Fixed some bugs in register stack pass.
[llvm/zpu.git] / test / CodeGen / X86 / sret.ll
blobb9455300bdbb11c3848c85ce6eba5578f2693128
1 ; RUN: llc < %s -march=x86 | grep ret | grep 4
3         %struct.foo = type { [4 x i32] }
5 define void @bar(%struct.foo* noalias sret %agg.result) nounwind  {
6 entry:
7         %tmp1 = getelementptr %struct.foo* %agg.result, i32 0, i32 0
8         %tmp3 = getelementptr [4 x i32]* %tmp1, i32 0, i32 0
9         store i32 1, i32* %tmp3, align 8
10         ret void
13 @dst = external global i32
15 define void @foo() nounwind {
16         %memtmp = alloca %struct.foo, align 4
17         call void @bar( %struct.foo* sret %memtmp ) nounwind
18         %tmp4 = getelementptr %struct.foo* %memtmp, i32 0, i32 0
19         %tmp5 = getelementptr [4 x i32]* %tmp4, i32 0, i32 0
20         %tmp6 = load i32* %tmp5
21         store i32 %tmp6, i32* @dst
22         ret void