| 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 154 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 165 if (instr->InputAt(1)->IsRegister()) { \ | 165 if (instr->InputAt(1)->IsRegister()) { \ |
| 166 __ asm_instr(i.OutputRegister##width(), i.InputRegister##width(0), \ | 166 __ asm_instr(i.OutputRegister##width(), i.InputRegister##width(0), \ |
| 167 i.InputRegister##width(1)); \ | 167 i.InputRegister##width(1)); \ |
| 168 } else { \ | 168 } else { \ |
| 169 int64_t imm = i.InputOperand##width(1).immediate().value(); \ | 169 int64_t imm = i.InputOperand##width(1).immediate().value(); \ |
| 170 __ asm_instr(i.OutputRegister##width(), i.InputRegister##width(0), imm); \ | 170 __ asm_instr(i.OutputRegister##width(), i.InputRegister##width(0), imm); \ |
| 171 } \ | 171 } \ |
| 172 } while (0) | 172 } while (0) |
| 173 | 173 |
| 174 | 174 |
| 175 #define ASSEMBLE_TEST_AND_BRANCH(asm_instr, width) \ | 175 #define ASSEMBLE_TEST_AND_BRANCH(asm_instr, width) \ |
| 176 do { \ | 176 do { \ |
| 177 bool fallthrough = IsNextInAssemblyOrder(i.InputRpo(3)); \ | 177 bool fallthrough = IsNextInAssemblyOrder(i.InputRpo(3)); \ |
| 178 __ asm_instr(i.InputRegister##width(0), i.InputInt6(1), \ | 178 __ asm_instr(i.InputRegister##width(0), i.InputInt6(1), \ |
| 179 code_->GetLabel(i.InputRpo(2))); \ | 179 GetLabel(i.InputRpo(2))); \ |
| 180 if (!fallthrough) __ B(code_->GetLabel(i.InputRpo(3))); \ | 180 if (!fallthrough) __ B(GetLabel(i.InputRpo(3))); \ |
| 181 } while (0) | 181 } while (0) |
| 182 | 182 |
| 183 | 183 |
| 184 // Assembles an instruction after register allocation, producing machine code. | 184 // Assembles an instruction after register allocation, producing machine code. |
| 185 void CodeGenerator::AssembleArchInstruction(Instruction* instr) { | 185 void CodeGenerator::AssembleArchInstruction(Instruction* instr) { |
| 186 Arm64OperandConverter i(this, instr); | 186 Arm64OperandConverter i(this, instr); |
| 187 InstructionCode opcode = instr->opcode(); | 187 InstructionCode opcode = instr->opcode(); |
| 188 switch (ArchOpcodeField::decode(opcode)) { | 188 switch (ArchOpcodeField::decode(opcode)) { |
| 189 case kArchCallCodeObject: { | 189 case kArchCallCodeObject: { |
| 190 EnsureSpaceForLazyDeopt(); | 190 EnsureSpaceForLazyDeopt(); |
| (...skipping 18 matching lines...) Expand all Loading... |
| 209 __ Ldr(temp, FieldMemOperand(func, JSFunction::kContextOffset)); | 209 __ Ldr(temp, FieldMemOperand(func, JSFunction::kContextOffset)); |
| 210 __ cmp(cp, temp); | 210 __ cmp(cp, temp); |
| 211 __ Assert(eq, kWrongFunctionContext); | 211 __ Assert(eq, kWrongFunctionContext); |
| 212 } | 212 } |
| 213 __ Ldr(x10, FieldMemOperand(func, JSFunction::kCodeEntryOffset)); | 213 __ Ldr(x10, FieldMemOperand(func, JSFunction::kCodeEntryOffset)); |
| 214 __ Call(x10); | 214 __ Call(x10); |
| 215 AddSafepointAndDeopt(instr); | 215 AddSafepointAndDeopt(instr); |
| 216 break; | 216 break; |
| 217 } | 217 } |
| 218 case kArchJmp: | 218 case kArchJmp: |
| 219 __ B(code_->GetLabel(i.InputRpo(0))); | 219 __ B(GetLabel(i.InputRpo(0))); |
| 220 break; | 220 break; |
| 221 case kArchNop: | 221 case kArchNop: |
| 222 // don't emit code for nops. | 222 // don't emit code for nops. |
| 223 break; | 223 break; |
| 224 case kArchRet: | 224 case kArchRet: |
| 225 AssembleReturn(); | 225 AssembleReturn(); |
| 226 break; | 226 break; |
| 227 case kArchStackPointer: | 227 case kArchStackPointer: |
| 228 __ mov(i.OutputRegister(), masm()->StackPointer()); | 228 __ mov(i.OutputRegister(), masm()->StackPointer()); |
| 229 break; | 229 break; |
| (...skipping 377 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 607 Arm64OperandConverter i(this, instr); | 607 Arm64OperandConverter i(this, instr); |
| 608 Label done; | 608 Label done; |
| 609 | 609 |
| 610 // Emit a branch. The true and false targets are always the last two inputs | 610 // Emit a branch. The true and false targets are always the last two inputs |
| 611 // to the instruction. | 611 // to the instruction. |
| 612 BasicBlock::RpoNumber tblock = | 612 BasicBlock::RpoNumber tblock = |
| 613 i.InputRpo(static_cast<int>(instr->InputCount()) - 2); | 613 i.InputRpo(static_cast<int>(instr->InputCount()) - 2); |
| 614 BasicBlock::RpoNumber fblock = | 614 BasicBlock::RpoNumber fblock = |
| 615 i.InputRpo(static_cast<int>(instr->InputCount()) - 1); | 615 i.InputRpo(static_cast<int>(instr->InputCount()) - 1); |
| 616 bool fallthru = IsNextInAssemblyOrder(fblock); | 616 bool fallthru = IsNextInAssemblyOrder(fblock); |
| 617 Label* tlabel = code()->GetLabel(tblock); | 617 Label* tlabel = GetLabel(tblock); |
| 618 Label* flabel = fallthru ? &done : code()->GetLabel(fblock); | 618 Label* flabel = fallthru ? &done : GetLabel(fblock); |
| 619 switch (condition) { | 619 switch (condition) { |
| 620 case kUnorderedEqual: | 620 case kUnorderedEqual: |
| 621 __ B(vs, flabel); | 621 __ B(vs, flabel); |
| 622 // Fall through. | 622 // Fall through. |
| 623 case kEqual: | 623 case kEqual: |
| 624 __ B(eq, tlabel); | 624 __ B(eq, tlabel); |
| 625 break; | 625 break; |
| 626 case kUnorderedNotEqual: | 626 case kUnorderedNotEqual: |
| 627 __ B(vs, tlabel); | 627 __ B(vs, tlabel); |
| 628 // Fall through. | 628 // Fall through. |
| (...skipping 391 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1020 } | 1020 } |
| 1021 } | 1021 } |
| 1022 MarkLazyDeoptSite(); | 1022 MarkLazyDeoptSite(); |
| 1023 } | 1023 } |
| 1024 | 1024 |
| 1025 #undef __ | 1025 #undef __ |
| 1026 | 1026 |
| 1027 } // namespace compiler | 1027 } // namespace compiler |
| 1028 } // namespace internal | 1028 } // namespace internal |
| 1029 } // namespace v8 | 1029 } // namespace v8 |
| OLD | NEW |