| OLD | NEW |
| 1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 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/ast/scopes.h" | 7 #include "src/ast/scopes.h" |
| 8 #include "src/compiler/code-generator-impl.h" | 8 #include "src/compiler/code-generator-impl.h" |
| 9 #include "src/compiler/gap-resolver.h" | 9 #include "src/compiler/gap-resolver.h" |
| 10 #include "src/compiler/node-matchers.h" | 10 #include "src/compiler/node-matchers.h" |
| (...skipping 911 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 922 __ rll(i.OutputRegister(), i.InputRegister(0), kScratchReg); | 922 __ rll(i.OutputRegister(), i.InputRegister(0), kScratchReg); |
| 923 } else { | 923 } else { |
| 924 __ rll(i.OutputRegister(), i.InputRegister(0), | 924 __ rll(i.OutputRegister(), i.InputRegister(0), |
| 925 Operand(32 - i.InputInt32(1))); | 925 Operand(32 - i.InputInt32(1))); |
| 926 } | 926 } |
| 927 break; | 927 break; |
| 928 #if V8_TARGET_ARCH_S390X | 928 #if V8_TARGET_ARCH_S390X |
| 929 case kS390_RotRight64: | 929 case kS390_RotRight64: |
| 930 if (HasRegisterInput(instr, 1)) { | 930 if (HasRegisterInput(instr, 1)) { |
| 931 __ LoadComplementRR(kScratchReg, i.InputRegister(1)); | 931 __ LoadComplementRR(kScratchReg, i.InputRegister(1)); |
| 932 __ rll(i.OutputRegister(), i.InputRegister(0), kScratchReg, | 932 __ rllg(i.OutputRegister(), i.InputRegister(0), kScratchReg); |
| 933 Operand(32)); | |
| 934 __ lgfr(i.OutputRegister(), i.OutputRegister()); | |
| 935 } else { | 933 } else { |
| 936 UNIMPLEMENTED(); // Not implemented for now | 934 __ rllg(i.OutputRegister(), i.InputRegister(0), |
| 935 Operand(64 - i.InputInt32(1))); |
| 937 } | 936 } |
| 938 break; | 937 break; |
| 939 #endif | 938 #endif |
| 940 case kS390_Not: | 939 case kS390_Not: |
| 941 __ LoadRR(i.OutputRegister(), i.InputRegister(0)); | 940 __ LoadRR(i.OutputRegister(), i.InputRegister(0)); |
| 942 __ NotP(i.OutputRegister()); | 941 __ NotP(i.OutputRegister()); |
| 943 break; | 942 break; |
| 944 case kS390_RotLeftAndMask32: | 943 case kS390_RotLeftAndMask32: |
| 945 if (CpuFeatures::IsSupported(GENERAL_INSTR_EXT)) { | 944 if (CpuFeatures::IsSupported(GENERAL_INSTR_EXT)) { |
| 946 int shiftAmount = i.InputInt32(1); | 945 int shiftAmount = i.InputInt32(1); |
| (...skipping 1120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2067 padding_size -= 2; | 2066 padding_size -= 2; |
| 2068 } | 2067 } |
| 2069 } | 2068 } |
| 2070 } | 2069 } |
| 2071 | 2070 |
| 2072 #undef __ | 2071 #undef __ |
| 2073 | 2072 |
| 2074 } // namespace compiler | 2073 } // namespace compiler |
| 2075 } // namespace internal | 2074 } // namespace internal |
| 2076 } // namespace v8 | 2075 } // namespace v8 |
| OLD | NEW |