Fix a couple of minor problems. Because PHI nodes can use themselves, this
authorChris Lattner <sabre@nondot.org>
Fri, 12 Mar 2004 23:12:55 +0000 (23:12 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 12 Mar 2004 23:12:55 +0000 (23:12 +0000)
could cause infinite loops.  Also, getUnderlyingObject can return null

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12351 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/BasicAliasAnalysis.cpp

index 617ae55d1aeaf5a9dee92d386541d612ff1619ed..e928a265ff091da20634fd413205ee51f10996a3 100644 (file)
@@ -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.