Skip to content

Commit 24b2348

Browse files
committed
Merging r246051:
------------------------------------------------------------------------ r246051 | Matthew.Arsenault | 2015-08-26 14:54:50 -0400 (Wed, 26 Aug 2015) | 6 lines AMDGPU: Make sure to reserve super registers I think this could potentially have broken if one of the super registers were allocated that contain v254/v255. ------------------------------------------------------------------------ git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_37@253235 91177308-0d34-0410-b5e6-96231b3b80d8
1 parent 50dd59a commit 24b2348

File tree

2 files changed

+18
-16
lines changed

2 files changed

+18
-16
lines changed

lib/Target/AMDGPU/SIRegisterInfo.cpp

Lines changed: 15 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -26,23 +26,25 @@ using namespace llvm;
2626

2727
SIRegisterInfo::SIRegisterInfo() : AMDGPURegisterInfo() {}
2828

29-
BitVector SIRegisterInfo::getReservedRegs(const MachineFunction &MF) const {
30-
BitVector Reserved(getNumRegs());
31-
Reserved.set(AMDGPU::EXEC);
29+
void SIRegisterInfo::reserveRegisterTuples(BitVector &Reserved, unsigned Reg) const {
30+
MCRegAliasIterator R(Reg, this, true);
3231

33-
// EXEC_LO and EXEC_HI could be allocated and used as regular register,
34-
// but this seems likely to result in bugs, so I'm marking them as reserved.
35-
Reserved.set(AMDGPU::EXEC_LO);
36-
Reserved.set(AMDGPU::EXEC_HI);
32+
for (; R.isValid(); ++R)
33+
Reserved.set(*R);
34+
}
3735

36+
BitVector SIRegisterInfo::getReservedRegs(const MachineFunction &MF) const {
37+
BitVector Reserved(getNumRegs());
3838
Reserved.set(AMDGPU::INDIRECT_BASE_ADDR);
39-
Reserved.set(AMDGPU::FLAT_SCR);
40-
Reserved.set(AMDGPU::FLAT_SCR_LO);
41-
Reserved.set(AMDGPU::FLAT_SCR_HI);
39+
40+
// EXEC_LO and EXEC_HI could be allocated and used as regular register, but
41+
// this seems likely to result in bugs, so I'm marking them as reserved.
42+
reserveRegisterTuples(Reserved, AMDGPU::EXEC);
43+
reserveRegisterTuples(Reserved, AMDGPU::FLAT_SCR);
4244

4345
// Reserve some VGPRs to use as temp registers in case we have to spill VGPRs
44-
Reserved.set(AMDGPU::VGPR255);
45-
Reserved.set(AMDGPU::VGPR254);
46+
reserveRegisterTuples(Reserved, AMDGPU::VGPR254);
47+
reserveRegisterTuples(Reserved, AMDGPU::VGPR255);
4648

4749
// Tonga and Iceland can only allocate a fixed number of SGPRs due
4850
// to a hw bug.
@@ -54,10 +56,7 @@ BitVector SIRegisterInfo::getReservedRegs(const MachineFunction &MF) const {
5456

5557
for (unsigned i = Limit; i < NumSGPRs; ++i) {
5658
unsigned Reg = AMDGPU::SGPR_32RegClass.getRegister(i);
57-
MCRegAliasIterator R = MCRegAliasIterator(Reg, this, true);
58-
59-
for (; R.isValid(); ++R)
60-
Reserved.set(*R);
59+
reserveRegisterTuples(Reserved, Reg);
6160
}
6261
}
6362

lib/Target/AMDGPU/SIRegisterInfo.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,10 @@
2323
namespace llvm {
2424

2525
struct SIRegisterInfo : public AMDGPURegisterInfo {
26+
private:
27+
void reserveRegisterTuples(BitVector &, unsigned Reg) const;
2628

29+
public:
2730
SIRegisterInfo();
2831

2932
BitVector getReservedRegs(const MachineFunction &MF) const override;

0 commit comments

Comments
 (0)