summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-07-08 18:51:25 +0000
committerChris Lattner <sabre@nondot.org>2009-07-08 18:51:25 +0000
commitd5ffa8ffb62df34c6fa3ba8ec4c29b2ea2891ad0 (patch)
treef2a79f110012c9669073947cbd170d2bf19c29b2
parent072198a2a1eb9424360c5bf9583641f1d52b6cba (diff)
downloadbcm5719-llvm-d5ffa8ffb62df34c6fa3ba8ec4c29b2ea2891ad0.tar.gz
bcm5719-llvm-d5ffa8ffb62df34c6fa3ba8ec4c29b2ea2891ad0.zip
add some more check for vector compares.
llvm-svn: 75024
-rw-r--r--llvm/test/CodeGen/X86/vec_compare.ll38
1 files changed, 36 insertions, 2 deletions
diff --git a/llvm/test/CodeGen/X86/vec_compare.ll b/llvm/test/CodeGen/X86/vec_compare.ll
index 42a3c2a8020..fc30763f40f 100644
--- a/llvm/test/CodeGen/X86/vec_compare.ll
+++ b/llvm/test/CodeGen/X86/vec_compare.ll
@@ -1,9 +1,43 @@
-; RUN: llvm-as < %s | llc -march=x86 -mcpu=yonah | grep pcmpgtd
+; RUN: llvm-as < %s | llc -march=x86 -mcpu=yonah | FileCheck %s
-define <4 x i32> @test2(<4 x i32> %A, <4 x i32> %B) nounwind {
+define <4 x i32> @test1(<4 x i32> %A, <4 x i32> %B) nounwind {
+; CHECK: test1:
+; CHECK: pcmpgtd
+; CHECK: ret
+
%C = icmp sgt <4 x i32> %A, %B
%D = sext <4 x i1> %C to <4 x i32>
ret <4 x i32> %D
}
+define <4 x i32> @test2(<4 x i32> %A, <4 x i32> %B) nounwind {
+; CHECK: test2:
+; CHECK: pcmp
+; CHECK: pcmp
+; CHECK: xorps
+; CHECK: ret
+ %C = icmp sge <4 x i32> %A, %B
+ %D = sext <4 x i1> %C to <4 x i32>
+ ret <4 x i32> %D
+}
+
+define <4 x i32> @test3(<4 x i32> %A, <4 x i32> %B) nounwind {
+; CHECK: test3:
+; CHECK: pcmpgtd
+; CHECK: movaps
+; CHECK: ret
+ %C = icmp slt <4 x i32> %A, %B
+ %D = sext <4 x i1> %C to <4 x i32>
+ ret <4 x i32> %D
+}
+
+define <4 x i32> @test4(<4 x i32> %A, <4 x i32> %B) nounwind {
+; CHECK: test4:
+; CHECK: movaps
+; CHECK: pcmpgtd
+; CHECK: ret
+ %C = icmp ugt <4 x i32> %A, %B
+ %D = sext <4 x i1> %C to <4 x i32>
+ ret <4 x i32> %D
+}
OpenPOWER on IntegriCloud