diff options
| author | Bruno Cardoso Lopes <bruno.cardoso@gmail.com> | 2011-07-29 01:31:07 +0000 | 
|---|---|---|
| committer | Bruno Cardoso Lopes <bruno.cardoso@gmail.com> | 2011-07-29 01:31:07 +0000 | 
| commit | d23709b18caaefbf3ab37c116be6c00fb0420f35 (patch) | |
| tree | 930076866f2b4d164e4dd791afb6ae1baea89644 /llvm | |
| parent | c00f6728bc803026d406daf5efba771ecb48b5af (diff) | |
| download | bcm5719-llvm-d23709b18caaefbf3ab37c116be6c00fb0420f35.tar.gz bcm5719-llvm-d23709b18caaefbf3ab37c116be6c00fb0420f35.zip | |
Add v8i32 and v4i64 vpermil patterns
llvm-svn: 136451
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrSSE.td | 4 | ||||
| -rw-r--r-- | llvm/test/CodeGen/X86/avx-vpermil.ll | 13 | 
2 files changed, 17 insertions, 0 deletions
| diff --git a/llvm/lib/Target/X86/X86InstrSSE.td b/llvm/lib/Target/X86/X86InstrSSE.td index 441c14639e0..066f7c01a53 100644 --- a/llvm/lib/Target/X86/X86InstrSSE.td +++ b/llvm/lib/Target/X86/X86InstrSSE.td @@ -5581,6 +5581,10 @@ def : Pat<(v8f32 (X86VPermilpsy VR256:$src1, (i8 imm:$imm))),            (VPERMILPSYri VR256:$src1, imm:$imm)>;  def : Pat<(v4f64 (X86VPermilpdy VR256:$src1, (i8 imm:$imm))),            (VPERMILPDYri VR256:$src1, imm:$imm)>; +def : Pat<(v8i32 (X86VPermilpsy VR256:$src1, (i8 imm:$imm))), +          (VPERMILPSYri VR256:$src1, imm:$imm)>; +def : Pat<(v4i64 (X86VPermilpdy VR256:$src1, (i8 imm:$imm))), +          (VPERMILPDYri VR256:$src1, imm:$imm)>;  //===----------------------------------------------------------------------===//  // VZERO - Zero YMM registers diff --git a/llvm/test/CodeGen/X86/avx-vpermil.ll b/llvm/test/CodeGen/X86/avx-vpermil.ll index d57c1737c46..f059948a799 100644 --- a/llvm/test/CodeGen/X86/avx-vpermil.ll +++ b/llvm/test/CodeGen/X86/avx-vpermil.ll @@ -14,3 +14,16 @@ entry:    ret <4 x double> %shuffle  } +; CHECK: vpermilps +define <8 x i32> @funcC(<8 x i32> %a) nounwind uwtable readnone ssp { +entry: +  %shuffle = shufflevector <8 x i32> %a, <8 x i32> undef, <8 x i32> <i32 1, i32 2, i32 3, i32 1, i32 5, i32 6, i32 7, i32 5> +  ret <8 x i32> %shuffle +} + +; CHECK: vpermilpd +define <4 x i64> @funcD(<4 x i64> %a) nounwind uwtable readnone ssp { +entry: +  %shuffle = shufflevector <4 x i64> %a, <4 x i64> undef, <4 x i32> <i32 1, i32 0, i32 3, i32 3> +  ret <4 x i64> %shuffle +} | 

