diff --git a/test/MC/AsmParser/directive_seh.s b/test/MC/AsmParser/directive_seh.s index 98fc6061f9d..1821747a2ba 100644 --- a/test/MC/AsmParser/directive_seh.s +++ b/test/MC/AsmParser/directive_seh.s @@ -1,36 +1,25 @@ # RUN: llvm-mc -triple x86_64-pc-win32 %s | FileCheck %s -# CHECK: .seh_proc func -# CHECK: .seh_pushframe @code -# CHECK: .seh_stackalloc 24 -# CHECK: .seh_savereg 6, 16 -# CHECK: .seh_savexmm 8, 0 -# CHECK: .seh_pushreg 3 -# CHECK: .seh_setframe 3, 0 -# CHECK: .seh_endprologue -# CHECK: .seh_handler __C_specific_handler, @except -# CHECK-NOT: .section{{.*}}.xdata -# CHECK: .seh_handlerdata -# CHECK: .text -# CHECK: .seh_startchained -# CHECK: .seh_endprologue -# CHECK: .seh_endchained -# CHECK: .seh_endproc - .text .globl func .def func; .scl 2; .type 32; .endef .seh_proc func +# CHECK: .seh_proc func func: .seh_pushframe @code +# CHECK: .seh_pushframe @code subq $24, %rsp .seh_stackalloc 24 +# CHECK: .seh_stackalloc 24 movq %rsi, 16(%rsp) .seh_savereg %rsi, 16 +# CHECK: .seh_savereg 6, 16 movups %xmm8, (%rsp) .seh_savexmm %xmm8, 0 +# CHECK: .seh_savexmm 8, 0 pushq %rbx .seh_pushreg 3 +# CHECK: .seh_pushreg 3 mov %rsp, %rbx .seh_setframe 3, 0 .seh_endprologue @@ -41,8 +30,18 @@ func: .seh_startchained .seh_endprologue .seh_endchained +# CHECK: .seh_setframe 3, 0 +# CHECK: .seh_endprologue +# CHECK: .seh_handler __C_specific_handler, @except +# CHECK-NOT: .section{{.*}}.xdata +# CHECK: .seh_handlerdata +# CHECK: .text +# CHECK: .seh_startchained +# CHECK: .seh_endprologue +# CHECK: .seh_endchained lea (%rbx), %rsp pop %rbx addq $24, %rsp ret .seh_endproc +# CHECK: .seh_endproc