mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
(1) Added special register class containing (for now) %fsr.
Fixed spilling of %fcc[0-3] which are part of %fsr. (2) Moved some machine-independent reg-class code to class TargetRegInfo from SparcReg{Class,}Info. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6343 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a22eace55b
commit
bfebd79dd1
@ -45,6 +45,8 @@ public:
|
|||||||
std::vector<bool> &IsColorUsedArr) const = 0;
|
std::vector<bool> &IsColorUsedArr) const = 0;
|
||||||
virtual bool isRegVolatile(int Reg) const = 0;
|
virtual bool isRegVolatile(int Reg) const = 0;
|
||||||
|
|
||||||
|
virtual const char* const getRegName(unsigned reg) const = 0;
|
||||||
|
|
||||||
TargetRegClassInfo(unsigned ID, unsigned NVR, unsigned NAR)
|
TargetRegClassInfo(unsigned ID, unsigned NVR, unsigned NAR)
|
||||||
: RegClassID(ID), NumOfAvailRegs(NVR), NumOfAllRegs(NAR) {}
|
: RegClassID(ID), NumOfAvailRegs(NVR), NumOfAllRegs(NAR) {}
|
||||||
};
|
};
|
||||||
@ -75,11 +77,16 @@ public:
|
|||||||
// code register class will be returned. Otherwise, the normal register
|
// code register class will be returned. Otherwise, the normal register
|
||||||
// class (eg. int, float) must be returned.
|
// class (eg. int, float) must be returned.
|
||||||
virtual unsigned getRegClassIDOfType (const Type *type,
|
virtual unsigned getRegClassIDOfType (const Type *type,
|
||||||
bool isCCReg = false) const =0;
|
bool isCCReg = false) const = 0;
|
||||||
virtual unsigned getRegClassIDOfReg (int unifiedRegNum) const =0;
|
virtual unsigned getRegClassIDOfRegType(int regType) const = 0;
|
||||||
virtual unsigned getRegClassIDOfRegType(int regType) const =0;
|
|
||||||
|
unsigned getRegClassIDOfReg(int unifiedRegNum) const {
|
||||||
inline unsigned int getNumOfRegClasses() const {
|
unsigned classId = 0;
|
||||||
|
(void) getClassRegNum(unifiedRegNum, classId);
|
||||||
|
return classId;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int getNumOfRegClasses() const {
|
||||||
return MachineRegClassArr.size();
|
return MachineRegClassArr.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -169,13 +176,43 @@ public:
|
|||||||
|
|
||||||
// Each register class has a seperate space for register IDs. To convert
|
// Each register class has a seperate space for register IDs. To convert
|
||||||
// a regId in a register class to a common Id, or vice versa,
|
// a regId in a register class to a common Id, or vice versa,
|
||||||
// we use the folloing methods.
|
// we use the folloing two methods.
|
||||||
//
|
//
|
||||||
virtual int getUnifiedRegNum(unsigned regClassID, int reg) const = 0;
|
// Thsi method converts from class reg. number to unified register number.
|
||||||
virtual int getClassRegNum(int unifiedRegNum, unsigned& regClassID) const =0;
|
int getUnifiedRegNum(unsigned regClassID, int reg) const {
|
||||||
|
if (reg == getInvalidRegNum()) { return getInvalidRegNum(); }
|
||||||
|
assert(regClassID < getNumOfRegClasses() && "Invalid register class");
|
||||||
|
int totalRegs = 0;
|
||||||
|
for (unsigned rcid = 0; rcid < regClassID; ++rcid)
|
||||||
|
totalRegs += MachineRegClassArr[rcid]->getNumOfAllRegs();
|
||||||
|
return reg + totalRegs;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This method converts the unified number to the number in its class,
|
||||||
|
// and returns the class ID in regClassID.
|
||||||
|
int getClassRegNum(int uRegNum, unsigned& regClassID) const {
|
||||||
|
if (uRegNum == getInvalidRegNum()) { return getInvalidRegNum(); }
|
||||||
|
|
||||||
|
int totalRegs = 0, rcid = 0, NC = getNumOfRegClasses();
|
||||||
|
while (rcid < NC &&
|
||||||
|
uRegNum >= totalRegs + (int) MachineRegClassArr[rcid]->getNumOfAllRegs()) {
|
||||||
|
totalRegs += MachineRegClassArr[rcid]->getNumOfAllRegs();
|
||||||
|
rcid++;
|
||||||
|
}
|
||||||
|
if (rcid == NC) {
|
||||||
|
assert(0 && "getClassRegNum(): Invalid register number");
|
||||||
|
return getInvalidRegNum();
|
||||||
|
}
|
||||||
|
regClassID = rcid;
|
||||||
|
return uRegNum - totalRegs;
|
||||||
|
}
|
||||||
|
|
||||||
// Returns the assembly-language name of the specified machine register.
|
// Returns the assembly-language name of the specified machine register.
|
||||||
virtual const char * const getUnifiedRegName(int UnifiedRegNum) const = 0;
|
const char * const getUnifiedRegName(int UnifiedRegNum) const {
|
||||||
|
unsigned regClassID = getNumOfRegClasses(); // initialize to invalid value
|
||||||
|
int regNumInClass = getClassRegNum(UnifiedRegNum, regClassID);
|
||||||
|
return MachineRegClassArr[regClassID]->getRegName(regNumInClass);
|
||||||
|
}
|
||||||
|
|
||||||
virtual int getRegType(const Type* type) const = 0;
|
virtual int getRegType(const Type* type) const = 0;
|
||||||
virtual int getRegType(const LiveRange *LR) const = 0;
|
virtual int getRegType(const LiveRange *LR) const = 0;
|
||||||
@ -191,7 +228,6 @@ public:
|
|||||||
//
|
//
|
||||||
virtual int getInvalidRegNum() const = 0;
|
virtual int getInvalidRegNum() const = 0;
|
||||||
|
|
||||||
|
|
||||||
// Method for inserting caller saving code. The caller must save all the
|
// Method for inserting caller saving code. The caller must save all the
|
||||||
// volatile registers across a call based on the calling conventions of
|
// volatile registers across a call based on the calling conventions of
|
||||||
// an architecture. This must insert code for saving and restoring
|
// an architecture. This must insert code for saving and restoring
|
||||||
|
Loading…
x
Reference in New Issue
Block a user