summaryrefslogtreecommitdiff
path: root/test/CodeGen/Generic
diff options
context:
space:
mode:
authorNadav Rotem <nadav.rotem@intel.com>2011-06-01 12:51:46 +0000
committerNadav Rotem <nadav.rotem@intel.com>2011-06-01 12:51:46 +0000
commitb6fbec3a546fd04bb2e79040db2436b0bd629162 (patch)
tree69e0dd2fd0368f2f6fbdd2d0ed8c461c0459e21d /test/CodeGen/Generic
parent4fd0dee3bfe8a35bbb62c9e9dea511cbc06cec2d (diff)
downloadllvm-b6fbec3a546fd04bb2e79040db2436b0bd629162.tar.gz
llvm-b6fbec3a546fd04bb2e79040db2436b0bd629162.tar.bz2
llvm-b6fbec3a546fd04bb2e79040db2436b0bd629162.tar.xz
This patch is another step in the direction of adding vector select. In this
patch we add a flag to enable a new type legalization decision - to promote integer elements in vectors. Currently, the rest of the codegen does not support this kind of legalization. This flag will be removed when the transition is complete. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@132394 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/Generic')
-rw-r--r--test/CodeGen/Generic/promote-integers.ll15
1 files changed, 15 insertions, 0 deletions
diff --git a/test/CodeGen/Generic/promote-integers.ll b/test/CodeGen/Generic/promote-integers.ll
new file mode 100644
index 0000000000..58125921b3
--- /dev/null
+++ b/test/CodeGen/Generic/promote-integers.ll
@@ -0,0 +1,15 @@
+; Test that vectors are scalarized/lowered correctly.
+; RUN: llc -march=x86 -promote-elements < %s | FileCheck %s
+
+; This test is the poster-child for integer-element-promotion.
+; Until this feature is complete, we mark this test as expected to fail.
+; XFAIL: *
+; CHECK: vector_code
+; CHECK: ret
+define <4 x float> @vector_code(<4 x i64> %A, <4 x i64> %B, <4 x float> %R0, <4 x float> %R1 ) {
+ %C = icmp eq <4 x i64> %A, %B
+ %K = xor <4 x i1> <i1 1, i1 1, i1 1, i1 1>, %C
+ %D = select <4 x i1> %K, <4 x float> %R1, <4 x float> %R0
+ ret <4 x float> %D
+}
+