Author: Anastasia Stulova
Date: 2020-02-25T16:05:37Z
New Revision: fa755d3e71ed590ac5c62f0e1eff09435c9593fe

URL: 
https://github.com/llvm/llvm-project/commit/fa755d3e71ed590ac5c62f0e1eff09435c9593fe
DIFF: 
https://github.com/llvm/llvm-project/commit/fa755d3e71ed590ac5c62f0e1eff09435c9593fe.diff

LOG: [Sema][C++] Propagate conversion kind to specialize the diagnostics

Compute and propagate conversion kind to diagnostics helper in C++
to provide more specific diagnostics about incorrect implicit
conversions in assignments, initializations, params, etc...

Duplicated some diagnostics as errors because C++ is more strict.

Tags: #clang

Differential Revision: https://reviews.llvm.org/D74116

Added: 
    

Modified: 
    clang/include/clang/Basic/DiagnosticSemaKinds.td
    clang/include/clang/Sema/Sema.h
    clang/lib/Sema/SemaExpr.cpp
    clang/lib/Sema/SemaExprCXX.cpp
    clang/test/CXX/conv/conv.fctptr/p1.cpp
    clang/test/CXX/drs/dr3xx.cpp
    clang/test/CXX/except/except.handle/p16.cpp
    clang/test/CXX/expr/p13.cpp
    clang/test/CXX/temp/temp.spec/temp.expl.spec/p19.cpp
    clang/test/CXX/temp/temp.spec/temp.explicit/p10.cpp
    clang/test/CXX/temp/temp.spec/temp.explicit/p9.cpp
    clang/test/OpenMP/allocate_allocator_messages.cpp
    clang/test/Sema/block-call.c
    clang/test/Sema/block-return.c
    clang/test/Sema/callingconv-ms_abi.c
    clang/test/Sema/callingconv-sysv_abi.c
    clang/test/Sema/callingconv.c
    clang/test/Sema/overloadable.c
    clang/test/Sema/pass-object-size.c
    clang/test/Sema/preserve-call-conv.c
    clang/test/SemaCXX/addr-of-overloaded-function.cpp
    clang/test/SemaCXX/decl-microsoft-call-conv.cpp
    clang/test/SemaCXX/goto.cpp
    clang/test/SemaCXX/int-ptr-cast-SFINAE.cpp
    clang/test/SemaCXX/ms-property-error.cpp
    clang/test/SemaObjC/arc.m
    clang/test/SemaObjC/comptypes-legal.m
    clang/test/SemaObjCXX/arc-type-conversion.mm
    clang/test/SemaObjCXX/comptypes-1.mm
    clang/test/SemaObjCXX/comptypes-7.mm
    clang/test/SemaObjCXX/instantiate-expr.mm
    clang/test/SemaObjCXX/instantiate-stmt.mm
    clang/test/SemaObjCXX/noescape.mm
    clang/test/SemaObjCXX/nullability-pragmas.mm
    clang/test/SemaObjCXX/objc-container-subscripting.mm
    clang/test/SemaObjCXX/parameterized_classes_subst.mm
    clang/test/SemaObjCXX/property-invalid-type.mm
    clang/test/SemaOpenCL/address-spaces-conversions-cl2.0.cl
    clang/test/SemaOpenCL/address-spaces.cl
    clang/test/SemaTemplate/extern-templates.cpp
    clang/test/SemaTemplate/instantiate-member-class.cpp
    clang/test/SemaTemplate/member-access-expr.cpp
    clang/test/SemaTemplate/temp_arg_nontype.cpp

Removed: 
    


################################################################################
diff  --git a/clang/include/clang/Basic/DiagnosticSemaKinds.td 
b/clang/include/clang/Basic/DiagnosticSemaKinds.td
index 60f2c777676d..91688cf99f9c 100644
--- a/clang/include/clang/Basic/DiagnosticSemaKinds.td
+++ b/clang/include/clang/Basic/DiagnosticSemaKinds.td
@@ -7367,6 +7367,21 @@ def warn_incompatible_qualified_id : Warning<
   "sending type to parameter of incompatible type}0,1"
   "|%
