mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-13 23:18:51 +00:00
[X86] Rename PABSB/D/W instructions to be consistent with SSE/AVX instructions instead of ending 128/256. NFC
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@279927 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3ed393863d
commit
460412aab8
@ -518,9 +518,9 @@ X86InstrInfo::X86InstrInfo(X86Subtarget &STI)
|
||||
{ X86::MOVZX32rr16, X86::MOVZX32rm16, 0 },
|
||||
{ X86::MOVZX32_NOREXrr8, X86::MOVZX32_NOREXrm8, 0 },
|
||||
{ X86::MOVZX32rr8, X86::MOVZX32rm8, 0 },
|
||||
{ X86::PABSBrr128, X86::PABSBrm128, TB_ALIGN_16 },
|
||||
{ X86::PABSDrr128, X86::PABSDrm128, TB_ALIGN_16 },
|
||||
{ X86::PABSWrr128, X86::PABSWrm128, TB_ALIGN_16 },
|
||||
{ X86::PABSBrr, X86::PABSBrm, TB_ALIGN_16 },
|
||||
{ X86::PABSDrr, X86::PABSDrm, TB_ALIGN_16 },
|
||||
{ X86::PABSWrr, X86::PABSWrm, TB_ALIGN_16 },
|
||||
{ X86::PCMPESTRIrr, X86::PCMPESTRIrm, TB_ALIGN_16 },
|
||||
{ X86::PCMPESTRM128rr, X86::PCMPESTRM128rm, TB_ALIGN_16 },
|
||||
{ X86::PCMPISTRIrr, X86::PCMPISTRIrm, TB_ALIGN_16 },
|
||||
@ -623,9 +623,9 @@ X86InstrInfo::X86InstrInfo(X86Subtarget &STI)
|
||||
{ X86::VMOVUPDrr, X86::VMOVUPDrm, 0 },
|
||||
{ X86::VMOVUPSrr, X86::VMOVUPSrm, 0 },
|
||||
{ X86::VMOVZPQILo2PQIrr,X86::VMOVZPQILo2PQIrm, TB_ALIGN_16 },
|
||||
{ X86::VPABSBrr128, X86::VPABSBrm128, 0 },
|
||||
{ X86::VPABSDrr128, X86::VPABSDrm128, 0 },
|
||||
{ X86::VPABSWrr128, X86::VPABSWrm128, 0 },
|
||||
{ X86::VPABSBrr, X86::VPABSBrm, 0 },
|
||||
{ X86::VPABSDrr, X86::VPABSDrm, 0 },
|
||||
{ X86::VPABSWrr, X86::VPABSWrm, 0 },
|
||||
{ X86::VPCMPESTRIrr, X86::VPCMPESTRIrm, 0 },
|
||||
{ X86::VPCMPESTRM128rr, X86::VPCMPESTRM128rm, 0 },
|
||||
{ X86::VPCMPISTRIrr, X86::VPCMPISTRIrm, 0 },
|
||||
@ -699,9 +699,9 @@ X86InstrInfo::X86InstrInfo(X86Subtarget &STI)
|
||||
{ X86::VBROADCASTSSrr, X86::VBROADCASTSSrm, TB_NO_REVERSE },
|
||||
{ X86::VBROADCASTSSYrr, X86::VBROADCASTSSYrm, TB_NO_REVERSE },
|
||||
{ X86::VBROADCASTSDYrr, X86::VBROADCASTSDYrm, TB_NO_REVERSE },
|
||||
{ X86::VPABSBrr256, X86::VPABSBrm256, 0 },
|
||||
{ X86::VPABSDrr256, X86::VPABSDrm256, 0 },
|
||||
{ X86::VPABSWrr256, X86::VPABSWrm256, 0 },
|
||||
{ X86::VPABSBYrr, X86::VPABSBYrm, 0 },
|
||||
{ X86::VPABSDYrr, X86::VPABSDYrm, 0 },
|
||||
{ X86::VPABSWYrr, X86::VPABSWYrm, 0 },
|
||||
{ X86::VPBROADCASTBrr, X86::VPBROADCASTBrm, 0 },
|
||||
{ X86::VPBROADCASTBYrr, X86::VPBROADCASTBYrm, 0 },
|
||||
{ X86::VPBROADCASTDrr, X86::VPBROADCASTDrm, 0 },
|
||||
|
@ -5392,35 +5392,35 @@ let Constraints = "$src1 = $dst" in {
|
||||
/// SS3I_unop_rm_int - Simple SSSE3 unary op whose type can be v*{i8,i16,i32}.
|
||||
multiclass SS3I_unop_rm<bits<8> opc, string OpcodeStr, ValueType vt,
|
||||
SDNode OpNode, PatFrag ld_frag> {
|
||||
def rr128 : SS38I<opc, MRMSrcReg, (outs VR128:$dst),
|
||||
(ins VR128:$src),
|
||||
!strconcat(OpcodeStr, "\t{$src, $dst|$dst, $src}"),
|
||||
[(set VR128:$dst, (vt (OpNode VR128:$src)))],
|
||||
IIC_SSE_PABS_RR>, Sched<[WriteVecALU]>;
|
||||
def rr : SS38I<opc, MRMSrcReg, (outs VR128:$dst),
|
||||
(ins VR128:$src),
|
||||
!strconcat(OpcodeStr, "\t{$src, $dst|$dst, $src}"),
|
||||
[(set VR128:$dst, (vt (OpNode VR128:$src)))],
|
||||
IIC_SSE_PABS_RR>, Sched<[WriteVecALU]>;
|
||||
|
||||
def rm128 : SS38I<opc, MRMSrcMem, (outs VR128:$dst),
|
||||
(ins i128mem:$src),
|
||||
!strconcat(OpcodeStr, "\t{$src, $dst|$dst, $src}"),
|
||||
[(set VR128:$dst,
|
||||
(vt (OpNode (bitconvert (ld_frag addr:$src)))))],
|
||||
IIC_SSE_PABS_RM>, Sched<[WriteVecALULd]>;
|
||||
def rm : SS38I<opc, MRMSrcMem, (outs VR128:$dst),
|
||||
(ins i128mem:$src),
|
||||
!strconcat(OpcodeStr, "\t{$src, $dst|$dst, $src}"),
|
||||
[(set VR128:$dst,
|
||||
(vt (OpNode (bitconvert (ld_frag addr:$src)))))],
|
||||
IIC_SSE_PABS_RM>, Sched<[WriteVecALULd]>;
|
||||
}
|
||||
|
||||
/// SS3I_unop_rm_int_y - Simple SSSE3 unary op whose type can be v*{i8,i16,i32}.
|
||||
multiclass SS3I_unop_rm_y<bits<8> opc, string OpcodeStr, ValueType vt,
|
||||
SDNode OpNode> {
|
||||
def rr256 : SS38I<opc, MRMSrcReg, (outs VR256:$dst),
|
||||
(ins VR256:$src),
|
||||
!strconcat(OpcodeStr, "\t{$src, $dst|$dst, $src}"),
|
||||
[(set VR256:$dst, (vt (OpNode VR256:$src)))]>,
|
||||
Sched<[WriteVecALU]>;
|
||||
def Yrr : SS38I<opc, MRMSrcReg, (outs VR256:$dst),
|
||||
(ins VR256:$src),
|
||||
!strconcat(OpcodeStr, "\t{$src, $dst|$dst, $src}"),
|
||||
[(set VR256:$dst, (vt (OpNode VR256:$src)))]>,
|
||||
Sched<[WriteVecALU]>;
|
||||
|
||||
def rm256 : SS38I<opc, MRMSrcMem, (outs VR256:$dst),
|
||||
(ins i256mem:$src),
|
||||
!strconcat(OpcodeStr, "\t{$src, $dst|$dst, $src}"),
|
||||
[(set VR256:$dst,
|
||||
(vt (OpNode (bitconvert (loadv4i64 addr:$src)))))]>,
|
||||
Sched<[WriteVecALULd]>;
|
||||
def Yrm : SS38I<opc, MRMSrcMem, (outs VR256:$dst),
|
||||
(ins i256mem:$src),
|
||||
!strconcat(OpcodeStr, "\t{$src, $dst|$dst, $src}"),
|
||||
[(set VR256:$dst,
|
||||
(vt (OpNode (bitconvert (loadv4i64 addr:$src)))))]>,
|
||||
Sched<[WriteVecALULd]>;
|
||||
}
|
||||
|
||||
// Helper fragments to match sext vXi1 to vXiY.
|
||||
@ -5445,15 +5445,15 @@ let Predicates = [HasAVX] in {
|
||||
def : Pat<(xor
|
||||
(bc_v2i64 (v16i1sextv16i8)),
|
||||
(bc_v2i64 (add (v16i8 VR128:$src), (v16i1sextv16i8)))),
|
||||
(VPABSBrr128 VR128:$src)>;
|
||||
(VPABSBrr VR128:$src)>;
|
||||
def : Pat<(xor
|
||||
(bc_v2i64 (v8i1sextv8i16)),
|
||||
(bc_v2i64 (add (v8i16 VR128:$src), (v8i1sextv8i16)))),
|
||||
(VPABSWrr128 VR128:$src)>;
|
||||
(VPABSWrr VR128:$src)>;
|
||||
def : Pat<(xor
|
||||
(bc_v2i64 (v4i1sextv4i32)),
|
||||
(bc_v2i64 (add (v4i32 VR128:$src), (v4i1sextv4i32)))),
|
||||
(VPABSDrr128 VR128:$src)>;
|
||||
(VPABSDrr VR128:$src)>;
|
||||
}
|
||||
|
||||
let Predicates = [HasAVX2, NoVLX_Or_NoBWI] in {
|
||||
@ -5468,15 +5468,15 @@ let Predicates = [HasAVX2] in {
|
||||
def : Pat<(xor
|
||||
(bc_v4i64 (v32i1sextv32i8)),
|
||||
(bc_v4i64 (add (v32i8 VR256:$src), (v32i1sextv32i8)))),
|
||||
(VPABSBrr256 VR256:$src)>;
|
||||
(VPABSBYrr VR256:$src)>;
|
||||
def : Pat<(xor
|
||||
(bc_v4i64 (v16i1sextv16i16)),
|
||||
(bc_v4i64 (add (v16i16 VR256:$src), (v16i1sextv16i16)))),
|
||||
(VPABSWrr256 VR256:$src)>;
|
||||
(VPABSWYrr VR256:$src)>;
|
||||
def : Pat<(xor
|
||||
(bc_v4i64 (v8i1sextv8i32)),
|
||||
(bc_v4i64 (add (v8i32 VR256:$src), (v8i1sextv8i32)))),
|
||||
(VPABSDrr256 VR256:$src)>;
|
||||
(VPABSDYrr VR256:$src)>;
|
||||
}
|
||||
|
||||
defm PABSB : SS3I_unop_rm<0x1C, "pabsb", v16i8, X86Abs, memopv2i64>;
|
||||
@ -5487,15 +5487,15 @@ let Predicates = [UseSSSE3] in {
|
||||
def : Pat<(xor
|
||||
(bc_v2i64 (v16i1sextv16i8)),
|
||||
(bc_v2i64 (add (v16i8 VR128:$src), (v16i1sextv16i8)))),
|
||||
(PABSBrr128 VR128:$src)>;
|
||||
(PABSBrr VR128:$src)>;
|
||||
def : Pat<(xor
|
||||
(bc_v2i64 (v8i1sextv8i16)),
|
||||
(bc_v2i64 (add (v8i16 VR128:$src), (v8i1sextv8i16)))),
|
||||
(PABSWrr128 VR128:$src)>;
|
||||
(PABSWrr VR128:$src)>;
|
||||
def : Pat<(xor
|
||||
(bc_v2i64 (v4i1sextv4i32)),
|
||||
(bc_v2i64 (add (v4i32 VR128:$src), (v4i1sextv4i32)))),
|
||||
(PABSDrr128 VR128:$src)>;
|
||||
(PABSDrr VR128:$src)>;
|
||||
}
|
||||
|
||||
//===---------------------------------------------------------------------===//
|
||||
|
Loading…
Reference in New Issue
Block a user