mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-16 00:17:32 +00:00
Use stripPointerCasts instead of doing the same manually.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@80267 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c75cd159cd
commit
aae87cde50
@ -308,13 +308,9 @@ BasicAliasAnalysis::getModRefInfo(CallSite CS1, CallSite CS2) {
|
||||
AliasAnalysis::AliasResult
|
||||
BasicAliasAnalysis::alias(const Value *V1, unsigned V1Size,
|
||||
const Value *V2, unsigned V2Size) {
|
||||
// Strip off any constant expression casts if they exist
|
||||
if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(V1))
|
||||
if (CE->isCast() && isa<PointerType>(CE->getOperand(0)->getType()))
|
||||
V1 = CE->getOperand(0);
|
||||
if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(V2))
|
||||
if (CE->isCast() && isa<PointerType>(CE->getOperand(0)->getType()))
|
||||
V2 = CE->getOperand(0);
|
||||
// Strip off any casts if they exist.
|
||||
V1 = V1->stripPointerCasts();
|
||||
V2 = V2->stripPointerCasts();
|
||||
|
||||
// Are we checking for alias of the same value?
|
||||
if (V1 == V2) return MustAlias;
|
||||
@ -322,13 +318,6 @@ BasicAliasAnalysis::alias(const Value *V1, unsigned V1Size,
|
||||
if (!isa<PointerType>(V1->getType()) || !isa<PointerType>(V2->getType()))
|
||||
return NoAlias; // Scalars cannot alias each other
|
||||
|
||||
// Strip off cast instructions. Since V1 and V2 are pointers, they must be
|
||||
// pointer<->pointer bitcasts.
|
||||
if (const BitCastInst *I = dyn_cast<BitCastInst>(V1))
|
||||
return alias(I->getOperand(0), V1Size, V2, V2Size);
|
||||
if (const BitCastInst *I = dyn_cast<BitCastInst>(V2))
|
||||
return alias(V1, V1Size, I->getOperand(0), V2Size);
|
||||
|
||||
// Figure out what objects these things are pointing to if we can.
|
||||
const Value *O1 = V1->getUnderlyingObject();
|
||||
const Value *O2 = V2->getUnderlyingObject();
|
||||
|
Loading…
Reference in New Issue
Block a user