[llvm] r285768 - AMDGPU: Handle CopyToReg in getOperandRegClass
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 1 16:22:18 PDT 2016
Author: arsenm
Date: Tue Nov 1 18:22:17 2016
New Revision: 285768
URL: http://llvm.org/viewvc/llvm-project?rev=285768&view=rev
Log:
AMDGPU: Handle CopyToReg in getOperandRegClass
Modified:
llvm/trunk/lib/Target/AMDGPU/AMDGPUISelDAGToDAG.cpp
Modified: llvm/trunk/lib/Target/AMDGPU/AMDGPUISelDAGToDAG.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/AMDGPU/AMDGPUISelDAGToDAG.cpp?rev=285768&r1=285767&r2=285768&view=diff
==============================================================================
--- llvm/trunk/lib/Target/AMDGPU/AMDGPUISelDAGToDAG.cpp (original)
+++ llvm/trunk/lib/Target/AMDGPU/AMDGPUISelDAGToDAG.cpp Tue Nov 1 18:22:17 2016
@@ -183,8 +183,21 @@ bool AMDGPUDAGToDAGISel::isInlineImmedia
/// determined.
const TargetRegisterClass *AMDGPUDAGToDAGISel::getOperandRegClass(SDNode *N,
unsigned OpNo) const {
- if (!N->isMachineOpcode())
+ if (!N->isMachineOpcode()) {
+ if (N->getOpcode() == ISD::CopyToReg) {
+ unsigned Reg = cast<RegisterSDNode>(N->getOperand(1))->getReg();
+ if (TargetRegisterInfo::isVirtualRegister(Reg)) {
+ MachineRegisterInfo &MRI = CurDAG->getMachineFunction().getRegInfo();
+ return MRI.getRegClass(Reg);
+ }
+
+ const SIRegisterInfo *TRI
+ = static_cast<const SISubtarget *>(Subtarget)->getRegisterInfo();
+ return TRI->getPhysRegClass(Reg);
+ }
+
return nullptr;
+ }
switch (N->getMachineOpcode()) {
default: {
More information about the llvm-commits
mailing list