diff {casting $ to incompatible type $|"
   "casting type to incompatible type}0,1}2">;
+def err_incompatible_qualified_id : Error<
+  "%select{%
diff {assigning to $ from incompatible type $|"
+  "assigning to type from incompatible type}0,1"
+  "|%
diff {passing $ to parameter of incompatible type $|"
+  "passing type to parameter of incompatible type}0,1"
+  "|%
diff {returning $ from a function with incompatible result type $|"
+  "returning type from a function with incompatible result type}0,1"
+  "|%
diff {converting $ to incompatible type $|"
+  "converting type to incompatible type}0,1"
+  "|%
diff {initializing $ with an expression of incompatible type $|"
+  "initializing type with an expression of incompatible type}0,1"
+  "|%
diff {sending $ to parameter of incompatible type $|"
+  "sending type to parameter of incompatible type}0,1"
+  "|%
diff {casting $ to incompatible type $|"
+  "casting type to incompatible type}0,1}2">;
 def ext_typecheck_convert_pointer_int : ExtWarn<
   "incompatible pointer to integer conversion "
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
@@ -7385,6 +7400,23 @@ def ext_typecheck_convert_pointer_int : ExtWarn<
   "; remove *|"
   "; remove &}3">,
   InGroup<IntConversion>;
+def err_typecheck_convert_pointer_int : Error<
+  "incompatible pointer to integer conversion "
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2"
+  "%select{|; dereference with *|"
+  "; take the address with &|"
+  "; remove *|"
+  "; remove &}3">;
 def ext_typecheck_convert_int_pointer : ExtWarn<
   "incompatible integer to pointer conversion "
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
@@ -7403,6 +7435,23 @@ def ext_typecheck_convert_int_pointer : ExtWarn<
   "; remove *|"
   "; remove &}3">,
   InGroup<IntConversion>, SFINAEFailure;
+def err_typecheck_convert_int_pointer : Error<
+  "incompatible integer to pointer conversion "
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2"
+  "%select{|; dereference with *|"
+  "; take the address with &|"
+  "; remove *|"
+  "; remove &}3">;
 def ext_typecheck_convert_pointer_void_func : Extension<
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
   "|%
diff {passing $ to parameter of type $|"
@@ -7416,6 +7465,19 @@ def ext_typecheck_convert_pointer_void_func : Extension<
   "sending to parameter of 
diff erent type}0,1"
   "|%
diff {casting $ to type $|casting between types}0,1}2"
   " converts between void pointer and function pointer">;
+def err_typecheck_convert_pointer_void_func : Error<
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2"
+  " converts between void pointer and function pointer">;
 def ext_typecheck_convert_incompatible_pointer_sign : ExtWarn<
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
   "|%
diff {passing $ to parameter of type $|"
@@ -7430,6 +7492,19 @@ def ext_typecheck_convert_incompatible_pointer_sign : 
ExtWarn<
   "|%
diff {casting $ to type $|casting between types}0,1}2"
   " converts between pointers to integer types with 
diff erent sign">,
   InGroup<DiagGroup<"pointer-sign">>;
+def err_typecheck_convert_incompatible_pointer_sign : Error<
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2"
+  " converts between pointers to integer types with 
diff erent sign">;
 def ext_typecheck_convert_incompatible_pointer : ExtWarn<
   "incompatible pointer types "
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
@@ -7448,6 +7523,23 @@ def ext_typecheck_convert_incompatible_pointer : ExtWarn<
   "; remove *|"
   "; remove &}3">,
   InGroup<IncompatiblePointerTypes>;
+def err_typecheck_convert_incompatible_pointer : Error<
+  "incompatible pointer types "
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2"
+  "%select{|; dereference with *|"
+  "; take the address with &|"
+  "; remove *|"
+  "; remove &}3">;
 def ext_typecheck_convert_incompatible_function_pointer : ExtWarn<
   "incompatible function pointer types "
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
@@ -7466,6 +7558,23 @@ def ext_typecheck_convert_incompatible_function_pointer 
: ExtWarn<
   "; remove *|"
   "; remove &}3">,
   InGroup<IncompatibleFunctionPointerTypes>;
+def err_typecheck_convert_incompatible_function_pointer : Error<
+  "incompatible function pointer types "
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2"
+  "%select{|; dereference with *|"
+  "; take the address with &|"
+  "; remove *|"
+  "; remove &}3">;
 def ext_typecheck_convert_discards_qualifiers : ExtWarn<
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
   "|%
diff {passing $ to parameter of type $|"
@@ -7480,6 +7589,19 @@ def ext_typecheck_convert_discards_qualifiers : ExtWarn<
   "|%
diff {casting $ to type $|casting between types}0,1}2"
   " discards qualifiers">,
   InGroup<IncompatiblePointerTypesDiscardsQualifiers>;
+def err_typecheck_convert_discards_qualifiers : Error<
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2"
+  " discards qualifiers">;
 def ext_nested_pointer_qualifier_mismatch : ExtWarn<
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
   "|%
diff {passing $ to parameter of type $|"
@@ -7494,6 +7616,19 @@ def ext_nested_pointer_qualifier_mismatch : ExtWarn<
   "|%
diff {casting $ to type $|casting between types}0,1}2"
   " discards qualifiers in nested pointer types">,
   InGroup<IncompatiblePointerTypesDiscardsQualifiers>;
+def err_nested_pointer_qualifier_mismatch : Error<
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2"
+  " discards qualifiers in nested pointer types">;
 def warn_incompatible_vectors : Warning<
   "incompatible vector types "
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
@@ -7508,6 +7643,19 @@ def warn_incompatible_vectors : Warning<
   "sending to parameter of 
diff erent type}0,1"
   "|%
diff {casting $ to type $|casting between types}0,1}2">,
   InGroup<VectorConversion>, DefaultIgnore;
+def err_incompatible_vectors : Error<
+  "incompatible vector types "
+  "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"
+  "|%
diff {passing $ to parameter of type $|"
+  "passing to parameter of 
diff erent type}0,1"
+  "|%
diff {returning $ from a function with result type $|"
+  "returning from function with 
diff erent return type}0,1"
+  "|%
diff {converting $ to type $|converting between types}0,1"
+  "|%
diff {initializing $ with an expression of type $|"
+  "initializing with expression of 
diff erent type}0,1"
+  "|%
diff {sending $ to parameter of type $|"
+  "sending to parameter of 
diff erent type}0,1"
+  "|%
diff {casting $ to type $|casting between types}0,1}2">;
 def err_int_to_block_pointer : Error<
   "invalid block pointer conversion "
   "%select{%
diff {assigning to $ from $|assigning to 
diff erent types}0,1"

diff  --git a/clang/include/clang/Sema/Sema.h b/clang/include/clang/Sema/Sema.h
index a6430353b241..f100b5760047 100644
--- a/clang/include/clang/Sema/Sema.h
+++ b/clang/include/clang/Sema/Sema.h
@@ -10681,6 +10681,11 @@ class Sema final {
     /// are not compatible, but we accept them as an extension.
     IncompatiblePointer,
 
+    /// IncompatibleFunctionPointer - The assignment is between two function
+    /// pointers types that are not compatible, but we accept them as an
+    /// extension.
+    IncompatibleFunctionPointer,
+
     /// IncompatiblePointerSign - The assignment is between two pointers types
     /// which point to integers which have a 
diff erent sign, but are otherwise
     /// identical. This is a subset of the above, but broken out because it's 
by

diff  --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp
index 9485906cf243..d07c32487c13 100644
--- a/clang/lib/Sema/SemaExpr.cpp
+++ b/clang/lib/Sema/SemaExpr.cpp
@@ -8144,11 +8144,13 @@ checkPointerTypesForAssignment(Sema &S, QualType 
LHSType, QualType RHSType) {
     }
 
     // General pointer incompatibility takes priority over qualifiers.
+    if (RHSType->isFunctionPointerType() && LHSType->isFunctionPointerType())
+      return Sema::IncompatibleFunctionPointer;
     return Sema::IncompatiblePointer;
   }
   if (!S.getLangOpts().CPlusPlus &&
       S.IsFunctionConversion(ltrans, rtrans, ltrans))
-    return Sema::IncompatiblePointer;
+    return Sema::IncompatibleFunctionPointer;
   return ConvTy;
 }
 
@@ -14780,24 +14782,44 @@ bool Sema::DiagnoseAssignmentResult(AssignConvertType 
ConvTy,
       return false;
 
   case PointerToInt:
-    DiagKind = diag::ext_typecheck_convert_pointer_int;
+    if (getLangOpts().CPlusPlus) {
+      DiagKind = diag::err_typecheck_convert_pointer_int;
+      isInvalid = true;
+    } else {
+      DiagKind = diag::ext_typecheck_convert_pointer_int;
+    }
     ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this);
     MayHaveConvFixit = true;
     break;
   case IntToPointer:
-    DiagKind = diag::ext_typecheck_convert_int_pointer;
+    if (getLangOpts().CPlusPlus) {
+      DiagKind = diag::err_typecheck_convert_int_pointer;
+      isInvalid = true;
+    } else {
+      DiagKind = diag::ext_typecheck_convert_int_pointer;
+    }
+    ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this);
+    MayHaveConvFixit = true;
+    break;
+  case IncompatibleFunctionPointer:
+    if (getLangOpts().CPlusPlus) {
+      DiagKind = diag::err_typecheck_convert_incompatible_function_pointer;
+      isInvalid = true;
+    } else {
+      DiagKind = diag::ext_typecheck_convert_incompatible_function_pointer;
+    }
     ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this);
     MayHaveConvFixit = true;
     break;
   case IncompatiblePointer:
-    if (Action == AA_Passing_CFAudited)
+    if (Action == AA_Passing_CFAudited) {
       DiagKind = diag::err_arc_typecheck_convert_incompatible_pointer;
-    else if (SrcType->isFunctionPointerType() &&
-             DstType->isFunctionPointerType())
-      DiagKind = diag::ext_typecheck_convert_incompatible_function_pointer;
-    else
+    } else if (getLangOpts().CPlusPlus) {
+      DiagKind = diag::err_typecheck_convert_incompatible_pointer;
+      isInvalid = true;
+    } else {
       DiagKind = diag::ext_typecheck_convert_incompatible_pointer;
-
+    }
     CheckInferredResultType = DstType->isObjCObjectPointerType() &&
       SrcType->isObjCObjectPointerType();
     if (Hint.isNull() && !CheckInferredResultType) {
@@ -14810,15 +14832,27 @@ bool Sema::DiagnoseAssignmentResult(AssignConvertType 
ConvTy,
     MayHaveConvFixit = true;
     break;
   case IncompatiblePointerSign:
-    DiagKind = diag::ext_typecheck_convert_incompatible_pointer_sign;
+    if (getLangOpts().CPlusPlus) {
+      DiagKind = diag::err_typecheck_convert_incompatible_pointer_sign;
+      isInvalid = true;
+    } else {
+      DiagKind = diag::ext_typecheck_convert_incompatible_pointer_sign;
+    }
     break;
   case FunctionVoidPointer:
-    DiagKind = diag::ext_typecheck_convert_pointer_void_func;
+    if (getLangOpts().CPlusPlus) {
+      DiagKind = diag::err_typecheck_convert_pointer_void_func;
+      isInvalid = true;
+    } else {
+      DiagKind = diag::ext_typecheck_convert_pointer_void_func;
+    }
     break;
   case IncompatiblePointerDiscardsQualifiers: {
     // Perform array-to-pointer decay if necessary.
     if (SrcType->isArrayType()) SrcType = Context.getArrayDecayedType(SrcType);
 
+    isInvalid = true;
+
     Qualifiers lhq = SrcType->getPointeeType().getQualifiers();
     Qualifiers rhq = DstType->getPointeeType().getQualifiers();
     if (lhq.getAddressSpace() != rhq.getAddressSpace()) {
@@ -14846,19 +14880,33 @@ bool Sema::DiagnoseAssignmentResult(AssignConvertType 
ConvTy,
     if (getLangOpts().CPlusPlus &&
         IsStringLiteralToNonConstPointerConversion(SrcExpr, DstType))
       return false;
-    DiagKind = diag::ext_typecheck_convert_discards_qualifiers;
+    if (getLangOpts().CPlusPlus) {
+      DiagKind =  diag::err_typecheck_convert_discards_qualifiers;
+      isInvalid = true;
+    } else {
+      DiagKind =  diag::ext_typecheck_convert_discards_qualifiers;
+    }
+
     break;
   case IncompatibleNestedPointerQualifiers:
-    DiagKind = diag::ext_nested_pointer_qualifier_mismatch;
+    if (getLangOpts().CPlusPlus) {
+      isInvalid = true;
+      DiagKind = diag::err_nested_pointer_qualifier_mismatch;
+    } else {
+      DiagKind = diag::ext_nested_pointer_qualifier_mismatch;
+    }
     break;
   case IncompatibleNestedPointerAddressSpaceMismatch:
     DiagKind = diag::err_typecheck_incompatible_nested_address_space;
+    isInvalid = true;
     break;
   case IntToBlockPointer:
     DiagKind = diag::err_int_to_block_pointer;
+    isInvalid = true;
     break;
   case IncompatibleBlockPointer:
     DiagKind = diag::err_typecheck_convert_incompatible_block_pointer;
+    isInvalid = true;
     break;
   case IncompatibleObjCQualifiedId: {
     if (SrcType->isObjCQualifiedIdType()) {
@@ -14883,14 +14931,25 @@ bool Sema::DiagnoseAssignmentResult(AssignConvertType 
ConvTy,
             SrcType->castAs<ObjCObjectPointerType>()->getInterfaceType())
         IFace = IFaceT->getDecl();
     }
-    DiagKind = diag::warn_incompatible_qualified_id;
+    if (getLangOpts().CPlusPlus) {
+      DiagKind = diag::err_incompatible_qualified_id;
+      isInvalid = true;
+    } else {
+      DiagKind = diag::warn_incompatible_qualified_id;
+    }
     break;
   }
   case IncompatibleVectors:
-    DiagKind = diag::warn_incompatible_vectors;
+    if (getLangOpts().CPlusPlus) {
+      DiagKind = diag::err_incompatible_vectors;
+      isInvalid = true;
+    } else {
+      DiagKind = diag::warn_incompatible_vectors;
+    }
     break;
   case IncompatibleObjCWeakRef:
     DiagKind = diag::err_arc_weak_unavailable_assign;
+    isInvalid = true;
     break;
   case Incompatible:
     if (maybeDiagnoseAssignmentToFunction(*this, DstType, SrcExpr)) {
@@ -14948,9 +15007,10 @@ bool Sema::DiagnoseAssignmentResult(AssignConvertType 
ConvTy,
     HandleFunctionTypeMismatch(FDiag, SecondType, FirstType);
 
   Diag(Loc, FDiag);
-  if (DiagKind == diag::warn_incompatible_qualified_id &&
+  if ((DiagKind == diag::warn_incompatible_qualified_id ||
+       DiagKind == diag::err_incompatible_qualified_id) &&
       PDecl && IFace && !IFace->hasDefinition())
-      Diag(IFace->getLocation(), diag::note_incomplete_class_and_qualified_id)
+    Diag(IFace->getLocation(), diag::note_incomplete_class_and_qualified_id)
         << IFace << PDecl;
 
   if (SecondType == Context.OverloadTy)

diff  --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp
index 83333857234c..800454555425 100644
--- a/clang/lib/Sema/SemaExprCXX.cpp
+++ b/clang/lib/Sema/SemaExprCXX.cpp
@@ -3917,9 +3917,11 @@ Sema::PerformImplicitConversion(Expr *From, QualType 
ToType,
     llvm_unreachable("Cannot perform an ellipsis conversion");
 
   case ImplicitConversionSequence::BadConversion:
-    bool Diagnosed =
-        DiagnoseAssignmentResult(Incompatible, From->getExprLoc(), ToType,
-                                 From->getType(), From, Action);
+    Sema::AssignConvertType ConvTy =
+        CheckAssignmentConstraints(From->getExprLoc(), ToType, 
From->getType());
+    bool Diagnosed = DiagnoseAssignmentResult(
+        ConvTy == Compatible ? Incompatible : ConvTy, From->getExprLoc(),
+        ToType, From->getType(), From, Action);
     assert(Diagnosed && "failed to diagnose bad conversion"); (void)Diagnosed;
     return ExprError();
   }

diff  --git a/clang/test/CXX/conv/conv.fctptr/p1.cpp 
b/clang/test/CXX/conv/conv.fctptr/p1.cpp
index be9c050af51e..d18bd349b688 100644
--- a/clang/test/CXX/conv/conv.fctptr/p1.cpp
+++ b/clang/test/CXX/conv/conv.fctptr/p1.cpp
@@ -11,7 +11,7 @@ Nothrow S::*c;
 Throw S::*d;
 
 void test() {
-  a = b; // expected-error {{assigning to 'Nothrow *' (aka 'void (*)() 
noexcept') from incompatible type 'Throw *' (aka 'void (*)()'): 
diff erent exception specifications}}
+  a = b; // expected-error {{incompatible function pointer types assigning to 
'Nothrow *' (aka 'void (*)() noexcept') from 'Throw *' (aka 'void (*)()')}}
   b = a;
   c = d; // expected-error {{assigning to 'Nothrow S::*' from incompatible 
type 'Throw S::*': 
diff erent exception specifications}}
   d = c;

diff  --git a/clang/test/CXX/drs/dr3xx.cpp b/clang/test/CXX/drs/dr3xx.cpp
index 4ce624974bbe..a5edc32fa48c 100644
--- a/clang/test/CXX/drs/dr3xx.cpp
+++ b/clang/test/CXX/drs/dr3xx.cpp
@@ -372,7 +372,7 @@ namespace dr330 { // dr330: 7
     s = q; // expected-error {{incompatible}}
     s = q2; // expected-error {{incompatible}}
     s = t; // ok, adding const
-    t = s; // expected-error {{incompatible}}
+    t = s; // expected-error {{discards qualifiers}}
     (void) const_cast<P>(q);
     (void) const_cast<P>(q2);
     (void) const_cast<Q>(p);

diff  --git a/clang/test/CXX/except/except.handle/p16.cpp 
b/clang/test/CXX/except/except.handle/p16.cpp
index 0810be108e41..86ced1ae4287 100644
--- a/clang/test/CXX/except/except.handle/p16.cpp
+++ b/clang/test/CXX/except/except.handle/p16.cpp
@@ -11,12 +11,12 @@ class X {
 public:
   X(const X<T> &) {
     int *ip = 0;
-    ptr = ip; // expected-error{{assigning to 'float *' from incompatible type 
'int *'}}
+    ptr = ip; // expected-error{{incompatible pointer types assigning to 
'float *' from 'int *'}}
   }
 
   ~X() {
     float *fp = 0;
-    ptr = fp; // expected-error{{assigning to 'int *' from incompatible type 
'float *'}}
+    ptr = fp; // expected-error{{incompatible pointer types assigning to 'int 
*' from 'float *'}}
   }
 };
 

diff  --git a/clang/test/CXX/expr/p13.cpp b/clang/test/CXX/expr/p13.cpp
index 0f22ce0b7ceb..44e7140ceb12 100644
--- a/clang/test/CXX/expr/p13.cpp
+++ b/clang/test/CXX/expr/p13.cpp
@@ -11,7 +11,7 @@ using E = void (Y::*)() noexcept;
 using F = void (Y::*)();
 
 void f(A a, B b, C c, D d, E e, F f, bool k) {
-  a = k ? a : b; // expected-error {{
diff erent exception specifications}}
+  a = k ? a : b; // expected-error {{incompatible function pointer types 
assigning to 'A' (aka 'void (*)() noexcept') from 'void (*)()'}}
   b = k ? a : b;
 
   c = k ? c : d; // expected-error {{
diff erent exception specifications}}

