| 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/ast/scopes.h" | 5 #include "src/ast/scopes.h" |
| 6 #include "src/compiler/code-generator.h" | 6 #include "src/compiler/code-generator.h" |
| 7 #include "src/compiler/code-generator-impl.h" | 7 #include "src/compiler/code-generator-impl.h" |
| 8 #include "src/compiler/gap-resolver.h" | 8 #include "src/compiler/gap-resolver.h" |
| 9 #include "src/compiler/node-matchers.h" | 9 #include "src/compiler/node-matchers.h" |
| 10 #include "src/compiler/osr.h" | 10 #include "src/compiler/osr.h" |
| (...skipping 902 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 913 i.InputInt8(2)); | 913 i.InputInt8(2)); |
| 914 break; | 914 break; |
| 915 case kMips64Lsa: | 915 case kMips64Lsa: |
| 916 DCHECK(instr->InputAt(2)->IsImmediate()); | 916 DCHECK(instr->InputAt(2)->IsImmediate()); |
| 917 __ Lsa(i.OutputRegister(), i.InputRegister(0), i.InputRegister(1), | 917 __ Lsa(i.OutputRegister(), i.InputRegister(0), i.InputRegister(1), |
| 918 i.InputInt8(2)); | 918 i.InputInt8(2)); |
| 919 break; | 919 break; |
| 920 case kMips64And: | 920 case kMips64And: |
| 921 __ And(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 921 __ And(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 922 break; | 922 break; |
| 923 case kMips64And32: |
| 924 if (instr->InputAt(1)->IsRegister()) { |
| 925 __ sll(i.InputRegister(0), i.InputRegister(0), 0x0); |
| 926 __ sll(i.InputRegister(1), i.InputRegister(1), 0x0); |
| 927 __ And(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 928 } else { |
| 929 __ sll(i.InputRegister(0), i.InputRegister(0), 0x0); |
| 930 __ And(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 931 } |
| 932 break; |
| 923 case kMips64Or: | 933 case kMips64Or: |
| 924 __ Or(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 934 __ Or(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 925 break; | 935 break; |
| 936 case kMips64Or32: |
| 937 if (instr->InputAt(1)->IsRegister()) { |
| 938 __ sll(i.InputRegister(0), i.InputRegister(0), 0x0); |
| 939 __ sll(i.InputRegister(1), i.InputRegister(1), 0x0); |
| 940 __ Or(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 941 } else { |
| 942 __ sll(i.InputRegister(0), i.InputRegister(0), 0x0); |
| 943 __ Or(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 944 } |
| 945 break; |
| 926 case kMips64Nor: | 946 case kMips64Nor: |
| 927 if (instr->InputAt(1)->IsRegister()) { | 947 if (instr->InputAt(1)->IsRegister()) { |
| 928 __ Nor(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 948 __ Nor(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 929 } else { | 949 } else { |
| 930 DCHECK(i.InputOperand(1).immediate() == 0); | 950 DCHECK(i.InputOperand(1).immediate() == 0); |
| 931 __ Nor(i.OutputRegister(), i.InputRegister(0), zero_reg); | 951 __ Nor(i.OutputRegister(), i.InputRegister(0), zero_reg); |
| 932 } | 952 } |
| 933 break; | 953 break; |
| 954 case kMips64Nor32: |
| 955 if (instr->InputAt(1)->IsRegister()) { |
| 956 __ sll(i.InputRegister(0), i.InputRegister(0), 0x0); |
| 957 __ sll(i.InputRegister(1), i.InputRegister(1), 0x0); |
| 958 __ Nor(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 959 } else { |
| 960 DCHECK(i.InputOperand(1).immediate() == 0); |
| 961 __ sll(i.InputRegister(0), i.InputRegister(0), 0x0); |
| 962 __ Nor(i.OutputRegister(), i.InputRegister(0), zero_reg); |
| 963 } |
| 964 break; |
| 934 case kMips64Xor: | 965 case kMips64Xor: |
| 935 __ Xor(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 966 __ Xor(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 936 break; | 967 break; |
| 968 case kMips64Xor32: |
| 969 if (instr->InputAt(1)->IsRegister()) { |
| 970 __ sll(i.InputRegister(0), i.InputRegister(0), 0x0); |
| 971 __ sll(i.InputRegister(1), i.InputRegister(1), 0x0); |
| 972 __ Xor(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 973 } else { |
| 974 __ sll(i.InputRegister(0), i.InputRegister(0), 0x0); |
| 975 __ Xor(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 976 } |
| 977 break; |
| 937 case kMips64Clz: | 978 case kMips64Clz: |
| 938 __ Clz(i.OutputRegister(), i.InputRegister(0)); | 979 __ Clz(i.OutputRegister(), i.InputRegister(0)); |
| 939 break; | 980 break; |
| 940 case kMips64Dclz: | 981 case kMips64Dclz: |
| 941 __ dclz(i.OutputRegister(), i.InputRegister(0)); | 982 __ dclz(i.OutputRegister(), i.InputRegister(0)); |
| 942 break; | 983 break; |
| 943 case kMips64Ctz: { | 984 case kMips64Ctz: { |
| 944 Register reg1 = kScratchReg; | 985 Register reg1 = kScratchReg; |
| 945 Register reg2 = kScratchReg2; | 986 Register reg2 = kScratchReg2; |
| 946 Label skip_for_zero; | 987 Label skip_for_zero; |
| (...skipping 1434 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2381 padding_size -= v8::internal::Assembler::kInstrSize; | 2422 padding_size -= v8::internal::Assembler::kInstrSize; |
| 2382 } | 2423 } |
| 2383 } | 2424 } |
| 2384 } | 2425 } |
| 2385 | 2426 |
| 2386 #undef __ | 2427 #undef __ |
| 2387 | 2428 |
| 2388 } // namespace compiler | 2429 } // namespace compiler |
| 2389 } // namespace internal | 2430 } // namespace internal |
| 2390 } // namespace v8 | 2431 } // namespace v8 |
| OLD | NEW |