From 00750441ad99fa20937773c65bc2719be068818b Mon Sep 17 00:00:00 2001 From: Hyxogen <8938732+Hyxogen@users.noreply.github.com> Date: Wed, 14 Feb 2024 14:19:02 +0100 Subject: [PATCH] interpreter: check if parent stackframe exists --- llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp b/llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp index e97ad00ac498..3b6c965ef064 100644 --- a/llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp +++ b/llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp @@ -274,8 +274,6 @@ GenericValue Interpreter::callExternalFunction(Function *F, TheInterpreter = this; auto &Fns = getFunctions(); - assert(ECStack.size() > 1); - ExecutionContext &CallerFrame = *(ECStack.end() - 2); std::unique_lock Guard(Fns.Lock); // Do a lookup to see if the function is in our cache... this should just be a @@ -285,7 +283,8 @@ GenericValue Interpreter::callExternalFunction(Function *F, if (ExFunc Fn = (FI == Fns.ExportedFunctions.end()) ? lookupFunction(F, LazyFunctionCreator) : FI->second) { Guard.unlock(); - return Fn(F->getFunctionType(), ArgVals, CallerFrame.Caller->getAttributes()); + AttributeList Attrs = ECStack.size() > 1 ? (ECStack.end() - 2)->Caller->getAttributes() : AttributeList(); + return Fn(F->getFunctionType(), ArgVals, Attrs); } #ifdef USE_LIBFFI