| 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_ARM. | 5 #include "vm/globals.h" // Needed here to get TARGET_ARCH_ARM. |
| 6 #if defined(TARGET_ARCH_ARM) | 6 #if defined(TARGET_ARCH_ARM) |
| 7 | 7 |
| 8 #include "vm/intermediate_language.h" | 8 #include "vm/intermediate_language.h" |
| 9 | 9 |
| 10 #include "vm/compiler.h" | 10 #include "vm/compiler.h" |
| (...skipping 5248 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5259 case Token::kBIT_XOR: __ veorq(result, left, right); break; | 5259 case Token::kBIT_XOR: __ veorq(result, left, right); break; |
| 5260 case Token::kADD: __ vaddqi(kWord, result, left, right); break; | 5260 case Token::kADD: __ vaddqi(kWord, result, left, right); break; |
| 5261 case Token::kSUB: __ vsubqi(kWord, result, left, right); break; | 5261 case Token::kSUB: __ vsubqi(kWord, result, left, right); break; |
| 5262 default: UNREACHABLE(); | 5262 default: UNREACHABLE(); |
| 5263 } | 5263 } |
| 5264 } | 5264 } |
| 5265 | 5265 |
| 5266 | 5266 |
| 5267 LocationSummary* MathUnaryInstr::MakeLocationSummary(Zone* zone, | 5267 LocationSummary* MathUnaryInstr::MakeLocationSummary(Zone* zone, |
| 5268 bool opt) const { | 5268 bool opt) const { |
| 5269 if ((kind() == MathUnaryInstr::kSin) || (kind() == MathUnaryInstr::kCos)) { | |
| 5270 const intptr_t kNumInputs = 1; | |
| 5271 const intptr_t kNumTemps = TargetCPUFeatures::hardfp_supported() ? 0 : 4; | |
| 5272 LocationSummary* summary = new(zone) LocationSummary( | |
| 5273 zone, kNumInputs, kNumTemps, LocationSummary::kCall); | |
| 5274 summary->set_in(0, Location::FpuRegisterLocation(Q0)); | |
| 5275 summary->set_out(0, Location::FpuRegisterLocation(Q0)); | |
| 5276 if (!TargetCPUFeatures::hardfp_supported()) { | |
| 5277 summary->set_temp(0, Location::RegisterLocation(R0)); | |
| 5278 summary->set_temp(1, Location::RegisterLocation(R1)); | |
| 5279 summary->set_temp(2, Location::RegisterLocation(R2)); | |
| 5280 summary->set_temp(3, Location::RegisterLocation(R3)); | |
| 5281 } | |
| 5282 return summary; | |
| 5283 } | |
| 5284 ASSERT((kind() == MathUnaryInstr::kSqrt) || | 5269 ASSERT((kind() == MathUnaryInstr::kSqrt) || |
| 5285 (kind() == MathUnaryInstr::kDoubleSquare)); | 5270 (kind() == MathUnaryInstr::kDoubleSquare)); |
| 5286 const intptr_t kNumInputs = 1; | 5271 const intptr_t kNumInputs = 1; |
| 5287 const intptr_t kNumTemps = 0; | 5272 const intptr_t kNumTemps = 0; |
| 5288 LocationSummary* summary = new(zone) LocationSummary( | 5273 LocationSummary* summary = new(zone) LocationSummary( |
| 5289 zone, kNumInputs, kNumTemps, LocationSummary::kNoCall); | 5274 zone, kNumInputs, kNumTemps, LocationSummary::kNoCall); |
| 5290 summary->set_in(0, Location::RequiresFpuRegister()); | 5275 summary->set_in(0, Location::RequiresFpuRegister()); |
| 5291 summary->set_out(0, Location::RequiresFpuRegister()); | 5276 summary->set_out(0, Location::RequiresFpuRegister()); |
| 5292 return summary; | 5277 return summary; |
| 5293 } | 5278 } |
| 5294 | 5279 |
| 5295 | 5280 |
| 5296 void MathUnaryInstr::EmitNativeCode(FlowGraphCompiler* compiler) { | 5281 void MathUnaryInstr::EmitNativeCode(FlowGraphCompiler* compiler) { |
| 5297 if (kind() == MathUnaryInstr::kSqrt) { | 5282 if (kind() == MathUnaryInstr::kSqrt) { |
| 5298 const DRegister val = EvenDRegisterOf(locs()->in(0).fpu_reg()); | 5283 const DRegister val = EvenDRegisterOf(locs()->in(0).fpu_reg()); |
| 5299 const DRegister result = EvenDRegisterOf(locs()->out(0).fpu_reg()); | 5284 const DRegister result = EvenDRegisterOf(locs()->out(0).fpu_reg()); |
| 5300 __ vsqrtd(result, val); | 5285 __ vsqrtd(result, val); |
| 5301 } else if (kind() == MathUnaryInstr::kDoubleSquare) { | 5286 } else if (kind() == MathUnaryInstr::kDoubleSquare) { |
| 5302 const DRegister val = EvenDRegisterOf(locs()->in(0).fpu_reg()); | 5287 const DRegister val = EvenDRegisterOf(locs()->in(0).fpu_reg()); |
| 5303 const DRegister result = EvenDRegisterOf(locs()->out(0).fpu_reg()); | 5288 const DRegister result = EvenDRegisterOf(locs()->out(0).fpu_reg()); |
| 5304 __ vmuld(result, val, val); | 5289 __ vmuld(result, val, val); |
| 5305 } else { | 5290 } else { |
| 5306 ASSERT((kind() == MathUnaryInstr::kSin) || | 5291 UNREACHABLE(); |
| 5307 (kind() == MathUnaryInstr::kCos)); | |
| 5308 if (TargetCPUFeatures::hardfp_supported()) { | |
| 5309 __ CallRuntime(TargetFunction(), InputCount()); | |
| 5310 } else { | |
| 5311 // If we aren't doing "hardfp", then we have to move the double arguments | |
| 5312 // to the integer registers, and take the results from the integer | |
| 5313 // registers. | |
| 5314 __ vmovrrd(R0, R1, D0); | |
| 5315 __ vmovrrd(R2, R3, D1); | |
| 5316 __ CallRuntime(TargetFunction(), InputCount()); | |
| 5317 __ vmovdrr(D0, R0, R1); | |
| 5318 __ vmovdrr(D1, R2, R3); | |
| 5319 } | |
| 5320 } | 5292 } |
| 5321 } | 5293 } |
| 5322 | 5294 |
| 5323 | 5295 |
| 5324 LocationSummary* CaseInsensitiveCompareUC16Instr::MakeLocationSummary( | 5296 LocationSummary* CaseInsensitiveCompareUC16Instr::MakeLocationSummary( |
| 5325 Zone* zone, bool opt) const { | 5297 Zone* zone, bool opt) const { |
| 5326 const intptr_t kNumTemps = 0; | 5298 const intptr_t kNumTemps = 0; |
| 5327 LocationSummary* summary = new(zone) LocationSummary( | 5299 LocationSummary* summary = new(zone) LocationSummary( |
| 5328 zone, InputCount(), kNumTemps, LocationSummary::kCall); | 5300 zone, InputCount(), kNumTemps, LocationSummary::kCall); |
| 5329 summary->set_in(0, Location::RegisterLocation(R0)); | 5301 summary->set_in(0, Location::RegisterLocation(R0)); |
| (...skipping 1683 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 7013 1, | 6985 1, |
| 7014 locs()); | 6986 locs()); |
| 7015 __ Drop(1); | 6987 __ Drop(1); |
| 7016 __ Pop(result); | 6988 __ Pop(result); |
| 7017 } | 6989 } |
| 7018 | 6990 |
| 7019 | 6991 |
| 7020 } // namespace dart | 6992 } // namespace dart |
| 7021 | 6993 |
| 7022 #endif // defined TARGET_ARCH_ARM | 6994 #endif // defined TARGET_ARCH_ARM |
| OLD | NEW |