| 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/ast/scopes.h" | 8 #include "src/ast/scopes.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 652 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 663 case kArmUxtab: | 663 case kArmUxtab: |
| 664 __ uxtab(i.OutputRegister(), i.InputRegister(0), i.InputRegister(1), | 664 __ uxtab(i.OutputRegister(), i.InputRegister(0), i.InputRegister(1), |
| 665 i.InputInt32(2)); | 665 i.InputInt32(2)); |
| 666 DCHECK_EQ(LeaveCC, i.OutputSBit()); | 666 DCHECK_EQ(LeaveCC, i.OutputSBit()); |
| 667 break; | 667 break; |
| 668 case kArmUxtah: | 668 case kArmUxtah: |
| 669 __ uxtah(i.OutputRegister(), i.InputRegister(0), i.InputRegister(1), | 669 __ uxtah(i.OutputRegister(), i.InputRegister(0), i.InputRegister(1), |
| 670 i.InputInt32(2)); | 670 i.InputInt32(2)); |
| 671 DCHECK_EQ(LeaveCC, i.OutputSBit()); | 671 DCHECK_EQ(LeaveCC, i.OutputSBit()); |
| 672 break; | 672 break; |
| 673 case kArmRbit: { |
| 674 CpuFeatureScope scope(masm(), ARMv7); |
| 675 __ rbit(i.OutputRegister(), i.InputRegister(0)); |
| 676 DCHECK_EQ(LeaveCC, i.OutputSBit()); |
| 677 break; |
| 678 } |
| 673 case kArmClz: | 679 case kArmClz: |
| 674 __ clz(i.OutputRegister(), i.InputRegister(0)); | 680 __ clz(i.OutputRegister(), i.InputRegister(0)); |
| 675 DCHECK_EQ(LeaveCC, i.OutputSBit()); | 681 DCHECK_EQ(LeaveCC, i.OutputSBit()); |
| 676 break; | 682 break; |
| 677 case kArmCmp: | 683 case kArmCmp: |
| 678 __ cmp(i.InputRegister(0), i.InputOperand2(1)); | 684 __ cmp(i.InputRegister(0), i.InputOperand2(1)); |
| 679 DCHECK_EQ(SetCC, i.OutputSBit()); | 685 DCHECK_EQ(SetCC, i.OutputSBit()); |
| 680 break; | 686 break; |
| 681 case kArmCmn: | 687 case kArmCmn: |
| 682 __ cmn(i.InputRegister(0), i.InputOperand2(1)); | 688 __ cmn(i.InputRegister(0), i.InputOperand2(1)); |
| (...skipping 734 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1417 padding_size -= v8::internal::Assembler::kInstrSize; | 1423 padding_size -= v8::internal::Assembler::kInstrSize; |
| 1418 } | 1424 } |
| 1419 } | 1425 } |
| 1420 } | 1426 } |
| 1421 | 1427 |
| 1422 #undef __ | 1428 #undef __ |
| 1423 | 1429 |
| 1424 } // namespace compiler | 1430 } // namespace compiler |
| 1425 } // namespace internal | 1431 } // namespace internal |
| 1426 } // namespace v8 | 1432 } // namespace v8 |
| OLD | NEW |