mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 02:32:11 +00:00
Thumb1 frame lowering: Mark CFI instructions with the FrameSetup flag.
Followup to r224294: ARM/AArch64: Attach the FrameSetup MIFlag to CFI instructions. Debug info marks the first instruction without the FrameSetup flag as being the end of the function prologue. Any CFI instructions in the middle of the function prologue would cause debug info to end the prologue too early and worse, attach the line number of the CFI instruction, which incidentally is often 0. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@224743 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
67924e9af8
commit
f5a21eaa18
@ -124,7 +124,8 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||||||
unsigned CFIIndex = MMI.addFrameInst(
|
unsigned CFIIndex = MMI.addFrameInst(
|
||||||
MCCFIInstruction::createDefCfaOffset(nullptr, CFAOffset));
|
MCCFIInstruction::createDefCfaOffset(nullptr, CFAOffset));
|
||||||
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||||
.addCFIIndex(CFIIndex);
|
.addCFIIndex(CFIIndex)
|
||||||
|
.setMIFlags(MachineInstr::FrameSetup);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!AFI->hasStackFrame()) {
|
if (!AFI->hasStackFrame()) {
|
||||||
@ -135,7 +136,8 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||||||
unsigned CFIIndex = MMI.addFrameInst(
|
unsigned CFIIndex = MMI.addFrameInst(
|
||||||
MCCFIInstruction::createDefCfaOffset(nullptr, CFAOffset));
|
MCCFIInstruction::createDefCfaOffset(nullptr, CFAOffset));
|
||||||
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||||
.addCFIIndex(CFIIndex);
|
.addCFIIndex(CFIIndex)
|
||||||
|
.setMIFlags(MachineInstr::FrameSetup);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -199,7 +201,8 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||||||
unsigned CFIIndex = MMI.addFrameInst(
|
unsigned CFIIndex = MMI.addFrameInst(
|
||||||
MCCFIInstruction::createDefCfaOffset(nullptr, CFAOffset));
|
MCCFIInstruction::createDefCfaOffset(nullptr, CFAOffset));
|
||||||
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||||
.addCFIIndex(CFIIndex);
|
.addCFIIndex(CFIIndex)
|
||||||
|
.setMIFlags(MachineInstr::FrameSetup);
|
||||||
}
|
}
|
||||||
for (std::vector<CalleeSavedInfo>::const_iterator I = CSI.begin(),
|
for (std::vector<CalleeSavedInfo>::const_iterator I = CSI.begin(),
|
||||||
E = CSI.end(); I != E; ++I) {
|
E = CSI.end(); I != E; ++I) {
|
||||||
@ -226,7 +229,8 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||||||
unsigned CFIIndex = MMI.addFrameInst(MCCFIInstruction::createOffset(
|
unsigned CFIIndex = MMI.addFrameInst(MCCFIInstruction::createOffset(
|
||||||
nullptr, MRI->getDwarfRegNum(Reg, true), MFI->getObjectOffset(FI)));
|
nullptr, MRI->getDwarfRegNum(Reg, true), MFI->getObjectOffset(FI)));
|
||||||
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||||
.addCFIIndex(CFIIndex);
|
.addCFIIndex(CFIIndex)
|
||||||
|
.setMIFlags(MachineInstr::FrameSetup);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -244,13 +248,15 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||||||
unsigned CFIIndex = MMI.addFrameInst(MCCFIInstruction::createDefCfa(
|
unsigned CFIIndex = MMI.addFrameInst(MCCFIInstruction::createDefCfa(
|
||||||
nullptr, MRI->getDwarfRegNum(FramePtr, true), CFAOffset));
|
nullptr, MRI->getDwarfRegNum(FramePtr, true), CFAOffset));
|
||||||
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||||
.addCFIIndex(CFIIndex);
|
.addCFIIndex(CFIIndex)
|
||||||
|
.setMIFlags(MachineInstr::FrameSetup);
|
||||||
} else {
|
} else {
|
||||||
unsigned CFIIndex =
|
unsigned CFIIndex =
|
||||||
MMI.addFrameInst(MCCFIInstruction::createDefCfaRegister(
|
MMI.addFrameInst(MCCFIInstruction::createDefCfaRegister(
|
||||||
nullptr, MRI->getDwarfRegNum(FramePtr, true)));
|
nullptr, MRI->getDwarfRegNum(FramePtr, true)));
|
||||||
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||||
.addCFIIndex(CFIIndex);
|
.addCFIIndex(CFIIndex)
|
||||||
|
.setMIFlags(MachineInstr::FrameSetup);
|
||||||
}
|
}
|
||||||
if (NumBytes > 508)
|
if (NumBytes > 508)
|
||||||
// If offset is > 508 then sp cannot be adjusted in a single instruction,
|
// If offset is > 508 then sp cannot be adjusted in a single instruction,
|
||||||
@ -267,7 +273,8 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||||||
unsigned CFIIndex = MMI.addFrameInst(
|
unsigned CFIIndex = MMI.addFrameInst(
|
||||||
MCCFIInstruction::createDefCfaOffset(nullptr, CFAOffset));
|
MCCFIInstruction::createDefCfaOffset(nullptr, CFAOffset));
|
||||||
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||||
.addCFIIndex(CFIIndex);
|
.addCFIIndex(CFIIndex)
|
||||||
|
.setMIFlags(MachineInstr::FrameSetup);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,7 +14,8 @@
|
|||||||
; The location of the prologue_end marker should not be affected by the presence
|
; The location of the prologue_end marker should not be affected by the presence
|
||||||
; of CFI instructions.
|
; of CFI instructions.
|
||||||
|
|
||||||
; RUN: llc -O0 -filetype=asm < %s | FileCheck %s
|
; RUN: llc -O0 -filetype=asm -mtriple=thumbv7-apple-ios < %s | FileCheck %s
|
||||||
|
; RUN: llc -O0 -filetype=asm -mtriple=thumbv6-apple-ios < %s | FileCheck %s
|
||||||
|
|
||||||
; ModuleID = 'test1.cpp'
|
; ModuleID = 'test1.cpp'
|
||||||
target datalayout = "e-m:o-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32"
|
target datalayout = "e-m:o-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user