OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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/compiler/code-generator.h" | 5 #include "src/compiler/code-generator.h" |
6 | 6 |
7 #include "src/arm/macro-assembler-arm.h" | 7 #include "src/arm/macro-assembler-arm.h" |
8 #include "src/assembler-inl.h" | 8 #include "src/assembler-inl.h" |
9 #include "src/compilation-info.h" | 9 #include "src/compilation-info.h" |
10 #include "src/compiler/code-generator-impl.h" | 10 #include "src/compiler/code-generator-impl.h" |
(...skipping 1426 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1437 case kArmVldrF32: { | 1437 case kArmVldrF32: { |
1438 __ vldr(i.OutputFloatRegister(), i.InputOffset()); | 1438 __ vldr(i.OutputFloatRegister(), i.InputOffset()); |
1439 DCHECK_EQ(LeaveCC, i.OutputSBit()); | 1439 DCHECK_EQ(LeaveCC, i.OutputSBit()); |
1440 break; | 1440 break; |
1441 } | 1441 } |
1442 case kArmVstrF32: | 1442 case kArmVstrF32: |
1443 __ vstr(i.InputFloatRegister(0), i.InputOffset(1)); | 1443 __ vstr(i.InputFloatRegister(0), i.InputOffset(1)); |
1444 DCHECK_EQ(LeaveCC, i.OutputSBit()); | 1444 DCHECK_EQ(LeaveCC, i.OutputSBit()); |
1445 break; | 1445 break; |
1446 case kArmVld1F64: { | 1446 case kArmVld1F64: { |
1447 __ vld1(NeonSize::Neon8, NeonListOperand(i.OutputDoubleRegister()), | 1447 __ vld1(Neon8, NeonListOperand(i.OutputDoubleRegister()), |
1448 NeonMemOperand(i.InputRegister(0))); | 1448 NeonMemOperand(i.InputRegister(0))); |
1449 break; | 1449 break; |
1450 } | 1450 } |
1451 case kArmVst1F64: { | 1451 case kArmVst1F64: { |
1452 __ vst1(Neon8, NeonListOperand(i.InputDoubleRegister(0)), | 1452 __ vst1(Neon8, NeonListOperand(i.InputDoubleRegister(0)), |
1453 NeonMemOperand(i.InputRegister(1))); | 1453 NeonMemOperand(i.InputRegister(1))); |
1454 break; | 1454 break; |
1455 } | 1455 } |
| 1456 case kArmVld1S128: { |
| 1457 __ vld1(Neon8, NeonListOperand(i.OutputSimd128Register()), |
| 1458 NeonMemOperand(i.InputRegister(0))); |
| 1459 break; |
| 1460 } |
| 1461 case kArmVst1S128: { |
| 1462 __ vst1(Neon8, NeonListOperand(i.InputSimd128Register(0)), |
| 1463 NeonMemOperand(i.InputRegister(1))); |
| 1464 break; |
| 1465 } |
1456 case kArmVldrF64: | 1466 case kArmVldrF64: |
1457 __ vldr(i.OutputDoubleRegister(), i.InputOffset()); | 1467 __ vldr(i.OutputDoubleRegister(), i.InputOffset()); |
1458 DCHECK_EQ(LeaveCC, i.OutputSBit()); | 1468 DCHECK_EQ(LeaveCC, i.OutputSBit()); |
1459 break; | 1469 break; |
1460 case kArmVstrF64: | 1470 case kArmVstrF64: |
1461 __ vstr(i.InputDoubleRegister(0), i.InputOffset(1)); | 1471 __ vstr(i.InputDoubleRegister(0), i.InputOffset(1)); |
1462 DCHECK_EQ(LeaveCC, i.OutputSBit()); | 1472 DCHECK_EQ(LeaveCC, i.OutputSBit()); |
1463 break; | 1473 break; |
1464 case kArmFloat32Max: { | 1474 case kArmFloat32Max: { |
1465 SwVfpRegister result = i.OutputFloatRegister(); | 1475 SwVfpRegister result = i.OutputFloatRegister(); |
(...skipping 519 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1985 case kArmUint8x16LessThanOrEqual: { | 1995 case kArmUint8x16LessThanOrEqual: { |
1986 __ vcge(NeonU8, i.OutputSimd128Register(), i.InputSimd128Register(1), | 1996 __ vcge(NeonU8, i.OutputSimd128Register(), i.InputSimd128Register(1), |
1987 i.InputSimd128Register(0)); | 1997 i.InputSimd128Register(0)); |
1988 break; | 1998 break; |
1989 } | 1999 } |
1990 case kArmSimd128Zero: { | 2000 case kArmSimd128Zero: { |
1991 __ veor(i.OutputSimd128Register(), i.OutputSimd128Register(), | 2001 __ veor(i.OutputSimd128Register(), i.OutputSimd128Register(), |
1992 i.OutputSimd128Register()); | 2002 i.OutputSimd128Register()); |
1993 break; | 2003 break; |
1994 } | 2004 } |
1995 case kArmSimd128Load: { | |
1996 MemOperand src = i.InputOffset(); | |
1997 __ vld1(Neon8, NeonListOperand(i.OutputSimd128Register()), | |
1998 NeonMemOperand(src.rn(), src.rm())); | |
1999 break; | |
2000 } | |
2001 case kArmSimd128Store: { | |
2002 MemOperand src = i.InputOffset(1); | |
2003 __ vst1(Neon8, NeonListOperand(i.InputSimd128Register(0)), | |
2004 NeonMemOperand(src.rn(), src.rm())); | |
2005 break; | |
2006 } | |
2007 case kArmSimd128And: { | 2005 case kArmSimd128And: { |
2008 __ vand(i.OutputSimd128Register(), i.InputSimd128Register(0), | 2006 __ vand(i.OutputSimd128Register(), i.InputSimd128Register(0), |
2009 i.InputSimd128Register(1)); | 2007 i.InputSimd128Register(1)); |
2010 break; | 2008 break; |
2011 } | 2009 } |
2012 case kArmSimd128Or: { | 2010 case kArmSimd128Or: { |
2013 __ vorr(i.OutputSimd128Register(), i.InputSimd128Register(0), | 2011 __ vorr(i.OutputSimd128Register(), i.InputSimd128Register(0), |
2014 i.InputSimd128Register(1)); | 2012 i.InputSimd128Register(1)); |
2015 break; | 2013 break; |
2016 } | 2014 } |
(...skipping 816 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2833 padding_size -= v8::internal::Assembler::kInstrSize; | 2831 padding_size -= v8::internal::Assembler::kInstrSize; |
2834 } | 2832 } |
2835 } | 2833 } |
2836 } | 2834 } |
2837 | 2835 |
2838 #undef __ | 2836 #undef __ |
2839 | 2837 |
2840 } // namespace compiler | 2838 } // namespace compiler |
2841 } // namespace internal | 2839 } // namespace internal |
2842 } // namespace v8 | 2840 } // namespace v8 |
OLD | NEW |