summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen
diff options
context:
space:
mode:
authorAhmed Bougacha <ahmed.bougacha@gmail.com>2014-12-11 23:07:52 +0000
committerAhmed Bougacha <ahmed.bougacha@gmail.com>2014-12-11 23:07:52 +0000
commit79c797443b2e3ebbccaeb7025ce637a9f40452b4 (patch)
tree465d5ef87b0c8d253fb1bc9a53bada07a9cf5d04 /llvm/test/CodeGen
parent5c7006e06283a61b26783a8141936466ad3dd3c7 (diff)
downloadbcm5719-llvm-79c797443b2e3ebbccaeb7025ce637a9f40452b4.tar.gz
bcm5719-llvm-79c797443b2e3ebbccaeb7025ce637a9f40452b4.zip
[X86] Add a temporary testcase for PR21876/r223996.
llvm-svn: 224074
Diffstat (limited to 'llvm/test/CodeGen')
-rw-r--r--llvm/test/CodeGen/X86/avx2-pmovx-256-old-shuffle.ll29
1 files changed, 29 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/avx2-pmovx-256-old-shuffle.ll b/llvm/test/CodeGen/X86/avx2-pmovx-256-old-shuffle.ll
new file mode 100644
index 00000000000..44eb42adb9f
--- /dev/null
+++ b/llvm/test/CodeGen/X86/avx2-pmovx-256-old-shuffle.ll
@@ -0,0 +1,29 @@
+; RUN: llc < %s -x86-experimental-vector-shuffle-lowering=false -mattr=+avx2 | FileCheck %s
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-apple-darwin"
+
+; PR21876
+; The old shuffle lowering sometimes generates VZEXT nodes with both input
+; and output same-sized types, here 256-bits. For instance, a v8i8 to v8i32
+; zero-extend would become a (v8i32 (VZEXT v32i8)) node, which can't happen
+; otherwise. The companion commit r223996 added those patterns temporarily.
+; This test, along with the VR256 for AVX2 PMOVXrr instructions, should be
+; removed once the old vector shuffle lowering goes away.
+
+define void @test_avx2_pmovx_256(<8 x i8>* %tmp64, <8 x float>* %tmp75) {
+; CHECK-LABEL: test_avx2_pmovx_256
+; We really don't care about the generated code.
+; CHECK: vpmovzxbd
+; CHECK: vpbroadcastd
+; CHECK: vpand
+; CHECK: vcvtdq2ps
+; CHECK: vmovups
+; CHECK: vzeroupper
+; CHECK: retq
+
+ %wide.load458 = load <8 x i8>* %tmp64, align 1
+ %tmp68 = uitofp <8 x i8> %wide.load458 to <8 x float>
+ store <8 x float> %tmp68, <8 x float>* %tmp75, align 4
+ ret void
+}
OpenPOWER on IntegriCloud