| OLD | NEW |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 #include "vm/globals.h" // Needed here to get TARGET_ARCH_X64. | 5 #include "vm/globals.h" // Needed here to get TARGET_ARCH_X64. |
| 6 #if defined(TARGET_ARCH_X64) | 6 #if defined(TARGET_ARCH_X64) |
| 7 | 7 |
| 8 #include "vm/intermediate_language.h" | 8 #include "vm/intermediate_language.h" |
| 9 | 9 |
| 10 #include "vm/dart_entry.h" | 10 #include "vm/dart_entry.h" |
| (...skipping 3121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3132 switch (op_kind()) { | 3132 switch (op_kind()) { |
| 3133 case Token::kADD: __ addps(left, right); break; | 3133 case Token::kADD: __ addps(left, right); break; |
| 3134 case Token::kSUB: __ subps(left, right); break; | 3134 case Token::kSUB: __ subps(left, right); break; |
| 3135 case Token::kMUL: __ mulps(left, right); break; | 3135 case Token::kMUL: __ mulps(left, right); break; |
| 3136 case Token::kDIV: __ divps(left, right); break; | 3136 case Token::kDIV: __ divps(left, right); break; |
| 3137 default: UNREACHABLE(); | 3137 default: UNREACHABLE(); |
| 3138 } | 3138 } |
| 3139 } | 3139 } |
| 3140 | 3140 |
| 3141 | 3141 |
| 3142 LocationSummary* Float32x4ShuffleInstr::MakeLocationSummary() const { | 3142 LocationSummary* Simd32x4ShuffleInstr::MakeLocationSummary() const { |
| 3143 const intptr_t kNumInputs = 1; | 3143 const intptr_t kNumInputs = 1; |
| 3144 const intptr_t kNumTemps = 0; | 3144 const intptr_t kNumTemps = 0; |
| 3145 LocationSummary* summary = | 3145 LocationSummary* summary = |
| 3146 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); | 3146 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3147 summary->set_in(0, Location::RequiresFpuRegister()); | 3147 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3148 summary->set_out(Location::SameAsFirstInput()); | 3148 summary->set_out(Location::SameAsFirstInput()); |
| 3149 return summary; | 3149 return summary; |
| 3150 } | 3150 } |
| 3151 | 3151 |
| 3152 | 3152 |
| 3153 void Float32x4ShuffleInstr::EmitNativeCode(FlowGraphCompiler* compiler) { | 3153 void Simd32x4ShuffleInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3154 XmmRegister value = locs()->in(0).fpu_reg(); | 3154 XmmRegister value = locs()->in(0).fpu_reg(); |
| 3155 | 3155 |
| 3156 ASSERT(locs()->out().fpu_reg() == value); | 3156 ASSERT(locs()->out().fpu_reg() == value); |
| 3157 | 3157 |
| 3158 switch (op_kind()) { | 3158 switch (op_kind()) { |
| 3159 case MethodRecognizer::kFloat32x4ShuffleX: | 3159 case MethodRecognizer::kFloat32x4ShuffleX: |
| 3160 __ shufps(value, value, Immediate(0x00)); | 3160 __ shufps(value, value, Immediate(0x00)); |
| 3161 __ cvtss2sd(value, value); | 3161 __ cvtss2sd(value, value); |
| 3162 break; | 3162 break; |
| 3163 case MethodRecognizer::kFloat32x4ShuffleY: | 3163 case MethodRecognizer::kFloat32x4ShuffleY: |
| 3164 __ shufps(value, value, Immediate(0x55)); | 3164 __ shufps(value, value, Immediate(0x55)); |
| 3165 __ cvtss2sd(value, value); | 3165 __ cvtss2sd(value, value); |
| 3166 break; | 3166 break; |
| 3167 case MethodRecognizer::kFloat32x4ShuffleZ: | 3167 case MethodRecognizer::kFloat32x4ShuffleZ: |
| 3168 __ shufps(value, value, Immediate(0xAA)); | 3168 __ shufps(value, value, Immediate(0xAA)); |
| 3169 __ cvtss2sd(value, value); | 3169 __ cvtss2sd(value, value); |
| 3170 break; | 3170 break; |
| 3171 case MethodRecognizer::kFloat32x4ShuffleW: | 3171 case MethodRecognizer::kFloat32x4ShuffleW: |
| 3172 __ shufps(value, value, Immediate(0xFF)); | 3172 __ shufps(value, value, Immediate(0xFF)); |
| 3173 __ cvtss2sd(value, value); | 3173 __ cvtss2sd(value, value); |
| 3174 break; | 3174 break; |
| 3175 case MethodRecognizer::kFloat32x4Shuffle: | 3175 case MethodRecognizer::kFloat32x4Shuffle: |
| 3176 case MethodRecognizer::kUint32x4Shuffle: |
| 3176 __ shufps(value, value, Immediate(mask_)); | 3177 __ shufps(value, value, Immediate(mask_)); |
| 3177 break; | 3178 break; |
| 3178 default: UNREACHABLE(); | 3179 default: UNREACHABLE(); |
| 3179 } | 3180 } |
| 3180 } | 3181 } |
| 3181 | 3182 |
| 3182 | 3183 |
| 3184 LocationSummary* Simd32x4ShuffleMixInstr::MakeLocationSummary() const { |
| 3185 const intptr_t kNumInputs = 2; |
| 3186 const intptr_t kNumTemps = 0; |
| 3187 LocationSummary* summary = |
| 3188 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3189 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3190 summary->set_in(1, Location::RequiresFpuRegister()); |
| 3191 summary->set_out(Location::SameAsFirstInput()); |
| 3192 return summary; |
| 3193 } |
| 3194 |
| 3195 |
| 3196 void Simd32x4ShuffleMixInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3197 XmmRegister left = locs()->in(0).fpu_reg(); |
| 3198 XmmRegister right = locs()->in(1).fpu_reg(); |
| 3199 |
| 3200 ASSERT(locs()->out().fpu_reg() == left); |
| 3201 switch (op_kind()) { |
| 3202 case MethodRecognizer::kFloat32x4ShuffleMix: |
| 3203 case MethodRecognizer::kUint32x4ShuffleMix: |
| 3204 __ shufps(left, right, Immediate(mask_)); |
| 3205 break; |
| 3206 default: UNREACHABLE(); |
| 3207 } |
| 3208 } |
| 3209 |
| 3210 |
| 3183 LocationSummary* Simd32x4GetSignMaskInstr::MakeLocationSummary() const { | 3211 LocationSummary* Simd32x4GetSignMaskInstr::MakeLocationSummary() const { |
| 3184 const intptr_t kNumInputs = 1; | 3212 const intptr_t kNumInputs = 1; |
| 3185 const intptr_t kNumTemps = 0; | 3213 const intptr_t kNumTemps = 0; |
| 3186 LocationSummary* summary = | 3214 LocationSummary* summary = |
| 3187 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); | 3215 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3188 summary->set_in(0, Location::RequiresFpuRegister()); | 3216 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3189 summary->set_out(Location::RequiresRegister()); | 3217 summary->set_out(Location::RequiresRegister()); |
| 3190 return summary; | 3218 return summary; |
| 3191 } | 3219 } |
| 3192 | 3220 |
| (...skipping 341 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3534 summary->set_out(Location::SameAsFirstInput()); | 3562 summary->set_out(Location::SameAsFirstInput()); |
| 3535 return summary; | 3563 return summary; |
| 3536 } | 3564 } |
| 3537 | 3565 |
| 3538 | 3566 |
| 3539 void Float32x4ToUint32x4Instr::EmitNativeCode(FlowGraphCompiler* compiler) { | 3567 void Float32x4ToUint32x4Instr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3540 // NOP. | 3568 // NOP. |
| 3541 } | 3569 } |
| 3542 | 3570 |
| 3543 | 3571 |
| 3544 LocationSummary* Float32x4TwoArgShuffleInstr::MakeLocationSummary() const { | |
| 3545 const intptr_t kNumInputs = 2; | |
| 3546 const intptr_t kNumTemps = 0; | |
| 3547 LocationSummary* summary = | |
| 3548 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); | |
| 3549 summary->set_in(0, Location::RequiresFpuRegister()); | |
| 3550 summary->set_in(1, Location::RequiresFpuRegister()); | |
| 3551 summary->set_out(Location::SameAsFirstInput()); | |
| 3552 return summary; | |
| 3553 } | |
| 3554 | |
| 3555 | |
| 3556 void Float32x4TwoArgShuffleInstr::EmitNativeCode(FlowGraphCompiler* compiler) { | |
| 3557 XmmRegister left = locs()->in(0).fpu_reg(); | |
| 3558 XmmRegister right = locs()->in(1).fpu_reg(); | |
| 3559 | |
| 3560 ASSERT(locs()->out().fpu_reg() == left); | |
| 3561 | |
| 3562 switch (op_kind()) { | |
| 3563 case MethodRecognizer::kFloat32x4WithZWInXY: | |
| 3564 __ movhlps(left, right); | |
| 3565 break; | |
| 3566 case MethodRecognizer::kFloat32x4InterleaveXY: | |
| 3567 __ unpcklps(left, right); | |
| 3568 break; | |
| 3569 case MethodRecognizer::kFloat32x4InterleaveZW: | |
| 3570 __ unpckhps(left, right); | |
| 3571 break; | |
| 3572 case MethodRecognizer::kFloat32x4InterleaveXYPairs: | |
| 3573 __ unpcklpd(left, right); | |
| 3574 break; | |
| 3575 case MethodRecognizer::kFloat32x4InterleaveZWPairs: | |
| 3576 __ unpckhpd(left, right); | |
| 3577 break; | |
| 3578 default: UNREACHABLE(); | |
| 3579 } | |
| 3580 } | |
| 3581 | |
| 3582 | |
| 3583 LocationSummary* Uint32x4BoolConstructorInstr::MakeLocationSummary() const { | 3572 LocationSummary* Uint32x4BoolConstructorInstr::MakeLocationSummary() const { |
| 3584 const intptr_t kNumInputs = 4; | 3573 const intptr_t kNumInputs = 4; |
| 3585 const intptr_t kNumTemps = 1; | 3574 const intptr_t kNumTemps = 1; |
| 3586 LocationSummary* summary = | 3575 LocationSummary* summary = |
| 3587 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); | 3576 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3588 summary->set_in(0, Location::RequiresRegister()); | 3577 summary->set_in(0, Location::RequiresRegister()); |
| 3589 summary->set_in(1, Location::RequiresRegister()); | 3578 summary->set_in(1, Location::RequiresRegister()); |
| 3590 summary->set_in(2, Location::RequiresRegister()); | 3579 summary->set_in(2, Location::RequiresRegister()); |
| 3591 summary->set_in(3, Location::RequiresRegister()); | 3580 summary->set_in(3, Location::RequiresRegister()); |
| 3592 summary->set_temp(0, Location::RequiresRegister()); | 3581 summary->set_temp(0, Location::RequiresRegister()); |
| (...skipping 1213 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4806 PcDescriptors::kOther, | 4795 PcDescriptors::kOther, |
| 4807 locs()); | 4796 locs()); |
| 4808 __ Drop(2); // Discard type arguments and receiver. | 4797 __ Drop(2); // Discard type arguments and receiver. |
| 4809 } | 4798 } |
| 4810 | 4799 |
| 4811 } // namespace dart | 4800 } // namespace dart |
| 4812 | 4801 |
| 4813 #undef __ | 4802 #undef __ |
| 4814 | 4803 |
| 4815 #endif // defined TARGET_ARCH_X64 | 4804 #endif // defined TARGET_ARCH_X64 |
| OLD | NEW |