[llvm-commits] [llvm] r118617 - /llvm/trunk/lib/Transforms/IPO/FunctionAttrs.cpp
Dan Gohman
gohman at apple.com
Tue Nov 9 11:56:27 PST 2010
Author: djg
Date: Tue Nov 9 13:56:27 2010
New Revision: 118617
URL: http://llvm.org/viewvc/llvm-project?rev=118617&view=rev
Log:
Teach FunctionAttrs about AccessesArgumentsReadonly.
Modified:
llvm/trunk/lib/Transforms/IPO/FunctionAttrs.cpp
Modified: llvm/trunk/lib/Transforms/IPO/FunctionAttrs.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/IPO/FunctionAttrs.cpp?rev=118617&r1=118616&r2=118617&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/IPO/FunctionAttrs.cpp (original)
+++ llvm/trunk/lib/Transforms/IPO/FunctionAttrs.cpp Tue Nov 9 13:56:27 2010
@@ -152,6 +152,25 @@
}
// Only reads and writes local memory.
continue;
+ case AliasAnalysis::AccessesArgumentsReadonly:
+ // Check whether all pointer arguments point to local memory, and
+ // ignore calls that only access local memory.
+ for (CallSite::arg_iterator CI = CS.arg_begin(), CE = CS.arg_end();
+ CI != CE; ++CI) {
+ Value *Arg = *CI;
+ if (Arg->getType()->isPointerTy()) {
+ AliasAnalysis::Location Loc(Arg,
+ AliasAnalysis::UnknownSize,
+ I->getMetadata(LLVMContext::MD_tbaa));
+ if (!AA->pointsToConstantMemory(Loc, /*OrLocal=*/true)) {
+ // Reads non-local memory.
+ ReadsMemory = true;
+ break;
+ }
+ }
+ }
+ // Only reads memory.
+ continue;
default:
// Otherwise, be conservative.
break;
More information about the llvm-commits
mailing list