diff options
author | DeLesley Hutchins <delesley@google.com> | 2011-12-29 00:56:48 +0000 |
---|---|---|
committer | DeLesley Hutchins <delesley@google.com> | 2011-12-29 00:56:48 +0000 |
commit | 714296cb3177329eb42411b85ef5a7fc9696efc7 (patch) | |
tree | 07db12be133e25e61eacabdf9ec15a879eee51a8 /clang/lib/Analysis/ThreadSafety.cpp | |
parent | f97c521368e266f228ecd91b71217c6d53cad448 (diff) | |
download | bcm5719-llvm-714296cb3177329eb42411b85ef5a7fc9696efc7.tar.gz bcm5719-llvm-714296cb3177329eb42411b85ef5a7fc9696efc7.zip |
Support for thread safety attributes on functions
llvm-svn: 147331
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 005d45545f1..a1a8f5a606a 100644 --- a/clang/lib/Analysis/ThreadSafety.cpp +++ b/clang/lib/Analysis/ThreadSafety.cpp @@ -147,6 +147,9 @@ class MutexID { Parent = CE->getImplicitObjectArgument(); NumArgs = CE->getNumArgs(); FunArgs = CE->getArgs(); + } else if (CallExpr *CE = dyn_cast<CallExpr>(DeclExp)) { + NumArgs = CE->getNumArgs(); + FunArgs = CE->getArgs(); } else if (CXXConstructExpr *CE = dyn_cast<CXXConstructExpr>(DeclExp)) { Parent = 0; // FIXME -- get the parent from DeclStmt NumArgs = CE->getNumArgs(); @@ -350,7 +353,7 @@ public: void VisitUnaryOperator(UnaryOperator *UO); void VisitBinaryOperator(BinaryOperator *BO); void VisitCastExpr(CastExpr *CE); - void VisitCXXMemberCallExpr(CXXMemberCallExpr *Exp); + void VisitCallExpr(CallExpr *Exp); void VisitCXXConstructExpr(CXXConstructExpr *Exp); void VisitDeclStmt(DeclStmt *S); }; @@ -647,7 +650,7 @@ void BuildLockset::VisitCastExpr(CastExpr *CE) { } -void BuildLockset::VisitCXXMemberCallExpr(CXXMemberCallExpr *Exp) { +void BuildLockset::VisitCallExpr(CallExpr *Exp) { NamedDecl *D = dyn_cast_or_null<NamedDecl>(Exp->getCalleeDecl()); if(!D || !D->hasAttrs()) return; |