diff options
author | Chris Lattner <sabre@nondot.org> | 2009-09-23 01:46:04 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-09-23 01:46:04 +0000 |
commit | fbd39762e9db897ffd8e30ce7d387715cba6d4c1 (patch) | |
tree | 0046ca4f019d2717a415ed81c4ed7960087578b1 /lib/ExecutionEngine/ExecutionEngine.cpp | |
parent | cd26ec5f3c089b3b24f80ff200e94e681eb9e1ee (diff) |
Make EngineBuilder return more error codes, by KS Sreeram.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@82600 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/ExecutionEngine/ExecutionEngine.cpp')
-rw-r--r-- | lib/ExecutionEngine/ExecutionEngine.cpp | 35 |
1 files changed, 22 insertions, 13 deletions
diff --git a/lib/ExecutionEngine/ExecutionEngine.cpp b/lib/ExecutionEngine/ExecutionEngine.cpp index 5be3aa87e0..fa6209d2df 100644 --- a/lib/ExecutionEngine/ExecutionEngine.cpp +++ b/lib/ExecutionEngine/ExecutionEngine.cpp @@ -269,7 +269,8 @@ static void *CreateArgv(LLVMContext &C, ExecutionEngine *EE, /// runStaticConstructorsDestructors - This method is used to execute all of /// the static constructors or destructors for a module, depending on the /// value of isDtors. -void ExecutionEngine::runStaticConstructorsDestructors(Module *module, bool isDtors) { +void ExecutionEngine::runStaticConstructorsDestructors(Module *module, + bool isDtors) { const char *Name = isDtors ? "llvm.global_dtors" : "llvm.global_ctors"; // Execute global ctors/dtors for each module in the program. @@ -425,30 +426,38 @@ ExecutionEngine *EngineBuilder::create() { // create, we assume they only want the JIT, and we fail if they only want // the interpreter. if (JMM) { - if (WhichEngine & EngineKind::JIT) { + if (WhichEngine & EngineKind::JIT) WhichEngine = EngineKind::JIT; - } else { + else { *ErrorStr = "Cannot create an interpreter with a memory manager."; + return 0; } } - ExecutionEngine *EE = 0; - // Unless the interpreter was explicitly selected or the JIT is not linked, // try making a JIT. - if (WhichEngine & EngineKind::JIT && ExecutionEngine::JITCtor) { - EE = ExecutionEngine::JITCtor(MP, ErrorStr, JMM, OptLevel, - AllocateGVsWithCode); + if (WhichEngine & EngineKind::JIT) { + if (ExecutionEngine::JITCtor) { + ExecutionEngine *EE = + ExecutionEngine::JITCtor(MP, ErrorStr, JMM, OptLevel, + AllocateGVsWithCode); + if (EE) return EE; + } else { + *ErrorStr = "JIT has not been linked in."; + return 0; + } } // If we can't make a JIT and we didn't request one specifically, try making // an interpreter instead. - if (WhichEngine & EngineKind::Interpreter && EE == 0 && - ExecutionEngine::InterpCtor) { - EE = ExecutionEngine::InterpCtor(MP, ErrorStr); + if (WhichEngine & EngineKind::Interpreter) { + if (ExecutionEngine::InterpCtor) + return ExecutionEngine::InterpCtor(MP, ErrorStr); + *ErrorStr = "Interpreter has not been linked in."; + return 0; } - - return EE; + + return 0; } /// getPointerToGlobal - This returns the address of the specified global |