diff options
author | DeLesley Hutchins <delesley@google.com> | 2012-09-19 19:18:29 +0000 |
---|---|---|
committer | DeLesley Hutchins <delesley@google.com> | 2012-09-19 19:18:29 +0000 |
commit | a15e1b4f631692340fc60c0590fddb9af950cdc3 (patch) | |
tree | bf75120f81771823eb0704eed4fd08d74ee9ad33 /clang/lib/Analysis/ThreadSafety.cpp | |
parent | 92b5940fbb49a15715fde80f6dd1221953519c7f (diff) | |
download | bcm5719-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.cpp | 7 |
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()); + } } |