Fixed some bugs in register stack pass.
[llvm/zpu.git] / test / CodeGen / X86 / pre-split2.ll
blobba902f95513d28eb4a45393f3b5423cf30c53fc7
1 ; RUN: llc < %s -march=x86 -mattr=+sse2 -pre-alloc-split -stats |& \
2 ; RUN:   grep {pre-alloc-split} | count 2
4 define i32 @t(i32 %arg) {
5 entry:
6         br label %bb6
8 .noexc6:                ; preds = %bb6
9         %0 = and i32 %2, -8             ; <i32> [#uses=1]
10         tail call void @llvm.memmove.i32(i8* %3, i8* null, i32 %0, i32 1) nounwind
11         store double %1, double* null, align 8
12         br label %bb6
14 bb6:            ; preds = %.noexc6, %entry
15         %1 = uitofp i32 %arg to double          ; <double> [#uses=1]
16         %2 = sub i32 0, 0               ; <i32> [#uses=1]
17         %3 = invoke i8* @_Znwm(i32 0)
18                         to label %.noexc6 unwind label %lpad32          ; <i8*> [#uses=1]
20 lpad32:         ; preds = %bb6
21         unreachable
24 declare void @llvm.memmove.i32(i8*, i8*, i32, i32) nounwind
26 declare i8* @_Znwm(i32)