[InstCombine] Signed saturation patterns
[llvm-core.git] / test / CodeGen / X86 / shrink-wrap-chkstk.ll
blob1364732813ad45fb30bfaa6086b6bba70b126f84
1 ; RUN: llc < %s -enable-shrink-wrap=true | FileCheck %s
3 ; chkstk cannot come before the usual prologue, since it adjusts ESP.
4 ; If chkstk is used in the prologue, we also have to be careful about preserving
5 ; EAX if it is used.
7 target datalayout = "e-m:x-p:32:32-i64:64-f80:32-n8:16:32-a:0:32-S32"
8 target triple = "i686-pc-windows-msvc18.0.0"
10 %struct.S = type { [8192 x i8] }
12 define x86_thiscallcc void @call_inalloca(i1 %x) {
13 entry:
14   %argmem = alloca inalloca <{ %struct.S }>, align 4
15   %argidx1 = getelementptr inbounds <{ %struct.S }>, <{ %struct.S }>* %argmem, i32 0, i32 0, i32 0, i32 0
16   %argidx2 = getelementptr inbounds <{ %struct.S }>, <{ %struct.S }>* %argmem, i32 0, i32 0, i32 0, i32 1
17   store i8 42, i8* %argidx2, align 4
18   br i1 %x, label %bb1, label %bb2
20 bb1:
21   store i8 42, i8* %argidx1, align 4
22   br label %bb2
24 bb2:
25   call void @inalloca_params(<{ %struct.S }>* inalloca nonnull %argmem)
26   ret void
29 ; CHECK-LABEL: _call_inalloca: # @call_inalloca
30 ; CHECK: pushl %ebp
31 ; CHECK: movl %esp, %ebp
32 ; CHECK: movl $8192, %eax
33 ; CHECK: calll __chkstk
34 ; CHECK: calll _inalloca_params
35 ; CHECK: movl %ebp, %esp
36 ; CHECK: popl %ebp
37 ; CHECK: retl
39 declare void @inalloca_params(<{ %struct.S }>* inalloca)
41 declare i32 @doSomething(i32, i32*)
43 ; In this test case, we force usage of EAX before the prologue, and have to
44 ; compensate before calling __chkstk. It would also be valid for us to avoid
45 ; shrink wrapping in this case.
47 define x86_fastcallcc i32 @use_eax_before_prologue(i32 inreg %a, i32 inreg %b) {
48   %tmp = alloca i32, i32 1024, align 4
49   %tmp2 = icmp slt i32 %a, %b
50   br i1 %tmp2, label %true, label %false
52 true:
53   store i32 %a, i32* %tmp, align 4
54   %tmp4 = call i32 @doSomething(i32 0, i32* %tmp)
55   br label %false
57 false:
58   %tmp.0 = phi i32 [ %tmp4, %true ], [ %a, %0 ]
59   ret i32 %tmp.0
62 ; CHECK-LABEL: @use_eax_before_prologue@8: # @use_eax_before_prologue
63 ; CHECK: movl %ecx, %eax
64 ; CHECK: cmpl %edx, %ecx
65 ; CHECK: jge LBB1_2
66 ; CHECK: pushl %eax
67 ; CHECK: movl $4092, %eax
68 ; CHECK: calll __chkstk
69 ; CHECK: movl 4092(%esp), %eax
70 ; CHECK: calll _doSomething
71 ; CHECK: LBB1_2:
72 ; CHECK: retl