| 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/frames-arm64.h" | 7 #include "src/arm64/frames-arm64.h" |
| 8 #include "src/arm64/macro-assembler-arm64.h" | 8 #include "src/arm64/macro-assembler-arm64.h" |
| 9 #include "src/ast/scopes.h" | 9 #include "src/ast/scopes.h" |
| 10 #include "src/compiler/code-generator-impl.h" | 10 #include "src/compiler/code-generator-impl.h" |
| (...skipping 1497 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1508 } | 1508 } |
| 1509 | 1509 |
| 1510 | 1510 |
| 1511 void CodeGenerator::AssembleDeoptimizerCall( | 1511 void CodeGenerator::AssembleDeoptimizerCall( |
| 1512 int deoptimization_id, Deoptimizer::BailoutType bailout_type) { | 1512 int deoptimization_id, Deoptimizer::BailoutType bailout_type) { |
| 1513 Address deopt_entry = Deoptimizer::GetDeoptimizationEntry( | 1513 Address deopt_entry = Deoptimizer::GetDeoptimizationEntry( |
| 1514 isolate(), deoptimization_id, bailout_type); | 1514 isolate(), deoptimization_id, bailout_type); |
| 1515 __ Call(deopt_entry, RelocInfo::RUNTIME_ENTRY); | 1515 __ Call(deopt_entry, RelocInfo::RUNTIME_ENTRY); |
| 1516 } | 1516 } |
| 1517 | 1517 |
| 1518 void CodeGenerator::AssembleSetupStackPointer() { | 1518 void CodeGenerator::FinishFrame(Frame* frame) { |
| 1519 const CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); | 1519 frame->AlignFrame(16); |
| 1520 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); |
| 1521 |
| 1520 if (descriptor->UseNativeStack() || descriptor->IsCFunctionCall()) { | 1522 if (descriptor->UseNativeStack() || descriptor->IsCFunctionCall()) { |
| 1521 __ SetStackPointer(csp); | 1523 __ SetStackPointer(csp); |
| 1522 } else { | 1524 } else { |
| 1523 __ SetStackPointer(jssp); | 1525 __ SetStackPointer(jssp); |
| 1524 } | 1526 } |
| 1527 |
| 1528 // Save FP registers. |
| 1529 CPURegList saves_fp = CPURegList(CPURegister::kFPRegister, kDRegSizeInBits, |
| 1530 descriptor->CalleeSavedFPRegisters()); |
| 1531 int saved_count = saves_fp.Count(); |
| 1532 if (saved_count != 0) { |
| 1533 DCHECK(saves_fp.list() == CPURegList::GetCalleeSavedFP().list()); |
| 1534 frame->AllocateSavedCalleeRegisterSlots(saved_count * |
| 1535 (kDoubleSize / kPointerSize)); |
| 1536 } |
| 1537 |
| 1538 CPURegList saves = CPURegList(CPURegister::kRegister, kXRegSizeInBits, |
| 1539 descriptor->CalleeSavedRegisters()); |
| 1540 saved_count = saves.Count(); |
| 1541 if (saved_count != 0) { |
| 1542 frame->AllocateSavedCalleeRegisterSlots(saved_count); |
| 1543 } |
| 1525 } | 1544 } |
| 1526 | 1545 |
| 1527 void CodeGenerator::AssemblePrologue() { | 1546 void CodeGenerator::AssembleConstructFrame() { |
| 1528 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); | 1547 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); |
| 1529 if (descriptor->UseNativeStack()) { | 1548 if (descriptor->UseNativeStack()) { |
| 1530 __ AssertCspAligned(); | 1549 __ AssertCspAligned(); |
| 1531 } | 1550 } |
| 1532 | 1551 |
| 1533 int stack_shrink_slots = frame()->GetSpillSlotCount(); | |
| 1534 if (frame_access_state()->has_frame()) { | 1552 if (frame_access_state()->has_frame()) { |
| 1535 if (descriptor->IsJSFunctionCall()) { | 1553 if (descriptor->IsJSFunctionCall()) { |
| 1536 DCHECK(!descriptor->UseNativeStack()); | 1554 DCHECK(!descriptor->UseNativeStack()); |
| 1537 __ Prologue(this->info()->GeneratePreagedPrologue()); | 1555 __ Prologue(this->info()->GeneratePreagedPrologue()); |
| 1538 } else { | 1556 } else { |
| 1539 if (descriptor->IsCFunctionCall()) { | 1557 if (descriptor->IsCFunctionCall()) { |
| 1540 __ Push(lr, fp); | 1558 __ Push(lr, fp); |
| 1541 __ Mov(fp, masm_.StackPointer()); | 1559 __ Mov(fp, masm_.StackPointer()); |
| 1542 __ Claim(stack_shrink_slots); | 1560 __ Claim(frame()->GetSpillSlotCount()); |
| 1543 } else { | 1561 } else { |
| 1544 __ StubPrologue(info()->GetOutputStackFrameType(), | 1562 __ StubPrologue(info()->GetOutputStackFrameType(), |
| 1545 frame()->GetTotalFrameSlotCount()); | 1563 frame()->GetTotalFrameSlotCount()); |
| 1546 } | 1564 } |
| 1547 } | 1565 } |
| 1548 } | 1566 } |
| 1549 | 1567 |
| 1568 int shrink_slots = frame()->GetSpillSlotCount(); |
| 1569 |
| 1550 if (info()->is_osr()) { | 1570 if (info()->is_osr()) { |
| 1551 // TurboFan OSR-compiled functions cannot be entered directly. | 1571 // TurboFan OSR-compiled functions cannot be entered directly. |
| 1552 __ Abort(kShouldNotDirectlyEnterOsrFunction); | 1572 __ Abort(kShouldNotDirectlyEnterOsrFunction); |
| 1553 | 1573 |
| 1554 // Unoptimized code jumps directly to this entrypoint while the unoptimized | 1574 // Unoptimized code jumps directly to this entrypoint while the unoptimized |
| 1555 // frame is still on the stack. Optimized code uses OSR values directly from | 1575 // frame is still on the stack. Optimized code uses OSR values directly from |
| 1556 // the unoptimized frame. Thus, all that needs to be done is to allocate the | 1576 // the unoptimized frame. Thus, all that needs to be done is to allocate the |
| 1557 // remaining stack slots. | 1577 // remaining stack slots. |
| 1558 if (FLAG_code_comments) __ RecordComment("-- OSR entrypoint --"); | 1578 if (FLAG_code_comments) __ RecordComment("-- OSR entrypoint --"); |
| 1559 osr_pc_offset_ = __ pc_offset(); | 1579 osr_pc_offset_ = __ pc_offset(); |
| 1560 stack_shrink_slots -= OsrHelper(info()).UnoptimizedFrameSlots(); | 1580 shrink_slots -= OsrHelper(info()).UnoptimizedFrameSlots(); |
| 1561 } | 1581 } |
| 1562 | 1582 |
| 1563 if (descriptor->IsJSFunctionCall()) { | 1583 if (descriptor->IsJSFunctionCall()) { |
| 1564 __ Claim(stack_shrink_slots); | 1584 __ Claim(shrink_slots); |
| 1565 } | 1585 } |
| 1566 | 1586 |
| 1567 // Save FP registers. | 1587 // Save FP registers. |
| 1568 CPURegList saves_fp = CPURegList(CPURegister::kFPRegister, kDRegSizeInBits, | 1588 CPURegList saves_fp = CPURegList(CPURegister::kFPRegister, kDRegSizeInBits, |
| 1569 descriptor->CalleeSavedFPRegisters()); | 1589 descriptor->CalleeSavedFPRegisters()); |
| 1570 int saved_count = saves_fp.Count(); | 1590 int saved_count = saves_fp.Count(); |
| 1571 if (saved_count != 0) { | 1591 if (saved_count != 0) { |
| 1572 DCHECK(saves_fp.list() == CPURegList::GetCalleeSavedFP().list()); | 1592 DCHECK(saves_fp.list() == CPURegList::GetCalleeSavedFP().list()); |
| 1573 __ PushCPURegList(saves_fp); | 1593 __ PushCPURegList(saves_fp); |
| 1574 frame()->AllocateSavedCalleeRegisterSlots(saved_count * | |
| 1575 (kDoubleSize / kPointerSize)); | |
| 1576 } | 1594 } |
| 1577 // Save registers. | 1595 // Save registers. |
| 1578 // TODO(palfia): TF save list is not in sync with | 1596 // TODO(palfia): TF save list is not in sync with |
| 1579 // CPURegList::GetCalleeSaved(): x30 is missing. | 1597 // CPURegList::GetCalleeSaved(): x30 is missing. |
| 1580 // DCHECK(saves.list() == CPURegList::GetCalleeSaved().list()); | 1598 // DCHECK(saves.list() == CPURegList::GetCalleeSaved().list()); |
| 1581 CPURegList saves = CPURegList(CPURegister::kRegister, kXRegSizeInBits, | 1599 CPURegList saves = CPURegList(CPURegister::kRegister, kXRegSizeInBits, |
| 1582 descriptor->CalleeSavedRegisters()); | 1600 descriptor->CalleeSavedRegisters()); |
| 1583 saved_count = saves.Count(); | 1601 saved_count = saves.Count(); |
| 1584 if (saved_count != 0) { | 1602 if (saved_count != 0) { |
| 1585 __ PushCPURegList(saves); | 1603 __ PushCPURegList(saves); |
| 1586 frame()->AllocateSavedCalleeRegisterSlots(saved_count); | |
| 1587 } | 1604 } |
| 1588 } | 1605 } |
| 1589 | 1606 |
| 1590 | 1607 |
| 1591 void CodeGenerator::AssembleReturn() { | 1608 void CodeGenerator::AssembleReturn() { |
| 1592 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); | 1609 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); |
| 1593 | 1610 |
| 1594 // Restore registers. | 1611 // Restore registers. |
| 1595 CPURegList saves = CPURegList(CPURegister::kRegister, kXRegSizeInBits, | 1612 CPURegList saves = CPURegList(CPURegister::kRegister, kXRegSizeInBits, |
| 1596 descriptor->CalleeSavedRegisters()); | 1613 descriptor->CalleeSavedRegisters()); |
| (...skipping 217 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1814 padding_size -= kInstructionSize; | 1831 padding_size -= kInstructionSize; |
| 1815 } | 1832 } |
| 1816 } | 1833 } |
| 1817 } | 1834 } |
| 1818 | 1835 |
| 1819 #undef __ | 1836 #undef __ |
| 1820 | 1837 |
| 1821 } // namespace compiler | 1838 } // namespace compiler |
| 1822 } // namespace internal | 1839 } // namespace internal |
| 1823 } // namespace v8 | 1840 } // namespace v8 |
| OLD | NEW |