Add a test for the foldSelectICmpAndOr fix committed in r180779.
[oota-llvm.git] / test / Transforms / InstCombine / fcmp.ll
1 ; RUN: opt -S -instcombine < %s | FileCheck %s
2
3 define i1 @test1(float %x, float %y) nounwind {
4   %ext1 = fpext float %x to double
5   %ext2 = fpext float %y to double
6   %cmp = fcmp ogt double %ext1, %ext2
7   ret i1 %cmp
8 ; CHECK: @test1
9 ; CHECK-NEXT: fcmp ogt float %x, %y
10 }
11
12 define i1 @test2(float %a) nounwind {
13   %ext = fpext float %a to double
14   %cmp = fcmp ogt double %ext, 1.000000e+00
15   ret i1 %cmp
16 ; CHECK: @test2
17 ; CHECK-NEXT: fcmp ogt float %a, 1.0
18 }
19
20 define i1 @test3(float %a) nounwind {
21   %ext = fpext float %a to double
22   %cmp = fcmp ogt double %ext, 0x3FF0000000000001 ; more precision than float.
23   ret i1 %cmp
24 ; CHECK: @test3
25 ; CHECK-NEXT: fpext float %a to double
26 }
27
28 define i1 @test4(float %a) nounwind {
29   %ext = fpext float %a to double
30   %cmp = fcmp ogt double %ext, 0x36A0000000000000 ; denormal in float.
31   ret i1 %cmp
32 ; CHECK: @test4
33 ; CHECK-NEXT: fpext float %a to double
34 }
35
36 define i1 @test5(float %a) nounwind {
37   %neg = fsub float -0.000000e+00, %a
38   %cmp = fcmp ogt float %neg, 1.000000e+00
39   ret i1 %cmp
40 ; CHECK: @test5
41 ; CHECK-NEXT: fcmp olt float %a, -1.0
42 }
43
44 define i1 @test6(float %x, float %y) nounwind {
45   %neg1 = fsub float -0.000000e+00, %x
46   %neg2 = fsub float -0.000000e+00, %y
47   %cmp = fcmp olt float %neg1, %neg2
48   ret i1 %cmp
49 ; CHECK: @test6
50 ; CHECK-NEXT: fcmp ogt float %x, %y
51 }
52
53 define i1 @test7(float %x) nounwind readnone ssp noredzone {
54   %ext = fpext float %x to ppc_fp128
55   %cmp = fcmp ogt ppc_fp128 %ext, 0xM00000000000000000000000000000000
56   ret i1 %cmp
57 ; CHECK: @test7
58 ; CHECK-NEXT: fcmp ogt float %x, 0.000000e+00
59 }
60
61 define float @test8(float %x) nounwind readnone optsize ssp {
62   %conv = fpext float %x to double
63   %cmp = fcmp olt double %conv, 0.000000e+00
64   %conv1 = zext i1 %cmp to i32
65   %conv2 = sitofp i32 %conv1 to float
66   ret float %conv2
67 ; Float comparison to zero shouldn't cast to double.
68 ; CHECK: @test8
69 ; CHECK-NEXT: fcmp olt float %x, 0.000000e+00
70 }
71
72 declare double @fabs(double) nounwind readnone
73
74 define i32 @test9(double %a) nounwind {
75   %call = tail call double @fabs(double %a) nounwind
76   %cmp = fcmp olt double %call, 0.000000e+00
77   %conv = zext i1 %cmp to i32
78   ret i32 %conv
79 ; CHECK: @test9
80 ; CHECK-NOT: fabs
81 ; CHECK: ret i32 0
82 }
83
84 define i32 @test10(double %a) nounwind {
85   %call = tail call double @fabs(double %a) nounwind
86   %cmp = fcmp ole double %call, 0.000000e+00
87   %conv = zext i1 %cmp to i32
88   ret i32 %conv
89 ; CHECK: @test10
90 ; CHECK-NOT: fabs
91 ; CHECK: fcmp oeq double %a, 0.000000e+00
92 }
93
94 define i32 @test11(double %a) nounwind {
95   %call = tail call double @fabs(double %a) nounwind
96   %cmp = fcmp ogt double %call, 0.000000e+00
97   %conv = zext i1 %cmp to i32
98   ret i32 %conv
99 ; CHECK: @test11
100 ; CHECK-NOT: fabs
101 ; CHECK: fcmp one double %a, 0.000000e+00
102 }
103
104 define i32 @test12(double %a) nounwind {
105   %call = tail call double @fabs(double %a) nounwind
106   %cmp = fcmp oge double %call, 0.000000e+00
107   %conv = zext i1 %cmp to i32
108   ret i32 %conv
109 ; CHECK: @test12
110 ; CHECK-NOT: fabs
111 ; CHECK: fcmp ord double %a, 0.000000e+00
112 }
113
114 define i32 @test13(double %a) nounwind {
115   %call = tail call double @fabs(double %a) nounwind
116   %cmp = fcmp une double %call, 0.000000e+00
117   %conv = zext i1 %cmp to i32
118   ret i32 %conv
119 ; CHECK: @test13
120 ; CHECK-NOT: fabs
121 ; CHECK: fcmp une double %a, 0.000000e+00
122 }
123
124 define i32 @test14(double %a) nounwind {
125   %call = tail call double @fabs(double %a) nounwind
126   %cmp = fcmp oeq double %call, 0.000000e+00
127   %conv = zext i1 %cmp to i32
128   ret i32 %conv
129 ; CHECK: @test14
130 ; CHECK-NOT: fabs
131 ; CHECK: fcmp oeq double %a, 0.000000e+00
132 }
133
134 define i32 @test15(double %a) nounwind {
135   %call = tail call double @fabs(double %a) nounwind
136   %cmp = fcmp one double %call, 0.000000e+00
137   %conv = zext i1 %cmp to i32
138   ret i32 %conv
139 ; CHECK: @test15
140 ; CHECK-NOT: fabs
141 ; CHECK: fcmp one double %a, 0.000000e+00
142 }
143
144 define i32 @test16(double %a) nounwind {
145   %call = tail call double @fabs(double %a) nounwind
146   %cmp = fcmp ueq double %call, 0.000000e+00
147   %conv = zext i1 %cmp to i32
148   ret i32 %conv
149 ; CHECK: @test16
150 ; CHECK-NOT: fabs
151 ; CHECK: fcmp ueq double %a, 0.000000e+00
152 }
153
154 ; Don't crash.
155 define i32 @test17(double %a, double (double)* %p) nounwind {
156   %call = tail call double %p(double %a) nounwind
157   %cmp = fcmp ueq double %call, 0.000000e+00
158   %conv = zext i1 %cmp to i32
159   ret i32 %conv
160 }