summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--llvm/lib/Target/ARM/MCTargetDesc/ARMMCAsmInfo.cpp6
-rw-r--r--llvm/lib/Target/ARM/MCTargetDesc/ARMWinCOFFStreamer.cpp7
-rw-r--r--llvm/test/CodeGen/ARM/ehabi.ll49
3 files changed, 59 insertions, 3 deletions
diff --git a/llvm/lib/Target/ARM/MCTargetDesc/ARMMCAsmInfo.cpp b/llvm/lib/Target/ARM/MCTargetDesc/ARMMCAsmInfo.cpp
index 608e1e01f8c..177b636077b 100644
--- a/llvm/lib/Target/ARM/MCTargetDesc/ARMMCAsmInfo.cpp
+++ b/llvm/lib/Target/ARM/MCTargetDesc/ARMMCAsmInfo.cpp
@@ -105,10 +105,10 @@ ARMCOFFMCAsmInfoGNU::ARMCOFFMCAsmInfoGNU() {
PrivateLabelPrefix = ".L";
SupportsDebugInformation = true;
- ExceptionsType = ExceptionHandling::None;
+ ExceptionsType = ExceptionHandling::DwarfCFI;
UseParensForSymbolVariant = true;
- UseIntegratedAssembler = false;
- DwarfRegNumForCFI = true;
+ UseIntegratedAssembler = true;
+ DwarfRegNumForCFI = false;
}
diff --git a/llvm/lib/Target/ARM/MCTargetDesc/ARMWinCOFFStreamer.cpp b/llvm/lib/Target/ARM/MCTargetDesc/ARMWinCOFFStreamer.cpp
index ba9246eafa9..a2424e1abab 100644
--- a/llvm/lib/Target/ARM/MCTargetDesc/ARMWinCOFFStreamer.cpp
+++ b/llvm/lib/Target/ARM/MCTargetDesc/ARMWinCOFFStreamer.cpp
@@ -23,6 +23,7 @@ public:
void EmitAssemblerFlag(MCAssemblerFlag Flag) override;
void EmitThumbFunc(MCSymbol *Symbol) override;
+ void FinishImpl() override;
};
void ARMWinCOFFStreamer::EmitAssemblerFlag(MCAssemblerFlag Flag) {
@@ -37,6 +38,12 @@ void ARMWinCOFFStreamer::EmitAssemblerFlag(MCAssemblerFlag Flag) {
void ARMWinCOFFStreamer::EmitThumbFunc(MCSymbol *Symbol) {
getAssembler().setIsThumbFunc(Symbol);
}
+
+void ARMWinCOFFStreamer::FinishImpl() {
+ EmitFrames(nullptr);
+
+ MCWinCOFFStreamer::FinishImpl();
+}
}
MCStreamer *llvm::createARMWinCOFFStreamer(
diff --git a/llvm/test/CodeGen/ARM/ehabi.ll b/llvm/test/CodeGen/ARM/ehabi.ll
index e2984de9ce4..f5a433b14bf 100644
--- a/llvm/test/CodeGen/ARM/ehabi.ll
+++ b/llvm/test/CodeGen/ARM/ehabi.ll
@@ -82,6 +82,10 @@
; RUN: -filetype=asm -o - %s \
; RUN: | FileCheck %s --check-prefix=DWARF-V7-FP-ELIM
+; RUN: llc -mtriple thumbv7-windows-gnu \
+; RUN: -filetype=asm -o - %s \
+; RUN: | FileCheck %s --check-prefix=DWARF-WIN-FP-ELIM
+
;-------------------------------------------------------------------------------
; Test 1
;-------------------------------------------------------------------------------
@@ -289,6 +293,26 @@ declare void @_ZSt9terminatev()
; DWARF-V7-FP-ELIM: pop {r4, pc}
; DWARF-V7-FP-ELIM: .cfi_endproc
+; DWARF-WIN-FP-ELIM-LABEL: _Z4testiiiiiddddd:
+; DWARF-WIN-FP-ELIM: .cfi_startproc
+; DWARF-WIN-FP-ELIM: .cfi_personality 0, __gxx_personality_v0
+; DWARF-WIN-FP-ELIM: .cfi_lsda 0, .Lexception0
+; DWARF-WIN-FP-ELIM: push {r4, lr}
+; DWARF-WIN-FP-ELIM: .cfi_def_cfa_offset 8
+; DWARF-WIN-FP-ELIM: .cfi_offset lr, -4
+; DWARF-WIN-FP-ELIM: .cfi_offset r4, -8
+; DWARF-WIN-FP-ELIM: vpush {d8, d9, d10, d11, d12}
+; DWARF-WIN-FP-ELIM: .cfi_offset d12, -16
+; DWARF-WIN-FP-ELIM: .cfi_offset d11, -24
+; DWARF-WIN-FP-ELIM: .cfi_offset d10, -32
+; DWARF-WIN-FP-ELIM: .cfi_offset d9, -40
+; DWARF-WIN-FP-ELIM: sub sp, #8
+; DWARF-WIN-FP-ELIM: .cfi_def_cfa_offset 56
+; DWARF-WIN-FP-ELIM: add sp, #8
+; DWARF-WIN-FP-ELIM: vpop {d8, d9, d10, d11, d12}
+; DWARF-WIN-FP-ELIM: pop {r4, pc}
+; DWARF-WIN-FP-ELIM: .cfi_endproc
+
;-------------------------------------------------------------------------------
; Test 2
;-------------------------------------------------------------------------------
@@ -377,6 +401,15 @@ entry:
; DWARF-V7-FP-ELIM: pop {r11, pc}
; DWARF-V7-FP-ELIM: .cfi_endproc
+; DWARF-WIN-FP-ELIM-LABEL: test2:
+; DWARF-WIN-FP-ELIM: .cfi_startproc
+; DWARF-WIN-FP-ELIM: push.w {r11, lr}
+; DWARF-WIN-FP-ELIM: .cfi_def_cfa_offset 8
+; DWARF-WIN-FP-ELIM: .cfi_offset lr, -4
+; DWARF-WIN-FP-ELIM: .cfi_offset r11, -8
+; DWARF-WIN-FP-ELIM: pop.w {r11, pc}
+; DWARF-WIN-FP-ELIM: .cfi_endproc
+
;-------------------------------------------------------------------------------
; Test 3
@@ -483,6 +516,17 @@ entry:
; DWARF-V7-FP-ELIM: pop {r4, r5, r11, pc}
; DWARF-V7-FP-ELIM: .cfi_endproc
+; DWARF-WIN-FP-ELIM-LABEL: test3:
+; DWARF-WIN-FP-ELIM: .cfi_startproc
+; DWARF-WIN-FP-ELIM: push.w {r4, r5, r11, lr}
+; DWARF-WIN-FP-ELIM: .cfi_def_cfa_offset 16
+; DWARF-WIN-FP-ELIM: .cfi_offset lr, -4
+; DWARF-WIN-FP-ELIM: .cfi_offset r11, -8
+; DWARF-WIN-FP-ELIM: .cfi_offset r5, -12
+; DWARF-WIN-FP-ELIM: .cfi_offset r4, -16
+; DWARF-WIN-FP-ELIM: pop.w {r4, r5, r11, pc}
+; DWARF-WIN-FP-ELIM: .cfi_endproc
+
;-------------------------------------------------------------------------------
; Test 4
@@ -540,3 +584,8 @@ entry:
; DWARF-V7-FP-ELIM: bx lr
; DWARF-V7-FP-ELIM-NOT: .cfi_endproc
; DWARF-V7-FP-ELIM: .size test4,
+
+; DWARF-WIN-FP-ELIM-LABEL: test4:
+; DWARF-WIN-FP-ELIM-NOT: .cfi_startproc
+; DWARF-WIN-FP-ELIM: bx lr
+; DWARF-WIN-FP-ELIM-NOT: .cfi_endproc
OpenPOWER on IntegriCloud