1*9880d681SAndroid Build Coastguard Worker; RUN: llc -stack-symbol-ordering=0 -mtriple=x86_64-windows-msvc < %s | FileCheck %s --check-prefix=X64 2*9880d681SAndroid Build Coastguard Worker; RUN: llc -stack-symbol-ordering=0 -mtriple=i686-windows-msvc < %s | FileCheck %s --check-prefix=X86 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.va_start(i8*) 5*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.va_end(i8*) 6*9880d681SAndroid Build Coastguard Workerdeclare i32 @__CxxFrameHandler3(...) 7*9880d681SAndroid Build Coastguard Workerdeclare void @g() 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Workerdefine i32 @f(i32 %a, ...) personality i32 (...)* @__CxxFrameHandler3 { 10*9880d681SAndroid Build Coastguard Workerentry: 11*9880d681SAndroid Build Coastguard Worker %ap = alloca i8* 12*9880d681SAndroid Build Coastguard Worker invoke void @g() 13*9880d681SAndroid Build Coastguard Worker to label %return unwind label %catch.dispatch 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Workercatch.dispatch: ; preds = %entry 16*9880d681SAndroid Build Coastguard Worker %cs1 = catchswitch within none [label %catch] unwind to caller 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Workercatch: ; preds = %catch.dispatch 19*9880d681SAndroid Build Coastguard Worker %0 = catchpad within %cs1 [i8* null, i32 64, i8* null] 20*9880d681SAndroid Build Coastguard Worker %ap1 = bitcast i8** %ap to i8* 21*9880d681SAndroid Build Coastguard Worker call void @llvm.va_start(i8* %ap1) 22*9880d681SAndroid Build Coastguard Worker %argp.cur = load i8*, i8** %ap 23*9880d681SAndroid Build Coastguard Worker %1 = bitcast i8* %argp.cur to i32* 24*9880d681SAndroid Build Coastguard Worker %arg2 = load i32, i32* %1 25*9880d681SAndroid Build Coastguard Worker call void @llvm.va_end(i8* %ap1) 26*9880d681SAndroid Build Coastguard Worker catchret from %0 to label %return 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Workerreturn: ; preds = %entry, %catch 29*9880d681SAndroid Build Coastguard Worker %retval.0 = phi i32 [ %arg2, %catch ], [ -1, %entry ] 30*9880d681SAndroid Build Coastguard Worker ret i32 %retval.0 31*9880d681SAndroid Build Coastguard Worker} 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Worker; X64-LABEL: .seh_proc f 34*9880d681SAndroid Build Coastguard Worker; X64: pushq %rbp 35*9880d681SAndroid Build Coastguard Worker; X64: subq $64, %rsp 36*9880d681SAndroid Build Coastguard Worker; X64: leaq 64(%rsp), %rbp 37*9880d681SAndroid Build Coastguard Worker; X64: movq $-2, -8(%rbp) 38*9880d681SAndroid Build Coastguard Worker; X64: movl $-1, -20(%rbp) # 4-byte Folded Spill 39*9880d681SAndroid Build Coastguard Worker; X64: callq g 40*9880d681SAndroid Build Coastguard Worker; X64: .LBB0_1 41*9880d681SAndroid Build Coastguard Worker; X64: movl -20(%rbp), %eax # 4-byte Reload 42*9880d681SAndroid Build Coastguard Worker; X64: addq $64, %rsp 43*9880d681SAndroid Build Coastguard Worker; X64: popq %rbp 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; X64-LABEL: "?catch${{[0-9]}}@?0?f@4HA": 46*9880d681SAndroid Build Coastguard Worker; X64: .seh_proc "?catch${{[0-9]}}@?0?f@4HA" 47*9880d681SAndroid Build Coastguard Worker; X64: movq %rdx, 16(%rsp) 48*9880d681SAndroid Build Coastguard Worker; X64: pushq %rbp 49*9880d681SAndroid Build Coastguard Worker; X64: subq $32, %rsp 50*9880d681SAndroid Build Coastguard Worker; X64: leaq 64(%rdx), %rbp 51*9880d681SAndroid Build Coastguard Worker; arg2 is at RBP+40: 52*9880d681SAndroid Build Coastguard Worker; start at arg2 53*9880d681SAndroid Build Coastguard Worker; + 8 for arg1 54*9880d681SAndroid Build Coastguard Worker; + 8 for retaddr 55*9880d681SAndroid Build Coastguard Worker; + 8 for RBP 56*9880d681SAndroid Build Coastguard Worker; + 64 for stackalloc 57*9880d681SAndroid Build Coastguard Worker; - 64 for setframe 58*9880d681SAndroid Build Coastguard Worker; = 40 59*9880d681SAndroid Build Coastguard Worker; X64: movl 24(%rbp), %eax 60*9880d681SAndroid Build Coastguard Worker; X64: movl %eax, -20(%rbp) # 4-byte Spill 61*9880d681SAndroid Build Coastguard Worker; X64: leaq .LBB0_1(%rip), %rax 62*9880d681SAndroid Build Coastguard Worker; X64: addq $32, %rsp 63*9880d681SAndroid Build Coastguard Worker; X64: popq %rbp 64*9880d681SAndroid Build Coastguard Worker; X64: retq # CATCHRET 65*9880d681SAndroid Build Coastguard Worker 66*9880d681SAndroid Build Coastguard Worker; X86-LABEL: _f: # @f 67*9880d681SAndroid Build Coastguard Worker; X86: pushl %ebp 68*9880d681SAndroid Build Coastguard Worker; X86: movl %esp, %ebp 69*9880d681SAndroid Build Coastguard Worker; X86: pushl %ebx 70*9880d681SAndroid Build Coastguard Worker; X86: pushl %edi 71*9880d681SAndroid Build Coastguard Worker; X86: pushl %esi 72*9880d681SAndroid Build Coastguard Worker; X86: subl $24, %esp 73*9880d681SAndroid Build Coastguard Worker; X86: movl $-1, -36(%ebp) 74*9880d681SAndroid Build Coastguard Worker; X86: calll _g 75*9880d681SAndroid Build Coastguard Worker; X86: LBB0_[[retbb:[0-9]+]]: 76*9880d681SAndroid Build Coastguard Worker; X86: movl -36(%ebp), %eax 77*9880d681SAndroid Build Coastguard Worker; X86: addl $24, %esp 78*9880d681SAndroid Build Coastguard Worker; X86: popl %esi 79*9880d681SAndroid Build Coastguard Worker; X86: popl %edi 80*9880d681SAndroid Build Coastguard Worker; X86: popl %ebx 81*9880d681SAndroid Build Coastguard Worker; X86: popl %ebp 82*9880d681SAndroid Build Coastguard Worker; X86: retl 83*9880d681SAndroid Build Coastguard Worker 84*9880d681SAndroid Build Coastguard Worker; X86: LBB0_[[restorebb:[0-9]+]]: # Block address taken 85*9880d681SAndroid Build Coastguard Worker; X86: addl $12, %ebp 86*9880d681SAndroid Build Coastguard Worker; arg2 is at EBP offset 12: 87*9880d681SAndroid Build Coastguard Worker; + 4 for arg1 88*9880d681SAndroid Build Coastguard Worker; + 4 for retaddr 89*9880d681SAndroid Build Coastguard Worker; + 4 for EBP 90*9880d681SAndroid Build Coastguard Worker; X86: movl 12(%ebp), %eax 91*9880d681SAndroid Build Coastguard Worker; X86: movl %eax, -36(%ebp) 92*9880d681SAndroid Build Coastguard Worker; X86: jmp LBB0_[[retbb]] 93*9880d681SAndroid Build Coastguard Worker 94*9880d681SAndroid Build Coastguard Worker; X86-LABEL: "?catch${{[0-9]}}@?0?f@4HA": 95*9880d681SAndroid Build Coastguard Worker; X86: pushl %ebp 96*9880d681SAndroid Build Coastguard Worker; X86: addl $12, %ebp 97*9880d681SAndroid Build Coastguard Worker; Done due to mov %esp, %ebp 98*9880d681SAndroid Build Coastguard Worker; X86: leal 12(%ebp), %eax 99*9880d681SAndroid Build Coastguard Worker; X86: movl $LBB0_[[restorebb]], %eax 100*9880d681SAndroid Build Coastguard Worker; X86: popl %ebp 101*9880d681SAndroid Build Coastguard Worker; X86: retl # CATCHRET 102