By definition, 'tail' calls cannot access the stack frame of their caller.
authorChris Lattner <sabre@nondot.org>
Sun, 8 May 2005 23:58:12 +0000 (23:58 +0000)
committerChris Lattner <sabre@nondot.org>
Sun, 8 May 2005 23:58:12 +0000 (23:58 +0000)
Expose this as a simple form of mod/ref information.  This implements
BasicAA/tailcall-modref.ll

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

lib/Analysis/BasicAliasAnalysis.cpp

index 334ef4a7d56560493119b58d96a843026da4916c..1110a017de9862236c4b1b2f3d1dfd318d4cbb1c 100644 (file)
@@ -239,6 +239,12 @@ BasicAliasAnalysis::getModRefInfo(CallSite CS, Value *P, unsigned Size) {
       // because it simply can't get its address.
       if (!AddressMightEscape(AI))
         return NoModRef;
+
+      // If this is a tail call and P points to a stack location, we know that
+      // the tail call cannot access or modify the local stack.
+      if (CallInst *CI = dyn_cast<CallInst>(CS.getInstruction()))
+        if (CI->isTailCall() && isa<AllocaInst>(AI))
+          return NoModRef;
     }
 
   // The AliasAnalysis base class has some smarts, lets use them.