summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/Lint.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2010-11-11 19:23:51 +0000
committerDan Gohman <gohman@apple.com>2010-11-11 19:23:51 +0000
commit7dacf8f3f30d9b4582c7ef2f12c8d139be68351a (patch)
treed1832099dfe82c5a45ccfaa4dc9fb8e717535abc /llvm/lib/Analysis/Lint.cpp
parent07f06c4e96916965c5d9a262a5b90116ad464e4c (diff)
downloadbcm5719-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.cpp7
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()) {
OpenPOWER on IntegriCloud