diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2013-02-26 21:15:54 +0000 |
---|---|---|
committer | Matt Arsenault <Matthew.Arsenault@amd.com> | 2013-02-26 21:15:54 +0000 |
commit | 5509f37aacf8a4d65f759554c9ec18adc1ac7b4e (patch) | |
tree | dbcc6dbfeedea5dc5ea4687816678a22f1b62e96 | |
parent | 58c79037256c77ffdbaa0da12205777e239fe096 (diff) |
Fix initializer for variables with attribute address_space set.
This would error in C++ mode unless the variable also had a cv
qualifier.
e.g.
__attribute__((address_space(2))) float foo = 1.0f; would error but
__attribute__((address_space(2))) const float foo = 1.0f; would not.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@176121 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Sema/SemaOverload.cpp | 6 | ||||
-rw-r--r-- | test/SemaCXX/address-space-initialize.cpp | 25 |
2 files changed, 26 insertions, 5 deletions
diff --git a/lib/Sema/SemaOverload.cpp b/lib/Sema/SemaOverload.cpp index 9bba5f6c78..16fd28e461 100644 --- a/lib/Sema/SemaOverload.cpp +++ b/lib/Sema/SemaOverload.cpp @@ -1667,11 +1667,7 @@ static bool IsStandardConversion(Sema &S, Expr* From, QualType ToType, CanonTo = S.Context.getCanonicalType(ToType); if (CanonFrom.getLocalUnqualifiedType() == CanonTo.getLocalUnqualifiedType() && - (CanonFrom.getLocalCVRQualifiers() != CanonTo.getLocalCVRQualifiers() - || CanonFrom.getObjCGCAttr() != CanonTo.getObjCGCAttr() - || CanonFrom.getObjCLifetime() != CanonTo.getObjCLifetime() - || (CanonFrom->isSamplerT() && - CanonFrom.getAddressSpace() != CanonTo.getAddressSpace()))) { + CanonFrom.getLocalQualifiers() != CanonTo.getLocalQualifiers()) { FromType = ToType; CanonFrom = CanonTo; } diff --git a/test/SemaCXX/address-space-initialize.cpp b/test/SemaCXX/address-space-initialize.cpp new file mode 100644 index 0000000000..50913384c5 --- /dev/null +++ b/test/SemaCXX/address-space-initialize.cpp @@ -0,0 +1,25 @@ +// RUN: %clang_cc1 -fsyntax-only -verify %s + +__attribute__((address_space(42))) +const float withc = 1.0f; + +__attribute__((address_space(42))) +volatile float withv = 1.0f; + +__attribute__((address_space(42))) +float nocv = 1.0f; + +__attribute__((address_space(42))) +float nocv_array[10] = { 1.0f }; + +__attribute__((address_space(42))) +int nocv_iarray[10] = { 4 }; + + +__attribute__((address_space(9999))) +int* as_ptr = nocv_iarray; // expected-error{{cannot initialize a variable of type '__attribute__((address_space(9999))) int *' with an lvalue of type '__attribute__((address_space(42))) int [10]'}} + + +__attribute__((address_space(42))) int* __attribute__((address_space(42))) ptr_in_same_addr_space = nocv_iarray; +__attribute__((address_space(42))) int* __attribute__((address_space(999))) ptr_in_different_addr_space = nocv_iarray; + |