aboutsummaryrefslogtreecommitdiffstats
path: root/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll
diff options
context:
space:
mode:
Diffstat (limited to 'test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll')
-rw-r--r--test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll52
1 files changed, 24 insertions, 28 deletions
diff --git a/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll b/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll
index 03e7f7b..1a72a20 100644
--- a/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll
+++ b/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll
@@ -1,36 +1,32 @@
-; RUN: llvm-upgrade < %s | llvm-as | \
+; RUN: llvm-as < %s | \
; RUN: llc -march=x86 -mtriple=i686-apple-darwin8 -relocation-model=static | \
; RUN: grep {movl _last} | count 1
-; RUN: llvm-upgrade < %s | llvm-as | \
+; RUN: llvm-as < %s | \
; RUN: llc -march=x86 -mtriple=i686-apple-darwin8 -relocation-model=static | \
; RUN: grep {cmpl.*_last} | count 1
-%block = external global ubyte* ; <ubyte**> [#uses=1]
-%last = external global int ; <int*> [#uses=3]
+@block = external global i8* ; <i8**> [#uses=1]
+@last = external global i32 ; <i32*> [#uses=3]
-implementation ; Functions:
-
-bool %loadAndRLEsource_no_exit_2E_1_label_2E_0(int %tmp.21.reload, int %tmp.8) {
+define i1 @loadAndRLEsource_no_exit_2E_1_label_2E_0(i32 %tmp.21.reload, i32 %tmp.8) {
newFuncRoot:
- br label %label.0
-
-label.0.no_exit.1_crit_edge.exitStub: ; preds = %label.0
- ret bool true
-
-codeRepl5.exitStub: ; preds = %label.0
- ret bool false
-
-label.0: ; preds = %newFuncRoot
- %tmp.35 = load int* %last ; <int> [#uses=1]
- %inc.1 = add int %tmp.35, 1 ; <int> [#uses=2]
- store int %inc.1, int* %last
- %tmp.36 = load ubyte** %block ; <ubyte*> [#uses=1]
- %tmp.38 = getelementptr ubyte* %tmp.36, int %inc.1 ; <ubyte*> [#uses=1]
- %tmp.40 = cast int %tmp.21.reload to ubyte ; <ubyte> [#uses=1]
- store ubyte %tmp.40, ubyte* %tmp.38
- %tmp.910 = load int* %last ; <int> [#uses=1]
- %tmp.1111 = setlt int %tmp.910, %tmp.8 ; <bool> [#uses=1]
- %tmp.1412 = setne int %tmp.21.reload, 257 ; <bool> [#uses=1]
- %tmp.1613 = and bool %tmp.1111, %tmp.1412 ; <bool> [#uses=1]
- br bool %tmp.1613, label %label.0.no_exit.1_crit_edge.exitStub, label %codeRepl5.exitStub
+ br label %label.0
+label.0.no_exit.1_crit_edge.exitStub: ; preds = %label.0
+ ret i1 true
+codeRepl5.exitStub: ; preds = %label.0
+ ret i1 false
+label.0: ; preds = %newFuncRoot
+ %tmp.35 = load i32* @last ; <i32> [#uses=1]
+ %inc.1 = add i32 %tmp.35, 1 ; <i32> [#uses=2]
+ store i32 %inc.1, i32* @last
+ %tmp.36 = load i8** @block ; <i8*> [#uses=1]
+ %tmp.38 = getelementptr i8* %tmp.36, i32 %inc.1 ; <i8*> [#uses=1]
+ %tmp.40 = trunc i32 %tmp.21.reload to i8 ; <i8> [#uses=1]
+ store i8 %tmp.40, i8* %tmp.38
+ %tmp.910 = load i32* @last ; <i32> [#uses=1]
+ %tmp.1111 = icmp slt i32 %tmp.910, %tmp.8 ; <i1> [#uses=1]
+ %tmp.1412 = icmp ne i32 %tmp.21.reload, 257 ; <i1> [#uses=1]
+ %tmp.1613 = and i1 %tmp.1111, %tmp.1412 ; <i1> [#uses=1]
+ br i1 %tmp.1613, label %label.0.no_exit.1_crit_edge.exitStub, label %codeRepl5.exitStub
}
+