Home | History | Annotate | Download | only in Sema
      1 //===--- SemaDeclAttr.cpp - Declaration Attribute Handling ----------------===//
      2 //
      3 //                     The LLVM Compiler Infrastructure
      4 //
      5 // This file is distributed under the University of Illinois Open Source
      6 // License. See LICENSE.TXT for details.
      7 //
      8 //===----------------------------------------------------------------------===//
      9 //
     10 //  This file implements decl-related attribute processing.
     11 //
     12 //===----------------------------------------------------------------------===//
     13 
     14 #include "clang/Sema/SemaInternal.h"
     15 #include "clang/AST/ASTConsumer.h"
     16 #include "clang/AST/ASTContext.h"
     17 #include "clang/AST/CXXInheritance.h"
     18 #include "clang/AST/DeclCXX.h"
     19 #include "clang/AST/DeclObjC.h"
     20 #include "clang/AST/DeclTemplate.h"
     21 #include "clang/AST/Expr.h"
     22 #include "clang/AST/ExprCXX.h"
     23 #include "clang/AST/Mangle.h"
     24 #include "clang/AST/ASTMutationListener.h"
     25 #include "clang/Basic/CharInfo.h"
     26 #include "clang/Basic/SourceManager.h"
     27 #include "clang/Basic/TargetInfo.h"
     28 #include "clang/Lex/Preprocessor.h"
     29 #include "clang/Sema/DeclSpec.h"
     30 #include "clang/Sema/DelayedDiagnostic.h"
     31 #include "clang/Sema/Initialization.h"
     32 #include "clang/Sema/Lookup.h"
     33 #include "clang/Sema/Scope.h"
     34 #include "llvm/ADT/StringExtras.h"
     35 #include "llvm/Support/MathExtras.h"
     36 
     37 using namespace clang;
     38 using namespace sema;
     39 
     40 namespace AttributeLangSupport {
     41   enum LANG {
     42     C,
     43     Cpp,
     44     ObjC
     45   };
     46 } // end namespace AttributeLangSupport
     47 
     48 //===----------------------------------------------------------------------===//
     49 //  Helper functions
     50 //===----------------------------------------------------------------------===//
     51 
     52 /// isFunctionOrMethod - Return true if the given decl has function
     53 /// type (function or function-typed variable) or an Objective-C
     54 /// method.
     55 static bool isFunctionOrMethod(const Decl *D) {
     56   return (D->getFunctionType() != nullptr) || isa<ObjCMethodDecl>(D);
     57 }
     58 
     59 /// \brief Return true if the given decl has function type (function or
     60 /// function-typed variable) or an Objective-C method or a block.
     61 static bool isFunctionOrMethodOrBlock(const Decl *D) {
     62   return isFunctionOrMethod(D) || isa<BlockDecl>(D);
     63 }
     64 
     65 /// Return true if the given decl has a declarator that should have
     66 /// been processed by Sema::GetTypeForDeclarator.
     67 static bool hasDeclarator(const Decl *D) {
     68   // In some sense, TypedefDecl really *ought* to be a DeclaratorDecl.
     69   return isa<DeclaratorDecl>(D) || isa<BlockDecl>(D) || isa<TypedefNameDecl>(D) ||
     70          isa<ObjCPropertyDecl>(D);
     71 }
     72 
     73 /// hasFunctionProto - Return true if the given decl has a argument
     74 /// information. This decl should have already passed
     75 /// isFunctionOrMethod or isFunctionOrMethodOrBlock.
     76 static bool hasFunctionProto(const Decl *D) {
     77   if (const FunctionType *FnTy = D->getFunctionType())
     78     return isa<FunctionProtoType>(FnTy);
     79   return isa<ObjCMethodDecl>(D) || isa<BlockDecl>(D);
     80 }
     81 
     82 /// getFunctionOrMethodNumParams - Return number of function or method
     83 /// parameters. It is an error to call this on a K&R function (use
     84 /// hasFunctionProto first).
     85 static unsigned getFunctionOrMethodNumParams(const Decl *D) {
     86   if (const FunctionType *FnTy = D->getFunctionType())
     87     return cast<FunctionProtoType>(FnTy)->getNumParams();
     88   if (const BlockDecl *BD = dyn_cast<BlockDecl>(D))
     89     return BD->getNumParams();
     90   return cast<ObjCMethodDecl>(D)->param_size();
     91 }
     92 
     93 static QualType getFunctionOrMethodParamType(const Decl *D, unsigned Idx) {
     94   if (const FunctionType *FnTy = D->getFunctionType())
     95     return cast<FunctionProtoType>(FnTy)->getParamType(Idx);
     96   if (const BlockDecl *BD = dyn_cast<BlockDecl>(D))
     97     return BD->getParamDecl(Idx)->getType();
     98 
     99   return cast<ObjCMethodDecl>(D)->parameters()[Idx]->getType();
    100 }
    101 
    102 static SourceRange getFunctionOrMethodParamRange(const Decl *D, unsigned Idx) {
    103   if (const auto *FD = dyn_cast<FunctionDecl>(D))
    104     return FD->getParamDecl(Idx)->getSourceRange();
    105   if (const auto *MD = dyn_cast<ObjCMethodDecl>(D))
    106     return MD->parameters()[Idx]->getSourceRange();
    107   if (const auto *BD = dyn_cast<BlockDecl>(D))
    108     return BD->getParamDecl(Idx)->getSourceRange();
    109   return SourceRange();
    110 }
    111 
    112 static QualType getFunctionOrMethodResultType(const Decl *D) {
    113   if (const FunctionType *FnTy = D->getFunctionType())
    114     return cast<FunctionType>(FnTy)->getReturnType();
    115   return cast<ObjCMethodDecl>(D)->getReturnType();
    116 }
    117 
    118 static SourceRange getFunctionOrMethodResultSourceRange(const Decl *D) {
    119   if (const auto *FD = dyn_cast<FunctionDecl>(D))
    120     return FD->getReturnTypeSourceRange();
    121   if (const auto *MD = dyn_cast<ObjCMethodDecl>(D))
    122     return MD->getReturnTypeSourceRange();
    123   return SourceRange();
    124 }
    125 
    126 static bool isFunctionOrMethodVariadic(const Decl *D) {
    127   if (const FunctionType *FnTy = D->getFunctionType()) {
    128     const FunctionProtoType *proto = cast<FunctionProtoType>(FnTy);
    129     return proto->isVariadic();
    130   }
    131   if (const BlockDecl *BD = dyn_cast<BlockDecl>(D))
    132     return BD->isVariadic();
    133 
    134   return cast<ObjCMethodDecl>(D)->isVariadic();
    135 }
    136 
    137 static bool isInstanceMethod(const Decl *D) {
    138   if (const CXXMethodDecl *MethodDecl = dyn_cast<CXXMethodDecl>(D))
    139     return MethodDecl->isInstance();
    140   return false;
    141 }
    142 
    143 static inline bool isNSStringType(QualType T, ASTContext &Ctx) {
    144   const ObjCObjectPointerType *PT = T->getAs<ObjCObjectPointerType>();
    145   if (!PT)
    146     return false;
    147 
    148   ObjCInterfaceDecl *Cls = PT->getObjectType()->getInterface();
    149   if (!Cls)
    150     return false;
    151 
    152   IdentifierInfo* ClsName = Cls->getIdentifier();
    153 
    154   // FIXME: Should we walk the chain of classes?
    155   return ClsName == &Ctx.Idents.get("NSString") ||
    156          ClsName == &Ctx.Idents.get("NSMutableString");
    157 }
    158 
    159 static inline bool isCFStringType(QualType T, ASTContext &Ctx) {
    160   const PointerType *PT = T->getAs<PointerType>();
    161   if (!PT)
    162     return false;
    163 
    164   const RecordType *RT = PT->getPointeeType()->getAs<RecordType>();
    165   if (!RT)
    166     return false;
    167 
    168   const RecordDecl *RD = RT->getDecl();
    169   if (RD->getTagKind() != TTK_Struct)
    170     return false;
    171 
    172   return RD->getIdentifier() == &Ctx.Idents.get("__CFString");
    173 }
    174 
    175 static unsigned getNumAttributeArgs(const AttributeList &Attr) {
    176   // FIXME: Include the type in the argument list.
    177   return Attr.getNumArgs() + Attr.hasParsedType();
    178 }
    179 
    180 template <typename Compare>
    181 static bool checkAttributeNumArgsImpl(Sema &S, const AttributeList &Attr,
    182                                       unsigned Num, unsigned Diag,
    183                                       Compare Comp) {
    184   if (Comp(getNumAttributeArgs(Attr), Num)) {
    185     S.Diag(Attr.getLoc(), Diag) << Attr.getName() << Num;
    186     return false;
    187   }
    188 
    189   return true;
    190 }
    191 
    192 /// \brief Check if the attribute has exactly as many args as Num. May
    193 /// output an error.
    194 static bool checkAttributeNumArgs(Sema &S, const AttributeList &Attr,
    195                                   unsigned Num) {
    196   return checkAttributeNumArgsImpl(S, Attr, Num,
    197                                    diag::err_attribute_wrong_number_arguments,
    198                                    std::not_equal_to<unsigned>());
    199 }
    200 
    201 /// \brief Check if the attribute has at least as many args as Num. May
    202 /// output an error.
    203 static bool checkAttributeAtLeastNumArgs(Sema &S, const AttributeList &Attr,
    204                                          unsigned Num) {
    205   return checkAttributeNumArgsImpl(S, Attr, Num,
    206                                    diag::err_attribute_too_few_arguments,
    207                                    std::less<unsigned>());
    208 }
    209 
    210 /// \brief Check if the attribute has at most as many args as Num. May
    211 /// output an error.
    212 static bool checkAttributeAtMostNumArgs(Sema &S, const AttributeList &Attr,
    213                                          unsigned Num) {
    214   return checkAttributeNumArgsImpl(S, Attr, Num,
    215                                    diag::err_attribute_too_many_arguments,
    216                                    std::greater<unsigned>());
    217 }
    218 
    219 /// \brief If Expr is a valid integer constant, get the value of the integer
    220 /// expression and return success or failure. May output an error.
    221 static bool checkUInt32Argument(Sema &S, const AttributeList &Attr,
    222                                 const Expr *Expr, uint32_t &Val,
    223                                 unsigned Idx = UINT_MAX) {
    224   llvm::APSInt I(32);
    225   if (Expr->isTypeDependent() || Expr->isValueDependent() ||
    226       !Expr->isIntegerConstantExpr(I, S.Context)) {
    227     if (Idx != UINT_MAX)
    228       S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
    229         << Attr.getName() << Idx << AANT_ArgumentIntegerConstant
    230         << Expr->getSourceRange();
    231     else
    232       S.Diag(Attr.getLoc(), diag::err_attribute_argument_type)
    233         << Attr.getName() << AANT_ArgumentIntegerConstant
    234         << Expr->getSourceRange();
    235     return false;
    236   }
    237 
    238   if (!I.isIntN(32)) {
    239     S.Diag(Expr->getExprLoc(), diag::err_ice_too_large)
    240         << I.toString(10, false) << 32 << /* Unsigned */ 1;
    241     return false;
    242   }
    243 
    244   Val = (uint32_t)I.getZExtValue();
    245   return true;
    246 }
    247 
    248 /// \brief Diagnose mutually exclusive attributes when present on a given
    249 /// declaration. Returns true if diagnosed.
    250 template <typename AttrTy>
    251 static bool checkAttrMutualExclusion(Sema &S, Decl *D, SourceRange Range,
    252                                      IdentifierInfo *Ident) {
    253   if (AttrTy *A = D->getAttr<AttrTy>()) {
    254     S.Diag(Range.getBegin(), diag::err_attributes_are_not_compatible) << Ident
    255                                                                       << A;
    256     S.Diag(A->getLocation(), diag::note_conflicting_attribute);
    257     return true;
    258   }
    259   return false;
    260 }
    261 
    262 /// \brief Check if IdxExpr is a valid parameter index for a function or
    263 /// instance method D.  May output an error.
    264 ///
    265 /// \returns true if IdxExpr is a valid index.
    266 static bool checkFunctionOrMethodParameterIndex(Sema &S, const Decl *D,
    267                                                 const AttributeList &Attr,
    268                                                 unsigned AttrArgNum,
    269                                                 const Expr *IdxExpr,
    270                                                 uint64_t &Idx) {
    271   assert(isFunctionOrMethodOrBlock(D));
    272 
    273   // In C++ the implicit 'this' function parameter also counts.
    274   // Parameters are counted from one.
    275   bool HP = hasFunctionProto(D);
    276   bool HasImplicitThisParam = isInstanceMethod(D);
    277   bool IV = HP && isFunctionOrMethodVariadic(D);
    278   unsigned NumParams =
    279       (HP ? getFunctionOrMethodNumParams(D) : 0) + HasImplicitThisParam;
    280 
    281   llvm::APSInt IdxInt;
    282   if (IdxExpr->isTypeDependent() || IdxExpr->isValueDependent() ||
    283       !IdxExpr->isIntegerConstantExpr(IdxInt, S.Context)) {
    284     S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
    285       << Attr.getName() << AttrArgNum << AANT_ArgumentIntegerConstant
    286       << IdxExpr->getSourceRange();
    287     return false;
    288   }
    289 
    290   Idx = IdxInt.getLimitedValue();
    291   if (Idx < 1 || (!IV && Idx > NumParams)) {
    292     S.Diag(Attr.getLoc(), diag::err_attribute_argument_out_of_bounds)
    293       << Attr.getName() << AttrArgNum << IdxExpr->getSourceRange();
    294     return false;
    295   }
    296   Idx--; // Convert to zero-based.
    297   if (HasImplicitThisParam) {
    298     if (Idx == 0) {
    299       S.Diag(Attr.getLoc(),
    300              diag::err_attribute_invalid_implicit_this_argument)
    301         << Attr.getName() << IdxExpr->getSourceRange();
    302       return false;
    303     }
    304     --Idx;
    305   }
    306 
    307   return true;
    308 }
    309 
    310 /// \brief Check if the argument \p ArgNum of \p Attr is a ASCII string literal.
    311 /// If not emit an error and return false. If the argument is an identifier it
    312 /// will emit an error with a fixit hint and treat it as if it was a string
    313 /// literal.
    314 bool Sema::checkStringLiteralArgumentAttr(const AttributeList &Attr,
    315                                           unsigned ArgNum, StringRef &Str,
    316                                           SourceLocation *ArgLocation) {
    317   // Look for identifiers. If we have one emit a hint to fix it to a literal.
    318   if (Attr.isArgIdent(ArgNum)) {
    319     IdentifierLoc *Loc = Attr.getArgAsIdent(ArgNum);
    320     Diag(Loc->Loc, diag::err_attribute_argument_type)
    321         << Attr.getName() << AANT_ArgumentString
    322         << FixItHint::CreateInsertion(Loc->Loc, "\"")
    323         << FixItHint::CreateInsertion(getLocForEndOfToken(Loc->Loc), "\"");
    324     Str = Loc->Ident->getName();
    325     if (ArgLocation)
    326       *ArgLocation = Loc->Loc;
    327     return true;
    328   }
    329 
    330   // Now check for an actual string literal.
    331   Expr *ArgExpr = Attr.getArgAsExpr(ArgNum);
    332   StringLiteral *Literal = dyn_cast<StringLiteral>(ArgExpr->IgnoreParenCasts());
    333   if (ArgLocation)
    334     *ArgLocation = ArgExpr->getLocStart();
    335 
    336   if (!Literal || !Literal->isAscii()) {
    337     Diag(ArgExpr->getLocStart(), diag::err_attribute_argument_type)
    338         << Attr.getName() << AANT_ArgumentString;
    339     return false;
    340   }
    341 
    342   Str = Literal->getString();
    343   return true;
    344 }
    345 
    346 /// \brief Applies the given attribute to the Decl without performing any
    347 /// additional semantic checking.
    348 template <typename AttrType>
    349 static void handleSimpleAttribute(Sema &S, Decl *D,
    350                                   const AttributeList &Attr) {
    351   D->addAttr(::new (S.Context) AttrType(Attr.getRange(), S.Context,
    352                                         Attr.getAttributeSpellingListIndex()));
    353 }
    354 
    355 template <typename AttrType>
    356 static void handleSimpleAttributeWithExclusions(Sema &S, Decl *D,
    357                                                 const AttributeList &Attr) {
    358   handleSimpleAttribute<AttrType>(S, D, Attr);
    359 }
    360 
    361 /// \brief Applies the given attribute to the Decl so long as the Decl doesn't
    362 /// already have one of the given incompatible attributes.
    363 template <typename AttrType, typename IncompatibleAttrType,
    364           typename... IncompatibleAttrTypes>
    365 static void handleSimpleAttributeWithExclusions(Sema &S, Decl *D,
    366                                                 const AttributeList &Attr) {
    367   if (checkAttrMutualExclusion<IncompatibleAttrType>(S, D, Attr.getRange(),
    368                                                      Attr.getName()))
    369     return;
    370   handleSimpleAttributeWithExclusions<AttrType, IncompatibleAttrTypes...>(S, D,
    371                                                                           Attr);
    372 }
    373 
    374 /// \brief Check if the passed-in expression is of type int or bool.
    375 static bool isIntOrBool(Expr *Exp) {
    376   QualType QT = Exp->getType();
    377   return QT->isBooleanType() || QT->isIntegerType();
    378 }
    379 
    380 
    381 // Check to see if the type is a smart pointer of some kind.  We assume
    382 // it's a smart pointer if it defines both operator-> and operator*.
    383 static bool threadSafetyCheckIsSmartPointer(Sema &S, const RecordType* RT) {
    384   DeclContextLookupResult Res1 = RT->getDecl()->lookup(
    385       S.Context.DeclarationNames.getCXXOperatorName(OO_Star));
    386   if (Res1.empty())
    387     return false;
    388 
    389   DeclContextLookupResult Res2 = RT->getDecl()->lookup(
    390       S.Context.DeclarationNames.getCXXOperatorName(OO_Arrow));
    391   if (Res2.empty())
    392     return false;
    393 
    394   return true;
    395 }
    396 
    397 /// \brief Check if passed in Decl is a pointer type.
    398 /// Note that this function may produce an error message.
    399 /// \return true if the Decl is a pointer type; false otherwise
    400 static bool threadSafetyCheckIsPointer(Sema &S, const Decl *D,
    401                                        const AttributeList &Attr) {
    402   const ValueDecl *vd = cast<ValueDecl>(D);
    403   QualType QT = vd->getType();
    404   if (QT->isAnyPointerType())
    405     return true;
    406 
    407   if (const RecordType *RT = QT->getAs<RecordType>()) {
    408     // If it's an incomplete type, it could be a smart pointer; skip it.
    409     // (We don't want to force template instantiation if we can avoid it,
    410     // since that would alter the order in which templates are instantiated.)
    411     if (RT->isIncompleteType())
    412       return true;
    413 
    414     if (threadSafetyCheckIsSmartPointer(S, RT))
    415       return true;
    416   }
    417 
    418   S.Diag(Attr.getLoc(), diag::warn_thread_attribute_decl_not_pointer)
    419     << Attr.getName() << QT;
    420   return false;
    421 }
    422 
    423 /// \brief Checks that the passed in QualType either is of RecordType or points
    424 /// to RecordType. Returns the relevant RecordType, null if it does not exit.
    425 static const RecordType *getRecordType(QualType QT) {
    426   if (const RecordType *RT = QT->getAs<RecordType>())
    427     return RT;
    428 
    429   // Now check if we point to record type.
    430   if (const PointerType *PT = QT->getAs<PointerType>())
    431     return PT->getPointeeType()->getAs<RecordType>();
    432 
    433   return nullptr;
    434 }
    435 
    436 static bool checkRecordTypeForCapability(Sema &S, QualType Ty) {
    437   const RecordType *RT = getRecordType(Ty);
    438 
    439   if (!RT)
    440     return false;
    441 
    442   // Don't check for the capability if the class hasn't been defined yet.
    443   if (RT->isIncompleteType())
    444     return true;
    445 
    446   // Allow smart pointers to be used as capability objects.
    447   // FIXME -- Check the type that the smart pointer points to.
    448   if (threadSafetyCheckIsSmartPointer(S, RT))
    449     return true;
    450 
    451   // Check if the record itself has a capability.
    452   RecordDecl *RD = RT->getDecl();
    453   if (RD->hasAttr<CapabilityAttr>())
    454     return true;
    455 
    456   // Else check if any base classes have a capability.
    457   if (CXXRecordDecl *CRD = dyn_cast<CXXRecordDecl>(RD)) {
    458     CXXBasePaths BPaths(false, false);
    459     if (CRD->lookupInBases([](const CXXBaseSpecifier *BS, CXXBasePath &) {
    460           const auto *Type = BS->getType()->getAs<RecordType>();
    461           return Type->getDecl()->hasAttr<CapabilityAttr>();
    462         }, BPaths))
    463       return true;
    464   }
    465   return false;
    466 }
    467 
    468 static bool checkTypedefTypeForCapability(QualType Ty) {
    469   const auto *TD = Ty->getAs<TypedefType>();
    470   if (!TD)
    471     return false;
    472 
    473   TypedefNameDecl *TN = TD->getDecl();
    474   if (!TN)
    475     return false;
    476 
    477   return TN->hasAttr<CapabilityAttr>();
    478 }
    479 
    480 static bool typeHasCapability(Sema &S, QualType Ty) {
    481   if (checkTypedefTypeForCapability(Ty))
    482     return true;
    483 
    484   if (checkRecordTypeForCapability(S, Ty))
    485     return true;
    486 
    487   return false;
    488 }
    489 
    490 static bool isCapabilityExpr(Sema &S, const Expr *Ex) {
    491   // Capability expressions are simple expressions involving the boolean logic
    492   // operators &&, || or !, a simple DeclRefExpr, CastExpr or a ParenExpr. Once
    493   // a DeclRefExpr is found, its type should be checked to determine whether it
    494   // is a capability or not.
    495 
    496   if (const auto *E = dyn_cast<DeclRefExpr>(Ex))
    497     return typeHasCapability(S, E->getType());
    498   else if (const auto *E = dyn_cast<CastExpr>(Ex))
    499     return isCapabilityExpr(S, E->getSubExpr());
    500   else if (const auto *E = dyn_cast<ParenExpr>(Ex))
    501     return isCapabilityExpr(S, E->getSubExpr());
    502   else if (const auto *E = dyn_cast<UnaryOperator>(Ex)) {
    503     if (E->getOpcode() == UO_LNot)
    504       return isCapabilityExpr(S, E->getSubExpr());
    505     return false;
    506   } else if (const auto *E = dyn_cast<BinaryOperator>(Ex)) {
    507     if (E->getOpcode() == BO_LAnd || E->getOpcode() == BO_LOr)
    508       return isCapabilityExpr(S, E->getLHS()) &&
    509              isCapabilityExpr(S, E->getRHS());
    510     return false;
    511   }
    512 
    513   return false;
    514 }
    515 
    516 /// \brief Checks that all attribute arguments, starting from Sidx, resolve to
    517 /// a capability object.
    518 /// \param Sidx The attribute argument index to start checking with.
    519 /// \param ParamIdxOk Whether an argument can be indexing into a function
    520 /// parameter list.
    521 static void checkAttrArgsAreCapabilityObjs(Sema &S, Decl *D,
    522                                            const AttributeList &Attr,
    523                                            SmallVectorImpl<Expr *> &Args,
    524                                            int Sidx = 0,
    525                                            bool ParamIdxOk = false) {
    526   for (unsigned Idx = Sidx; Idx < Attr.getNumArgs(); ++Idx) {
    527     Expr *ArgExp = Attr.getArgAsExpr(Idx);
    528 
    529     if (ArgExp->isTypeDependent()) {
    530       // FIXME -- need to check this again on template instantiation
    531       Args.push_back(ArgExp);
    532       continue;
    533     }
    534 
    535     if (StringLiteral *StrLit = dyn_cast<StringLiteral>(ArgExp)) {
    536       if (StrLit->getLength() == 0 ||
    537           (StrLit->isAscii() && StrLit->getString() == StringRef("*"))) {
    538         // Pass empty strings to the analyzer without warnings.
    539         // Treat "*" as the universal lock.
    540         Args.push_back(ArgExp);
    541         continue;
    542       }
    543 
    544       // We allow constant strings to be used as a placeholder for expressions
    545       // that are not valid C++ syntax, but warn that they are ignored.
    546       S.Diag(Attr.getLoc(), diag::warn_thread_attribute_ignored) <<
    547         Attr.getName();
    548       Args.push_back(ArgExp);
    549       continue;
    550     }
    551 
    552     QualType ArgTy = ArgExp->getType();
    553 
    554     // A pointer to member expression of the form  &MyClass::mu is treated
    555     // specially -- we need to look at the type of the member.
    556     if (UnaryOperator *UOp = dyn_cast<UnaryOperator>(ArgExp))
    557       if (UOp->getOpcode() == UO_AddrOf)
    558         if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(UOp->getSubExpr()))
    559           if (DRE->getDecl()->isCXXInstanceMember())
    560             ArgTy = DRE->getDecl()->getType();
    561 
    562     // First see if we can just cast to record type, or pointer to record type.
    563     const RecordType *RT = getRecordType(ArgTy);
    564 
    565     // Now check if we index into a record type function param.
    566     if(!RT && ParamIdxOk) {
    567       FunctionDecl *FD = dyn_cast<FunctionDecl>(D);
    568       IntegerLiteral *IL = dyn_cast<IntegerLiteral>(ArgExp);
    569       if(FD && IL) {
    570         unsigned int NumParams = FD->getNumParams();
    571         llvm::APInt ArgValue = IL->getValue();
    572         uint64_t ParamIdxFromOne = ArgValue.getZExtValue();
    573         uint64_t ParamIdxFromZero = ParamIdxFromOne - 1;
    574         if(!ArgValue.isStrictlyPositive() || ParamIdxFromOne > NumParams) {
    575           S.Diag(Attr.getLoc(), diag::err_attribute_argument_out_of_range)
    576             << Attr.getName() << Idx + 1 << NumParams;
    577           continue;
    578         }
    579         ArgTy = FD->getParamDecl(ParamIdxFromZero)->getType();
    580       }
    581     }
    582 
    583     // If the type does not have a capability, see if the components of the
    584     // expression have capabilities. This allows for writing C code where the
    585     // capability may be on the type, and the expression is a capability
    586     // boolean logic expression. Eg) requires_capability(A || B && !C)
    587     if (!typeHasCapability(S, ArgTy) && !isCapabilityExpr(S, ArgExp))
    588       S.Diag(Attr.getLoc(), diag::warn_thread_attribute_argument_not_lockable)
    589           << Attr.getName() << ArgTy;
    590 
    591     Args.push_back(ArgExp);
    592   }
    593 }
    594 
    595 //===----------------------------------------------------------------------===//
    596 // Attribute Implementations
    597 //===----------------------------------------------------------------------===//
    598 
    599 static void handlePtGuardedVarAttr(Sema &S, Decl *D,
    600                                    const AttributeList &Attr) {
    601   if (!threadSafetyCheckIsPointer(S, D, Attr))
    602     return;
    603 
    604   D->addAttr(::new (S.Context)
    605              PtGuardedVarAttr(Attr.getRange(), S.Context,
    606                               Attr.getAttributeSpellingListIndex()));
    607 }
    608 
    609 static bool checkGuardedByAttrCommon(Sema &S, Decl *D,
    610                                      const AttributeList &Attr,
    611                                      Expr* &Arg) {
    612   SmallVector<Expr*, 1> Args;
    613   // check that all arguments are lockable objects
    614   checkAttrArgsAreCapabilityObjs(S, D, Attr, Args);
    615   unsigned Size = Args.size();
    616   if (Size != 1)
    617     return false;
    618 
    619   Arg = Args[0];
    620 
    621   return true;
    622 }
    623 
    624 static void handleGuardedByAttr(Sema &S, Decl *D, const AttributeList &Attr) {
    625   Expr *Arg = nullptr;
    626   if (!checkGuardedByAttrCommon(S, D, Attr, Arg))
    627     return;
    628 
    629   D->addAttr(::new (S.Context) GuardedByAttr(Attr.getRange(), S.Context, Arg,
    630                                         Attr.getAttributeSpellingListIndex()));
    631 }
    632 
    633 static void handlePtGuardedByAttr(Sema &S, Decl *D,
    634                                   const AttributeList &Attr) {
    635   Expr *Arg = nullptr;
    636   if (!checkGuardedByAttrCommon(S, D, Attr, Arg))
    637     return;
    638 
    639   if (!threadSafetyCheckIsPointer(S, D, Attr))
    640     return;
    641 
    642   D->addAttr(::new (S.Context) PtGuardedByAttr(Attr.getRange(),
    643                                                S.Context, Arg,
    644                                         Attr.getAttributeSpellingListIndex()));
    645 }
    646 
    647 static bool checkAcquireOrderAttrCommon(Sema &S, Decl *D,
    648                                         const AttributeList &Attr,
    649                                         SmallVectorImpl<Expr *> &Args) {
    650   if (!checkAttributeAtLeastNumArgs(S, Attr, 1))
    651     return false;
    652 
    653   // Check that this attribute only applies to lockable types.
    654   QualType QT = cast<ValueDecl>(D)->getType();
    655   if (!QT->isDependentType() && !typeHasCapability(S, QT)) {
    656     S.Diag(Attr.getLoc(), diag::warn_thread_attribute_decl_not_lockable)
    657       << Attr.getName();
    658     return false;
    659   }
    660 
    661   // Check that all arguments are lockable objects.
    662   checkAttrArgsAreCapabilityObjs(S, D, Attr, Args);
    663   if (Args.empty())
    664     return false;
    665 
    666   return true;
    667 }
    668 
    669 static void handleAcquiredAfterAttr(Sema &S, Decl *D,
    670                                     const AttributeList &Attr) {
    671   SmallVector<Expr*, 1> Args;
    672   if (!checkAcquireOrderAttrCommon(S, D, Attr, Args))
    673     return;
    674 
    675   Expr **StartArg = &Args[0];
    676   D->addAttr(::new (S.Context)
    677              AcquiredAfterAttr(Attr.getRange(), S.Context,
    678                                StartArg, Args.size(),
    679                                Attr.getAttributeSpellingListIndex()));
    680 }
    681 
    682 static void handleAcquiredBeforeAttr(Sema &S, Decl *D,
    683                                      const AttributeList &Attr) {
    684   SmallVector<Expr*, 1> Args;
    685   if (!checkAcquireOrderAttrCommon(S, D, Attr, Args))
    686     return;
    687 
    688   Expr **StartArg = &Args[0];
    689   D->addAttr(::new (S.Context)
    690              AcquiredBeforeAttr(Attr.getRange(), S.Context,
    691                                 StartArg, Args.size(),
    692                                 Attr.getAttributeSpellingListIndex()));
    693 }
    694 
    695 static bool checkLockFunAttrCommon(Sema &S, Decl *D,
    696                                    const AttributeList &Attr,
    697                                    SmallVectorImpl<Expr *> &Args) {
    698   // zero or more arguments ok
    699   // check that all arguments are lockable objects
    700   checkAttrArgsAreCapabilityObjs(S, D, Attr, Args, 0, /*ParamIdxOk=*/true);
    701 
    702   return true;
    703 }
    704 
    705 static void handleAssertSharedLockAttr(Sema &S, Decl *D,
    706                                        const AttributeList &Attr) {
    707   SmallVector<Expr*, 1> Args;
    708   if (!checkLockFunAttrCommon(S, D, Attr, Args))
    709     return;
    710 
    711   unsigned Size = Args.size();
    712   Expr **StartArg = Size == 0 ? nullptr : &Args[0];
    713   D->addAttr(::new (S.Context)
    714              AssertSharedLockAttr(Attr.getRange(), S.Context, StartArg, Size,
    715                                   Attr.getAttributeSpellingListIndex()));
    716 }
    717 
    718 static void handleAssertExclusiveLockAttr(Sema &S, Decl *D,
    719                                           const AttributeList &Attr) {
    720   SmallVector<Expr*, 1> Args;
    721   if (!checkLockFunAttrCommon(S, D, Attr, Args))
    722     return;
    723 
    724   unsigned Size = Args.size();
    725   Expr **StartArg = Size == 0 ? nullptr : &Args[0];
    726   D->addAttr(::new (S.Context)
    727              AssertExclusiveLockAttr(Attr.getRange(), S.Context,
    728                                      StartArg, Size,
    729                                      Attr.getAttributeSpellingListIndex()));
    730 }
    731 
    732 
    733 static bool checkTryLockFunAttrCommon(Sema &S, Decl *D,
    734                                       const AttributeList &Attr,
    735                                       SmallVectorImpl<Expr *> &Args) {
    736   if (!checkAttributeAtLeastNumArgs(S, Attr, 1))
    737     return false;
    738 
    739   if (!isIntOrBool(Attr.getArgAsExpr(0))) {
    740     S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
    741       << Attr.getName() << 1 << AANT_ArgumentIntOrBool;
    742     return false;
    743   }
    744 
    745   // check that all arguments are lockable objects
    746   checkAttrArgsAreCapabilityObjs(S, D, Attr, Args, 1);
    747 
    748   return true;
    749 }
    750 
    751 static void handleSharedTrylockFunctionAttr(Sema &S, Decl *D,
    752                                             const AttributeList &Attr) {
    753   SmallVector<Expr*, 2> Args;
    754   if (!checkTryLockFunAttrCommon(S, D, Attr, Args))
    755     return;
    756 
    757   D->addAttr(::new (S.Context)
    758              SharedTrylockFunctionAttr(Attr.getRange(), S.Context,
    759                                        Attr.getArgAsExpr(0),
    760                                        Args.data(), Args.size(),
    761                                        Attr.getAttributeSpellingListIndex()));
    762 }
    763 
    764 static void handleExclusiveTrylockFunctionAttr(Sema &S, Decl *D,
    765                                                const AttributeList &Attr) {
    766   SmallVector<Expr*, 2> Args;
    767   if (!checkTryLockFunAttrCommon(S, D, Attr, Args))
    768     return;
    769 
    770   D->addAttr(::new (S.Context) ExclusiveTrylockFunctionAttr(
    771       Attr.getRange(), S.Context, Attr.getArgAsExpr(0), Args.data(),
    772       Args.size(), Attr.getAttributeSpellingListIndex()));
    773 }
    774 
    775 static void handleLockReturnedAttr(Sema &S, Decl *D,
    776                                    const AttributeList &Attr) {
    777   // check that the argument is lockable object
    778   SmallVector<Expr*, 1> Args;
    779   checkAttrArgsAreCapabilityObjs(S, D, Attr, Args);
    780   unsigned Size = Args.size();
    781   if (Size == 0)
    782     return;
    783 
    784   D->addAttr(::new (S.Context)
    785              LockReturnedAttr(Attr.getRange(), S.Context, Args[0],
    786                               Attr.getAttributeSpellingListIndex()));
    787 }
    788 
    789 static void handleLocksExcludedAttr(Sema &S, Decl *D,
    790                                     const AttributeList &Attr) {
    791   if (!checkAttributeAtLeastNumArgs(S, Attr, 1))
    792     return;
    793 
    794   // check that all arguments are lockable objects
    795   SmallVector<Expr*, 1> Args;
    796   checkAttrArgsAreCapabilityObjs(S, D, Attr, Args);
    797   unsigned Size = Args.size();
    798   if (Size == 0)
    799     return;
    800   Expr **StartArg = &Args[0];
    801 
    802   D->addAttr(::new (S.Context)
    803              LocksExcludedAttr(Attr.getRange(), S.Context, StartArg, Size,
    804                                Attr.getAttributeSpellingListIndex()));
    805 }
    806 
    807 static void handleEnableIfAttr(Sema &S, Decl *D, const AttributeList &Attr) {
    808   S.Diag(Attr.getLoc(), diag::ext_clang_enable_if);
    809 
    810   Expr *Cond = Attr.getArgAsExpr(0);
    811   if (!Cond->isTypeDependent()) {
    812     ExprResult Converted = S.PerformContextuallyConvertToBool(Cond);
    813     if (Converted.isInvalid())
    814       return;
    815     Cond = Converted.get();
    816   }
    817 
    818   StringRef Msg;
    819   if (!S.checkStringLiteralArgumentAttr(Attr, 1, Msg))
    820     return;
    821 
    822   SmallVector<PartialDiagnosticAt, 8> Diags;
    823   if (!Cond->isValueDependent() &&
    824       !Expr::isPotentialConstantExprUnevaluated(Cond, cast<FunctionDecl>(D),
    825                                                 Diags)) {
    826     S.Diag(Attr.getLoc(), diag::err_enable_if_never_constant_expr);
    827     for (int I = 0, N = Diags.size(); I != N; ++I)
    828       S.Diag(Diags[I].first, Diags[I].second);
    829     return;
    830   }
    831 
    832   D->addAttr(::new (S.Context)
    833              EnableIfAttr(Attr.getRange(), S.Context, Cond, Msg,
    834                           Attr.getAttributeSpellingListIndex()));
    835 }
    836 
    837 static void handlePassObjectSizeAttr(Sema &S, Decl *D,
    838                                      const AttributeList &Attr) {
    839   if (D->hasAttr<PassObjectSizeAttr>()) {
    840     S.Diag(D->getLocStart(), diag::err_attribute_only_once_per_parameter)
    841         << Attr.getName();
    842     return;
    843   }
    844 
    845   Expr *E = Attr.getArgAsExpr(0);
    846   uint32_t Type;
    847   if (!checkUInt32Argument(S, Attr, E, Type, /*Idx=*/1))
    848     return;
    849 
    850   // pass_object_size's argument is passed in as the second argument of
    851   // __builtin_object_size. So, it has the same constraints as that second
    852   // argument; namely, it must be in the range [0, 3].
    853   if (Type > 3) {
    854     S.Diag(E->getLocStart(), diag::err_attribute_argument_outof_range)
    855         << Attr.getName() << 0 << 3 << E->getSourceRange();
    856     return;
    857   }
    858 
    859   // pass_object_size is only supported on constant pointer parameters; as a
    860   // kindness to users, we allow the parameter to be non-const for declarations.
    861   // At this point, we have no clue if `D` belongs to a function declaration or
    862   // definition, so we defer the constness check until later.
    863   if (!cast<ParmVarDecl>(D)->getType()->isPointerType()) {
    864     S.Diag(D->getLocStart(), diag::err_attribute_pointers_only)
    865         << Attr.getName() << 1;
    866     return;
    867   }
    868 
    869   D->addAttr(::new (S.Context)
    870                  PassObjectSizeAttr(Attr.getRange(), S.Context, (int)Type,
    871                                     Attr.getAttributeSpellingListIndex()));
    872 }
    873 
    874 static void handleConsumableAttr(Sema &S, Decl *D, const AttributeList &Attr) {
    875   ConsumableAttr::ConsumedState DefaultState;
    876 
    877   if (Attr.isArgIdent(0)) {
    878     IdentifierLoc *IL = Attr.getArgAsIdent(0);
    879     if (!ConsumableAttr::ConvertStrToConsumedState(IL->Ident->getName(),
    880                                                    DefaultState)) {
    881       S.Diag(IL->Loc, diag::warn_attribute_type_not_supported)
    882         << Attr.getName() << IL->Ident;
    883       return;
    884     }
    885   } else {
    886     S.Diag(Attr.getLoc(), diag::err_attribute_argument_type)
    887         << Attr.getName() << AANT_ArgumentIdentifier;
    888     return;
    889   }
    890 
    891   D->addAttr(::new (S.Context)
    892              ConsumableAttr(Attr.getRange(), S.Context, DefaultState,
    893                             Attr.getAttributeSpellingListIndex()));
    894 }
    895 
    896 static bool checkForConsumableClass(Sema &S, const CXXMethodDecl *MD,
    897                                         const AttributeList &Attr) {
    898   ASTContext &CurrContext = S.getASTContext();
    899   QualType ThisType = MD->getThisType(CurrContext)->getPointeeType();
    900 
    901   if (const CXXRecordDecl *RD = ThisType->getAsCXXRecordDecl()) {
    902     if (!RD->hasAttr<ConsumableAttr>()) {
    903       S.Diag(Attr.getLoc(), diag::warn_attr_on_unconsumable_class) <<
    904         RD->getNameAsString();
    905 
    906       return false;
    907     }
    908   }
    909 
    910   return true;
    911 }
    912 
    913 static void handleCallableWhenAttr(Sema &S, Decl *D,
    914                                    const AttributeList &Attr) {
    915   if (!checkAttributeAtLeastNumArgs(S, Attr, 1))
    916     return;
    917 
    918   if (!checkForConsumableClass(S, cast<CXXMethodDecl>(D), Attr))
    919     return;
    920 
    921   SmallVector<CallableWhenAttr::ConsumedState, 3> States;
    922   for (unsigned ArgIndex = 0; ArgIndex < Attr.getNumArgs(); ++ArgIndex) {
    923     CallableWhenAttr::ConsumedState CallableState;
    924 
    925     StringRef StateString;
    926     SourceLocation Loc;
    927     if (Attr.isArgIdent(ArgIndex)) {
    928       IdentifierLoc *Ident = Attr.getArgAsIdent(ArgIndex);
    929       StateString = Ident->Ident->getName();
    930       Loc = Ident->Loc;
    931     } else {
    932       if (!S.checkStringLiteralArgumentAttr(Attr, ArgIndex, StateString, &Loc))
    933         return;
    934     }
    935 
    936     if (!CallableWhenAttr::ConvertStrToConsumedState(StateString,
    937                                                      CallableState)) {
    938       S.Diag(Loc, diag::warn_attribute_type_not_supported)
    939         << Attr.getName() << StateString;
    940       return;
    941     }
    942 
    943     States.push_back(CallableState);
    944   }
    945 
    946   D->addAttr(::new (S.Context)
    947              CallableWhenAttr(Attr.getRange(), S.Context, States.data(),
    948                States.size(), Attr.getAttributeSpellingListIndex()));
    949 }
    950 
    951 static void handleParamTypestateAttr(Sema &S, Decl *D,
    952                                     const AttributeList &Attr) {
    953   ParamTypestateAttr::ConsumedState ParamState;
    954 
    955   if (Attr.isArgIdent(0)) {
    956     IdentifierLoc *Ident = Attr.getArgAsIdent(0);
    957     StringRef StateString = Ident->Ident->getName();
    958 
    959     if (!ParamTypestateAttr::ConvertStrToConsumedState(StateString,
    960                                                        ParamState)) {
    961       S.Diag(Ident->Loc, diag::warn_attribute_type_not_supported)
    962         << Attr.getName() << StateString;
    963       return;
    964     }
    965   } else {
    966     S.Diag(Attr.getLoc(), diag::err_attribute_argument_type) <<
    967       Attr.getName() << AANT_ArgumentIdentifier;
    968     return;
    969   }
    970 
    971   // FIXME: This check is currently being done in the analysis.  It can be
    972   //        enabled here only after the parser propagates attributes at
    973   //        template specialization definition, not declaration.
    974   //QualType ReturnType = cast<ParmVarDecl>(D)->getType();
    975   //const CXXRecordDecl *RD = ReturnType->getAsCXXRecordDecl();
    976   //
    977   //if (!RD || !RD->hasAttr<ConsumableAttr>()) {
    978   //    S.Diag(Attr.getLoc(), diag::warn_return_state_for_unconsumable_type) <<
    979   //      ReturnType.getAsString();
    980   //    return;
    981   //}
    982 
    983   D->addAttr(::new (S.Context)
    984              ParamTypestateAttr(Attr.getRange(), S.Context, ParamState,
    985                                 Attr.getAttributeSpellingListIndex()));
    986 }
    987 
    988 static void handleReturnTypestateAttr(Sema &S, Decl *D,
    989                                       const AttributeList &Attr) {
    990   ReturnTypestateAttr::ConsumedState ReturnState;
    991 
    992   if (Attr.isArgIdent(0)) {
    993     IdentifierLoc *IL = Attr.getArgAsIdent(0);
    994     if (!ReturnTypestateAttr::ConvertStrToConsumedState(IL->Ident->getName(),
    995                                                         ReturnState)) {
    996       S.Diag(IL->Loc, diag::warn_attribute_type_not_supported)
    997         << Attr.getName() << IL->Ident;
    998       return;
    999     }
   1000   } else {
   1001     S.Diag(Attr.getLoc(), diag::err_attribute_argument_type) <<
   1002       Attr.getName() << AANT_ArgumentIdentifier;
   1003     return;
   1004   }
   1005 
   1006   // FIXME: This check is currently being done in the analysis.  It can be
   1007   //        enabled here only after the parser propagates attributes at
   1008   //        template specialization definition, not declaration.
   1009   //QualType ReturnType;
   1010   //
   1011   //if (const ParmVarDecl *Param = dyn_cast<ParmVarDecl>(D)) {
   1012   //  ReturnType = Param->getType();
   1013   //
   1014   //} else if (const CXXConstructorDecl *Constructor =
   1015   //             dyn_cast<CXXConstructorDecl>(D)) {
   1016   //  ReturnType = Constructor->getThisType(S.getASTContext())->getPointeeType();
   1017   //
   1018   //} else {
   1019   //
   1020   //  ReturnType = cast<FunctionDecl>(D)->getCallResultType();
   1021   //}
   1022   //
   1023   //const CXXRecordDecl *RD = ReturnType->getAsCXXRecordDecl();
   1024   //
   1025   //if (!RD || !RD->hasAttr<ConsumableAttr>()) {
   1026   //    S.Diag(Attr.getLoc(), diag::warn_return_state_for_unconsumable_type) <<
   1027   //      ReturnType.getAsString();
   1028   //    return;
   1029   //}
   1030 
   1031   D->addAttr(::new (S.Context)
   1032              ReturnTypestateAttr(Attr.getRange(), S.Context, ReturnState,
   1033                                  Attr.getAttributeSpellingListIndex()));
   1034 }
   1035 
   1036 static void handleSetTypestateAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1037   if (!checkForConsumableClass(S, cast<CXXMethodDecl>(D), Attr))
   1038     return;
   1039 
   1040   SetTypestateAttr::ConsumedState NewState;
   1041   if (Attr.isArgIdent(0)) {
   1042     IdentifierLoc *Ident = Attr.getArgAsIdent(0);
   1043     StringRef Param = Ident->Ident->getName();
   1044     if (!SetTypestateAttr::ConvertStrToConsumedState(Param, NewState)) {
   1045       S.Diag(Ident->Loc, diag::warn_attribute_type_not_supported)
   1046         << Attr.getName() << Param;
   1047       return;
   1048     }
   1049   } else {
   1050     S.Diag(Attr.getLoc(), diag::err_attribute_argument_type) <<
   1051       Attr.getName() << AANT_ArgumentIdentifier;
   1052     return;
   1053   }
   1054 
   1055   D->addAttr(::new (S.Context)
   1056              SetTypestateAttr(Attr.getRange(), S.Context, NewState,
   1057                               Attr.getAttributeSpellingListIndex()));
   1058 }
   1059 
   1060 static void handleTestTypestateAttr(Sema &S, Decl *D,
   1061                                     const AttributeList &Attr) {
   1062   if (!checkForConsumableClass(S, cast<CXXMethodDecl>(D), Attr))
   1063     return;
   1064 
   1065   TestTypestateAttr::ConsumedState TestState;
   1066   if (Attr.isArgIdent(0)) {
   1067     IdentifierLoc *Ident = Attr.getArgAsIdent(0);
   1068     StringRef Param = Ident->Ident->getName();
   1069     if (!TestTypestateAttr::ConvertStrToConsumedState(Param, TestState)) {
   1070       S.Diag(Ident->Loc, diag::warn_attribute_type_not_supported)
   1071         << Attr.getName() << Param;
   1072       return;
   1073     }
   1074   } else {
   1075     S.Diag(Attr.getLoc(), diag::err_attribute_argument_type) <<
   1076       Attr.getName() << AANT_ArgumentIdentifier;
   1077     return;
   1078   }
   1079 
   1080   D->addAttr(::new (S.Context)
   1081              TestTypestateAttr(Attr.getRange(), S.Context, TestState,
   1082                                 Attr.getAttributeSpellingListIndex()));
   1083 }
   1084 
   1085 static void handleExtVectorTypeAttr(Sema &S, Scope *scope, Decl *D,
   1086                                     const AttributeList &Attr) {
   1087   // Remember this typedef decl, we will need it later for diagnostics.
   1088   S.ExtVectorDecls.push_back(cast<TypedefNameDecl>(D));
   1089 }
   1090 
   1091 static void handlePackedAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1092   if (TagDecl *TD = dyn_cast<TagDecl>(D))
   1093     TD->addAttr(::new (S.Context) PackedAttr(Attr.getRange(), S.Context,
   1094                                         Attr.getAttributeSpellingListIndex()));
   1095   else if (FieldDecl *FD = dyn_cast<FieldDecl>(D)) {
   1096     // Report warning about changed offset in the newer compiler versions.
   1097     if (!FD->getType()->isDependentType() &&
   1098         !FD->getType()->isIncompleteType() && FD->isBitField() &&
   1099         S.Context.getTypeAlign(FD->getType()) <= 8)
   1100       S.Diag(Attr.getLoc(), diag::warn_attribute_packed_for_bitfield);
   1101 
   1102     FD->addAttr(::new (S.Context) PackedAttr(
   1103         Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   1104   } else
   1105     S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName();
   1106 }
   1107 
   1108 static bool checkIBOutletCommon(Sema &S, Decl *D, const AttributeList &Attr) {
   1109   // The IBOutlet/IBOutletCollection attributes only apply to instance
   1110   // variables or properties of Objective-C classes.  The outlet must also
   1111   // have an object reference type.
   1112   if (const ObjCIvarDecl *VD = dyn_cast<ObjCIvarDecl>(D)) {
   1113     if (!VD->getType()->getAs<ObjCObjectPointerType>()) {
   1114       S.Diag(Attr.getLoc(), diag::warn_iboutlet_object_type)
   1115         << Attr.getName() << VD->getType() << 0;
   1116       return false;
   1117     }
   1118   }
   1119   else if (const ObjCPropertyDecl *PD = dyn_cast<ObjCPropertyDecl>(D)) {
   1120     if (!PD->getType()->getAs<ObjCObjectPointerType>()) {
   1121       S.Diag(Attr.getLoc(), diag::warn_iboutlet_object_type)
   1122         << Attr.getName() << PD->getType() << 1;
   1123       return false;
   1124     }
   1125   }
   1126   else {
   1127     S.Diag(Attr.getLoc(), diag::warn_attribute_iboutlet) << Attr.getName();
   1128     return false;
   1129   }
   1130 
   1131   return true;
   1132 }
   1133 
   1134 static void handleIBOutlet(Sema &S, Decl *D, const AttributeList &Attr) {
   1135   if (!checkIBOutletCommon(S, D, Attr))
   1136     return;
   1137 
   1138   D->addAttr(::new (S.Context)
   1139              IBOutletAttr(Attr.getRange(), S.Context,
   1140                           Attr.getAttributeSpellingListIndex()));
   1141 }
   1142 
   1143 static void handleIBOutletCollection(Sema &S, Decl *D,
   1144                                      const AttributeList &Attr) {
   1145 
   1146   // The iboutletcollection attribute can have zero or one arguments.
   1147   if (Attr.getNumArgs() > 1) {
   1148     S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments)
   1149       << Attr.getName() << 1;
   1150     return;
   1151   }
   1152 
   1153   if (!checkIBOutletCommon(S, D, Attr))
   1154     return;
   1155 
   1156   ParsedType PT;
   1157 
   1158   if (Attr.hasParsedType())
   1159     PT = Attr.getTypeArg();
   1160   else {
   1161     PT = S.getTypeName(S.Context.Idents.get("NSObject"), Attr.getLoc(),
   1162                        S.getScopeForContext(D->getDeclContext()->getParent()));
   1163     if (!PT) {
   1164       S.Diag(Attr.getLoc(), diag::err_iboutletcollection_type) << "NSObject";
   1165       return;
   1166     }
   1167   }
   1168 
   1169   TypeSourceInfo *QTLoc = nullptr;
   1170   QualType QT = S.GetTypeFromParser(PT, &QTLoc);
   1171   if (!QTLoc)
   1172     QTLoc = S.Context.getTrivialTypeSourceInfo(QT, Attr.getLoc());
   1173 
   1174   // Diagnose use of non-object type in iboutletcollection attribute.
   1175   // FIXME. Gnu attribute extension ignores use of builtin types in
   1176   // attributes. So, __attribute__((iboutletcollection(char))) will be
   1177   // treated as __attribute__((iboutletcollection())).
   1178   if (!QT->isObjCIdType() && !QT->isObjCObjectType()) {
   1179     S.Diag(Attr.getLoc(),
   1180            QT->isBuiltinType() ? diag::err_iboutletcollection_builtintype
   1181                                : diag::err_iboutletcollection_type) << QT;
   1182     return;
   1183   }
   1184 
   1185   D->addAttr(::new (S.Context)
   1186              IBOutletCollectionAttr(Attr.getRange(), S.Context, QTLoc,
   1187                                     Attr.getAttributeSpellingListIndex()));
   1188 }
   1189 
   1190 bool Sema::isValidPointerAttrType(QualType T, bool RefOkay) {
   1191   if (RefOkay) {
   1192     if (T->isReferenceType())
   1193       return true;
   1194   } else {
   1195     T = T.getNonReferenceType();
   1196   }
   1197 
   1198   // The nonnull attribute, and other similar attributes, can be applied to a
   1199   // transparent union that contains a pointer type.
   1200   if (const RecordType *UT = T->getAsUnionType()) {
   1201     if (UT && UT->getDecl()->hasAttr<TransparentUnionAttr>()) {
   1202       RecordDecl *UD = UT->getDecl();
   1203       for (const auto *I : UD->fields()) {
   1204         QualType QT = I->getType();
   1205         if (QT->isAnyPointerType() || QT->isBlockPointerType())
   1206           return true;
   1207       }
   1208     }
   1209   }
   1210 
   1211   return T->isAnyPointerType() || T->isBlockPointerType();
   1212 }
   1213 
   1214 static bool attrNonNullArgCheck(Sema &S, QualType T, const AttributeList &Attr,
   1215                                 SourceRange AttrParmRange,
   1216                                 SourceRange TypeRange,
   1217                                 bool isReturnValue = false) {
   1218   if (!S.isValidPointerAttrType(T)) {
   1219     if (isReturnValue)
   1220       S.Diag(Attr.getLoc(), diag::warn_attribute_return_pointers_only)
   1221           << Attr.getName() << AttrParmRange << TypeRange;
   1222     else
   1223       S.Diag(Attr.getLoc(), diag::warn_attribute_pointers_only)
   1224           << Attr.getName() << AttrParmRange << TypeRange << 0;
   1225     return false;
   1226   }
   1227   return true;
   1228 }
   1229 
   1230 static void handleNonNullAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1231   SmallVector<unsigned, 8> NonNullArgs;
   1232   for (unsigned I = 0; I < Attr.getNumArgs(); ++I) {
   1233     Expr *Ex = Attr.getArgAsExpr(I);
   1234     uint64_t Idx;
   1235     if (!checkFunctionOrMethodParameterIndex(S, D, Attr, I + 1, Ex, Idx))
   1236       return;
   1237 
   1238     // Is the function argument a pointer type?
   1239     if (Idx < getFunctionOrMethodNumParams(D) &&
   1240         !attrNonNullArgCheck(S, getFunctionOrMethodParamType(D, Idx), Attr,
   1241                              Ex->getSourceRange(),
   1242                              getFunctionOrMethodParamRange(D, Idx)))
   1243       continue;
   1244 
   1245     NonNullArgs.push_back(Idx);
   1246   }
   1247 
   1248   // If no arguments were specified to __attribute__((nonnull)) then all pointer
   1249   // arguments have a nonnull attribute; warn if there aren't any. Skip this
   1250   // check if the attribute came from a macro expansion or a template
   1251   // instantiation.
   1252   if (NonNullArgs.empty() && Attr.getLoc().isFileID() &&
   1253       S.ActiveTemplateInstantiations.empty()) {
   1254     bool AnyPointers = isFunctionOrMethodVariadic(D);
   1255     for (unsigned I = 0, E = getFunctionOrMethodNumParams(D);
   1256          I != E && !AnyPointers; ++I) {
   1257       QualType T = getFunctionOrMethodParamType(D, I);
   1258       if (T->isDependentType() || S.isValidPointerAttrType(T))
   1259         AnyPointers = true;
   1260     }
   1261 
   1262     if (!AnyPointers)
   1263       S.Diag(Attr.getLoc(), diag::warn_attribute_nonnull_no_pointers);
   1264   }
   1265 
   1266   unsigned *Start = NonNullArgs.data();
   1267   unsigned Size = NonNullArgs.size();
   1268   llvm::array_pod_sort(Start, Start + Size);
   1269   D->addAttr(::new (S.Context)
   1270              NonNullAttr(Attr.getRange(), S.Context, Start, Size,
   1271                          Attr.getAttributeSpellingListIndex()));
   1272 }
   1273 
   1274 static void handleNonNullAttrParameter(Sema &S, ParmVarDecl *D,
   1275                                        const AttributeList &Attr) {
   1276   if (Attr.getNumArgs() > 0) {
   1277     if (D->getFunctionType()) {
   1278       handleNonNullAttr(S, D, Attr);
   1279     } else {
   1280       S.Diag(Attr.getLoc(), diag::warn_attribute_nonnull_parm_no_args)
   1281         << D->getSourceRange();
   1282     }
   1283     return;
   1284   }
   1285 
   1286   // Is the argument a pointer type?
   1287   if (!attrNonNullArgCheck(S, D->getType(), Attr, SourceRange(),
   1288                            D->getSourceRange()))
   1289     return;
   1290 
   1291   D->addAttr(::new (S.Context)
   1292              NonNullAttr(Attr.getRange(), S.Context, nullptr, 0,
   1293                          Attr.getAttributeSpellingListIndex()));
   1294 }
   1295 
   1296 static void handleReturnsNonNullAttr(Sema &S, Decl *D,
   1297                                      const AttributeList &Attr) {
   1298   QualType ResultType = getFunctionOrMethodResultType(D);
   1299   SourceRange SR = getFunctionOrMethodResultSourceRange(D);
   1300   if (!attrNonNullArgCheck(S, ResultType, Attr, SourceRange(), SR,
   1301                            /* isReturnValue */ true))
   1302     return;
   1303 
   1304   D->addAttr(::new (S.Context)
   1305             ReturnsNonNullAttr(Attr.getRange(), S.Context,
   1306                                Attr.getAttributeSpellingListIndex()));
   1307 }
   1308 
   1309 static void handleAssumeAlignedAttr(Sema &S, Decl *D,
   1310                                     const AttributeList &Attr) {
   1311   Expr *E = Attr.getArgAsExpr(0),
   1312        *OE = Attr.getNumArgs() > 1 ? Attr.getArgAsExpr(1) : nullptr;
   1313   S.AddAssumeAlignedAttr(Attr.getRange(), D, E, OE,
   1314                          Attr.getAttributeSpellingListIndex());
   1315 }
   1316 
   1317 void Sema::AddAssumeAlignedAttr(SourceRange AttrRange, Decl *D, Expr *E,
   1318                                 Expr *OE, unsigned SpellingListIndex) {
   1319   QualType ResultType = getFunctionOrMethodResultType(D);
   1320   SourceRange SR = getFunctionOrMethodResultSourceRange(D);
   1321 
   1322   AssumeAlignedAttr TmpAttr(AttrRange, Context, E, OE, SpellingListIndex);
   1323   SourceLocation AttrLoc = AttrRange.getBegin();
   1324 
   1325   if (!isValidPointerAttrType(ResultType, /* RefOkay */ true)) {
   1326     Diag(AttrLoc, diag::warn_attribute_return_pointers_refs_only)
   1327       << &TmpAttr << AttrRange << SR;
   1328     return;
   1329   }
   1330 
   1331   if (!E->isValueDependent()) {
   1332     llvm::APSInt I(64);
   1333     if (!E->isIntegerConstantExpr(I, Context)) {
   1334       if (OE)
   1335         Diag(AttrLoc, diag::err_attribute_argument_n_type)
   1336           << &TmpAttr << 1 << AANT_ArgumentIntegerConstant
   1337           << E->getSourceRange();
   1338       else
   1339         Diag(AttrLoc, diag::err_attribute_argument_type)
   1340           << &TmpAttr << AANT_ArgumentIntegerConstant
   1341           << E->getSourceRange();
   1342       return;
   1343     }
   1344 
   1345     if (!I.isPowerOf2()) {
   1346       Diag(AttrLoc, diag::err_alignment_not_power_of_two)
   1347         << E->getSourceRange();
   1348       return;
   1349     }
   1350   }
   1351 
   1352   if (OE) {
   1353     if (!OE->isValueDependent()) {
   1354       llvm::APSInt I(64);
   1355       if (!OE->isIntegerConstantExpr(I, Context)) {
   1356         Diag(AttrLoc, diag::err_attribute_argument_n_type)
   1357           << &TmpAttr << 2 << AANT_ArgumentIntegerConstant
   1358           << OE->getSourceRange();
   1359         return;
   1360       }
   1361     }
   1362   }
   1363 
   1364   D->addAttr(::new (Context)
   1365             AssumeAlignedAttr(AttrRange, Context, E, OE, SpellingListIndex));
   1366 }
   1367 
   1368 /// Normalize the attribute, __foo__ becomes foo.
   1369 /// Returns true if normalization was applied.
   1370 static bool normalizeName(StringRef &AttrName) {
   1371   if (AttrName.size() > 4 && AttrName.startswith("__") &&
   1372       AttrName.endswith("__")) {
   1373     AttrName = AttrName.drop_front(2).drop_back(2);
   1374     return true;
   1375   }
   1376   return false;
   1377 }
   1378 
   1379 static void handleOwnershipAttr(Sema &S, Decl *D, const AttributeList &AL) {
   1380   // This attribute must be applied to a function declaration. The first
   1381   // argument to the attribute must be an identifier, the name of the resource,
   1382   // for example: malloc. The following arguments must be argument indexes, the
   1383   // arguments must be of integer type for Returns, otherwise of pointer type.
   1384   // The difference between Holds and Takes is that a pointer may still be used
   1385   // after being held. free() should be __attribute((ownership_takes)), whereas
   1386   // a list append function may well be __attribute((ownership_holds)).
   1387 
   1388   if (!AL.isArgIdent(0)) {
   1389     S.Diag(AL.getLoc(), diag::err_attribute_argument_n_type)
   1390       << AL.getName() << 1 << AANT_ArgumentIdentifier;
   1391     return;
   1392   }
   1393 
   1394   // Figure out our Kind.
   1395   OwnershipAttr::OwnershipKind K =
   1396       OwnershipAttr(AL.getLoc(), S.Context, nullptr, nullptr, 0,
   1397                     AL.getAttributeSpellingListIndex()).getOwnKind();
   1398 
   1399   // Check arguments.
   1400   switch (K) {
   1401   case OwnershipAttr::Takes:
   1402   case OwnershipAttr::Holds:
   1403     if (AL.getNumArgs() < 2) {
   1404       S.Diag(AL.getLoc(), diag::err_attribute_too_few_arguments)
   1405         << AL.getName() << 2;
   1406       return;
   1407     }
   1408     break;
   1409   case OwnershipAttr::Returns:
   1410     if (AL.getNumArgs() > 2) {
   1411       S.Diag(AL.getLoc(), diag::err_attribute_too_many_arguments)
   1412         << AL.getName() << 1;
   1413       return;
   1414     }
   1415     break;
   1416   }
   1417 
   1418   IdentifierInfo *Module = AL.getArgAsIdent(0)->Ident;
   1419 
   1420   StringRef ModuleName = Module->getName();
   1421   if (normalizeName(ModuleName)) {
   1422     Module = &S.PP.getIdentifierTable().get(ModuleName);
   1423   }
   1424 
   1425   SmallVector<unsigned, 8> OwnershipArgs;
   1426   for (unsigned i = 1; i < AL.getNumArgs(); ++i) {
   1427     Expr *Ex = AL.getArgAsExpr(i);
   1428     uint64_t Idx;
   1429     if (!checkFunctionOrMethodParameterIndex(S, D, AL, i, Ex, Idx))
   1430       return;
   1431 
   1432     // Is the function argument a pointer type?
   1433     QualType T = getFunctionOrMethodParamType(D, Idx);
   1434     int Err = -1;  // No error
   1435     switch (K) {
   1436       case OwnershipAttr::Takes:
   1437       case OwnershipAttr::Holds:
   1438         if (!T->isAnyPointerType() && !T->isBlockPointerType())
   1439           Err = 0;
   1440         break;
   1441       case OwnershipAttr::Returns:
   1442         if (!T->isIntegerType())
   1443           Err = 1;
   1444         break;
   1445     }
   1446     if (-1 != Err) {
   1447       S.Diag(AL.getLoc(), diag::err_ownership_type) << AL.getName() << Err
   1448         << Ex->getSourceRange();
   1449       return;
   1450     }
   1451 
   1452     // Check we don't have a conflict with another ownership attribute.
   1453     for (const auto *I : D->specific_attrs<OwnershipAttr>()) {
   1454       // Cannot have two ownership attributes of different kinds for the same
   1455       // index.
   1456       if (I->getOwnKind() != K && I->args_end() !=
   1457           std::find(I->args_begin(), I->args_end(), Idx)) {
   1458         S.Diag(AL.getLoc(), diag::err_attributes_are_not_compatible)
   1459           << AL.getName() << I;
   1460         return;
   1461       } else if (K == OwnershipAttr::Returns &&
   1462                  I->getOwnKind() == OwnershipAttr::Returns) {
   1463         // A returns attribute conflicts with any other returns attribute using
   1464         // a different index. Note, diagnostic reporting is 1-based, but stored
   1465         // argument indexes are 0-based.
   1466         if (std::find(I->args_begin(), I->args_end(), Idx) == I->args_end()) {
   1467           S.Diag(I->getLocation(), diag::err_ownership_returns_index_mismatch)
   1468               << *(I->args_begin()) + 1;
   1469           if (I->args_size())
   1470             S.Diag(AL.getLoc(), diag::note_ownership_returns_index_mismatch)
   1471                 << (unsigned)Idx + 1 << Ex->getSourceRange();
   1472           return;
   1473         }
   1474       }
   1475     }
   1476     OwnershipArgs.push_back(Idx);
   1477   }
   1478 
   1479   unsigned* start = OwnershipArgs.data();
   1480   unsigned size = OwnershipArgs.size();
   1481   llvm::array_pod_sort(start, start + size);
   1482 
   1483   D->addAttr(::new (S.Context)
   1484              OwnershipAttr(AL.getLoc(), S.Context, Module, start, size,
   1485                            AL.getAttributeSpellingListIndex()));
   1486 }
   1487 
   1488 static void handleWeakRefAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1489   // Check the attribute arguments.
   1490   if (Attr.getNumArgs() > 1) {
   1491     S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments)
   1492       << Attr.getName() << 1;
   1493     return;
   1494   }
   1495 
   1496   NamedDecl *nd = cast<NamedDecl>(D);
   1497 
   1498   // gcc rejects
   1499   // class c {
   1500   //   static int a __attribute__((weakref ("v2")));
   1501   //   static int b() __attribute__((weakref ("f3")));
   1502   // };
   1503   // and ignores the attributes of
   1504   // void f(void) {
   1505   //   static int a __attribute__((weakref ("v2")));
   1506   // }
   1507   // we reject them
   1508   const DeclContext *Ctx = D->getDeclContext()->getRedeclContext();
   1509   if (!Ctx->isFileContext()) {
   1510     S.Diag(Attr.getLoc(), diag::err_attribute_weakref_not_global_context)
   1511       << nd;
   1512     return;
   1513   }
   1514 
   1515   // The GCC manual says
   1516   //
   1517   // At present, a declaration to which `weakref' is attached can only
   1518   // be `static'.
   1519   //
   1520   // It also says
   1521   //
   1522   // Without a TARGET,
   1523   // given as an argument to `weakref' or to `alias', `weakref' is
   1524   // equivalent to `weak'.
   1525   //
   1526   // gcc 4.4.1 will accept
   1527   // int a7 __attribute__((weakref));
   1528   // as
   1529   // int a7 __attribute__((weak));
   1530   // This looks like a bug in gcc. We reject that for now. We should revisit
   1531   // it if this behaviour is actually used.
   1532 
   1533   // GCC rejects
   1534   // static ((alias ("y"), weakref)).
   1535   // Should we? How to check that weakref is before or after alias?
   1536 
   1537   // FIXME: it would be good for us to keep the WeakRefAttr as-written instead
   1538   // of transforming it into an AliasAttr.  The WeakRefAttr never uses the
   1539   // StringRef parameter it was given anyway.
   1540   StringRef Str;
   1541   if (Attr.getNumArgs() && S.checkStringLiteralArgumentAttr(Attr, 0, Str))
   1542     // GCC will accept anything as the argument of weakref. Should we
   1543     // check for an existing decl?
   1544     D->addAttr(::new (S.Context) AliasAttr(Attr.getRange(), S.Context, Str,
   1545                                         Attr.getAttributeSpellingListIndex()));
   1546 
   1547   D->addAttr(::new (S.Context)
   1548              WeakRefAttr(Attr.getRange(), S.Context,
   1549                          Attr.getAttributeSpellingListIndex()));
   1550 }
   1551 
   1552 static void handleIFuncAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1553   StringRef Str;
   1554   if (!S.checkStringLiteralArgumentAttr(Attr, 0, Str))
   1555     return;
   1556 
   1557   // Aliases should be on declarations, not definitions.
   1558   const auto *FD = cast<FunctionDecl>(D);
   1559   if (FD->isThisDeclarationADefinition()) {
   1560     S.Diag(Attr.getLoc(), diag::err_alias_is_definition) << FD << 1;
   1561     return;
   1562   }
   1563   // FIXME: it should be handled as a target specific attribute.
   1564   if (S.Context.getTargetInfo().getTriple().getObjectFormat() !=
   1565           llvm::Triple::ELF) {
   1566     S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName();
   1567     return;
   1568   }
   1569 
   1570   D->addAttr(::new (S.Context) IFuncAttr(Attr.getRange(), S.Context, Str,
   1571                                          Attr.getAttributeSpellingListIndex()));
   1572 }
   1573 
   1574 static void handleAliasAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1575   StringRef Str;
   1576   if (!S.checkStringLiteralArgumentAttr(Attr, 0, Str))
   1577     return;
   1578 
   1579   if (S.Context.getTargetInfo().getTriple().isOSDarwin()) {
   1580     S.Diag(Attr.getLoc(), diag::err_alias_not_supported_on_darwin);
   1581     return;
   1582   }
   1583   if (S.Context.getTargetInfo().getTriple().isNVPTX()) {
   1584     S.Diag(Attr.getLoc(), diag::err_alias_not_supported_on_nvptx);
   1585   }
   1586 
   1587   // Aliases should be on declarations, not definitions.
   1588   if (const auto *FD = dyn_cast<FunctionDecl>(D)) {
   1589     if (FD->isThisDeclarationADefinition()) {
   1590       S.Diag(Attr.getLoc(), diag::err_alias_is_definition) << FD << 0;
   1591       return;
   1592     }
   1593   } else {
   1594     const auto *VD = cast<VarDecl>(D);
   1595     if (VD->isThisDeclarationADefinition() && VD->isExternallyVisible()) {
   1596       S.Diag(Attr.getLoc(), diag::err_alias_is_definition) << VD << 0;
   1597       return;
   1598     }
   1599   }
   1600 
   1601   // FIXME: check if target symbol exists in current file
   1602 
   1603   D->addAttr(::new (S.Context) AliasAttr(Attr.getRange(), S.Context, Str,
   1604                                          Attr.getAttributeSpellingListIndex()));
   1605 }
   1606 
   1607 static void handleColdAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1608   if (checkAttrMutualExclusion<HotAttr>(S, D, Attr.getRange(), Attr.getName()))
   1609     return;
   1610 
   1611   D->addAttr(::new (S.Context) ColdAttr(Attr.getRange(), S.Context,
   1612                                         Attr.getAttributeSpellingListIndex()));
   1613 }
   1614 
   1615 static void handleHotAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1616   if (checkAttrMutualExclusion<ColdAttr>(S, D, Attr.getRange(), Attr.getName()))
   1617     return;
   1618 
   1619   D->addAttr(::new (S.Context) HotAttr(Attr.getRange(), S.Context,
   1620                                        Attr.getAttributeSpellingListIndex()));
   1621 }
   1622 
   1623 static void handleTLSModelAttr(Sema &S, Decl *D,
   1624                                const AttributeList &Attr) {
   1625   StringRef Model;
   1626   SourceLocation LiteralLoc;
   1627   // Check that it is a string.
   1628   if (!S.checkStringLiteralArgumentAttr(Attr, 0, Model, &LiteralLoc))
   1629     return;
   1630 
   1631   // Check that the value.
   1632   if (Model != "global-dynamic" && Model != "local-dynamic"
   1633       && Model != "initial-exec" && Model != "local-exec") {
   1634     S.Diag(LiteralLoc, diag::err_attr_tlsmodel_arg);
   1635     return;
   1636   }
   1637 
   1638   D->addAttr(::new (S.Context)
   1639              TLSModelAttr(Attr.getRange(), S.Context, Model,
   1640                           Attr.getAttributeSpellingListIndex()));
   1641 }
   1642 
   1643 static void handleRestrictAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1644   QualType ResultType = getFunctionOrMethodResultType(D);
   1645   if (ResultType->isAnyPointerType() || ResultType->isBlockPointerType()) {
   1646     D->addAttr(::new (S.Context) RestrictAttr(
   1647         Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   1648     return;
   1649   }
   1650 
   1651   S.Diag(Attr.getLoc(), diag::warn_attribute_return_pointers_only)
   1652       << Attr.getName() << getFunctionOrMethodResultSourceRange(D);
   1653 }
   1654 
   1655 static void handleCommonAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1656   if (S.LangOpts.CPlusPlus) {
   1657     S.Diag(Attr.getLoc(), diag::err_attribute_not_supported_in_lang)
   1658         << Attr.getName() << AttributeLangSupport::Cpp;
   1659     return;
   1660   }
   1661 
   1662   if (CommonAttr *CA = S.mergeCommonAttr(D, Attr.getRange(), Attr.getName(),
   1663                                          Attr.getAttributeSpellingListIndex()))
   1664     D->addAttr(CA);
   1665 }
   1666 
   1667 static void handleNakedAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1668   if (checkAttrMutualExclusion<DisableTailCallsAttr>(S, D, Attr.getRange(),
   1669                                                      Attr.getName()))
   1670     return;
   1671 
   1672   D->addAttr(::new (S.Context) NakedAttr(Attr.getRange(), S.Context,
   1673                                          Attr.getAttributeSpellingListIndex()));
   1674 }
   1675 
   1676 static void handleNoReturnAttr(Sema &S, Decl *D, const AttributeList &attr) {
   1677   if (hasDeclarator(D)) return;
   1678 
   1679   if (S.CheckNoReturnAttr(attr)) return;
   1680 
   1681   if (!isa<ObjCMethodDecl>(D)) {
   1682     S.Diag(attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   1683       << attr.getName() << ExpectedFunctionOrMethod;
   1684     return;
   1685   }
   1686 
   1687   D->addAttr(::new (S.Context)
   1688              NoReturnAttr(attr.getRange(), S.Context,
   1689                           attr.getAttributeSpellingListIndex()));
   1690 }
   1691 
   1692 bool Sema::CheckNoReturnAttr(const AttributeList &attr) {
   1693   if (!checkAttributeNumArgs(*this, attr, 0)) {
   1694     attr.setInvalid();
   1695     return true;
   1696   }
   1697 
   1698   return false;
   1699 }
   1700 
   1701 static void handleAnalyzerNoReturnAttr(Sema &S, Decl *D,
   1702                                        const AttributeList &Attr) {
   1703 
   1704   // The checking path for 'noreturn' and 'analyzer_noreturn' are different
   1705   // because 'analyzer_noreturn' does not impact the type.
   1706   if (!isFunctionOrMethodOrBlock(D)) {
   1707     ValueDecl *VD = dyn_cast<ValueDecl>(D);
   1708     if (!VD || (!VD->getType()->isBlockPointerType() &&
   1709                 !VD->getType()->isFunctionPointerType())) {
   1710       S.Diag(Attr.getLoc(),
   1711              Attr.isCXX11Attribute() ? diag::err_attribute_wrong_decl_type
   1712                                      : diag::warn_attribute_wrong_decl_type)
   1713         << Attr.getName() << ExpectedFunctionMethodOrBlock;
   1714       return;
   1715     }
   1716   }
   1717 
   1718   D->addAttr(::new (S.Context)
   1719              AnalyzerNoReturnAttr(Attr.getRange(), S.Context,
   1720                                   Attr.getAttributeSpellingListIndex()));
   1721 }
   1722 
   1723 // PS3 PPU-specific.
   1724 static void handleVecReturnAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1725 /*
   1726   Returning a Vector Class in Registers
   1727 
   1728   According to the PPU ABI specifications, a class with a single member of
   1729   vector type is returned in memory when used as the return value of a function.
   1730   This results in inefficient code when implementing vector classes. To return
   1731   the value in a single vector register, add the vecreturn attribute to the
   1732   class definition. This attribute is also applicable to struct types.
   1733 
   1734   Example:
   1735 
   1736   struct Vector
   1737   {
   1738     __vector float xyzw;
   1739   } __attribute__((vecreturn));
   1740 
   1741   Vector Add(Vector lhs, Vector rhs)
   1742   {
   1743     Vector result;
   1744     result.xyzw = vec_add(lhs.xyzw, rhs.xyzw);
   1745     return result; // This will be returned in a register
   1746   }
   1747 */
   1748   if (VecReturnAttr *A = D->getAttr<VecReturnAttr>()) {
   1749     S.Diag(Attr.getLoc(), diag::err_repeat_attribute) << A;
   1750     return;
   1751   }
   1752 
   1753   RecordDecl *record = cast<RecordDecl>(D);
   1754   int count = 0;
   1755 
   1756   if (!isa<CXXRecordDecl>(record)) {
   1757     S.Diag(Attr.getLoc(), diag::err_attribute_vecreturn_only_vector_member);
   1758     return;
   1759   }
   1760 
   1761   if (!cast<CXXRecordDecl>(record)->isPOD()) {
   1762     S.Diag(Attr.getLoc(), diag::err_attribute_vecreturn_only_pod_record);
   1763     return;
   1764   }
   1765 
   1766   for (const auto *I : record->fields()) {
   1767     if ((count == 1) || !I->getType()->isVectorType()) {
   1768       S.Diag(Attr.getLoc(), diag::err_attribute_vecreturn_only_vector_member);
   1769       return;
   1770     }
   1771     count++;
   1772   }
   1773 
   1774   D->addAttr(::new (S.Context)
   1775              VecReturnAttr(Attr.getRange(), S.Context,
   1776                            Attr.getAttributeSpellingListIndex()));
   1777 }
   1778 
   1779 static void handleDependencyAttr(Sema &S, Scope *Scope, Decl *D,
   1780                                  const AttributeList &Attr) {
   1781   if (isa<ParmVarDecl>(D)) {
   1782     // [[carries_dependency]] can only be applied to a parameter if it is a
   1783     // parameter of a function declaration or lambda.
   1784     if (!(Scope->getFlags() & clang::Scope::FunctionDeclarationScope)) {
   1785       S.Diag(Attr.getLoc(),
   1786              diag::err_carries_dependency_param_not_function_decl);
   1787       return;
   1788     }
   1789   }
   1790 
   1791   D->addAttr(::new (S.Context) CarriesDependencyAttr(
   1792                                    Attr.getRange(), S.Context,
   1793                                    Attr.getAttributeSpellingListIndex()));
   1794 }
   1795 
   1796 static void handleNotTailCalledAttr(Sema &S, Decl *D,
   1797                                     const AttributeList &Attr) {
   1798   if (checkAttrMutualExclusion<AlwaysInlineAttr>(S, D, Attr.getRange(),
   1799                                                  Attr.getName()))
   1800     return;
   1801 
   1802   D->addAttr(::new (S.Context) NotTailCalledAttr(
   1803       Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   1804 }
   1805 
   1806 static void handleDisableTailCallsAttr(Sema &S, Decl *D,
   1807                                        const AttributeList &Attr) {
   1808   if (checkAttrMutualExclusion<NakedAttr>(S, D, Attr.getRange(),
   1809                                           Attr.getName()))
   1810     return;
   1811 
   1812   D->addAttr(::new (S.Context) DisableTailCallsAttr(
   1813       Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   1814 }
   1815 
   1816 static void handleUsedAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1817   if (const VarDecl *VD = dyn_cast<VarDecl>(D)) {
   1818     if (VD->hasLocalStorage()) {
   1819       S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName();
   1820       return;
   1821     }
   1822   } else if (!isFunctionOrMethod(D)) {
   1823     S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   1824       << Attr.getName() << ExpectedVariableOrFunction;
   1825     return;
   1826   }
   1827 
   1828   D->addAttr(::new (S.Context)
   1829              UsedAttr(Attr.getRange(), S.Context,
   1830                       Attr.getAttributeSpellingListIndex()));
   1831 }
   1832 
   1833 static void handleUnusedAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1834   bool IsCXX1zAttr = Attr.isCXX11Attribute() && !Attr.getScopeName();
   1835 
   1836   if (IsCXX1zAttr && isa<VarDecl>(D)) {
   1837     // The C++1z spelling of this attribute cannot be applied to a static data
   1838     // member per [dcl.attr.unused]p2.
   1839     if (cast<VarDecl>(D)->isStaticDataMember()) {
   1840       S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   1841           << Attr.getName() << ExpectedForMaybeUnused;
   1842       return;
   1843     }
   1844   }
   1845 
   1846   // If this is spelled as the standard C++1z attribute, but not in C++1z, warn
   1847   // about using it as an extension.
   1848   if (!S.getLangOpts().CPlusPlus1z && IsCXX1zAttr)
   1849     S.Diag(Attr.getLoc(), diag::ext_cxx1z_attr) << Attr.getName();
   1850 
   1851   D->addAttr(::new (S.Context) UnusedAttr(
   1852       Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   1853 }
   1854 
   1855 static void handleConstructorAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1856   uint32_t priority = ConstructorAttr::DefaultPriority;
   1857   if (Attr.getNumArgs() &&
   1858       !checkUInt32Argument(S, Attr, Attr.getArgAsExpr(0), priority))
   1859     return;
   1860 
   1861   D->addAttr(::new (S.Context)
   1862              ConstructorAttr(Attr.getRange(), S.Context, priority,
   1863                              Attr.getAttributeSpellingListIndex()));
   1864 }
   1865 
   1866 static void handleDestructorAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   1867   uint32_t priority = DestructorAttr::DefaultPriority;
   1868   if (Attr.getNumArgs() &&
   1869       !checkUInt32Argument(S, Attr, Attr.getArgAsExpr(0), priority))
   1870     return;
   1871 
   1872   D->addAttr(::new (S.Context)
   1873              DestructorAttr(Attr.getRange(), S.Context, priority,
   1874                             Attr.getAttributeSpellingListIndex()));
   1875 }
   1876 
   1877 template <typename AttrTy>
   1878 static void handleAttrWithMessage(Sema &S, Decl *D,
   1879                                   const AttributeList &Attr) {
   1880   // Handle the case where the attribute has a text message.
   1881   StringRef Str;
   1882   if (Attr.getNumArgs() == 1 && !S.checkStringLiteralArgumentAttr(Attr, 0, Str))
   1883     return;
   1884 
   1885   D->addAttr(::new (S.Context) AttrTy(Attr.getRange(), S.Context, Str,
   1886                                       Attr.getAttributeSpellingListIndex()));
   1887 }
   1888 
   1889 static void handleObjCSuppresProtocolAttr(Sema &S, Decl *D,
   1890                                           const AttributeList &Attr) {
   1891   if (!cast<ObjCProtocolDecl>(D)->isThisDeclarationADefinition()) {
   1892     S.Diag(Attr.getLoc(), diag::err_objc_attr_protocol_requires_definition)
   1893       << Attr.getName() << Attr.getRange();
   1894     return;
   1895   }
   1896 
   1897   D->addAttr(::new (S.Context)
   1898           ObjCExplicitProtocolImplAttr(Attr.getRange(), S.Context,
   1899                                        Attr.getAttributeSpellingListIndex()));
   1900 }
   1901 
   1902 static bool checkAvailabilityAttr(Sema &S, SourceRange Range,
   1903                                   IdentifierInfo *Platform,
   1904                                   VersionTuple Introduced,
   1905                                   VersionTuple Deprecated,
   1906                                   VersionTuple Obsoleted) {
   1907   StringRef PlatformName
   1908     = AvailabilityAttr::getPrettyPlatformName(Platform->getName());
   1909   if (PlatformName.empty())
   1910     PlatformName = Platform->getName();
   1911 
   1912   // Ensure that Introduced <= Deprecated <= Obsoleted (although not all
   1913   // of these steps are needed).
   1914   if (!Introduced.empty() && !Deprecated.empty() &&
   1915       !(Introduced <= Deprecated)) {
   1916     S.Diag(Range.getBegin(), diag::warn_availability_version_ordering)
   1917       << 1 << PlatformName << Deprecated.getAsString()
   1918       << 0 << Introduced.getAsString();
   1919     return true;
   1920   }
   1921 
   1922   if (!Introduced.empty() && !Obsoleted.empty() &&
   1923       !(Introduced <= Obsoleted)) {
   1924     S.Diag(Range.getBegin(), diag::warn_availability_version_ordering)
   1925       << 2 << PlatformName << Obsoleted.getAsString()
   1926       << 0 << Introduced.getAsString();
   1927     return true;
   1928   }
   1929 
   1930   if (!Deprecated.empty() && !Obsoleted.empty() &&
   1931       !(Deprecated <= Obsoleted)) {
   1932     S.Diag(Range.getBegin(), diag::warn_availability_version_ordering)
   1933       << 2 << PlatformName << Obsoleted.getAsString()
   1934       << 1 << Deprecated.getAsString();
   1935     return true;
   1936   }
   1937 
   1938   return false;
   1939 }
   1940 
   1941 /// \brief Check whether the two versions match.
   1942 ///
   1943 /// If either version tuple is empty, then they are assumed to match. If
   1944 /// \p BeforeIsOkay is true, then \p X can be less than or equal to \p Y.
   1945 static bool versionsMatch(const VersionTuple &X, const VersionTuple &Y,
   1946                           bool BeforeIsOkay) {
   1947   if (X.empty() || Y.empty())
   1948     return true;
   1949 
   1950   if (X == Y)
   1951     return true;
   1952 
   1953   if (BeforeIsOkay && X < Y)
   1954     return true;
   1955 
   1956   return false;
   1957 }
   1958 
   1959 AvailabilityAttr *Sema::mergeAvailabilityAttr(NamedDecl *D, SourceRange Range,
   1960                                               IdentifierInfo *Platform,
   1961                                               bool Implicit,
   1962                                               VersionTuple Introduced,
   1963                                               VersionTuple Deprecated,
   1964                                               VersionTuple Obsoleted,
   1965                                               bool IsUnavailable,
   1966                                               StringRef Message,
   1967                                               bool IsStrict,
   1968                                               StringRef Replacement,
   1969                                               AvailabilityMergeKind AMK,
   1970                                               unsigned AttrSpellingListIndex) {
   1971   VersionTuple MergedIntroduced = Introduced;
   1972   VersionTuple MergedDeprecated = Deprecated;
   1973   VersionTuple MergedObsoleted = Obsoleted;
   1974   bool FoundAny = false;
   1975   bool OverrideOrImpl = false;
   1976   switch (AMK) {
   1977   case AMK_None:
   1978   case AMK_Redeclaration:
   1979     OverrideOrImpl = false;
   1980     break;
   1981 
   1982   case AMK_Override:
   1983   case AMK_ProtocolImplementation:
   1984     OverrideOrImpl = true;
   1985     break;
   1986   }
   1987 
   1988   if (D->hasAttrs()) {
   1989     AttrVec &Attrs = D->getAttrs();
   1990     for (unsigned i = 0, e = Attrs.size(); i != e;) {
   1991       const AvailabilityAttr *OldAA = dyn_cast<AvailabilityAttr>(Attrs[i]);
   1992       if (!OldAA) {
   1993         ++i;
   1994         continue;
   1995       }
   1996 
   1997       IdentifierInfo *OldPlatform = OldAA->getPlatform();
   1998       if (OldPlatform != Platform) {
   1999         ++i;
   2000         continue;
   2001       }
   2002 
   2003       // If there is an existing availability attribute for this platform that
   2004       // is explicit and the new one is implicit use the explicit one and
   2005       // discard the new implicit attribute.
   2006       if (!OldAA->isImplicit() && Implicit) {
   2007         return nullptr;
   2008       }
   2009 
   2010       // If there is an existing attribute for this platform that is implicit
   2011       // and the new attribute is explicit then erase the old one and
   2012       // continue processing the attributes.
   2013       if (!Implicit && OldAA->isImplicit()) {
   2014         Attrs.erase(Attrs.begin() + i);
   2015         --e;
   2016         continue;
   2017       }
   2018 
   2019       FoundAny = true;
   2020       VersionTuple OldIntroduced = OldAA->getIntroduced();
   2021       VersionTuple OldDeprecated = OldAA->getDeprecated();
   2022       VersionTuple OldObsoleted = OldAA->getObsoleted();
   2023       bool OldIsUnavailable = OldAA->getUnavailable();
   2024 
   2025       if (!versionsMatch(OldIntroduced, Introduced, OverrideOrImpl) ||
   2026           !versionsMatch(Deprecated, OldDeprecated, OverrideOrImpl) ||
   2027           !versionsMatch(Obsoleted, OldObsoleted, OverrideOrImpl) ||
   2028           !(OldIsUnavailable == IsUnavailable ||
   2029             (OverrideOrImpl && !OldIsUnavailable && IsUnavailable))) {
   2030         if (OverrideOrImpl) {
   2031           int Which = -1;
   2032           VersionTuple FirstVersion;
   2033           VersionTuple SecondVersion;
   2034           if (!versionsMatch(OldIntroduced, Introduced, OverrideOrImpl)) {
   2035             Which = 0;
   2036             FirstVersion = OldIntroduced;
   2037             SecondVersion = Introduced;
   2038           } else if (!versionsMatch(Deprecated, OldDeprecated, OverrideOrImpl)) {
   2039             Which = 1;
   2040             FirstVersion = Deprecated;
   2041             SecondVersion = OldDeprecated;
   2042           } else if (!versionsMatch(Obsoleted, OldObsoleted, OverrideOrImpl)) {
   2043             Which = 2;
   2044             FirstVersion = Obsoleted;
   2045             SecondVersion = OldObsoleted;
   2046           }
   2047 
   2048           if (Which == -1) {
   2049             Diag(OldAA->getLocation(),
   2050                  diag::warn_mismatched_availability_override_unavail)
   2051               << AvailabilityAttr::getPrettyPlatformName(Platform->getName())
   2052               << (AMK == AMK_Override);
   2053           } else {
   2054             Diag(OldAA->getLocation(),
   2055                  diag::warn_mismatched_availability_override)
   2056               << Which
   2057               << AvailabilityAttr::getPrettyPlatformName(Platform->getName())
   2058               << FirstVersion.getAsString() << SecondVersion.getAsString()
   2059               << (AMK == AMK_Override);
   2060           }
   2061           if (AMK == AMK_Override)
   2062             Diag(Range.getBegin(), diag::note_overridden_method);
   2063           else
   2064             Diag(Range.getBegin(), diag::note_protocol_method);
   2065         } else {
   2066           Diag(OldAA->getLocation(), diag::warn_mismatched_availability);
   2067           Diag(Range.getBegin(), diag::note_previous_attribute);
   2068         }
   2069 
   2070         Attrs.erase(Attrs.begin() + i);
   2071         --e;
   2072         continue;
   2073       }
   2074 
   2075       VersionTuple MergedIntroduced2 = MergedIntroduced;
   2076       VersionTuple MergedDeprecated2 = MergedDeprecated;
   2077       VersionTuple MergedObsoleted2 = MergedObsoleted;
   2078 
   2079       if (MergedIntroduced2.empty())
   2080         MergedIntroduced2 = OldIntroduced;
   2081       if (MergedDeprecated2.empty())
   2082         MergedDeprecated2 = OldDeprecated;
   2083       if (MergedObsoleted2.empty())
   2084         MergedObsoleted2 = OldObsoleted;
   2085 
   2086       if (checkAvailabilityAttr(*this, OldAA->getRange(), Platform,
   2087                                 MergedIntroduced2, MergedDeprecated2,
   2088                                 MergedObsoleted2)) {
   2089         Attrs.erase(Attrs.begin() + i);
   2090         --e;
   2091         continue;
   2092       }
   2093 
   2094       MergedIntroduced = MergedIntroduced2;
   2095       MergedDeprecated = MergedDeprecated2;
   2096       MergedObsoleted = MergedObsoleted2;
   2097       ++i;
   2098     }
   2099   }
   2100 
   2101   if (FoundAny &&
   2102       MergedIntroduced == Introduced &&
   2103       MergedDeprecated == Deprecated &&
   2104       MergedObsoleted == Obsoleted)
   2105     return nullptr;
   2106 
   2107   // Only create a new attribute if !OverrideOrImpl, but we want to do
   2108   // the checking.
   2109   if (!checkAvailabilityAttr(*this, Range, Platform, MergedIntroduced,
   2110                              MergedDeprecated, MergedObsoleted) &&
   2111       !OverrideOrImpl) {
   2112     auto *Avail =  ::new (Context) AvailabilityAttr(Range, Context, Platform,
   2113                                             Introduced, Deprecated,
   2114                                             Obsoleted, IsUnavailable, Message,
   2115                                             IsStrict, Replacement,
   2116                                             AttrSpellingListIndex);
   2117     Avail->setImplicit(Implicit);
   2118     return Avail;
   2119   }
   2120   return nullptr;
   2121 }
   2122 
   2123 static void handleAvailabilityAttr(Sema &S, Decl *D,
   2124                                    const AttributeList &Attr) {
   2125   if (!checkAttributeNumArgs(S, Attr, 1))
   2126     return;
   2127   IdentifierLoc *Platform = Attr.getArgAsIdent(0);
   2128   unsigned Index = Attr.getAttributeSpellingListIndex();
   2129 
   2130   IdentifierInfo *II = Platform->Ident;
   2131   if (AvailabilityAttr::getPrettyPlatformName(II->getName()).empty())
   2132     S.Diag(Platform->Loc, diag::warn_availability_unknown_platform)
   2133       << Platform->Ident;
   2134 
   2135   NamedDecl *ND = dyn_cast<NamedDecl>(D);
   2136   if (!ND) {
   2137     S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName();
   2138     return;
   2139   }
   2140 
   2141   AvailabilityChange Introduced = Attr.getAvailabilityIntroduced();
   2142   AvailabilityChange Deprecated = Attr.getAvailabilityDeprecated();
   2143   AvailabilityChange Obsoleted = Attr.getAvailabilityObsoleted();
   2144   bool IsUnavailable = Attr.getUnavailableLoc().isValid();
   2145   bool IsStrict = Attr.getStrictLoc().isValid();
   2146   StringRef Str;
   2147   if (const StringLiteral *SE =
   2148           dyn_cast_or_null<StringLiteral>(Attr.getMessageExpr()))
   2149     Str = SE->getString();
   2150   StringRef Replacement;
   2151   if (const StringLiteral *SE =
   2152           dyn_cast_or_null<StringLiteral>(Attr.getReplacementExpr()))
   2153     Replacement = SE->getString();
   2154 
   2155   AvailabilityAttr *NewAttr = S.mergeAvailabilityAttr(ND, Attr.getRange(), II,
   2156                                                       false/*Implicit*/,
   2157                                                       Introduced.Version,
   2158                                                       Deprecated.Version,
   2159                                                       Obsoleted.Version,
   2160                                                       IsUnavailable, Str,
   2161                                                       IsStrict, Replacement,
   2162                                                       Sema::AMK_None,
   2163                                                       Index);
   2164   if (NewAttr)
   2165     D->addAttr(NewAttr);
   2166 
   2167   // Transcribe "ios" to "watchos" (and add a new attribute) if the versioning
   2168   // matches before the start of the watchOS platform.
   2169   if (S.Context.getTargetInfo().getTriple().isWatchOS()) {
   2170     IdentifierInfo *NewII = nullptr;
   2171     if (II->getName() == "ios")
   2172       NewII = &S.Context.Idents.get("watchos");
   2173     else if (II->getName() == "ios_app_extension")
   2174       NewII = &S.Context.Idents.get("watchos_app_extension");
   2175 
   2176     if (NewII) {
   2177         auto adjustWatchOSVersion = [](VersionTuple Version) -> VersionTuple {
   2178           if (Version.empty())
   2179             return Version;
   2180           auto Major = Version.getMajor();
   2181           auto NewMajor = Major >= 9 ? Major - 7 : 0;
   2182           if (NewMajor >= 2) {
   2183             if (Version.getMinor().hasValue()) {
   2184               if (Version.getSubminor().hasValue())
   2185                 return VersionTuple(NewMajor, Version.getMinor().getValue(),
   2186                                     Version.getSubminor().getValue());
   2187               else
   2188                 return VersionTuple(NewMajor, Version.getMinor().getValue());
   2189             }
   2190           }
   2191 
   2192           return VersionTuple(2, 0);
   2193         };
   2194 
   2195         auto NewIntroduced = adjustWatchOSVersion(Introduced.Version);
   2196         auto NewDeprecated = adjustWatchOSVersion(Deprecated.Version);
   2197         auto NewObsoleted = adjustWatchOSVersion(Obsoleted.Version);
   2198 
   2199         AvailabilityAttr *NewAttr = S.mergeAvailabilityAttr(ND,
   2200                                                             Attr.getRange(),
   2201                                                             NewII,
   2202                                                             true/*Implicit*/,
   2203                                                             NewIntroduced,
   2204                                                             NewDeprecated,
   2205                                                             NewObsoleted,
   2206                                                             IsUnavailable, Str,
   2207                                                             IsStrict,
   2208                                                             Replacement,
   2209                                                             Sema::AMK_None,
   2210                                                             Index);
   2211         if (NewAttr)
   2212           D->addAttr(NewAttr);
   2213       }
   2214   } else if (S.Context.getTargetInfo().getTriple().isTvOS()) {
   2215     // Transcribe "ios" to "tvos" (and add a new attribute) if the versioning
   2216     // matches before the start of the tvOS platform.
   2217     IdentifierInfo *NewII = nullptr;
   2218     if (II->getName() == "ios")
   2219       NewII = &S.Context.Idents.get("tvos");
   2220     else if (II->getName() == "ios_app_extension")
   2221       NewII = &S.Context.Idents.get("tvos_app_extension");
   2222 
   2223     if (NewII) {
   2224         AvailabilityAttr *NewAttr = S.mergeAvailabilityAttr(ND,
   2225                                                             Attr.getRange(),
   2226                                                             NewII,
   2227                                                             true/*Implicit*/,
   2228                                                             Introduced.Version,
   2229                                                             Deprecated.Version,
   2230                                                             Obsoleted.Version,
   2231                                                             IsUnavailable, Str,
   2232                                                             IsStrict,
   2233                                                             Replacement,
   2234                                                             Sema::AMK_None,
   2235                                                             Index);
   2236         if (NewAttr)
   2237           D->addAttr(NewAttr);
   2238       }
   2239   }
   2240 }
   2241 
   2242 template <class T>
   2243 static T *mergeVisibilityAttr(Sema &S, Decl *D, SourceRange range,
   2244                               typename T::VisibilityType value,
   2245                               unsigned attrSpellingListIndex) {
   2246   T *existingAttr = D->getAttr<T>();
   2247   if (existingAttr) {
   2248     typename T::VisibilityType existingValue = existingAttr->getVisibility();
   2249     if (existingValue == value)
   2250       return nullptr;
   2251     S.Diag(existingAttr->getLocation(), diag::err_mismatched_visibility);
   2252     S.Diag(range.getBegin(), diag::note_previous_attribute);
   2253     D->dropAttr<T>();
   2254   }
   2255   return ::new (S.Context) T(range, S.Context, value, attrSpellingListIndex);
   2256 }
   2257 
   2258 VisibilityAttr *Sema::mergeVisibilityAttr(Decl *D, SourceRange Range,
   2259                                           VisibilityAttr::VisibilityType Vis,
   2260                                           unsigned AttrSpellingListIndex) {
   2261   return ::mergeVisibilityAttr<VisibilityAttr>(*this, D, Range, Vis,
   2262                                                AttrSpellingListIndex);
   2263 }
   2264 
   2265 TypeVisibilityAttr *Sema::mergeTypeVisibilityAttr(Decl *D, SourceRange Range,
   2266                                       TypeVisibilityAttr::VisibilityType Vis,
   2267                                       unsigned AttrSpellingListIndex) {
   2268   return ::mergeVisibilityAttr<TypeVisibilityAttr>(*this, D, Range, Vis,
   2269                                                    AttrSpellingListIndex);
   2270 }
   2271 
   2272 static void handleVisibilityAttr(Sema &S, Decl *D, const AttributeList &Attr,
   2273                                  bool isTypeVisibility) {
   2274   // Visibility attributes don't mean anything on a typedef.
   2275   if (isa<TypedefNameDecl>(D)) {
   2276     S.Diag(Attr.getRange().getBegin(), diag::warn_attribute_ignored)
   2277       << Attr.getName();
   2278     return;
   2279   }
   2280 
   2281   // 'type_visibility' can only go on a type or namespace.
   2282   if (isTypeVisibility &&
   2283       !(isa<TagDecl>(D) ||
   2284         isa<ObjCInterfaceDecl>(D) ||
   2285         isa<NamespaceDecl>(D))) {
   2286     S.Diag(Attr.getRange().getBegin(), diag::err_attribute_wrong_decl_type)
   2287       << Attr.getName() << ExpectedTypeOrNamespace;
   2288     return;
   2289   }
   2290 
   2291   // Check that the argument is a string literal.
   2292   StringRef TypeStr;
   2293   SourceLocation LiteralLoc;
   2294   if (!S.checkStringLiteralArgumentAttr(Attr, 0, TypeStr, &LiteralLoc))
   2295     return;
   2296 
   2297   VisibilityAttr::VisibilityType type;
   2298   if (!VisibilityAttr::ConvertStrToVisibilityType(TypeStr, type)) {
   2299     S.Diag(LiteralLoc, diag::warn_attribute_type_not_supported)
   2300       << Attr.getName() << TypeStr;
   2301     return;
   2302   }
   2303 
   2304   // Complain about attempts to use protected visibility on targets
   2305   // (like Darwin) that don't support it.
   2306   if (type == VisibilityAttr::Protected &&
   2307       !S.Context.getTargetInfo().hasProtectedVisibility()) {
   2308     S.Diag(Attr.getLoc(), diag::warn_attribute_protected_visibility);
   2309     type = VisibilityAttr::Default;
   2310   }
   2311 
   2312   unsigned Index = Attr.getAttributeSpellingListIndex();
   2313   clang::Attr *newAttr;
   2314   if (isTypeVisibility) {
   2315     newAttr = S.mergeTypeVisibilityAttr(D, Attr.getRange(),
   2316                                     (TypeVisibilityAttr::VisibilityType) type,
   2317                                         Index);
   2318   } else {
   2319     newAttr = S.mergeVisibilityAttr(D, Attr.getRange(), type, Index);
   2320   }
   2321   if (newAttr)
   2322     D->addAttr(newAttr);
   2323 }
   2324 
   2325 static void handleObjCMethodFamilyAttr(Sema &S, Decl *decl,
   2326                                        const AttributeList &Attr) {
   2327   ObjCMethodDecl *method = cast<ObjCMethodDecl>(decl);
   2328   if (!Attr.isArgIdent(0)) {
   2329     S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
   2330       << Attr.getName() << 1 << AANT_ArgumentIdentifier;
   2331     return;
   2332   }
   2333 
   2334   IdentifierLoc *IL = Attr.getArgAsIdent(0);
   2335   ObjCMethodFamilyAttr::FamilyKind F;
   2336   if (!ObjCMethodFamilyAttr::ConvertStrToFamilyKind(IL->Ident->getName(), F)) {
   2337     S.Diag(IL->Loc, diag::warn_attribute_type_not_supported) << Attr.getName()
   2338       << IL->Ident;
   2339     return;
   2340   }
   2341 
   2342   if (F == ObjCMethodFamilyAttr::OMF_init &&
   2343       !method->getReturnType()->isObjCObjectPointerType()) {
   2344     S.Diag(method->getLocation(), diag::err_init_method_bad_return_type)
   2345         << method->getReturnType();
   2346     // Ignore the attribute.
   2347     return;
   2348   }
   2349 
   2350   method->addAttr(new (S.Context) ObjCMethodFamilyAttr(Attr.getRange(),
   2351                                                        S.Context, F,
   2352                                         Attr.getAttributeSpellingListIndex()));
   2353 }
   2354 
   2355 static void handleObjCNSObject(Sema &S, Decl *D, const AttributeList &Attr) {
   2356   if (TypedefNameDecl *TD = dyn_cast<TypedefNameDecl>(D)) {
   2357     QualType T = TD->getUnderlyingType();
   2358     if (!T->isCARCBridgableType()) {
   2359       S.Diag(TD->getLocation(), diag::err_nsobject_attribute);
   2360       return;
   2361     }
   2362   }
   2363   else if (ObjCPropertyDecl *PD = dyn_cast<ObjCPropertyDecl>(D)) {
   2364     QualType T = PD->getType();
   2365     if (!T->isCARCBridgableType()) {
   2366       S.Diag(PD->getLocation(), diag::err_nsobject_attribute);
   2367       return;
   2368     }
   2369   }
   2370   else {
   2371     // It is okay to include this attribute on properties, e.g.:
   2372     //
   2373     //  @property (retain, nonatomic) struct Bork *Q __attribute__((NSObject));
   2374     //
   2375     // In this case it follows tradition and suppresses an error in the above
   2376     // case.
   2377     S.Diag(D->getLocation(), diag::warn_nsobject_attribute);
   2378   }
   2379   D->addAttr(::new (S.Context)
   2380              ObjCNSObjectAttr(Attr.getRange(), S.Context,
   2381                               Attr.getAttributeSpellingListIndex()));
   2382 }
   2383 
   2384 static void handleObjCIndependentClass(Sema &S, Decl *D, const AttributeList &Attr) {
   2385   if (TypedefNameDecl *TD = dyn_cast<TypedefNameDecl>(D)) {
   2386     QualType T = TD->getUnderlyingType();
   2387     if (!T->isObjCObjectPointerType()) {
   2388       S.Diag(TD->getLocation(), diag::warn_ptr_independentclass_attribute);
   2389       return;
   2390     }
   2391   } else {
   2392     S.Diag(D->getLocation(), diag::warn_independentclass_attribute);
   2393     return;
   2394   }
   2395   D->addAttr(::new (S.Context)
   2396              ObjCIndependentClassAttr(Attr.getRange(), S.Context,
   2397                               Attr.getAttributeSpellingListIndex()));
   2398 }
   2399 
   2400 static void handleBlocksAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   2401   if (!Attr.isArgIdent(0)) {
   2402     S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
   2403       << Attr.getName() << 1 << AANT_ArgumentIdentifier;
   2404     return;
   2405   }
   2406 
   2407   IdentifierInfo *II = Attr.getArgAsIdent(0)->Ident;
   2408   BlocksAttr::BlockType type;
   2409   if (!BlocksAttr::ConvertStrToBlockType(II->getName(), type)) {
   2410     S.Diag(Attr.getLoc(), diag::warn_attribute_type_not_supported)
   2411       << Attr.getName() << II;
   2412     return;
   2413   }
   2414 
   2415   D->addAttr(::new (S.Context)
   2416              BlocksAttr(Attr.getRange(), S.Context, type,
   2417                         Attr.getAttributeSpellingListIndex()));
   2418 }
   2419 
   2420 static void handleSentinelAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   2421   unsigned sentinel = (unsigned)SentinelAttr::DefaultSentinel;
   2422   if (Attr.getNumArgs() > 0) {
   2423     Expr *E = Attr.getArgAsExpr(0);
   2424     llvm::APSInt Idx(32);
   2425     if (E->isTypeDependent() || E->isValueDependent() ||
   2426         !E->isIntegerConstantExpr(Idx, S.Context)) {
   2427       S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
   2428         << Attr.getName() << 1 << AANT_ArgumentIntegerConstant
   2429         << E->getSourceRange();
   2430       return;
   2431     }
   2432 
   2433     if (Idx.isSigned() && Idx.isNegative()) {
   2434       S.Diag(Attr.getLoc(), diag::err_attribute_sentinel_less_than_zero)
   2435         << E->getSourceRange();
   2436       return;
   2437     }
   2438 
   2439     sentinel = Idx.getZExtValue();
   2440   }
   2441 
   2442   unsigned nullPos = (unsigned)SentinelAttr::DefaultNullPos;
   2443   if (Attr.getNumArgs() > 1) {
   2444     Expr *E = Attr.getArgAsExpr(1);
   2445     llvm::APSInt Idx(32);
   2446     if (E->isTypeDependent() || E->isValueDependent() ||
   2447         !E->isIntegerConstantExpr(Idx, S.Context)) {
   2448       S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
   2449         << Attr.getName() << 2 << AANT_ArgumentIntegerConstant
   2450         << E->getSourceRange();
   2451       return;
   2452     }
   2453     nullPos = Idx.getZExtValue();
   2454 
   2455     if ((Idx.isSigned() && Idx.isNegative()) || nullPos > 1) {
   2456       // FIXME: This error message could be improved, it would be nice
   2457       // to say what the bounds actually are.
   2458       S.Diag(Attr.getLoc(), diag::err_attribute_sentinel_not_zero_or_one)
   2459         << E->getSourceRange();
   2460       return;
   2461     }
   2462   }
   2463 
   2464   if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {
   2465     const FunctionType *FT = FD->getType()->castAs<FunctionType>();
   2466     if (isa<FunctionNoProtoType>(FT)) {
   2467       S.Diag(Attr.getLoc(), diag::warn_attribute_sentinel_named_arguments);
   2468       return;
   2469     }
   2470 
   2471     if (!cast<FunctionProtoType>(FT)->isVariadic()) {
   2472       S.Diag(Attr.getLoc(), diag::warn_attribute_sentinel_not_variadic) << 0;
   2473       return;
   2474     }
   2475   } else if (ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D)) {
   2476     if (!MD->isVariadic()) {
   2477       S.Diag(Attr.getLoc(), diag::warn_attribute_sentinel_not_variadic) << 0;
   2478       return;
   2479     }
   2480   } else if (BlockDecl *BD = dyn_cast<BlockDecl>(D)) {
   2481     if (!BD->isVariadic()) {
   2482       S.Diag(Attr.getLoc(), diag::warn_attribute_sentinel_not_variadic) << 1;
   2483       return;
   2484     }
   2485   } else if (const VarDecl *V = dyn_cast<VarDecl>(D)) {
   2486     QualType Ty = V->getType();
   2487     if (Ty->isBlockPointerType() || Ty->isFunctionPointerType()) {
   2488       const FunctionType *FT = Ty->isFunctionPointerType()
   2489        ? D->getFunctionType()
   2490        : Ty->getAs<BlockPointerType>()->getPointeeType()->getAs<FunctionType>();
   2491       if (!cast<FunctionProtoType>(FT)->isVariadic()) {
   2492         int m = Ty->isFunctionPointerType() ? 0 : 1;
   2493         S.Diag(Attr.getLoc(), diag::warn_attribute_sentinel_not_variadic) << m;
   2494         return;
   2495       }
   2496     } else {
   2497       S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   2498         << Attr.getName() << ExpectedFunctionMethodOrBlock;
   2499       return;
   2500     }
   2501   } else {
   2502     S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   2503       << Attr.getName() << ExpectedFunctionMethodOrBlock;
   2504     return;
   2505   }
   2506   D->addAttr(::new (S.Context)
   2507              SentinelAttr(Attr.getRange(), S.Context, sentinel, nullPos,
   2508                           Attr.getAttributeSpellingListIndex()));
   2509 }
   2510 
   2511 static void handleWarnUnusedResult(Sema &S, Decl *D, const AttributeList &Attr) {
   2512   if (D->getFunctionType() &&
   2513       D->getFunctionType()->getReturnType()->isVoidType()) {
   2514     S.Diag(Attr.getLoc(), diag::warn_attribute_void_function_method)
   2515       << Attr.getName() << 0;
   2516     return;
   2517   }
   2518   if (const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D))
   2519     if (MD->getReturnType()->isVoidType()) {
   2520       S.Diag(Attr.getLoc(), diag::warn_attribute_void_function_method)
   2521       << Attr.getName() << 1;
   2522       return;
   2523     }
   2524 
   2525   // If this is spelled as the standard C++1z attribute, but not in C++1z, warn
   2526   // about using it as an extension.
   2527   if (!S.getLangOpts().CPlusPlus1z && Attr.isCXX11Attribute() &&
   2528       !Attr.getScopeName())
   2529     S.Diag(Attr.getLoc(), diag::ext_cxx1z_attr) << Attr.getName();
   2530 
   2531   D->addAttr(::new (S.Context)
   2532              WarnUnusedResultAttr(Attr.getRange(), S.Context,
   2533                                   Attr.getAttributeSpellingListIndex()));
   2534 }
   2535 
   2536 static void handleWeakImportAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   2537   // weak_import only applies to variable & function declarations.
   2538   bool isDef = false;
   2539   if (!D->canBeWeakImported(isDef)) {
   2540     if (isDef)
   2541       S.Diag(Attr.getLoc(), diag::warn_attribute_invalid_on_definition)
   2542         << "weak_import";
   2543     else if (isa<ObjCPropertyDecl>(D) || isa<ObjCMethodDecl>(D) ||
   2544              (S.Context.getTargetInfo().getTriple().isOSDarwin() &&
   2545               (isa<ObjCInterfaceDecl>(D) || isa<EnumDecl>(D)))) {
   2546       // Nothing to warn about here.
   2547     } else
   2548       S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   2549         << Attr.getName() << ExpectedVariableOrFunction;
   2550 
   2551     return;
   2552   }
   2553 
   2554   D->addAttr(::new (S.Context)
   2555              WeakImportAttr(Attr.getRange(), S.Context,
   2556                             Attr.getAttributeSpellingListIndex()));
   2557 }
   2558 
   2559 // Handles reqd_work_group_size and work_group_size_hint.
   2560 template <typename WorkGroupAttr>
   2561 static void handleWorkGroupSize(Sema &S, Decl *D,
   2562                                 const AttributeList &Attr) {
   2563   uint32_t WGSize[3];
   2564   for (unsigned i = 0; i < 3; ++i) {
   2565     const Expr *E = Attr.getArgAsExpr(i);
   2566     if (!checkUInt32Argument(S, Attr, E, WGSize[i], i))
   2567       return;
   2568     if (WGSize[i] == 0) {
   2569       S.Diag(Attr.getLoc(), diag::err_attribute_argument_is_zero)
   2570         << Attr.getName() << E->getSourceRange();
   2571       return;
   2572     }
   2573   }
   2574 
   2575   WorkGroupAttr *Existing = D->getAttr<WorkGroupAttr>();
   2576   if (Existing && !(Existing->getXDim() == WGSize[0] &&
   2577                     Existing->getYDim() == WGSize[1] &&
   2578                     Existing->getZDim() == WGSize[2]))
   2579     S.Diag(Attr.getLoc(), diag::warn_duplicate_attribute) << Attr.getName();
   2580 
   2581   D->addAttr(::new (S.Context) WorkGroupAttr(Attr.getRange(), S.Context,
   2582                                              WGSize[0], WGSize[1], WGSize[2],
   2583                                        Attr.getAttributeSpellingListIndex()));
   2584 }
   2585 
   2586 static void handleVecTypeHint(Sema &S, Decl *D, const AttributeList &Attr) {
   2587   if (!Attr.hasParsedType()) {
   2588     S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments)
   2589       << Attr.getName() << 1;
   2590     return;
   2591   }
   2592 
   2593   TypeSourceInfo *ParmTSI = nullptr;
   2594   QualType ParmType = S.GetTypeFromParser(Attr.getTypeArg(), &ParmTSI);
   2595   assert(ParmTSI && "no type source info for attribute argument");
   2596 
   2597   if (!ParmType->isExtVectorType() && !ParmType->isFloatingType() &&
   2598       (ParmType->isBooleanType() ||
   2599        !ParmType->isIntegralType(S.getASTContext()))) {
   2600     S.Diag(Attr.getLoc(), diag::err_attribute_argument_vec_type_hint)
   2601         << ParmType;
   2602     return;
   2603   }
   2604 
   2605   if (VecTypeHintAttr *A = D->getAttr<VecTypeHintAttr>()) {
   2606     if (!S.Context.hasSameType(A->getTypeHint(), ParmType)) {
   2607       S.Diag(Attr.getLoc(), diag::warn_duplicate_attribute) << Attr.getName();
   2608       return;
   2609     }
   2610   }
   2611 
   2612   D->addAttr(::new (S.Context) VecTypeHintAttr(Attr.getLoc(), S.Context,
   2613                                                ParmTSI,
   2614                                         Attr.getAttributeSpellingListIndex()));
   2615 }
   2616 
   2617 SectionAttr *Sema::mergeSectionAttr(Decl *D, SourceRange Range,
   2618                                     StringRef Name,
   2619                                     unsigned AttrSpellingListIndex) {
   2620   if (SectionAttr *ExistingAttr = D->getAttr<SectionAttr>()) {
   2621     if (ExistingAttr->getName() == Name)
   2622       return nullptr;
   2623     Diag(ExistingAttr->getLocation(), diag::warn_mismatched_section);
   2624     Diag(Range.getBegin(), diag::note_previous_attribute);
   2625     return nullptr;
   2626   }
   2627   return ::new (Context) SectionAttr(Range, Context, Name,
   2628                                      AttrSpellingListIndex);
   2629 }
   2630 
   2631 bool Sema::checkSectionName(SourceLocation LiteralLoc, StringRef SecName) {
   2632   std::string Error = Context.getTargetInfo().isValidSectionSpecifier(SecName);
   2633   if (!Error.empty()) {
   2634     Diag(LiteralLoc, diag::err_attribute_section_invalid_for_target) << Error;
   2635     return false;
   2636   }
   2637   return true;
   2638 }
   2639 
   2640 static void handleSectionAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   2641   // Make sure that there is a string literal as the sections's single
   2642   // argument.
   2643   StringRef Str;
   2644   SourceLocation LiteralLoc;
   2645   if (!S.checkStringLiteralArgumentAttr(Attr, 0, Str, &LiteralLoc))
   2646     return;
   2647 
   2648   if (!S.checkSectionName(LiteralLoc, Str))
   2649     return;
   2650 
   2651   // If the target wants to validate the section specifier, make it happen.
   2652   std::string Error = S.Context.getTargetInfo().isValidSectionSpecifier(Str);
   2653   if (!Error.empty()) {
   2654     S.Diag(LiteralLoc, diag::err_attribute_section_invalid_for_target)
   2655     << Error;
   2656     return;
   2657   }
   2658 
   2659   unsigned Index = Attr.getAttributeSpellingListIndex();
   2660   SectionAttr *NewAttr = S.mergeSectionAttr(D, Attr.getRange(), Str, Index);
   2661   if (NewAttr)
   2662     D->addAttr(NewAttr);
   2663 }
   2664 
   2665 // Check for things we'd like to warn about, no errors or validation for now.
   2666 // TODO: Validation should use a backend target library that specifies
   2667 // the allowable subtarget features and cpus. We could use something like a
   2668 // TargetCodeGenInfo hook here to do validation.
   2669 void Sema::checkTargetAttr(SourceLocation LiteralLoc, StringRef AttrStr) {
   2670   for (auto Str : {"tune=", "fpmath="})
   2671     if (AttrStr.find(Str) != StringRef::npos)
   2672       Diag(LiteralLoc, diag::warn_unsupported_target_attribute) << Str;
   2673 }
   2674 
   2675 static void handleTargetAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   2676   StringRef Str;
   2677   SourceLocation LiteralLoc;
   2678   if (!S.checkStringLiteralArgumentAttr(Attr, 0, Str, &LiteralLoc))
   2679     return;
   2680   S.checkTargetAttr(LiteralLoc, Str);
   2681   unsigned Index = Attr.getAttributeSpellingListIndex();
   2682   TargetAttr *NewAttr =
   2683       ::new (S.Context) TargetAttr(Attr.getRange(), S.Context, Str, Index);
   2684   D->addAttr(NewAttr);
   2685 }
   2686 
   2687 static void handleCleanupAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   2688   VarDecl *VD = cast<VarDecl>(D);
   2689   if (!VD->hasLocalStorage()) {
   2690     S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName();
   2691     return;
   2692   }
   2693 
   2694   Expr *E = Attr.getArgAsExpr(0);
   2695   SourceLocation Loc = E->getExprLoc();
   2696   FunctionDecl *FD = nullptr;
   2697   DeclarationNameInfo NI;
   2698 
   2699   // gcc only allows for simple identifiers. Since we support more than gcc, we
   2700   // will warn the user.
   2701   if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) {
   2702     if (DRE->hasQualifier())
   2703       S.Diag(Loc, diag::warn_cleanup_ext);
   2704     FD = dyn_cast<FunctionDecl>(DRE->getDecl());
   2705     NI = DRE->getNameInfo();
   2706     if (!FD) {
   2707       S.Diag(Loc, diag::err_attribute_cleanup_arg_not_function) << 1
   2708         << NI.getName();
   2709       return;
   2710     }
   2711   } else if (UnresolvedLookupExpr *ULE = dyn_cast<UnresolvedLookupExpr>(E)) {
   2712     if (ULE->hasExplicitTemplateArgs())
   2713       S.Diag(Loc, diag::warn_cleanup_ext);
   2714     FD = S.ResolveSingleFunctionTemplateSpecialization(ULE, true);
   2715     NI = ULE->getNameInfo();
   2716     if (!FD) {
   2717       S.Diag(Loc, diag::err_attribute_cleanup_arg_not_function) << 2
   2718         << NI.getName();
   2719       if (ULE->getType() == S.Context.OverloadTy)
   2720         S.NoteAllOverloadCandidates(ULE);
   2721       return;
   2722     }
   2723   } else {
   2724     S.Diag(Loc, diag::err_attribute_cleanup_arg_not_function) << 0;
   2725     return;
   2726   }
   2727 
   2728   if (FD->getNumParams() != 1) {
   2729     S.Diag(Loc, diag::err_attribute_cleanup_func_must_take_one_arg)
   2730       << NI.getName();
   2731     return;
   2732   }
   2733 
   2734   // We're currently more strict than GCC about what function types we accept.
   2735   // If this ever proves to be a problem it should be easy to fix.
   2736   QualType Ty = S.Context.getPointerType(VD->getType());
   2737   QualType ParamTy = FD->getParamDecl(0)->getType();
   2738   if (S.CheckAssignmentConstraints(FD->getParamDecl(0)->getLocation(),
   2739                                    ParamTy, Ty) != Sema::Compatible) {
   2740     S.Diag(Loc, diag::err_attribute_cleanup_func_arg_incompatible_type)
   2741       << NI.getName() << ParamTy << Ty;
   2742     return;
   2743   }
   2744 
   2745   D->addAttr(::new (S.Context)
   2746              CleanupAttr(Attr.getRange(), S.Context, FD,
   2747                          Attr.getAttributeSpellingListIndex()));
   2748 }
   2749 
   2750 /// Handle __attribute__((format_arg((idx)))) attribute based on
   2751 /// http://gcc.gnu.org/onlinedocs/gcc/Function-Attributes.html
   2752 static void handleFormatArgAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   2753   Expr *IdxExpr = Attr.getArgAsExpr(0);
   2754   uint64_t Idx;
   2755   if (!checkFunctionOrMethodParameterIndex(S, D, Attr, 1, IdxExpr, Idx))
   2756     return;
   2757 
   2758   // Make sure the format string is really a string.
   2759   QualType Ty = getFunctionOrMethodParamType(D, Idx);
   2760 
   2761   bool NotNSStringTy = !isNSStringType(Ty, S.Context);
   2762   if (NotNSStringTy &&
   2763       !isCFStringType(Ty, S.Context) &&
   2764       (!Ty->isPointerType() ||
   2765        !Ty->getAs<PointerType>()->getPointeeType()->isCharType())) {
   2766     S.Diag(Attr.getLoc(), diag::err_format_attribute_not)
   2767         << "a string type" << IdxExpr->getSourceRange()
   2768         << getFunctionOrMethodParamRange(D, 0);
   2769     return;
   2770   }
   2771   Ty = getFunctionOrMethodResultType(D);
   2772   if (!isNSStringType(Ty, S.Context) &&
   2773       !isCFStringType(Ty, S.Context) &&
   2774       (!Ty->isPointerType() ||
   2775        !Ty->getAs<PointerType>()->getPointeeType()->isCharType())) {
   2776     S.Diag(Attr.getLoc(), diag::err_format_attribute_result_not)
   2777         << (NotNSStringTy ? "string type" : "NSString")
   2778         << IdxExpr->getSourceRange() << getFunctionOrMethodParamRange(D, 0);
   2779     return;
   2780   }
   2781 
   2782   // We cannot use the Idx returned from checkFunctionOrMethodParameterIndex
   2783   // because that has corrected for the implicit this parameter, and is zero-
   2784   // based.  The attribute expects what the user wrote explicitly.
   2785   llvm::APSInt Val;
   2786   IdxExpr->EvaluateAsInt(Val, S.Context);
   2787 
   2788   D->addAttr(::new (S.Context)
   2789              FormatArgAttr(Attr.getRange(), S.Context, Val.getZExtValue(),
   2790                            Attr.getAttributeSpellingListIndex()));
   2791 }
   2792 
   2793 enum FormatAttrKind {
   2794   CFStringFormat,
   2795   NSStringFormat,
   2796   StrftimeFormat,
   2797   SupportedFormat,
   2798   IgnoredFormat,
   2799   InvalidFormat
   2800 };
   2801 
   2802 /// getFormatAttrKind - Map from format attribute names to supported format
   2803 /// types.
   2804 static FormatAttrKind getFormatAttrKind(StringRef Format) {
   2805   return llvm::StringSwitch<FormatAttrKind>(Format)
   2806     // Check for formats that get handled specially.
   2807     .Case("NSString", NSStringFormat)
   2808     .Case("CFString", CFStringFormat)
   2809     .Case("strftime", StrftimeFormat)
   2810 
   2811     // Otherwise, check for supported formats.
   2812     .Cases("scanf", "printf", "printf0", "strfmon", SupportedFormat)
   2813     .Cases("cmn_err", "vcmn_err", "zcmn_err", SupportedFormat)
   2814     .Case("kprintf", SupportedFormat) // OpenBSD.
   2815     .Case("freebsd_kprintf", SupportedFormat) // FreeBSD.
   2816     .Case("os_trace", SupportedFormat)
   2817 
   2818     .Cases("gcc_diag", "gcc_cdiag", "gcc_cxxdiag", "gcc_tdiag", IgnoredFormat)
   2819     .Default(InvalidFormat);
   2820 }
   2821 
   2822 /// Handle __attribute__((init_priority(priority))) attributes based on
   2823 /// http://gcc.gnu.org/onlinedocs/gcc/C_002b_002b-Attributes.html
   2824 static void handleInitPriorityAttr(Sema &S, Decl *D,
   2825                                    const AttributeList &Attr) {
   2826   if (!S.getLangOpts().CPlusPlus) {
   2827     S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName();
   2828     return;
   2829   }
   2830 
   2831   if (S.getCurFunctionOrMethodDecl()) {
   2832     S.Diag(Attr.getLoc(), diag::err_init_priority_object_attr);
   2833     Attr.setInvalid();
   2834     return;
   2835   }
   2836   QualType T = cast<VarDecl>(D)->getType();
   2837   if (S.Context.getAsArrayType(T))
   2838     T = S.Context.getBaseElementType(T);
   2839   if (!T->getAs<RecordType>()) {
   2840     S.Diag(Attr.getLoc(), diag::err_init_priority_object_attr);
   2841     Attr.setInvalid();
   2842     return;
   2843   }
   2844 
   2845   Expr *E = Attr.getArgAsExpr(0);
   2846   uint32_t prioritynum;
   2847   if (!checkUInt32Argument(S, Attr, E, prioritynum)) {
   2848     Attr.setInvalid();
   2849     return;
   2850   }
   2851 
   2852   if (prioritynum < 101 || prioritynum > 65535) {
   2853     S.Diag(Attr.getLoc(), diag::err_attribute_argument_outof_range)
   2854       << E->getSourceRange() << Attr.getName() << 101 << 65535;
   2855     Attr.setInvalid();
   2856     return;
   2857   }
   2858   D->addAttr(::new (S.Context)
   2859              InitPriorityAttr(Attr.getRange(), S.Context, prioritynum,
   2860                               Attr.getAttributeSpellingListIndex()));
   2861 }
   2862 
   2863 FormatAttr *Sema::mergeFormatAttr(Decl *D, SourceRange Range,
   2864                                   IdentifierInfo *Format, int FormatIdx,
   2865                                   int FirstArg,
   2866                                   unsigned AttrSpellingListIndex) {
   2867   // Check whether we already have an equivalent format attribute.
   2868   for (auto *F : D->specific_attrs<FormatAttr>()) {
   2869     if (F->getType() == Format &&
   2870         F->getFormatIdx() == FormatIdx &&
   2871         F->getFirstArg() == FirstArg) {
   2872       // If we don't have a valid location for this attribute, adopt the
   2873       // location.
   2874       if (F->getLocation().isInvalid())
   2875         F->setRange(Range);
   2876       return nullptr;
   2877     }
   2878   }
   2879 
   2880   return ::new (Context) FormatAttr(Range, Context, Format, FormatIdx,
   2881                                     FirstArg, AttrSpellingListIndex);
   2882 }
   2883 
   2884 /// Handle __attribute__((format(type,idx,firstarg))) attributes based on
   2885 /// http://gcc.gnu.org/onlinedocs/gcc/Function-Attributes.html
   2886 static void handleFormatAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   2887   if (!Attr.isArgIdent(0)) {
   2888     S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
   2889       << Attr.getName() << 1 << AANT_ArgumentIdentifier;
   2890     return;
   2891   }
   2892 
   2893   // In C++ the implicit 'this' function parameter also counts, and they are
   2894   // counted from one.
   2895   bool HasImplicitThisParam = isInstanceMethod(D);
   2896   unsigned NumArgs = getFunctionOrMethodNumParams(D) + HasImplicitThisParam;
   2897 
   2898   IdentifierInfo *II = Attr.getArgAsIdent(0)->Ident;
   2899   StringRef Format = II->getName();
   2900 
   2901   if (normalizeName(Format)) {
   2902     // If we've modified the string name, we need a new identifier for it.
   2903     II = &S.Context.Idents.get(Format);
   2904   }
   2905 
   2906   // Check for supported formats.
   2907   FormatAttrKind Kind = getFormatAttrKind(Format);
   2908 
   2909   if (Kind == IgnoredFormat)
   2910     return;
   2911 
   2912   if (Kind == InvalidFormat) {
   2913     S.Diag(Attr.getLoc(), diag::warn_attribute_type_not_supported)
   2914       << Attr.getName() << II->getName();
   2915     return;
   2916   }
   2917 
   2918   // checks for the 2nd argument
   2919   Expr *IdxExpr = Attr.getArgAsExpr(1);
   2920   uint32_t Idx;
   2921   if (!checkUInt32Argument(S, Attr, IdxExpr, Idx, 2))
   2922     return;
   2923 
   2924   if (Idx < 1 || Idx > NumArgs) {
   2925     S.Diag(Attr.getLoc(), diag::err_attribute_argument_out_of_bounds)
   2926       << Attr.getName() << 2 << IdxExpr->getSourceRange();
   2927     return;
   2928   }
   2929 
   2930   // FIXME: Do we need to bounds check?
   2931   unsigned ArgIdx = Idx - 1;
   2932 
   2933   if (HasImplicitThisParam) {
   2934     if (ArgIdx == 0) {
   2935       S.Diag(Attr.getLoc(),
   2936              diag::err_format_attribute_implicit_this_format_string)
   2937         << IdxExpr->getSourceRange();
   2938       return;
   2939     }
   2940     ArgIdx--;
   2941   }
   2942 
   2943   // make sure the format string is really a string
   2944   QualType Ty = getFunctionOrMethodParamType(D, ArgIdx);
   2945 
   2946   if (Kind == CFStringFormat) {
   2947     if (!isCFStringType(Ty, S.Context)) {
   2948       S.Diag(Attr.getLoc(), diag::err_format_attribute_not)
   2949         << "a CFString" << IdxExpr->getSourceRange()
   2950         << getFunctionOrMethodParamRange(D, ArgIdx);
   2951       return;
   2952     }
   2953   } else if (Kind == NSStringFormat) {
   2954     // FIXME: do we need to check if the type is NSString*?  What are the
   2955     // semantics?
   2956     if (!isNSStringType(Ty, S.Context)) {
   2957       S.Diag(Attr.getLoc(), diag::err_format_attribute_not)
   2958         << "an NSString" << IdxExpr->getSourceRange()
   2959         << getFunctionOrMethodParamRange(D, ArgIdx);
   2960       return;
   2961     }
   2962   } else if (!Ty->isPointerType() ||
   2963              !Ty->getAs<PointerType>()->getPointeeType()->isCharType()) {
   2964     S.Diag(Attr.getLoc(), diag::err_format_attribute_not)
   2965       << "a string type" << IdxExpr->getSourceRange()
   2966       << getFunctionOrMethodParamRange(D, ArgIdx);
   2967     return;
   2968   }
   2969 
   2970   // check the 3rd argument
   2971   Expr *FirstArgExpr = Attr.getArgAsExpr(2);
   2972   uint32_t FirstArg;
   2973   if (!checkUInt32Argument(S, Attr, FirstArgExpr, FirstArg, 3))
   2974     return;
   2975 
   2976   // check if the function is variadic if the 3rd argument non-zero
   2977   if (FirstArg != 0) {
   2978     if (isFunctionOrMethodVariadic(D)) {
   2979       ++NumArgs; // +1 for ...
   2980     } else {
   2981       S.Diag(D->getLocation(), diag::err_format_attribute_requires_variadic);
   2982       return;
   2983     }
   2984   }
   2985 
   2986   // strftime requires FirstArg to be 0 because it doesn't read from any
   2987   // variable the input is just the current time + the format string.
   2988   if (Kind == StrftimeFormat) {
   2989     if (FirstArg != 0) {
   2990       S.Diag(Attr.getLoc(), diag::err_format_strftime_third_parameter)
   2991         << FirstArgExpr->getSourceRange();
   2992       return;
   2993     }
   2994   // if 0 it disables parameter checking (to use with e.g. va_list)
   2995   } else if (FirstArg != 0 && FirstArg != NumArgs) {
   2996     S.Diag(Attr.getLoc(), diag::err_attribute_argument_out_of_bounds)
   2997       << Attr.getName() << 3 << FirstArgExpr->getSourceRange();
   2998     return;
   2999   }
   3000 
   3001   FormatAttr *NewAttr = S.mergeFormatAttr(D, Attr.getRange(), II,
   3002                                           Idx, FirstArg,
   3003                                           Attr.getAttributeSpellingListIndex());
   3004   if (NewAttr)
   3005     D->addAttr(NewAttr);
   3006 }
   3007 
   3008 static void handleTransparentUnionAttr(Sema &S, Decl *D,
   3009                                        const AttributeList &Attr) {
   3010   // Try to find the underlying union declaration.
   3011   RecordDecl *RD = nullptr;
   3012   TypedefNameDecl *TD = dyn_cast<TypedefNameDecl>(D);
   3013   if (TD && TD->getUnderlyingType()->isUnionType())
   3014     RD = TD->getUnderlyingType()->getAsUnionType()->getDecl();
   3015   else
   3016     RD = dyn_cast<RecordDecl>(D);
   3017 
   3018   if (!RD || !RD->isUnion()) {
   3019     S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   3020       << Attr.getName() << ExpectedUnion;
   3021     return;
   3022   }
   3023 
   3024   if (!RD->isCompleteDefinition()) {
   3025     S.Diag(Attr.getLoc(),
   3026         diag::warn_transparent_union_attribute_not_definition);
   3027     return;
   3028   }
   3029 
   3030   RecordDecl::field_iterator Field = RD->field_begin(),
   3031                           FieldEnd = RD->field_end();
   3032   if (Field == FieldEnd) {
   3033     S.Diag(Attr.getLoc(), diag::warn_transparent_union_attribute_zero_fields);
   3034     return;
   3035   }
   3036 
   3037   FieldDecl *FirstField = *Field;
   3038   QualType FirstType = FirstField->getType();
   3039   if (FirstType->hasFloatingRepresentation() || FirstType->isVectorType()) {
   3040     S.Diag(FirstField->getLocation(),
   3041            diag::warn_transparent_union_attribute_floating)
   3042       << FirstType->isVectorType() << FirstType;
   3043     return;
   3044   }
   3045 
   3046   uint64_t FirstSize = S.Context.getTypeSize(FirstType);
   3047   uint64_t FirstAlign = S.Context.getTypeAlign(FirstType);
   3048   for (; Field != FieldEnd; ++Field) {
   3049     QualType FieldType = Field->getType();
   3050     // FIXME: this isn't fully correct; we also need to test whether the
   3051     // members of the union would all have the same calling convention as the
   3052     // first member of the union. Checking just the size and alignment isn't
   3053     // sufficient (consider structs passed on the stack instead of in registers
   3054     // as an example).
   3055     if (S.Context.getTypeSize(FieldType) != FirstSize ||
   3056         S.Context.getTypeAlign(FieldType) > FirstAlign) {
   3057       // Warn if we drop the attribute.
   3058       bool isSize = S.Context.getTypeSize(FieldType) != FirstSize;
   3059       unsigned FieldBits = isSize? S.Context.getTypeSize(FieldType)
   3060                                  : S.Context.getTypeAlign(FieldType);
   3061       S.Diag(Field->getLocation(),
   3062           diag::warn_transparent_union_attribute_field_size_align)
   3063         << isSize << Field->getDeclName() << FieldBits;
   3064       unsigned FirstBits = isSize? FirstSize : FirstAlign;
   3065       S.Diag(FirstField->getLocation(),
   3066              diag::note_transparent_union_first_field_size_align)
   3067         << isSize << FirstBits;
   3068       return;
   3069     }
   3070   }
   3071 
   3072   RD->addAttr(::new (S.Context)
   3073               TransparentUnionAttr(Attr.getRange(), S.Context,
   3074                                    Attr.getAttributeSpellingListIndex()));
   3075 }
   3076 
   3077 static void handleAnnotateAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   3078   // Make sure that there is a string literal as the annotation's single
   3079   // argument.
   3080   StringRef Str;
   3081   if (!S.checkStringLiteralArgumentAttr(Attr, 0, Str))
   3082     return;
   3083 
   3084   // Don't duplicate annotations that are already set.
   3085   for (const auto *I : D->specific_attrs<AnnotateAttr>()) {
   3086     if (I->getAnnotation() == Str)
   3087       return;
   3088   }
   3089 
   3090   D->addAttr(::new (S.Context)
   3091              AnnotateAttr(Attr.getRange(), S.Context, Str,
   3092                           Attr.getAttributeSpellingListIndex()));
   3093 }
   3094 
   3095 static void handleAlignValueAttr(Sema &S, Decl *D,
   3096                                  const AttributeList &Attr) {
   3097   S.AddAlignValueAttr(Attr.getRange(), D, Attr.getArgAsExpr(0),
   3098                       Attr.getAttributeSpellingListIndex());
   3099 }
   3100 
   3101 void Sema::AddAlignValueAttr(SourceRange AttrRange, Decl *D, Expr *E,
   3102                              unsigned SpellingListIndex) {
   3103   AlignValueAttr TmpAttr(AttrRange, Context, E, SpellingListIndex);
   3104   SourceLocation AttrLoc = AttrRange.getBegin();
   3105 
   3106   QualType T;
   3107   if (TypedefNameDecl *TD = dyn_cast<TypedefNameDecl>(D))
   3108     T = TD->getUnderlyingType();
   3109   else if (ValueDecl *VD = dyn_cast<ValueDecl>(D))
   3110     T = VD->getType();
   3111   else
   3112     llvm_unreachable("Unknown decl type for align_value");
   3113 
   3114   if (!T->isDependentType() && !T->isAnyPointerType() &&
   3115       !T->isReferenceType() && !T->isMemberPointerType()) {
   3116     Diag(AttrLoc, diag::warn_attribute_pointer_or_reference_only)
   3117       << &TmpAttr /*TmpAttr.getName()*/ << T << D->getSourceRange();
   3118     return;
   3119   }
   3120 
   3121   if (!E->isValueDependent()) {
   3122     llvm::APSInt Alignment;
   3123     ExprResult ICE
   3124       = VerifyIntegerConstantExpression(E, &Alignment,
   3125           diag::err_align_value_attribute_argument_not_int,
   3126             /*AllowFold*/ false);
   3127     if (ICE.isInvalid())
   3128       return;
   3129 
   3130     if (!Alignment.isPowerOf2()) {
   3131       Diag(AttrLoc, diag::err_alignment_not_power_of_two)
   3132         << E->getSourceRange();
   3133       return;
   3134     }
   3135 
   3136     D->addAttr(::new (Context)
   3137                AlignValueAttr(AttrRange, Context, ICE.get(),
   3138                SpellingListIndex));
   3139     return;
   3140   }
   3141 
   3142   // Save dependent expressions in the AST to be instantiated.
   3143   D->addAttr(::new (Context) AlignValueAttr(TmpAttr));
   3144 }
   3145 
   3146 static void handleAlignedAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   3147   // check the attribute arguments.
   3148   if (Attr.getNumArgs() > 1) {
   3149     S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments)
   3150       << Attr.getName() << 1;
   3151     return;
   3152   }
   3153 
   3154   if (Attr.getNumArgs() == 0) {
   3155     D->addAttr(::new (S.Context) AlignedAttr(Attr.getRange(), S.Context,
   3156                true, nullptr, Attr.getAttributeSpellingListIndex()));
   3157     return;
   3158   }
   3159 
   3160   Expr *E = Attr.getArgAsExpr(0);
   3161   if (Attr.isPackExpansion() && !E->containsUnexpandedParameterPack()) {
   3162     S.Diag(Attr.getEllipsisLoc(),
   3163            diag::err_pack_expansion_without_parameter_packs);
   3164     return;
   3165   }
   3166 
   3167   if (!Attr.isPackExpansion() && S.DiagnoseUnexpandedParameterPack(E))
   3168     return;
   3169 
   3170   if (E->isValueDependent()) {
   3171     if (const auto *TND = dyn_cast<TypedefNameDecl>(D)) {
   3172       if (!TND->getUnderlyingType()->isDependentType()) {
   3173         S.Diag(Attr.getLoc(), diag::err_alignment_dependent_typedef_name)
   3174             << E->getSourceRange();
   3175         return;
   3176       }
   3177     }
   3178   }
   3179 
   3180   S.AddAlignedAttr(Attr.getRange(), D, E, Attr.getAttributeSpellingListIndex(),
   3181                    Attr.isPackExpansion());
   3182 }
   3183 
   3184 void Sema::AddAlignedAttr(SourceRange AttrRange, Decl *D, Expr *E,
   3185                           unsigned SpellingListIndex, bool IsPackExpansion) {
   3186   AlignedAttr TmpAttr(AttrRange, Context, true, E, SpellingListIndex);
   3187   SourceLocation AttrLoc = AttrRange.getBegin();
   3188 
   3189   // C++11 alignas(...) and C11 _Alignas(...) have additional requirements.
   3190   if (TmpAttr.isAlignas()) {
   3191     // C++11 [dcl.align]p1:
   3192     //   An alignment-specifier may be applied to a variable or to a class
   3193     //   data member, but it shall not be applied to a bit-field, a function
   3194     //   parameter, the formal parameter of a catch clause, or a variable
   3195     //   declared with the register storage class specifier. An
   3196     //   alignment-specifier may also be applied to the declaration of a class
   3197     //   or enumeration type.
   3198     // C11 6.7.5/2:
   3199     //   An alignment attribute shall not be specified in a declaration of
   3200     //   a typedef, or a bit-field, or a function, or a parameter, or an
   3201     //   object declared with the register storage-class specifier.
   3202     int DiagKind = -1;
   3203     if (isa<ParmVarDecl>(D)) {
   3204       DiagKind = 0;
   3205     } else if (VarDecl *VD = dyn_cast<VarDecl>(D)) {
   3206       if (VD->getStorageClass() == SC_Register)
   3207         DiagKind = 1;
   3208       if (VD->isExceptionVariable())
   3209         DiagKind = 2;
   3210     } else if (FieldDecl *FD = dyn_cast<FieldDecl>(D)) {
   3211       if (FD->isBitField())
   3212         DiagKind = 3;
   3213     } else if (!isa<TagDecl>(D)) {
   3214       Diag(AttrLoc, diag::err_attribute_wrong_decl_type) << &TmpAttr
   3215         << (TmpAttr.isC11() ? ExpectedVariableOrField
   3216                             : ExpectedVariableFieldOrTag);
   3217       return;
   3218     }
   3219     if (DiagKind != -1) {
   3220       Diag(AttrLoc, diag::err_alignas_attribute_wrong_decl_type)
   3221         << &TmpAttr << DiagKind;
   3222       return;
   3223     }
   3224   }
   3225 
   3226   if (E->isTypeDependent() || E->isValueDependent()) {
   3227     // Save dependent expressions in the AST to be instantiated.
   3228     AlignedAttr *AA = ::new (Context) AlignedAttr(TmpAttr);
   3229     AA->setPackExpansion(IsPackExpansion);
   3230     D->addAttr(AA);
   3231     return;
   3232   }
   3233 
   3234   // FIXME: Cache the number on the Attr object?
   3235   llvm::APSInt Alignment;
   3236   ExprResult ICE
   3237     = VerifyIntegerConstantExpression(E, &Alignment,
   3238         diag::err_aligned_attribute_argument_not_int,
   3239         /*AllowFold*/ false);
   3240   if (ICE.isInvalid())
   3241     return;
   3242 
   3243   uint64_t AlignVal = Alignment.getZExtValue();
   3244 
   3245   // C++11 [dcl.align]p2:
   3246   //   -- if the constant expression evaluates to zero, the alignment
   3247   //      specifier shall have no effect
   3248   // C11 6.7.5p6:
   3249   //   An alignment specification of zero has no effect.
   3250   if (!(TmpAttr.isAlignas() && !Alignment)) {
   3251     if (!llvm::isPowerOf2_64(AlignVal)) {
   3252       Diag(AttrLoc, diag::err_alignment_not_power_of_two)
   3253         << E->getSourceRange();
   3254       return;
   3255     }
   3256   }
   3257 
   3258   // Alignment calculations can wrap around if it's greater than 2**28.
   3259   unsigned MaxValidAlignment =
   3260       Context.getTargetInfo().getTriple().isOSBinFormatCOFF() ? 8192
   3261                                                               : 268435456;
   3262   if (AlignVal > MaxValidAlignment) {
   3263     Diag(AttrLoc, diag::err_attribute_aligned_too_great) << MaxValidAlignment
   3264                                                          << E->getSourceRange();
   3265     return;
   3266   }
   3267 
   3268   if (Context.getTargetInfo().isTLSSupported()) {
   3269     unsigned MaxTLSAlign =
   3270         Context.toCharUnitsFromBits(Context.getTargetInfo().getMaxTLSAlign())
   3271             .getQuantity();
   3272     auto *VD = dyn_cast<VarDecl>(D);
   3273     if (MaxTLSAlign && AlignVal > MaxTLSAlign && VD &&
   3274         VD->getTLSKind() != VarDecl::TLS_None) {
   3275       Diag(VD->getLocation(), diag::err_tls_var_aligned_over_maximum)
   3276           << (unsigned)AlignVal << VD << MaxTLSAlign;
   3277       return;
   3278     }
   3279   }
   3280 
   3281   AlignedAttr *AA = ::new (Context) AlignedAttr(AttrRange, Context, true,
   3282                                                 ICE.get(), SpellingListIndex);
   3283   AA->setPackExpansion(IsPackExpansion);
   3284   D->addAttr(AA);
   3285 }
   3286 
   3287 void Sema::AddAlignedAttr(SourceRange AttrRange, Decl *D, TypeSourceInfo *TS,
   3288                           unsigned SpellingListIndex, bool IsPackExpansion) {
   3289   // FIXME: Cache the number on the Attr object if non-dependent?
   3290   // FIXME: Perform checking of type validity
   3291   AlignedAttr *AA = ::new (Context) AlignedAttr(AttrRange, Context, false, TS,
   3292                                                 SpellingListIndex);
   3293   AA->setPackExpansion(IsPackExpansion);
   3294   D->addAttr(AA);
   3295 }
   3296 
   3297 void Sema::CheckAlignasUnderalignment(Decl *D) {
   3298   assert(D->hasAttrs() && "no attributes on decl");
   3299 
   3300   QualType UnderlyingTy, DiagTy;
   3301   if (ValueDecl *VD = dyn_cast<ValueDecl>(D)) {
   3302     UnderlyingTy = DiagTy = VD->getType();
   3303   } else {
   3304     UnderlyingTy = DiagTy = Context.getTagDeclType(cast<TagDecl>(D));
   3305     if (EnumDecl *ED = dyn_cast<EnumDecl>(D))
   3306       UnderlyingTy = ED->getIntegerType();
   3307   }
   3308   if (DiagTy->isDependentType() || DiagTy->isIncompleteType())
   3309     return;
   3310 
   3311   // C++11 [dcl.align]p5, C11 6.7.5/4:
   3312   //   The combined effect of all alignment attributes in a declaration shall
   3313   //   not specify an alignment that is less strict than the alignment that
   3314   //   would otherwise be required for the entity being declared.
   3315   AlignedAttr *AlignasAttr = nullptr;
   3316   unsigned Align = 0;
   3317   for (auto *I : D->specific_attrs<AlignedAttr>()) {
   3318     if (I->isAlignmentDependent())
   3319       return;
   3320     if (I->isAlignas())
   3321       AlignasAttr = I;
   3322     Align = std::max(Align, I->getAlignment(Context));
   3323   }
   3324 
   3325   if (AlignasAttr && Align) {
   3326     CharUnits RequestedAlign = Context.toCharUnitsFromBits(Align);
   3327     CharUnits NaturalAlign = Context.getTypeAlignInChars(UnderlyingTy);
   3328     if (NaturalAlign > RequestedAlign)
   3329       Diag(AlignasAttr->getLocation(), diag::err_alignas_underaligned)
   3330         << DiagTy << (unsigned)NaturalAlign.getQuantity();
   3331   }
   3332 }
   3333 
   3334 bool Sema::checkMSInheritanceAttrOnDefinition(
   3335     CXXRecordDecl *RD, SourceRange Range, bool BestCase,
   3336     MSInheritanceAttr::Spelling SemanticSpelling) {
   3337   assert(RD->hasDefinition() && "RD has no definition!");
   3338 
   3339   // We may not have seen base specifiers or any virtual methods yet.  We will
   3340   // have to wait until the record is defined to catch any mismatches.
   3341   if (!RD->getDefinition()->isCompleteDefinition())
   3342     return false;
   3343 
   3344   // The unspecified model never matches what a definition could need.
   3345   if (SemanticSpelling == MSInheritanceAttr::Keyword_unspecified_inheritance)
   3346     return false;
   3347 
   3348   if (BestCase) {
   3349     if (RD->calculateInheritanceModel() == SemanticSpelling)
   3350       return false;
   3351   } else {
   3352     if (RD->calculateInheritanceModel() <= SemanticSpelling)
   3353       return false;
   3354   }
   3355 
   3356   Diag(Range.getBegin(), diag::err_mismatched_ms_inheritance)
   3357       << 0 /*definition*/;
   3358   Diag(RD->getDefinition()->getLocation(), diag::note_defined_here)
   3359       << RD->getNameAsString();
   3360   return true;
   3361 }
   3362 
   3363 /// parseModeAttrArg - Parses attribute mode string and returns parsed type
   3364 /// attribute.
   3365 static void parseModeAttrArg(Sema &S, StringRef Str, unsigned &DestWidth,
   3366                              bool &IntegerMode, bool &ComplexMode) {
   3367   IntegerMode = true;
   3368   ComplexMode = false;
   3369   switch (Str.size()) {
   3370   case 2:
   3371     switch (Str[0]) {
   3372     case 'Q':
   3373       DestWidth = 8;
   3374       break;
   3375     case 'H':
   3376       DestWidth = 16;
   3377       break;
   3378     case 'S':
   3379       DestWidth = 32;
   3380       break;
   3381     case 'D':
   3382       DestWidth = 64;
   3383       break;
   3384     case 'X':
   3385       DestWidth = 96;
   3386       break;
   3387     case 'T':
   3388       DestWidth = 128;
   3389       break;
   3390     }
   3391     if (Str[1] == 'F') {
   3392       IntegerMode = false;
   3393     } else if (Str[1] == 'C') {
   3394       IntegerMode = false;
   3395       ComplexMode = true;
   3396     } else if (Str[1] != 'I') {
   3397       DestWidth = 0;
   3398     }
   3399     break;
   3400   case 4:
   3401     // FIXME: glibc uses 'word' to define register_t; this is narrower than a
   3402     // pointer on PIC16 and other embedded platforms.
   3403     if (Str == "word")
   3404       DestWidth = S.Context.getTargetInfo().getRegisterWidth();
   3405     else if (Str == "byte")
   3406       DestWidth = S.Context.getTargetInfo().getCharWidth();
   3407     break;
   3408   case 7:
   3409     if (Str == "pointer")
   3410       DestWidth = S.Context.getTargetInfo().getPointerWidth(0);
   3411     break;
   3412   case 11:
   3413     if (Str == "unwind_word")
   3414       DestWidth = S.Context.getTargetInfo().getUnwindWordWidth();
   3415     break;
   3416   }
   3417 }
   3418 
   3419 /// handleModeAttr - This attribute modifies the width of a decl with primitive
   3420 /// type.
   3421 ///
   3422 /// Despite what would be logical, the mode attribute is a decl attribute, not a
   3423 /// type attribute: 'int ** __attribute((mode(HI))) *G;' tries to make 'G' be
   3424 /// HImode, not an intermediate pointer.
   3425 static void handleModeAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   3426   // This attribute isn't documented, but glibc uses it.  It changes
   3427   // the width of an int or unsigned int to the specified size.
   3428   if (!Attr.isArgIdent(0)) {
   3429     S.Diag(Attr.getLoc(), diag::err_attribute_argument_type) << Attr.getName()
   3430       << AANT_ArgumentIdentifier;
   3431     return;
   3432   }
   3433 
   3434   IdentifierInfo *Name = Attr.getArgAsIdent(0)->Ident;
   3435 
   3436   S.AddModeAttr(Attr.getRange(), D, Name, Attr.getAttributeSpellingListIndex());
   3437 }
   3438 
   3439 void Sema::AddModeAttr(SourceRange AttrRange, Decl *D, IdentifierInfo *Name,
   3440                        unsigned SpellingListIndex, bool InInstantiation) {
   3441   StringRef Str = Name->getName();
   3442   normalizeName(Str);
   3443   SourceLocation AttrLoc = AttrRange.getBegin();
   3444 
   3445   unsigned DestWidth = 0;
   3446   bool IntegerMode = true;
   3447   bool ComplexMode = false;
   3448   llvm::APInt VectorSize(64, 0);
   3449   if (Str.size() >= 4 && Str[0] == 'V') {
   3450     // Minimal length of vector mode is 4: 'V' + NUMBER(>=1) + TYPE(>=2).
   3451     size_t StrSize = Str.size();
   3452     size_t VectorStringLength = 0;
   3453     while ((VectorStringLength + 1) < StrSize &&
   3454            isdigit(Str[VectorStringLength + 1]))
   3455       ++VectorStringLength;
   3456     if (VectorStringLength &&
   3457         !Str.substr(1, VectorStringLength).getAsInteger(10, VectorSize) &&
   3458         VectorSize.isPowerOf2()) {
   3459       parseModeAttrArg(*this, Str.substr(VectorStringLength + 1), DestWidth,
   3460                        IntegerMode, ComplexMode);
   3461       // Avoid duplicate warning from template instantiation.
   3462       if (!InInstantiation)
   3463         Diag(AttrLoc, diag::warn_vector_mode_deprecated);
   3464     } else {
   3465       VectorSize = 0;
   3466     }
   3467   }
   3468 
   3469   if (!VectorSize)
   3470     parseModeAttrArg(*this, Str, DestWidth, IntegerMode, ComplexMode);
   3471 
   3472   // FIXME: Sync this with InitializePredefinedMacros; we need to match int8_t
   3473   // and friends, at least with glibc.
   3474   // FIXME: Make sure floating-point mappings are accurate
   3475   // FIXME: Support XF and TF types
   3476   if (!DestWidth) {
   3477     Diag(AttrLoc, diag::err_machine_mode) << 0 /*Unknown*/ << Name;
   3478     return;
   3479   }
   3480 
   3481   QualType OldTy;
   3482   if (TypedefNameDecl *TD = dyn_cast<TypedefNameDecl>(D))
   3483     OldTy = TD->getUnderlyingType();
   3484   else if (EnumDecl *ED = dyn_cast<EnumDecl>(D)) {
   3485     // Something like 'typedef enum { X } __attribute__((mode(XX))) T;'.
   3486     // Try to get type from enum declaration, default to int.
   3487     OldTy = ED->getIntegerType();
   3488     if (OldTy.isNull())
   3489       OldTy = Context.IntTy;
   3490   } else
   3491     OldTy = cast<ValueDecl>(D)->getType();
   3492 
   3493   if (OldTy->isDependentType()) {
   3494     D->addAttr(::new (Context)
   3495                ModeAttr(AttrRange, Context, Name, SpellingListIndex));
   3496     return;
   3497   }
   3498 
   3499   // Base type can also be a vector type (see PR17453).
   3500   // Distinguish between base type and base element type.
   3501   QualType OldElemTy = OldTy;
   3502   if (const VectorType *VT = OldTy->getAs<VectorType>())
   3503     OldElemTy = VT->getElementType();
   3504 
   3505   // GCC allows 'mode' attribute on enumeration types (even incomplete), except
   3506   // for vector modes. So, 'enum X __attribute__((mode(QI)));' forms a complete
   3507   // type, 'enum { A } __attribute__((mode(V4SI)))' is rejected.
   3508   if ((isa<EnumDecl>(D) || OldElemTy->getAs<EnumType>()) &&
   3509       VectorSize.getBoolValue()) {
   3510     Diag(AttrLoc, diag::err_enum_mode_vector_type) << Name << AttrRange;
   3511     return;
   3512   }
   3513   bool IntegralOrAnyEnumType =
   3514       OldElemTy->isIntegralOrEnumerationType() || OldElemTy->getAs<EnumType>();
   3515 
   3516   if (!OldElemTy->getAs<BuiltinType>() && !OldElemTy->isComplexType() &&
   3517       !IntegralOrAnyEnumType)
   3518     Diag(AttrLoc, diag::err_mode_not_primitive);
   3519   else if (IntegerMode) {
   3520     if (!IntegralOrAnyEnumType)
   3521       Diag(AttrLoc, diag::err_mode_wrong_type);
   3522   } else if (ComplexMode) {
   3523     if (!OldElemTy->isComplexType())
   3524       Diag(AttrLoc, diag::err_mode_wrong_type);
   3525   } else {
   3526     if (!OldElemTy->isFloatingType())
   3527       Diag(AttrLoc, diag::err_mode_wrong_type);
   3528   }
   3529 
   3530   QualType NewElemTy;
   3531 
   3532   if (IntegerMode)
   3533     NewElemTy = Context.getIntTypeForBitwidth(DestWidth,
   3534                                               OldElemTy->isSignedIntegerType());
   3535   else
   3536     NewElemTy = Context.getRealTypeForBitwidth(DestWidth);
   3537 
   3538   if (NewElemTy.isNull()) {
   3539     Diag(AttrLoc, diag::err_machine_mode) << 1 /*Unsupported*/ << Name;
   3540     return;
   3541   }
   3542 
   3543   if (ComplexMode) {
   3544     NewElemTy = Context.getComplexType(NewElemTy);
   3545   }
   3546 
   3547   QualType NewTy = NewElemTy;
   3548   if (VectorSize.getBoolValue()) {
   3549     NewTy = Context.getVectorType(NewTy, VectorSize.getZExtValue(),
   3550                                   VectorType::GenericVector);
   3551   } else if (const VectorType *OldVT = OldTy->getAs<VectorType>()) {
   3552     // Complex machine mode does not support base vector types.
   3553     if (ComplexMode) {
   3554       Diag(AttrLoc, diag::err_complex_mode_vector_type);
   3555       return;
   3556     }
   3557     unsigned NumElements = Context.getTypeSize(OldElemTy) *
   3558                            OldVT->getNumElements() /
   3559                            Context.getTypeSize(NewElemTy);
   3560     NewTy =
   3561         Context.getVectorType(NewElemTy, NumElements, OldVT->getVectorKind());
   3562   }
   3563 
   3564   if (NewTy.isNull()) {
   3565     Diag(AttrLoc, diag::err_mode_wrong_type);
   3566     return;
   3567   }
   3568 
   3569   // Install the new type.
   3570   if (TypedefNameDecl *TD = dyn_cast<TypedefNameDecl>(D))
   3571     TD->setModedTypeSourceInfo(TD->getTypeSourceInfo(), NewTy);
   3572   else if (EnumDecl *ED = dyn_cast<EnumDecl>(D))
   3573     ED->setIntegerType(NewTy);
   3574   else
   3575     cast<ValueDecl>(D)->setType(NewTy);
   3576 
   3577   D->addAttr(::new (Context)
   3578              ModeAttr(AttrRange, Context, Name, SpellingListIndex));
   3579 }
   3580 
   3581 static void handleNoDebugAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   3582   D->addAttr(::new (S.Context)
   3583              NoDebugAttr(Attr.getRange(), S.Context,
   3584                          Attr.getAttributeSpellingListIndex()));
   3585 }
   3586 
   3587 AlwaysInlineAttr *Sema::mergeAlwaysInlineAttr(Decl *D, SourceRange Range,
   3588                                               IdentifierInfo *Ident,
   3589                                               unsigned AttrSpellingListIndex) {
   3590   if (OptimizeNoneAttr *Optnone = D->getAttr<OptimizeNoneAttr>()) {
   3591     Diag(Range.getBegin(), diag::warn_attribute_ignored) << Ident;
   3592     Diag(Optnone->getLocation(), diag::note_conflicting_attribute);
   3593     return nullptr;
   3594   }
   3595 
   3596   if (D->hasAttr<AlwaysInlineAttr>())
   3597     return nullptr;
   3598 
   3599   return ::new (Context) AlwaysInlineAttr(Range, Context,
   3600                                           AttrSpellingListIndex);
   3601 }
   3602 
   3603 CommonAttr *Sema::mergeCommonAttr(Decl *D, SourceRange Range,
   3604                                   IdentifierInfo *Ident,
   3605                                   unsigned AttrSpellingListIndex) {
   3606   if (checkAttrMutualExclusion<InternalLinkageAttr>(*this, D, Range, Ident))
   3607     return nullptr;
   3608 
   3609   return ::new (Context) CommonAttr(Range, Context, AttrSpellingListIndex);
   3610 }
   3611 
   3612 InternalLinkageAttr *
   3613 Sema::mergeInternalLinkageAttr(Decl *D, SourceRange Range,
   3614                                IdentifierInfo *Ident,
   3615                                unsigned AttrSpellingListIndex) {
   3616   if (auto VD = dyn_cast<VarDecl>(D)) {
   3617     // Attribute applies to Var but not any subclass of it (like ParmVar,
   3618     // ImplicitParm or VarTemplateSpecialization).
   3619     if (VD->getKind() != Decl::Var) {
   3620       Diag(Range.getBegin(), diag::warn_attribute_wrong_decl_type)
   3621           << Ident << (getLangOpts().CPlusPlus ? ExpectedFunctionVariableOrClass
   3622                                                : ExpectedVariableOrFunction);
   3623       return nullptr;
   3624     }
   3625     // Attribute does not apply to non-static local variables.
   3626     if (VD->hasLocalStorage()) {
   3627       Diag(VD->getLocation(), diag::warn_internal_linkage_local_storage);
   3628       return nullptr;
   3629     }
   3630   }
   3631 
   3632   if (checkAttrMutualExclusion<CommonAttr>(*this, D, Range, Ident))
   3633     return nullptr;
   3634 
   3635   return ::new (Context)
   3636       InternalLinkageAttr(Range, Context, AttrSpellingListIndex);
   3637 }
   3638 
   3639 MinSizeAttr *Sema::mergeMinSizeAttr(Decl *D, SourceRange Range,
   3640                                     unsigned AttrSpellingListIndex) {
   3641   if (OptimizeNoneAttr *Optnone = D->getAttr<OptimizeNoneAttr>()) {
   3642     Diag(Range.getBegin(), diag::warn_attribute_ignored) << "'minsize'";
   3643     Diag(Optnone->getLocation(), diag::note_conflicting_attribute);
   3644     return nullptr;
   3645   }
   3646 
   3647   if (D->hasAttr<MinSizeAttr>())
   3648     return nullptr;
   3649 
   3650   return ::new (Context) MinSizeAttr(Range, Context, AttrSpellingListIndex);
   3651 }
   3652 
   3653 OptimizeNoneAttr *Sema::mergeOptimizeNoneAttr(Decl *D, SourceRange Range,
   3654                                               unsigned AttrSpellingListIndex) {
   3655   if (AlwaysInlineAttr *Inline = D->getAttr<AlwaysInlineAttr>()) {
   3656     Diag(Inline->getLocation(), diag::warn_attribute_ignored) << Inline;
   3657     Diag(Range.getBegin(), diag::note_conflicting_attribute);
   3658     D->dropAttr<AlwaysInlineAttr>();
   3659   }
   3660   if (MinSizeAttr *MinSize = D->getAttr<MinSizeAttr>()) {
   3661     Diag(MinSize->getLocation(), diag::warn_attribute_ignored) << MinSize;
   3662     Diag(Range.getBegin(), diag::note_conflicting_attribute);
   3663     D->dropAttr<MinSizeAttr>();
   3664   }
   3665 
   3666   if (D->hasAttr<OptimizeNoneAttr>())
   3667     return nullptr;
   3668 
   3669   return ::new (Context) OptimizeNoneAttr(Range, Context,
   3670                                           AttrSpellingListIndex);
   3671 }
   3672 
   3673 static void handleAlwaysInlineAttr(Sema &S, Decl *D,
   3674                                    const AttributeList &Attr) {
   3675   if (checkAttrMutualExclusion<NotTailCalledAttr>(S, D, Attr.getRange(),
   3676                                                   Attr.getName()))
   3677     return;
   3678 
   3679   if (AlwaysInlineAttr *Inline = S.mergeAlwaysInlineAttr(
   3680           D, Attr.getRange(), Attr.getName(),
   3681           Attr.getAttributeSpellingListIndex()))
   3682     D->addAttr(Inline);
   3683 }
   3684 
   3685 static void handleMinSizeAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   3686   if (MinSizeAttr *MinSize = S.mergeMinSizeAttr(
   3687           D, Attr.getRange(), Attr.getAttributeSpellingListIndex()))
   3688     D->addAttr(MinSize);
   3689 }
   3690 
   3691 static void handleOptimizeNoneAttr(Sema &S, Decl *D,
   3692                                    const AttributeList &Attr) {
   3693   if (OptimizeNoneAttr *Optnone = S.mergeOptimizeNoneAttr(
   3694           D, Attr.getRange(), Attr.getAttributeSpellingListIndex()))
   3695     D->addAttr(Optnone);
   3696 }
   3697 
   3698 static void handleGlobalAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   3699   if (checkAttrMutualExclusion<CUDADeviceAttr>(S, D, Attr.getRange(),
   3700                                                Attr.getName()) ||
   3701       checkAttrMutualExclusion<CUDAHostAttr>(S, D, Attr.getRange(),
   3702                                              Attr.getName())) {
   3703     return;
   3704   }
   3705   FunctionDecl *FD = cast<FunctionDecl>(D);
   3706   if (!FD->getReturnType()->isVoidType()) {
   3707     SourceRange RTRange = FD->getReturnTypeSourceRange();
   3708     S.Diag(FD->getTypeSpecStartLoc(), diag::err_kern_type_not_void_return)
   3709         << FD->getType()
   3710         << (RTRange.isValid() ? FixItHint::CreateReplacement(RTRange, "void")
   3711                               : FixItHint());
   3712     return;
   3713   }
   3714   if (const auto *Method = dyn_cast<CXXMethodDecl>(FD)) {
   3715     if (Method->isInstance()) {
   3716       S.Diag(Method->getLocStart(), diag::err_kern_is_nonstatic_method)
   3717           << Method;
   3718       return;
   3719     }
   3720     S.Diag(Method->getLocStart(), diag::warn_kern_is_method) << Method;
   3721   }
   3722   // Only warn for "inline" when compiling for host, to cut down on noise.
   3723   if (FD->isInlineSpecified() && !S.getLangOpts().CUDAIsDevice)
   3724     S.Diag(FD->getLocStart(), diag::warn_kern_is_inline) << FD;
   3725 
   3726   D->addAttr(::new (S.Context)
   3727               CUDAGlobalAttr(Attr.getRange(), S.Context,
   3728                              Attr.getAttributeSpellingListIndex()));
   3729 }
   3730 
   3731 static void handleGNUInlineAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   3732   FunctionDecl *Fn = cast<FunctionDecl>(D);
   3733   if (!Fn->isInlineSpecified()) {
   3734     S.Diag(Attr.getLoc(), diag::warn_gnu_inline_attribute_requires_inline);
   3735     return;
   3736   }
   3737 
   3738   D->addAttr(::new (S.Context)
   3739              GNUInlineAttr(Attr.getRange(), S.Context,
   3740                            Attr.getAttributeSpellingListIndex()));
   3741 }
   3742 
   3743 static void handleCallConvAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   3744   if (hasDeclarator(D)) return;
   3745 
   3746   // Diagnostic is emitted elsewhere: here we store the (valid) Attr
   3747   // in the Decl node for syntactic reasoning, e.g., pretty-printing.
   3748   CallingConv CC;
   3749   if (S.CheckCallingConvAttr(Attr, CC, /*FD*/nullptr))
   3750     return;
   3751 
   3752   if (!isa<ObjCMethodDecl>(D)) {
   3753     S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   3754       << Attr.getName() << ExpectedFunctionOrMethod;
   3755     return;
   3756   }
   3757 
   3758   switch (Attr.getKind()) {
   3759   case AttributeList::AT_FastCall:
   3760     D->addAttr(::new (S.Context)
   3761                FastCallAttr(Attr.getRange(), S.Context,
   3762                             Attr.getAttributeSpellingListIndex()));
   3763     return;
   3764   case AttributeList::AT_StdCall:
   3765     D->addAttr(::new (S.Context)
   3766                StdCallAttr(Attr.getRange(), S.Context,
   3767                            Attr.getAttributeSpellingListIndex()));
   3768     return;
   3769   case AttributeList::AT_ThisCall:
   3770     D->addAttr(::new (S.Context)
   3771                ThisCallAttr(Attr.getRange(), S.Context,
   3772                             Attr.getAttributeSpellingListIndex()));
   3773     return;
   3774   case AttributeList::AT_CDecl:
   3775     D->addAttr(::new (S.Context)
   3776                CDeclAttr(Attr.getRange(), S.Context,
   3777                          Attr.getAttributeSpellingListIndex()));
   3778     return;
   3779   case AttributeList::AT_Pascal:
   3780     D->addAttr(::new (S.Context)
   3781                PascalAttr(Attr.getRange(), S.Context,
   3782                           Attr.getAttributeSpellingListIndex()));
   3783     return;
   3784   case AttributeList::AT_SwiftCall:
   3785     D->addAttr(::new (S.Context)
   3786                SwiftCallAttr(Attr.getRange(), S.Context,
   3787                              Attr.getAttributeSpellingListIndex()));
   3788     return;
   3789   case AttributeList::AT_VectorCall:
   3790     D->addAttr(::new (S.Context)
   3791                VectorCallAttr(Attr.getRange(), S.Context,
   3792                               Attr.getAttributeSpellingListIndex()));
   3793     return;
   3794   case AttributeList::AT_MSABI:
   3795     D->addAttr(::new (S.Context)
   3796                MSABIAttr(Attr.getRange(), S.Context,
   3797                          Attr.getAttributeSpellingListIndex()));
   3798     return;
   3799   case AttributeList::AT_SysVABI:
   3800     D->addAttr(::new (S.Context)
   3801                SysVABIAttr(Attr.getRange(), S.Context,
   3802                            Attr.getAttributeSpellingListIndex()));
   3803     return;
   3804   case AttributeList::AT_Pcs: {
   3805     PcsAttr::PCSType PCS;
   3806     switch (CC) {
   3807     case CC_AAPCS:
   3808       PCS = PcsAttr::AAPCS;
   3809       break;
   3810     case CC_AAPCS_VFP:
   3811       PCS = PcsAttr::AAPCS_VFP;
   3812       break;
   3813     default:
   3814       llvm_unreachable("unexpected calling convention in pcs attribute");
   3815     }
   3816 
   3817     D->addAttr(::new (S.Context)
   3818                PcsAttr(Attr.getRange(), S.Context, PCS,
   3819                        Attr.getAttributeSpellingListIndex()));
   3820     return;
   3821   }
   3822   case AttributeList::AT_IntelOclBicc:
   3823     D->addAttr(::new (S.Context)
   3824                IntelOclBiccAttr(Attr.getRange(), S.Context,
   3825                                 Attr.getAttributeSpellingListIndex()));
   3826     return;
   3827   case AttributeList::AT_PreserveMost:
   3828     D->addAttr(::new (S.Context) PreserveMostAttr(
   3829         Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   3830     return;
   3831   case AttributeList::AT_PreserveAll:
   3832     D->addAttr(::new (S.Context) PreserveAllAttr(
   3833         Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   3834     return;
   3835   default:
   3836     llvm_unreachable("unexpected attribute kind");
   3837   }
   3838 }
   3839 
   3840 bool Sema::CheckCallingConvAttr(const AttributeList &attr, CallingConv &CC,
   3841                                 const FunctionDecl *FD) {
   3842   if (attr.isInvalid())
   3843     return true;
   3844 
   3845   if (attr.hasProcessingCache()) {
   3846     CC = (CallingConv) attr.getProcessingCache();
   3847     return false;
   3848   }
   3849 
   3850   unsigned ReqArgs = attr.getKind() == AttributeList::AT_Pcs ? 1 : 0;
   3851   if (!checkAttributeNumArgs(*this, attr, ReqArgs)) {
   3852     attr.setInvalid();
   3853     return true;
   3854   }
   3855 
   3856   // TODO: diagnose uses of these conventions on the wrong target.
   3857   switch (attr.getKind()) {
   3858   case AttributeList::AT_CDecl: CC = CC_C; break;
   3859   case AttributeList::AT_FastCall: CC = CC_X86FastCall; break;
   3860   case AttributeList::AT_StdCall: CC = CC_X86StdCall; break;
   3861   case AttributeList::AT_ThisCall: CC = CC_X86ThisCall; break;
   3862   case AttributeList::AT_Pascal: CC = CC_X86Pascal; break;
   3863   case AttributeList::AT_SwiftCall: CC = CC_Swift; break;
   3864   case AttributeList::AT_VectorCall: CC = CC_X86VectorCall; break;
   3865   case AttributeList::AT_MSABI:
   3866     CC = Context.getTargetInfo().getTriple().isOSWindows() ? CC_C :
   3867                                                              CC_X86_64Win64;
   3868     break;
   3869   case AttributeList::AT_SysVABI:
   3870     CC = Context.getTargetInfo().getTriple().isOSWindows() ? CC_X86_64SysV :
   3871                                                              CC_C;
   3872     break;
   3873   case AttributeList::AT_Pcs: {
   3874     StringRef StrRef;
   3875     if (!checkStringLiteralArgumentAttr(attr, 0, StrRef)) {
   3876       attr.setInvalid();
   3877       return true;
   3878     }
   3879     if (StrRef == "aapcs") {
   3880       CC = CC_AAPCS;
   3881       break;
   3882     } else if (StrRef == "aapcs-vfp") {
   3883       CC = CC_AAPCS_VFP;
   3884       break;
   3885     }
   3886 
   3887     attr.setInvalid();
   3888     Diag(attr.getLoc(), diag::err_invalid_pcs);
   3889     return true;
   3890   }
   3891   case AttributeList::AT_IntelOclBicc: CC = CC_IntelOclBicc; break;
   3892   case AttributeList::AT_PreserveMost: CC = CC_PreserveMost; break;
   3893   case AttributeList::AT_PreserveAll: CC = CC_PreserveAll; break;
   3894   default: llvm_unreachable("unexpected attribute kind");
   3895   }
   3896 
   3897   const TargetInfo &TI = Context.getTargetInfo();
   3898   TargetInfo::CallingConvCheckResult A = TI.checkCallingConvention(CC);
   3899   if (A != TargetInfo::CCCR_OK) {
   3900     if (A == TargetInfo::CCCR_Warning)
   3901       Diag(attr.getLoc(), diag::warn_cconv_ignored) << attr.getName();
   3902 
   3903     // This convention is not valid for the target. Use the default function or
   3904     // method calling convention.
   3905     bool IsCXXMethod = false, IsVariadic = false;
   3906     if (FD) {
   3907       IsCXXMethod = FD->isCXXInstanceMember();
   3908       IsVariadic = FD->isVariadic();
   3909     }
   3910     CC = Context.getDefaultCallingConvention(IsVariadic, IsCXXMethod);
   3911   }
   3912 
   3913   attr.setProcessingCache((unsigned) CC);
   3914   return false;
   3915 }
   3916 
   3917 /// Pointer-like types in the default address space.
   3918 static bool isValidSwiftContextType(QualType type) {
   3919   if (!type->hasPointerRepresentation())
   3920     return type->isDependentType();
   3921   return type->getPointeeType().getAddressSpace() == 0;
   3922 }
   3923 
   3924 /// Pointers and references in the default address space.
   3925 static bool isValidSwiftIndirectResultType(QualType type) {
   3926   if (auto ptrType = type->getAs<PointerType>()) {
   3927     type = ptrType->getPointeeType();
   3928   } else if (auto refType = type->getAs<ReferenceType>()) {
   3929     type = refType->getPointeeType();
   3930   } else {
   3931     return type->isDependentType();
   3932   }
   3933   return type.getAddressSpace() == 0;
   3934 }
   3935 
   3936 /// Pointers and references to pointers in the default address space.
   3937 static bool isValidSwiftErrorResultType(QualType type) {
   3938   if (auto ptrType = type->getAs<PointerType>()) {
   3939     type = ptrType->getPointeeType();
   3940   } else if (auto refType = type->getAs<ReferenceType>()) {
   3941     type = refType->getPointeeType();
   3942   } else {
   3943     return type->isDependentType();
   3944   }
   3945   if (!type.getQualifiers().empty())
   3946     return false;
   3947   return isValidSwiftContextType(type);
   3948 }
   3949 
   3950 static void handleParameterABIAttr(Sema &S, Decl *D, const AttributeList &attr,
   3951                                    ParameterABI abi) {
   3952   S.AddParameterABIAttr(attr.getRange(), D, abi,
   3953                         attr.getAttributeSpellingListIndex());
   3954 }
   3955 
   3956 void Sema::AddParameterABIAttr(SourceRange range, Decl *D, ParameterABI abi,
   3957                                unsigned spellingIndex) {
   3958 
   3959   QualType type = cast<ParmVarDecl>(D)->getType();
   3960 
   3961   if (auto existingAttr = D->getAttr<ParameterABIAttr>()) {
   3962     if (existingAttr->getABI() != abi) {
   3963       Diag(range.getBegin(), diag::err_attributes_are_not_compatible)
   3964         << getParameterABISpelling(abi) << existingAttr;
   3965       Diag(existingAttr->getLocation(), diag::note_conflicting_attribute);
   3966       return;
   3967     }
   3968   }
   3969 
   3970   switch (abi) {
   3971   case ParameterABI::Ordinary:
   3972     llvm_unreachable("explicit attribute for ordinary parameter ABI?");
   3973 
   3974   case ParameterABI::SwiftContext:
   3975     if (!isValidSwiftContextType(type)) {
   3976       Diag(range.getBegin(), diag::err_swift_abi_parameter_wrong_type)
   3977         << getParameterABISpelling(abi)
   3978         << /*pointer to pointer */ 0 << type;
   3979     }
   3980     D->addAttr(::new (Context)
   3981                SwiftContextAttr(range, Context, spellingIndex));
   3982     return;
   3983 
   3984   case ParameterABI::SwiftErrorResult:
   3985     if (!isValidSwiftErrorResultType(type)) {
   3986       Diag(range.getBegin(), diag::err_swift_abi_parameter_wrong_type)
   3987         << getParameterABISpelling(abi)
   3988         << /*pointer to pointer */ 1 << type;
   3989     }
   3990     D->addAttr(::new (Context)
   3991                SwiftErrorResultAttr(range, Context, spellingIndex));
   3992     return;
   3993 
   3994   case ParameterABI::SwiftIndirectResult:
   3995     if (!isValidSwiftIndirectResultType(type)) {
   3996       Diag(range.getBegin(), diag::err_swift_abi_parameter_wrong_type)
   3997         << getParameterABISpelling(abi)
   3998         << /*pointer*/ 0 << type;
   3999     }
   4000     D->addAttr(::new (Context)
   4001                SwiftIndirectResultAttr(range, Context, spellingIndex));
   4002     return;
   4003   }
   4004   llvm_unreachable("bad parameter ABI attribute");
   4005 }
   4006 
   4007 /// Checks a regparm attribute, returning true if it is ill-formed and
   4008 /// otherwise setting numParams to the appropriate value.
   4009 bool Sema::CheckRegparmAttr(const AttributeList &Attr, unsigned &numParams) {
   4010   if (Attr.isInvalid())
   4011     return true;
   4012 
   4013   if (!checkAttributeNumArgs(*this, Attr, 1)) {
   4014     Attr.setInvalid();
   4015     return true;
   4016   }
   4017 
   4018   uint32_t NP;
   4019   Expr *NumParamsExpr = Attr.getArgAsExpr(0);
   4020   if (!checkUInt32Argument(*this, Attr, NumParamsExpr, NP)) {
   4021     Attr.setInvalid();
   4022     return true;
   4023   }
   4024 
   4025   if (Context.getTargetInfo().getRegParmMax() == 0) {
   4026     Diag(Attr.getLoc(), diag::err_attribute_regparm_wrong_platform)
   4027       << NumParamsExpr->getSourceRange();
   4028     Attr.setInvalid();
   4029     return true;
   4030   }
   4031 
   4032   numParams = NP;
   4033   if (numParams > Context.getTargetInfo().getRegParmMax()) {
   4034     Diag(Attr.getLoc(), diag::err_attribute_regparm_invalid_number)
   4035       << Context.getTargetInfo().getRegParmMax() << NumParamsExpr->getSourceRange();
   4036     Attr.setInvalid();
   4037     return true;
   4038   }
   4039 
   4040   return false;
   4041 }
   4042 
   4043 // Checks whether an argument of launch_bounds attribute is
   4044 // acceptable, performs implicit conversion to Rvalue, and returns
   4045 // non-nullptr Expr result on success. Otherwise, it returns nullptr
   4046 // and may output an error.
   4047 static Expr *makeLaunchBoundsArgExpr(Sema &S, Expr *E,
   4048                                      const CUDALaunchBoundsAttr &Attr,
   4049                                      const unsigned Idx) {
   4050   if (S.DiagnoseUnexpandedParameterPack(E))
   4051     return nullptr;
   4052 
   4053   // Accept template arguments for now as they depend on something else.
   4054   // We'll get to check them when they eventually get instantiated.
   4055   if (E->isValueDependent())
   4056     return E;
   4057 
   4058   llvm::APSInt I(64);
   4059   if (!E->isIntegerConstantExpr(I, S.Context)) {
   4060     S.Diag(E->getExprLoc(), diag::err_attribute_argument_n_type)
   4061         << &Attr << Idx << AANT_ArgumentIntegerConstant << E->getSourceRange();
   4062     return nullptr;
   4063   }
   4064   // Make sure we can fit it in 32 bits.
   4065   if (!I.isIntN(32)) {
   4066     S.Diag(E->getExprLoc(), diag::err_ice_too_large) << I.toString(10, false)
   4067                                                      << 32 << /* Unsigned */ 1;
   4068     return nullptr;
   4069   }
   4070   if (I < 0)
   4071     S.Diag(E->getExprLoc(), diag::warn_attribute_argument_n_negative)
   4072         << &Attr << Idx << E->getSourceRange();
   4073 
   4074   // We may need to perform implicit conversion of the argument.
   4075   InitializedEntity Entity = InitializedEntity::InitializeParameter(
   4076       S.Context, S.Context.getConstType(S.Context.IntTy), /*consume*/ false);
   4077   ExprResult ValArg = S.PerformCopyInitialization(Entity, SourceLocation(), E);
   4078   assert(!ValArg.isInvalid() &&
   4079          "Unexpected PerformCopyInitialization() failure.");
   4080 
   4081   return ValArg.getAs<Expr>();
   4082 }
   4083 
   4084 void Sema::AddLaunchBoundsAttr(SourceRange AttrRange, Decl *D, Expr *MaxThreads,
   4085                                Expr *MinBlocks, unsigned SpellingListIndex) {
   4086   CUDALaunchBoundsAttr TmpAttr(AttrRange, Context, MaxThreads, MinBlocks,
   4087                                SpellingListIndex);
   4088   MaxThreads = makeLaunchBoundsArgExpr(*this, MaxThreads, TmpAttr, 0);
   4089   if (MaxThreads == nullptr)
   4090     return;
   4091 
   4092   if (MinBlocks) {
   4093     MinBlocks = makeLaunchBoundsArgExpr(*this, MinBlocks, TmpAttr, 1);
   4094     if (MinBlocks == nullptr)
   4095       return;
   4096   }
   4097 
   4098   D->addAttr(::new (Context) CUDALaunchBoundsAttr(
   4099       AttrRange, Context, MaxThreads, MinBlocks, SpellingListIndex));
   4100 }
   4101 
   4102 static void handleLaunchBoundsAttr(Sema &S, Decl *D,
   4103                                    const AttributeList &Attr) {
   4104   if (!checkAttributeAtLeastNumArgs(S, Attr, 1) ||
   4105       !checkAttributeAtMostNumArgs(S, Attr, 2))
   4106     return;
   4107 
   4108   S.AddLaunchBoundsAttr(Attr.getRange(), D, Attr.getArgAsExpr(0),
   4109                         Attr.getNumArgs() > 1 ? Attr.getArgAsExpr(1) : nullptr,
   4110                         Attr.getAttributeSpellingListIndex());
   4111 }
   4112 
   4113 static void handleArgumentWithTypeTagAttr(Sema &S, Decl *D,
   4114                                           const AttributeList &Attr) {
   4115   if (!Attr.isArgIdent(0)) {
   4116     S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
   4117       << Attr.getName() << /* arg num = */ 1 << AANT_ArgumentIdentifier;
   4118     return;
   4119   }
   4120 
   4121   if (!checkAttributeNumArgs(S, Attr, 3))
   4122     return;
   4123 
   4124   IdentifierInfo *ArgumentKind = Attr.getArgAsIdent(0)->Ident;
   4125 
   4126   if (!isFunctionOrMethod(D) || !hasFunctionProto(D)) {
   4127     S.Diag(Attr.getLoc(), diag::err_attribute_wrong_decl_type)
   4128       << Attr.getName() << ExpectedFunctionOrMethod;
   4129     return;
   4130   }
   4131 
   4132   uint64_t ArgumentIdx;
   4133   if (!checkFunctionOrMethodParameterIndex(S, D, Attr, 2, Attr.getArgAsExpr(1),
   4134                                            ArgumentIdx))
   4135     return;
   4136 
   4137   uint64_t TypeTagIdx;
   4138   if (!checkFunctionOrMethodParameterIndex(S, D, Attr, 3, Attr.getArgAsExpr(2),
   4139                                            TypeTagIdx))
   4140     return;
   4141 
   4142   bool IsPointer = (Attr.getName()->getName() == "pointer_with_type_tag");
   4143   if (IsPointer) {
   4144     // Ensure that buffer has a pointer type.
   4145     QualType BufferTy = getFunctionOrMethodParamType(D, ArgumentIdx);
   4146     if (!BufferTy->isPointerType()) {
   4147       S.Diag(Attr.getLoc(), diag::err_attribute_pointers_only)
   4148         << Attr.getName() << 0;
   4149     }
   4150   }
   4151 
   4152   D->addAttr(::new (S.Context)
   4153              ArgumentWithTypeTagAttr(Attr.getRange(), S.Context, ArgumentKind,
   4154                                      ArgumentIdx, TypeTagIdx, IsPointer,
   4155                                      Attr.getAttributeSpellingListIndex()));
   4156 }
   4157 
   4158 static void handleTypeTagForDatatypeAttr(Sema &S, Decl *D,
   4159                                          const AttributeList &Attr) {
   4160   if (!Attr.isArgIdent(0)) {
   4161     S.Diag(Attr.getLoc(), diag::err_attribute_argument_n_type)
   4162       << Attr.getName() << 1 << AANT_ArgumentIdentifier;
   4163     return;
   4164   }
   4165 
   4166   if (!checkAttributeNumArgs(S, Attr, 1))
   4167     return;
   4168 
   4169   if (!isa<VarDecl>(D)) {
   4170     S.Diag(Attr.getLoc(), diag::err_attribute_wrong_decl_type)
   4171       << Attr.getName() << ExpectedVariable;
   4172     return;
   4173   }
   4174 
   4175   IdentifierInfo *PointerKind = Attr.getArgAsIdent(0)->Ident;
   4176   TypeSourceInfo *MatchingCTypeLoc = nullptr;
   4177   S.GetTypeFromParser(Attr.getMatchingCType(), &MatchingCTypeLoc);
   4178   assert(MatchingCTypeLoc && "no type source info for attribute argument");
   4179 
   4180   D->addAttr(::new (S.Context)
   4181              TypeTagForDatatypeAttr(Attr.getRange(), S.Context, PointerKind,
   4182                                     MatchingCTypeLoc,
   4183                                     Attr.getLayoutCompatible(),
   4184                                     Attr.getMustBeNull(),
   4185                                     Attr.getAttributeSpellingListIndex()));
   4186 }
   4187 
   4188 //===----------------------------------------------------------------------===//
   4189 // Checker-specific attribute handlers.
   4190 //===----------------------------------------------------------------------===//
   4191 
   4192 static bool isValidSubjectOfNSReturnsRetainedAttribute(QualType type) {
   4193   return type->isDependentType() ||
   4194          type->isObjCRetainableType();
   4195 }
   4196 
   4197 static bool isValidSubjectOfNSAttribute(Sema &S, QualType type) {
   4198   return type->isDependentType() ||
   4199          type->isObjCObjectPointerType() ||
   4200          S.Context.isObjCNSObjectType(type);
   4201 }
   4202 
   4203 static bool isValidSubjectOfCFAttribute(Sema &S, QualType type) {
   4204   return type->isDependentType() ||
   4205          type->isPointerType() ||
   4206          isValidSubjectOfNSAttribute(S, type);
   4207 }
   4208 
   4209 static void handleNSConsumedAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   4210   S.AddNSConsumedAttr(Attr.getRange(), D, Attr.getAttributeSpellingListIndex(),
   4211                       Attr.getKind() == AttributeList::AT_NSConsumed,
   4212                       /*template instantiation*/ false);
   4213 }
   4214 
   4215 void Sema::AddNSConsumedAttr(SourceRange attrRange, Decl *D,
   4216                              unsigned spellingIndex, bool isNSConsumed,
   4217                              bool isTemplateInstantiation) {
   4218   ParmVarDecl *param = cast<ParmVarDecl>(D);
   4219   bool typeOK;
   4220 
   4221   if (isNSConsumed) {
   4222     typeOK = isValidSubjectOfNSAttribute(*this, param->getType());
   4223   } else {
   4224     typeOK = isValidSubjectOfCFAttribute(*this, param->getType());
   4225   }
   4226 
   4227   if (!typeOK) {
   4228     // These attributes are normally just advisory, but in ARC, ns_consumed
   4229     // is significant.  Allow non-dependent code to contain inappropriate
   4230     // attributes even in ARC, but require template instantiations to be
   4231     // set up correctly.
   4232     Diag(D->getLocStart(),
   4233          (isTemplateInstantiation && isNSConsumed &&
   4234             getLangOpts().ObjCAutoRefCount
   4235           ? diag::err_ns_attribute_wrong_parameter_type
   4236           : diag::warn_ns_attribute_wrong_parameter_type))
   4237       << attrRange
   4238       << (isNSConsumed ? "ns_consumed" : "cf_consumed")
   4239       << (isNSConsumed ? /*objc pointers*/ 0 : /*cf pointers*/ 1);
   4240     return;
   4241   }
   4242 
   4243   if (isNSConsumed)
   4244     param->addAttr(::new (Context)
   4245                    NSConsumedAttr(attrRange, Context, spellingIndex));
   4246   else
   4247     param->addAttr(::new (Context)
   4248                    CFConsumedAttr(attrRange, Context, spellingIndex));
   4249 }
   4250 
   4251 static void handleNSReturnsRetainedAttr(Sema &S, Decl *D,
   4252                                         const AttributeList &Attr) {
   4253   QualType returnType;
   4254 
   4255   if (ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D))
   4256     returnType = MD->getReturnType();
   4257   else if (S.getLangOpts().ObjCAutoRefCount && hasDeclarator(D) &&
   4258            (Attr.getKind() == AttributeList::AT_NSReturnsRetained))
   4259     return; // ignore: was handled as a type attribute
   4260   else if (ObjCPropertyDecl *PD = dyn_cast<ObjCPropertyDecl>(D))
   4261     returnType = PD->getType();
   4262   else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D))
   4263     returnType = FD->getReturnType();
   4264   else if (auto *Param = dyn_cast<ParmVarDecl>(D)) {
   4265     returnType = Param->getType()->getPointeeType();
   4266     if (returnType.isNull()) {
   4267       S.Diag(D->getLocStart(), diag::warn_ns_attribute_wrong_parameter_type)
   4268           << Attr.getName() << /*pointer-to-CF*/2
   4269           << Attr.getRange();
   4270       return;
   4271     }
   4272   } else {
   4273     AttributeDeclKind ExpectedDeclKind;
   4274     switch (Attr.getKind()) {
   4275     default: llvm_unreachable("invalid ownership attribute");
   4276     case AttributeList::AT_NSReturnsRetained:
   4277     case AttributeList::AT_NSReturnsAutoreleased:
   4278     case AttributeList::AT_NSReturnsNotRetained:
   4279       ExpectedDeclKind = ExpectedFunctionOrMethod;
   4280       break;
   4281 
   4282     case AttributeList::AT_CFReturnsRetained:
   4283     case AttributeList::AT_CFReturnsNotRetained:
   4284       ExpectedDeclKind = ExpectedFunctionMethodOrParameter;
   4285       break;
   4286     }
   4287     S.Diag(D->getLocStart(), diag::warn_attribute_wrong_decl_type)
   4288         << Attr.getRange() << Attr.getName() << ExpectedDeclKind;
   4289     return;
   4290   }
   4291 
   4292   bool typeOK;
   4293   bool cf;
   4294   switch (Attr.getKind()) {
   4295   default: llvm_unreachable("invalid ownership attribute");
   4296   case AttributeList::AT_NSReturnsRetained:
   4297     typeOK = isValidSubjectOfNSReturnsRetainedAttribute(returnType);
   4298     cf = false;
   4299     break;
   4300 
   4301   case AttributeList::AT_NSReturnsAutoreleased:
   4302   case AttributeList::AT_NSReturnsNotRetained:
   4303     typeOK = isValidSubjectOfNSAttribute(S, returnType);
   4304     cf = false;
   4305     break;
   4306 
   4307   case AttributeList::AT_CFReturnsRetained:
   4308   case AttributeList::AT_CFReturnsNotRetained:
   4309     typeOK = isValidSubjectOfCFAttribute(S, returnType);
   4310     cf = true;
   4311     break;
   4312   }
   4313 
   4314   if (!typeOK) {
   4315     if (isa<ParmVarDecl>(D)) {
   4316       S.Diag(D->getLocStart(), diag::warn_ns_attribute_wrong_parameter_type)
   4317           << Attr.getName() << /*pointer-to-CF*/2
   4318           << Attr.getRange();
   4319     } else {
   4320       // Needs to be kept in sync with warn_ns_attribute_wrong_return_type.
   4321       enum : unsigned {
   4322         Function,
   4323         Method,
   4324         Property
   4325       } SubjectKind = Function;
   4326       if (isa<ObjCMethodDecl>(D))
   4327         SubjectKind = Method;
   4328       else if (isa<ObjCPropertyDecl>(D))
   4329         SubjectKind = Property;
   4330       S.Diag(D->getLocStart(), diag::warn_ns_attribute_wrong_return_type)
   4331           << Attr.getName() << SubjectKind << cf
   4332           << Attr.getRange();
   4333     }
   4334     return;
   4335   }
   4336 
   4337   switch (Attr.getKind()) {
   4338     default:
   4339       llvm_unreachable("invalid ownership attribute");
   4340     case AttributeList::AT_NSReturnsAutoreleased:
   4341       D->addAttr(::new (S.Context) NSReturnsAutoreleasedAttr(
   4342           Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   4343       return;
   4344     case AttributeList::AT_CFReturnsNotRetained:
   4345       D->addAttr(::new (S.Context) CFReturnsNotRetainedAttr(
   4346           Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   4347       return;
   4348     case AttributeList::AT_NSReturnsNotRetained:
   4349       D->addAttr(::new (S.Context) NSReturnsNotRetainedAttr(
   4350           Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   4351       return;
   4352     case AttributeList::AT_CFReturnsRetained:
   4353       D->addAttr(::new (S.Context) CFReturnsRetainedAttr(
   4354           Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   4355       return;
   4356     case AttributeList::AT_NSReturnsRetained:
   4357       D->addAttr(::new (S.Context) NSReturnsRetainedAttr(
   4358           Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   4359       return;
   4360   };
   4361 }
   4362 
   4363 static void handleObjCReturnsInnerPointerAttr(Sema &S, Decl *D,
   4364                                               const AttributeList &attr) {
   4365   const int EP_ObjCMethod = 1;
   4366   const int EP_ObjCProperty = 2;
   4367 
   4368   SourceLocation loc = attr.getLoc();
   4369   QualType resultType;
   4370   if (isa<ObjCMethodDecl>(D))
   4371     resultType = cast<ObjCMethodDecl>(D)->getReturnType();
   4372   else
   4373     resultType = cast<ObjCPropertyDecl>(D)->getType();
   4374 
   4375   if (!resultType->isReferenceType() &&
   4376       (!resultType->isPointerType() || resultType->isObjCRetainableType())) {
   4377     S.Diag(D->getLocStart(), diag::warn_ns_attribute_wrong_return_type)
   4378       << SourceRange(loc)
   4379     << attr.getName()
   4380     << (isa<ObjCMethodDecl>(D) ? EP_ObjCMethod : EP_ObjCProperty)
   4381     << /*non-retainable pointer*/ 2;
   4382 
   4383     // Drop the attribute.
   4384     return;
   4385   }
   4386 
   4387   D->addAttr(::new (S.Context) ObjCReturnsInnerPointerAttr(
   4388       attr.getRange(), S.Context, attr.getAttributeSpellingListIndex()));
   4389 }
   4390 
   4391 static void handleObjCRequiresSuperAttr(Sema &S, Decl *D,
   4392                                         const AttributeList &attr) {
   4393   ObjCMethodDecl *method = cast<ObjCMethodDecl>(D);
   4394 
   4395   DeclContext *DC = method->getDeclContext();
   4396   if (const ObjCProtocolDecl *PDecl = dyn_cast_or_null<ObjCProtocolDecl>(DC)) {
   4397     S.Diag(D->getLocStart(), diag::warn_objc_requires_super_protocol)
   4398     << attr.getName() << 0;
   4399     S.Diag(PDecl->getLocation(), diag::note_protocol_decl);
   4400     return;
   4401   }
   4402   if (method->getMethodFamily() == OMF_dealloc) {
   4403     S.Diag(D->getLocStart(), diag::warn_objc_requires_super_protocol)
   4404     << attr.getName() << 1;
   4405     return;
   4406   }
   4407 
   4408   method->addAttr(::new (S.Context)
   4409                   ObjCRequiresSuperAttr(attr.getRange(), S.Context,
   4410                                         attr.getAttributeSpellingListIndex()));
   4411 }
   4412 
   4413 static void handleCFAuditedTransferAttr(Sema &S, Decl *D,
   4414                                         const AttributeList &Attr) {
   4415   if (checkAttrMutualExclusion<CFUnknownTransferAttr>(S, D, Attr.getRange(),
   4416                                                       Attr.getName()))
   4417     return;
   4418 
   4419   D->addAttr(::new (S.Context)
   4420              CFAuditedTransferAttr(Attr.getRange(), S.Context,
   4421                                    Attr.getAttributeSpellingListIndex()));
   4422 }
   4423 
   4424 static void handleCFUnknownTransferAttr(Sema &S, Decl *D,
   4425                                         const AttributeList &Attr) {
   4426   if (checkAttrMutualExclusion<CFAuditedTransferAttr>(S, D, Attr.getRange(),
   4427                                                       Attr.getName()))
   4428     return;
   4429 
   4430   D->addAttr(::new (S.Context)
   4431              CFUnknownTransferAttr(Attr.getRange(), S.Context,
   4432              Attr.getAttributeSpellingListIndex()));
   4433 }
   4434 
   4435 static void handleObjCBridgeAttr(Sema &S, Scope *Sc, Decl *D,
   4436                                 const AttributeList &Attr) {
   4437   IdentifierLoc * Parm = Attr.isArgIdent(0) ? Attr.getArgAsIdent(0) : nullptr;
   4438 
   4439   if (!Parm) {
   4440     S.Diag(D->getLocStart(), diag::err_objc_attr_not_id) << Attr.getName() << 0;
   4441     return;
   4442   }
   4443 
   4444   // Typedefs only allow objc_bridge(id) and have some additional checking.
   4445   if (auto TD = dyn_cast<TypedefNameDecl>(D)) {
   4446     if (!Parm->Ident->isStr("id")) {
   4447       S.Diag(Attr.getLoc(), diag::err_objc_attr_typedef_not_id)
   4448         << Attr.getName();
   4449       return;
   4450     }
   4451 
   4452     // Only allow 'cv void *'.
   4453     QualType T = TD->getUnderlyingType();
   4454     if (!T->isVoidPointerType()) {
   4455       S.Diag(Attr.getLoc(), diag::err_objc_attr_typedef_not_void_pointer);
   4456       return;
   4457     }
   4458   }
   4459 
   4460   D->addAttr(::new (S.Context)
   4461              ObjCBridgeAttr(Attr.getRange(), S.Context, Parm->Ident,
   4462                            Attr.getAttributeSpellingListIndex()));
   4463 }
   4464 
   4465 static void handleObjCBridgeMutableAttr(Sema &S, Scope *Sc, Decl *D,
   4466                                         const AttributeList &Attr) {
   4467   IdentifierLoc * Parm = Attr.isArgIdent(0) ? Attr.getArgAsIdent(0) : nullptr;
   4468 
   4469   if (!Parm) {
   4470     S.Diag(D->getLocStart(), diag::err_objc_attr_not_id) << Attr.getName() << 0;
   4471     return;
   4472   }
   4473 
   4474   D->addAttr(::new (S.Context)
   4475              ObjCBridgeMutableAttr(Attr.getRange(), S.Context, Parm->Ident,
   4476                             Attr.getAttributeSpellingListIndex()));
   4477 }
   4478 
   4479 static void handleObjCBridgeRelatedAttr(Sema &S, Scope *Sc, Decl *D,
   4480                                  const AttributeList &Attr) {
   4481   IdentifierInfo *RelatedClass =
   4482     Attr.isArgIdent(0) ? Attr.getArgAsIdent(0)->Ident : nullptr;
   4483   if (!RelatedClass) {
   4484     S.Diag(D->getLocStart(), diag::err_objc_attr_not_id) << Attr.getName() << 0;
   4485     return;
   4486   }
   4487   IdentifierInfo *ClassMethod =
   4488     Attr.getArgAsIdent(1) ? Attr.getArgAsIdent(1)->Ident : nullptr;
   4489   IdentifierInfo *InstanceMethod =
   4490     Attr.getArgAsIdent(2) ? Attr.getArgAsIdent(2)->Ident : nullptr;
   4491   D->addAttr(::new (S.Context)
   4492              ObjCBridgeRelatedAttr(Attr.getRange(), S.Context, RelatedClass,
   4493                                    ClassMethod, InstanceMethod,
   4494                                    Attr.getAttributeSpellingListIndex()));
   4495 }
   4496 
   4497 static void handleObjCDesignatedInitializer(Sema &S, Decl *D,
   4498                                             const AttributeList &Attr) {
   4499   ObjCInterfaceDecl *IFace;
   4500   if (ObjCCategoryDecl *CatDecl =
   4501           dyn_cast<ObjCCategoryDecl>(D->getDeclContext()))
   4502     IFace = CatDecl->getClassInterface();
   4503   else
   4504     IFace = cast<ObjCInterfaceDecl>(D->getDeclContext());
   4505 
   4506   if (!IFace)
   4507     return;
   4508 
   4509   IFace->setHasDesignatedInitializers();
   4510   D->addAttr(::new (S.Context)
   4511                   ObjCDesignatedInitializerAttr(Attr.getRange(), S.Context,
   4512                                          Attr.getAttributeSpellingListIndex()));
   4513 }
   4514 
   4515 static void handleObjCRuntimeName(Sema &S, Decl *D,
   4516                                   const AttributeList &Attr) {
   4517   StringRef MetaDataName;
   4518   if (!S.checkStringLiteralArgumentAttr(Attr, 0, MetaDataName))
   4519     return;
   4520   D->addAttr(::new (S.Context)
   4521              ObjCRuntimeNameAttr(Attr.getRange(), S.Context,
   4522                                  MetaDataName,
   4523                                  Attr.getAttributeSpellingListIndex()));
   4524 }
   4525 
   4526 // When a user wants to use objc_boxable with a union or struct
   4527 // but they don't have access to the declaration (legacy/third-party code)
   4528 // then they can 'enable' this feature with a typedef:
   4529 // typedef struct __attribute((objc_boxable)) legacy_struct legacy_struct;
   4530 static void handleObjCBoxable(Sema &S, Decl *D, const AttributeList &Attr) {
   4531   bool notify = false;
   4532 
   4533   RecordDecl *RD = dyn_cast<RecordDecl>(D);
   4534   if (RD && RD->getDefinition()) {
   4535     RD = RD->getDefinition();
   4536     notify = true;
   4537   }
   4538 
   4539   if (RD) {
   4540     ObjCBoxableAttr *BoxableAttr = ::new (S.Context)
   4541                           ObjCBoxableAttr(Attr.getRange(), S.Context,
   4542                                           Attr.getAttributeSpellingListIndex());
   4543     RD->addAttr(BoxableAttr);
   4544     if (notify) {
   4545       // we need to notify ASTReader/ASTWriter about
   4546       // modification of existing declaration
   4547       if (ASTMutationListener *L = S.getASTMutationListener())
   4548         L->AddedAttributeToRecord(BoxableAttr, RD);
   4549     }
   4550   }
   4551 }
   4552 
   4553 static void handleObjCOwnershipAttr(Sema &S, Decl *D,
   4554                                     const AttributeList &Attr) {
   4555   if (hasDeclarator(D)) return;
   4556 
   4557   S.Diag(D->getLocStart(), diag::err_attribute_wrong_decl_type)
   4558     << Attr.getRange() << Attr.getName() << ExpectedVariable;
   4559 }
   4560 
   4561 static void handleObjCPreciseLifetimeAttr(Sema &S, Decl *D,
   4562                                           const AttributeList &Attr) {
   4563   ValueDecl *vd = cast<ValueDecl>(D);
   4564   QualType type = vd->getType();
   4565 
   4566   if (!type->isDependentType() &&
   4567       !type->isObjCLifetimeType()) {
   4568     S.Diag(Attr.getLoc(), diag::err_objc_precise_lifetime_bad_type)
   4569       << type;
   4570     return;
   4571   }
   4572 
   4573   Qualifiers::ObjCLifetime lifetime = type.getObjCLifetime();
   4574 
   4575   // If we have no lifetime yet, check the lifetime we're presumably
   4576   // going to infer.
   4577   if (lifetime == Qualifiers::OCL_None && !type->isDependentType())
   4578     lifetime = type->getObjCARCImplicitLifetime();
   4579 
   4580   switch (lifetime) {
   4581   case Qualifiers::OCL_None:
   4582     assert(type->isDependentType() &&
   4583            "didn't infer lifetime for non-dependent type?");
   4584     break;
   4585 
   4586   case Qualifiers::OCL_Weak:   // meaningful
   4587   case Qualifiers::OCL_Strong: // meaningful
   4588     break;
   4589 
   4590   case Qualifiers::OCL_ExplicitNone:
   4591   case Qualifiers::OCL_Autoreleasing:
   4592     S.Diag(Attr.getLoc(), diag::warn_objc_precise_lifetime_meaningless)
   4593       << (lifetime == Qualifiers::OCL_Autoreleasing);
   4594     break;
   4595   }
   4596 
   4597   D->addAttr(::new (S.Context)
   4598              ObjCPreciseLifetimeAttr(Attr.getRange(), S.Context,
   4599                                      Attr.getAttributeSpellingListIndex()));
   4600 }
   4601 
   4602 //===----------------------------------------------------------------------===//
   4603 // Microsoft specific attribute handlers.
   4604 //===----------------------------------------------------------------------===//
   4605 
   4606 static void handleUuidAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   4607   if (!S.LangOpts.CPlusPlus) {
   4608     S.Diag(Attr.getLoc(), diag::err_attribute_not_supported_in_lang)
   4609       << Attr.getName() << AttributeLangSupport::C;
   4610     return;
   4611   }
   4612 
   4613   if (!isa<CXXRecordDecl>(D)) {
   4614     S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   4615       << Attr.getName() << ExpectedClass;
   4616     return;
   4617   }
   4618 
   4619   StringRef StrRef;
   4620   SourceLocation LiteralLoc;
   4621   if (!S.checkStringLiteralArgumentAttr(Attr, 0, StrRef, &LiteralLoc))
   4622     return;
   4623 
   4624   // GUID format is "XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX" or
   4625   // "{XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}", normalize to the former.
   4626   if (StrRef.size() == 38 && StrRef.front() == '{' && StrRef.back() == '}')
   4627     StrRef = StrRef.drop_front().drop_back();
   4628 
   4629   // Validate GUID length.
   4630   if (StrRef.size() != 36) {
   4631     S.Diag(LiteralLoc, diag::err_attribute_uuid_malformed_guid);
   4632     return;
   4633   }
   4634 
   4635   for (unsigned i = 0; i < 36; ++i) {
   4636     if (i == 8 || i == 13 || i == 18 || i == 23) {
   4637       if (StrRef[i] != '-') {
   4638         S.Diag(LiteralLoc, diag::err_attribute_uuid_malformed_guid);
   4639         return;
   4640       }
   4641     } else if (!isHexDigit(StrRef[i])) {
   4642       S.Diag(LiteralLoc, diag::err_attribute_uuid_malformed_guid);
   4643       return;
   4644     }
   4645   }
   4646 
   4647   D->addAttr(::new (S.Context) UuidAttr(Attr.getRange(), S.Context, StrRef,
   4648                                         Attr.getAttributeSpellingListIndex()));
   4649 }
   4650 
   4651 static void handleMSInheritanceAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   4652   if (!S.LangOpts.CPlusPlus) {
   4653     S.Diag(Attr.getLoc(), diag::err_attribute_not_supported_in_lang)
   4654       << Attr.getName() << AttributeLangSupport::C;
   4655     return;
   4656   }
   4657   MSInheritanceAttr *IA = S.mergeMSInheritanceAttr(
   4658       D, Attr.getRange(), /*BestCase=*/true,
   4659       Attr.getAttributeSpellingListIndex(),
   4660       (MSInheritanceAttr::Spelling)Attr.getSemanticSpelling());
   4661   if (IA) {
   4662     D->addAttr(IA);
   4663     S.Consumer.AssignInheritanceModel(cast<CXXRecordDecl>(D));
   4664   }
   4665 }
   4666 
   4667 static void handleDeclspecThreadAttr(Sema &S, Decl *D,
   4668                                      const AttributeList &Attr) {
   4669   VarDecl *VD = cast<VarDecl>(D);
   4670   if (!S.Context.getTargetInfo().isTLSSupported()) {
   4671     S.Diag(Attr.getLoc(), diag::err_thread_unsupported);
   4672     return;
   4673   }
   4674   if (VD->getTSCSpec() != TSCS_unspecified) {
   4675     S.Diag(Attr.getLoc(), diag::err_declspec_thread_on_thread_variable);
   4676     return;
   4677   }
   4678   if (VD->hasLocalStorage()) {
   4679     S.Diag(Attr.getLoc(), diag::err_thread_non_global) << "__declspec(thread)";
   4680     return;
   4681   }
   4682   VD->addAttr(::new (S.Context) ThreadAttr(
   4683       Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   4684 }
   4685 
   4686 static void handleAbiTagAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   4687   SmallVector<StringRef, 4> Tags;
   4688   for (unsigned I = 0, E = Attr.getNumArgs(); I != E; ++I) {
   4689     StringRef Tag;
   4690     if (!S.checkStringLiteralArgumentAttr(Attr, I, Tag))
   4691       return;
   4692     Tags.push_back(Tag);
   4693   }
   4694 
   4695   if (const auto *NS = dyn_cast<NamespaceDecl>(D)) {
   4696     if (!NS->isInline()) {
   4697       S.Diag(Attr.getLoc(), diag::warn_attr_abi_tag_namespace) << 0;
   4698       return;
   4699     }
   4700     if (NS->isAnonymousNamespace()) {
   4701       S.Diag(Attr.getLoc(), diag::warn_attr_abi_tag_namespace) << 1;
   4702       return;
   4703     }
   4704     if (Attr.getNumArgs() == 0)
   4705       Tags.push_back(NS->getName());
   4706   } else if (!checkAttributeAtLeastNumArgs(S, Attr, 1))
   4707     return;
   4708 
   4709   // Store tags sorted and without duplicates.
   4710   std::sort(Tags.begin(), Tags.end());
   4711   Tags.erase(std::unique(Tags.begin(), Tags.end()), Tags.end());
   4712 
   4713   D->addAttr(::new (S.Context)
   4714              AbiTagAttr(Attr.getRange(), S.Context, Tags.data(), Tags.size(),
   4715                         Attr.getAttributeSpellingListIndex()));
   4716 }
   4717 
   4718 static void handleARMInterruptAttr(Sema &S, Decl *D,
   4719                                    const AttributeList &Attr) {
   4720   // Check the attribute arguments.
   4721   if (Attr.getNumArgs() > 1) {
   4722     S.Diag(Attr.getLoc(), diag::err_attribute_too_many_arguments)
   4723       << Attr.getName() << 1;
   4724     return;
   4725   }
   4726 
   4727   StringRef Str;
   4728   SourceLocation ArgLoc;
   4729 
   4730   if (Attr.getNumArgs() == 0)
   4731     Str = "";
   4732   else if (!S.checkStringLiteralArgumentAttr(Attr, 0, Str, &ArgLoc))
   4733     return;
   4734 
   4735   ARMInterruptAttr::InterruptType Kind;
   4736   if (!ARMInterruptAttr::ConvertStrToInterruptType(Str, Kind)) {
   4737     S.Diag(Attr.getLoc(), diag::warn_attribute_type_not_supported)
   4738       << Attr.getName() << Str << ArgLoc;
   4739     return;
   4740   }
   4741 
   4742   unsigned Index = Attr.getAttributeSpellingListIndex();
   4743   D->addAttr(::new (S.Context)
   4744              ARMInterruptAttr(Attr.getLoc(), S.Context, Kind, Index));
   4745 }
   4746 
   4747 static void handleMSP430InterruptAttr(Sema &S, Decl *D,
   4748                                       const AttributeList &Attr) {
   4749   if (!checkAttributeNumArgs(S, Attr, 1))
   4750     return;
   4751 
   4752   if (!Attr.isArgExpr(0)) {
   4753     S.Diag(Attr.getLoc(), diag::err_attribute_argument_type) << Attr.getName()
   4754       << AANT_ArgumentIntegerConstant;
   4755     return;
   4756   }
   4757 
   4758   // FIXME: Check for decl - it should be void ()(void).
   4759 
   4760   Expr *NumParamsExpr = static_cast<Expr *>(Attr.getArgAsExpr(0));
   4761   llvm::APSInt NumParams(32);
   4762   if (!NumParamsExpr->isIntegerConstantExpr(NumParams, S.Context)) {
   4763     S.Diag(Attr.getLoc(), diag::err_attribute_argument_type)
   4764       << Attr.getName() << AANT_ArgumentIntegerConstant
   4765       << NumParamsExpr->getSourceRange();
   4766     return;
   4767   }
   4768 
   4769   unsigned Num = NumParams.getLimitedValue(255);
   4770   if ((Num & 1) || Num > 30) {
   4771     S.Diag(Attr.getLoc(), diag::err_attribute_argument_out_of_bounds)
   4772       << Attr.getName() << (int)NumParams.getSExtValue()
   4773       << NumParamsExpr->getSourceRange();
   4774     return;
   4775   }
   4776 
   4777   D->addAttr(::new (S.Context)
   4778               MSP430InterruptAttr(Attr.getLoc(), S.Context, Num,
   4779                                   Attr.getAttributeSpellingListIndex()));
   4780   D->addAttr(UsedAttr::CreateImplicit(S.Context));
   4781 }
   4782 
   4783 static void handleMipsInterruptAttr(Sema &S, Decl *D,
   4784                                     const AttributeList &Attr) {
   4785   // Only one optional argument permitted.
   4786   if (Attr.getNumArgs() > 1) {
   4787     S.Diag(Attr.getLoc(), diag::err_attribute_too_many_arguments)
   4788         << Attr.getName() << 1;
   4789     return;
   4790   }
   4791 
   4792   StringRef Str;
   4793   SourceLocation ArgLoc;
   4794 
   4795   if (Attr.getNumArgs() == 0)
   4796     Str = "";
   4797   else if (!S.checkStringLiteralArgumentAttr(Attr, 0, Str, &ArgLoc))
   4798     return;
   4799 
   4800   // Semantic checks for a function with the 'interrupt' attribute for MIPS:
   4801   // a) Must be a function.
   4802   // b) Must have no parameters.
   4803   // c) Must have the 'void' return type.
   4804   // d) Cannot have the 'mips16' attribute, as that instruction set
   4805   //    lacks the 'eret' instruction.
   4806   // e) The attribute itself must either have no argument or one of the
   4807   //    valid interrupt types, see [MipsInterruptDocs].
   4808 
   4809   if (!isFunctionOrMethod(D)) {
   4810     S.Diag(D->getLocation(), diag::warn_attribute_wrong_decl_type)
   4811         << "'interrupt'" << ExpectedFunctionOrMethod;
   4812     return;
   4813   }
   4814 
   4815   if (hasFunctionProto(D) && getFunctionOrMethodNumParams(D) != 0) {
   4816     S.Diag(D->getLocation(), diag::warn_mips_interrupt_attribute)
   4817         << 0;
   4818     return;
   4819   }
   4820 
   4821   if (!getFunctionOrMethodResultType(D)->isVoidType()) {
   4822     S.Diag(D->getLocation(), diag::warn_mips_interrupt_attribute)
   4823         << 1;
   4824     return;
   4825   }
   4826 
   4827   if (checkAttrMutualExclusion<Mips16Attr>(S, D, Attr.getRange(),
   4828                                            Attr.getName()))
   4829     return;
   4830 
   4831   MipsInterruptAttr::InterruptType Kind;
   4832   if (!MipsInterruptAttr::ConvertStrToInterruptType(Str, Kind)) {
   4833     S.Diag(Attr.getLoc(), diag::warn_attribute_type_not_supported)
   4834         << Attr.getName() << "'" + std::string(Str) + "'";
   4835     return;
   4836   }
   4837 
   4838   D->addAttr(::new (S.Context) MipsInterruptAttr(
   4839       Attr.getLoc(), S.Context, Kind, Attr.getAttributeSpellingListIndex()));
   4840 }
   4841 
   4842 static void handleAnyX86InterruptAttr(Sema &S, Decl *D,
   4843                                       const AttributeList &Attr) {
   4844   // Semantic checks for a function with the 'interrupt' attribute.
   4845   // a) Must be a function.
   4846   // b) Must have the 'void' return type.
   4847   // c) Must take 1 or 2 arguments.
   4848   // d) The 1st argument must be a pointer.
   4849   // e) The 2nd argument (if any) must be an unsigned integer.
   4850   if (!isFunctionOrMethod(D) || !hasFunctionProto(D) || isInstanceMethod(D) ||
   4851       CXXMethodDecl::isStaticOverloadedOperator(
   4852           cast<NamedDecl>(D)->getDeclName().getCXXOverloadedOperator())) {
   4853     S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   4854         << Attr.getName() << ExpectedFunctionWithProtoType;
   4855     return;
   4856   }
   4857   // Interrupt handler must have void return type.
   4858   if (!getFunctionOrMethodResultType(D)->isVoidType()) {
   4859     S.Diag(getFunctionOrMethodResultSourceRange(D).getBegin(),
   4860            diag::err_anyx86_interrupt_attribute)
   4861         << (S.Context.getTargetInfo().getTriple().getArch() == llvm::Triple::x86
   4862                 ? 0
   4863                 : 1)
   4864         << 0;
   4865     return;
   4866   }
   4867   // Interrupt handler must have 1 or 2 parameters.
   4868   unsigned NumParams = getFunctionOrMethodNumParams(D);
   4869   if (NumParams < 1 || NumParams > 2) {
   4870     S.Diag(D->getLocStart(), diag::err_anyx86_interrupt_attribute)
   4871         << (S.Context.getTargetInfo().getTriple().getArch() == llvm::Triple::x86
   4872                 ? 0
   4873                 : 1)
   4874         << 1;
   4875     return;
   4876   }
   4877   // The first argument must be a pointer.
   4878   if (!getFunctionOrMethodParamType(D, 0)->isPointerType()) {
   4879     S.Diag(getFunctionOrMethodParamRange(D, 0).getBegin(),
   4880            diag::err_anyx86_interrupt_attribute)
   4881         << (S.Context.getTargetInfo().getTriple().getArch() == llvm::Triple::x86
   4882                 ? 0
   4883                 : 1)
   4884         << 2;
   4885     return;
   4886   }
   4887   // The second argument, if present, must be an unsigned integer.
   4888   unsigned TypeSize =
   4889       S.Context.getTargetInfo().getTriple().getArch() == llvm::Triple::x86_64
   4890           ? 64
   4891           : 32;
   4892   if (NumParams == 2 &&
   4893       (!getFunctionOrMethodParamType(D, 1)->isUnsignedIntegerType() ||
   4894        S.Context.getTypeSize(getFunctionOrMethodParamType(D, 1)) != TypeSize)) {
   4895     S.Diag(getFunctionOrMethodParamRange(D, 1).getBegin(),
   4896            diag::err_anyx86_interrupt_attribute)
   4897         << (S.Context.getTargetInfo().getTriple().getArch() == llvm::Triple::x86
   4898                 ? 0
   4899                 : 1)
   4900         << 3 << S.Context.getIntTypeForBitwidth(TypeSize, /*Signed=*/false);
   4901     return;
   4902   }
   4903   D->addAttr(::new (S.Context) AnyX86InterruptAttr(
   4904       Attr.getLoc(), S.Context, Attr.getAttributeSpellingListIndex()));
   4905   D->addAttr(UsedAttr::CreateImplicit(S.Context));
   4906 }
   4907 
   4908 static void handleInterruptAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   4909   // Dispatch the interrupt attribute based on the current target.
   4910   switch (S.Context.getTargetInfo().getTriple().getArch()) {
   4911   case llvm::Triple::msp430:
   4912     handleMSP430InterruptAttr(S, D, Attr);
   4913     break;
   4914   case llvm::Triple::mipsel:
   4915   case llvm::Triple::mips:
   4916     handleMipsInterruptAttr(S, D, Attr);
   4917     break;
   4918   case llvm::Triple::x86:
   4919   case llvm::Triple::x86_64:
   4920     handleAnyX86InterruptAttr(S, D, Attr);
   4921     break;
   4922   default:
   4923     handleARMInterruptAttr(S, D, Attr);
   4924     break;
   4925   }
   4926 }
   4927 
   4928 static void handleAMDGPUNumVGPRAttr(Sema &S, Decl *D,
   4929                                     const AttributeList &Attr) {
   4930   uint32_t NumRegs;
   4931   Expr *NumRegsExpr = static_cast<Expr *>(Attr.getArgAsExpr(0));
   4932   if (!checkUInt32Argument(S, Attr, NumRegsExpr, NumRegs))
   4933     return;
   4934 
   4935   D->addAttr(::new (S.Context)
   4936              AMDGPUNumVGPRAttr(Attr.getLoc(), S.Context,
   4937                                NumRegs,
   4938                                Attr.getAttributeSpellingListIndex()));
   4939 }
   4940 
   4941 static void handleAMDGPUNumSGPRAttr(Sema &S, Decl *D,
   4942                                     const AttributeList &Attr) {
   4943   uint32_t NumRegs;
   4944   Expr *NumRegsExpr = static_cast<Expr *>(Attr.getArgAsExpr(0));
   4945   if (!checkUInt32Argument(S, Attr, NumRegsExpr, NumRegs))
   4946     return;
   4947 
   4948   D->addAttr(::new (S.Context)
   4949              AMDGPUNumSGPRAttr(Attr.getLoc(), S.Context,
   4950                                NumRegs,
   4951                                Attr.getAttributeSpellingListIndex()));
   4952 }
   4953 
   4954 static void handleX86ForceAlignArgPointerAttr(Sema &S, Decl *D,
   4955                                               const AttributeList& Attr) {
   4956   // If we try to apply it to a function pointer, don't warn, but don't
   4957   // do anything, either. It doesn't matter anyway, because there's nothing
   4958   // special about calling a force_align_arg_pointer function.
   4959   ValueDecl *VD = dyn_cast<ValueDecl>(D);
   4960   if (VD && VD->getType()->isFunctionPointerType())
   4961     return;
   4962   // Also don't warn on function pointer typedefs.
   4963   TypedefNameDecl *TD = dyn_cast<TypedefNameDecl>(D);
   4964   if (TD && (TD->getUnderlyingType()->isFunctionPointerType() ||
   4965     TD->getUnderlyingType()->isFunctionType()))
   4966     return;
   4967   // Attribute can only be applied to function types.
   4968   if (!isa<FunctionDecl>(D)) {
   4969     S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
   4970       << Attr.getName() << /* function */0;
   4971     return;
   4972   }
   4973 
   4974   D->addAttr(::new (S.Context)
   4975               X86ForceAlignArgPointerAttr(Attr.getRange(), S.Context,
   4976                                         Attr.getAttributeSpellingListIndex()));
   4977 }
   4978 
   4979 static void handleLayoutVersion(Sema &S, Decl *D, const AttributeList &Attr) {
   4980   uint32_t Version;
   4981   Expr *VersionExpr = static_cast<Expr *>(Attr.getArgAsExpr(0));
   4982   if (!checkUInt32Argument(S, Attr, Attr.getArgAsExpr(0), Version))
   4983     return;
   4984 
   4985   // TODO: Investigate what happens with the next major version of MSVC.
   4986   if (Version != LangOptions::MSVC2015) {
   4987     S.Diag(Attr.getLoc(), diag::err_attribute_argument_out_of_bounds)
   4988         << Attr.getName() << Version << VersionExpr->getSourceRange();
   4989     return;
   4990   }
   4991 
   4992   D->addAttr(::new (S.Context)
   4993                  LayoutVersionAttr(Attr.getRange(), S.Context, Version,
   4994                                    Attr.getAttributeSpellingListIndex()));
   4995 }
   4996 
   4997 DLLImportAttr *Sema::mergeDLLImportAttr(Decl *D, SourceRange Range,
   4998                                         unsigned AttrSpellingListIndex) {
   4999   if (D->hasAttr<DLLExportAttr>()) {
   5000     Diag(Range.getBegin(), diag::warn_attribute_ignored) << "'dllimport'";
   5001     return nullptr;
   5002   }
   5003 
   5004   if (D->hasAttr<DLLImportAttr>())
   5005     return nullptr;
   5006 
   5007   return ::new (Context) DLLImportAttr(Range, Context, AttrSpellingListIndex);
   5008 }
   5009 
   5010 DLLExportAttr *Sema::mergeDLLExportAttr(Decl *D, SourceRange Range,
   5011                                         unsigned AttrSpellingListIndex) {
   5012   if (DLLImportAttr *Import = D->getAttr<DLLImportAttr>()) {
   5013     Diag(Import->getLocation(), diag::warn_attribute_ignored) << Import;
   5014     D->dropAttr<DLLImportAttr>();
   5015   }
   5016 
   5017   if (D->hasAttr<DLLExportAttr>())
   5018     return nullptr;
   5019 
   5020   return ::new (Context) DLLExportAttr(Range, Context, AttrSpellingListIndex);
   5021 }
   5022 
   5023 static void handleDLLAttr(Sema &S, Decl *D, const AttributeList &A) {
   5024   if (isa<ClassTemplatePartialSpecializationDecl>(D) &&
   5025       S.Context.getTargetInfo().getCXXABI().isMicrosoft()) {
   5026     S.Diag(A.getRange().getBegin(), diag::warn_attribute_ignored)
   5027         << A.getName();
   5028     return;
   5029   }
   5030 
   5031   if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {
   5032     if (FD->isInlined() && A.getKind() == AttributeList::AT_DLLImport &&
   5033         !S.Context.getTargetInfo().getCXXABI().isMicrosoft()) {
   5034       // MinGW doesn't allow dllimport on inline functions.
   5035       S.Diag(A.getRange().getBegin(), diag::warn_attribute_ignored_on_inline)
   5036           << A.getName();
   5037       return;
   5038     }
   5039   }
   5040 
   5041   if (auto *MD = dyn_cast<CXXMethodDecl>(D)) {
   5042     if (S.Context.getTargetInfo().getCXXABI().isMicrosoft() &&
   5043         MD->getParent()->isLambda()) {
   5044       S.Diag(A.getRange().getBegin(), diag::err_attribute_dll_lambda) << A.getName();
   5045       return;
   5046     }
   5047   }
   5048 
   5049   unsigned Index = A.getAttributeSpellingListIndex();
   5050   Attr *NewAttr = A.getKind() == AttributeList::AT_DLLExport
   5051                       ? (Attr *)S.mergeDLLExportAttr(D, A.getRange(), Index)
   5052                       : (Attr *)S.mergeDLLImportAttr(D, A.getRange(), Index);
   5053   if (NewAttr)
   5054     D->addAttr(NewAttr);
   5055 }
   5056 
   5057 MSInheritanceAttr *
   5058 Sema::mergeMSInheritanceAttr(Decl *D, SourceRange Range, bool BestCase,
   5059                              unsigned AttrSpellingListIndex,
   5060                              MSInheritanceAttr::Spelling SemanticSpelling) {
   5061   if (MSInheritanceAttr *IA = D->getAttr<MSInheritanceAttr>()) {
   5062     if (IA->getSemanticSpelling() == SemanticSpelling)
   5063       return nullptr;
   5064     Diag(IA->getLocation(), diag::err_mismatched_ms_inheritance)
   5065         << 1 /*previous declaration*/;
   5066     Diag(Range.getBegin(), diag::note_previous_ms_inheritance);
   5067     D->dropAttr<MSInheritanceAttr>();
   5068   }
   5069 
   5070   CXXRecordDecl *RD = cast<CXXRecordDecl>(D);
   5071   if (RD->hasDefinition()) {
   5072     if (checkMSInheritanceAttrOnDefinition(RD, Range, BestCase,
   5073                                            SemanticSpelling)) {
   5074       return nullptr;
   5075     }
   5076   } else {
   5077     if (isa<ClassTemplatePartialSpecializationDecl>(RD)) {
   5078       Diag(Range.getBegin(), diag::warn_ignored_ms_inheritance)
   5079           << 1 /*partial specialization*/;
   5080       return nullptr;
   5081     }
   5082     if (RD->getDescribedClassTemplate()) {
   5083       Diag(Range.getBegin(), diag::warn_ignored_ms_inheritance)
   5084           << 0 /*primary template*/;
   5085       return nullptr;
   5086     }
   5087   }
   5088 
   5089   return ::new (Context)
   5090       MSInheritanceAttr(Range, Context, BestCase, AttrSpellingListIndex);
   5091 }
   5092 
   5093 static void handleCapabilityAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   5094   // The capability attributes take a single string parameter for the name of
   5095   // the capability they represent. The lockable attribute does not take any
   5096   // parameters. However, semantically, both attributes represent the same
   5097   // concept, and so they use the same semantic attribute. Eventually, the
   5098   // lockable attribute will be removed.
   5099   //
   5100   // For backward compatibility, any capability which has no specified string
   5101   // literal will be considered a "mutex."
   5102   StringRef N("mutex");
   5103   SourceLocation LiteralLoc;
   5104   if (Attr.getKind() == AttributeList::AT_Capability &&
   5105       !S.checkStringLiteralArgumentAttr(Attr, 0, N, &LiteralLoc))
   5106     return;
   5107 
   5108   // Currently, there are only two names allowed for a capability: role and
   5109   // mutex (case insensitive). Diagnose other capability names.
   5110   if (!N.equals_lower("mutex") && !N.equals_lower("role"))
   5111     S.Diag(LiteralLoc, diag::warn_invalid_capability_name) << N;
   5112 
   5113   D->addAttr(::new (S.Context) CapabilityAttr(Attr.getRange(), S.Context, N,
   5114                                         Attr.getAttributeSpellingListIndex()));
   5115 }
   5116 
   5117 static void handleAssertCapabilityAttr(Sema &S, Decl *D,
   5118                                        const AttributeList &Attr) {
   5119   D->addAttr(::new (S.Context) AssertCapabilityAttr(Attr.getRange(), S.Context,
   5120                                                     Attr.getArgAsExpr(0),
   5121                                         Attr.getAttributeSpellingListIndex()));
   5122 }
   5123 
   5124 static void handleAcquireCapabilityAttr(Sema &S, Decl *D,
   5125                                         const AttributeList &Attr) {
   5126   SmallVector<Expr*, 1> Args;
   5127   if (!checkLockFunAttrCommon(S, D, Attr, Args))
   5128     return;
   5129 
   5130   D->addAttr(::new (S.Context) AcquireCapabilityAttr(Attr.getRange(),
   5131                                                      S.Context,
   5132                                                      Args.data(), Args.size(),
   5133                                         Attr.getAttributeSpellingListIndex()));
   5134 }
   5135 
   5136 static void handleTryAcquireCapabilityAttr(Sema &S, Decl *D,
   5137                                            const AttributeList &Attr) {
   5138   SmallVector<Expr*, 2> Args;
   5139   if (!checkTryLockFunAttrCommon(S, D, Attr, Args))
   5140     return;
   5141 
   5142   D->addAttr(::new (S.Context) TryAcquireCapabilityAttr(Attr.getRange(),
   5143                                                         S.Context,
   5144                                                         Attr.getArgAsExpr(0),
   5145                                                         Args.data(),
   5146                                                         Args.size(),
   5147                                         Attr.getAttributeSpellingListIndex()));
   5148 }
   5149 
   5150 static void handleReleaseCapabilityAttr(Sema &S, Decl *D,
   5151                                         const AttributeList &Attr) {
   5152   // Check that all arguments are lockable objects.
   5153   SmallVector<Expr *, 1> Args;
   5154   checkAttrArgsAreCapabilityObjs(S, D, Attr, Args, 0, true);
   5155 
   5156   D->addAttr(::new (S.Context) ReleaseCapabilityAttr(
   5157       Attr.getRange(), S.Context, Args.data(), Args.size(),
   5158       Attr.getAttributeSpellingListIndex()));
   5159 }
   5160 
   5161 static void handleRequiresCapabilityAttr(Sema &S, Decl *D,
   5162                                          const AttributeList &Attr) {
   5163   if (!checkAttributeAtLeastNumArgs(S, Attr, 1))
   5164     return;
   5165 
   5166   // check that all arguments are lockable objects
   5167   SmallVector<Expr*, 1> Args;
   5168   checkAttrArgsAreCapabilityObjs(S, D, Attr, Args);
   5169   if (Args.empty())
   5170     return;
   5171 
   5172   RequiresCapabilityAttr *RCA = ::new (S.Context)
   5173     RequiresCapabilityAttr(Attr.getRange(), S.Context, Args.data(),
   5174                            Args.size(), Attr.getAttributeSpellingListIndex());
   5175 
   5176   D->addAttr(RCA);
   5177 }
   5178 
   5179 static void handleDeprecatedAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   5180   if (auto *NSD = dyn_cast<NamespaceDecl>(D)) {
   5181     if (NSD->isAnonymousNamespace()) {
   5182       S.Diag(Attr.getLoc(), diag::warn_deprecated_anonymous_namespace);
   5183       // Do not want to attach the attribute to the namespace because that will
   5184       // cause confusing diagnostic reports for uses of declarations within the
   5185       // namespace.
   5186       return;
   5187     }
   5188   }
   5189 
   5190   // Handle the cases where the attribute has a text message.
   5191   StringRef Str, Replacement;
   5192   if (Attr.isArgExpr(0) && Attr.getArgAsExpr(0) &&
   5193       !S.checkStringLiteralArgumentAttr(Attr, 0, Str))
   5194     return;
   5195 
   5196   // Only support a single optional message for Declspec and CXX11.
   5197   if (Attr.isDeclspecAttribute() || Attr.isCXX11Attribute())
   5198     checkAttributeAtMostNumArgs(S, Attr, 1);
   5199   else if (Attr.isArgExpr(1) && Attr.getArgAsExpr(1) &&
   5200            !S.checkStringLiteralArgumentAttr(Attr, 1, Replacement))
   5201     return;
   5202 
   5203   if (!S.getLangOpts().CPlusPlus14)
   5204     if (Attr.isCXX11Attribute() &&
   5205         !(Attr.hasScope() && Attr.getScopeName()->isStr("gnu")))
   5206       S.Diag(Attr.getLoc(), diag::ext_cxx14_attr) << Attr.getName();
   5207 
   5208   D->addAttr(::new (S.Context) DeprecatedAttr(Attr.getRange(), S.Context, Str,
   5209                                    Replacement,
   5210                                    Attr.getAttributeSpellingListIndex()));
   5211 }
   5212 
   5213 static void handleNoSanitizeAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   5214   if (!checkAttributeAtLeastNumArgs(S, Attr, 1))
   5215     return;
   5216 
   5217   std::vector<StringRef> Sanitizers;
   5218 
   5219   for (unsigned I = 0, E = Attr.getNumArgs(); I != E; ++I) {
   5220     StringRef SanitizerName;
   5221     SourceLocation LiteralLoc;
   5222 
   5223     if (!S.checkStringLiteralArgumentAttr(Attr, I, SanitizerName, &LiteralLoc))
   5224       return;
   5225 
   5226     if (parseSanitizerValue(SanitizerName, /*AllowGroups=*/true) == 0)
   5227       S.Diag(LiteralLoc, diag::warn_unknown_sanitizer_ignored) << SanitizerName;
   5228 
   5229     Sanitizers.push_back(SanitizerName);
   5230   }
   5231 
   5232   D->addAttr(::new (S.Context) NoSanitizeAttr(
   5233       Attr.getRange(), S.Context, Sanitizers.data(), Sanitizers.size(),
   5234       Attr.getAttributeSpellingListIndex()));
   5235 }
   5236 
   5237 static void handleNoSanitizeSpecificAttr(Sema &S, Decl *D,
   5238                                          const AttributeList &Attr) {
   5239   StringRef AttrName = Attr.getName()->getName();
   5240   normalizeName(AttrName);
   5241   StringRef SanitizerName =
   5242       llvm::StringSwitch<StringRef>(AttrName)
   5243           .Case("no_address_safety_analysis", "address")
   5244           .Case("no_sanitize_address", "address")
   5245           .Case("no_sanitize_thread", "thread")
   5246           .Case("no_sanitize_memory", "memory");
   5247   D->addAttr(::new (S.Context)
   5248                  NoSanitizeAttr(Attr.getRange(), S.Context, &SanitizerName, 1,
   5249                                 Attr.getAttributeSpellingListIndex()));
   5250 }
   5251 
   5252 static void handleInternalLinkageAttr(Sema &S, Decl *D,
   5253                                       const AttributeList &Attr) {
   5254   if (InternalLinkageAttr *Internal =
   5255           S.mergeInternalLinkageAttr(D, Attr.getRange(), Attr.getName(),
   5256                                      Attr.getAttributeSpellingListIndex()))
   5257     D->addAttr(Internal);
   5258 }
   5259 
   5260 static void handleOpenCLNoSVMAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   5261   if (S.LangOpts.OpenCLVersion != 200)
   5262     S.Diag(Attr.getLoc(), diag::err_attribute_requires_opencl_version)
   5263         << Attr.getName() << "2.0" << 0;
   5264   else
   5265     S.Diag(Attr.getLoc(), diag::warn_opencl_attr_deprecated_ignored)
   5266         << Attr.getName() << "2.0";
   5267 }
   5268 
   5269 /// Handles semantic checking for features that are common to all attributes,
   5270 /// such as checking whether a parameter was properly specified, or the correct
   5271 /// number of arguments were passed, etc.
   5272 static bool handleCommonAttributeFeatures(Sema &S, Scope *scope, Decl *D,
   5273                                           const AttributeList &Attr) {
   5274   // Several attributes carry different semantics than the parsing requires, so
   5275   // those are opted out of the common handling.
   5276   //
   5277   // We also bail on unknown and ignored attributes because those are handled
   5278   // as part of the target-specific handling logic.
   5279   if (Attr.hasCustomParsing() ||
   5280       Attr.getKind() == AttributeList::UnknownAttribute)
   5281     return false;
   5282 
   5283   // Check whether the attribute requires specific language extensions to be
   5284   // enabled.
   5285   if (!Attr.diagnoseLangOpts(S))
   5286     return true;
   5287 
   5288   if (Attr.getMinArgs() == Attr.getMaxArgs()) {
   5289     // If there are no optional arguments, then checking for the argument count
   5290     // is trivial.
   5291     if (!checkAttributeNumArgs(S, Attr, Attr.getMinArgs()))
   5292       return true;
   5293   } else {
   5294     // There are optional arguments, so checking is slightly more involved.
   5295     if (Attr.getMinArgs() &&
   5296         !checkAttributeAtLeastNumArgs(S, Attr, Attr.getMinArgs()))
   5297       return true;
   5298     else if (!Attr.hasVariadicArg() && Attr.getMaxArgs() &&
   5299              !checkAttributeAtMostNumArgs(S, Attr, Attr.getMaxArgs()))
   5300       return true;
   5301   }
   5302 
   5303   // Check whether the attribute appertains to the given subject.
   5304   if (!Attr.diagnoseAppertainsTo(S, D))
   5305     return true;
   5306 
   5307   return false;
   5308 }
   5309 
   5310 static void handleOpenCLAccessAttr(Sema &S, Decl *D,
   5311                                    const AttributeList &Attr) {
   5312   if (D->isInvalidDecl())
   5313     return;
   5314 
   5315   // Check if there is only one access qualifier.
   5316   if (D->hasAttr<OpenCLAccessAttr>()) {
   5317     S.Diag(Attr.getLoc(), diag::err_opencl_multiple_access_qualifiers)
   5318         << D->getSourceRange();
   5319     D->setInvalidDecl(true);
   5320     return;
   5321   }
   5322 
   5323   // OpenCL v2.0 s6.6 - read_write can be used for image types to specify that an
   5324   // image object can be read and written.
   5325   // OpenCL v2.0 s6.13.6 - A kernel cannot read from and write to the same pipe
   5326   // object. Using the read_write (or __read_write) qualifier with the pipe
   5327   // qualifier is a compilation error.
   5328   if (const ParmVarDecl *PDecl = dyn_cast<ParmVarDecl>(D)) {
   5329     const Type *DeclTy = PDecl->getType().getCanonicalType().getTypePtr();
   5330     if (Attr.getName()->getName().find("read_write") != StringRef::npos) {
   5331       if (S.getLangOpts().OpenCLVersion < 200 || DeclTy->isPipeType()) {
   5332         S.Diag(Attr.getLoc(), diag::err_opencl_invalid_read_write)
   5333             << Attr.getName() << PDecl->getType() << DeclTy->isImageType();
   5334         D->setInvalidDecl(true);
   5335         return;
   5336       }
   5337     }
   5338   }
   5339 
   5340   D->addAttr(::new (S.Context) OpenCLAccessAttr(
   5341       Attr.getRange(), S.Context, Attr.getAttributeSpellingListIndex()));
   5342 }
   5343 
   5344 //===----------------------------------------------------------------------===//
   5345 // Top Level Sema Entry Points
   5346 //===----------------------------------------------------------------------===//
   5347 
   5348 /// ProcessDeclAttribute - Apply the specific attribute to the specified decl if
   5349 /// the attribute applies to decls.  If the attribute is a type attribute, just
   5350 /// silently ignore it if a GNU attribute.
   5351 static void ProcessDeclAttribute(Sema &S, Scope *scope, Decl *D,
   5352                                  const AttributeList &Attr,
   5353                                  bool IncludeCXX11Attributes) {
   5354   if (Attr.isInvalid() || Attr.getKind() == AttributeList::IgnoredAttribute)
   5355     return;
   5356 
   5357   // Ignore C++11 attributes on declarator chunks: they appertain to the type
   5358   // instead.
   5359   if (Attr.isCXX11Attribute() && !IncludeCXX11Attributes)
   5360     return;
   5361 
   5362   // Unknown attributes are automatically warned on. Target-specific attributes
   5363   // which do not apply to the current target architecture are treated as
   5364   // though they were unknown attributes.
   5365   if (Attr.getKind() == AttributeList::UnknownAttribute ||
   5366       !Attr.existsInTarget(S.Context.getTargetInfo())) {
   5367     S.Diag(Attr.getLoc(), Attr.isDeclspecAttribute()
   5368                               ? diag::warn_unhandled_ms_attribute_ignored
   5369                               : diag::warn_unknown_attribute_ignored)
   5370         << Attr.getName();
   5371     return;
   5372   }
   5373 
   5374   if (handleCommonAttributeFeatures(S, scope, D, Attr))
   5375     return;
   5376 
   5377   switch (Attr.getKind()) {
   5378   default:
   5379     if (!Attr.isStmtAttr()) {
   5380       // Type attributes are handled elsewhere; silently move on.
   5381       assert(Attr.isTypeAttr() && "Non-type attribute not handled");
   5382       break;
   5383     }
   5384     S.Diag(Attr.getLoc(), diag::err_stmt_attribute_invalid_on_decl)
   5385         << Attr.getName() << D->getLocation();
   5386     break;
   5387   case AttributeList::AT_Interrupt:
   5388     handleInterruptAttr(S, D, Attr);
   5389     break;
   5390   case AttributeList::AT_X86ForceAlignArgPointer:
   5391     handleX86ForceAlignArgPointerAttr(S, D, Attr);
   5392     break;
   5393   case AttributeList::AT_DLLExport:
   5394   case AttributeList::AT_DLLImport:
   5395     handleDLLAttr(S, D, Attr);
   5396     break;
   5397   case AttributeList::AT_Mips16:
   5398     handleSimpleAttributeWithExclusions<Mips16Attr, MipsInterruptAttr>(S, D,
   5399                                                                        Attr);
   5400     break;
   5401   case AttributeList::AT_NoMips16:
   5402     handleSimpleAttribute<NoMips16Attr>(S, D, Attr);
   5403     break;
   5404   case AttributeList::AT_AMDGPUNumVGPR:
   5405     handleAMDGPUNumVGPRAttr(S, D, Attr);
   5406     break;
   5407   case AttributeList::AT_AMDGPUNumSGPR:
   5408     handleAMDGPUNumSGPRAttr(S, D, Attr);
   5409     break;
   5410   case AttributeList::AT_IBAction:
   5411     handleSimpleAttribute<IBActionAttr>(S, D, Attr);
   5412     break;
   5413   case AttributeList::AT_IBOutlet:
   5414     handleIBOutlet(S, D, Attr);
   5415     break;
   5416   case AttributeList::AT_IBOutletCollection:
   5417     handleIBOutletCollection(S, D, Attr);
   5418     break;
   5419   case AttributeList::AT_IFunc:
   5420     handleIFuncAttr(S, D, Attr);
   5421     break;
   5422   case AttributeList::AT_Alias:
   5423     handleAliasAttr(S, D, Attr);
   5424     break;
   5425   case AttributeList::AT_Aligned:
   5426     handleAlignedAttr(S, D, Attr);
   5427     break;
   5428   case AttributeList::AT_AlignValue:
   5429     handleAlignValueAttr(S, D, Attr);
   5430     break;
   5431   case AttributeList::AT_AlwaysInline:
   5432     handleAlwaysInlineAttr(S, D, Attr);
   5433     break;
   5434   case AttributeList::AT_AnalyzerNoReturn:
   5435     handleAnalyzerNoReturnAttr(S, D, Attr);
   5436     break;
   5437   case AttributeList::AT_TLSModel:
   5438     handleTLSModelAttr(S, D, Attr);
   5439     break;
   5440   case AttributeList::AT_Annotate:
   5441     handleAnnotateAttr(S, D, Attr);
   5442     break;
   5443   case AttributeList::AT_Availability:
   5444     handleAvailabilityAttr(S, D, Attr);
   5445     break;
   5446   case AttributeList::AT_CarriesDependency:
   5447     handleDependencyAttr(S, scope, D, Attr);
   5448     break;
   5449   case AttributeList::AT_Common:
   5450     handleCommonAttr(S, D, Attr);
   5451     break;
   5452   case AttributeList::AT_CUDAConstant:
   5453     handleSimpleAttributeWithExclusions<CUDAConstantAttr, CUDASharedAttr>(S, D,
   5454                                                                           Attr);
   5455     break;
   5456   case AttributeList::AT_PassObjectSize:
   5457     handlePassObjectSizeAttr(S, D, Attr);
   5458     break;
   5459   case AttributeList::AT_Constructor:
   5460     handleConstructorAttr(S, D, Attr);
   5461     break;
   5462   case AttributeList::AT_CXX11NoReturn:
   5463     handleSimpleAttribute<CXX11NoReturnAttr>(S, D, Attr);
   5464     break;
   5465   case AttributeList::AT_Deprecated:
   5466     handleDeprecatedAttr(S, D, Attr);
   5467     break;
   5468   case AttributeList::AT_Destructor:
   5469     handleDestructorAttr(S, D, Attr);
   5470     break;
   5471   case AttributeList::AT_EnableIf:
   5472     handleEnableIfAttr(S, D, Attr);
   5473     break;
   5474   case AttributeList::AT_ExtVectorType:
   5475     handleExtVectorTypeAttr(S, scope, D, Attr);
   5476     break;
   5477   case AttributeList::AT_MinSize:
   5478     handleMinSizeAttr(S, D, Attr);
   5479     break;
   5480   case AttributeList::AT_OptimizeNone:
   5481     handleOptimizeNoneAttr(S, D, Attr);
   5482     break;
   5483   case AttributeList::AT_FlagEnum:
   5484     handleSimpleAttribute<FlagEnumAttr>(S, D, Attr);
   5485     break;
   5486   case AttributeList::AT_Flatten:
   5487     handleSimpleAttribute<FlattenAttr>(S, D, Attr);
   5488     break;
   5489   case AttributeList::AT_Format:
   5490     handleFormatAttr(S, D, Attr);
   5491     break;
   5492   case AttributeList::AT_FormatArg:
   5493     handleFormatArgAttr(S, D, Attr);
   5494     break;
   5495   case AttributeList::AT_CUDAGlobal:
   5496     handleGlobalAttr(S, D, Attr);
   5497     break;
   5498   case AttributeList::AT_CUDADevice:
   5499     handleSimpleAttributeWithExclusions<CUDADeviceAttr, CUDAGlobalAttr>(S, D,
   5500                                                                         Attr);
   5501     break;
   5502   case AttributeList::AT_CUDAHost:
   5503     handleSimpleAttributeWithExclusions<CUDAHostAttr, CUDAGlobalAttr>(S, D,
   5504                                                                       Attr);
   5505     break;
   5506   case AttributeList::AT_GNUInline:
   5507     handleGNUInlineAttr(S, D, Attr);
   5508     break;
   5509   case AttributeList::AT_CUDALaunchBounds:
   5510     handleLaunchBoundsAttr(S, D, Attr);
   5511     break;
   5512   case AttributeList::AT_Restrict:
   5513     handleRestrictAttr(S, D, Attr);
   5514     break;
   5515   case AttributeList::AT_MayAlias:
   5516     handleSimpleAttribute<MayAliasAttr>(S, D, Attr);
   5517     break;
   5518   case AttributeList::AT_Mode:
   5519     handleModeAttr(S, D, Attr);
   5520     break;
   5521   case AttributeList::AT_NoAlias:
   5522     handleSimpleAttribute<NoAliasAttr>(S, D, Attr);
   5523     break;
   5524   case AttributeList::AT_NoCommon:
   5525     handleSimpleAttribute<NoCommonAttr>(S, D, Attr);
   5526     break;
   5527   case AttributeList::AT_NoSplitStack:
   5528     handleSimpleAttribute<NoSplitStackAttr>(S, D, Attr);
   5529     break;
   5530   case AttributeList::AT_NonNull:
   5531     if (ParmVarDecl *PVD = dyn_cast<ParmVarDecl>(D))
   5532       handleNonNullAttrParameter(S, PVD, Attr);
   5533     else
   5534       handleNonNullAttr(S, D, Attr);
   5535     break;
   5536   case AttributeList::AT_ReturnsNonNull:
   5537     handleReturnsNonNullAttr(S, D, Attr);
   5538     break;
   5539   case AttributeList::AT_AssumeAligned:
   5540     handleAssumeAlignedAttr(S, D, Attr);
   5541     break;
   5542   case AttributeList::AT_Overloadable:
   5543     handleSimpleAttribute<OverloadableAttr>(S, D, Attr);
   5544     break;
   5545   case AttributeList::AT_Ownership:
   5546     handleOwnershipAttr(S, D, Attr);
   5547     break;
   5548   case AttributeList::AT_Cold:
   5549     handleColdAttr(S, D, Attr);
   5550     break;
   5551   case AttributeList::AT_Hot:
   5552     handleHotAttr(S, D, Attr);
   5553     break;
   5554   case AttributeList::AT_Naked:
   5555     handleNakedAttr(S, D, Attr);
   5556     break;
   5557   case AttributeList::AT_NoReturn:
   5558     handleNoReturnAttr(S, D, Attr);
   5559     break;
   5560   case AttributeList::AT_NoThrow:
   5561     handleSimpleAttribute<NoThrowAttr>(S, D, Attr);
   5562     break;
   5563   case AttributeList::AT_CUDAShared:
   5564     handleSimpleAttributeWithExclusions<CUDASharedAttr, CUDAConstantAttr>(S, D,
   5565                                                                           Attr);
   5566     break;
   5567   case AttributeList::AT_VecReturn:
   5568     handleVecReturnAttr(S, D, Attr);
   5569     break;
   5570   case AttributeList::AT_ObjCOwnership:
   5571     handleObjCOwnershipAttr(S, D, Attr);
   5572     break;
   5573   case AttributeList::AT_ObjCPreciseLifetime:
   5574     handleObjCPreciseLifetimeAttr(S, D, Attr);
   5575     break;
   5576   case AttributeList::AT_ObjCReturnsInnerPointer:
   5577     handleObjCReturnsInnerPointerAttr(S, D, Attr);
   5578     break;
   5579   case AttributeList::AT_ObjCRequiresSuper:
   5580     handleObjCRequiresSuperAttr(S, D, Attr);
   5581     break;
   5582   case AttributeList::AT_ObjCBridge:
   5583     handleObjCBridgeAttr(S, scope, D, Attr);
   5584     break;
   5585   case AttributeList::AT_ObjCBridgeMutable:
   5586     handleObjCBridgeMutableAttr(S, scope, D, Attr);
   5587     break;
   5588   case AttributeList::AT_ObjCBridgeRelated:
   5589     handleObjCBridgeRelatedAttr(S, scope, D, Attr);
   5590     break;
   5591   case AttributeList::AT_ObjCDesignatedInitializer:
   5592     handleObjCDesignatedInitializer(S, D, Attr);
   5593     break;
   5594   case AttributeList::AT_ObjCRuntimeName:
   5595     handleObjCRuntimeName(S, D, Attr);
   5596     break;
   5597    case AttributeList::AT_ObjCRuntimeVisible:
   5598     handleSimpleAttribute<ObjCRuntimeVisibleAttr>(S, D, Attr);
   5599     break;
   5600   case AttributeList::AT_ObjCBoxable:
   5601     handleObjCBoxable(S, D, Attr);
   5602     break;
   5603   case AttributeList::AT_CFAuditedTransfer:
   5604     handleCFAuditedTransferAttr(S, D, Attr);
   5605     break;
   5606   case AttributeList::AT_CFUnknownTransfer:
   5607     handleCFUnknownTransferAttr(S, D, Attr);
   5608     break;
   5609   case AttributeList::AT_CFConsumed:
   5610   case AttributeList::AT_NSConsumed:
   5611     handleNSConsumedAttr(S, D, Attr);
   5612     break;
   5613   case AttributeList::AT_NSConsumesSelf:
   5614     handleSimpleAttribute<NSConsumesSelfAttr>(S, D, Attr);
   5615     break;
   5616   case AttributeList::AT_NSReturnsAutoreleased:
   5617   case AttributeList::AT_NSReturnsNotRetained:
   5618   case AttributeList::AT_CFReturnsNotRetained:
   5619   case AttributeList::AT_NSReturnsRetained:
   5620   case AttributeList::AT_CFReturnsRetained:
   5621     handleNSReturnsRetainedAttr(S, D, Attr);
   5622     break;
   5623   case AttributeList::AT_WorkGroupSizeHint:
   5624     handleWorkGroupSize<WorkGroupSizeHintAttr>(S, D, Attr);
   5625     break;
   5626   case AttributeList::AT_ReqdWorkGroupSize:
   5627     handleWorkGroupSize<ReqdWorkGroupSizeAttr>(S, D, Attr);
   5628     break;
   5629   case AttributeList::AT_VecTypeHint:
   5630     handleVecTypeHint(S, D, Attr);
   5631     break;
   5632   case AttributeList::AT_InitPriority:
   5633     handleInitPriorityAttr(S, D, Attr);
   5634     break;
   5635   case AttributeList::AT_Packed:
   5636     handlePackedAttr(S, D, Attr);
   5637     break;
   5638   case AttributeList::AT_Section:
   5639     handleSectionAttr(S, D, Attr);
   5640     break;
   5641   case AttributeList::AT_Target:
   5642     handleTargetAttr(S, D, Attr);
   5643     break;
   5644   case AttributeList::AT_Unavailable:
   5645     handleAttrWithMessage<UnavailableAttr>(S, D, Attr);
   5646     break;
   5647   case AttributeList::AT_ArcWeakrefUnavailable:
   5648     handleSimpleAttribute<ArcWeakrefUnavailableAttr>(S, D, Attr);
   5649     break;
   5650   case AttributeList::AT_ObjCRootClass:
   5651     handleSimpleAttribute<ObjCRootClassAttr>(S, D, Attr);
   5652     break;
   5653   case AttributeList::AT_ObjCExplicitProtocolImpl:
   5654     handleObjCSuppresProtocolAttr(S, D, Attr);
   5655     break;
   5656   case AttributeList::AT_ObjCRequiresPropertyDefs:
   5657     handleSimpleAttribute<ObjCRequiresPropertyDefsAttr>(S, D, Attr);
   5658     break;
   5659   case AttributeList::AT_Unused:
   5660     handleUnusedAttr(S, D, Attr);
   5661     break;
   5662   case AttributeList::AT_ReturnsTwice:
   5663     handleSimpleAttribute<ReturnsTwiceAttr>(S, D, Attr);
   5664     break;
   5665   case AttributeList::AT_NotTailCalled:
   5666     handleNotTailCalledAttr(S, D, Attr);
   5667     break;
   5668   case AttributeList::AT_DisableTailCalls:
   5669     handleDisableTailCallsAttr(S, D, Attr);
   5670     break;
   5671   case AttributeList::AT_Used:
   5672     handleUsedAttr(S, D, Attr);
   5673     break;
   5674   case AttributeList::AT_Visibility:
   5675     handleVisibilityAttr(S, D, Attr, false);
   5676     break;
   5677   case AttributeList::AT_TypeVisibility:
   5678     handleVisibilityAttr(S, D, Attr, true);
   5679     break;
   5680   case AttributeList::AT_WarnUnused:
   5681     handleSimpleAttribute<WarnUnusedAttr>(S, D, Attr);
   5682     break;
   5683   case AttributeList::AT_WarnUnusedResult:
   5684     handleWarnUnusedResult(S, D, Attr);
   5685     break;
   5686   case AttributeList::AT_Weak:
   5687     handleSimpleAttribute<WeakAttr>(S, D, Attr);
   5688     break;
   5689   case AttributeList::AT_WeakRef:
   5690     handleWeakRefAttr(S, D, Attr);
   5691     break;
   5692   case AttributeList::AT_WeakImport:
   5693     handleWeakImportAttr(S, D, Attr);
   5694     break;
   5695   case AttributeList::AT_TransparentUnion:
   5696     handleTransparentUnionAttr(S, D, Attr);
   5697     break;
   5698   case AttributeList::AT_ObjCException:
   5699     handleSimpleAttribute<ObjCExceptionAttr>(S, D, Attr);
   5700     break;
   5701   case AttributeList::AT_ObjCMethodFamily:
   5702     handleObjCMethodFamilyAttr(S, D, Attr);
   5703     break;
   5704   case AttributeList::AT_ObjCNSObject:
   5705     handleObjCNSObject(S, D, Attr);
   5706     break;
   5707   case AttributeList::AT_ObjCIndependentClass:
   5708     handleObjCIndependentClass(S, D, Attr);
   5709     break;
   5710   case AttributeList::AT_Blocks:
   5711     handleBlocksAttr(S, D, Attr);
   5712     break;
   5713   case AttributeList::AT_Sentinel:
   5714     handleSentinelAttr(S, D, Attr);
   5715     break;
   5716   case AttributeList::AT_Const:
   5717     handleSimpleAttribute<ConstAttr>(S, D, Attr);
   5718     break;
   5719   case AttributeList::AT_Pure:
   5720     handleSimpleAttribute<PureAttr>(S, D, Attr);
   5721     break;
   5722   case AttributeList::AT_Cleanup:
   5723     handleCleanupAttr(S, D, Attr);
   5724     break;
   5725   case AttributeList::AT_NoDebug:
   5726     handleNoDebugAttr(S, D, Attr);
   5727     break;
   5728   case AttributeList::AT_NoDuplicate:
   5729     handleSimpleAttribute<NoDuplicateAttr>(S, D, Attr);
   5730     break;
   5731   case AttributeList::AT_NoInline:
   5732     handleSimpleAttribute<NoInlineAttr>(S, D, Attr);
   5733     break;
   5734   case AttributeList::AT_NoInstrumentFunction: // Interacts with -pg.
   5735     handleSimpleAttribute<NoInstrumentFunctionAttr>(S, D, Attr);
   5736     break;
   5737   case AttributeList::AT_StdCall:
   5738   case AttributeList::AT_CDecl:
   5739   case AttributeList::AT_FastCall:
   5740   case AttributeList::AT_ThisCall:
   5741   case AttributeList::AT_Pascal:
   5742   case AttributeList::AT_SwiftCall:
   5743   case AttributeList::AT_VectorCall:
   5744   case AttributeList::AT_MSABI:
   5745   case AttributeList::AT_SysVABI:
   5746   case AttributeList::AT_Pcs:
   5747   case AttributeList::AT_IntelOclBicc:
   5748   case AttributeList::AT_PreserveMost:
   5749   case AttributeList::AT_PreserveAll:
   5750     handleCallConvAttr(S, D, Attr);
   5751     break;
   5752   case AttributeList::AT_OpenCLKernel:
   5753     handleSimpleAttribute<OpenCLKernelAttr>(S, D, Attr);
   5754     break;
   5755   case AttributeList::AT_OpenCLAccess:
   5756     handleOpenCLAccessAttr(S, D, Attr);
   5757     break;
   5758   case AttributeList::AT_OpenCLNoSVM:
   5759     handleOpenCLNoSVMAttr(S, D, Attr);
   5760     break;
   5761   case AttributeList::AT_SwiftContext:
   5762     handleParameterABIAttr(S, D, Attr, ParameterABI::SwiftContext);
   5763     break;
   5764   case AttributeList::AT_SwiftErrorResult:
   5765     handleParameterABIAttr(S, D, Attr, ParameterABI::SwiftErrorResult);
   5766     break;
   5767   case AttributeList::AT_SwiftIndirectResult:
   5768     handleParameterABIAttr(S, D, Attr, ParameterABI::SwiftIndirectResult);
   5769     break;
   5770   case AttributeList::AT_InternalLinkage:
   5771     handleInternalLinkageAttr(S, D, Attr);
   5772     break;
   5773   case AttributeList::AT_LTOVisibilityPublic:
   5774     handleSimpleAttribute<LTOVisibilityPublicAttr>(S, D, Attr);
   5775     break;
   5776 
   5777   // Microsoft attributes:
   5778   case AttributeList::AT_EmptyBases:
   5779     handleSimpleAttribute<EmptyBasesAttr>(S, D, Attr);
   5780     break;
   5781   case AttributeList::AT_LayoutVersion:
   5782     handleLayoutVersion(S, D, Attr);
   5783     break;
   5784   case AttributeList::AT_MSNoVTable:
   5785     handleSimpleAttribute<MSNoVTableAttr>(S, D, Attr);
   5786     break;
   5787   case AttributeList::AT_MSStruct:
   5788     handleSimpleAttribute<MSStructAttr>(S, D, Attr);
   5789     break;
   5790   case AttributeList::AT_Uuid:
   5791     handleUuidAttr(S, D, Attr);
   5792     break;
   5793   case AttributeList::AT_MSInheritance:
   5794     handleMSInheritanceAttr(S, D, Attr);
   5795     break;
   5796   case AttributeList::AT_SelectAny:
   5797     handleSimpleAttribute<SelectAnyAttr>(S, D, Attr);
   5798     break;
   5799   case AttributeList::AT_Thread:
   5800     handleDeclspecThreadAttr(S, D, Attr);
   5801     break;
   5802 
   5803   case AttributeList::AT_AbiTag:
   5804     handleAbiTagAttr(S, D, Attr);
   5805     break;
   5806 
   5807   // Thread safety attributes:
   5808   case AttributeList::AT_AssertExclusiveLock:
   5809     handleAssertExclusiveLockAttr(S, D, Attr);
   5810     break;
   5811   case AttributeList::AT_AssertSharedLock:
   5812     handleAssertSharedLockAttr(S, D, Attr);
   5813     break;
   5814   case AttributeList::AT_GuardedVar:
   5815     handleSimpleAttribute<GuardedVarAttr>(S, D, Attr);
   5816     break;
   5817   case AttributeList::AT_PtGuardedVar:
   5818     handlePtGuardedVarAttr(S, D, Attr);
   5819     break;
   5820   case AttributeList::AT_ScopedLockable:
   5821     handleSimpleAttribute<ScopedLockableAttr>(S, D, Attr);
   5822     break;
   5823   case AttributeList::AT_NoSanitize:
   5824     handleNoSanitizeAttr(S, D, Attr);
   5825     break;
   5826   case AttributeList::AT_NoSanitizeSpecific:
   5827     handleNoSanitizeSpecificAttr(S, D, Attr);
   5828     break;
   5829   case AttributeList::AT_NoThreadSafetyAnalysis:
   5830     handleSimpleAttribute<NoThreadSafetyAnalysisAttr>(S, D, Attr);
   5831     break;
   5832   case AttributeList::AT_GuardedBy:
   5833     handleGuardedByAttr(S, D, Attr);
   5834     break;
   5835   case AttributeList::AT_PtGuardedBy:
   5836     handlePtGuardedByAttr(S, D, Attr);
   5837     break;
   5838   case AttributeList::AT_ExclusiveTrylockFunction:
   5839     handleExclusiveTrylockFunctionAttr(S, D, Attr);
   5840     break;
   5841   case AttributeList::AT_LockReturned:
   5842     handleLockReturnedAttr(S, D, Attr);
   5843     break;
   5844   case AttributeList::AT_LocksExcluded:
   5845     handleLocksExcludedAttr(S, D, Attr);
   5846     break;
   5847   case AttributeList::AT_SharedTrylockFunction:
   5848     handleSharedTrylockFunctionAttr(S, D, Attr);
   5849     break;
   5850   case AttributeList::AT_AcquiredBefore:
   5851     handleAcquiredBeforeAttr(S, D, Attr);
   5852     break;
   5853   case AttributeList::AT_AcquiredAfter:
   5854     handleAcquiredAfterAttr(S, D, Attr);
   5855     break;
   5856 
   5857   // Capability analysis attributes.
   5858   case AttributeList::AT_Capability:
   5859   case AttributeList::AT_Lockable:
   5860     handleCapabilityAttr(S, D, Attr);
   5861     break;
   5862   case AttributeList::AT_RequiresCapability:
   5863     handleRequiresCapabilityAttr(S, D, Attr);
   5864     break;
   5865 
   5866   case AttributeList::AT_AssertCapability:
   5867     handleAssertCapabilityAttr(S, D, Attr);
   5868     break;
   5869   case AttributeList::AT_AcquireCapability:
   5870     handleAcquireCapabilityAttr(S, D, Attr);
   5871     break;
   5872   case AttributeList::AT_ReleaseCapability:
   5873     handleReleaseCapabilityAttr(S, D, Attr);
   5874     break;
   5875   case AttributeList::AT_TryAcquireCapability:
   5876     handleTryAcquireCapabilityAttr(S, D, Attr);
   5877     break;
   5878 
   5879   // Consumed analysis attributes.
   5880   case AttributeList::AT_Consumable:
   5881     handleConsumableAttr(S, D, Attr);
   5882     break;
   5883   case AttributeList::AT_ConsumableAutoCast:
   5884     handleSimpleAttribute<ConsumableAutoCastAttr>(S, D, Attr);
   5885     break;
   5886   case AttributeList::AT_ConsumableSetOnRead:
   5887     handleSimpleAttribute<ConsumableSetOnReadAttr>(S, D, Attr);
   5888     break;
   5889   case AttributeList::AT_CallableWhen:
   5890     handleCallableWhenAttr(S, D, Attr);
   5891     break;
   5892   case AttributeList::AT_ParamTypestate:
   5893     handleParamTypestateAttr(S, D, Attr);
   5894     break;
   5895   case AttributeList::AT_ReturnTypestate:
   5896     handleReturnTypestateAttr(S, D, Attr);
   5897     break;
   5898   case AttributeList::AT_SetTypestate:
   5899     handleSetTypestateAttr(S, D, Attr);
   5900     break;
   5901   case AttributeList::AT_TestTypestate:
   5902     handleTestTypestateAttr(S, D, Attr);
   5903     break;
   5904 
   5905   // Type safety attributes.
   5906   case AttributeList::AT_ArgumentWithTypeTag:
   5907     handleArgumentWithTypeTagAttr(S, D, Attr);
   5908     break;
   5909   case AttributeList::AT_TypeTagForDatatype:
   5910     handleTypeTagForDatatypeAttr(S, D, Attr);
   5911     break;
   5912   case AttributeList::AT_RenderScriptKernel:
   5913     handleSimpleAttribute<RenderScriptKernelAttr>(S, D, Attr);
   5914     break;
   5915   // XRay attributes.
   5916   case AttributeList::AT_XRayInstrument:
   5917     handleSimpleAttribute<XRayInstrumentAttr>(S, D, Attr);
   5918     break;
   5919   }
   5920 }
   5921 
   5922 /// ProcessDeclAttributeList - Apply all the decl attributes in the specified
   5923 /// attribute list to the specified decl, ignoring any type attributes.
   5924 void Sema::ProcessDeclAttributeList(Scope *S, Decl *D,
   5925                                     const AttributeList *AttrList,
   5926                                     bool IncludeCXX11Attributes) {
   5927   for (const AttributeList* l = AttrList; l; l = l->getNext())
   5928     ProcessDeclAttribute(*this, S, D, *l, IncludeCXX11Attributes);
   5929 
   5930   // FIXME: We should be able to handle these cases in TableGen.
   5931   // GCC accepts
   5932   // static int a9 __attribute__((weakref));
   5933   // but that looks really pointless. We reject it.
   5934   if (D->hasAttr<WeakRefAttr>() && !D->hasAttr<AliasAttr>()) {
   5935     Diag(AttrList->getLoc(), diag::err_attribute_weakref_without_alias)
   5936       << cast<NamedDecl>(D);
   5937     D->dropAttr<WeakRefAttr>();
   5938     return;
   5939   }
   5940 
   5941   // FIXME: We should be able to handle this in TableGen as well. It would be
   5942   // good to have a way to specify "these attributes must appear as a group",
   5943   // for these. Additionally, it would be good to have a way to specify "these
   5944   // attribute must never appear as a group" for attributes like cold and hot.
   5945   if (!D->hasAttr<OpenCLKernelAttr>()) {
   5946     // These attributes cannot be applied to a non-kernel function.
   5947     if (Attr *A = D->getAttr<ReqdWorkGroupSizeAttr>()) {
   5948       // FIXME: This emits a different error message than
   5949       // diag::err_attribute_wrong_decl_type + ExpectedKernelFunction.
   5950       Diag(D->getLocation(), diag::err_opencl_kernel_attr) << A;
   5951       D->setInvalidDecl();
   5952     } else if (Attr *A = D->getAttr<WorkGroupSizeHintAttr>()) {
   5953       Diag(D->getLocation(), diag::err_opencl_kernel_attr) << A;
   5954       D->setInvalidDecl();
   5955     } else if (Attr *A = D->getAttr<VecTypeHintAttr>()) {
   5956       Diag(D->getLocation(), diag::err_opencl_kernel_attr) << A;
   5957       D->setInvalidDecl();
   5958     } else if (Attr *A = D->getAttr<AMDGPUNumVGPRAttr>()) {
   5959       Diag(D->getLocation(), diag::err_attribute_wrong_decl_type)
   5960         << A << ExpectedKernelFunction;
   5961       D->setInvalidDecl();
   5962     } else if (Attr *A = D->getAttr<AMDGPUNumSGPRAttr>()) {
   5963       Diag(D->getLocation(), diag::err_attribute_wrong_decl_type)
   5964         << A << ExpectedKernelFunction;
   5965       D->setInvalidDecl();
   5966     }
   5967   }
   5968 }
   5969 
   5970 // Annotation attributes are the only attributes allowed after an access
   5971 // specifier.
   5972 bool Sema::ProcessAccessDeclAttributeList(AccessSpecDecl *ASDecl,
   5973                                           const AttributeList *AttrList) {
   5974   for (const AttributeList* l = AttrList; l; l = l->getNext()) {
   5975     if (l->getKind() == AttributeList::AT_Annotate) {
   5976       ProcessDeclAttribute(*this, nullptr, ASDecl, *l, l->isCXX11Attribute());
   5977     } else {
   5978       Diag(l->getLoc(), diag::err_only_annotate_after_access_spec);
   5979       return true;
   5980     }
   5981   }
   5982 
   5983   return false;
   5984 }
   5985 
   5986 /// checkUnusedDeclAttributes - Check a list of attributes to see if it
   5987 /// contains any decl attributes that we should warn about.
   5988 static void checkUnusedDeclAttributes(Sema &S, const AttributeList *A) {
   5989   for ( ; A; A = A->getNext()) {
   5990     // Only warn if the attribute is an unignored, non-type attribute.
   5991     if (A->isUsedAsTypeAttr() || A->isInvalid()) continue;
   5992     if (A->getKind() == AttributeList::IgnoredAttribute) continue;
   5993 
   5994     if (A->getKind() == AttributeList::UnknownAttribute) {
   5995       S.Diag(A->getLoc(), diag::warn_unknown_attribute_ignored)
   5996         << A->getName() << A->getRange();
   5997     } else {
   5998       S.Diag(A->getLoc(), diag::warn_attribute_not_on_decl)
   5999         << A->getName() << A->getRange();
   6000     }
   6001   }
   6002 }
   6003 
   6004 /// checkUnusedDeclAttributes - Given a declarator which is not being
   6005 /// used to build a declaration, complain about any decl attributes
   6006 /// which might be lying around on it.
   6007 void Sema::checkUnusedDeclAttributes(Declarator &D) {
   6008   ::checkUnusedDeclAttributes(*this, D.getDeclSpec().getAttributes().getList());
   6009   ::checkUnusedDeclAttributes(*this, D.getAttributes());
   6010   for (unsigned i = 0, e = D.getNumTypeObjects(); i != e; ++i)
   6011     ::checkUnusedDeclAttributes(*this, D.getTypeObject(i).getAttrs());
   6012 }
   6013 
   6014 /// DeclClonePragmaWeak - clone existing decl (maybe definition),
   6015 /// \#pragma weak needs a non-definition decl and source may not have one.
   6016 NamedDecl * Sema::DeclClonePragmaWeak(NamedDecl *ND, IdentifierInfo *II,
   6017                                       SourceLocation Loc) {
   6018   assert(isa<FunctionDecl>(ND) || isa<VarDecl>(ND));
   6019   NamedDecl *NewD = nullptr;
   6020   if (FunctionDecl *FD = dyn_cast<FunctionDecl>(ND)) {
   6021     FunctionDecl *NewFD;
   6022     // FIXME: Missing call to CheckFunctionDeclaration().
   6023     // FIXME: Mangling?
   6024     // FIXME: Is the qualifier info correct?
   6025     // FIXME: Is the DeclContext correct?
   6026     NewFD = FunctionDecl::Create(FD->getASTContext(), FD->getDeclContext(),
   6027                                  Loc, Loc, DeclarationName(II),
   6028                                  FD->getType(), FD->getTypeSourceInfo(),
   6029                                  SC_None, false/*isInlineSpecified*/,
   6030                                  FD->hasPrototype(),
   6031                                  false/*isConstexprSpecified*/);
   6032     NewD = NewFD;
   6033 
   6034     if (FD->getQualifier())
   6035       NewFD->setQualifierInfo(FD->getQualifierLoc());
   6036 
   6037     // Fake up parameter variables; they are declared as if this were
   6038     // a typedef.
   6039     QualType FDTy = FD->getType();
   6040     if (const FunctionProtoType *FT = FDTy->getAs<FunctionProtoType>()) {
   6041       SmallVector<ParmVarDecl*, 16> Params;
   6042       for (const auto &AI : FT->param_types()) {
   6043         ParmVarDecl *Param = BuildParmVarDeclForTypedef(NewFD, Loc, AI);
   6044         Param->setScopeInfo(0, Params.size());
   6045         Params.push_back(Param);
   6046       }
   6047       NewFD->setParams(Params);
   6048     }
   6049   } else if (VarDecl *VD = dyn_cast<VarDecl>(ND)) {
   6050     NewD = VarDecl::Create(VD->getASTContext(), VD->getDeclContext(),
   6051                            VD->getInnerLocStart(), VD->getLocation(), II,
   6052                            VD->getType(), VD->getTypeSourceInfo(),
   6053                            VD->getStorageClass());
   6054     if (VD->getQualifier()) {
   6055       VarDecl *NewVD = cast<VarDecl>(NewD);
   6056       NewVD->setQualifierInfo(VD->getQualifierLoc());
   6057     }
   6058   }
   6059   return NewD;
   6060 }
   6061 
   6062 /// DeclApplyPragmaWeak - A declaration (maybe definition) needs \#pragma weak
   6063 /// applied to it, possibly with an alias.
   6064 void Sema::DeclApplyPragmaWeak(Scope *S, NamedDecl *ND, WeakInfo &W) {
   6065   if (W.getUsed()) return; // only do this once
   6066   W.setUsed(true);
   6067   if (W.getAlias()) { // clone decl, impersonate __attribute(weak,alias(...))
   6068     IdentifierInfo *NDId = ND->getIdentifier();
   6069     NamedDecl *NewD = DeclClonePragmaWeak(ND, W.getAlias(), W.getLocation());
   6070     NewD->addAttr(AliasAttr::CreateImplicit(Context, NDId->getName(),
   6071                                             W.getLocation()));
   6072     NewD->addAttr(WeakAttr::CreateImplicit(Context, W.getLocation()));
   6073     WeakTopLevelDecl.push_back(NewD);
   6074     // FIXME: "hideous" code from Sema::LazilyCreateBuiltin
   6075     // to insert Decl at TU scope, sorry.
   6076     DeclContext *SavedContext = CurContext;
   6077     CurContext = Context.getTranslationUnitDecl();
   6078     NewD->setDeclContext(CurContext);
   6079     NewD->setLexicalDeclContext(CurContext);
   6080     PushOnScopeChains(NewD, S);
   6081     CurContext = SavedContext;
   6082   } else { // just add weak to existing
   6083     ND->addAttr(WeakAttr::CreateImplicit(Context, W.getLocation()));
   6084   }
   6085 }
   6086 
   6087 void Sema::ProcessPragmaWeak(Scope *S, Decl *D) {
   6088   // It's valid to "forward-declare" #pragma weak, in which case we
   6089   // have to do this.
   6090   LoadExternalWeakUndeclaredIdentifiers();
   6091   if (!WeakUndeclaredIdentifiers.empty()) {
   6092     NamedDecl *ND = nullptr;
   6093     if (VarDecl *VD = dyn_cast<VarDecl>(D))
   6094       if (VD->isExternC())
   6095         ND = VD;
   6096     if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D))
   6097       if (FD->isExternC())
   6098         ND = FD;
   6099     if (ND) {
   6100       if (IdentifierInfo *Id = ND->getIdentifier()) {
   6101         auto I = WeakUndeclaredIdentifiers.find(Id);
   6102         if (I != WeakUndeclaredIdentifiers.end()) {
   6103           WeakInfo W = I->second;
   6104           DeclApplyPragmaWeak(S, ND, W);
   6105           WeakUndeclaredIdentifiers[Id] = W;
   6106         }
   6107       }
   6108     }
   6109   }
   6110 }
   6111 
   6112 /// ProcessDeclAttributes - Given a declarator (PD) with attributes indicated in
   6113 /// it, apply them to D.  This is a bit tricky because PD can have attributes
   6114 /// specified in many different places, and we need to find and apply them all.
   6115 void Sema::ProcessDeclAttributes(Scope *S, Decl *D, const Declarator &PD) {
   6116   // Apply decl attributes from the DeclSpec if present.
   6117   if (const AttributeList *Attrs = PD.getDeclSpec().getAttributes().getList())
   6118     ProcessDeclAttributeList(S, D, Attrs);
   6119 
   6120   // Walk the declarator structure, applying decl attributes that were in a type
   6121   // position to the decl itself.  This handles cases like:
   6122   //   int *__attr__(x)** D;
   6123   // when X is a decl attribute.
   6124   for (unsigned i = 0, e = PD.getNumTypeObjects(); i != e; ++i)
   6125     if (const AttributeList *Attrs = PD.getTypeObject(i).getAttrs())
   6126       ProcessDeclAttributeList(S, D, Attrs, /*IncludeCXX11Attributes=*/false);
   6127 
   6128   // Finally, apply any attributes on the decl itself.
   6129   if (const AttributeList *Attrs = PD.getAttributes())
   6130     ProcessDeclAttributeList(S, D, Attrs);
   6131 }
   6132 
   6133 /// Is the given declaration allowed to use a forbidden type?
   6134 /// If so, it'll still be annotated with an attribute that makes it
   6135 /// illegal to actually use.
   6136 static bool isForbiddenTypeAllowed(Sema &S, Decl *decl,
   6137                                    const DelayedDiagnostic &diag,
   6138                                    UnavailableAttr::ImplicitReason &reason) {
   6139   // Private ivars are always okay.  Unfortunately, people don't
   6140   // always properly make their ivars private, even in system headers.
   6141   // Plus we need to make fields okay, too.
   6142   if (!isa<FieldDecl>(decl) && !isa<ObjCPropertyDecl>(decl) &&
   6143       !isa<FunctionDecl>(decl))
   6144     return false;
   6145 
   6146   // Silently accept unsupported uses of __weak in both user and system
   6147   // declarations when it's been disabled, for ease of integration with
   6148   // -fno-objc-arc files.  We do have to take some care against attempts
   6149   // to define such things;  for now, we've only done that for ivars
   6150   // and properties.
   6151   if ((isa<ObjCIvarDecl>(decl) || isa<ObjCPropertyDecl>(decl))) {
   6152     if (diag.getForbiddenTypeDiagnostic() == diag::err_arc_weak_disabled ||
   6153         diag.getForbiddenTypeDiagnostic() == diag::err_arc_weak_no_runtime) {
   6154       reason = UnavailableAttr::IR_ForbiddenWeak;
   6155       return true;
   6156     }
   6157   }
   6158 
   6159   // Allow all sorts of things in system headers.
   6160   if (S.Context.getSourceManager().isInSystemHeader(decl->getLocation())) {
   6161     // Currently, all the failures dealt with this way are due to ARC
   6162     // restrictions.
   6163     reason = UnavailableAttr::IR_ARCForbiddenType;
   6164     return true;
   6165   }
   6166 
   6167   return false;
   6168 }
   6169 
   6170 /// Handle a delayed forbidden-type diagnostic.
   6171 static void handleDelayedForbiddenType(Sema &S, DelayedDiagnostic &diag,
   6172                                        Decl *decl) {
   6173   auto reason = UnavailableAttr::IR_None;
   6174   if (decl && isForbiddenTypeAllowed(S, decl, diag, reason)) {
   6175     assert(reason && "didn't set reason?");
   6176     decl->addAttr(UnavailableAttr::CreateImplicit(S.Context, "", reason,
   6177                                                   diag.Loc));
   6178     return;
   6179   }
   6180   if (S.getLangOpts().ObjCAutoRefCount)
   6181     if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(decl)) {
   6182       // FIXME: we may want to suppress diagnostics for all
   6183       // kind of forbidden type messages on unavailable functions.
   6184       if (FD->hasAttr<UnavailableAttr>() &&
   6185           diag.getForbiddenTypeDiagnostic() ==
   6186           diag::err_arc_array_param_no_ownership) {
   6187         diag.Triggered = true;
   6188         return;
   6189       }
   6190     }
   6191 
   6192   S.Diag(diag.Loc, diag.getForbiddenTypeDiagnostic())
   6193     << diag.getForbiddenTypeOperand() << diag.getForbiddenTypeArgument();
   6194   diag.Triggered = true;
   6195 }
   6196 
   6197 static bool isDeclDeprecated(Decl *D) {
   6198   do {
   6199     if (D->isDeprecated())
   6200       return true;
   6201     // A category implicitly has the availability of the interface.
   6202     if (const ObjCCategoryDecl *CatD = dyn_cast<ObjCCategoryDecl>(D))
   6203       if (const ObjCInterfaceDecl *Interface = CatD->getClassInterface())
   6204         return Interface->isDeprecated();
   6205   } while ((D = cast_or_null<Decl>(D->getDeclContext())));
   6206   return false;
   6207 }
   6208 
   6209 static bool isDeclUnavailable(Decl *D) {
   6210   do {
   6211     if (D->isUnavailable())
   6212       return true;
   6213     // A category implicitly has the availability of the interface.
   6214     if (const ObjCCategoryDecl *CatD = dyn_cast<ObjCCategoryDecl>(D))
   6215       if (const ObjCInterfaceDecl *Interface = CatD->getClassInterface())
   6216         return Interface->isUnavailable();
   6217   } while ((D = cast_or_null<Decl>(D->getDeclContext())));
   6218   return false;
   6219 }
   6220 
   6221 static const AvailabilityAttr *getAttrForPlatform(ASTContext &Context,
   6222                                                   const Decl *D) {
   6223   // Check each AvailabilityAttr to find the one for this platform.
   6224   for (const auto *A : D->attrs()) {
   6225     if (const auto *Avail = dyn_cast<AvailabilityAttr>(A)) {
   6226       // FIXME: this is copied from CheckAvailability. We should try to
   6227       // de-duplicate.
   6228 
   6229       // Check if this is an App Extension "platform", and if so chop off
   6230       // the suffix for matching with the actual platform.
   6231       StringRef ActualPlatform = Avail->getPlatform()->getName();
   6232       StringRef RealizedPlatform = ActualPlatform;
   6233       if (Context.getLangOpts().AppExt) {
   6234         size_t suffix = RealizedPlatform.rfind("_app_extension");
   6235         if (suffix != StringRef::npos)
   6236           RealizedPlatform = RealizedPlatform.slice(0, suffix);
   6237       }
   6238 
   6239       StringRef TargetPlatform = Context.getTargetInfo().getPlatformName();
   6240 
   6241       // Match the platform name.
   6242       if (RealizedPlatform == TargetPlatform)
   6243         return Avail;
   6244     }
   6245   }
   6246   return nullptr;
   6247 }
   6248 
   6249 static void DoEmitAvailabilityWarning(Sema &S, Sema::AvailabilityDiagnostic K,
   6250                                       Decl *Ctx, const NamedDecl *D,
   6251                                       StringRef Message, SourceLocation Loc,
   6252                                       const ObjCInterfaceDecl *UnknownObjCClass,
   6253                                       const ObjCPropertyDecl *ObjCProperty,
   6254                                       bool ObjCPropertyAccess) {
   6255   // Diagnostics for deprecated or unavailable.
   6256   unsigned diag, diag_message, diag_fwdclass_message;
   6257   unsigned diag_available_here = diag::note_availability_specified_here;
   6258 
   6259   // Matches 'diag::note_property_attribute' options.
   6260   unsigned property_note_select;
   6261 
   6262   // Matches diag::note_availability_specified_here.
   6263   unsigned available_here_select_kind;
   6264 
   6265   // Don't warn if our current context is deprecated or unavailable.
   6266   switch (K) {
   6267   case Sema::AD_Deprecation:
   6268     if (isDeclDeprecated(Ctx) || isDeclUnavailable(Ctx))
   6269       return;
   6270     diag = !ObjCPropertyAccess ? diag::warn_deprecated
   6271                                : diag::warn_property_method_deprecated;
   6272     diag_message = diag::warn_deprecated_message;
   6273     diag_fwdclass_message = diag::warn_deprecated_fwdclass_message;
   6274     property_note_select = /* deprecated */ 0;
   6275     available_here_select_kind = /* deprecated */ 2;
   6276     break;
   6277 
   6278   case Sema::AD_Unavailable:
   6279     if (isDeclUnavailable(Ctx))
   6280       return;
   6281     diag = !ObjCPropertyAccess ? diag::err_unavailable
   6282                                : diag::err_property_method_unavailable;
   6283     diag_message = diag::err_unavailable_message;
   6284     diag_fwdclass_message = diag::warn_unavailable_fwdclass_message;
   6285     property_note_select = /* unavailable */ 1;
   6286     available_here_select_kind = /* unavailable */ 0;
   6287 
   6288     if (auto attr = D->getAttr<UnavailableAttr>()) {
   6289       if (attr->isImplicit() && attr->getImplicitReason()) {
   6290         // Most of these failures are due to extra restrictions in ARC;
   6291         // reflect that in the primary diagnostic when applicable.
   6292         auto flagARCError = [&] {
   6293           if (S.getLangOpts().ObjCAutoRefCount &&
   6294               S.getSourceManager().isInSystemHeader(D->getLocation()))
   6295             diag = diag::err_unavailable_in_arc;
   6296         };
   6297 
   6298         switch (attr->getImplicitReason()) {
   6299         case UnavailableAttr::IR_None: break;
   6300 
   6301         case UnavailableAttr::IR_ARCForbiddenType:
   6302           flagARCError();
   6303           diag_available_here = diag::note_arc_forbidden_type;
   6304           break;
   6305 
   6306         case UnavailableAttr::IR_ForbiddenWeak:
   6307           if (S.getLangOpts().ObjCWeakRuntime)
   6308             diag_available_here = diag::note_arc_weak_disabled;
   6309           else
   6310             diag_available_here = diag::note_arc_weak_no_runtime;
   6311           break;
   6312 
   6313         case UnavailableAttr::IR_ARCForbiddenConversion:
   6314           flagARCError();
   6315           diag_available_here = diag::note_performs_forbidden_arc_conversion;
   6316           break;
   6317 
   6318         case UnavailableAttr::IR_ARCInitReturnsUnrelated:
   6319           flagARCError();
   6320           diag_available_here = diag::note_arc_init_returns_unrelated;
   6321           break;
   6322 
   6323         case UnavailableAttr::IR_ARCFieldWithOwnership:
   6324           flagARCError();
   6325           diag_available_here = diag::note_arc_field_with_ownership;
   6326           break;
   6327         }
   6328       }
   6329     }
   6330     break;
   6331 
   6332   case Sema::AD_Partial:
   6333     diag = diag::warn_partial_availability;
   6334     diag_message = diag::warn_partial_message;
   6335     diag_fwdclass_message = diag::warn_partial_fwdclass_message;
   6336     property_note_select = /* partial */ 2;
   6337     available_here_select_kind = /* partial */ 3;
   6338     break;
   6339   }
   6340 
   6341   CharSourceRange UseRange;
   6342   StringRef Replacement;
   6343   if (K == Sema::AD_Deprecation) {
   6344     if (auto attr = D->getAttr<DeprecatedAttr>())
   6345       Replacement = attr->getReplacement();
   6346     if (auto attr = getAttrForPlatform(S.Context, D))
   6347       Replacement = attr->getReplacement();
   6348 
   6349     if (!Replacement.empty())
   6350       UseRange =
   6351           CharSourceRange::getCharRange(Loc, S.getLocForEndOfToken(Loc));
   6352   }
   6353 
   6354   if (!Message.empty()) {
   6355     S.Diag(Loc, diag_message) << D << Message
   6356       << (UseRange.isValid() ?
   6357           FixItHint::CreateReplacement(UseRange, Replacement) : FixItHint());
   6358     if (ObjCProperty)
   6359       S.Diag(ObjCProperty->getLocation(), diag::note_property_attribute)
   6360           << ObjCProperty->getDeclName() << property_note_select;
   6361   } else if (!UnknownObjCClass) {
   6362     S.Diag(Loc, diag) << D
   6363       << (UseRange.isValid() ?
   6364           FixItHint::CreateReplacement(UseRange, Replacement) : FixItHint());
   6365     if (ObjCProperty)
   6366       S.Diag(ObjCProperty->getLocation(), diag::note_property_attribute)
   6367           << ObjCProperty->getDeclName() << property_note_select;
   6368   } else {
   6369     S.Diag(Loc, diag_fwdclass_message) << D
   6370       << (UseRange.isValid() ?
   6371           FixItHint::CreateReplacement(UseRange, Replacement) : FixItHint());
   6372     S.Diag(UnknownObjCClass->getLocation(), diag::note_forward_class);
   6373   }
   6374 
   6375   // The declaration can have multiple availability attributes, we are looking
   6376   // at one of them.
   6377   const AvailabilityAttr *A = getAttrForPlatform(S.Context, D);
   6378   if (A && A->isInherited()) {
   6379     for (const Decl *Redecl = D->getMostRecentDecl(); Redecl;
   6380          Redecl = Redecl->getPreviousDecl()) {
   6381       const AvailabilityAttr *AForRedecl = getAttrForPlatform(S.Context,
   6382                                                               Redecl);
   6383       if (AForRedecl && !AForRedecl->isInherited()) {
   6384         // If D is a declaration with inherited attributes, the note should
   6385         // point to the declaration with actual attributes.
   6386         S.Diag(Redecl->getLocation(), diag_available_here) << D
   6387             << available_here_select_kind;
   6388         break;
   6389       }
   6390     }
   6391   }
   6392   else
   6393     S.Diag(D->getLocation(), diag_available_here)
   6394         << D << available_here_select_kind;
   6395 
   6396   if (K == Sema::AD_Partial)
   6397     S.Diag(Loc, diag::note_partial_availability_silence) << D;
   6398 }
   6399 
   6400 static void handleDelayedAvailabilityCheck(Sema &S, DelayedDiagnostic &DD,
   6401                                            Decl *Ctx) {
   6402   assert(DD.Kind == DelayedDiagnostic::Deprecation ||
   6403          DD.Kind == DelayedDiagnostic::Unavailable);
   6404   Sema::AvailabilityDiagnostic AD = DD.Kind == DelayedDiagnostic::Deprecation
   6405                                         ? Sema::AD_Deprecation
   6406                                         : Sema::AD_Unavailable;
   6407   DD.Triggered = true;
   6408   DoEmitAvailabilityWarning(
   6409       S, AD, Ctx, DD.getDeprecationDecl(), DD.getDeprecationMessage(), DD.Loc,
   6410       DD.getUnknownObjCClass(), DD.getObjCProperty(), false);
   6411 }
   6412 
   6413 void Sema::PopParsingDeclaration(ParsingDeclState state, Decl *decl) {
   6414   assert(DelayedDiagnostics.getCurrentPool());
   6415   DelayedDiagnosticPool &poppedPool = *DelayedDiagnostics.getCurrentPool();
   6416   DelayedDiagnostics.popWithoutEmitting(state);
   6417 
   6418   // When delaying diagnostics to run in the context of a parsed
   6419   // declaration, we only want to actually emit anything if parsing
   6420   // succeeds.
   6421   if (!decl) return;
   6422 
   6423   // We emit all the active diagnostics in this pool or any of its
   6424   // parents.  In general, we'll get one pool for the decl spec
   6425   // and a child pool for each declarator; in a decl group like:
   6426   //   deprecated_typedef foo, *bar, baz();
   6427   // only the declarator pops will be passed decls.  This is correct;
   6428   // we really do need to consider delayed diagnostics from the decl spec
   6429   // for each of the different declarations.
   6430   const DelayedDiagnosticPool *pool = &poppedPool;
   6431   do {
   6432     for (DelayedDiagnosticPool::pool_iterator
   6433            i = pool->pool_begin(), e = pool->pool_end(); i != e; ++i) {
   6434       // This const_cast is a bit lame.  Really, Triggered should be mutable.
   6435       DelayedDiagnostic &diag = const_cast<DelayedDiagnostic&>(*i);
   6436       if (diag.Triggered)
   6437         continue;
   6438 
   6439       switch (diag.Kind) {
   6440       case DelayedDiagnostic::Deprecation:
   6441       case DelayedDiagnostic::Unavailable:
   6442         // Don't bother giving deprecation/unavailable diagnostics if
   6443         // the decl is invalid.
   6444         if (!decl->isInvalidDecl())
   6445           handleDelayedAvailabilityCheck(*this, diag, decl);
   6446         break;
   6447 
   6448       case DelayedDiagnostic::Access:
   6449         HandleDelayedAccessCheck(diag, decl);
   6450         break;
   6451 
   6452       case DelayedDiagnostic::ForbiddenType:
   6453         handleDelayedForbiddenType(*this, diag, decl);
   6454         break;
   6455       }
   6456     }
   6457   } while ((pool = pool->getParent()));
   6458 }
   6459 
   6460 /// Given a set of delayed diagnostics, re-emit them as if they had
   6461 /// been delayed in the current context instead of in the given pool.
   6462 /// Essentially, this just moves them to the current pool.
   6463 void Sema::redelayDiagnostics(DelayedDiagnosticPool &pool) {
   6464   DelayedDiagnosticPool *curPool = DelayedDiagnostics.getCurrentPool();
   6465   assert(curPool && "re-emitting in undelayed context not supported");
   6466   curPool->steal(pool);
   6467 }
   6468 
   6469 void Sema::EmitAvailabilityWarning(AvailabilityDiagnostic AD,
   6470                                    NamedDecl *D, StringRef Message,
   6471                                    SourceLocation Loc,
   6472                                    const ObjCInterfaceDecl *UnknownObjCClass,
   6473                                    const ObjCPropertyDecl  *ObjCProperty,
   6474                                    bool ObjCPropertyAccess) {
   6475   // Delay if we're currently parsing a declaration.
   6476   if (DelayedDiagnostics.shouldDelayDiagnostics() && AD != AD_Partial) {
   6477     DelayedDiagnostics.add(DelayedDiagnostic::makeAvailability(
   6478         AD, Loc, D, UnknownObjCClass, ObjCProperty, Message,
   6479         ObjCPropertyAccess));
   6480     return;
   6481   }
   6482 
   6483   Decl *Ctx = cast<Decl>(getCurLexicalContext());
   6484   DoEmitAvailabilityWarning(*this, AD, Ctx, D, Message, Loc, UnknownObjCClass,
   6485                             ObjCProperty, ObjCPropertyAccess);
   6486 }
   6487