Add support for 'rename'
authorChris Lattner <sabre@nondot.org>
Tue, 24 Feb 2004 22:17:00 +0000 (22:17 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 24 Feb 2004 22:17:00 +0000 (22:17 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@11813 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/DataStructure/Local.cpp

index 52e588bf28579c9b180e294c03997a6904587550..681b61f67ba723932043741f3a8595a4e4af2909 100644 (file)
@@ -484,10 +484,15 @@ void GraphBuilder::visitCallSite(CallSite CS) {
             N->setHeapNodeMarker()->setModifiedMarker()->setReadMarker();
           return;
         } else if (F->getName() == "atoi" || F->getName() == "atof" ||
-                   F->getName() == "remove") {
-          // atoi reads its argument.
-          if (DSNode *N = getValueDest(**CS.arg_begin()).getNode())
-            N->setReadMarker();
+                   F->getName() == "remove" || F->getName() == "unlink" ||
+                   F->getName() == "rename") {
+          // These functions read all of their pointer operands.
+          for (CallSite::arg_iterator AI = CS.arg_begin(), E = CS.arg_end();
+               AI != E; ++AI) {
+            if (isPointerType((*AI)->getType()))
+              if (DSNode *N = getValueDest(**AI).getNode())
+                N->setReadMarker();   
+          }
           return;
 
         } else if (F->getName() == "fopen" && CS.arg_end()-CS.arg_begin() == 2){