Teach Type::getPointerAddressSpace to look through pointer vectors

politely and document this feature.

This simple API extension then allows us to write all of the
Instructions' address space query methods much more simply. No
functionality change intended here.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@167223 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chandler Carruth 2012-11-01 09:37:49 +00:00
parent 426c2bf5cd
commit 8fb614cb3b
3 changed files with 11 additions and 35 deletions

View File

@ -226,7 +226,7 @@ public:
static unsigned getPointerOperandIndex() { return 0U; }
unsigned getPointerAddressSpace() const {
return cast<PointerType>(getPointerOperand()->getType())->getAddressSpace();
return getPointerOperand()->getType()->getPointerAddressSpace();
}
@ -348,16 +348,7 @@ public:
static unsigned getPointerOperandIndex() { return 1U; }
unsigned getPointerAddressSpace() const {
if (getPointerOperand()->getType()->isPointerTy())
return cast<PointerType>(getPointerOperand()->getType())
->getAddressSpace();
if (getPointerOperand()->getType()->isVectorTy()
&& cast<VectorType>(getPointerOperand()->getType())->isPointerTy())
return cast<PointerType>(cast<VectorType>(
getPointerOperand()->getType())->getElementType())
->getAddressSpace();
llvm_unreachable("Only a vector of pointers or pointers can be used!");
return 0;
return getPointerOperand()->getType()->getPointerAddressSpace();
}
// Methods for support type inquiry through isa, cast, and dyn_cast:
@ -527,7 +518,7 @@ public:
const Value *getNewValOperand() const { return getOperand(2); }
unsigned getPointerAddressSpace() const {
return cast<PointerType>(getPointerOperand()->getType())->getAddressSpace();
return getPointerOperand()->getType()->getPointerAddressSpace();
}
// Methods for support type inquiry through isa, cast, and dyn_cast:
@ -670,7 +661,7 @@ public:
const Value *getValOperand() const { return getOperand(1); }
unsigned getPointerAddressSpace() const {
return cast<PointerType>(getPointerOperand()->getType())->getAddressSpace();
return getPointerOperand()->getType()->getPointerAddressSpace();
}
// Methods for support type inquiry through isa, cast, and dyn_cast:
@ -801,7 +792,7 @@ public:
}
unsigned getPointerAddressSpace() const {
return cast<PointerType>(getPointerOperandType())->getAddressSpace();
return getPointerOperand()->getType()->getPointerAddressSpace();
}
/// getPointerOperandType - Method to return the pointer operand as a
@ -3616,15 +3607,7 @@ public:
/// @brief return the address space of the pointer.
unsigned getAddressSpace() const {
if (getType()->isPointerTy())
return cast<PointerType>(getType())->getAddressSpace();
if (getType()->isVectorTy() &&
cast<VectorType>(getType())->getElementType()->isPointerTy())
return cast<PointerType>(
cast<VectorType>(getType())->getElementType())
->getAddressSpace();
llvm_unreachable("Must be a pointer or a vector of pointers.");
return 0;
return getType()->getPointerAddressSpace();
}
// Methods for support type inquiry through isa, cast, and dyn_cast:
@ -3665,16 +3648,7 @@ public:
/// @brief return the address space of the pointer.
unsigned getPointerAddressSpace() const {
Type *Ty = getOperand(0)->getType();
if (Ty->isPointerTy())
return cast<PointerType>(Ty)->getAddressSpace();
if (Ty->isVectorTy()
&& cast<VectorType>(Ty)->getElementType()->isPointerTy())
return cast<PointerType>(
cast<VectorType>(Ty)->getElementType())
->getAddressSpace();
llvm_unreachable("Must be a pointer or a vector of pointers.");
return 0;
return getOperand(0)->getType()->getPointerAddressSpace();
}
// Methods for support type inquiry through isa, cast, and dyn_cast:

View File

@ -346,8 +346,10 @@ public:
unsigned getVectorNumElements() const;
Type *getVectorElementType() const { return getSequentialElementType(); }
unsigned getPointerAddressSpace() const;
Type *getPointerElementType() const { return getSequentialElementType(); }
/// \brief Get the address space of this pointer or pointer vector type.
unsigned getPointerAddressSpace() const;
//===--------------------------------------------------------------------===//
// Static members exported by the Type class itself. Useful for getting

View File

@ -215,7 +215,7 @@ unsigned Type::getVectorNumElements() const {
}
unsigned Type::getPointerAddressSpace() const {
return cast<PointerType>(this)->getAddressSpace();
return cast<PointerType>(getScalarType())->getAddressSpace();
}