; RUN: | FileCheck %s --check-prefix=DWARF-V7-FP-ELIM
; RUN: llc -mtriple thumbv7-windows-gnu \
-; RUN: -filetype=asm -o - %s \
+; RUN: -filetype=asm -exception-model=dwarf -o - %s \
; RUN: | FileCheck %s --check-prefix=DWARF-WIN-FP-ELIM
+; RUN: llc -mtriple thumbv7-windows-gnu \
+; RUN: -filetype=asm -o - %s \
+; RUN: | FileCheck %s --check-prefix=SEH-WIN-FP-ELIM
+
;-------------------------------------------------------------------------------
; Test 1
;-------------------------------------------------------------------------------
; DWARF-WIN-FP-ELIM: pop {r4, pc}
; DWARF-WIN-FP-ELIM: .cfi_endproc
+; SEH-WIN-FP-ELIM-LABEL: _Z4testiiiiiddddd:
+; SEH-WIN-FP-ELIM: .seh_proc _Z4testiiiiiddddd
+; SEH-WIN-FP-ELIM: .seh_handler __gxx_personality_v0, %unwind, %except
+; SEH-WIN-FP-ELIM: push {r4, lr}
+; SEH-WIN-FP-ELIM: .seh_save_regs {r4, lr}
+; SEH-WIN-FP-ELIM: vpush {d8, d9, d10, d11, d12}
+; SEH-WIN-FP-ELIM: .seh_save_fregs {d8-d12}
+; SEH-WIN-FP-ELIM: sub sp, #8
+; SEH-WIN-FP-ELIM: .seh_stackalloc 8
+; SEH-WIN-FP-ELIM: .seh_endprologue
+; SEH-WIN-FP-ELIM: .seh_startepilogue
+; SEH-WIN-FP-ELIM: add sp, #8
+; SEH-WIN-FP-ELIM: .seh_stackalloc 8
+; SEH-WIN-FP-ELIM: vpop {d8, d9, d10, d11, d12}
+; SEH-WIN-FP-ELIM: .seh_save_fregs {d8-d12}
+; SEH-WIN-FP-ELIM: pop {r4, pc}
+; SEH-WIN-FP-ELIM: .seh_save_regs {r4, lr}
+; SEH-WIN-FP-ELIM: .seh_endepilogue
+; SEH-WIN-FP-ELIM: .seh_endproc
+
;-------------------------------------------------------------------------------
; Test 2
;-------------------------------------------------------------------------------
; DWARF-WIN-FP-ELIM: pop.w {r11, pc}
; DWARF-WIN-FP-ELIM: .cfi_endproc
+; SEH-WIN-FP-ELIM-LABEL: test2:
+; SEH-WIN-FP-ELIM: .seh_proc test2
+; SEH-WIN-FP-ELIM: push.w {r11, lr}
+; SEH-WIN-FP-ELIM: .seh_save_regs_w {r11, lr}
+; SEH-WIN-FP-ELIM: .seh_endprologue
+; SEH-WIN-FP-ELIM: .seh_startepilogue
+; SEH-WIN-FP-ELIM: pop.w {r11, pc}
+; SEH-WIN-FP-ELIM: .seh_endepilogue
+; SEH-WIN-FP-ELIM: .seh_endproc
+
;-------------------------------------------------------------------------------
; Test 3
; DWARF-WIN-FP-ELIM: pop.w {r4, r5, r11, pc}
; DWARF-WIN-FP-ELIM: .cfi_endproc
+; SEH-WIN-FP-ELIM-LABEL: test3:
+; SEH-WIN-FP-ELIM: .seh_proc test3
+; SEH-WIN-FP-ELIM: push.w {r4, r5, r11, lr}
+; SEH-WIN-FP-ELIM: .seh_save_regs_w {r4-r5, r11, lr}
+; SEH-WIN-FP-ELIM: .seh_endprologue
+; SEH-WIN-FP-ELIM: .seh_startepilogue
+; SEH-WIN-FP-ELIM: pop.w {r4, r5, r11, pc}
+; SEH-WIN-FP-ELIM: .seh_save_regs_w {r4-r5, r11, lr}
+; SEH-WIN-FP-ELIM: .seh_endepilogue
+; SEH-WIN-FP-ELIM: .seh_endproc
+
;-------------------------------------------------------------------------------
; Test 4
; DWARF-WIN-FP-ELIM-NOT: .cfi_startproc
; DWARF-WIN-FP-ELIM: bx lr
; DWARF-WIN-FP-ELIM-NOT: .cfi_endproc
+
+; SEH-WIN-FP-ELIM-LABEL: test4:
+; SEH-WIN-FP-ELIM-NOT: .seh_proc test4
+; SEH-WIN-FP-ELIM: bx lr
+; SEH-WIN-FP-ELIM-NOT: .seh_endproc