diff  --git a/clang/test/CXX/temp/temp.spec/temp.expl.spec/p19.cpp 
b/clang/test/CXX/temp/temp.spec/temp.expl.spec/p19.cpp
index 1c2ea7ebde71..16666d185b06 100644
--- a/clang/test/CXX/temp/temp.spec/temp.expl.spec/p19.cpp
+++ b/clang/test/CXX/temp/temp.spec/temp.expl.spec/p19.cpp
@@ -14,7 +14,7 @@ struct X<int>::Inner {
 
 template<> template<typename U>
 void X<int>::f(int x, U y) { 
-  x = y; // expected-error{{incompatible type}}
+  x = y; // expected-error{{incompatible pointer to integer conversion}}
 }
 
 void test(X<int> xi, X<long> xl, float *fp) {

diff  --git a/clang/test/CXX/temp/temp.spec/temp.explicit/p10.cpp 
b/clang/test/CXX/temp/temp.spec/temp.explicit/p10.cpp
index 290a874296e1..b21db7f51f1a 100644
--- a/clang/test/CXX/temp/temp.spec/temp.explicit/p10.cpp
+++ b/clang/test/CXX/temp/temp.spec/temp.explicit/p10.cpp
@@ -11,7 +11,7 @@ struct X0 {
 
 template<typename T>
 void X0<T>::f(T& t) { 
-  t = 1; // expected-error{{incompatible type}}
+  t = 1; // expected-error{{incompatible integer to pointer conversion}}
 }
 
 template<typename T>

diff  --git a/clang/test/CXX/temp/temp.spec/temp.explicit/p9.cpp 
b/clang/test/CXX/temp/temp.spec/temp.explicit/p9.cpp
index 86490175f0c3..3e9b4f8fccf4 100644
--- a/clang/test/CXX/temp/temp.spec/temp.explicit/p9.cpp
+++ b/clang/test/CXX/temp/temp.spec/temp.explicit/p9.cpp
@@ -3,7 +3,7 @@
 template<typename T>
 struct X0 {
   void f(T &t) {
-    t = 1; // expected-error{{incompatible type}}
+    t = 1; // expected-error{{incompatible integer to pointer conversion}}
   }
   
   void g(T &t);
@@ -15,7 +15,7 @@ struct X0 {
 
 template<typename T>
 inline void X0<T>::g(T & t) {
-  t = 1; // expected-error{{incompatible type}}
+  t = 1; // expected-error{{incompatible integer to pointer conversion}}
 }
 
 template<typename T>
@@ -37,12 +37,12 @@ int *&test(X0<int*> xi, int *ip) {
 
 template<typename T>
 void f0(T& t) {
-  t = 1; // expected-error{{incompatible type}}
+  t = 1; // expected-error{{incompatible integer to pointer conversion}}
 }
 
 template<typename T>
 inline void f1(T& t) {
-  t = 1; // expected-error 2{{incompatible type}}
+  t = 1; // expected-error 2{{incompatible integer to pointer conversion}}
 }
 
 extern template void f0<>(int *&);

diff  --git a/clang/test/OpenMP/allocate_allocator_messages.cpp 
b/clang/test/OpenMP/allocate_allocator_messages.cpp
index fced4cae9d52..0c4d36fc5f56 100644
--- a/clang/test/OpenMP/allocate_allocator_messages.cpp
+++ b/clang/test/OpenMP/allocate_allocator_messages.cpp
@@ -28,7 +28,7 @@ extern const omp_allocator_handle_t omp_thread_mem_alloc;
 struct St1{
  int a;
  static int b;
-#pragma omp allocate(b) allocator(sss) // expected-error {{initializing 'const 
omp_allocator_handle_t' (aka 'void **const') with an expression of incompatible 
type 'int'}} expected-note {{previous allocator is specified here}}
+#pragma omp allocate(b) allocator(sss) // expected-error {{incompatible 
integer to pointer conversion initializing 'const omp_allocator_handle_t' (aka 
'void **const') with an expression of type 'int'}} expected-note {{previous 
allocator is specified here}}
 #pragma omp allocate(b)
 #pragma omp allocate(b) allocator(omp_thread_mem_alloc) // expected-warning 
{{allocate directive specifies 'omp_thread_mem_alloc' allocator while 
previously used default}}
 } d; // expected-note 2 {{'d' defined here}}

diff  --git a/clang/test/Sema/block-call.c b/clang/test/Sema/block-call.c
index 2aa1422dd915..8dd5bd8f21b3 100644
--- a/clang/test/Sema/block-call.c
+++ b/clang/test/Sema/block-call.c
@@ -33,7 +33,7 @@ int main() {
   int (^IPCC6) (int, char (^CArg) (float))  = IPCC4; // expected-error 
{{incompatible block pointer types initializing 'int (^)(int, char (^)(float))' 
with an expression of type 'int (^)(int, char (^)(double))'}}
 
   IPCC2 = 0;
-  IPCC2 = 1; // expected-error {{invalid block pointer conversion assigning to 
'int *(^)()' from 'int'}}
+  IPCC1 = 1; // expected-error {{invalid block pointer conversion assigning to 
'int *const (^)()' from 'int'}}
   int (^x)() = 0;
   int (^y)() = 3;   // expected-error {{invalid block pointer conversion 
initializing 'int (^)()' with an expression of type 'int'}}
   int a = 1;

diff  --git a/clang/test/Sema/block-return.c b/clang/test/Sema/block-return.c
index e4af8f57c2a1..a51446aaa1e1 100644
--- a/clang/test/Sema/block-return.c
+++ b/clang/test/Sema/block-return.c
@@ -79,7 +79,7 @@ static int funk(char *s) {
 void next();
 void foo4() {
   int (^xx)(const char *s) = ^(char *s) { return 1; }; // expected-error 
{{incompatible block pointer types initializing 'int (^)(const char *)' with an 
expression of type 'int (^)(char *)'}}
-  int (*yy)(const char *s) = funk; // expected-warning {{incompatible pointer 
types initializing 'int (*)(const char *)' with an expression of type 'int 
(char *)'}}
+  int (*yy)(const char *s) = funk; // expected-warning {{incompatible function 
pointer types initializing 'int (*)(const char *)' with an expression of type 
'int (char *)'}}
   
   int (^nested)(char *s) = ^(char *str) { void (^nest)(void) = ^(void) { 
printf("%s\n", str); }; next(); return 1; }; // expected-warning{{implicitly 
declaring library function 'printf' with type 'int (const char *, ...)'}} \
   // expected-note{{include the header <stdio.h> or explicitly provide a 
declaration for 'printf'}}

diff  --git a/clang/test/Sema/callingconv-ms_abi.c 
b/clang/test/Sema/callingconv-ms_abi.c
index 64c5970adf1d..311df725d81f 100644
--- a/clang/test/Sema/callingconv-ms_abi.c
+++ b/clang/test/Sema/callingconv-ms_abi.c
@@ -4,6 +4,6 @@ void __attribute__((ms_abi)) foo(void);
 void (*pfoo)(void) = foo;
 
 void __attribute__((sysv_abi)) bar(void);
-void (*pbar)(void) = bar; // expected-warning{{incompatible pointer types}}
+void (*pbar)(void) = bar; // expected-warning{{incompatible function pointer 
types}}
 
-void (__attribute__((sysv_abi)) *pfoo2)(void) = foo; // 
expected-warning{{incompatible pointer types}}
+void (__attribute__((sysv_abi)) *pfoo2)(void) = foo; // 
expected-warning{{incompatible function pointer types}}

diff  --git a/clang/test/Sema/callingconv-sysv_abi.c 
b/clang/test/Sema/callingconv-sysv_abi.c
index 015357d054f7..2dcc30c92f4f 100644
--- a/clang/test/Sema/callingconv-sysv_abi.c
+++ b/clang/test/Sema/callingconv-sysv_abi.c
@@ -1,9 +1,9 @@
 // RUN: %clang_cc1 -fsyntax-only -verify -triple x86_64-pc-linux-gnu %s
 
 void __attribute__((ms_abi)) foo(void);
-void (*pfoo)(void) = foo; // expected-warning{{incompatible pointer types}}
+void (*pfoo)(void) = foo; // expected-warning{{incompatible function pointer 
types}}
 
 void __attribute__((sysv_abi)) bar(void);
 void (*pbar)(void) = bar;
 
-void (__attribute__((ms_abi)) *pbar2)(void) = bar; // 
expected-warning{{incompatible pointer types}}
+void (__attribute__((ms_abi)) *pbar2)(void) = bar; // 
expected-warning{{incompatible function pointer types}}

diff  --git a/clang/test/Sema/callingconv.c b/clang/test/Sema/callingconv.c
index 6273d04f2121..c2e3a61b1ee4 100644
--- a/clang/test/Sema/callingconv.c
+++ b/clang/test/Sema/callingconv.c
@@ -31,7 +31,7 @@ void (__attribute__((fastcall)) *pfoo)(float*) = foo;
 
 void (__attribute__((stdcall)) *pbar)(float*) = bar;
 
-void (__attribute__((cdecl)) *ptest1)(void) = test1; // expected-warning 
{{incompatible pointer types}}
+void (__attribute__((cdecl)) *ptest1)(void) = test1; // expected-warning 
{{incompatible function pointer types}}
 
 void (*pctest0)() = ctest0;
 

diff  --git a/clang/test/Sema/overloadable.c b/clang/test/Sema/overloadable.c
index 61ef3fddaf32..360f3308302e 100644
--- a/clang/test/Sema/overloadable.c
+++ b/clang/test/Sema/overloadable.c
@@ -26,7 +26,7 @@ float *accept_funcptr(int (*)(int, double)) 
__attribute__((overloadable)); //  \
 void test_funcptr(int (*f1)(int, double),
                   int (*f2)(int, float)) {
   float *fp = accept_funcptr(f1);
-  accept_funcptr(f2); // expected-error{{call to 'accept_funcptr' is 
ambiguous}}
+  accept_funcptr(f2); // expected-error{{no matching function for call to 
'accept_funcptr'}}
 }
 
 struct X { int x; float y; };
@@ -119,8 +119,8 @@ void fn_type_conversions() {
   void disabled(char *c) __attribute__((overloadable, enable_if(1, "The 
function name lies.")));
   // To be clear, these should all point to the last overload of 'disabled'
   void (*dptr1)(char *c) = &disabled;
-  void (*dptr2)(void *c) = &disabled; // expected-warning{{incompatible 
pointer types initializing 'void (*)(void *)' with an expression of type 
'<overloaded function type>'}} expected-note@-5{{candidate function made 
ineligible by enable_if}} expected-note@-4{{candidate function made ineligible 
by enable_if}} expected-note@-3{{candidate function has type mismatch at 1st 
parameter (expected 'void *' but has 'char *')}}
-  void (*dptr3)(int *c) = &disabled; // expected-warning{{incompatible pointer 
types initializing 'void (*)(int *)' with an expression of type '<overloaded 
function type>'}} expected-note@-6{{candidate function made ineligible by 
enable_if}} expected-note@-5{{candidate function made ineligible by enable_if}} 
expected-note@-4{{candidate function has type mismatch at 1st parameter 
(expected 'int *' but has 'char *')}}
+  void (*dptr2)(void *c) = &disabled; // expected-warning{{incompatible 
function pointer types initializing 'void (*)(void *)' with an expression of 
type '<overloaded function type>'}} expected-note@-5{{candidate function made 
ineligible by enable_if}} expected-note@-4{{candidate function made ineligible 
by enable_if}} expected-note@-3{{candidate function has type mismatch at 1st 
parameter (expected 'void *' but has 'char *')}}
+  void (*dptr3)(int *c) = &disabled; // expected-warning{{incompatible 
function pointer types initializing 'void (*)(int *)' with an expression of 
type '<overloaded function type>'}} expected-note@-6{{candidate function made 
ineligible by enable_if}} expected-note@-5{{candidate function made ineligible 
by enable_if}} expected-note@-4{{candidate function has type mismatch at 1st 
parameter (expected 'int *' but has 'char *')}}
 
   void *specific_disabled = &disabled;
 }

diff  --git a/clang/test/Sema/pass-object-size.c 
b/clang/test/Sema/pass-object-size.c
index 445d20ba6f61..8c357b2637c6 100644
--- a/clang/test/Sema/pass-object-size.c
+++ b/clang/test/Sema/pass-object-size.c
@@ -44,8 +44,8 @@ void FunctionPtrs() {
   void (*p)(void *) = NotOverloaded; //expected-error{{cannot take address of 
function 'NotOverloaded' because parameter 1 has pass_object_size attribute}}
   void (*p2)(void *) = &NotOverloaded; //expected-error{{cannot take address 
of function 'NotOverloaded' because parameter 1 has pass_object_size attribute}}
 
-  void (*p3)(void *) = IsOverloaded; //expected-warning{{incompatible pointer 
types initializing 'void (*)(void *)' with an expression of type '<overloaded 
function type>'}}
-  void (*p4)(void *) = &IsOverloaded; //expected-warning{{incompatible pointer 
types initializing 'void (*)(void *)' with an expression of type '<overloaded 
function type>'}}
+  void (*p3)(void *) = IsOverloaded; //expected-warning{{incompatible function 
pointer types initializing 'void (*)(void *)' with an expression of type 
'<overloaded function type>'}}
+  void (*p4)(void *) = &IsOverloaded; //expected-warning{{incompatible 
function pointer types initializing 'void (*)(void *)' with an expression of 
type '<overloaded function type>'}}
 
   void (*p5)(char *) = IsOverloaded;
   void (*p6)(char *) = &IsOverloaded;

