diff options
author | Dan Gohman <gohman@apple.com> | 2010-11-11 19:23:51 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2010-11-11 19:23:51 +0000 |
commit | 7dacf8f3f30d9b4582c7ef2f12c8d139be68351a (patch) | |
tree | d1832099dfe82c5a45ccfaa4dc9fb8e717535abc /llvm/lib/Analysis/Lint.cpp | |
parent | 07f06c4e96916965c5d9a262a5b90116ad464e4c (diff) | |
download | bcm5719-llvm-7dacf8f3f30d9b4582c7ef2f12c8d139be68351a.tar.gz bcm5719-llvm-7dacf8f3f30d9b4582c7ef2f12c8d139be68351a.zip |
Avoid calling alias on non-pointer values.
llvm-svn: 118822
Diffstat (limited to 'llvm/lib/Analysis/Lint.cpp')
-rw-r--r-- | llvm/lib/Analysis/Lint.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/llvm/lib/Analysis/Lint.cpp b/llvm/lib/Analysis/Lint.cpp index b27ca47142f..4318a30fa6c 100644 --- a/llvm/lib/Analysis/Lint.cpp +++ b/llvm/lib/Analysis/Lint.cpp @@ -231,10 +231,11 @@ void Lint::visitCallSite(CallSite CS) { // to do. Known partial overlap is not distinguished from the case // where nothing is known. if (Formal->hasNoAliasAttr() && Actual->getType()->isPointerTy()) - for (CallSite::arg_iterator BI = CS.arg_begin(); BI != AE; ++BI) { - Assert1(AI == BI || AA->alias(*AI, *BI) != AliasAnalysis::MustAlias, + 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); - } // Check that an sret argument points to valid memory. if (Formal->hasStructRetAttr() && Actual->getType()->isPointerTy()) { |