diff --git a/clang/lib/AST/Interp/InterpBuiltin.cpp b/clang/lib/AST/Interp/InterpBuiltin.cpp --- a/clang/lib/AST/Interp/InterpBuiltin.cpp +++ b/clang/lib/AST/Interp/InterpBuiltin.cpp @@ -121,6 +121,15 @@ return true; } +static bool interp__builtin_inf(InterpState &S, CodePtr OpPC, + const InterpFrame *Frame, const Function *F) { + const llvm::fltSemantics &TargetSemantics = + S.getCtx().getFloatTypeSemantics(F->getDecl()->getReturnType()); + + S.Stk.push(Floating::getInf(TargetSemantics)); + return true; +} + bool InterpretBuiltin(InterpState &S, CodePtr OpPC, const Function *F) { InterpFrame *Frame = S.Current; APValue Dummy; @@ -152,6 +161,20 @@ return Ret(S, OpPC, Dummy); break; + case Builtin::BI__builtin_huge_val: + case Builtin::BI__builtin_huge_valf: + case Builtin::BI__builtin_huge_vall: + case Builtin::BI__builtin_huge_valf16: + case Builtin::BI__builtin_huge_valf128: + case Builtin::BI__builtin_inf: + case Builtin::BI__builtin_inff: + case Builtin::BI__builtin_infl: + case Builtin::BI__builtin_inff16: + case Builtin::BI__builtin_inff128: + if (interp__builtin_inf(S, OpPC, Frame, F)) + return Ret(S, OpPC, Dummy); + break; + default: return false; }