summaryrefslogtreecommitdiffstats
path: root/clang/lib/Analysis/ThreadSafety.cpp
diff options
context:
space:
mode:
authorDeLesley Hutchins <delesley@google.com>2012-09-19 19:18:29 +0000
committerDeLesley Hutchins <delesley@google.com>2012-09-19 19:18:29 +0000
commita15e1b4f631692340fc60c0590fddb9af950cdc3 (patch)
treebf75120f81771823eb0704eed4fd08d74ee9ad33 /clang/lib/Analysis/ThreadSafety.cpp
parent92b5940fbb49a15715fde80f6dd1221953519c7f (diff)
downloadbcm5719-llvm-a15e1b4f631692340fc60c0590fddb9af950cdc3.tar.gz
bcm5719-llvm-a15e1b4f631692340fc60c0590fddb9af950cdc3.zip
Thread-safety analysis: fix ICE when EXCLUSIVE_LOCKS_REQUIRED or
LOCKS_EXCLUDED is used on a method with a name that is is not a simple identifier. llvm-svn: 164242
Diffstat (limited to 'clang/lib/Analysis/ThreadSafety.cpp')
-rw-r--r--clang/lib/Analysis/ThreadSafety.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/clang/lib/Analysis/ThreadSafety.cpp b/clang/lib/Analysis/ThreadSafety.cpp
index 196d5e1eb36..e7d9a2d642c 100644
--- a/clang/lib/Analysis/ThreadSafety.cpp
+++ b/clang/lib/Analysis/ThreadSafety.cpp
@@ -1794,9 +1794,12 @@ void BuildLockset::warnIfMutexHeld(const NamedDecl *D, Expr* Exp,
}
LockData* LDat = FSet.findLock(Analyzer->FactMan, Mutex);
- if (LDat)
- Analyzer->Handler.handleFunExcludesLock(D->getName(), Mutex.toString(),
+ if (LDat) {
+ std::string DeclName = D->getNameAsString();
+ StringRef DeclNameSR (DeclName);
+ Analyzer->Handler.handleFunExcludesLock(DeclNameSR, Mutex.toString(),
Exp->getExprLoc());
+ }
}
OpenPOWER on IntegriCloud