summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/X86/extractelement-index.ll
diff options
context:
space:
mode:
authorPawel Bylica <chfast@gmail.com>2015-05-06 16:43:21 +0000
committerPawel Bylica <chfast@gmail.com>2015-05-06 16:43:21 +0000
commit3b0adaf6b031288c10b8badfd491832a03dce89b (patch)
tree652d221d17cc32a72755868b4c590af9e2c43993 /llvm/test/CodeGen/X86/extractelement-index.ll
parentd927c6eaf87ac128c320987c4c63dccae2fba4f3 (diff)
downloadbcm5719-llvm-3b0adaf6b031288c10b8badfd491832a03dce89b.tar.gz
bcm5719-llvm-3b0adaf6b031288c10b8badfd491832a03dce89b.zip
Readd the regression test from r236584. Calling convention fixed to linux.
llvm-svn: 236610
Diffstat (limited to 'llvm/test/CodeGen/X86/extractelement-index.ll')
-rw-r--r--llvm/test/CodeGen/X86/extractelement-index.ll51
1 files changed, 51 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/extractelement-index.ll b/llvm/test/CodeGen/X86/extractelement-index.ll
new file mode 100644
index 00000000000..ab3ff8ed435
--- /dev/null
+++ b/llvm/test/CodeGen/X86/extractelement-index.ll
@@ -0,0 +1,51 @@
+; RUN: llc < %s -mtriple=x86_64-pc-linux | FileCheck %s -check-prefix=X64
+; RUN: llc < %s -mtriple=x86_64-pc-linux -mattr=+avx | FileCheck %s -check-prefix=AVX
+
+
+; CHECK-LABEL: extractelement_index_1:
+define i8 @extractelement_index_1(<32 x i8> %a) nounwind {
+ ; X64: movaps
+ ; AVX: vpextrb $1
+ %b = extractelement <32 x i8> %a, i256 1
+ ret i8 %b
+}
+
+; CHECK-LABEL: extractelement_index_2:
+define i32 @extractelement_index_2(<8 x i32> %a) nounwind {
+ ; X64: pshufd
+ ; AVX: vextractf128 $1
+ ; AVX-NEXT: vpextrd $3
+ %b = extractelement <8 x i32> %a, i64 7
+ ret i32 %b
+}
+
+; CHECK-LABEL: extractelement_index_3:
+define i32 @extractelement_index_3(<8 x i32> %a) nounwind {
+ ; CHECK-NOT: pextr
+ %b = extractelement <8 x i32> %a, i64 15
+ ret i32 %b
+}
+
+; CHECK-LABEL: extractelement_index_4:
+define i32 @extractelement_index_4(<8 x i32> %a) nounwind {
+ ; X64: movd
+ ; AVX: vextractf128 $1
+ ; AVX-NEXT: vmovd
+ %b = extractelement <8 x i32> %a, i256 4
+ ret i32 %b
+}
+
+; CHECK-LABEL: extractelement_index_5:
+define i8 @extractelement_index_5(<32 x i8> %a, i256 %i) nounwind {
+ ; X64: movaps
+ ; AVX: vmovaps
+ %b = extractelement <32 x i8> %a, i256 %i
+ ret i8 %b
+}
+
+; CHECK-LABEL: extractelement_index_6:
+define i8 @extractelement_index_6(<32 x i8> %a) nounwind {
+ ; CHECK-NOT: pextr
+ %b = extractelement <32 x i8> %a, i256 -1
+ ret i8 %b
+} \ No newline at end of file
OpenPOWER on IntegriCloud