diff options
Diffstat (limited to 'clang/lib/Sema')
| -rw-r--r-- | clang/lib/Sema/SemaExpr.cpp | 4 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaType.cpp | 25 | 
2 files changed, 27 insertions, 2 deletions
| diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 406b8201a3f..e232230db77 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -7037,11 +7037,11 @@ Sema::OwningExprResult Sema::ActOnBlockStmtExpr(SourceLocation CaretLoc,    QualType BlockTy;    if (!BSI->hasPrototype)      BlockTy = Context.getFunctionType(RetTy, 0, 0, false, 0, false, false, 0, 0, -                                  FunctionType::ExtInfo(NoReturn, CC_Default)); +                                FunctionType::ExtInfo(NoReturn, 0, CC_Default));    else      BlockTy = Context.getFunctionType(RetTy, ArgTypes.data(), ArgTypes.size(),                                        BSI->isVariadic, 0, false, false, 0, 0, -                                   FunctionType::ExtInfo(NoReturn, CC_Default)); +                                FunctionType::ExtInfo(NoReturn, 0, CC_Default));    // FIXME: Check that return/parameter types are complete/non-abstract    DiagnoseUnusedParameters(BSI->Params.begin(), BSI->Params.end()); diff --git a/clang/lib/Sema/SemaType.cpp b/clang/lib/Sema/SemaType.cpp index ce410a7605c..2c6cc7fc9d1 100644 --- a/clang/lib/Sema/SemaType.cpp +++ b/clang/lib/Sema/SemaType.cpp @@ -1739,6 +1739,30 @@ bool ProcessFnAttr(Sema &S, QualType &Type, const AttributeList &Attr) {      return false;    } +  if (Attr.getKind() == AttributeList::AT_regparm) { +    // The warning is emitted elsewhere +    if (Attr.getNumArgs() != 1) { +      return false; +    } + +    // Delay if this is not a function or pointer to block. +    if (!Type->isFunctionPointerType() +        && !Type->isBlockPointerType() +        && !Type->isFunctionType()) +      return true; + +    // Otherwise we can process right away. +    Expr *NumParamsExpr = static_cast<Expr *>(Attr.getArg(0)); +    llvm::APSInt NumParams(32); + +    // The warning is emitted elsewhere +    if (!NumParamsExpr->isIntegerConstantExpr(NumParams, S.Context)) +      return false; + +    Type = S.Context.getRegParmType(Type, NumParams.getZExtValue()); +    return false; +  } +    // Otherwise, a calling convention.    if (Attr.getNumArgs() != 0) {      S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0; @@ -1868,6 +1892,7 @@ void ProcessTypeAttributeList(Sema &S, QualType &Result,      case AttributeList::AT_cdecl:      case AttributeList::AT_fastcall:      case AttributeList::AT_stdcall: +    case AttributeList::AT_regparm:        // Don't process these on the DeclSpec.        if (IsDeclSpec ||            ProcessFnAttr(S, Result, *AL)) | 

