fix test to not get a moduleid that matches 'br'
[llvm/avr.git] / test / CodeGen / X86 / select.ll
blob95ed9e97cdfda92121ab8f11b0386aa19b3d1334
1 ; RUN: llc < %s -march=x86 -mcpu=pentium 
2 ; RUN: llc < %s -march=x86 -mcpu=yonah 
3 ; RUN: llc < %s -march=x86 -mcpu=yonah  | not grep set
5 define i1 @boolSel(i1 %A, i1 %B, i1 %C) nounwind {
6         %X = select i1 %A, i1 %B, i1 %C         ; <i1> [#uses=1]
7         ret i1 %X
10 define i8 @byteSel(i1 %A, i8 %B, i8 %C) nounwind {
11         %X = select i1 %A, i8 %B, i8 %C         ; <i8> [#uses=1]
12         ret i8 %X
15 define i16 @shortSel(i1 %A, i16 %B, i16 %C) nounwind {
16         %X = select i1 %A, i16 %B, i16 %C               ; <i16> [#uses=1]
17         ret i16 %X
20 define i32 @intSel(i1 %A, i32 %B, i32 %C) nounwind {
21         %X = select i1 %A, i32 %B, i32 %C               ; <i32> [#uses=1]
22         ret i32 %X
25 define i64 @longSel(i1 %A, i64 %B, i64 %C) nounwind {
26         %X = select i1 %A, i64 %B, i64 %C               ; <i64> [#uses=1]
27         ret i64 %X
30 define double @doubleSel(i1 %A, double %B, double %C) nounwind {
31         %X = select i1 %A, double %B, double %C         ; <double> [#uses=1]
32         ret double %X
35 define i8 @foldSel(i1 %A, i8 %B, i8 %C) nounwind {
36         %Cond = icmp slt i8 %B, %C              ; <i1> [#uses=1]
37         %X = select i1 %Cond, i8 %B, i8 %C              ; <i8> [#uses=1]
38         ret i8 %X
41 define i32 @foldSel2(i1 %A, i32 %B, i32 %C) nounwind {
42         %Cond = icmp eq i32 %B, %C              ; <i1> [#uses=1]
43         %X = select i1 %Cond, i32 %B, i32 %C            ; <i32> [#uses=1]
44         ret i32 %X
47 define i32 @foldSel2a(i1 %A, i32 %B, i32 %C, double %X, double %Y) nounwind {
48         %Cond = fcmp olt double %X, %Y          ; <i1> [#uses=1]
49         %X.upgrd.1 = select i1 %Cond, i32 %B, i32 %C            ; <i32> [#uses=1]
50         ret i32 %X.upgrd.1
53 define float @foldSel3(i1 %A, float %B, float %C, i32 %X, i32 %Y) nounwind {
54         %Cond = icmp ult i32 %X, %Y             ; <i1> [#uses=1]
55         %X.upgrd.2 = select i1 %Cond, float %B, float %C                ; <float> [#uses=1]
56         ret float %X.upgrd.2
59 define float @nofoldSel4(i1 %A, float %B, float %C, i32 %X, i32 %Y) nounwind {
60         %Cond = icmp slt i32 %X, %Y             ; <i1> [#uses=1]
61         %X.upgrd.3 = select i1 %Cond, float %B, float %C                ; <float> [#uses=1]
62         ret float %X.upgrd.3