diff options
author | Sanjay Patel <spatel@rotateright.com> | 2020-11-22 12:54:18 -0500 |
---|---|---|
committer | Sanjay Patel <spatel@rotateright.com> | 2020-11-22 12:54:18 -0500 |
commit | c5a4d80fd47cfdae1995df46d0c407f78d8666e8 (patch) | |
tree | f7b74a8766f3162104654a792ac2994ef17e23c2 /llvm/lib/Analysis/ValueTracking.cpp | |
parent | 221c2b8862b1e507a6e79ca2731c2f839a2fd482 (diff) | |
download | llvm-c5a4d80fd47cfdae1995df46d0c407f78d8666e8.zip llvm-c5a4d80fd47cfdae1995df46d0c407f78d8666e8.tar.gz llvm-c5a4d80fd47cfdae1995df46d0c407f78d8666e8.tar.bz2 |
[ValueTracking][MemCpyOpt] avoid crash on inttoptr with vector pointer type (PR48075)
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
-rw-r--r-- | llvm/lib/Analysis/ValueTracking.cpp | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp index bcf3511..90f8dff 100644 --- a/llvm/lib/Analysis/ValueTracking.cpp +++ b/llvm/lib/Analysis/ValueTracking.cpp @@ -3610,12 +3610,13 @@ Value *llvm::isBytewiseValue(Value *V, const DataLayout &DL) { if (auto *CE = dyn_cast<ConstantExpr>(C)) { if (CE->getOpcode() == Instruction::IntToPtr) { - auto PS = DL.getPointerSizeInBits( - cast<PointerType>(CE->getType())->getAddressSpace()); - return isBytewiseValue( - ConstantExpr::getIntegerCast(CE->getOperand(0), - Type::getIntNTy(Ctx, PS), false), - DL); + if (auto *PtrTy = dyn_cast<PointerType>(CE->getType())) { + unsigned BitWidth = DL.getPointerSizeInBits(PtrTy->getAddressSpace()); + return isBytewiseValue( + ConstantExpr::getIntegerCast(CE->getOperand(0), + Type::getIntNTy(Ctx, BitWidth), false), + DL); + } } } |