diff  --git a/clang/test/Sema/preserve-call-conv.c 
b/clang/test/Sema/preserve-call-conv.c
index 6add3095c667..6cd8e08cc6dc 100644
--- a/clang/test/Sema/preserve-call-conv.c
+++ b/clang/test/Sema/preserve-call-conv.c
@@ -14,8 +14,8 @@ void __attribute__((preserve_most(1))) foo1(void *ptr) { // 
expected-error {{'pr
 
 void (__attribute__((preserve_most)) *pfoo1)(void *) = foo;
 
-void (__attribute__((cdecl)) *pfoo2)(void *) = foo; // expected-warning 
{{incompatible pointer types initializing 'void (*)(void *) 
__attribute__((cdecl))' with an expression of type 'void (void *) 
__attribute__((preserve_most))'}}
-void (*pfoo3)(void *) = foo; // expected-warning {{incompatible pointer types 
initializing 'void (*)(void *)' with an expression of type 'void (void *) 
__attribute__((preserve_most))'}}
+void (__attribute__((cdecl)) *pfoo2)(void *) = foo; // expected-warning 
{{incompatible function pointer types initializing 'void (*)(void *) 
__attribute__((cdecl))' with an expression of type 'void (void *) 
__attribute__((preserve_most))'}}
+void (*pfoo3)(void *) = foo; // expected-warning {{incompatible function 
pointer types initializing 'void (*)(void *)' with an expression of type 'void 
(void *) __attribute__((preserve_most))'}}
 
 typedef_fun_t typedef_fun_foo; // expected-note {{previous declaration is 
here}}
 void __attribute__((preserve_most)) typedef_fun_foo(int x) { } // 
expected-error {{function declared 'preserve_most' here was previously declared 
without calling convention}}
@@ -30,8 +30,8 @@ void __attribute__((preserve_all(1))) boo1(void *ptr) { // 
expected-error {{'pre
 
 void (__attribute__((preserve_all)) *pboo1)(void *) = boo;
 
-void (__attribute__((cdecl)) *pboo2)(void *) = boo; // expected-warning 
{{incompatible pointer types initializing 'void (*)(void *) 
__attribute__((cdecl))' with an expression of type 'void (void *) 
__attribute__((preserve_all))'}}
-void (*pboo3)(void *) = boo; // expected-warning {{incompatible pointer types 
initializing 'void (*)(void *)' with an expression of type 'void (void *) 
__attribute__((preserve_all))'}}
+void (__attribute__((cdecl)) *pboo2)(void *) = boo; // expected-warning 
{{incompatible function pointer types initializing 'void (*)(void *) 
__attribute__((cdecl))' with an expression of type 'void (void *) 
__attribute__((preserve_all))'}}
+void (*pboo3)(void *) = boo; // expected-warning {{incompatible function 
pointer types initializing 'void (*)(void *)' with an expression of type 'void 
(void *) __attribute__((preserve_all))'}}
 
 typedef_fun_t typedef_fun_boo; // expected-note {{previous declaration is 
here}}
 void __attribute__((preserve_all)) typedef_fun_boo(int x) { } // 
expected-error {{function declared 'preserve_all' here was previously declared 
without calling convention}}

diff  --git a/clang/test/SemaCXX/addr-of-overloaded-function.cpp 
b/clang/test/SemaCXX/addr-of-overloaded-function.cpp
index 6b6734bae17d..dd1c3462c8c1 100644
--- a/clang/test/SemaCXX/addr-of-overloaded-function.cpp
+++ b/clang/test/SemaCXX/addr-of-overloaded-function.cpp
@@ -182,19 +182,19 @@ namespace test1 {
   void parameter_number() {
     void (*ptr1)(int, int) = &fun; // expected-error {{cannot initialize a 
variable of type 'void (*)(int, int)' with an rvalue of type 'void (*)(int)': 
diff erent number of parameters (2 vs 1)}}
     void (*ptr2)(int, int);
-    ptr2 = &fun;  // expected-error {{assigning to 'void (*)(int, int)' from 
incompatible type 'void (*)(int)': 
diff erent number of parameters (2 vs 1)}}
+    ptr2 = &fun;  // expected-error {{incompatible function pointer types 
assigning to 'void (*)(int, int)' from 'void (*)(int)'}}
   }
 
   void parameter_mismatch() {
     void (*ptr1)(double) = &fun; // expected-error {{cannot initialize a 
variable of type 'void (*)(double)' with an rvalue of type 'void (*)(int)': 
type mismatch at 1st parameter ('double' vs 'int')}}
     void (*ptr2)(double);
-    ptr2 = &fun; // expected-error {{assigning to 'void (*)(double)' from 
incompatible type 'void (*)(int)': type mismatch at 1st parameter ('double' vs 
'int')}}
+    ptr2 = &fun; // expected-error {{incompatible function pointer types 
assigning to 'void (*)(double)' from 'void (*)(int)'}}
   }
 
   void return_type_test() {
     int (*ptr1)(int) = &fun; // expected-error {{cannot initialize a variable 
of type 'int (*)(int)' with an rvalue of type 'void (*)(int)': 
diff erent return type ('int' vs 'void')}}
     int (*ptr2)(int);
-    ptr2 = &fun;  // expected-error {{assigning to 'int (*)(int)' from 
incompatible type 'void (*)(int)': 
diff erent return type ('int' vs 'void')}}
+    ptr2 = &fun;  // expected-error {{incompatible function pointer types 
assigning to 'int (*)(int)' from 'void (*)(int)'}}
   }
 
   int foo(double x, double y) {return 0;} // expected-note {{candidate 
function has 
diff erent number of parameters (expected 1 but has 2)}}

diff  --git a/clang/test/SemaCXX/decl-microsoft-call-conv.cpp 
b/clang/test/SemaCXX/decl-microsoft-call-conv.cpp
index a2a04ac9c8b9..b399d8e35bd4 100644
--- a/clang/test/SemaCXX/decl-microsoft-call-conv.cpp
+++ b/clang/test/SemaCXX/decl-microsoft-call-conv.cpp
@@ -239,7 +239,7 @@ namespace test8 {
   template <typename T>
   struct S {
     void f(T t) { // expected-note {{previous declaration is here}}
-      t = 42; // expected-error {{assigning to 'void *' from incompatible type 
'int'}}
+      t = 42; // expected-error {{incompatible integer to pointer conversion 
assigning to 'void *' from 'int'}}
     }
   };
   template<> void __cdecl S<void*>::f(void*); // expected-error {{function 
declared 'cdecl' here was previously declared without calling convention}}

diff  --git a/clang/test/SemaCXX/goto.cpp b/clang/test/SemaCXX/goto.cpp
index 2d37ea9099a2..beaf88cf60f1 100644
--- a/clang/test/SemaCXX/goto.cpp
+++ b/clang/test/SemaCXX/goto.cpp
@@ -40,7 +40,7 @@ namespace N {
 }
 
 void g() {
-  end = 1; // expected-error{{assigning to 'double *' from incompatible type 
'int'}}
+  end = 1; // expected-error{{incompatible integer to pointer conversion 
assigning to 'double *' from 'int'}}
 }
 
 void h(int end) {

diff  --git a/clang/test/SemaCXX/int-ptr-cast-SFINAE.cpp 
b/clang/test/SemaCXX/int-ptr-cast-SFINAE.cpp
index 5782a6dbaeae..68eae7f69c78 100644
--- a/clang/test/SemaCXX/int-ptr-cast-SFINAE.cpp
+++ b/clang/test/SemaCXX/int-ptr-cast-SFINAE.cpp
@@ -2,7 +2,7 @@
 // RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++17
 
 void foo(int* a, int *b) {
-  a -= b; // expected-warning {{incompatible integer to pointer conversion 
assigning to 'int *' from}}
+  a -= b; // expected-error {{incompatible integer to pointer conversion 
assigning to 'int *' from}}
 }
 
 template<typename T> T declval();

diff  --git a/clang/test/SemaCXX/ms-property-error.cpp 
b/clang/test/SemaCXX/ms-property-error.cpp
index ca52538f3a67..4173f840960c 100644
--- a/clang/test/SemaCXX/ms-property-error.cpp
+++ b/clang/test/SemaCXX/ms-property-error.cpp
@@ -19,7 +19,7 @@ class St {
     x[2][3] = 4;
     ++x[2][3];
     x[1][2] = x[3][4][5]; // expected-error {{too many arguments to function 
call, expected 2, have 3}}
-    ptr = x[1][2] = x[3][4]; // expected-error {{assigning to 'char *' from 
incompatible type 'int'}}
+    ptr = x[1][2] = x[3][4]; // expected-error {{incompatible integer to 
pointer conversion assigning to 'char *' from 'int'}}
   }
 };
 

diff  --git a/clang/test/SemaObjC/arc.m b/clang/test/SemaObjC/arc.m
index 639483913fa5..e46d66b0dcf3 100644
--- a/clang/test/SemaObjC/arc.m
+++ b/clang/test/SemaObjC/arc.m
@@ -114,7 +114,8 @@ void test5() {
 
   __autoreleasing id *a = &x; // expected-error {{initializing 
'__autoreleasing id *' with an expression of type '__strong id *' changes 
retain/release properties of pointer}}
 
-  a = &x; // expected-error {{assigning '__strong id *' to '__autoreleasing id 
*' changes retain/release properties of pointer}}
+  __autoreleasing id *aa;
+  aa = &x; // expected-error {{assigning '__strong id *' to '__autoreleasing 
id *' changes retain/release properties of pointer}}
 
   extern void test5_helper2(id const *);
   test5_helper2(&x);

diff  --git a/clang/test/SemaObjC/comptypes-legal.m 
b/clang/test/SemaObjC/comptypes-legal.m
index 7ac4e143338a..57b040c61321 100644
--- a/clang/test/SemaObjC/comptypes-legal.m
+++ b/clang/test/SemaObjC/comptypes-legal.m
@@ -33,7 +33,7 @@ void foo(void)
 {
   // GCC currently allows this (it has some fiarly new support for covariant 
return types and contravariant argument types).
   // Since registerFunc: expects a Derived object as it's second argument, I 
don't know why this would be legal.
-  [Derived registerFunc: ExternFunc];  // expected-warning{{incompatible 
pointer types sending 'NSObject *(NSObject *, NSObject *)' to parameter of type 
'FuncSignature *'}}
+  [Derived registerFunc: ExternFunc];  // expected-warning{{incompatible 
function pointer types sending 'NSObject *(NSObject *, NSObject *)' to 
parameter of type 'FuncSignature *' (aka 'id (*)(NSObject *, Derived *)')}}
 }
 
 // rdar://10751015

diff  --git a/clang/test/SemaObjCXX/arc-type-conversion.mm 
b/clang/test/SemaObjCXX/arc-type-conversion.mm
index 8544726e25ad..1e3790bfa472 100644
--- a/clang/test/SemaObjCXX/arc-type-conversion.mm
+++ b/clang/test/SemaObjCXX/arc-type-conversion.mm
@@ -124,12 +124,12 @@ void test_unsafe_unretained(__strong id *sip, __weak id 
*wip,
                             __autoreleasing id *aip,
                             __unsafe_unretained id *uip,
                             const __unsafe_unretained id *cuip) {
-  uip = sip; // expected-error{{assigning to '__unsafe_unretained id *' from 
incompatible type '__strong id *'}}
-  uip = wip; // expected-error{{assigning to '__unsafe_unretained id *' from 
incompatible type '__weak id *'}}
-  uip = aip; // expected-error{{assigning to '__unsafe_unretained id *' from 
incompatible type '__autoreleasing id *'}}
+  uip = sip; // expected-error{{assigning '__strong id *' to 
'__unsafe_unretained id *' changes retain/release properties of pointer}}
+  uip = wip; // expected-error{{assigning '__weak id *' to 
'__unsafe_unretained id *' changes retain/release properties of pointer}}
+  uip = aip; // expected-error{{assigning '__autoreleasing id *' to 
'__unsafe_unretained id *' changes retain/release properties of pointer}}
 
   cuip = sip;
