| # RUN: llc -march=x86-64 -run-pass none -o - %s | FileCheck %s |
| # This test ensures that the MIR parser parses the stack protector stack |
| # object reference in the machine frame info correctly. |
| |
| --- | |
| @.str = private unnamed_addr constant [4 x i8] c"%s\0A\00", align 1 |
| @__stack_chk_guard = external global i8* |
| |
| define i32 @test() #0 { |
| entry: |
| %StackGuardSlot = alloca i8* |
| %StackGuard = load i8*, i8** @__stack_chk_guard |
| call void @llvm.stackprotector(i8* %StackGuard, i8** %StackGuardSlot) |
| %test = alloca i8*, align 8 |
| %a = alloca i8, i64 5 |
| store i8* %a, i8** %test, align 8 |
| %b = load i8*, i8** %test, align 8 |
| %call = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i8* %b) |
| call void @llvm.stackprotectorcheck(i8** @__stack_chk_guard) |
| ret i32 %call |
| } |
| |
| declare i32 @printf(i8*, ...) |
| |
| declare void @llvm.stackprotector(i8*, i8**) #1 |
| |
| declare void @llvm.stackprotectorcheck(i8**) #2 |
| |
| attributes #0 = { ssp "stack-protector-buffer-size"="5" } |
| attributes #1 = { nounwind } |
| attributes #2 = { nounwind argmemonly } |
| ... |
| --- |
| name: test |
| alignment: 4 |
| tracksRegLiveness: true |
| frameInfo: |
| stackSize: 40 |
| maxAlignment: 8 |
| adjustsStack: true |
| hasCalls: true |
| # CHECK-LABEL: name: test |
| # CHECK: frameInfo |
| # CHECK: stackProtector: '%stack.0.StackGuardSlot' |
| stackProtector: '%stack.0.StackGuardSlot' |
| fixedStack: |
| - { id: 0, type: spill-slot, offset: -16, size: 8, alignment: 16, |
| callee-saved-register: '$rbx' } |
| stack: |
| - { id: 0, name: StackGuardSlot, offset: -24, size: 8, alignment: 8 } |
| - { id: 1, name: test, offset: -40, size: 8, alignment: 8 } |
| - { id: 2, name: a, offset: -29, size: 5, alignment: 1 } |
| body: | |
| bb.0.entry: |
| successors: %bb.1.entry, %bb.2.entry |
| liveins: $rbx, $rbx |
| |
| frame-setup PUSH64r killed $rbx, implicit-def $rsp, implicit $rsp |
| $rsp = frame-setup SUB64ri8 $rsp, 32, implicit-def dead $eflags |
| $rbx = LOAD_STACK_GUARD :: (invariant load 8 from @__stack_chk_guard) |
| MOV64mr $rsp, 1, _, 24, _, $rbx |
| $rsi = LEA64r $rsp, 1, _, 19, _ |
| MOV64mr $rsp, 1, _, 8, _, $rsi |
| $rdi = LEA64r $rip, 1, _, @.str, _ |
| dead $eax = MOV32r0 implicit-def dead $eflags, implicit-def $al |
| CALL64pcrel32 @printf, csr_64, implicit $rsp, implicit $rdi, implicit $rsi, implicit $al, implicit-def $rsp, implicit-def $eax |
| CMP64rm killed $rbx, $rsp, 1, _, 24, _, implicit-def $eflags |
| JNE_1 %bb.2.entry, implicit $eflags |
| |
| bb.1.entry: |
| liveins: $eax |
| |
| $rsp = ADD64ri8 $rsp, 32, implicit-def dead $eflags |
| $rbx = POP64r implicit-def $rsp, implicit $rsp |
| RETQ $eax |
| |
| bb.2.entry: |
| CALL64pcrel32 &__stack_chk_fail, csr_64, implicit $rsp, implicit-def $rsp |
| ... |