Skip to content

Commit

Permalink
AMDGPU: Move SelectFlatOffset back into AMDGPUISelDAGToDAG
Browse files Browse the repository at this point in the history
llvm-svn: 374495
  • Loading branch information
arsenm committed Oct 11, 2019
1 parent 7b5c879 commit 4227c62
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 62 deletions.
53 changes: 43 additions & 10 deletions llvm/lib/Target/AMDGPU/AMDGPUISelDAGToDAG.cpp
Expand Up @@ -209,15 +209,14 @@ class AMDGPUDAGToDAGISel : public SelectionDAGISel {
bool SelectMUBUFOffset(SDValue Addr, SDValue &SRsrc, SDValue &Soffset,
SDValue &Offset) const;

template <bool IsSigned>
bool SelectFlatOffset(SDNode *N, SDValue Addr, SDValue &VAddr,
SDValue &Offset, SDValue &SLC) const;
bool SelectFlatAtomic(SDNode *N, SDValue Addr, SDValue &VAddr,
SDValue &Offset, SDValue &SLC) const;
bool SelectFlatAtomicSigned(SDNode *N, SDValue Addr, SDValue &VAddr,
SDValue &Offset, SDValue &SLC) const;

template <bool IsSigned>
bool SelectFlatOffset(SDNode *N, SDValue Addr, SDValue &VAddr,
SDValue &Offset, SDValue &SLC) const;

bool SelectSMRDOffset(SDValue ByteOffsetNode, SDValue &Offset,
bool &Imm) const;
SDValue Expand32BitAddress(SDValue Addr) const;
Expand Down Expand Up @@ -1606,14 +1605,48 @@ bool AMDGPUDAGToDAGISel::SelectMUBUFOffset(SDValue Addr, SDValue &SRsrc,
return SelectMUBUFOffset(Addr, SRsrc, Soffset, Offset, GLC, SLC, TFE, DLC, SWZ);
}

// Find a load or store from corresponding pattern root.
// Roots may be build_vector, bitconvert or their combinations.
static MemSDNode* findMemSDNode(SDNode *N) {
N = AMDGPUTargetLowering::stripBitcast(SDValue(N,0)).getNode();
if (MemSDNode *MN = dyn_cast<MemSDNode>(N))
return MN;
assert(isa<BuildVectorSDNode>(N));
for (SDValue V : N->op_values())
if (MemSDNode *MN =
dyn_cast<MemSDNode>(AMDGPUTargetLowering::stripBitcast(V)))
return MN;
llvm_unreachable("cannot find MemSDNode in the pattern!");
}

template <bool IsSigned>
bool AMDGPUDAGToDAGISel::SelectFlatOffset(SDNode *N,
SDValue Addr,
SDValue &VAddr,
SDValue &Offset,
SDValue &SLC) const {
return static_cast<const SITargetLowering*>(getTargetLowering())->
SelectFlatOffset(IsSigned, *CurDAG, N, Addr, VAddr, Offset, SLC);
int64_t OffsetVal = 0;

if (Subtarget->hasFlatInstOffsets() &&
(!Subtarget->hasFlatSegmentOffsetBug() ||
findMemSDNode(N)->getAddressSpace() != AMDGPUAS::FLAT_ADDRESS) &&
CurDAG->isBaseWithConstantOffset(Addr)) {
SDValue N0 = Addr.getOperand(0);
SDValue N1 = Addr.getOperand(1);
int64_t COffsetVal = cast<ConstantSDNode>(N1)->getSExtValue();

const SIInstrInfo *TII = Subtarget->getInstrInfo();
if (TII->isLegalFLATOffset(COffsetVal, findMemSDNode(N)->getAddressSpace(),
IsSigned)) {
Addr = N0;
OffsetVal = COffsetVal;
}
}

VAddr = Addr;
Offset = CurDAG->getTargetConstant(OffsetVal, SDLoc(), MVT::i16);
SLC = CurDAG->getTargetConstant(0, SDLoc(), MVT::i1);
return true;
}

bool AMDGPUDAGToDAGISel::SelectFlatAtomic(SDNode *N,
Expand All @@ -1625,10 +1658,10 @@ bool AMDGPUDAGToDAGISel::SelectFlatAtomic(SDNode *N,
}

bool AMDGPUDAGToDAGISel::SelectFlatAtomicSigned(SDNode *N,
SDValue Addr,
SDValue &VAddr,
SDValue &Offset,
SDValue &SLC) const {
SDValue Addr,
SDValue &VAddr,
SDValue &Offset,
SDValue &SLC) const {
return SelectFlatOffset<true>(N, Addr, VAddr, Offset, SLC);
}

Expand Down
48 changes: 0 additions & 48 deletions llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp
Expand Up @@ -2828,54 +2828,6 @@ bool AMDGPUTargetLowering::shouldCombineMemoryType(EVT VT) const {
return true;
}

// Find a load or store from corresponding pattern root.
// Roots may be build_vector, bitconvert or their combinations.
static MemSDNode* findMemSDNode(SDNode *N) {
N = AMDGPUTargetLowering::stripBitcast(SDValue(N,0)).getNode();
if (MemSDNode *MN = dyn_cast<MemSDNode>(N))
return MN;
assert(isa<BuildVectorSDNode>(N));
for (SDValue V : N->op_values())
if (MemSDNode *MN =
dyn_cast<MemSDNode>(AMDGPUTargetLowering::stripBitcast(V)))
return MN;
llvm_unreachable("cannot find MemSDNode in the pattern!");
}

bool AMDGPUTargetLowering::SelectFlatOffset(bool IsSigned,
SelectionDAG &DAG,
SDNode *N,
SDValue Addr,
SDValue &VAddr,
SDValue &Offset,
SDValue &SLC) const {
const GCNSubtarget &ST =
DAG.getMachineFunction().getSubtarget<GCNSubtarget>();
int64_t OffsetVal = 0;

if (ST.hasFlatInstOffsets() &&
(!ST.hasFlatSegmentOffsetBug() ||
findMemSDNode(N)->getAddressSpace() != AMDGPUAS::FLAT_ADDRESS) &&
DAG.isBaseWithConstantOffset(Addr)) {
SDValue N0 = Addr.getOperand(0);
SDValue N1 = Addr.getOperand(1);
int64_t COffsetVal = cast<ConstantSDNode>(N1)->getSExtValue();

const SIInstrInfo *TII = ST.getInstrInfo();
if (TII->isLegalFLATOffset(COffsetVal, findMemSDNode(N)->getAddressSpace(),
IsSigned)) {
Addr = N0;
OffsetVal = COffsetVal;
}
}

VAddr = Addr;
Offset = DAG.getTargetConstant(OffsetVal, SDLoc(), MVT::i16);
SLC = DAG.getTargetConstant(0, SDLoc(), MVT::i1);

return true;
}

// Replace load of an illegal type with a store of a bitcast to a friendlier
// type.
SDValue AMDGPUTargetLowering::performLoadCombine(SDNode *N,
Expand Down
4 changes: 0 additions & 4 deletions llvm/lib/Target/AMDGPU/AMDGPUISelLowering.h
Expand Up @@ -326,10 +326,6 @@ class AMDGPUTargetLowering : public TargetLowering {
}

AtomicExpansionKind shouldExpandAtomicRMWInIR(AtomicRMWInst *) const override;

bool SelectFlatOffset(bool IsSigned, SelectionDAG &DAG, SDNode *N,
SDValue Addr, SDValue &VAddr, SDValue &Offset,
SDValue &SLC) const;
};

namespace AMDGPUISD {
Expand Down

0 comments on commit 4227c62

Please sign in to comment.