diff options
author | Geoff Berry <gberry@codeaurora.org> | 2018-01-24 18:09:53 +0000 |
---|---|---|
committer | Geoff Berry <gberry@codeaurora.org> | 2018-01-24 18:09:53 +0000 |
commit | c4796d474572a03c97d0ddac4584b65c3e0e267f (patch) | |
tree | f23aaa1d3507a9beadc02a456199e02afa52811e /llvm/lib | |
parent | 4afb64e4c601e89f0645deb86de3784f5ff2927b (diff) | |
download | bcm5719-llvm-c4796d474572a03c97d0ddac4584b65c3e0e267f.tar.gz bcm5719-llvm-c4796d474572a03c97d0ddac4584b65c3e0e267f.zip |
[AMDGPU] Make sure all super regs of reserved regs are marked reserved.
Summary:
Move reserveRegisterTuples into AMDGPURegisterInfo and use it in
R600RegisterInfo::getReservedRegs and
R600InstrInfo::reserveIndirectRegisters to ensure that all super
registers of reserved registers are also marked as reserved.
Before this change, under certain circumstances, the registers %t1_x and
%t1_xyzw would be marked as reserved, but %t1_xy and %t1_xyz would not
be, leading to the register allocator sometimes assigning a register to
%t1_xy, which is invalid since %t1_x is reserved.
Reviewers: arsenm, tstellar, MatzeB, qcolombet
Subscribers: kzhuravl, wdng, nhaehnle, yaxunl, dstuttard, tpr, t-tye, mcrosier, llvm-commits
Differential Revision: https://reviews.llvm.org/D42448
llvm-svn: 323356
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.cpp | 7 | ||||
-rw-r--r-- | llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.h | 2 | ||||
-rw-r--r-- | llvm/lib/Target/AMDGPU/R600InstrInfo.cpp | 7 | ||||
-rw-r--r-- | llvm/lib/Target/AMDGPU/R600InstrInfo.h | 3 | ||||
-rw-r--r-- | llvm/lib/Target/AMDGPU/R600RegisterInfo.cpp | 32 | ||||
-rw-r--r-- | llvm/lib/Target/AMDGPU/SIRegisterInfo.cpp | 7 | ||||
-rw-r--r-- | llvm/lib/Target/AMDGPU/SIRegisterInfo.h | 1 |
7 files changed, 30 insertions, 29 deletions
diff --git a/llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.cpp b/llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.cpp index 5e4d33aaa69..376be7db6ec 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.cpp +++ b/llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.cpp @@ -37,6 +37,13 @@ unsigned AMDGPURegisterInfo::getSubRegFromChannel(unsigned Channel) const { return SubRegs[Channel]; } +void AMDGPURegisterInfo::reserveRegisterTuples(BitVector &Reserved, unsigned Reg) const { + MCRegAliasIterator R(Reg, this, true); + + for (; R.isValid(); ++R) + Reserved.set(*R); +} + #define GET_REGINFO_TARGET_DESC #include "AMDGPUGenRegisterInfo.inc" diff --git a/llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.h b/llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.h index d8604d2590f..00d1e1e8ddc 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.h +++ b/llvm/lib/Target/AMDGPU/AMDGPURegisterInfo.h @@ -30,6 +30,8 @@ struct AMDGPURegisterInfo : public AMDGPUGenRegisterInfo { /// \returns the sub reg enum value for the given \p Channel /// (e.g. getSubRegFromChannel(0) -> AMDGPU::sub0) unsigned getSubRegFromChannel(unsigned Channel) const; + + void reserveRegisterTuples(BitVector &, unsigned Reg) const; }; } // End namespace llvm diff --git a/llvm/lib/Target/AMDGPU/R600InstrInfo.cpp b/llvm/lib/Target/AMDGPU/R600InstrInfo.cpp index 23e646c8147..3e718f14c7f 100644 --- a/llvm/lib/Target/AMDGPU/R600InstrInfo.cpp +++ b/llvm/lib/Target/AMDGPU/R600InstrInfo.cpp @@ -1082,7 +1082,8 @@ bool R600InstrInfo::expandPostRAPseudo(MachineInstr &MI) const { } void R600InstrInfo::reserveIndirectRegisters(BitVector &Reserved, - const MachineFunction &MF) const { + const MachineFunction &MF, + const R600RegisterInfo &TRI) const { const R600Subtarget &ST = MF.getSubtarget<R600Subtarget>(); const R600FrameLowering *TFL = ST.getFrameLowering(); @@ -1093,11 +1094,9 @@ void R600InstrInfo::reserveIndirectRegisters(BitVector &Reserved, return; for (int Index = getIndirectIndexBegin(MF); Index <= End; ++Index) { - unsigned SuperReg = AMDGPU::R600_Reg128RegClass.getRegister(Index); - Reserved.set(SuperReg); for (unsigned Chan = 0; Chan < StackWidth; ++Chan) { unsigned Reg = AMDGPU::R600_TReg32RegClass.getRegister((4 * Index) + Chan); - Reserved.set(Reg); + TRI.reserveRegisterTuples(Reserved, Reg); } } } diff --git a/llvm/lib/Target/AMDGPU/R600InstrInfo.h b/llvm/lib/Target/AMDGPU/R600InstrInfo.h index abaa3745075..9999cc516f6 100644 --- a/llvm/lib/Target/AMDGPU/R600InstrInfo.h +++ b/llvm/lib/Target/AMDGPU/R600InstrInfo.h @@ -211,7 +211,8 @@ public: /// \brief Reserve the registers that may be accesed using indirect addressing. void reserveIndirectRegisters(BitVector &Reserved, - const MachineFunction &MF) const; + const MachineFunction &MF, + const R600RegisterInfo &TRI) const; /// Calculate the "Indirect Address" for the given \p RegIndex and /// \p Channel diff --git a/llvm/lib/Target/AMDGPU/R600RegisterInfo.cpp b/llvm/lib/Target/AMDGPU/R600RegisterInfo.cpp index 7501facb0cb..b622110690c 100644 --- a/llvm/lib/Target/AMDGPU/R600RegisterInfo.cpp +++ b/llvm/lib/Target/AMDGPU/R600RegisterInfo.cpp @@ -31,27 +31,27 @@ BitVector R600RegisterInfo::getReservedRegs(const MachineFunction &MF) const { const R600Subtarget &ST = MF.getSubtarget<R600Subtarget>(); const R600InstrInfo *TII = ST.getInstrInfo(); - Reserved.set(AMDGPU::ZERO); - Reserved.set(AMDGPU::HALF); - Reserved.set(AMDGPU::ONE); - Reserved.set(AMDGPU::ONE_INT); - Reserved.set(AMDGPU::NEG_HALF); - Reserved.set(AMDGPU::NEG_ONE); - Reserved.set(AMDGPU::PV_X); - Reserved.set(AMDGPU::ALU_LITERAL_X); - Reserved.set(AMDGPU::ALU_CONST); - Reserved.set(AMDGPU::PREDICATE_BIT); - Reserved.set(AMDGPU::PRED_SEL_OFF); - Reserved.set(AMDGPU::PRED_SEL_ZERO); - Reserved.set(AMDGPU::PRED_SEL_ONE); - Reserved.set(AMDGPU::INDIRECT_BASE_ADDR); + reserveRegisterTuples(Reserved, AMDGPU::ZERO); + reserveRegisterTuples(Reserved, AMDGPU::HALF); + reserveRegisterTuples(Reserved, AMDGPU::ONE); + reserveRegisterTuples(Reserved, AMDGPU::ONE_INT); + reserveRegisterTuples(Reserved, AMDGPU::NEG_HALF); + reserveRegisterTuples(Reserved, AMDGPU::NEG_ONE); + reserveRegisterTuples(Reserved, AMDGPU::PV_X); + reserveRegisterTuples(Reserved, AMDGPU::ALU_LITERAL_X); + reserveRegisterTuples(Reserved, AMDGPU::ALU_CONST); + reserveRegisterTuples(Reserved, AMDGPU::PREDICATE_BIT); + reserveRegisterTuples(Reserved, AMDGPU::PRED_SEL_OFF); + reserveRegisterTuples(Reserved, AMDGPU::PRED_SEL_ZERO); + reserveRegisterTuples(Reserved, AMDGPU::PRED_SEL_ONE); + reserveRegisterTuples(Reserved, AMDGPU::INDIRECT_BASE_ADDR); for (TargetRegisterClass::iterator I = AMDGPU::R600_AddrRegClass.begin(), E = AMDGPU::R600_AddrRegClass.end(); I != E; ++I) { - Reserved.set(*I); + reserveRegisterTuples(Reserved, *I); } - TII->reserveIndirectRegisters(Reserved, MF); + TII->reserveIndirectRegisters(Reserved, MF, *this); return Reserved; } diff --git a/llvm/lib/Target/AMDGPU/SIRegisterInfo.cpp b/llvm/lib/Target/AMDGPU/SIRegisterInfo.cpp index 3c73dd78f20..21658ece2f2 100644 --- a/llvm/lib/Target/AMDGPU/SIRegisterInfo.cpp +++ b/llvm/lib/Target/AMDGPU/SIRegisterInfo.cpp @@ -101,13 +101,6 @@ SIRegisterInfo::SIRegisterInfo(const SISubtarget &ST) : VGPRSetID < NumRegPressureSets); } -void SIRegisterInfo::reserveRegisterTuples(BitVector &Reserved, unsigned Reg) const { - MCRegAliasIterator R(Reg, this, true); - - for (; R.isValid(); ++R) - Reserved.set(*R); -} - unsigned SIRegisterInfo::reservedPrivateSegmentBufferReg( const MachineFunction &MF) const { diff --git a/llvm/lib/Target/AMDGPU/SIRegisterInfo.h b/llvm/lib/Target/AMDGPU/SIRegisterInfo.h index bf814b6974a..81515ec8a25 100644 --- a/llvm/lib/Target/AMDGPU/SIRegisterInfo.h +++ b/llvm/lib/Target/AMDGPU/SIRegisterInfo.h @@ -36,7 +36,6 @@ private: bool SpillSGPRToVGPR; bool SpillSGPRToSMEM; - void reserveRegisterTuples(BitVector &, unsigned Reg) const; void classifyPressureSet(unsigned PSetID, unsigned Reg, BitVector &PressureSets) const; public: |