[llvm-commits] [llvm] r121514 - /llvm/trunk/lib/Analysis/Lint.cpp
Dan Gohman
gohman at apple.com
Fri Dec 10 12:04:06 PST 2010
Author: djg
Date: Fri Dec 10 14:04:06 2010
New Revision: 121514
URL: http://llvm.org/viewvc/llvm-project?rev=121514&view=rev
Log:
Use PartialAlias to do better noalias lint checking.
Modified:
llvm/trunk/lib/Analysis/Lint.cpp
Modified: llvm/trunk/lib/Analysis/Lint.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/Lint.cpp?rev=121514&r1=121513&r2=121514&view=diff
==============================================================================
--- llvm/trunk/lib/Analysis/Lint.cpp (original)
+++ llvm/trunk/lib/Analysis/Lint.cpp Fri Dec 10 14:04:06 2010
@@ -232,10 +232,12 @@
// where nothing is known.
if (Formal->hasNoAliasAttr() && Actual->getType()->isPointerTy())
for (CallSite::arg_iterator BI = CS.arg_begin(); BI != AE; ++BI)
- Assert1(AI == BI ||
- !(*BI)->getType()->isPointerTy() ||
- AA->alias(*AI, *BI) != AliasAnalysis::MustAlias,
- "Unusual: noalias argument aliases another argument", &I);
+ if (AI != BI && (*BI)->getType()->isPointerTy()) {
+ AliasAnalysis::AliasResult Result = AA->alias(*AI, *BI);
+ Assert1(Result != AliasAnalysis::MustAlias &&
+ Result != AliasAnalysis::PartialAlias,
+ "Unusual: noalias argument aliases another argument", &I);
+ }
// Check that an sret argument points to valid memory.
if (Formal->hasStructRetAttr() && Actual->getType()->isPointerTy()) {
More information about the llvm-commits
mailing list