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 3252 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3263 switch (op_kind()) { | 3263 switch (op_kind()) { |
3264 case Token::kADD: __ addps(left, right); break; | 3264 case Token::kADD: __ addps(left, right); break; |
3265 case Token::kSUB: __ subps(left, right); break; | 3265 case Token::kSUB: __ subps(left, right); break; |
3266 case Token::kMUL: __ mulps(left, right); break; | 3266 case Token::kMUL: __ mulps(left, right); break; |
3267 case Token::kDIV: __ divps(left, right); break; | 3267 case Token::kDIV: __ divps(left, right); break; |
3268 default: UNREACHABLE(); | 3268 default: UNREACHABLE(); |
3269 } | 3269 } |
3270 } | 3270 } |
3271 | 3271 |
3272 | 3272 |
| 3273 LocationSummary* BinaryFloat64x2OpInstr::MakeLocationSummary(bool opt) const { |
| 3274 const intptr_t kNumInputs = 2; |
| 3275 const intptr_t kNumTemps = 0; |
| 3276 LocationSummary* summary = |
| 3277 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3278 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3279 summary->set_in(1, Location::RequiresFpuRegister()); |
| 3280 summary->set_out(Location::SameAsFirstInput()); |
| 3281 return summary; |
| 3282 } |
| 3283 |
| 3284 |
| 3285 void BinaryFloat64x2OpInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3286 XmmRegister left = locs()->in(0).fpu_reg(); |
| 3287 XmmRegister right = locs()->in(1).fpu_reg(); |
| 3288 |
| 3289 ASSERT(locs()->out().fpu_reg() == left); |
| 3290 |
| 3291 switch (op_kind()) { |
| 3292 case Token::kADD: __ addpd(left, right); break; |
| 3293 case Token::kSUB: __ subpd(left, right); break; |
| 3294 case Token::kMUL: __ mulpd(left, right); break; |
| 3295 case Token::kDIV: __ divpd(left, right); break; |
| 3296 default: UNREACHABLE(); |
| 3297 } |
| 3298 } |
| 3299 |
| 3300 |
3273 LocationSummary* Simd32x4ShuffleInstr::MakeLocationSummary(bool opt) const { | 3301 LocationSummary* Simd32x4ShuffleInstr::MakeLocationSummary(bool opt) const { |
3274 const intptr_t kNumInputs = 1; | 3302 const intptr_t kNumInputs = 1; |
3275 const intptr_t kNumTemps = 0; | 3303 const intptr_t kNumTemps = 0; |
3276 LocationSummary* summary = | 3304 LocationSummary* summary = |
3277 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); | 3305 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
3278 summary->set_in(0, Location::RequiresFpuRegister()); | 3306 summary->set_in(0, Location::RequiresFpuRegister()); |
3279 summary->set_out(Location::SameAsFirstInput()); | 3307 summary->set_out(Location::SameAsFirstInput()); |
3280 return summary; | 3308 return summary; |
3281 } | 3309 } |
3282 | 3310 |
(...skipping 411 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3694 summary->set_out(Location::SameAsFirstInput()); | 3722 summary->set_out(Location::SameAsFirstInput()); |
3695 return summary; | 3723 return summary; |
3696 } | 3724 } |
3697 | 3725 |
3698 | 3726 |
3699 void Float32x4ToInt32x4Instr::EmitNativeCode(FlowGraphCompiler* compiler) { | 3727 void Float32x4ToInt32x4Instr::EmitNativeCode(FlowGraphCompiler* compiler) { |
3700 // NOP. | 3728 // NOP. |
3701 } | 3729 } |
3702 | 3730 |
3703 | 3731 |
| 3732 LocationSummary* Simd64x2ShuffleInstr::MakeLocationSummary(bool opt) const { |
| 3733 const intptr_t kNumInputs = 1; |
| 3734 const intptr_t kNumTemps = 0; |
| 3735 LocationSummary* summary = |
| 3736 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3737 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3738 summary->set_out(Location::SameAsFirstInput()); |
| 3739 return summary; |
| 3740 } |
| 3741 |
| 3742 |
| 3743 void Simd64x2ShuffleInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3744 XmmRegister value = locs()->in(0).fpu_reg(); |
| 3745 |
| 3746 ASSERT(locs()->out().fpu_reg() == value); |
| 3747 switch (op_kind()) { |
| 3748 case MethodRecognizer::kFloat64x2GetX: |
| 3749 __ shufpd(value, value, Immediate(0x00)); |
| 3750 break; |
| 3751 case MethodRecognizer::kFloat64x2GetY: |
| 3752 __ shufpd(value, value, Immediate(0x33)); |
| 3753 break; |
| 3754 default: UNREACHABLE(); |
| 3755 } |
| 3756 } |
| 3757 |
| 3758 |
| 3759 LocationSummary* Float64x2ZeroInstr::MakeLocationSummary(bool opt) const { |
| 3760 const intptr_t kNumInputs = 0; |
| 3761 const intptr_t kNumTemps = 0; |
| 3762 LocationSummary* summary = |
| 3763 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3764 summary->set_out(Location::RequiresFpuRegister()); |
| 3765 return summary; |
| 3766 } |
| 3767 |
| 3768 |
| 3769 void Float64x2ZeroInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3770 XmmRegister value = locs()->out().fpu_reg(); |
| 3771 __ xorpd(value, value); |
| 3772 } |
| 3773 |
| 3774 |
| 3775 LocationSummary* Float64x2SplatInstr::MakeLocationSummary(bool opt) const { |
| 3776 const intptr_t kNumInputs = 1; |
| 3777 const intptr_t kNumTemps = 0; |
| 3778 LocationSummary* summary = |
| 3779 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3780 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3781 summary->set_out(Location::SameAsFirstInput()); |
| 3782 return summary; |
| 3783 } |
| 3784 |
| 3785 |
| 3786 void Float64x2SplatInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3787 XmmRegister value = locs()->out().fpu_reg(); |
| 3788 __ shufpd(value, value, Immediate(0x0)); |
| 3789 } |
| 3790 |
| 3791 |
| 3792 LocationSummary* Float64x2ConstructorInstr::MakeLocationSummary( |
| 3793 bool opt) const { |
| 3794 const intptr_t kNumInputs = 2; |
| 3795 const intptr_t kNumTemps = 0; |
| 3796 LocationSummary* summary = |
| 3797 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3798 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3799 summary->set_in(1, Location::RequiresFpuRegister()); |
| 3800 summary->set_out(Location::SameAsFirstInput()); |
| 3801 return summary; |
| 3802 } |
| 3803 |
| 3804 |
| 3805 void Float64x2ConstructorInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3806 XmmRegister v0 = locs()->in(0).fpu_reg(); |
| 3807 XmmRegister v1 = locs()->in(1).fpu_reg(); |
| 3808 ASSERT(v0 == locs()->out().fpu_reg()); |
| 3809 __ AddImmediate(RSP, Immediate(-16), PP); |
| 3810 __ movsd(Address(RSP, 0), v0); |
| 3811 __ movsd(Address(RSP, 8), v1); |
| 3812 __ movups(v0, Address(RSP, 0)); |
| 3813 __ AddImmediate(RSP, Immediate(16), PP); |
| 3814 } |
| 3815 |
| 3816 |
| 3817 LocationSummary* Float64x2ToFloat32x4Instr::MakeLocationSummary( |
| 3818 bool opt) const { |
| 3819 const intptr_t kNumInputs = 1; |
| 3820 const intptr_t kNumTemps = 0; |
| 3821 LocationSummary* summary = |
| 3822 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3823 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3824 summary->set_out(Location::SameAsFirstInput()); |
| 3825 return summary; |
| 3826 } |
| 3827 |
| 3828 |
| 3829 void Float64x2ToFloat32x4Instr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3830 XmmRegister value = locs()->out().fpu_reg(); |
| 3831 __ cvtpd2ps(value, value); |
| 3832 } |
| 3833 |
| 3834 |
| 3835 LocationSummary* Float32x4ToFloat64x2Instr::MakeLocationSummary( |
| 3836 bool opt) const { |
| 3837 const intptr_t kNumInputs = 1; |
| 3838 const intptr_t kNumTemps = 0; |
| 3839 LocationSummary* summary = |
| 3840 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 3841 summary->set_in(0, Location::RequiresFpuRegister()); |
| 3842 summary->set_out(Location::SameAsFirstInput()); |
| 3843 return summary; |
| 3844 } |
| 3845 |
| 3846 |
| 3847 void Float32x4ToFloat64x2Instr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 3848 XmmRegister value = locs()->out().fpu_reg(); |
| 3849 __ cvtps2pd(value, value); |
| 3850 } |
| 3851 |
| 3852 |
3704 LocationSummary* Int32x4BoolConstructorInstr::MakeLocationSummary( | 3853 LocationSummary* Int32x4BoolConstructorInstr::MakeLocationSummary( |
3705 bool opt) const { | 3854 bool opt) const { |
3706 const intptr_t kNumInputs = 4; | 3855 const intptr_t kNumInputs = 4; |
3707 const intptr_t kNumTemps = 1; | 3856 const intptr_t kNumTemps = 1; |
3708 LocationSummary* summary = | 3857 LocationSummary* summary = |
3709 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); | 3858 new LocationSummary(kNumInputs, kNumTemps, LocationSummary::kNoCall); |
3710 summary->set_in(0, Location::RequiresRegister()); | 3859 summary->set_in(0, Location::RequiresRegister()); |
3711 summary->set_in(1, Location::RequiresRegister()); | 3860 summary->set_in(1, Location::RequiresRegister()); |
3712 summary->set_in(2, Location::RequiresRegister()); | 3861 summary->set_in(2, Location::RequiresRegister()); |
3713 summary->set_in(3, Location::RequiresRegister()); | 3862 summary->set_in(3, Location::RequiresRegister()); |
(...skipping 1375 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5089 PcDescriptors::kOther, | 5238 PcDescriptors::kOther, |
5090 locs()); | 5239 locs()); |
5091 __ Drop(ArgumentCount()); // Discard arguments. | 5240 __ Drop(ArgumentCount()); // Discard arguments. |
5092 } | 5241 } |
5093 | 5242 |
5094 } // namespace dart | 5243 } // namespace dart |
5095 | 5244 |
5096 #undef __ | 5245 #undef __ |
5097 | 5246 |
5098 #endif // defined TARGET_ARCH_X64 | 5247 #endif // defined TARGET_ARCH_X64 |
OLD | NEW |