1 # RUN: llc -mtriple=x86_64-unknown-linux-gnu -mcpu=corei7 -no-stack-coloring=false -run-pass stack-coloring -o - %s
3 # Test to insure that the liveness analysis in the StackColoring
4 # pass gracefully handles statically unreachable blocks. See PR 37310.
6 # This MIR testcase was created by compiling the following test, first
7 # with "clang -emit-llvm -S" and then "llc -stop-before stack-coloring",
8 # and finally editing the resulting MIR by hand to introduce a statically
9 # unreachable BB (to wit: rename all bb.3 to bb.4, rename bb.2 to bb.3,
10 # then add bb.2 with unconditional jump to bb.4).
13 # extern int inita(int *);
26 define void @foo(i32 %x) {
28 %q = alloca [128 x i32], align 16
29 %r = alloca [128 x i32], align 16
30 %cmp = icmp eq i32 %x, 3
31 br i1 %cmp, label %if.end, label %if.then
33 if.then: ; preds = %entry
34 %0 = bitcast [128 x i32]* %q to i8*
35 call void @llvm.lifetime.start.p0i8(i64 512, i8* nonnull %0)
36 %arrayidx2 = bitcast [128 x i32]* %q to i32*
37 %call = call i32 @inita(i32* nonnull %arrayidx2)
38 call void @llvm.lifetime.end.p0i8(i64 512, i8* nonnull %0)
44 if.end: ; preds = %entry
45 %1 = bitcast [128 x i32]* %r to i8*
46 call void @llvm.lifetime.start.p0i8(i64 512, i8* nonnull %1)
47 %arrayidx1 = getelementptr inbounds [128 x i32], [128 x i32]* %r, i64 0, i64 3
48 %call2 = call i32 @inita(i32* nonnull %arrayidx1)
49 call void @llvm.lifetime.end.p0i8(i64 512, i8* nonnull %1)
52 return: ; preds = %if.end, %if.then
56 declare void @llvm.lifetime.start.p0i8(i64, i8* nocapture)
58 declare i32 @inita(i32*)
60 declare void @llvm.lifetime.end.p0i8(i64, i8* nocapture)
62 declare void @llvm.stackprotector(i8*, i8**)
68 exposesReturnsTwice: false
70 regBankSelected: false
73 tracksRegLiveness: true
75 - { id: 0, class: gr32, preferred-register: '' }
76 - { id: 1, class: gr32, preferred-register: '' }
77 - { id: 2, class: gr64, preferred-register: '' }
78 - { id: 3, class: gr32, preferred-register: '' }
79 - { id: 4, class: gr64, preferred-register: '' }
80 - { id: 5, class: gr32, preferred-register: '' }
84 isFrameAddressTaken: false
85 isReturnAddressTaken: false
94 maxCallFrameSize: 4294967295
95 hasOpaqueSPAdjustment: false
97 hasMustTailInVarArgFunc: false
103 - { id: 0, name: q, type: default, offset: 0, size: 512, alignment: 16,
104 stack-id: 0, callee-saved-register: '', callee-saved-restored: true,
105 debug-info-variable: '', debug-info-expression: '', debug-info-location: '' }
106 - { id: 1, name: r, type: default, offset: 0, size: 512, alignment: 16,
107 stack-id: 0, callee-saved-register: '', callee-saved-restored: true,
108 debug-info-variable: '', debug-info-expression: '', debug-info-location: '' }
112 successors: %bb.3(0x40000000), %bb.1(0x40000000)
116 %1:gr32 = SUB32ri8 %0, 3, implicit-def $eflags
117 JE_1 %bb.3, implicit $eflags
121 successors: %bb.4(0x80000000)
123 LIFETIME_START %stack.0.q
124 ADJCALLSTACKDOWN64 0, 0, 0, implicit-def dead $rsp, implicit-def dead $eflags, implicit-def dead $ssp, implicit $rsp, implicit $ssp
125 %2:gr64 = LEA64r %stack.0.q, 1, $noreg, 0, $noreg
127 CALL64pcrel32 @inita, csr_64, implicit $rsp, implicit $ssp, implicit $rdi, implicit-def $rsp, implicit-def $ssp, implicit-def $eax
128 ADJCALLSTACKUP64 0, 0, implicit-def dead $rsp, implicit-def dead $eflags, implicit-def dead $ssp, implicit $rsp, implicit $ssp
130 LIFETIME_END %stack.0.q
134 successors: %bb.4(0x80000000)
139 successors: %bb.4(0x80000000)
141 LIFETIME_START %stack.1.r
142 %4:gr64 = LEA64r %stack.1.r, 1, $noreg, 12, $noreg
143 ADJCALLSTACKDOWN64 0, 0, 0, implicit-def dead $rsp, implicit-def dead $eflags, implicit-def dead $ssp, implicit $rsp, implicit $ssp
145 CALL64pcrel32 @inita, csr_64, implicit $rsp, implicit $ssp, implicit $rdi, implicit-def $rsp, implicit-def $ssp, implicit-def $eax
146 ADJCALLSTACKUP64 0, 0, implicit-def dead $rsp, implicit-def dead $eflags, implicit-def dead $ssp, implicit $rsp, implicit $ssp
148 LIFETIME_END %stack.1.r