[llvm] 9a7afae - [OpaquePtr][InferAddrSpace] Use PointerType::getWithSamePointeeType()
Arthur Eubanks via llvm-commits
llvm-commits at lists.llvm.org
Fri Jul 9 10:29:46 PDT 2021
Author: Arthur Eubanks
Date: 2021-07-09T10:29:08-07:00
New Revision: 9a7afae4927c5a379631b538116c3796f402a970
URL: https://github.com/llvm/llvm-project/commit/9a7afae4927c5a379631b538116c3796f402a970
DIFF: https://github.com/llvm/llvm-project/commit/9a7afae4927c5a379631b538116c3796f402a970.diff
LOG: [OpaquePtr][InferAddrSpace] Use PointerType::getWithSamePointeeType()
Added:
Modified:
llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp b/llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp
index c48a0e7b7ed2..63b8425f2d01 100644
--- a/llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp
+++ b/llvm/lib/Transforms/Scalar/InferAddressSpaces.cpp
@@ -508,8 +508,8 @@ static Value *operandWithNewAddressSpaceOrCreateUndef(
SmallVectorImpl<const Use *> *UndefUsesToFix) {
Value *Operand = OperandUse.get();
- Type *NewPtrTy =
- Operand->getType()->getPointerElementType()->getPointerTo(NewAddrSpace);
+ Type *NewPtrTy = PointerType::getWithSamePointeeType(
+ cast<PointerType>(Operand->getType()), NewAddrSpace);
if (Constant *C = dyn_cast<Constant>(Operand))
return ConstantExpr::getAddrSpaceCast(C, NewPtrTy);
@@ -537,8 +537,8 @@ Value *InferAddressSpacesImpl::cloneInstructionWithNewAddressSpace(
Instruction *I, unsigned NewAddrSpace,
const ValueToValueMapTy &ValueWithNewAddrSpace,
SmallVectorImpl<const Use *> *UndefUsesToFix) const {
- Type *NewPtrType =
- I->getType()->getPointerElementType()->getPointerTo(NewAddrSpace);
+ Type *NewPtrType = PointerType::getWithSamePointeeType(
+ cast<PointerType>(I->getType()), NewAddrSpace);
if (I->getOpcode() == Instruction::AddrSpaceCast) {
Value *Src = I->getOperand(0);
@@ -572,7 +572,8 @@ Value *InferAddressSpacesImpl::cloneInstructionWithNewAddressSpace(
if (AS != UninitializedAddressSpace) {
// For the assumed address space, insert an `addrspacecast` to make that
// explicit.
- auto *NewPtrTy = I->getType()->getPointerElementType()->getPointerTo(AS);
+ Type *NewPtrTy = PointerType::getWithSamePointeeType(
+ cast<PointerType>(I->getType()), AS);
auto *NewI = new AddrSpaceCastInst(I, NewPtrTy);
NewI->insertAfter(I);
return NewI;
@@ -634,8 +635,8 @@ static Value *cloneConstantExprWithNewAddressSpace(
ConstantExpr *CE, unsigned NewAddrSpace,
const ValueToValueMapTy &ValueWithNewAddrSpace, const DataLayout *DL,
const TargetTransformInfo *TTI) {
- Type *TargetType =
- CE->getType()->getPointerElementType()->getPointerTo(NewAddrSpace);
+ Type *TargetType = PointerType::getWithSamePointeeType(
+ cast<PointerType>(CE->getType()), NewAddrSpace);
if (CE->getOpcode() == Instruction::AddrSpaceCast) {
// Because CE is flat, the source address space must be specific.
More information about the llvm-commits
mailing list