[x86] Add intrinsics for the pshufd, pshuflw, and pshufhw instructions.
llvm-svn: 211694
This commit is contained in:
parent
ca237b586e
commit
e5724d7532
|
@ -667,6 +667,15 @@ let TargetPrefix = "x86" in { // All intrinsics start with "llvm.x86.".
|
|||
def int_x86_ssse3_pshuf_b_128 : GCCBuiltin<"__builtin_ia32_pshufb128">,
|
||||
Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
|
||||
llvm_v16i8_ty], [IntrNoMem]>;
|
||||
def int_x86_sse2_pshuf_d : GCCBuiltin<"__builtin_ia32_pshufd">,
|
||||
Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty, llvm_i8_ty],
|
||||
[IntrNoMem]>;
|
||||
def int_x86_sse2_pshufl_w : GCCBuiltin<"__builtin_ia32_pshuflw">,
|
||||
Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty, llvm_i8_ty],
|
||||
[IntrNoMem]>;
|
||||
def int_x86_sse2_pshufh_w : GCCBuiltin<"__builtin_ia32_pshufhw">,
|
||||
Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty, llvm_i8_ty],
|
||||
[IntrNoMem]>;
|
||||
def int_x86_sse_pshuf_w : GCCBuiltin<"__builtin_ia32_pshufw">,
|
||||
Intrinsic<[llvm_x86mmx_ty], [llvm_x86mmx_ty, llvm_i8_ty],
|
||||
[IntrNoMem]>;
|
||||
|
|
|
@ -12660,6 +12660,18 @@ static SDValue LowerINTRINSIC_WO_CHAIN(SDValue Op, SelectionDAG &DAG) {
|
|||
return DAG.getNode(X86ISD::PSHUFB, dl, Op.getValueType(),
|
||||
Op.getOperand(1), Op.getOperand(2));
|
||||
|
||||
case Intrinsic::x86_sse2_pshuf_d:
|
||||
return DAG.getNode(X86ISD::PSHUFD, dl, Op.getValueType(),
|
||||
Op.getOperand(1), Op.getOperand(2));
|
||||
|
||||
case Intrinsic::x86_sse2_pshufl_w:
|
||||
return DAG.getNode(X86ISD::PSHUFLW, dl, Op.getValueType(),
|
||||
Op.getOperand(1), Op.getOperand(2));
|
||||
|
||||
case Intrinsic::x86_sse2_pshufh_w:
|
||||
return DAG.getNode(X86ISD::PSHUFHW, dl, Op.getValueType(),
|
||||
Op.getOperand(1), Op.getOperand(2));
|
||||
|
||||
case Intrinsic::x86_ssse3_psign_b_128:
|
||||
case Intrinsic::x86_ssse3_psign_w_128:
|
||||
case Intrinsic::x86_ssse3_psign_d_128:
|
||||
|
|
|
@ -717,3 +717,30 @@ define void @test_x86_sse2_pause() {
|
|||
ret void
|
||||
}
|
||||
declare void @llvm.x86.sse2.pause() nounwind
|
||||
|
||||
define <4 x i32> @test_x86_sse2_pshuf_d(<4 x i32> %a) {
|
||||
; CHECK-LABEL: test_x86_sse2_pshuf_d:
|
||||
; CHECK: pshufd $27
|
||||
entry:
|
||||
%res = call <4 x i32> @llvm.x86.sse2.pshuf.d(<4 x i32> %a, i8 27) nounwind readnone
|
||||
ret <4 x i32> %res
|
||||
}
|
||||
declare <4 x i32> @llvm.x86.sse2.pshuf.d(<4 x i32>, i8) nounwind readnone
|
||||
|
||||
define <8 x i16> @test_x86_sse2_pshufl_w(<8 x i16> %a) {
|
||||
; CHECK-LABEL: test_x86_sse2_pshufl_w:
|
||||
; CHECK: pshuflw $27
|
||||
entry:
|
||||
%res = call <8 x i16> @llvm.x86.sse2.pshufl.w(<8 x i16> %a, i8 27) nounwind readnone
|
||||
ret <8 x i16> %res
|
||||
}
|
||||
declare <8 x i16> @llvm.x86.sse2.pshufl.w(<8 x i16>, i8) nounwind readnone
|
||||
|
||||
define <8 x i16> @test_x86_sse2_pshufh_w(<8 x i16> %a) {
|
||||
; CHECK-LABEL: test_x86_sse2_pshufh_w:
|
||||
; CHECK: pshufhw $27
|
||||
entry:
|
||||
%res = call <8 x i16> @llvm.x86.sse2.pshufh.w(<8 x i16> %a, i8 27) nounwind readnone
|
||||
ret <8 x i16> %res
|
||||
}
|
||||
declare <8 x i16> @llvm.x86.sse2.pshufh.w(<8 x i16>, i8) nounwind readnone
|
||||
|
|
Loading…
Reference in New Issue