OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include <limits.h> // For LONG_MIN, LONG_MAX. | 5 #include <limits.h> // For LONG_MIN, LONG_MAX. |
6 | 6 |
7 #if V8_TARGET_ARCH_ARM | 7 #if V8_TARGET_ARCH_ARM |
8 | 8 |
9 #include "src/base/bits.h" | 9 #include "src/base/bits.h" |
10 #include "src/base/division-by-constant.h" | 10 #include "src/base/division-by-constant.h" |
(...skipping 1083 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1094 | 1094 |
1095 | 1095 |
1096 void MacroAssembler::VmovLow(DwVfpRegister dst, Register src) { | 1096 void MacroAssembler::VmovLow(DwVfpRegister dst, Register src) { |
1097 if (dst.code() < 16) { | 1097 if (dst.code() < 16) { |
1098 const LowDwVfpRegister loc = LowDwVfpRegister::from_code(dst.code()); | 1098 const LowDwVfpRegister loc = LowDwVfpRegister::from_code(dst.code()); |
1099 vmov(loc.low(), src); | 1099 vmov(loc.low(), src); |
1100 } else { | 1100 } else { |
1101 vmov(dst, VmovIndexLo, src); | 1101 vmov(dst, VmovIndexLo, src); |
1102 } | 1102 } |
1103 } | 1103 } |
1104 void MacroAssembler::PairLsl(Register dst_low, Register dst_high, | 1104 void MacroAssembler::LslPair(Register dst_low, Register dst_high, |
1105 Register src_low, Register src_high, | 1105 Register src_low, Register src_high, |
1106 Register scratch, Register shift) { | 1106 Register scratch, Register shift) { |
1107 DCHECK(!AreAliased(dst_low, src_high, shift)); | 1107 DCHECK(!AreAliased(dst_high, src_low)); |
1108 DCHECK(!AreAliased(dst_high, src_low, shift)); | 1108 DCHECK(!AreAliased(dst_high, shift)); |
1109 | |
1109 Label less_than_32; | 1110 Label less_than_32; |
1110 Label done; | 1111 Label done; |
1111 cmp_raw_immediate(shift, 32); | 1112 cmp_raw_immediate(shift, 32); |
1112 b(lt, &less_than_32); | 1113 b(lt, &less_than_32); |
1113 // If shift >= 32 | 1114 // If shift >= 32 |
1114 and_(scratch, shift, Operand(0x1f)); | 1115 and_(scratch, shift, Operand(0x1f)); |
1115 lsl(dst_high, src_low, Operand(scratch)); | 1116 lsl(dst_high, src_low, Operand(scratch)); |
1116 mov(dst_low, Operand(0)); | 1117 mov(dst_low, Operand(0)); |
1117 jmp(&done); | 1118 jmp(&done); |
1118 bind(&less_than_32); | 1119 bind(&less_than_32); |
1119 // If shift < 32 | 1120 // If shift < 32 |
1120 rsb(scratch, shift, Operand(32)); | 1121 rsb(scratch, shift, Operand(32)); |
1121 lsl(dst_high, src_high, Operand(shift)); | 1122 lsl(dst_high, src_high, Operand(shift)); |
1122 orr(dst_high, dst_high, Operand(src_low, LSR, scratch)); | 1123 orr(dst_high, dst_high, Operand(src_low, LSR, scratch)); |
1123 lsl(dst_low, src_low, Operand(shift)); | 1124 lsl(dst_low, src_low, Operand(shift)); |
1124 bind(&done); | 1125 bind(&done); |
1125 } | 1126 } |
1126 | 1127 |
1127 void MacroAssembler::PairLsl(Register dst_low, Register dst_high, | 1128 void MacroAssembler::LslPair(Register dst_low, Register dst_high, |
1128 Register src_low, Register src_high, | 1129 Register src_low, Register src_high, |
1129 uint32_t shift) { | 1130 uint32_t shift) { |
1130 DCHECK(!AreAliased(dst_low, src_high)); | |
1131 DCHECK(!AreAliased(dst_high, src_low)); | 1131 DCHECK(!AreAliased(dst_high, src_low)); |
1132 Label less_than_32; | 1132 Label less_than_32; |
1133 Label done; | 1133 Label done; |
1134 if (shift >= 32) { | 1134 if (shift >= 32) { |
titzer
2016/03/10 10:51:08
Do you want to handle the == 32 case specially too
| |
1135 shift &= 0x1f; | 1135 shift &= 0x1f; |
1136 lsl(dst_high, src_low, Operand(shift)); | 1136 lsl(dst_high, src_low, Operand(shift)); |
1137 mov(dst_low, Operand(0)); | 1137 mov(dst_low, Operand(0)); |
1138 } else if (shift == 0) { | 1138 } else if (shift == 0) { |
1139 Move(dst_high, src_high); | |
1139 Move(dst_low, src_low); | 1140 Move(dst_low, src_low); |
1140 Move(dst_high, src_high); | |
1141 } else { | 1141 } else { |
1142 lsl(dst_high, src_high, Operand(shift)); | 1142 lsl(dst_high, src_high, Operand(shift)); |
1143 orr(dst_high, dst_high, Operand(src_low, LSR, 32 - shift)); | 1143 orr(dst_high, dst_high, Operand(src_low, LSR, 32 - shift)); |
1144 lsl(dst_low, src_low, Operand(shift)); | 1144 lsl(dst_low, src_low, Operand(shift)); |
1145 } | 1145 } |
1146 } | 1146 } |
1147 | 1147 |
1148 void MacroAssembler::LoadConstantPoolPointerRegisterFromCodeTargetAddress( | 1148 void MacroAssembler::LoadConstantPoolPointerRegisterFromCodeTargetAddress( |
1149 Register code_target_address) { | 1149 Register code_target_address) { |
1150 DCHECK(FLAG_enable_embedded_constant_pool); | 1150 DCHECK(FLAG_enable_embedded_constant_pool); |
(...skipping 2685 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
3836 } | 3836 } |
3837 } | 3837 } |
3838 if (mag.shift > 0) mov(result, Operand(result, ASR, mag.shift)); | 3838 if (mag.shift > 0) mov(result, Operand(result, ASR, mag.shift)); |
3839 add(result, result, Operand(dividend, LSR, 31)); | 3839 add(result, result, Operand(dividend, LSR, 31)); |
3840 } | 3840 } |
3841 | 3841 |
3842 } // namespace internal | 3842 } // namespace internal |
3843 } // namespace v8 | 3843 } // namespace v8 |
3844 | 3844 |
3845 #endif // V8_TARGET_ARCH_ARM | 3845 #endif // V8_TARGET_ARCH_ARM |
OLD | NEW |