mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-31 16:02:52 +01:00
66a9e4f863
Added a test for shuffles using VPERM. llvm-svn: 188147
67 lines
2.0 KiB
LLVM
67 lines
2.0 KiB
LLVM
; RUN: llc < %s -mtriple=x86_64-apple-darwin -mcpu=knl | FileCheck %s
|
|
; CHECK: LCP
|
|
; CHECK: .long 2
|
|
; CHECK: .long 5
|
|
; CHECK: .long 0
|
|
; CHECK: .long 0
|
|
; CHECK: .long 7
|
|
; CHECK: .long 0
|
|
; CHECK: .long 10
|
|
; CHECK: .long 1
|
|
; CHECK: .long 0
|
|
; CHECK: .long 5
|
|
; CHECK: .long 0
|
|
; CHECK: .long 4
|
|
; CHECK: .long 7
|
|
; CHECK: .long 0
|
|
; CHECK: .long 10
|
|
; CHECK: .long 1
|
|
; CHECK: test1:
|
|
; CHECK: vpermps
|
|
; CHECK: ret
|
|
define <16 x float> @test1(<16 x float> %a) nounwind {
|
|
%c = shufflevector <16 x float> %a, <16 x float> undef, <16 x i32> <i32 2, i32 5, i32 undef, i32 undef, i32 7, i32 undef, i32 10, i32 1, i32 0, i32 5, i32 undef, i32 4, i32 7, i32 undef, i32 10, i32 1>
|
|
ret <16 x float> %c
|
|
}
|
|
|
|
; CHECK: test2:
|
|
; CHECK: vpermd
|
|
; CHECK: ret
|
|
define <16 x i32> @test2(<16 x i32> %a) nounwind {
|
|
%c = shufflevector <16 x i32> %a, <16 x i32> undef, <16 x i32> <i32 2, i32 5, i32 undef, i32 undef, i32 7, i32 undef, i32 10, i32 1, i32 0, i32 5, i32 undef, i32 4, i32 7, i32 undef, i32 10, i32 1>
|
|
ret <16 x i32> %c
|
|
}
|
|
|
|
; CHECK: test3:
|
|
; CHECK: vpermq
|
|
; CHECK: ret
|
|
define <8 x i64> @test3(<8 x i64> %a) nounwind {
|
|
%c = shufflevector <8 x i64> %a, <8 x i64> undef, <8 x i32> <i32 2, i32 5, i32 1, i32 undef, i32 7, i32 undef, i32 3, i32 1>
|
|
ret <8 x i64> %c
|
|
}
|
|
|
|
; CHECK: test4:
|
|
; CHECK: vpermpd
|
|
; CHECK: ret
|
|
define <8 x double> @test4(<8 x double> %a) nounwind {
|
|
%c = shufflevector <8 x double> %a, <8 x double> undef, <8 x i32> <i32 1, i32 3, i32 undef, i32 undef, i32 undef, i32 undef, i32 undef, i32 undef>
|
|
ret <8 x double> %c
|
|
}
|
|
|
|
; CHECK: test5:
|
|
; CHECK: vpermi2pd
|
|
; CHECK: ret
|
|
define <8 x double> @test5(<8 x double> %a, <8 x double> %b) nounwind {
|
|
%c = shufflevector <8 x double> %a, <8 x double> %b, <8 x i32> <i32 2, i32 8, i32 0, i32 1, i32 6, i32 10, i32 4, i32 5>
|
|
ret <8 x double> %c
|
|
}
|
|
|
|
; CHECK: test6:
|
|
; CHECK: vpermq $30
|
|
; CHECK: ret
|
|
define <8 x i64> @test6(<8 x i64> %a) nounwind {
|
|
%c = shufflevector <8 x i64> %a, <8 x i64> undef, <8 x i32> <i32 2, i32 3, i32 1, i32 0, i32 6, i32 7, i32 5, i32 4>
|
|
ret <8 x i64> %c
|
|
}
|
|
|