blob: fc30763f40fb59014913879559ab1403140d718c [file] [log] [blame]
Chris Lattner40353072009-07-08 18:51:25 +00001; RUN: llvm-as < %s | llc -march=x86 -mcpu=yonah | FileCheck %s
Chris Lattner08074e92009-07-07 22:51:09 +00002
Chris Lattner42005c02009-07-07 23:03:54 +00003
Chris Lattner40353072009-07-08 18:51:25 +00004define <4 x i32> @test1(<4 x i32> %A, <4 x i32> %B) nounwind {
5; CHECK: test1:
6; CHECK: pcmpgtd
7; CHECK: ret
8
Chris Lattner42005c02009-07-07 23:03:54 +00009 %C = icmp sgt <4 x i32> %A, %B
10 %D = sext <4 x i1> %C to <4 x i32>
11 ret <4 x i32> %D
12}
13
Chris Lattner40353072009-07-08 18:51:25 +000014define <4 x i32> @test2(<4 x i32> %A, <4 x i32> %B) nounwind {
15; CHECK: test2:
16; CHECK: pcmp
17; CHECK: pcmp
18; CHECK: xorps
19; CHECK: ret
20 %C = icmp sge <4 x i32> %A, %B
21 %D = sext <4 x i1> %C to <4 x i32>
22 ret <4 x i32> %D
23}
24
25define <4 x i32> @test3(<4 x i32> %A, <4 x i32> %B) nounwind {
26; CHECK: test3:
27; CHECK: pcmpgtd
28; CHECK: movaps
29; CHECK: ret
30 %C = icmp slt <4 x i32> %A, %B
31 %D = sext <4 x i1> %C to <4 x i32>
32 ret <4 x i32> %D
33}
34
35define <4 x i32> @test4(<4 x i32> %A, <4 x i32> %B) nounwind {
36; CHECK: test4:
37; CHECK: movaps
38; CHECK: pcmpgtd
39; CHECK: ret
40 %C = icmp ugt <4 x i32> %A, %B
41 %D = sext <4 x i1> %C to <4 x i32>
42 ret <4 x i32> %D
43}