diff options
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaChecking.cpp | 2 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaExpr.cpp | 20 | 
2 files changed, 12 insertions, 10 deletions
| diff --git a/clang/lib/Sema/SemaChecking.cpp b/clang/lib/Sema/SemaChecking.cpp index a45d4fdfd70..b74be1b30aa 100644 --- a/clang/lib/Sema/SemaChecking.cpp +++ b/clang/lib/Sema/SemaChecking.cpp @@ -1308,7 +1308,6 @@ Sema::CheckBuiltinFunctionCall(FunctionDecl *FDecl, unsigned BuiltinID,      // check for the argument.      if (SemaBuiltinRWPipe(*this, TheCall))        return ExprError(); -    TheCall->setType(Context.IntTy);      break;    case Builtin::BIreserve_read_pipe:    case Builtin::BIreserve_write_pipe: @@ -1340,7 +1339,6 @@ Sema::CheckBuiltinFunctionCall(FunctionDecl *FDecl, unsigned BuiltinID,    case Builtin::BIget_pipe_max_packets:      if (SemaBuiltinPipePackets(*this, TheCall))        return ExprError(); -    TheCall->setType(Context.UnsignedIntTy);      break;    case Builtin::BIto_global:    case Builtin::BIto_local: diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index c9be58be9f1..8921d851ffb 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -5547,12 +5547,17 @@ Sema::BuildResolvedCallExpr(Expr *Fn, NamedDecl *NDecl,    // We special-case function promotion here because we only allow promoting    // builtin functions to function pointers in the callee of a call.    ExprResult Result; +  QualType ReturnTy;    if (BuiltinID &&        Fn->getType()->isSpecificBuiltinType(BuiltinType::BuiltinFn)) { -    Result = ImpCastExprToType(Fn, Context.getPointerType(FDecl->getType()), -                               CK_BuiltinFnToFnPtr).get(); +    // Extract the return type from the (builtin) function pointer type. +    auto FnPtrTy = Context.getPointerType(FDecl->getType()); +    Result = ImpCastExprToType(Fn, FnPtrTy, CK_BuiltinFnToFnPtr).get(); +    auto FnTy = FnPtrTy->getPointeeType()->castAs<FunctionType>(); +    ReturnTy = FnTy->getReturnType();    } else {      Result = CallExprUnaryConversions(Fn); +    ReturnTy = Context.BoolTy;    }    if (Result.isInvalid())      return ExprError(); @@ -5562,13 +5567,12 @@ Sema::BuildResolvedCallExpr(Expr *Fn, NamedDecl *NDecl,    // of arguments and function on error.    CallExpr *TheCall;    if (Config) -    TheCall = new (Context) CUDAKernelCallExpr(Context, Fn, -                                               cast<CallExpr>(Config), Args, -                                               Context.BoolTy, VK_RValue, -                                               RParenLoc); +    TheCall = +        new (Context) CUDAKernelCallExpr(Context, Fn, cast<CallExpr>(Config), +                                         Args, ReturnTy, VK_RValue, RParenLoc);    else -    TheCall = new (Context) CallExpr(Context, Fn, Args, Context.BoolTy, -                                     VK_RValue, RParenLoc); +    TheCall = new (Context) +        CallExpr(Context, Fn, Args, ReturnTy, VK_RValue, RParenLoc);    if (!getLangOpts().CPlusPlus) {      // C cannot always handle TypoExpr nodes in builtin calls and direct | 

