X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=test%2FCodeGen%2FX86%2F2006-04-27-ISelFoldingBug.ll;h=fb1262a372950960ff4c090a3e12a38a2af2f41c;hb=b3009eec47d2aaa61cc848a66a7bbd69ad9e0f19;hp=db82d6591ebb0e9f40b2b1c457f950e88ff0da98;hpb=d3b1f6d3e0597baa77bf54cfe072c2fe974f56c1;p=oota-llvm.git diff --git a/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll b/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll index db82d6591eb..fb1262a3729 100644 --- a/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll +++ b/test/CodeGen/X86/2006-04-27-ISelFoldingBug.ll @@ -1,36 +1,29 @@ -; RUN: llvm-upgrade < %s | llvm-as | \ -; RUN: llc -march=x86 -mtriple=i686-apple-darwin8 -relocation-model=static | \ -; RUN: grep {movl _last} | wc -l | grep 1 -; RUN: llvm-upgrade < %s | llvm-as | \ -; RUN: llc -march=x86 -mtriple=i686-apple-darwin8 -relocation-model=static | \ -; RUN: grep {cmpl.*_last} | wc -l | grep 1 +; RUN: llc < %s -march=x86 -mtriple=i686-apple-darwin8 -relocation-model=static > %t +; RUN: grep "movl _last" %t | count 1 +; RUN: grep "cmpl.*_last" %t | count 1 -%block = external global ubyte* ; [#uses=1] -%last = external global int ; [#uses=3] +@block = external global i8* ; [#uses=1] +@last = external global 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 ; [#uses=1] - %inc.1 = add int %tmp.35, 1 ; [#uses=2] - store int %inc.1, int* %last - %tmp.36 = load ubyte** %block ; [#uses=1] - %tmp.38 = getelementptr ubyte* %tmp.36, int %inc.1 ; [#uses=1] - %tmp.40 = cast int %tmp.21.reload to ubyte ; [#uses=1] - store ubyte %tmp.40, ubyte* %tmp.38 - %tmp.910 = load int* %last ; [#uses=1] - %tmp.1111 = setlt int %tmp.910, %tmp.8 ; [#uses=1] - %tmp.1412 = setne int %tmp.21.reload, 257 ; [#uses=1] - %tmp.1613 = and bool %tmp.1111, %tmp.1412 ; [#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 ; [#uses=1] + %inc.1 = add i32 %tmp.35, 1 ; [#uses=2] + store i32 %inc.1, i32* @last + %tmp.36 = load i8** @block ; [#uses=1] + %tmp.38 = getelementptr i8* %tmp.36, i32 %inc.1 ; [#uses=1] + %tmp.40 = trunc i32 %tmp.21.reload to i8 ; [#uses=1] + store i8 %tmp.40, i8* %tmp.38 + %tmp.910 = load i32* @last ; [#uses=1] + %tmp.1111 = icmp slt i32 %tmp.910, %tmp.8 ; [#uses=1] + %tmp.1412 = icmp ne i32 %tmp.21.reload, 257 ; [#uses=1] + %tmp.1613 = and i1 %tmp.1111, %tmp.1412 ; [#uses=1] + br i1 %tmp.1613, label %label.0.no_exit.1_crit_edge.exitStub, label %codeRepl5.exitStub } +