Since onlyReadsMemory returns true if in fact
authorDuncan Sands <baldrick@free.fr>
Wed, 3 Sep 2008 15:31:24 +0000 (15:31 +0000)
committerDuncan Sands <baldrick@free.fr>
Wed, 3 Sep 2008 15:31:24 +0000 (15:31 +0000)
doesNotAccessMemory, check doesNotAccessMemory
first, since otherwise functions may be
marked readonly rather than readnone.

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

lib/Analysis/IPA/GlobalsModRef.cpp
test/Analysis/GlobalsModRef/2008-09-03-ReadNone.ll [new file with mode: 0644]

index c8347c23fdb94be09bc78c52cf6787ac863f60e4..5f3846949842ced366f110d13ae4c8f9f2d935b3 100644 (file)
@@ -376,14 +376,16 @@ void GlobalsModRef::AnalyzeCallGraph(CallGraph &CG, Module &M) {
 
       if (F->isDeclaration()) {
         // Try to get mod/ref behaviour from function attributes.
-        if (F->onlyReadsMemory()) {
+        if (F->doesNotAccessMemory()) {
+          // Can't do better than that!
+        } else if (F->onlyReadsMemory()) {
           FunctionEffect |= Ref;
           // This function might call back into the module and read a global, so
           // mark all globals read somewhere as being read by this function.
           for (std::set<GlobalValue*>::iterator GI = ReadGlobals.begin(),
                E = ReadGlobals.end(); GI != E; ++GI)
             FR.GlobalInfo[*GI] |= Ref;
-        } else if (!F->doesNotAccessMemory()) {
+        } else {
           // Can't say anything useful.
           KnowNothing = true;
         }
diff --git a/test/Analysis/GlobalsModRef/2008-09-03-ReadNone.ll b/test/Analysis/GlobalsModRef/2008-09-03-ReadNone.ll
new file mode 100644 (file)
index 0000000..b286ada
--- /dev/null
@@ -0,0 +1,9 @@
+; RUN: llvm-as < %s | opt -globalsmodref-aa -markmodref | llvm-dis | grep readnone | count 2
+
+define i32 @f() {
+entry:
+       %tmp = call i32 @e( )           ; <i32> [#uses=1]
+       ret i32 %tmp
+}
+
+declare i32 @e() readnone