| 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/compilation-info.h" | 8 #include "src/compilation-info.h" | 
| 9 #include "src/compiler/code-generator-impl.h" | 9 #include "src/compiler/code-generator-impl.h" | 
| 10 #include "src/compiler/gap-resolver.h" | 10 #include "src/compiler/gap-resolver.h" | 
| (...skipping 1597 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1608     case kArmInt32x4Min: { | 1608     case kArmInt32x4Min: { | 
| 1609       __ vmin(NeonS32, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1609       __ vmin(NeonS32, i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1610               i.InputSimd128Register(1)); | 1610               i.InputSimd128Register(1)); | 
| 1611       break; | 1611       break; | 
| 1612     } | 1612     } | 
| 1613     case kArmInt32x4Max: { | 1613     case kArmInt32x4Max: { | 
| 1614       __ vmax(NeonS32, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1614       __ vmax(NeonS32, i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1615               i.InputSimd128Register(1)); | 1615               i.InputSimd128Register(1)); | 
| 1616       break; | 1616       break; | 
| 1617     } | 1617     } | 
|  | 1618     case kArmSimd1x4AnyTrue: { | 
|  | 1619       break; | 
|  | 1620     } | 
|  | 1621     case kArmSimd1x4AllTrue: { | 
|  | 1622       break; | 
|  | 1623     } | 
| 1618     case kArmInt32x4Equal: { | 1624     case kArmInt32x4Equal: { | 
| 1619       __ vceq(Neon32, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1625       __ vceq(Neon32, i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1620               i.InputSimd128Register(1)); | 1626               i.InputSimd128Register(1)); | 
| 1621       break; | 1627       break; | 
| 1622     } | 1628     } | 
| 1623     case kArmInt32x4NotEqual: { | 1629     case kArmInt32x4NotEqual: { | 
| 1624       Simd128Register dst = i.OutputSimd128Register(); | 1630       Simd128Register dst = i.OutputSimd128Register(); | 
| 1625       __ vceq(Neon32, dst, i.InputSimd128Register(0), | 1631       __ vceq(Neon32, dst, i.InputSimd128Register(0), | 
| 1626               i.InputSimd128Register(1)); | 1632               i.InputSimd128Register(1)); | 
| 1627       __ vmvn(dst, dst); | 1633       __ vmvn(dst, dst); | 
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1675     } | 1681     } | 
| 1676     case kArmInt16x8ReplaceLane: { | 1682     case kArmInt16x8ReplaceLane: { | 
| 1677       __ ReplaceLane(i.OutputSimd128Register(), i.InputSimd128Register(0), | 1683       __ ReplaceLane(i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1678                      i.InputRegister(2), NeonS16, i.InputInt8(1)); | 1684                      i.InputRegister(2), NeonS16, i.InputInt8(1)); | 
| 1679       break; | 1685       break; | 
| 1680     } | 1686     } | 
| 1681     case kArmInt16x8Neg: { | 1687     case kArmInt16x8Neg: { | 
| 1682       __ vneg(Neon16, i.OutputSimd128Register(), i.InputSimd128Register(0)); | 1688       __ vneg(Neon16, i.OutputSimd128Register(), i.InputSimd128Register(0)); | 
| 1683       break; | 1689       break; | 
| 1684     } | 1690     } | 
|  | 1691     case kArmSimd1x8AnyTrue: { | 
|  | 1692       break; | 
|  | 1693     } | 
|  | 1694     case kArmSimd1x8AllTrue: { | 
|  | 1695       break; | 
|  | 1696     } | 
| 1685     case kArmInt16x8ShiftLeftByScalar: { | 1697     case kArmInt16x8ShiftLeftByScalar: { | 
| 1686       __ vshl(NeonS16, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1698       __ vshl(NeonS16, i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1687               i.InputInt4(1)); | 1699               i.InputInt4(1)); | 
| 1688       break; | 1700       break; | 
| 1689     } | 1701     } | 
| 1690     case kArmInt16x8ShiftRightByScalar: { | 1702     case kArmInt16x8ShiftRightByScalar: { | 
| 1691       __ vshr(NeonS16, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1703       __ vshr(NeonS16, i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1692               i.InputInt4(1)); | 1704               i.InputInt4(1)); | 
| 1693       break; | 1705       break; | 
| 1694     } | 1706     } | 
| (...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1797     } | 1809     } | 
| 1798     case kArmInt8x16ReplaceLane: { | 1810     case kArmInt8x16ReplaceLane: { | 
| 1799       __ ReplaceLane(i.OutputSimd128Register(), i.InputSimd128Register(0), | 1811       __ ReplaceLane(i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1800                      i.InputRegister(2), NeonS8, i.InputInt8(1)); | 1812                      i.InputRegister(2), NeonS8, i.InputInt8(1)); | 
| 1801       break; | 1813       break; | 
| 1802     } | 1814     } | 
| 1803     case kArmInt8x16Neg: { | 1815     case kArmInt8x16Neg: { | 
| 1804       __ vneg(Neon8, i.OutputSimd128Register(), i.InputSimd128Register(0)); | 1816       __ vneg(Neon8, i.OutputSimd128Register(), i.InputSimd128Register(0)); | 
| 1805       break; | 1817       break; | 
| 1806     } | 1818     } | 
|  | 1819     case kArmSimd1x16AnyTrue: { | 
|  | 1820       break; | 
|  | 1821     } | 
|  | 1822     case kArmSimd1x16AllTrue: { | 
|  | 1823       break; | 
|  | 1824     } | 
| 1807     case kArmInt8x16ShiftLeftByScalar: { | 1825     case kArmInt8x16ShiftLeftByScalar: { | 
| 1808       __ vshl(NeonS8, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1826       __ vshl(NeonS8, i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1809               i.InputInt3(1)); | 1827               i.InputInt3(1)); | 
| 1810       break; | 1828       break; | 
| 1811     } | 1829     } | 
| 1812     case kArmInt8x16ShiftRightByScalar: { | 1830     case kArmInt8x16ShiftRightByScalar: { | 
| 1813       __ vshr(NeonS8, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1831       __ vshr(NeonS8, i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1814               i.InputInt3(1)); | 1832               i.InputInt3(1)); | 
| 1815       break; | 1833       break; | 
| 1816     } | 1834     } | 
| (...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1919     } | 1937     } | 
| 1920     case kArmSimd128Xor: { | 1938     case kArmSimd128Xor: { | 
| 1921       __ veor(i.OutputSimd128Register(), i.InputSimd128Register(0), | 1939       __ veor(i.OutputSimd128Register(), i.InputSimd128Register(0), | 
| 1922               i.InputSimd128Register(1)); | 1940               i.InputSimd128Register(1)); | 
| 1923       break; | 1941       break; | 
| 1924     } | 1942     } | 
| 1925     case kArmSimd128Not: { | 1943     case kArmSimd128Not: { | 
| 1926       __ vmvn(i.OutputSimd128Register(), i.InputSimd128Register(0)); | 1944       __ vmvn(i.OutputSimd128Register(), i.InputSimd128Register(0)); | 
| 1927       break; | 1945       break; | 
| 1928     } | 1946     } | 
| 1929     case kArmSimd32x4Select: { | 1947     case kArmSimd128Select: { | 
| 1930       // Canonicalize input 0 lanes to all 0's or all 1's and move to dest. | 1948       // vbsl clobbers the mask input so make sure it was DefineSameAsFirst. | 
| 1931       __ vtst(Neon32, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1949       DCHECK(i.OutputSimd128Register().is(i.InputSimd128Register(0))); | 
| 1932               i.InputSimd128Register(0)); |  | 
| 1933       __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), | 1950       __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), | 
| 1934               i.InputSimd128Register(2)); | 1951               i.InputSimd128Register(2)); | 
| 1935       break; | 1952       break; | 
| 1936     } |  | 
| 1937     case kArmSimd16x8Select: { |  | 
| 1938       // Canonicalize input 0 lanes to all 0's or all 1's and move to dest. |  | 
| 1939       __ vtst(Neon16, i.OutputSimd128Register(), i.InputSimd128Register(0), |  | 
| 1940               i.InputSimd128Register(0)); |  | 
| 1941       __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), |  | 
| 1942               i.InputSimd128Register(2)); |  | 
| 1943       break; |  | 
| 1944     } |  | 
| 1945     case kArmSimd8x16Select: { |  | 
| 1946       // Canonicalize input 0 lanes to all 0's or all 1's and move to dest. |  | 
| 1947       __ vtst(Neon8, i.OutputSimd128Register(), i.InputSimd128Register(0), |  | 
| 1948               i.InputSimd128Register(0)); |  | 
| 1949       __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), |  | 
| 1950               i.InputSimd128Register(2)); |  | 
| 1951       break; |  | 
| 1952     } | 1953     } | 
| 1953     case kCheckedLoadInt8: | 1954     case kCheckedLoadInt8: | 
| 1954       ASSEMBLE_CHECKED_LOAD_INTEGER(ldrsb); | 1955       ASSEMBLE_CHECKED_LOAD_INTEGER(ldrsb); | 
| 1955       break; | 1956       break; | 
| 1956     case kCheckedLoadUint8: | 1957     case kCheckedLoadUint8: | 
| 1957       ASSEMBLE_CHECKED_LOAD_INTEGER(ldrb); | 1958       ASSEMBLE_CHECKED_LOAD_INTEGER(ldrb); | 
| 1958       break; | 1959       break; | 
| 1959     case kCheckedLoadInt16: | 1960     case kCheckedLoadInt16: | 
| 1960       ASSEMBLE_CHECKED_LOAD_INTEGER(ldrsh); | 1961       ASSEMBLE_CHECKED_LOAD_INTEGER(ldrsh); | 
| 1961       break; | 1962       break; | 
| (...skipping 651 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 2613       padding_size -= v8::internal::Assembler::kInstrSize; | 2614       padding_size -= v8::internal::Assembler::kInstrSize; | 
| 2614     } | 2615     } | 
| 2615   } | 2616   } | 
| 2616 } | 2617 } | 
| 2617 | 2618 | 
| 2618 #undef __ | 2619 #undef __ | 
| 2619 | 2620 | 
| 2620 }  // namespace compiler | 2621 }  // namespace compiler | 
| 2621 }  // namespace internal | 2622 }  // namespace internal | 
| 2622 }  // namespace v8 | 2623 }  // namespace v8 | 
| OLD | NEW | 
|---|