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 "src/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #if V8_TARGET_ARCH_X64 | 7 #if V8_TARGET_ARCH_X64 |
8 | 8 |
9 #include "src/base/bits.h" | 9 #include "src/base/bits.h" |
10 #include "src/macro-assembler.h" | 10 #include "src/macro-assembler.h" |
(...skipping 3164 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3175 void Assembler::pcmpeqd(XMMRegister dst, XMMRegister src) { | 3175 void Assembler::pcmpeqd(XMMRegister dst, XMMRegister src) { |
3176 EnsureSpace ensure_space(this); | 3176 EnsureSpace ensure_space(this); |
3177 emit(0x66); | 3177 emit(0x66); |
3178 emit_optional_rex_32(dst, src); | 3178 emit_optional_rex_32(dst, src); |
3179 emit(0x0F); | 3179 emit(0x0F); |
3180 emit(0x76); | 3180 emit(0x76); |
3181 emit_sse_operand(dst, src); | 3181 emit_sse_operand(dst, src); |
3182 } | 3182 } |
3183 | 3183 |
3184 | 3184 |
3185 // byte 1 of 3-byte VEX | 3185 // AVX instructions |
3186 void Assembler::emit_vex3_byte1(XMMRegister reg, XMMRegister rm, byte m) { | |
3187 DCHECK(1 <= m && m <= 3); | |
3188 byte rxb = ~((reg.high_bit() << 2) | rm.high_bit()) << 5; | |
3189 emit(rxb | m); | |
3190 } | |
3191 | |
3192 | |
3193 // byte 1 of 3-byte VEX | |
3194 void Assembler::emit_vex3_byte1(XMMRegister reg, const Operand& rm, byte m) { | |
3195 DCHECK(1 <= m && m <= 3); | |
3196 byte rxb = ~((reg.high_bit() << 2) | rm.rex_) << 5; | |
3197 emit(rxb | m); | |
3198 } | |
3199 | |
3200 | |
3201 // byte 1 of 2-byte VEX | |
3202 void Assembler::emit_vex2_byte1(XMMRegister reg, XMMRegister v, byte lpp) { | |
3203 DCHECK(lpp <= 3); | |
3204 byte rv = ~((reg.high_bit() << 4) | v.code()) << 3; | |
3205 emit(rv | lpp); | |
3206 } | |
3207 | |
3208 | |
3209 // byte 2 of 3-byte VEX | |
3210 void Assembler::emit_vex3_byte2(byte w, XMMRegister v, byte lpp) { | |
3211 DCHECK(w <= 1); | |
3212 DCHECK(lpp <= 3); | |
3213 emit((w << 7) | ((~v.code() & 0xf) << 3) | lpp); | |
3214 } | |
3215 | |
3216 | |
3217 void Assembler::vfmasd(byte op, XMMRegister dst, XMMRegister src1, | 3186 void Assembler::vfmasd(byte op, XMMRegister dst, XMMRegister src1, |
3218 XMMRegister src2) { | 3187 XMMRegister src2) { |
3219 DCHECK(IsEnabled(FMA3)); | 3188 DCHECK(IsEnabled(FMA3)); |
3220 EnsureSpace ensure_space(this); | 3189 EnsureSpace ensure_space(this); |
3221 emit_vex3_byte0(); | 3190 emit_vex_prefix(dst, src1, src2, kLIG, k66, k0F38, kW1); |
3222 emit_vex3_byte1(dst, src2, 0x02); | |
3223 emit_vex3_byte2(0x1, src1, 0x01); | |
3224 emit(op); | 3191 emit(op); |
3225 emit_sse_operand(dst, src2); | 3192 emit_sse_operand(dst, src2); |
3226 } | 3193 } |
3227 | 3194 |
3228 | 3195 |
3229 void Assembler::vfmasd(byte op, XMMRegister dst, XMMRegister src1, | 3196 void Assembler::vfmasd(byte op, XMMRegister dst, XMMRegister src1, |
3230 const Operand& src2) { | 3197 const Operand& src2) { |
3231 DCHECK(IsEnabled(FMA3)); | 3198 DCHECK(IsEnabled(FMA3)); |
3232 EnsureSpace ensure_space(this); | 3199 EnsureSpace ensure_space(this); |
3233 emit_vex3_byte0(); | 3200 emit_vex_prefix(dst, src1, src2, kLIG, k66, k0F38, kW1); |
3234 emit_vex3_byte1(dst, src2, 0x02); | |
3235 emit_vex3_byte2(0x1, src1, 0x01); | |
3236 emit(op); | 3201 emit(op); |
3237 emit_sse_operand(dst, src2); | 3202 emit_sse_operand(dst, src2); |
3238 } | 3203 } |
3239 | 3204 |
3240 | 3205 |
3241 void Assembler::vfmass(byte op, XMMRegister dst, XMMRegister src1, | 3206 void Assembler::vfmass(byte op, XMMRegister dst, XMMRegister src1, |
3242 XMMRegister src2) { | 3207 XMMRegister src2) { |
3243 DCHECK(IsEnabled(FMA3)); | 3208 DCHECK(IsEnabled(FMA3)); |
3244 EnsureSpace ensure_space(this); | 3209 EnsureSpace ensure_space(this); |
3245 emit_vex3_byte0(); | 3210 emit_vex_prefix(dst, src1, src2, kLIG, k66, k0F38, kW0); |
3246 emit_vex3_byte1(dst, src2, 0x02); | |
3247 emit_vex3_byte2(0x0, src1, 0x01); | |
3248 emit(op); | 3211 emit(op); |
3249 emit_sse_operand(dst, src2); | 3212 emit_sse_operand(dst, src2); |
3250 } | 3213 } |
3251 | 3214 |
3252 | 3215 |
3253 void Assembler::vfmass(byte op, XMMRegister dst, XMMRegister src1, | 3216 void Assembler::vfmass(byte op, XMMRegister dst, XMMRegister src1, |
3254 const Operand& src2) { | 3217 const Operand& src2) { |
3255 DCHECK(IsEnabled(FMA3)); | 3218 DCHECK(IsEnabled(FMA3)); |
3256 EnsureSpace ensure_space(this); | 3219 EnsureSpace ensure_space(this); |
3257 emit_vex3_byte0(); | 3220 emit_vex_prefix(dst, src1, src2, kLIG, k66, k0F38, kW0); |
3258 emit_vex3_byte1(dst, src2, 0x02); | |
3259 emit_vex3_byte2(0x0, src1, 0x01); | |
3260 emit(op); | 3221 emit(op); |
3261 emit_sse_operand(dst, src2); | 3222 emit_sse_operand(dst, src2); |
3262 } | 3223 } |
| 3224 |
| 3225 |
| 3226 void Assembler::vsd(byte op, XMMRegister dst, XMMRegister src1, |
| 3227 XMMRegister src2) { |
| 3228 DCHECK(IsEnabled(AVX)); |
| 3229 EnsureSpace ensure_space(this); |
| 3230 emit_vex_prefix(dst, src1, src2, kLIG, kF2, k0F, kWIG); |
| 3231 emit(op); |
| 3232 emit_sse_operand(dst, src2); |
| 3233 } |
| 3234 |
| 3235 |
| 3236 void Assembler::vsd(byte op, XMMRegister dst, XMMRegister src1, |
| 3237 const Operand& src2) { |
| 3238 DCHECK(IsEnabled(AVX)); |
| 3239 EnsureSpace ensure_space(this); |
| 3240 emit_vex_prefix(dst, src1, src2, kLIG, kF2, k0F, kWIG); |
| 3241 emit(op); |
| 3242 emit_sse_operand(dst, src2); |
| 3243 } |
3263 | 3244 |
3264 | 3245 |
3265 void Assembler::emit_sse_operand(XMMRegister reg, const Operand& adr) { | 3246 void Assembler::emit_sse_operand(XMMRegister reg, const Operand& adr) { |
3266 Register ireg = { reg.code() }; | 3247 Register ireg = { reg.code() }; |
3267 emit_operand(ireg, adr); | 3248 emit_operand(ireg, adr); |
3268 } | 3249 } |
3269 | 3250 |
3270 | 3251 |
3271 void Assembler::emit_sse_operand(Register reg, const Operand& adr) { | 3252 void Assembler::emit_sse_operand(Register reg, const Operand& adr) { |
3272 Register ireg = {reg.code()}; | 3253 Register ireg = {reg.code()}; |
(...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3369 | 3350 |
3370 | 3351 |
3371 bool RelocInfo::IsInConstantPool() { | 3352 bool RelocInfo::IsInConstantPool() { |
3372 return false; | 3353 return false; |
3373 } | 3354 } |
3374 | 3355 |
3375 | 3356 |
3376 } } // namespace v8::internal | 3357 } } // namespace v8::internal |
3377 | 3358 |
3378 #endif // V8_TARGET_ARCH_X64 | 3359 #endif // V8_TARGET_ARCH_X64 |
OLD | NEW |