summaryrefslogtreecommitdiff
path: root/test/Feature
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2007-01-04 00:29:09 +0000
committerReid Spencer <rspencer@reidspencer.com>2007-01-04 00:29:09 +0000
commitc01901c63774de143237a8d18940e7d7a5eb8a00 (patch)
tree04198a5b19af7fbf424aa87afad1f3b57779a221 /test/Feature
parente68853be66078c6bf311b1beeb9a86d6821bebea (diff)
downloadllvm-c01901c63774de143237a8d18940e7d7a5eb8a00.tar.gz
llvm-c01901c63774de143237a8d18940e7d7a5eb8a00.tar.bz2
llvm-c01901c63774de143237a8d18940e7d7a5eb8a00.tar.xz
Add a test to ensure that we can assembly comparisons of packed values.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32854 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Feature')
-rwxr-xr-xtest/Feature/packed_cmp.ll57
1 files changed, 57 insertions, 0 deletions
diff --git a/test/Feature/packed_cmp.ll b/test/Feature/packed_cmp.ll
new file mode 100755
index 0000000000..ca3a644108
--- /dev/null
+++ b/test/Feature/packed_cmp.ll
@@ -0,0 +1,57 @@
+; This test checks to make sure that NE and EQ comparisons of
+; vector types work.
+; RUN: llvm-as < %s | llvm-dis > %t1.ll
+; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
+; RUN: diff %t1.ll %t2.ll
+
+%ivec_type = type <4 x i8>
+%ivec1 = constant %ivec_type < i8 1, i8 1, i8 1, i8 1 >
+%ivec2 = constant %ivec_type < i8 0, i8 0, i8 0, i8 0 >
+
+%fvec_type = type <4 x float>
+%fvec1 = constant %fvec_type <float 1.0, float 1.0, float 1.0, float 1.0>
+%fvec2 = constant %fvec_type <float 0.0, float 0.0, float 0.0, float 0.0>
+
+implementation ; Functions:
+
+define bool %ivectest1() {
+ %v1 = load %ivec_type* getelementptr(%ivec_type* %ivec1, i32 0)
+ %v2 = load %ivec_type* getelementptr(%ivec_type* %ivec2, i32 0)
+ %res = icmp ne %ivec_type %v1, %v2
+ ret bool %res
+}
+
+define bool %ivectest2() {
+ %v1 = load %ivec_type* getelementptr(%ivec_type* %ivec1, i32 0)
+ %v2 = load %ivec_type* getelementptr(%ivec_type* %ivec2, i32 0)
+ %res = icmp eq %ivec_type %v1, %v2
+ ret bool %res
+}
+
+define bool %fvectest1() {
+ %v1 = load %fvec_type* %fvec1
+ %v2 = load %fvec_type* %fvec2
+ %res = fcmp one %fvec_type %v1, %v2
+ ret bool %res
+}
+
+define bool %fvectest2() {
+ %v1 = load %fvec_type* %fvec1
+ %v2 = load %fvec_type* %fvec2
+ %res = fcmp oeq %fvec_type %v1, %v2
+ ret bool %res
+}
+
+define bool %fvectest3() {
+ %v1 = load %fvec_type* %fvec1
+ %v2 = load %fvec_type* %fvec2
+ %res = fcmp une %fvec_type %v1, %v2
+ ret bool %res
+}
+
+define bool %fvectest4() {
+ %v1 = load %fvec_type* %fvec1
+ %v2 = load %fvec_type* %fvec2
+ %res = fcmp ueq %fvec_type %v1, %v2
+ ret bool %res
+}