aboutsummaryrefslogtreecommitdiff
path: root/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
commit5b280f28351bbdc103cc50d3b0f52f92d286fa0a (patch)
tree55e1e1ce8256a7cc8f16e6ca67b1998b6ed89cd5 /lib/Analysis/ThreadSafety.cpp
parent1deeedb6808c6a2aa24de6317960199f04012345 (diff)
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. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@164242 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/ThreadSafety.cpp')
-rw-r--r--lib/Analysis/ThreadSafety.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/lib/Analysis/ThreadSafety.cpp b/lib/Analysis/ThreadSafety.cpp
index 196d5e1eb3..e7d9a2d642 100644
--- a/lib/Analysis/ThreadSafety.cpp
+++ b/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());
+ }
}