-  cuip = wip; // expected-error{{assigning to '__unsafe_unretained id const *' 
from incompatible type '__weak id *'}}
+  cuip = wip; // expected-error{{assigning '__weak id *' to 
'__unsafe_unretained id const *' changes retain/release properties of pointer}}
   cuip = aip;
 }
 

diff  --git a/clang/test/SemaObjCXX/comptypes-1.mm 
b/clang/test/SemaObjCXX/comptypes-1.mm
index abb87775d152..595223aa793d 100644
--- a/clang/test/SemaObjCXX/comptypes-1.mm
+++ b/clang/test/SemaObjCXX/comptypes-1.mm
@@ -37,9 +37,9 @@ int main()
      warning, unless done from an 'id'.  */
   obj_c = obj;    /* Ok */
   obj_c = obj_p;  // expected-error {{assigning to 'MyClass *' from 
incompatible type 'id<MyProtocol>'}}
-  obj_c = obj_cp; // expected-error {{assigning to 'MyClass *' from 
incompatible type 'MyOtherClass *'}}
-  obj_c = obj_C;  // expected-error {{assigning to 'MyClass *' from 
incompatible type 'Class'}}
-  obj_c = obj_CP; // expected-error {{assigning to 'MyClass *' from 
incompatible type 'Class<MyProtocol>'}}
+  obj_c = obj_cp; // expected-error {{incompatible pointer types assigning to 
'MyClass *' from 'MyOtherClass *'}}
+  obj_c = obj_C;  // expected-error {{incompatible pointer types assigning to 
'MyClass *' from 'Class'}}
+  obj_c = obj_CP; // expected-error {{incompatible pointer types assigning to 
'MyClass *' from 'Class<MyProtocol>'}}
 
   /* Assigning to an 'id<MyProtocol>' variable should generate a
      warning if done from a 'MyClass *' (which doesn't implement
@@ -48,28 +48,28 @@ int main()
   obj_p = obj;    /* Ok */
   obj_p = obj_c;  // expected-error {{assigning to 'id<MyProtocol>' from 
incompatible type 'MyClass *'}}
   obj_p = obj_cp; /* Ok  */
-  obj_p = obj_C;  // expected-error {{assigning to 'id<MyProtocol>' from 
incompatible type 'Class'}}
+  obj_p = obj_C;  // expected-error {{incompatible pointer types assigning to 
'id<MyProtocol>' from 'Class'}}
   obj_p = obj_CP; // expected-error {{assigning to 'id<MyProtocol>' from 
incompatible type 'Class<MyProtocol>'}}
 
   /* Assigning to a 'MyOtherClass *' variable should always generate
      a warning, unless done from an 'id' or an 'id<MyProtocol>' (since
      MyOtherClass implements MyProtocol).  */
   obj_cp = obj;    /* Ok */
-  obj_cp = obj_c;  // expected-error {{assigning to 'MyOtherClass *' from 
incompatible type 'MyClass *'}}
+  obj_cp = obj_c;  // expected-error {{incompatible pointer types assigning to 
'MyOtherClass *' from 'MyClass *'}}
   obj_cp = obj_p;  /* Ok */
-  obj_cp = obj_C;  // expected-error {{assigning to 'MyOtherClass *' from 
incompatible type 'Class'}}
-  obj_cp = obj_CP; // expected-error {{assigning to 'MyOtherClass *' from 
incompatible type 'Class<MyProtocol>'}}
+  obj_cp = obj_C;  // expected-error {{incompatible pointer types assigning to 
'MyOtherClass *' from 'Class'}}
+  obj_cp = obj_CP; // expected-error {{incompatible pointer types assigning to 
'MyOtherClass *' from 'Class<MyProtocol>'}}
 
   obj_C = obj;     // Ok
-  obj_C = obj_p;   // expected-error {{assigning to 'Class' from incompatible 
type 'id<MyProtocol>'}}
-  obj_C = obj_c;   // expected-error {{assigning to 'Class' from incompatible 
type 'MyClass *'}}
-  obj_C = obj_cp;  // expected-error {{assigning to 'Class' from incompatible 
type 'MyOtherClass *'}}
+  obj_C = obj_p;   // expected-error {{incompatible pointer types assigning to 
'Class' from 'id<MyProtocol>'}}
+  obj_C = obj_c;   // expected-error {{incompatible pointer types assigning to 
'Class' from 'MyClass *'}}
+  obj_C = obj_cp;  // expected-error {{incompatible pointer types assigning to 
'Class' from 'MyOtherClass *'}}
   obj_C = obj_CP;  // Ok
 
   obj_CP = obj;     // Ok
   obj_CP = obj_p;   // expected-error {{assigning to 'Class<MyProtocol>' from 
incompatible type 'id<MyProtocol>'}}
-  obj_CP = obj_c;   // expected-error {{assigning to 'Class<MyProtocol>' from 
incompatible type 'MyClass *}}
-  obj_CP = obj_cp;  // expected-error {{assigning to 'Class<MyProtocol>' from 
incompatible type 'MyOtherClass *'}}
+  obj_CP = obj_c;   // expected-error {{incompatible pointer types assigning 
to 'Class<MyProtocol>' from 'MyClass *'}}
+  obj_CP = obj_cp;  // expected-error {{incompatible pointer types assigning 
to 'Class<MyProtocol>' from 'MyOtherClass *'}}
   obj_CP = obj_C;   // Ok
 
   /* Any comparison involving an 'id' must be without warnings.  */

diff  --git a/clang/test/SemaObjCXX/comptypes-7.mm 
b/clang/test/SemaObjCXX/comptypes-7.mm
index 010c2cacc484..cc3d085e1c61 100644
--- a/clang/test/SemaObjCXX/comptypes-7.mm
+++ b/clang/test/SemaObjCXX/comptypes-7.mm
@@ -23,27 +23,27 @@ int main()
 
   /* These should all generate errors.  */
 
-  obj = i; // expected-error {{assigning to 'id' from incompatible type 'int'}}
-  obj = j; // expected-error {{assigning to 'id' from incompatible type 'int 
*'}}
+  obj = i; // expected-error {{incompatible integer to pointer conversion 
assigning to 'id' from 'int'}}
+  obj = j; // expected-error {{incompatible pointer types assigning to 'id' 
from 'int *'}}
 
-  obj_p = i; // expected-error {{assigning to 'id<MyProtocol>' from 
incompatible type 'int'}}
-  obj_p = j; // expected-error {{assigning to 'id<MyProtocol>' from 
incompatible type 'int *'}}
+  obj_p = i; // expected-error {{incompatible integer to pointer conversion 
assigning to 'id<MyProtocol>' from 'int'}}
+  obj_p = j; // expected-error {{incompatible pointer types assigning to 
'id<MyProtocol>' from 'int *'}}
 
-  obj_c = i; // expected-error {{assigning to 'MyClass *' from incompatible 
type 'int'}}
-  obj_c = j; // expected-error {{assigning to 'MyClass *' from incompatible 
type 'int *'}}
+  obj_c = i; // expected-error {{incompatible integer to pointer conversion 
assigning to 'MyClass *' from 'int'}}
+  obj_c = j; // expected-error {{incompatible pointer types assigning to 
'MyClass *' from 'int *'}}
 
-  obj_C = i; // expected-error {{assigning to 'Class' from incompatible type 
'int'}}
-  obj_C = j; // expected-error {{assigning to 'Class' from incompatible type 
'int *'}}
+  obj_C = i; // expected-error {{incompatible integer to pointer conversion 
assigning to 'Class' from 'int'}}
+  obj_C = j; // expected-error {{incompatible pointer types assigning to 
'Class' from 'int *'}}
 
-  i = obj;   // expected-error {{assigning to 'int' from incompatible type 
'id'}}
-  i = obj_p; // expected-error {{assigning to 'int' from incompatible type 
'id<MyProtocol>'}}
-  i = obj_c; // expected-error {{assigning to 'int' from incompatible type 
'MyClass *'}}
-  i = obj_C; // expected-error {{assigning to 'int' from incompatible type 
'Class'}}
+  i = obj;   // expected-error {{incompatible pointer to integer conversion 
assigning to 'int' from 'id'}}
+  i = obj_p; // expected-error {{incompatible pointer to integer conversion 
assigning to 'int' from 'id<MyProtocol>'}}
+  i = obj_c; // expected-error {{incompatible pointer to integer conversion 
assigning to 'int' from 'MyClass *'}}
+  i = obj_C; // expected-error {{incompatible pointer to integer conversion 
assigning to 'int' from 'Class'}}
 
-  j = obj;   // expected-error {{assigning to 'int *' from incompatible type 
'id'}}
-  j = obj_p; // expected-error {{assigning to 'int *' from incompatible type 
'id<MyProtocol>'}}
-  j = obj_c; // expected-error {{assigning to 'int *' from incompatible type 
'MyClass *'}}
-  j = obj_C; // expected-error {{assigning to 'int *' from incompatible type 
'Class'}}
+  j = obj;   // expected-error {{incompatible pointer types assigning to 'int 
*' from 'id'}}
+  j = obj_p; // expected-error {{incompatible pointer types assigning to 'int 
*' from 'id<MyProtocol>'}}
+  j = obj_c; // expected-error {{incompatible pointer types assigning to 'int 
*' from 'MyClass *'}}
+  j = obj_C; // expected-error {{incompatible pointer types assigning to 'int 
*' from 'Class'}}
 
   if (obj == i) foo() ; // expected-error {{comparison between pointer and 
integer ('id' and 'int')}}
   if (i == obj) foo() ; // expected-error {{comparison between pointer and 
integer ('int' and 'id')}}

diff  --git a/clang/test/SemaObjCXX/instantiate-expr.mm 
b/clang/test/SemaObjCXX/instantiate-expr.mm
index e9d296db8fec..fd674d8828cb 100644
--- a/clang/test/SemaObjCXX/instantiate-expr.mm
+++ b/clang/test/SemaObjCXX/instantiate-expr.mm
@@ -18,8 +18,8 @@ @interface A {
 
 template<unsigned N, typename T, typename U, typename V>
 void f(U value, V value2) {
-  get_an_A(N)->ivar = value; // expected-error{{assigning to 'int' from 
incompatible type 'int *'}}
-  get_an_A(N).prop = value2; // expected-error{{assigning to 'int' from 
incompatible type 'double *'}}
+  get_an_A(N)->ivar = value; // expected-error{{incompatible pointer to 
integer conversion assigning to 'int' from 'int *'; dereference with *}}
+  get_an_A(N).prop = value2; // expected-error{{incompatible pointer to 
integer conversion assigning to 'int' from 'double *'}}
   T c = get_an_id(N)->isa; // expected-error{{cannot initialize a variable of 
type 'int' with an lvalue of type 'Class'}} \
                            // expected-warning 3 {{direct access to 
Objective-C's isa is deprecated in favor of object_getClass()}}
 }
@@ -33,8 +33,8 @@ void f(U value, V value2) {
 // ivar reference.
 template<typename T, typename U, typename V>
 void f2(T ptr, U value, V value2) {
-  ptr->ivar = value; // expected-error{{assigning to 'int' from incompatible 
type 'int *'}}
-  ptr.prop = value2; // expected-error{{assigning to 'int' from incompatible 
type 'double *'}}
+  ptr->ivar = value; // expected-error{{incompatible pointer to integer 
conversion assigning to 'int' from 'int *'; dereference with *}}
+  ptr.prop = value2; // expected-error{{incompatible pointer to integer 
conversion assigning to 'int' from 'double *'}}
 }
 
 template void f2(A*, int, int);
@@ -60,7 +60,7 @@ - (void)setFoo:(int)value;
 
 template<typename T>
 void f4(B *b, T value) {
-  b.foo = value; // expected-error{{assigning to 'int' from incompatible type 
'int *'}}
+  b.foo = value; // expected-error{{incompatible pointer to integer conversion 
assigning to 'int' from 'int *'; dereference with *}}
 }
 
 template void f4(B*, int);
@@ -68,7 +68,7 @@ void f4(B *b, T value) {
 
 template<typename T, typename U>
 void f5(T ptr, U value) {
-  ptr.foo = value; // expected-error{{assigning to 'int' from incompatible 
type 'int *'}}
+  ptr.foo = value; // expected-error{{incompatible pointer to integer 
conversion assigning to 'int' from 'int *'; dereference with *}}
 }
 
 template void f5(B*, int);

