mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-16 23:19:37 +00:00
Check in some intermediate code that adds a skeleton for matching vsplt*
instructions git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26894 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ba753c61b7
commit
3c0f9cc90c
@ -82,7 +82,19 @@ namespace llvm {
|
||||
/// Return with a flag operand, matched by 'blr'
|
||||
RET_FLAG,
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
/// Define some predicates that are used for node matching.
|
||||
namespace PPC {
|
||||
/// isSplatShuffleMask - Return true if the specified VECTOR_SHUFFLE operand
|
||||
/// specifies a splat of a single element that is suitable for input to
|
||||
/// VSPLTB/VSPLTH/VSPLTW.
|
||||
bool isSplatShuffleMask(SDNode *N) { return false; } // FIXME:
|
||||
|
||||
/// getVSPLTImmediate - Return the appropriate VSPLT* immediate to splat the
|
||||
/// specified isSplatShuffleMask VECTOR_SHUFFLE mask.
|
||||
unsigned getVSPLTImmediate(SDNode *N) { return 0; } // FIXME:
|
||||
}
|
||||
|
||||
class PPCTargetLowering : public TargetLowering {
|
||||
int VarArgsFrameIndex; // FrameIndex for start of varargs area.
|
||||
|
@ -123,6 +123,14 @@ def imm16Shifted : PatLeaf<(imm), [{
|
||||
return ((unsigned)N->getValue() & 0xFFFF0000U) == (unsigned)N->getValue();
|
||||
}], HI16>;
|
||||
|
||||
// VSPLT_get_imm xform function: convert vector_shuffle mask to VSPLT* imm.
|
||||
def VSPLT_get_imm : SDNodeXForm<build_vector, [{
|
||||
return getI32Imm(PPC::getVSPLTImmediate(N));
|
||||
}]>;
|
||||
|
||||
def VSPLT_shuffle_mask : PatLeaf<(build_vector), [{
|
||||
return PPC::isSplatShuffleMask(N);
|
||||
}], VSPLT_get_imm>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// PowerPC Flag Definitions.
|
||||
@ -937,6 +945,7 @@ def RLDICR : MDForm_1<30, 1,
|
||||
[]>, isPPC64;
|
||||
}
|
||||
|
||||
|
||||
let PPC970_Unit = 5 in { // VALU Operations.
|
||||
// VA-Form instructions. 3-input AltiVec ops.
|
||||
def VMADDFP : VAForm_1<46, (ops VRRC:$vD, VRRC:$vA, VRRC:$vB, VRRC:$vC),
|
||||
@ -1022,9 +1031,11 @@ def VSPLTB : VXForm_1<524, (ops VRRC:$vD, u5imm:$UIMM, VRRC:$vB),
|
||||
def VSPLTH : VXForm_1<588, (ops VRRC:$vD, u5imm:$UIMM, VRRC:$vB),
|
||||
"vsplth $vD, $vB, $UIMM", VecPerm,
|
||||
[]>;
|
||||
def VSPLTW : VXForm_1<652, (ops VRRC:$vD, u5imm:$UIMM, VRRC:$vB),
|
||||
"vspltw $vD, $vB, $UIMM", VecPerm,
|
||||
[]>;
|
||||
|
||||
//def VSPLTW : VXForm_1<652, (ops VRRC:$vD, u5imm:$UIMM, VRRC:$vB),
|
||||
// "vspltw $vD, $vB, $UIMM", VecPerm,
|
||||
// [(set VRRC:$vD, (vector_shuffle (v4f32 VRRC:$vB), (undef),
|
||||
// VSPLT_shuffle_mask:$UIMM))]>;
|
||||
|
||||
// VX-Form Pseudo Instructions
|
||||
|
||||
@ -1033,6 +1044,7 @@ def V_SET0 : VXForm_setzero<1220, (ops VRRC:$vD),
|
||||
[]>;
|
||||
}
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// DWARF Pseudo Instructions
|
||||
//
|
||||
|
Loading…
x
Reference in New Issue
Block a user