summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/InstCombine
diff options
context:
space:
mode:
authorEugene Leviant <eleviant@accesssoftek.com>2017-02-17 07:36:03 +0000
committerEugene Leviant <eleviant@accesssoftek.com>2017-02-17 07:36:03 +0000
commit958fcd75026983975f8a5e04b1e2a64bf20695d8 (patch)
treeac08012fa7280390602865c84a5e9c98e63c9d25 /llvm/test/Transforms/InstCombine
parent7f1604aae62800e111f008717523498630473422 (diff)
downloadbcm5719-llvm-958fcd75026983975f8a5e04b1e2a64bf20695d8.tar.gz
bcm5719-llvm-958fcd75026983975f8a5e04b1e2a64bf20695d8.zip
InstCombine: fix extraction when performing vector/array punning
Differential revision: https://reviews.llvm.org/D29491 llvm-svn: 295429
Diffstat (limited to 'llvm/test/Transforms/InstCombine')
-rw-r--r--llvm/test/Transforms/InstCombine/shufflevec-bitcast.ll16
1 files changed, 16 insertions, 0 deletions
diff --git a/llvm/test/Transforms/InstCombine/shufflevec-bitcast.ll b/llvm/test/Transforms/InstCombine/shufflevec-bitcast.ll
new file mode 100644
index 00000000000..0f0365a07fb
--- /dev/null
+++ b/llvm/test/Transforms/InstCombine/shufflevec-bitcast.ll
@@ -0,0 +1,16 @@
+; RUN: opt < %s -instcombine -S | FileCheck %s
+
+define void @test(<16 x i8> %w, i32* %o1, float* %o2) {
+
+; CHECK: %v.bc = bitcast <16 x i8> %w to <4 x i32>
+; CHECK-NEXT: %v.extract = extractelement <4 x i32> %v.bc, i32 3
+; CHECK-NEXT: %v.bc{{[0-9]*}} = bitcast <16 x i8> %w to <4 x float>
+; CHECK-NEXT: %v.extract{{[0-9]*}} = extractelement <4 x float> %v.bc{{[0-9]*}}, i32 3
+
+ %v = shufflevector <16 x i8> %w, <16 x i8> undef, <4 x i32> <i32 12, i32 13, i32 14, i32 15>
+ %f = bitcast <4 x i8> %v to float
+ %i = bitcast <4 x i8> %v to i32
+ store i32 %i, i32* %o1, align 4
+ store float %f, float* %o2, align 4
+ ret void
+}
OpenPOWER on IntegriCloud