mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-09-28 07:17:32 +00:00
Don't print an unused label before .cfi_endproc.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@147763 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -35,6 +35,7 @@ class MCObjectStreamer : public MCStreamer {
|
|||||||
|
|
||||||
virtual void EmitInstToData(const MCInst &Inst) = 0;
|
virtual void EmitInstToData(const MCInst &Inst) = 0;
|
||||||
virtual void EmitCFIStartProcImpl(MCDwarfFrameInfo &Frame);
|
virtual void EmitCFIStartProcImpl(MCDwarfFrameInfo &Frame);
|
||||||
|
virtual void EmitCFIEndProcImpl(MCDwarfFrameInfo &Frame);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
MCObjectStreamer(MCContext &Context, MCAsmBackend &TAB,
|
MCObjectStreamer(MCContext &Context, MCAsmBackend &TAB,
|
||||||
|
@@ -96,6 +96,8 @@ namespace llvm {
|
|||||||
|
|
||||||
void RecordProcStart(MCDwarfFrameInfo &Frame);
|
void RecordProcStart(MCDwarfFrameInfo &Frame);
|
||||||
virtual void EmitCFIStartProcImpl(MCDwarfFrameInfo &Frame);
|
virtual void EmitCFIStartProcImpl(MCDwarfFrameInfo &Frame);
|
||||||
|
void RecordProcEnd(MCDwarfFrameInfo &Frame);
|
||||||
|
virtual void EmitCFIEndProcImpl(MCDwarfFrameInfo &CurFrame);
|
||||||
void EmitFrames(bool usingCFI);
|
void EmitFrames(bool usingCFI);
|
||||||
|
|
||||||
MCWin64EHUnwindInfo *getCurrentW64UnwindInfo(){return CurrentW64UnwindInfo;}
|
MCWin64EHUnwindInfo *getCurrentW64UnwindInfo(){return CurrentW64UnwindInfo;}
|
||||||
@@ -539,7 +541,7 @@ namespace llvm {
|
|||||||
virtual void EmitCompactUnwindEncoding(uint32_t CompactUnwindEncoding);
|
virtual void EmitCompactUnwindEncoding(uint32_t CompactUnwindEncoding);
|
||||||
virtual void EmitCFISections(bool EH, bool Debug);
|
virtual void EmitCFISections(bool EH, bool Debug);
|
||||||
void EmitCFIStartProc();
|
void EmitCFIStartProc();
|
||||||
virtual void EmitCFIEndProc();
|
void EmitCFIEndProc();
|
||||||
virtual void EmitCFIDefCfa(int64_t Register, int64_t Offset);
|
virtual void EmitCFIDefCfa(int64_t Register, int64_t Offset);
|
||||||
virtual void EmitCFIDefCfaOffset(int64_t Offset);
|
virtual void EmitCFIDefCfaOffset(int64_t Offset);
|
||||||
virtual void EmitCFIDefCfaRegister(int64_t Register);
|
virtual void EmitCFIDefCfaRegister(int64_t Register);
|
||||||
|
@@ -62,6 +62,7 @@ private:
|
|||||||
|
|
||||||
void EmitRegisterName(int64_t Register);
|
void EmitRegisterName(int64_t Register);
|
||||||
virtual void EmitCFIStartProcImpl(MCDwarfFrameInfo &Frame);
|
virtual void EmitCFIStartProcImpl(MCDwarfFrameInfo &Frame);
|
||||||
|
virtual void EmitCFIEndProcImpl(MCDwarfFrameInfo &Frame);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MCAsmStreamer(MCContext &Context, formatted_raw_ostream &os,
|
MCAsmStreamer(MCContext &Context, formatted_raw_ostream &os,
|
||||||
@@ -210,7 +211,6 @@ public:
|
|||||||
StringRef FileName);
|
StringRef FileName);
|
||||||
|
|
||||||
virtual void EmitCFISections(bool EH, bool Debug);
|
virtual void EmitCFISections(bool EH, bool Debug);
|
||||||
virtual void EmitCFIEndProc();
|
|
||||||
virtual void EmitCFIDefCfa(int64_t Register, int64_t Offset);
|
virtual void EmitCFIDefCfa(int64_t Register, int64_t Offset);
|
||||||
virtual void EmitCFIDefCfaOffset(int64_t Offset);
|
virtual void EmitCFIDefCfaOffset(int64_t Offset);
|
||||||
virtual void EmitCFIDefCfaRegister(int64_t Register);
|
virtual void EmitCFIDefCfaRegister(int64_t Register);
|
||||||
@@ -851,11 +851,15 @@ void MCAsmStreamer::EmitCFIStartProcImpl(MCDwarfFrameInfo &Frame) {
|
|||||||
EmitEOL();
|
EmitEOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MCAsmStreamer::EmitCFIEndProc() {
|
void MCAsmStreamer::EmitCFIEndProcImpl(MCDwarfFrameInfo &Frame) {
|
||||||
MCStreamer::EmitCFIEndProc();
|
if (!UseCFI) {
|
||||||
|
RecordProcEnd(Frame);
|
||||||
if (!UseCFI)
|
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Put a dummy non-null value in Frame.End to mark that this frame has been
|
||||||
|
// closed.
|
||||||
|
Frame.End = (MCSymbol *) 1;
|
||||||
|
|
||||||
OS << "\t.cfi_endproc";
|
OS << "\t.cfi_endproc";
|
||||||
EmitEOL();
|
EmitEOL();
|
||||||
|
@@ -109,6 +109,10 @@ void MCObjectStreamer::EmitCFIStartProcImpl(MCDwarfFrameInfo &Frame) {
|
|||||||
RecordProcStart(Frame);
|
RecordProcStart(Frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MCObjectStreamer::EmitCFIEndProcImpl(MCDwarfFrameInfo &Frame) {
|
||||||
|
RecordProcEnd(Frame);
|
||||||
|
}
|
||||||
|
|
||||||
void MCObjectStreamer::EmitLabel(MCSymbol *Symbol) {
|
void MCObjectStreamer::EmitLabel(MCSymbol *Symbol) {
|
||||||
MCStreamer::EmitLabel(Symbol);
|
MCStreamer::EmitLabel(Symbol);
|
||||||
|
|
||||||
|
@@ -301,8 +301,15 @@ void MCStreamer::RecordProcStart(MCDwarfFrameInfo &Frame) {
|
|||||||
void MCStreamer::EmitCFIEndProc() {
|
void MCStreamer::EmitCFIEndProc() {
|
||||||
EnsureValidFrame();
|
EnsureValidFrame();
|
||||||
MCDwarfFrameInfo *CurFrame = getCurrentFrameInfo();
|
MCDwarfFrameInfo *CurFrame = getCurrentFrameInfo();
|
||||||
CurFrame->End = getContext().CreateTempSymbol();
|
EmitCFIEndProcImpl(*CurFrame);
|
||||||
EmitLabel(CurFrame->End);
|
}
|
||||||
|
|
||||||
|
void MCStreamer::EmitCFIEndProcImpl(MCDwarfFrameInfo &Frame) {
|
||||||
|
}
|
||||||
|
|
||||||
|
void MCStreamer::RecordProcEnd(MCDwarfFrameInfo &Frame) {
|
||||||
|
Frame.End = getContext().CreateTempSymbol();
|
||||||
|
EmitLabel(Frame.End);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MCStreamer::EmitCFIDefCfa(int64_t Register, int64_t Offset) {
|
void MCStreamer::EmitCFIDefCfa(int64_t Register, int64_t Offset) {
|
||||||
|
@@ -6,9 +6,9 @@ target triple = "thumbv7-apple-macosx10.6.7"
|
|||||||
;CHECK: Ldebug_loc0:
|
;CHECK: Ldebug_loc0:
|
||||||
;CHECK-NEXT: .long Ltmp0
|
;CHECK-NEXT: .long Ltmp0
|
||||||
;CHECK-NEXT: .long Ltmp1
|
;CHECK-NEXT: .long Ltmp1
|
||||||
;CHECK-NEXT: Lset[[N:[0-9]+]] = Ltmp9-Ltmp8 @ Loc expr size
|
;CHECK-NEXT: Lset[[N:[0-9]+]] = Ltmp8-Ltmp7 @ Loc expr size
|
||||||
;CHECK-NEXT: .short Lset[[N]]
|
;CHECK-NEXT: .short Lset[[N]]
|
||||||
;CHECK-NEXT: Ltmp8:
|
;CHECK-NEXT: Ltmp7:
|
||||||
;CHECK-NEXT: .byte 144 @ DW_OP_regx for S register
|
;CHECK-NEXT: .byte 144 @ DW_OP_regx for S register
|
||||||
|
|
||||||
define void @_Z3foov() optsize ssp {
|
define void @_Z3foov() optsize ssp {
|
||||||
|
@@ -10,7 +10,7 @@ target triple = "x86_64-apple-darwin8"
|
|||||||
;CHECK-NEXT: .short Lset
|
;CHECK-NEXT: .short Lset
|
||||||
;CHECK-NEXT: Ltmp
|
;CHECK-NEXT: Ltmp
|
||||||
;CHECK-NEXT: .byte 85 ## DW_OP_reg5
|
;CHECK-NEXT: .byte 85 ## DW_OP_reg5
|
||||||
;CHECK-NEXT: Ltmp6
|
;CHECK-NEXT: Ltmp5
|
||||||
;CHECK-NEXT: .quad 0
|
;CHECK-NEXT: .quad 0
|
||||||
;CHECK-NEXT: .quad 0
|
;CHECK-NEXT: .quad 0
|
||||||
|
|
||||||
|
@@ -8,7 +8,6 @@ entry:
|
|||||||
; CHECK-NO-FP: _func:
|
; CHECK-NO-FP: _func:
|
||||||
; CHECK-NO-FP-NEXT: .cfi_startproc
|
; CHECK-NO-FP-NEXT: .cfi_startproc
|
||||||
; CHECK-NO-FP: nop
|
; CHECK-NO-FP: nop
|
||||||
; CHECK-NO-FP-NEXT: :
|
|
||||||
; CHECK-NO-FP-NEXT: .cfi_endproc
|
; CHECK-NO-FP-NEXT: .cfi_endproc
|
||||||
|
|
||||||
; CHECK-FP: _func:
|
; CHECK-FP: _func:
|
||||||
@@ -23,5 +22,4 @@ entry:
|
|||||||
; CHECK-FP-NEXT: :
|
; CHECK-FP-NEXT: :
|
||||||
; CHECK-FP-NEXT: .cfi_def_cfa_register %rbp
|
; CHECK-FP-NEXT: .cfi_def_cfa_register %rbp
|
||||||
; CHECK-FP-NEXT: nop
|
; CHECK-FP-NEXT: nop
|
||||||
; CHECK-FP-NEXT: :
|
|
||||||
; CHECK-FP-NEXT: .cfi_endproc
|
; CHECK-FP-NEXT: .cfi_endproc
|
||||||
|
Reference in New Issue
Block a user