mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-07 12:30:44 +00:00
Move ExtractVectorElements to SelectionDAG.
This seems generally useful, and makes sense to go along with SplitVector. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@206041 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e04360918b
commit
d879166376
@ -1160,6 +1160,12 @@ public:
|
||||
return SplitVector(N->getOperand(OpNo), SDLoc(N));
|
||||
}
|
||||
|
||||
/// ExtractVectorElements - Append the extracted elements from Start to Count
|
||||
/// out of the vector Op in Args. If Count is 0, all of the elements will be
|
||||
/// extracted.
|
||||
void ExtractVectorElements(SDValue Op, SmallVectorImpl<SDValue> &Args,
|
||||
unsigned Start = 0, unsigned Count = 0);
|
||||
|
||||
private:
|
||||
bool RemoveNodeFromCSEMaps(SDNode *N);
|
||||
void AddModifiedNodeToCSEMaps(SDNode *N);
|
||||
|
@ -6511,6 +6511,22 @@ SelectionDAG::SplitVector(const SDValue &N, const SDLoc &DL, const EVT &LoVT,
|
||||
return std::make_pair(Lo, Hi);
|
||||
}
|
||||
|
||||
void SelectionDAG::ExtractVectorElements(SDValue Op,
|
||||
SmallVectorImpl<SDValue> &Args,
|
||||
unsigned Start, unsigned Count) {
|
||||
EVT VT = Op.getValueType();
|
||||
if (Count == 0)
|
||||
Count = VT.getVectorNumElements();
|
||||
|
||||
EVT EltVT = VT.getVectorElementType();
|
||||
EVT IdxTy = TLI->getVectorIdxTy();
|
||||
SDLoc SL(Op);
|
||||
for (unsigned i = Start, e = Start + Count; i != e; ++i) {
|
||||
Args.push_back(getNode(ISD::EXTRACT_VECTOR_ELT, SL, EltVT,
|
||||
Op, getConstant(i, IdxTy)));
|
||||
}
|
||||
}
|
||||
|
||||
// getAddressSpace - Return the address space this GlobalAddress belongs to.
|
||||
unsigned GlobalAddressSDNode::getAddressSpace() const {
|
||||
return getGlobal()->getType()->getAddressSpace();
|
||||
|
@ -471,28 +471,14 @@ SDValue AMDGPUTargetLowering::LowerGlobalAddress(AMDGPUMachineFunction* MFI,
|
||||
}
|
||||
}
|
||||
|
||||
void AMDGPUTargetLowering::ExtractVectorElements(SDValue Op, SelectionDAG &DAG,
|
||||
SmallVectorImpl<SDValue> &Args,
|
||||
unsigned Start,
|
||||
unsigned Count) const {
|
||||
EVT VT = Op.getValueType();
|
||||
for (unsigned i = Start, e = Start + Count; i != e; ++i) {
|
||||
Args.push_back(DAG.getNode(ISD::EXTRACT_VECTOR_ELT, SDLoc(Op),
|
||||
VT.getVectorElementType(),
|
||||
Op, DAG.getConstant(i, MVT::i32)));
|
||||
}
|
||||
}
|
||||
|
||||
SDValue AMDGPUTargetLowering::LowerCONCAT_VECTORS(SDValue Op,
|
||||
SelectionDAG &DAG) const {
|
||||
SmallVector<SDValue, 8> Args;
|
||||
SDValue A = Op.getOperand(0);
|
||||
SDValue B = Op.getOperand(1);
|
||||
|
||||
ExtractVectorElements(A, DAG, Args, 0,
|
||||
A.getValueType().getVectorNumElements());
|
||||
ExtractVectorElements(B, DAG, Args, 0,
|
||||
B.getValueType().getVectorNumElements());
|
||||
DAG.ExtractVectorElements(A, Args);
|
||||
DAG.ExtractVectorElements(B, Args);
|
||||
|
||||
return DAG.getNode(ISD::BUILD_VECTOR, SDLoc(Op), Op.getValueType(),
|
||||
Args.data(), Args.size());
|
||||
@ -502,10 +488,10 @@ SDValue AMDGPUTargetLowering::LowerEXTRACT_SUBVECTOR(SDValue Op,
|
||||
SelectionDAG &DAG) const {
|
||||
|
||||
SmallVector<SDValue, 8> Args;
|
||||
EVT VT = Op.getValueType();
|
||||
unsigned Start = cast<ConstantSDNode>(Op.getOperand(1))->getZExtValue();
|
||||
ExtractVectorElements(Op.getOperand(0), DAG, Args, Start,
|
||||
VT.getVectorNumElements());
|
||||
EVT VT = Op.getValueType();
|
||||
DAG.ExtractVectorElements(Op.getOperand(0), Args, Start,
|
||||
VT.getVectorNumElements());
|
||||
|
||||
return DAG.getNode(ISD::BUILD_VECTOR, SDLoc(Op), Op.getValueType(),
|
||||
Args.data(), Args.size());
|
||||
@ -1046,7 +1032,7 @@ SDValue AMDGPUTargetLowering::LowerSIGN_EXTEND_INREG(SDValue Op,
|
||||
// TODO: Don't scalarize on Evergreen?
|
||||
unsigned NElts = VT.getVectorNumElements();
|
||||
SmallVector<SDValue, 8> Args;
|
||||
ExtractVectorElements(Src, DAG, Args, 0, NElts);
|
||||
DAG.ExtractVectorElements(Src, Args);
|
||||
|
||||
SDValue VTOp = DAG.getValueType(ExtraVT.getScalarType());
|
||||
for (unsigned I = 0; I < NElts; ++I)
|
||||
|
@ -29,9 +29,6 @@ protected:
|
||||
const AMDGPUSubtarget *Subtarget;
|
||||
|
||||
private:
|
||||
void ExtractVectorElements(SDValue Op, SelectionDAG &DAG,
|
||||
SmallVectorImpl<SDValue> &Args,
|
||||
unsigned Start, unsigned Count) const;
|
||||
SDValue LowerConstantInitializer(const Constant* Init, const GlobalValue *GV,
|
||||
const SDValue &InitPtr,
|
||||
SDValue Chain,
|
||||
|
Loading…
Reference in New Issue
Block a user