diff  --git a/clang/test/SemaObjCXX/instantiate-stmt.mm 
b/clang/test/SemaObjCXX/instantiate-stmt.mm
index 7575f7ad1a8f..bc870206eac4 100644
--- a/clang/test/SemaObjCXX/instantiate-stmt.mm
+++ b/clang/test/SemaObjCXX/instantiate-stmt.mm
@@ -64,7 +64,7 @@ void fast_enumeration_test(T collection) {
 template<typename T, typename U>
 void try_catch_finally_test(U value) {
   @try {
-    value = 1; // expected-error{{assigning to 'int *' from incompatible type 
'int'}}
+    value = 1; // expected-error{{incompatible integer to pointer conversion 
assigning to 'int *' from 'int'}}
   }
   @catch (T obj) { // expected-error{{@catch parameter is not a pointer to an 
interface type}}
     id x = obj;

diff  --git a/clang/test/SemaObjCXX/noescape.mm 
b/clang/test/SemaObjCXX/noescape.mm
index efa2a76d668a..199d1ae11ee7 100644
--- a/clang/test/SemaObjCXX/noescape.mm
+++ b/clang/test/SemaObjCXX/noescape.mm
@@ -74,7 +74,7 @@ -(void) m0:(int*) p {}
 void test0() {
   fnptr0 = &func0;
   fnptr0 = &noescapeFunc2;
-  fnptr1 = &func0; // expected-error {{assigning to 'void 
(*)(__attribute__((noescape)) int *)' from incompatible type 'void (*)(int *)'}}
+  fnptr1 = &func0; // expected-error {{incompatible function pointer types 
assigning to 'void (*)(__attribute__((noescape)) int *)' from 'void (*)(int 
*)'}}
   fnptr1 = &noescapeFunc2;
   S4<&func0> e0;
   S4<&noescapeFunc2> e1;

diff  --git a/clang/test/SemaObjCXX/nullability-pragmas.mm 
b/clang/test/SemaObjCXX/nullability-pragmas.mm
index 817d056a14ac..bbb8cd8832a5 100644
--- a/clang/test/SemaObjCXX/nullability-pragmas.mm
+++ b/clang/test/SemaObjCXX/nullability-pragmas.mm
@@ -32,26 +32,26 @@ void test_pragmas_1(A * _Nonnull a, AA * _Nonnull aa) {
   [a method4: a]; // expected-error{{cannot initialize a parameter of type 
'NSErrorPtr  _Nullable * _Nullable' (aka 'NSError **') with an lvalue of type 
'A * _Nonnull'}}
 
   float *ptr;
-  ptr = f13(); // expected-error{{assigning to 'float *' from incompatible 
type 'int_ptr _Nonnull' (aka 'int *')}}
-  ptr = f14(); // expected-error{{assigning to 'float *' from incompatible 
type 'A * _Nonnull'}}
-  ptr = [a method1:a]; // expected-error{{assigning to 'float *' from 
incompatible type 'A * _Nonnull'}}
-  ptr = a.aProp; // expected-error{{assigning to 'float *' from incompatible 
type 'A * _Nonnull'}}
-  ptr = global_int_ptr; // expected-error{{assigning to 'float *' from 
incompatible type 'int * _Nonnull'}}
-  ptr = f15(); // expected-error{{assigning to 'float *' from incompatible 
type 'int * _Null_unspecified'}}
-  ptr = f16(); // expected-error{{assigning to 'float *' from incompatible 
type 'A * _Null_unspecified'}}
-  ptr = [a method2]; // expected-error{{assigning to 'float *' from 
incompatible type 'A * _Null_unspecified'}}
-
-  ptr = aa->ivar1; // expected-error{{from incompatible type 'id'}}
-  ptr = aa->ivar2; // expected-error{{from incompatible type 'id _Nonnull'}}
+  ptr = f13(); // expected-error{{incompatible pointer types assigning to 
'float *' from 'int_ptr _Nonnull' (aka 'int *')}}
+  ptr = f14(); // expected-error{{incompatible pointer types assigning to 
'float *' from 'A * _Nonnull'}}
+  ptr = [a method1:a]; // expected-error{{incompatible pointer types assigning 
to 'float *' from 'A * _Nonnull'}}
+  ptr = a.aProp; // expected-error{{incompatible pointer types assigning to 
'float *' from 'A * _Nonnull'}}
+  ptr = global_int_ptr; // expected-error{{incompatible pointer types 
assigning to 'float *' from 'int * _Nonnull'}}
+  ptr = f15(); // expected-error{{incompatible pointer types assigning to 
'float *' from 'int * _Null_unspecified'}}
+  ptr = f16(); // expected-error{{incompatible pointer types assigning to 
'float *' from 'A * _Null_unspecified'}}
+  ptr = [a method2]; // expected-error{{incompatible pointer types assigning 
to 'float *' from 'A * _Null_unspecified'}}
+
+  ptr = aa->ivar1; // expected-error{{incompatible pointer types assigning to 
'float *' from 'id'}}
+  ptr = aa->ivar2; // expected-error{{incompatible pointer types assigning to 
'float *' from 'id _Nonnull'}}
 }
 
 void test_pragmas_generics(void) {
   float *fp;
 
   NSGeneric<C *> *genC;
-  fp = [genC tee]; // expected-error{{from incompatible type 'C *'}}
-  fp = [genC maybeTee]; // expected-error{{from incompatible type 'C * 
_Nullable'}}
+  fp = [genC tee]; // expected-error{{incompatible pointer types assigning to 
'float *' from 'C *'}}
+  fp = [genC maybeTee]; // expected-error{{incompatible pointer types 
assigning to 'float *' from 'C * _Nullable'}}
 
   Generic_with_C genC2;
-  fp = genC2; // expected-error{{from incompatible type 'Generic_with_C' (aka 
'NSGeneric<C *> *')}}
+  fp = genC2; // expected-error{{incompatible pointer types assigning to 
'float *' from 'Generic_with_C' (aka 'NSGeneric<C *> *')}}
 }

diff  --git a/clang/test/SemaObjCXX/objc-container-subscripting.mm 
b/clang/test/SemaObjCXX/objc-container-subscripting.mm
index 537e1520df5c..a7a3263ee511 100644
--- a/clang/test/SemaObjCXX/objc-container-subscripting.mm
+++ b/clang/test/SemaObjCXX/objc-container-subscripting.mm
@@ -12,7 +12,7 @@ void test_dictionary_subscripts(T base, U key, O obj) {
   base[key] = obj; // expected-error {{expected method to write array element 
not found on object of type 'NSMutableDictionary *'}} \
                    // expected-error {{cannot initialize a parameter of type 
'id' with an lvalue of type 'int'}}
   obj = base[key];  // expected-error {{expected method to read array element 
not found on object of type 'NSMutableDictionary *'}} \
-                    // expected-error {{assigning to 'int' from incompatible 
type 'id'}}
+                    // expected-error {{incompatible pointer to integer 
conversion assigning to 'int' from 'id'}}
      
 }
 

diff  --git a/clang/test/SemaObjCXX/parameterized_classes_subst.mm 
b/clang/test/SemaObjCXX/parameterized_classes_subst.mm
index 88d001274b1c..2eb630aeedf4 100644
--- a/clang/test/SemaObjCXX/parameterized_classes_subst.mm
+++ b/clang/test/SemaObjCXX/parameterized_classes_subst.mm
@@ -106,27 +106,27 @@ void test_message_send_result(
        NSArray<NSString *> *stringArray,
        void (^block)(void)) {
   int *ip;
-  ip = [stringSet firstObject]; // expected-error{{from incompatible type 
'NSString *'}}
-  ip = [mutStringSet firstObject]; // expected-error{{from incompatible type 
'NSString *'}}
-  ip = [widgetSet firstObject]; // expected-error{{from incompatible type 
'Widget *'}}
-  ip = [untypedMutSet firstObject]; // expected-error{{from incompatible type 
'id'}}
-  ip = [mutStringArraySet firstObject]; // expected-error{{from incompatible 
type 'NSArray<NSString *> *'}}
-  ip = [set firstObject]; // expected-error{{from incompatible type 'id'}}
-  ip = [mutSet firstObject]; // expected-error{{from incompatible type 'id'}}
-  ip = [mutArraySet firstObject]; // expected-error{{from incompatible type 
'id'}}
-  ip = [block firstObject]; // expected-error{{from incompatible type 'id'}}
-
-  ip = [stringSet findObject:@"blah"]; // expected-error{{from incompatible 
type 'NSString *'}}
+  ip = [stringSet firstObject]; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSString *'}}
+  ip = [mutStringSet firstObject]; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSString *'}}
+  ip = [widgetSet firstObject]; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'Widget *'}}
+  ip = [untypedMutSet firstObject]; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'id'}}
+  ip = [mutStringArraySet firstObject]; // expected-error{{incompatible 
pointer types assigning to 'int *' from 'NSArray<NSString *> *'}}
+  ip = [set firstObject]; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'id'}}
+  ip = [mutSet firstObject]; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'id'}}
+  ip = [mutArraySet firstObject]; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'id'}}
+  ip = [block firstObject]; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'id'}}
+
+  ip = [stringSet findObject:@"blah"]; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSString *'}}
 
   // Class messages.
-  ip = [NSSet<NSString *> alloc]; // expected-error{{from incompatible type 
'NSSet<NSString *> *'}}
-  ip = [NSSet alloc]; // expected-error{{from incompatible type 'NSSet *'}}
-  ip = [MutableSetOfArrays<NSString *> alloc]; // expected-error{{from 
incompatible type 'MutableSetOfArrays<NSString *> *'}}
-  ip = [MutableSetOfArrays alloc];  // expected-error{{from incompatible type 
'MutableSetOfArrays *'}}
-  ip = [NSArray<NSString *> array]; // expected-error{{from incompatible type 
'NSArray<NSString *> *'}}
-  ip = [NSArray<NSString *><NSCopying> array]; // expected-error{{from 
incompatible type 'NSArray<NSString *> *'}}
+  ip = [NSSet<NSString *> alloc]; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSSet<NSString *> *'}}
+  ip = [NSSet alloc]; // expected-error{{incompatible pointer types assigning 
to 'int *' from 'NSSet *'}}
+  ip = [MutableSetOfArrays<NSString *> alloc]; // expected-error{{incompatible 
pointer types assigning to 'int *' from 'MutableSetOfArrays<NSString *> *'}}
+  ip = [MutableSetOfArrays alloc];  // expected-error{{incompatible pointer 
types assigning to 'int *' from 'MutableSetOfArrays *'}}
+  ip = [NSArray<NSString *> array]; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSArray<NSString *> *'}}
+  ip = [NSArray<NSString *><NSCopying> array]; // expected-error{{incompatible 
pointer types assigning to 'int *' from 'NSArray<NSString *> *'}}
 
-  ip = [[NSMutableArray<NSString *> alloc] init];  // expected-error{{from 
incompatible type 'NSMutableArray<NSString *> *'}}
+  ip = [[NSMutableArray<NSString *> alloc] init];  // 
expected-error{{incompatible pointer types assigning to 'int *' from 
'NSMutableArray<NSString *> *'}}
 
   [[NSMutableArray alloc] initWithArray: stringArray]; // okay
   [[NSMutableArray<NSString *> alloc] initWithArray: stringArray]; // okay
@@ -166,16 +166,16 @@ void test_property_read(
        MutableSetOfArrays *mutArraySet,
        NSMutableDictionary *mutDict) {
   int *ip;
-  ip = stringSet.allObjects; // expected-error{{from incompatible type 
'NSArray<NSString *> *'}}
-  ip = mutStringSet.allObjects; // expected-error{{from incompatible type 
'NSArray<NSString *> *'}}
-  ip = widgetSet.allObjects; // expected-error{{from incompatible type 
'NSArray<Widget *> *'}}
-  ip = untypedMutSet.allObjects; // expected-error{{from incompatible type 
'NSArray *'}}
-  ip = mutStringArraySet.allObjects; // expected-error{{from incompatible type 
'NSArray<NSArray<NSString *> *> *'}}
-  ip = set.allObjects; // expected-error{{from incompatible type 'NSArray *'}}
-  ip = mutSet.allObjects; // expected-error{{from incompatible type 'NSArray 
*'}}
-  ip = mutArraySet.allObjects; // expected-error{{from incompatible type 
'NSArray *'}}
-
-  ip = mutDict.someRandomKey; // expected-error{{from incompatible type 
'__kindof id<NSCopying>'}}
+  ip = stringSet.allObjects; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSArray<NSString *> *'}}
+  ip = mutStringSet.allObjects; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSArray<NSString *> *'}}
+  ip = widgetSet.allObjects; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSArray<Widget *> *'}}
+  ip = untypedMutSet.allObjects; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSArray *'}}
+  ip = mutStringArraySet.allObjects; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSArray<NSArray<NSString *> *> *'}}
+  ip = set.allObjects; // expected-error{{incompatible pointer types assigning 
to 'int *' from 'NSArray *'}}
+  ip = mutSet.allObjects; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSArray *'}}
+  ip = mutArraySet.allObjects; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSArray *'}}
+
+  ip = mutDict.someRandomKey; // expected-error{{incompatible pointer types 
assigning to 'int *' from '__kindof id<NSCopying>'}}
 }
 
 void test_property_write(
@@ -215,27 +215,27 @@ void test_subscripting(
   Widget *widget;
   Window *window;
 
-  ip = stringArray[0]; // expected-error{{from incompatible type 'NSString *'}}
+  ip = stringArray[0]; // expected-error{{incompatible pointer types assigning 
to 'int *' from 'NSString *'}}
 
