forked from OSchip/llvm-project
Add a public method called getAddressSpace() to the GlobalAddressSDNode.
llvm-svn: 70366
This commit is contained in:
parent
e525dc3c66
commit
ccd30945f9
|
@ -1814,6 +1814,8 @@ public:
|
|||
|
||||
GlobalValue *getGlobal() const { return TheGlobal; }
|
||||
int64_t getOffset() const { return Offset; }
|
||||
// Return the address space this GlobalAddress belongs to.
|
||||
unsigned getAddressSpace() const;
|
||||
|
||||
static bool classof(const GlobalAddressSDNode *) { return true; }
|
||||
static bool classof(const SDNode *N) {
|
||||
|
|
|
@ -5649,6 +5649,13 @@ void SDNode::dumpr() const {
|
|||
DumpNodesr(errs(), this, 0, 0, once);
|
||||
}
|
||||
|
||||
|
||||
// getAddressSpace - Return the address space this GlobalAddress belongs to.
|
||||
unsigned GlobalAddressSDNode::getAddressSpace() const {
|
||||
return getGlobal()->getType()->getAddressSpace();
|
||||
}
|
||||
|
||||
|
||||
const Type *ConstantPoolSDNode::getType() const {
|
||||
if (isMachineConstantPoolEntry())
|
||||
return Val.MachineCPVal->getType();
|
||||
|
|
|
@ -483,9 +483,8 @@ bool PIC16TargetLowering::isRomAddress(const SDValue &Op) {
|
|||
// It is BUILD_PAIR((PIC16Lo TGA), (PIC16Hi TGA)) and Op is BUILD_PAIR
|
||||
SDValue TGA = Op.getOperand(0).getOperand(0);
|
||||
GlobalAddressSDNode *GSDN = dyn_cast<GlobalAddressSDNode>(TGA);
|
||||
int AddrSpace = GSDN->getGlobal()->getType()->getAddressSpace();
|
||||
|
||||
if (AddrSpace == PIC16ISD::ROM_SPACE)
|
||||
if (GSDN->getAddressSpace() == PIC16ISD::ROM_SPACE)
|
||||
return true;
|
||||
|
||||
// Any other address space return it false
|
||||
|
|
Loading…
Reference in New Issue