| 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/arm64/macro-assembler-arm64.h" | 7 #include "src/arm64/macro-assembler-arm64.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 722 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 733 Register tmp = scope.AcquireX(); | 733 Register tmp = scope.AcquireX(); |
| 734 __ Fmov(tmp.W(), i.InputFloat32Register(0)); | 734 __ Fmov(tmp.W(), i.InputFloat32Register(0)); |
| 735 __ Bfi(tmp, i.InputRegister(1), 32, 32); | 735 __ Bfi(tmp, i.InputRegister(1), 32, 32); |
| 736 __ Fmov(i.OutputFloat64Register(), tmp); | 736 __ Fmov(i.OutputFloat64Register(), tmp); |
| 737 break; | 737 break; |
| 738 } | 738 } |
| 739 case kArm64Float64MoveU64: { | 739 case kArm64Float64MoveU64: { |
| 740 __ Fmov(i.OutputFloat64Register(), i.InputRegister(0)); | 740 __ Fmov(i.OutputFloat64Register(), i.InputRegister(0)); |
| 741 break; | 741 break; |
| 742 } | 742 } |
| 743 case kArm64Float64Max: |
| 744 __ Fmax(i.OutputDoubleRegister(), i.InputDoubleRegister(0), |
| 745 i.InputDoubleRegister(1)); |
| 746 break; |
| 747 case kArm64Float64Min: |
| 748 __ Fmin(i.OutputDoubleRegister(), i.InputDoubleRegister(0), |
| 749 i.InputDoubleRegister(1)); |
| 750 break; |
| 743 case kArm64Ldrb: | 751 case kArm64Ldrb: |
| 744 __ Ldrb(i.OutputRegister(), i.MemoryOperand()); | 752 __ Ldrb(i.OutputRegister(), i.MemoryOperand()); |
| 745 break; | 753 break; |
| 746 case kArm64Ldrsb: | 754 case kArm64Ldrsb: |
| 747 __ Ldrsb(i.OutputRegister(), i.MemoryOperand()); | 755 __ Ldrsb(i.OutputRegister(), i.MemoryOperand()); |
| 748 break; | 756 break; |
| 749 case kArm64Strb: | 757 case kArm64Strb: |
| 750 __ Strb(i.InputRegister(2), i.MemoryOperand()); | 758 __ Strb(i.InputRegister(2), i.MemoryOperand()); |
| 751 break; | 759 break; |
| 752 case kArm64Ldrh: | 760 case kArm64Ldrh: |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 835 case kCheckedStoreWord32: | 843 case kCheckedStoreWord32: |
| 836 ASSEMBLE_CHECKED_STORE_INTEGER(Str); | 844 ASSEMBLE_CHECKED_STORE_INTEGER(Str); |
| 837 break; | 845 break; |
| 838 case kCheckedStoreFloat32: | 846 case kCheckedStoreFloat32: |
| 839 ASSEMBLE_CHECKED_STORE_FLOAT(32); | 847 ASSEMBLE_CHECKED_STORE_FLOAT(32); |
| 840 break; | 848 break; |
| 841 case kCheckedStoreFloat64: | 849 case kCheckedStoreFloat64: |
| 842 ASSEMBLE_CHECKED_STORE_FLOAT(64); | 850 ASSEMBLE_CHECKED_STORE_FLOAT(64); |
| 843 break; | 851 break; |
| 844 } | 852 } |
| 845 } | 853 } // NOLINT(readability/fn_size) |
| 846 | 854 |
| 847 | 855 |
| 848 // Assemble branches after this instruction. | 856 // Assemble branches after this instruction. |
| 849 void CodeGenerator::AssembleArchBranch(Instruction* instr, BranchInfo* branch) { | 857 void CodeGenerator::AssembleArchBranch(Instruction* instr, BranchInfo* branch) { |
| 850 Arm64OperandConverter i(this, instr); | 858 Arm64OperandConverter i(this, instr); |
| 851 Label* tlabel = branch->true_label; | 859 Label* tlabel = branch->true_label; |
| 852 Label* flabel = branch->false_label; | 860 Label* flabel = branch->false_label; |
| 853 FlagsCondition condition = branch->condition; | 861 FlagsCondition condition = branch->condition; |
| 854 ArchOpcode opcode = instr->arch_opcode(); | 862 ArchOpcode opcode = instr->arch_opcode(); |
| 855 | 863 |
| (...skipping 353 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1209 } | 1217 } |
| 1210 } | 1218 } |
| 1211 MarkLazyDeoptSite(); | 1219 MarkLazyDeoptSite(); |
| 1212 } | 1220 } |
| 1213 | 1221 |
| 1214 #undef __ | 1222 #undef __ |
| 1215 | 1223 |
| 1216 } // namespace compiler | 1224 } // namespace compiler |
| 1217 } // namespace internal | 1225 } // namespace internal |
| 1218 } // namespace v8 | 1226 } // namespace v8 |
| OLD | NEW |