In some rare cases, the register allocator can spill registers but end up not utilizi...
[llvm/msp430.git] / test / CodeGen / X86 / 2006-04-27-ISelFoldingBug.ll
blob4a0b5c37e26172279be0a32018e315450adfd780
1 ; RUN: llvm-as < %s | \
2 ; RUN:   llc -march=x86 -mtriple=i686-apple-darwin8 -relocation-model=static > %t
3 ; RUN: grep {movl       _last} %t | count 1
4 ; RUN: grep {cmpl.*_last} %t | count 1
6 @block = external global i8*            ; <i8**> [#uses=1]
7 @last = external global i32             ; <i32*> [#uses=3]
9 define i1 @loadAndRLEsource_no_exit_2E_1_label_2E_0(i32 %tmp.21.reload, i32 %tmp.8) {
10 newFuncRoot:
11         br label %label.0
12 label.0.no_exit.1_crit_edge.exitStub:           ; preds = %label.0
13         ret i1 true
14 codeRepl5.exitStub:             ; preds = %label.0
15         ret i1 false
16 label.0:                ; preds = %newFuncRoot
17         %tmp.35 = load i32* @last               ; <i32> [#uses=1]
18         %inc.1 = add i32 %tmp.35, 1             ; <i32> [#uses=2]
19         store i32 %inc.1, i32* @last
20         %tmp.36 = load i8** @block              ; <i8*> [#uses=1]
21         %tmp.38 = getelementptr i8* %tmp.36, i32 %inc.1         ; <i8*> [#uses=1]
22         %tmp.40 = trunc i32 %tmp.21.reload to i8                ; <i8> [#uses=1]
23         store i8 %tmp.40, i8* %tmp.38
24         %tmp.910 = load i32* @last              ; <i32> [#uses=1]
25         %tmp.1111 = icmp slt i32 %tmp.910, %tmp.8               ; <i1> [#uses=1]
26         %tmp.1412 = icmp ne i32 %tmp.21.reload, 257             ; <i1> [#uses=1]
27         %tmp.1613 = and i1 %tmp.1111, %tmp.1412         ; <i1> [#uses=1]
28         br i1 %tmp.1613, label %label.0.no_exit.1_crit_edge.exitStub, label %codeRepl5.exitStub