diff options
author | David Majnemer <david.majnemer@gmail.com> | 2014-12-16 06:31:17 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2014-12-16 06:31:17 +0000 |
commit | e7029bce82c9048aa7c8730bda838d3d4a10c837 (patch) | |
tree | 96124e60f7ad751f2cf99d2d9b86bddc7f008b8b /clang | |
parent | 0f479da711772d7f87b2622fca002809d28a822e (diff) | |
download | bcm5719-llvm-e7029bce82c9048aa7c8730bda838d3d4a10c837.tar.gz bcm5719-llvm-e7029bce82c9048aa7c8730bda838d3d4a10c837.zip |
Sema: Don't crash converting to bool from _Atomic
Turning our _Atomic L-value into an R-value removes its _Atomic-ness.
However, we didn't update our 'FromType' which made
ScalarTypeToBooleanCastKind think we were trying to pass it a
non-scalar.
This fixes PR21836.
llvm-svn: 224322
Diffstat (limited to 'clang')
-rw-r--r-- | clang/lib/Sema/SemaExprCXX.cpp | 2 | ||||
-rw-r--r-- | clang/test/SemaCXX/atomic-type.cpp | 4 |
2 files changed, 5 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp index 1f9c1ea73cd..2227721f70e 100644 --- a/clang/lib/Sema/SemaExprCXX.cpp +++ b/clang/lib/Sema/SemaExprCXX.cpp @@ -2754,10 +2754,10 @@ Sema::PerformImplicitConversion(Expr *From, QualType ToType, case ICK_Lvalue_To_Rvalue: { assert(From->getObjectKind() != OK_ObjCProperty); - FromType = FromType.getUnqualifiedType(); ExprResult FromRes = DefaultLvalueConversion(From); assert(!FromRes.isInvalid() && "Can't perform deduced conversion?!"); From = FromRes.get(); + FromType = From->getType(); break; } diff --git a/clang/test/SemaCXX/atomic-type.cpp b/clang/test/SemaCXX/atomic-type.cpp index ae18eab5b4a..779b0671cad 100644 --- a/clang/test/SemaCXX/atomic-type.cpp +++ b/clang/test/SemaCXX/atomic-type.cpp @@ -83,3 +83,7 @@ namespace copy_init { // allows extraneous braces around initializers. Y y3 = { { X(0) }, { 4 } }; // expected-error 2{{illegal initializer type}} } + +bool PR21836(_Atomic(int) *x) { + return *x; +} |