Fixed some bugs in register stack pass.
[llvm/zpu.git] / test / CodeGen / X86 / tailcall-stackalign.ll
blobd3f811cff2480b34a4bc8dc28e275f183d10453a
1 ; RUN: llc < %s  -mtriple=i686-unknown-linux  -tailcallopt | FileCheck %s
2 ; Linux has 8 byte alignment so the params cause stack size 20 when tailcallopt
3 ; is enabled, ensure that a normal fastcc call has matching stack size
6 define fastcc i32 @tailcallee(i32 %a1, i32 %a2, i32 %a3, i32 %a4) {
7        ret i32 %a3
10 define fastcc i32 @tailcaller(i32 %in1, i32 %in2, i32 %in3, i32 %in4) {
11        %tmp11 = tail call fastcc i32 @tailcallee(i32 %in1, i32 %in2,
12                                                  i32 %in1, i32 %in2)
13        ret i32 %tmp11
16 define i32 @main(i32 %argc, i8** %argv) {
17  %tmp1 = call fastcc i32 @tailcaller( i32 1, i32 2, i32 3, i32 4 )
18  ; expect match subl [stacksize] here
19  ret i32 0
22 ; CHECK: calll tailcaller
23 ; CHECK-NEXT: subl $12