Use PMULDQ for v2i64 multiplies when SSE4.1 is available. And add
[oota-llvm.git] / test / CodeGen / X86 / 2006-04-27-ISelFoldingBug.ll
1 ; RUN: llvm-as < %s | \
2 ; RUN:   llc -march=x86 -mtriple=i686-apple-darwin8 -relocation-model=static | \
3 ; RUN:   grep {movl     _last} | count 1
4 ; RUN: llvm-as < %s | \
5 ; RUN:   llc -march=x86 -mtriple=i686-apple-darwin8 -relocation-model=static | \
6 ; RUN:   grep {cmpl.*_last} | count 1
7
8 @block = external global i8*            ; <i8**> [#uses=1]
9 @last = external global i32             ; <i32*> [#uses=3]
10
11 define i1 @loadAndRLEsource_no_exit_2E_1_label_2E_0(i32 %tmp.21.reload, i32 %tmp.8) {
12 newFuncRoot:
13         br label %label.0
14 label.0.no_exit.1_crit_edge.exitStub:           ; preds = %label.0
15         ret i1 true
16 codeRepl5.exitStub:             ; preds = %label.0
17         ret i1 false
18 label.0:                ; preds = %newFuncRoot
19         %tmp.35 = load i32* @last               ; <i32> [#uses=1]
20         %inc.1 = add i32 %tmp.35, 1             ; <i32> [#uses=2]
21         store i32 %inc.1, i32* @last
22         %tmp.36 = load i8** @block              ; <i8*> [#uses=1]
23         %tmp.38 = getelementptr i8* %tmp.36, i32 %inc.1         ; <i8*> [#uses=1]
24         %tmp.40 = trunc i32 %tmp.21.reload to i8                ; <i8> [#uses=1]
25         store i8 %tmp.40, i8* %tmp.38
26         %tmp.910 = load i32* @last              ; <i32> [#uses=1]
27         %tmp.1111 = icmp slt i32 %tmp.910, %tmp.8               ; <i1> [#uses=1]
28         %tmp.1412 = icmp ne i32 %tmp.21.reload, 257             ; <i1> [#uses=1]
29         %tmp.1613 = and i1 %tmp.1111, %tmp.1412         ; <i1> [#uses=1]
30         br i1 %tmp.1613, label %label.0.no_exit.1_crit_edge.exitStub, label %codeRepl5.exitStub
31 }
32