diff options
author | Nadav Rotem <nadav.rotem@intel.com> | 2011-06-01 12:51:46 +0000 |
---|---|---|
committer | Nadav Rotem <nadav.rotem@intel.com> | 2011-06-01 12:51:46 +0000 |
commit | b6fbec3a546fd04bb2e79040db2436b0bd629162 (patch) | |
tree | 69e0dd2fd0368f2f6fbdd2d0ed8c461c0459e21d /test/CodeGen/Generic | |
parent | 4fd0dee3bfe8a35bbb62c9e9dea511cbc06cec2d (diff) | |
download | llvm-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.ll | 15 |
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 +} + |