mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-13 23:20:41 +00:00
Fix a couple of minor problems. Because PHI nodes can use themselves, this
could cause infinite loops. Also, getUnderlyingObject can return null llvm-svn: 12351
This commit is contained in:
parent
a9c937b8ec
commit
bb08e801d4
@ -159,9 +159,6 @@ static bool AddressMightEscape(const Value *V) {
|
||||
return true;
|
||||
if (AddressMightEscape(I)) return true;
|
||||
break;
|
||||
case Instruction::PHI:
|
||||
if (AddressMightEscape(I)) return true;
|
||||
break;
|
||||
default:
|
||||
return true;
|
||||
}
|
||||
@ -178,7 +175,7 @@ AliasAnalysis::ModRefResult
|
||||
BasicAliasAnalysis::getModRefInfo(CallSite CS, Value *P, unsigned Size) {
|
||||
if (!isa<Constant>(P) && !isa<GlobalValue>(P))
|
||||
if (const AllocationInst *AI =
|
||||
dyn_cast<AllocationInst>(getUnderlyingObject(P))) {
|
||||
dyn_cast_or_null<AllocationInst>(getUnderlyingObject(P))) {
|
||||
// Okay, the pointer is to a stack allocated object. If we can prove that
|
||||
// the pointer never "escapes", then we know the call cannot clobber it,
|
||||
// because it simply can't get its address.
|
||||
|
Loading…
x
Reference in New Issue
Block a user