-  ip = mutStringArray[0]; // expected-error{{from incompatible type 'NSString 
*'}}
+  ip = mutStringArray[0]; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSString *'}}
   mutStringArray[0] = ip; // expected-error{{parameter of type 'NSString *'}}
 
-  ip = array[0]; // expected-error{{from incompatible type 'id'}}
+  ip = array[0]; // expected-error{{incompatible pointer types assigning to 
'int *' from 'id'}}
 
-  ip = mutArray[0]; // expected-error{{from incompatible type 'id'}}
+  ip = mutArray[0]; // expected-error{{incompatible pointer types assigning to 
'int *' from 'id'}}
   mutArray[0] = ip; // expected-error{{parameter of type 'id'}}
 
-  ip = stringWidgetDict[string]; // expected-error{{from incompatible type 
'Widget *'}}
+  ip = stringWidgetDict[string]; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'Widget *'}}
   widget = stringWidgetDict[widget]; // expected-error{{parameter of type 
'NSString *'}}
 
-  ip = mutStringWidgetDict[string]; // expected-error{{from incompatible type 
'Widget *'}}
+  ip = mutStringWidgetDict[string]; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'Widget *'}}
   widget = mutStringWidgetDict[widget]; // expected-error{{parameter of type 
'NSString *'}}
   mutStringWidgetDict[string] = ip; // expected-error{{parameter of type 
'Widget *'}}
   mutStringWidgetDict[widget] = widget; // expected-error{{parameter of type 
'NSString *'}}
 
-  ip = dict[string]; // expected-error{{from incompatible type 'id'}}
+  ip = dict[string]; // expected-error{{incompatible pointer types assigning 
to 'int *' from 'id'}}
 
-  ip = mutDict[string]; // expected-error{{incompatible type 'id'}}
+  ip = mutDict[string]; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'id'}}
   mutDict[string] = ip; // expected-error{{parameter of type 'id'}}
 
   widget = mutDict[window];
@@ -249,15 +249,15 @@ void test_instance_variable(NSArray<NSString *> 
*stringArray,
                             NSArray *array) {
   int *ip;
 
-  ip = stringArray->data; // expected-error{{from incompatible type 'NSString 
**'}}
-  ip = array->data; // expected-error{{from incompatible type 'id *'}}
+  ip = stringArray->data; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSString **'}}
+  ip = array->data; // expected-error{{incompatible pointer types assigning to 
'int *' from 'id *'}}
 }
 
 @implementation WindowArray
 - (void)testInstanceVariable {
   int *ip;
 
-  ip = data; // expected-error{{from incompatible type 'Window **'}}
+  ip = data; // expected-error{{incompatible pointer types assigning to 'int 
*' from 'Window **'}}
 }
 @end
 
@@ -276,13 +276,13 @@ void test_implicit_conversions(NSArray<NSString *> 
*stringArray,
   stringArray = array;
 
   // Specialized -> specialized failure (same level).
-  stringArray = numberArray; // expected-error{{assigning to 'NSArray<NSString 
*> *' from incompatible type 'NSArray<NSNumber *> *'}}
+  stringArray = numberArray; // expected-error{{incompatible pointer types 
assigning to 'NSArray<NSString *> *' from 'NSArray<NSNumber *> *'}}
 
   // Specialized -> specialized (
diff erent levels).
   stringArray = mutStringArray;
 
   // Specialized -> specialized failure (
diff erent levels).
-  numberArray = mutStringArray; // expected-error{{assigning to 
'NSArray<NSNumber *> *' from incompatible type 'NSMutableArray<NSString *> *'}}
+  numberArray = mutStringArray; // expected-error{{incompatible pointer types 
assigning to 'NSArray<NSNumber *> *' from 'NSMutableArray<NSString *> *'}}
 
   // Unspecialized -> specialized (
diff erent levels).
   stringArray = mutArray;
@@ -334,19 +334,19 @@ void test_ternary_operator(NSArray<NSString *> 
*stringArray,
   int *ip;
   id object;
 
-  ip = cond ? stringArray : mutStringArray; // expected-error{{from 
incompatible type 'NSArray<NSString *> *'}}
-  ip = cond ? mutStringArray : stringArray; // expected-error{{from 
incompatible type 'NSArray<NSString *> *'}}
+  ip = cond ? stringArray : mutStringArray; // expected-error{{incompatible 
pointer types assigning to 'int *' from 'NSArray<NSString *> *'}}
+  ip = cond ? mutStringArray : stringArray; // expected-error{{incompatible 
pointer types assigning to 'int *' from 'NSArray<NSString *> *'}}
 
-  ip = cond ? stringArray2 : mutStringArray; // expected-error{{from 
incompatible type 'NSArray<NSString *> *'}}
-  ip = cond ? mutStringArray : stringArray2; // expected-error{{from 
incompatible type 'NSArray<NSString *> *'}}
+  ip = cond ? stringArray2 : mutStringArray; // expected-error{{incompatible 
pointer types assigning to 'int *' from 'NSArray<NSString *> *'}}
+  ip = cond ? mutStringArray : stringArray2; // expected-error{{incompatible 
pointer types assigning to 'int *' from 'NSArray<NSString *> *'}}
 
-  ip = cond ? stringArray : mutArray; // expected-error{{from incompatible 
type 'NSArray *'}}
+  ip = cond ? stringArray : mutArray; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSArray *'}}
 
-  ip = cond ? stringArray2 : mutArray; // expected-error{{from incompatible 
type 'NSArray *'}}
+  ip = cond ? stringArray2 : mutArray; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSArray *'}}
 
-  ip = cond ? mutArray : stringArray; // expected-error{{from incompatible 
type 'NSArray *'}}
+  ip = cond ? mutArray : stringArray; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSArray *'}}
 
-  ip = cond ? mutArray : stringArray2; // expected-error{{from incompatible 
type 'NSArray *'}}
+  ip = cond ? mutArray : stringArray2; // expected-error{{incompatible pointer 
types assigning to 'int *' from 'NSArray *'}}
 
   object = cond ? stringArray : numberArray; // expected-warning{{incompatible 
operand types ('NSArray<NSString *> *' and 'NSArray<NSNumber *> *')}}
 }
@@ -357,14 +357,14 @@ void test_ternary_operator(NSArray<NSString *> 
*stringArray,
 @implementation NSStringArray
 - (void)useSuperMethod {
   int *ip;
-  ip = super.lastObject; // expected-error{{from incompatible type 'NSString 
*'}}
-  ip = [super objectAtIndexedSubscript:0]; // expected-error{{from 
incompatible type 'NSString *'}}
+  ip = super.lastObject; // expected-error{{incompatible pointer types 
assigning to 'int *' from 'NSString *'}}
+  ip = [super objectAtIndexedSubscript:0]; // expected-error{{incompatible 
pointer types assigning to 'int *' from 'NSString *'}}
 }
 
 + (void)useSuperMethod {
   int *ip;
-  ip = super.array; // expected-error{{from incompatible type 
'NSArray<NSString *> *'}}
-  ip = [super array]; // expected-error{{from incompatible type 
'NSArray<NSString *> *'}}
+  ip = super.array; // expected-error{{incompatible pointer types assigning to 
'int *' from 'NSArray<NSString *> *'}}
+  ip = [super array]; // expected-error{{incompatible pointer types assigning 
to 'int *' from 'NSArray<NSString *> *'}}
 }
 @end
 

diff  --git a/clang/test/SemaObjCXX/property-invalid-type.mm 
b/clang/test/SemaObjCXX/property-invalid-type.mm
index 648235894ec4..9122426f4c30 100644
--- a/clang/test/SemaObjCXX/property-invalid-type.mm
+++ b/clang/test/SemaObjCXX/property-invalid-type.mm
@@ -13,7 +13,7 @@ @implementation I
 @synthesize response;
 - (void) foo :(A*) a   // expected-error {{expected a type}}
 {
-  self.response = a; // expected-error{{assigning to 'int *' from incompatible 
type 'id'}}
+  self.response = a; // expected-error{{incompatible pointer types assigning 
to 'int *' from 'id'}}
 }
 @end
 

diff  --git a/clang/test/SemaOpenCL/address-spaces-conversions-cl2.0.cl 
b/clang/test/SemaOpenCL/address-spaces-conversions-cl2.0.cl
index 5efea216346a..a5a838241347 100644
--- a/clang/test/SemaOpenCL/address-spaces-conversions-cl2.0.cl
+++ b/clang/test/SemaOpenCL/address-spaces-conversions-cl2.0.cl
@@ -178,7 +178,7 @@ void test_conversion(__global int *arg_glob, __local int 
*arg_loc,
 #if !__OPENCL_CPP_VERSION__
 // expected-error@-3{{assigning '__global int *__private' to '__constant int 
*__private' changes address space of pointer}}
 #else
-// expected-error@-5{{assigning to '__constant int *' from incompatible type 
'__global int *__private'}}
+// expected-error@-5{{assigning '__global int *__private' to '__constant int 
*' changes address space of pointer}}
 #endif
 #endif
 
@@ -187,7 +187,7 @@ void test_conversion(__global int *arg_glob, __local int 
*arg_loc,
 #if !__OPENCL_CPP_VERSION__
 // expected-error-re@-3{{assigning '__local int *__private' to 
'__{{global|constant}} int *__private' changes address space of pointer}}
 #else
-// expected-error-re@-5{{assigning to '__{{global|constant}} int *' from 
incompatible type '__local int *__private'}}
+// expected-error-re@-5{{assigning '__local int *__private' to 
'__{{global|constant}} int *' changes address space of pointer}}
 #endif
 #endif
 
@@ -196,7 +196,7 @@ void test_conversion(__global int *arg_glob, __local int 
*arg_loc,
 #if !__OPENCL_CPP_VERSION__
 // expected-error-re@-3{{assigning '__constant int *__private' to 
'__{{global|generic}} int *__private' changes address space of pointer}}
 #else
-// expected-error-re@-5{{assigning to '__{{global|generic}} int *' from 
incompatible type '__constant int *__private'}}
+// expected-error-re@-5{{assigning '__constant int *__private' to 
'__{{global|generic}} int *' changes address space of pointer}}
 #endif
 #endif
 
@@ -205,7 +205,7 @@ void test_conversion(__global int *arg_glob, __local int 
*arg_loc,
 #if !__OPENCL_CPP_VERSION__
 // expected-error-re@-3{{assigning '__private int *__private' to 
'__{{global|constant}} int *__private' changes address space of pointer}}
 #else
-// expected-error-re@-5{{assigning to '__{{global|constant}} int *' from 
incompatible type '__private int *__private'}}
+// expected-error-re@-5{{assigning '__private int *__private' to 
'__{{global|constant}} int *' changes address space of pointer}}
 #endif
 #endif
 
@@ -214,7 +214,7 @@ void test_conversion(__global int *arg_glob, __local int 
*arg_loc,
 #if !__OPENCL_CPP_VERSION__
 // expected-error-re@-3{{assigning '__generic int *__private' to 
'__{{global|constant}} int *__private' changes address space of pointer}}
 #else
-// expected-error-re@-5{{assigning to '__{{global|constant}} int *' from 
incompatible type '__generic int *__private'}}
+// expected-error-re@-5{{assigning '__generic int *__private' to 
'__{{global|constant}} int *' changes address space of pointer}}
 #endif
 #endif
 
