Chromium Code Reviews| 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 1909 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1920 case kArmSimd128Xor: { | 1920 case kArmSimd128Xor: { |
| 1921 __ veor(i.OutputSimd128Register(), i.InputSimd128Register(0), | 1921 __ veor(i.OutputSimd128Register(), i.InputSimd128Register(0), |
| 1922 i.InputSimd128Register(1)); | 1922 i.InputSimd128Register(1)); |
| 1923 break; | 1923 break; |
| 1924 } | 1924 } |
| 1925 case kArmSimd128Not: { | 1925 case kArmSimd128Not: { |
| 1926 __ vmvn(i.OutputSimd128Register(), i.InputSimd128Register(0)); | 1926 __ vmvn(i.OutputSimd128Register(), i.InputSimd128Register(0)); |
| 1927 break; | 1927 break; |
| 1928 } | 1928 } |
| 1929 case kArmSimd32x4Select: { | 1929 case kArmSimd32x4Select: { |
| 1930 // Canonicalize input 0 lanes to all 0's or all 1's and move to dest. | 1930 // vbsl is a ternary opcode, so move input 0 into dest. |
| 1931 __ vtst(Neon32, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1931 __ Move(i.OutputSimd128Register(), i.InputSimd128Register(0)); |
|
gdeepti
2017/02/17 17:51:48
Would it be possible to use DefineSameAsFirst in t
bbudge
2017/02/17 23:39:56
Yes, that seems better. Also, I noticed that these
| |
| 1932 i.InputSimd128Register(0)); | |
| 1933 __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), | 1932 __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), |
| 1934 i.InputSimd128Register(2)); | 1933 i.InputSimd128Register(2)); |
| 1935 break; | 1934 break; |
| 1936 } | 1935 } |
| 1937 case kArmSimd16x8Select: { | 1936 case kArmSimd16x8Select: { |
| 1938 // Canonicalize input 0 lanes to all 0's or all 1's and move to dest. | 1937 // vbsl is a ternary opcode, so move input 0 into dest. |
| 1939 __ vtst(Neon16, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1938 __ Move(i.OutputSimd128Register(), i.InputSimd128Register(0)); |
| 1940 i.InputSimd128Register(0)); | |
| 1941 __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), | 1939 __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), |
| 1942 i.InputSimd128Register(2)); | 1940 i.InputSimd128Register(2)); |
| 1943 break; | 1941 break; |
| 1944 } | 1942 } |
| 1945 case kArmSimd8x16Select: { | 1943 case kArmSimd8x16Select: { |
| 1946 // Canonicalize input 0 lanes to all 0's or all 1's and move to dest. | 1944 // vbsl is a ternary opcode, so move input 0 into dest. |
| 1947 __ vtst(Neon8, i.OutputSimd128Register(), i.InputSimd128Register(0), | 1945 __ Move(i.OutputSimd128Register(), i.InputSimd128Register(0)); |
| 1948 i.InputSimd128Register(0)); | |
| 1949 __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), | 1946 __ vbsl(i.OutputSimd128Register(), i.InputSimd128Register(1), |
| 1950 i.InputSimd128Register(2)); | 1947 i.InputSimd128Register(2)); |
| 1951 break; | 1948 break; |
| 1952 } | 1949 } |
| 1953 case kCheckedLoadInt8: | 1950 case kCheckedLoadInt8: |
| 1954 ASSEMBLE_CHECKED_LOAD_INTEGER(ldrsb); | 1951 ASSEMBLE_CHECKED_LOAD_INTEGER(ldrsb); |
| 1955 break; | 1952 break; |
| 1956 case kCheckedLoadUint8: | 1953 case kCheckedLoadUint8: |
| 1957 ASSEMBLE_CHECKED_LOAD_INTEGER(ldrb); | 1954 ASSEMBLE_CHECKED_LOAD_INTEGER(ldrb); |
| 1958 break; | 1955 break; |
| (...skipping 654 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2613 padding_size -= v8::internal::Assembler::kInstrSize; | 2610 padding_size -= v8::internal::Assembler::kInstrSize; |
| 2614 } | 2611 } |
| 2615 } | 2612 } |
| 2616 } | 2613 } |
| 2617 | 2614 |
| 2618 #undef __ | 2615 #undef __ |
| 2619 | 2616 |
| 2620 } // namespace compiler | 2617 } // namespace compiler |
| 2621 } // namespace internal | 2618 } // namespace internal |
| 2622 } // namespace v8 | 2619 } // namespace v8 |
| OLD | NEW |