| ; RUN: llc -stack-symbol-ordering=0 -mtriple=x86_64-windows-msvc < %s | FileCheck %s --check-prefix=X64 |
| ; RUN: llc -stack-symbol-ordering=0 -mtriple=i686-windows-msvc < %s | FileCheck %s --check-prefix=X86 |
| |
| declare void @llvm.va_start(i8*) |
| declare void @llvm.va_end(i8*) |
| declare i32 @__CxxFrameHandler3(...) |
| declare void @g() |
| |
| define i32 @f(i32 %a, ...) personality i32 (...)* @__CxxFrameHandler3 { |
| entry: |
| %ap = alloca i8* |
| invoke void @g() |
| to label %return unwind label %catch.dispatch |
| |
| catch.dispatch: ; preds = %entry |
| %cs1 = catchswitch within none [label %catch] unwind to caller |
| |
| catch: ; preds = %catch.dispatch |
| %0 = catchpad within %cs1 [i8* null, i32 64, i8* null] |
| %ap1 = bitcast i8** %ap to i8* |
| call void @llvm.va_start(i8* %ap1) |
| %argp.cur = load i8*, i8** %ap |
| %1 = bitcast i8* %argp.cur to i32* |
| %arg2 = load i32, i32* %1 |
| call void @llvm.va_end(i8* %ap1) |
| catchret from %0 to label %return |
| |
| return: ; preds = %entry, %catch |
| %retval.0 = phi i32 [ %arg2, %catch ], [ -1, %entry ] |
| ret i32 %retval.0 |
| } |
| |
| ; X64-LABEL: .seh_proc f |
| ; X64: pushq %rbp |
| ; X64: subq $64, %rsp |
| ; X64: leaq 64(%rsp), %rbp |
| ; X64: movq $-2, -8(%rbp) |
| ; X64: movl $-1, -20(%rbp) # 4-byte Folded Spill |
| ; X64: callq g |
| ; X64: .LBB0_1 |
| ; X64: movl -20(%rbp), %eax # 4-byte Reload |
| ; X64: addq $64, %rsp |
| ; X64: popq %rbp |
| |
| ; X64-LABEL: "?catch${{[0-9]}}@?0?f@4HA": |
| ; X64: .seh_proc "?catch${{[0-9]}}@?0?f@4HA" |
| ; X64: movq %rdx, 16(%rsp) |
| ; X64: pushq %rbp |
| ; X64: subq $32, %rsp |
| ; X64: leaq 64(%rdx), %rbp |
| ; arg2 is at RBP+40: |
| ; start at arg2 |
| ; + 8 for arg1 |
| ; + 8 for retaddr |
| ; + 8 for RBP |
| ; + 64 for stackalloc |
| ; - 64 for setframe |
| ; = 40 |
| ; X64: movl 24(%rbp), %eax |
| ; X64: movl %eax, -20(%rbp) # 4-byte Spill |
| ; X64: leaq .LBB0_1(%rip), %rax |
| ; X64: addq $32, %rsp |
| ; X64: popq %rbp |
| ; X64: retq # CATCHRET |
| |
| ; X86-LABEL: _f: # @f |
| ; X86: pushl %ebp |
| ; X86: movl %esp, %ebp |
| ; X86: pushl %ebx |
| ; X86: pushl %edi |
| ; X86: pushl %esi |
| ; X86: subl $24, %esp |
| ; X86: movl $-1, -36(%ebp) |
| ; X86: calll _g |
| ; X86: LBB0_[[retbb:[0-9]+]]: |
| ; X86: movl -36(%ebp), %eax |
| ; X86: addl $24, %esp |
| ; X86: popl %esi |
| ; X86: popl %edi |
| ; X86: popl %ebx |
| ; X86: popl %ebp |
| ; X86: retl |
| |
| ; X86: LBB0_[[restorebb:[0-9]+]]: # Block address taken |
| ; X86: addl $12, %ebp |
| ; arg2 is at EBP offset 12: |
| ; + 4 for arg1 |
| ; + 4 for retaddr |
| ; + 4 for EBP |
| ; X86: movl 12(%ebp), %eax |
| ; X86: movl %eax, -36(%ebp) |
| ; X86: jmp LBB0_[[retbb]] |
| |
| ; X86-LABEL: "?catch${{[0-9]}}@?0?f@4HA": |
| ; X86: pushl %ebp |
| ; X86: addl $12, %ebp |
| ; Done due to mov %esp, %ebp |
| ; X86: leal 12(%ebp), %eax |
| ; X86: movl $LBB0_[[restorebb]], %eax |
| ; X86: popl %ebp |
| ; X86: retl # CATCHRET |