summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2011-10-25 06:33:21 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2011-10-25 06:33:21 +0000
commitd4268d91e7f1df42776a8e1994c7415fc04d7571 (patch)
tree866bc335d2012fc24360b3d9b54e2f7f67d717a8
parent7b2fbc61de0dc43dc72bec93e4bb4110b9635931 (diff)
downloadbcm5719-llvm-d4268d91e7f1df42776a8e1994c7415fc04d7571.tar.gz
bcm5719-llvm-d4268d91e7f1df42776a8e1994c7415fc04d7571.zip
Don't forget the lvalue-to-rvalue conversion on the LHS when instantiating a
dependent ->, where the member being referred to is an anonymous struct or union. This path was missed by the fix in r142890. llvm-svn: 142910
-rw-r--r--clang/lib/Sema/TreeTransform.h5
-rw-r--r--clang/test/SemaCXX/warn-thread-safety-analysis.cpp7
2 files changed, 12 insertions, 0 deletions
diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h
index 46bd05b14ba..3c118cb423d 100644
--- a/clang/lib/Sema/TreeTransform.h
+++ b/clang/lib/Sema/TreeTransform.h
@@ -1482,6 +1482,11 @@ public:
FoundDecl, Member);
if (BaseResult.isInvalid())
return ExprError();
+ if (isArrow) {
+ BaseResult = getSema().DefaultLvalueConversion(BaseResult.take());
+ if (BaseResult.isInvalid())
+ return ExprError();
+ }
Base = BaseResult.take();
ExprValueKind VK = isArrow ? VK_LValue : Base->getValueKind();
MemberExpr *ME =
diff --git a/clang/test/SemaCXX/warn-thread-safety-analysis.cpp b/clang/test/SemaCXX/warn-thread-safety-analysis.cpp
index b020e5712a0..b4d44170fec 100644
--- a/clang/test/SemaCXX/warn-thread-safety-analysis.cpp
+++ b/clang/test/SemaCXX/warn-thread-safety-analysis.cpp
@@ -1516,10 +1516,17 @@ namespace template_member_test {
Mutex m;
S *s GUARDED_BY(this->m);
};
+ Mutex m;
+ struct U {
+ union {
+ int n;
+ };
+ } *u GUARDED_BY(m);
template<typename U>
struct IndirectLock {
int DoNaughtyThings(T *t) {
+ u->n = 0; // expected-warning {{reading variable 'u' requires locking 'm'}}
return t->s->n; // expected-warning {{reading variable 's' requires locking 'm'}}
}
};
OpenPOWER on IntegriCloud