@@ -518,7 +518,7 @@ void test_pointer_chains() {
 #if !__OPENCL_CPP_VERSION__
 // expected-error@-3 {{assigning '__local int *__local *__private' to 
'__generic int *__generic *__private' changes address space of nested pointer}}
 #else
-// expected-error@-5 {{assigning to '__generic int *__generic *' from 
incompatible type '__local int *__local *__private'}}
+// expected-error@-5 {{assigning '__local int *__local *__private' to 
'__generic int *__generic *' changes address space of nested pointer}}
 #endif
 #endif
 

diff  --git a/clang/test/SemaOpenCL/address-spaces.cl 
b/clang/test/SemaOpenCL/address-spaces.cl
index 07547ea19680..e9825fd1682a 100644
--- a/clang/test/SemaOpenCL/address-spaces.cl
+++ b/clang/test/SemaOpenCL/address-spaces.cl
@@ -20,7 +20,7 @@ __kernel void foo(__global int *gip) {
 #if !__OPENCL_CPP_VERSION__
 // expected-error@-2 {{assigning '__constant int *' to '__generic int 
*__private' changes address space of pointer}}
 #else
-// expected-error@-4 {{assigning to '__generic int *' from incompatible type 
'__constant int *'}}
+// expected-error@-4 {{assigning '__constant int *' to '__generic int *' 
changes address space of pointer}}
 #endif
 #endif
 }
@@ -176,46 +176,46 @@ void nested(__global int *g, __global int * __private 
*gg, __local int *l, __loc
 }
 #else
 void nested(__global int *g, __global int * __private *gg, __local int *l, 
__local int * __private *ll, __global float * __private *gg_f) {
-  g = gg;    // expected-error {{assigning to '__global int *' from 
incompatible type '__global int *__private *__private'}}
-  g = l;     // expected-error {{assigning to '__global int *' from 
incompatible type '__local int *__private'}}
-  g = ll;    // expected-error {{assigning to '__global int *' from 
incompatible type '__local int *__private *__private'}}
-  g = gg_f;  // expected-error {{assigning to '__global int *' from 
incompatible type '__global float *__private *__private'}}
+  g = gg;    // expected-error {{assigning '__global int *__private 
*__private' to '__global int *' changes address space of pointer}}
+  g = l;     // expected-error {{assigning '__local int *__private' to 
'__global int *' changes address space of pointer}}
+  g = ll;    // expected-error {{assigning '__local int *__private *__private' 
to '__global int *' changes address space of pointer}}
+  g = gg_f;  // expected-error {{assigning '__global float *__private 
*__private' to '__global int *' changes address space of pointer}}
   g = (__global int *)gg_f; // expected-error {{C-style cast from '__global 
float *__private *' to '__global int *' converts between mismatching address 
spaces}}
 
-  gg = g;    // expected-error {{assigning to '__global int *__private *' from 
incompatible type '__global int *__private'; take the address with &}}
-  gg = l;    // expected-error {{assigning to '__global int *__private *' from 
incompatible type '__local int *__private'}}
-  gg = ll;   // expected-error {{assigning to '__global int *__private *' from 
incompatible type '__local int *__private *__private'}}
-  gg = gg_f; // expected-error {{assigning to '__global int *__private *' from 
incompatible type '__global float *__private *__private'}}
+  gg = g;    // expected-error {{assigning '__global int *__private' to 
'__global int *__private *' changes address space of pointer}}
+  gg = l;    // expected-error {{assigning '__local int *__private' to 
'__global int *__private *' changes address space of pointer}}
+  gg = ll;   // expected-error {{assigning '__local int *__private *__private' 
to '__global int *__private *' changes address space of nested pointer}}
+  gg = gg_f; // expected-error {{incompatible pointer types assigning to 
'__global int *__private *' from '__global float *__private *__private'}}
   gg = (__global int * __private *)gg_f;
 
-  l = g;     // expected-error {{assigning to '__local int *' from 
incompatible type '__global int *__private'}}
-  l = gg;    // expected-error {{assigning to '__local int *' from 
incompatible type '__global int *__private *__private'}}
-  l = ll;    // expected-error {{assigning to '__local int *' from 
incompatible type '__local int *__private *__private'}}
-  l = gg_f;  // expected-error {{assigning to '__local int *' from 
incompatible type '__global float *__private *__private'}}
+  l = g;     // expected-error {{assigning '__global int *__private' to 
'__local int *' changes address space of pointer}}
+  l = gg;    // expected-error {{assigning '__global int *__private 
*__private' to '__local int *' changes address space of pointer}}
+  l = ll;    // expected-error {{assigning '__local int *__private *__private' 
to '__local int *' changes address space of pointer}}
+  l = gg_f;  // expected-error {{assigning '__global float *__private 
*__private' to '__local int *' changes address space of pointer}}
   l = (__local int *)gg_f; // expected-error {{C-style cast from '__global 
float *__private *' to '__local int *' converts between mismatching address 
spaces}}
 
-  ll = g;    // expected-error {{assigning to '__local int *__private *' from 
incompatible type '__global int *__private'}}
-  ll = gg;   // expected-error {{assigning to '__local int *__private *' from 
incompatible type '__global int *__private *__private'}}
-  ll = l;    // expected-error {{assigning to '__local int *__private *' from 
incompatible type '__local int *__private'; take the address with &}}
-  ll = gg_f; // expected-error {{assigning to '__local int *__private *' from 
incompatible type '__global float *__private *__private'}}
+  ll = g;    // expected-error {{assigning '__global int *__private' to 
'__local int *__private *' changes address space of pointer}}
+  ll = gg;   // expected-error {{assigning '__global int *__private 
*__private' to '__local int *__private *' changes address space of nested 
pointer}}
+  ll = l;    // expected-error {{assigning '__local int *__private' to 
'__local int *__private *' changes address space of pointer}}
+  ll = gg_f; // expected-error {{assigning '__global float *__private 
*__private' to '__local int *__private *' changes address space of nested 
pointer}}
   ll = (__local int *__private *)gg; //expected-warning{{C-style cast from 
'__global int *__private *' to '__local int *__private *' changes address space 
of nested pointers}}
 
-  gg_f = g;  // expected-error {{assigning to '__global float *__private *' 
from incompatible type '__global int *__private'}}
-  gg_f = gg; // expected-error {{assigning to '__global float *__private *' 
from incompatible type '__global int *__private *__private'}}
-  gg_f = l;  // expected-error {{assigning to '__global float *__private *' 
from incompatible type '__local int *__private'}}
-  gg_f = ll; // expected-error {{assigning to '__global float *__private *' 
from incompatible type '__local int *__private *__private'}}
+  gg_f = g;  // expected-error {{assigning '__global int *__private' to 
'__global float *__private *' changes address space of pointer}}
+  gg_f = gg; // expected-error {{incompatible pointer types assigning to 
'__global float *__private *' from '__global int *__private *__private'}}
+  gg_f = l;  // expected-error {{assigning '__local int *__private' to 
'__global float *__private *' changes address space of pointer}}
+  gg_f = ll; // expected-error {{assigning '__local int *__private *__private' 
to '__global float *__private *' changes address space of nested pointer}}
   gg_f = (__global float * __private *)gg;
 
   typedef __local int * l_t;
   typedef __global int * g_t;
   __private l_t * pl;
   __private g_t * pg;
-  gg = pl;  // expected-error {{assigning to '__global int *__private *' from 
incompatible type '__private l_t *__private' (aka '__local int *__private 
*__private')}}
-  pl = gg;  // expected-error {{assigning to '__private l_t *' (aka '__local 
int *__private *') from incompatible type '__global int *__private *__private'}}
+  gg = pl;  // expected-error {{assigning '__private l_t *__private' (aka 
'__local int *__private *__private') to '__global int *__private *' changes 
address space of nested pointer}}
+  pl = gg;  // expected-error {{assigning '__global int *__private *__private' 
to '__private l_t *' (aka '__local int *__private *') changes address space of 
nested pointer}}
   gg = pg;
   pg = gg;
-  pg = pl;  // expected-error {{assigning to '__private g_t *' (aka '__global 
int *__private *') from incompatible type '__private l_t *__private' (aka 
'__local int *__private *__private')}}
-  pl = pg;  // expected-error {{assigning to '__private l_t *' (aka '__local 
int *__private *') from incompatible type '__private g_t *__private' (aka 
'__global int *__private *__private')}}
+  pg = pl;  // expected-error {{assigning '__private l_t *__private' (aka 
'__local int *__private *__private') to '__private g_t *' (aka '__global int 
*__private *') changes address space of nested pointer}}
+  pl = pg;  // expected-error {{assigning '__private g_t *__private' (aka 
'__global int *__private *__private') to '__private l_t *' (aka '__local int 
*__private *') changes address space of nested pointer}}
 
   ll = (__local int * __private *)(void *)gg;
   void *vp = ll;

diff  --git a/clang/test/SemaTemplate/extern-templates.cpp 
b/clang/test/SemaTemplate/extern-templates.cpp
index acbc9d57122e..efc4690bbb2c 100644
--- a/clang/test/SemaTemplate/extern-templates.cpp
+++ b/clang/test/SemaTemplate/extern-templates.cpp
@@ -23,9 +23,9 @@ extern template class X0<int*>;
 template<typename T>
 void X0<T>::Inner::g(T t) {
 #ifdef MS
-  t = 17; // expected-error{{assigning to 'long *' from incompatible}} 
expected-error{{assigning to 'int *' from incompatible}}
+  t = 17; // expected-error{{incompatible integer to pointer conversion 
assigning to 'long *'}} expected-error{{incompatible integer to pointer 
conversion assigning to 'int *'}}
 #else
-  t = 17; // expected-error{{assigning to 'long *' from incompatible}}
+  t = 17; // expected-error{{incompatible integer to pointer conversion 
assigning to 'long *'}}
 #endif
 }
 

diff  --git a/clang/test/SemaTemplate/instantiate-member-class.cpp 
b/clang/test/SemaTemplate/instantiate-member-class.cpp
index 5a9e2e30e851..efaa40036598 100644
--- a/clang/test/SemaTemplate/instantiate-member-class.cpp
+++ b/clang/test/SemaTemplate/instantiate-member-class.cpp
@@ -43,8 +43,8 @@ X<int>::X *xi; // expected-error{{qualified reference to 'X' 
is a constructor na
 X<float>::X *xf; // expected-error{{qualified reference to 'X' is a 
constructor name rather than a type}}
 
 void test_naming() {
-  c1 = c2; // expected-error{{assigning to 'X<int>::C *' from incompatible 
type 'X<float>::C *'}}
-  xi = xf;  // expected-error{{assigning to 'X<int>::X<int> *' from 
incompatible type 'X<float>::X<float> *'}}
+  c1 = c2; // expected-error{{incompatible pointer types assigning to 
'X<int>::C *' from 'X<float>::C *'}}
+  xi = xf;  // expected-error{{incompatible pointer types assigning to 
'X<int>::X<int> *' from 'X<float>::X<float> *'}}
     // FIXME: error above doesn't print the type X<int>::X cleanly!
 }
 

diff  --git a/clang/test/SemaTemplate/member-access-expr.cpp 
b/clang/test/SemaTemplate/member-access-expr.cpp
index ef10d72a0ef8..36d602257728 100644
--- a/clang/test/SemaTemplate/member-access-expr.cpp
+++ b/clang/test/SemaTemplate/member-access-expr.cpp
@@ -156,7 +156,7 @@ namespace test6 {
     void get(B **ptr) {
       // It's okay if at some point we figure out how to diagnose this
       // at instantiation time.
-      *ptr = field; // expected-error {{assigning to 'test6::B *' from 
incompatible type 'test6::A *}}
+      *ptr = field; // expected-error {{incompatible pointer types assigning 
to 'test6::B *' from 'test6::A *'}}
     }
   };
 }

diff  --git a/clang/test/SemaTemplate/temp_arg_nontype.cpp 
b/clang/test/SemaTemplate/temp_arg_nontype.cpp
index 08ed7d5004ad..245b9a60269d 100644
--- a/clang/test/SemaTemplate/temp_arg_nontype.cpp
+++ b/clang/test/SemaTemplate/temp_arg_nontype.cpp
@@ -194,7 +194,7 @@ namespace EntityReferenced {
   template<typename T>
   struct Y {
     static void f(T x) { 
-      x = 1; // expected-error{{assigning to 'int *' from incompatible type 
'int'}}
+      x = 1; // expected-error{{incompatible integer to pointer conversion 
assigning to 'int *' from 'int'}}
     }
   };
 


        
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to