mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-10 06:03:52 +00:00
AMDGPU: Add helper function for implicit parameter offsets.
Patch by: Zoltan Gilian git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@241861 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b5ebaf3ae5
commit
847c023a2e
@ -2649,6 +2649,18 @@ SDValue AMDGPUTargetLowering::CreateLiveInRegister(SelectionDAG &DAG,
|
||||
return DAG.getRegister(VirtualRegister, VT);
|
||||
}
|
||||
|
||||
uint32_t AMDGPUTargetLowering::getImplicitParameterOffset(
|
||||
const AMDGPUMachineFunction *MFI, const ImplicitParameter Param) const {
|
||||
uint64_t ArgOffset = MFI->ABIArgOffset;
|
||||
switch (Param) {
|
||||
case GRID_DIM:
|
||||
return ArgOffset;
|
||||
case GRID_OFFSET:
|
||||
return ArgOffset + 4;
|
||||
}
|
||||
llvm_unreachable("unexpected implicit parameter type");
|
||||
}
|
||||
|
||||
#define NODE_NAME_CASE(node) case AMDGPUISD::node: return #node;
|
||||
|
||||
const char* AMDGPUTargetLowering::getTargetNodeName(unsigned Opcode) const {
|
||||
|
@ -207,6 +207,16 @@ public:
|
||||
virtual SDValue CreateLiveInRegister(SelectionDAG &DAG,
|
||||
const TargetRegisterClass *RC,
|
||||
unsigned Reg, EVT VT) const;
|
||||
|
||||
enum ImplicitParameter {
|
||||
GRID_DIM,
|
||||
GRID_OFFSET
|
||||
};
|
||||
|
||||
/// \brief Helper function that returns the byte offset of the given
|
||||
/// type of implicit parameter.
|
||||
unsigned getImplicitParameterOffset(const AMDGPUMachineFunction *MFI,
|
||||
const ImplicitParameter Param) const;
|
||||
};
|
||||
|
||||
namespace AMDGPUISD {
|
||||
|
@ -815,8 +815,10 @@ SDValue R600TargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) const
|
||||
case Intrinsic::r600_read_local_size_z:
|
||||
return LowerImplicitParameter(DAG, VT, DL, 8);
|
||||
|
||||
case Intrinsic::AMDGPU_read_workdim:
|
||||
return LowerImplicitParameter(DAG, VT, DL, MFI->ABIArgOffset / 4);
|
||||
case Intrinsic::AMDGPU_read_workdim: {
|
||||
uint32_t ByteOffset = getImplicitParameterOffset(MFI, GRID_DIM);
|
||||
return LowerImplicitParameter(DAG, VT, DL, ByteOffset / 4);
|
||||
}
|
||||
|
||||
case Intrinsic::r600_read_tgid_x:
|
||||
return CreateLiveInRegister(DAG, &AMDGPU::R600_TReg32RegClass,
|
||||
|
@ -928,6 +928,7 @@ SDValue SITargetLowering::copyToM0(SelectionDAG &DAG, SDValue Chain, SDLoc DL,
|
||||
SDValue SITargetLowering::LowerINTRINSIC_WO_CHAIN(SDValue Op,
|
||||
SelectionDAG &DAG) const {
|
||||
MachineFunction &MF = DAG.getMachineFunction();
|
||||
auto MFI = MF.getInfo<SIMachineFunctionInfo>();
|
||||
const SIRegisterInfo *TRI =
|
||||
static_cast<const SIRegisterInfo *>(Subtarget->getRegisterInfo());
|
||||
|
||||
@ -966,8 +967,7 @@ SDValue SITargetLowering::LowerINTRINSIC_WO_CHAIN(SDValue Op,
|
||||
|
||||
case Intrinsic::AMDGPU_read_workdim:
|
||||
return LowerParameter(DAG, VT, VT, DL, DAG.getEntryNode(),
|
||||
MF.getInfo<SIMachineFunctionInfo>()->ABIArgOffset,
|
||||
false);
|
||||
getImplicitParameterOffset(MFI, GRID_DIM), false);
|
||||
|
||||
case Intrinsic::r600_read_tgid_x:
|
||||
return CreateLiveInRegister(DAG, &AMDGPU::SReg_32RegClass,
|
||||
|
Loading…
Reference in New Issue
Block a user