[MIParser] Set RegClassOrRegBank during instruction parsing
[llvm-complete.git] / test / CodeGen / MIR / X86 / frame-info-stack-references.mir
blob4083e889cc0dedd983533787236b73b0c396ce34
1 # RUN: llc -march=x86-64 -run-pass none -o - %s | FileCheck %s
2 # This test ensures that the MIR parser parses the stack protector stack
3 # object reference in the machine frame info correctly.
5 --- |
6   @.str = private unnamed_addr constant [4 x i8] c"%s\0A\00", align 1
7   @__stack_chk_guard = external global i8*
9   define i32 @test() #0 {
10   entry:
11     %StackGuardSlot = alloca i8*
12     %StackGuard = load i8*, i8** @__stack_chk_guard
13     call void @llvm.stackprotector(i8* %StackGuard, i8** %StackGuardSlot)
14     %test = alloca i8*, align 8
15     %a = alloca i8, i64 5
16     store i8* %a, i8** %test, align 8
17     %b = load i8*, i8** %test, align 8
18     %call = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i8* %b)
19     call void @llvm.stackprotectorcheck(i8** @__stack_chk_guard)
20     ret i32 %call
21   }
23   declare i32 @printf(i8*, ...)
25   declare void @llvm.stackprotector(i8*, i8**) #1
27   declare void @llvm.stackprotectorcheck(i8**) #2
29   attributes #0 = { ssp "stack-protector-buffer-size"="5" }
30   attributes #1 = { nounwind }
31   attributes #2 = { nounwind argmemonly }
32 ...
33 ---
34 name:            test
35 alignment:       16
36 tracksRegLiveness: true
37 frameInfo:
38   stackSize:       40
39   maxAlignment:    8
40   adjustsStack:    true
41   hasCalls:        true
42 # CHECK-LABEL: name: test
43 # CHECK: frameInfo
44 # CHECK: stackProtector: '%stack.0.StackGuardSlot'
45   stackProtector:  '%stack.0.StackGuardSlot'
46 fixedStack:
47   - { id: 0, type: spill-slot, offset: -16, size: 8, alignment: 16,
48       callee-saved-register: '$rbx' }
49 stack:
50   - { id: 0, name: StackGuardSlot, offset: -24, size: 8, alignment: 8 }
51   - { id: 1, name: test, offset: -40, size: 8, alignment: 8 }
52   - { id: 2, name: a, offset: -29, size: 5, alignment: 1 }
53 body: |
54   bb.0.entry:
55     successors: %bb.1.entry, %bb.2.entry
56     liveins: $rbx, $rbx
58     frame-setup PUSH64r killed $rbx, implicit-def $rsp, implicit $rsp
59     $rsp = frame-setup SUB64ri8 $rsp, 32, implicit-def dead $eflags
60     $rbx = LOAD_STACK_GUARD :: (invariant load 8 from @__stack_chk_guard)
61     MOV64mr $rsp, 1, _, 24, _, $rbx
62     $rsi = LEA64r $rsp, 1, _, 19, _
63     MOV64mr $rsp, 1, _, 8, _, $rsi
64     $rdi = LEA64r $rip, 1, _, @.str, _
65     dead $eax = MOV32r0 implicit-def dead $eflags, implicit-def $al
66     CALL64pcrel32 @printf, csr_64, implicit $rsp, implicit $rdi, implicit $rsi, implicit $al, implicit-def $rsp, implicit-def $eax
67     CMP64rm killed $rbx, $rsp, 1, _, 24, _, implicit-def $eflags
68     JCC_1 %bb.2.entry, 5, implicit $eflags
70   bb.1.entry:
71     liveins: $eax
73     $rsp = ADD64ri8 $rsp, 32, implicit-def dead $eflags
74     $rbx = POP64r implicit-def $rsp, implicit $rsp
75     RETQ $eax
77   bb.2.entry:
78     CALL64pcrel32 &__stack_chk_fail, csr_64, implicit $rsp, implicit-def $rsp
79 ...