PR2919: __builtin_types_compatible_p strips CRV qualifiers.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@58079 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/AST/ExprConstant.cpp b/lib/AST/ExprConstant.cpp
index 5bc4170..1201064 100644
--- a/lib/AST/ExprConstant.cpp
+++ b/lib/AST/ExprConstant.cpp
@@ -205,7 +205,13 @@
   }
   bool VisitTypesCompatibleExpr(const TypesCompatibleExpr *E) {
     Result.zextOrTrunc(getIntTypeSizeInBits(E->getType()));
-    Result = Info.Ctx.typesAreCompatible(E->getArgType1(), E->getArgType2());
+    // Per gcc docs "this built-in function ignores top level
+    // qualifiers".  We need to use the canonical version to properly
+    // be able to strip CRV qualifiers from the type.
+    QualType T0 = Info.Ctx.getCanonicalType(E->getArgType1());
+    QualType T1 = Info.Ctx.getCanonicalType(E->getArgType2());
+    Result = Info.Ctx.typesAreCompatible(T0.getUnqualifiedType(), 
+                                         T1.getUnqualifiedType());
     return true;
   }
   bool VisitDeclRefExpr(const DeclRefExpr *E);