From c72efbeb42a9eaa0a83b8bba4954dcaf9ae64103 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 23 Sep 2009 02:03:49 +0000 Subject: [PATCH] errorstr can be null, don't unconditionally set it. Only report that "the jit has not been linked in" if the interpreter failed. This fixes a unit test failure. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@82601 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/ExecutionEngine/ExecutionEngine.cpp | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/lib/ExecutionEngine/ExecutionEngine.cpp b/lib/ExecutionEngine/ExecutionEngine.cpp index fa6209d2dff..335d4deff84 100644 --- a/lib/ExecutionEngine/ExecutionEngine.cpp +++ b/lib/ExecutionEngine/ExecutionEngine.cpp @@ -429,7 +429,8 @@ ExecutionEngine *EngineBuilder::create() { if (WhichEngine & EngineKind::JIT) WhichEngine = EngineKind::JIT; else { - *ErrorStr = "Cannot create an interpreter with a memory manager."; + if (ErrorStr) + *ErrorStr = "Cannot create an interpreter with a memory manager."; return 0; } } @@ -442,9 +443,6 @@ ExecutionEngine *EngineBuilder::create() { ExecutionEngine::JITCtor(MP, ErrorStr, JMM, OptLevel, AllocateGVsWithCode); if (EE) return EE; - } else { - *ErrorStr = "JIT has not been linked in."; - return 0; } } @@ -453,10 +451,15 @@ ExecutionEngine *EngineBuilder::create() { if (WhichEngine & EngineKind::Interpreter) { if (ExecutionEngine::InterpCtor) return ExecutionEngine::InterpCtor(MP, ErrorStr); - *ErrorStr = "Interpreter has not been linked in."; + if (ErrorStr) + *ErrorStr = "Interpreter has not been linked in."; return 0; } - + + if ((WhichEngine & EngineKind::JIT) && ExecutionEngine::JITCtor == 0) { + if (ErrorStr) + *ErrorStr = "JIT has not been linked in."; + } return 0; }