diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp index 9bba5f6c78d9..16fd28e4615e 100644 --- a/clang/lib/Sema/SemaOverload.cpp +++ b/clang/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/clang/test/SemaCXX/address-space-initialize.cpp b/clang/test/SemaCXX/address-space-initialize.cpp new file mode 100644 index 000000000000..50913384c5cf --- /dev/null +++ b/clang/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; +