diff options
Diffstat (limited to 'test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll')
-rw-r--r-- | test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll | 52 |
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 } + |