diff options
| author | Chris Lattner <sabre@nondot.org> | 2004-11-15 23:18:09 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2004-11-15 23:18:09 +0000 |
| commit | b264f7f428ef69b1eff9b99029c509d6cf484e62 (patch) | |
| tree | cde66140dd9977a3d25a84dbaf658c08cab51fa8 /llvm/lib/ExecutionEngine | |
| parent | 9cc2dac7c14d19c7da6923483df1cd5d09c48072 (diff) | |
| download | bcm5719-llvm-b264f7f428ef69b1eff9b99029c509d6cf484e62.tar.gz bcm5719-llvm-b264f7f428ef69b1eff9b99029c509d6cf484e62.zip | |
There is no reason to try to materialize the function from bytecode if it
already has been. This may be a small speedup.
llvm-svn: 17863
Diffstat (limited to 'llvm/lib/ExecutionEngine')
| -rw-r--r-- | llvm/lib/ExecutionEngine/JIT/JIT.cpp | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/llvm/lib/ExecutionEngine/JIT/JIT.cpp b/llvm/lib/ExecutionEngine/JIT/JIT.cpp index d9866c87ee4..71f1dd0d6b3 100644 --- a/llvm/lib/ExecutionEngine/JIT/JIT.cpp +++ b/llvm/lib/ExecutionEngine/JIT/JIT.cpp @@ -239,15 +239,18 @@ void *JIT::getPointerToFunction(Function *F) { return Addr; // Check if function already code gen'd // Make sure we read in the function if it exists in this Module - try { - MP->materializeFunction(F); - } catch ( std::string& errmsg ) { - std::cerr << "Error reading bytecode file: " << errmsg << "\n"; - abort(); - } catch (...) { - std::cerr << "Error reading bytecode file!\n"; - abort(); - } + if (F->hasNotBeenReadFromBytecode()) + try { + MP->materializeFunction(F); + } catch ( std::string& errmsg ) { + std::cerr << "Error reading function '" << F->getName() + << "' from bytecode file: " << errmsg << "\n"; + abort(); + } catch (...) { + std::cerr << "Error reading function '" << F->getName() + << "from bytecode file!\n"; + abort(); + } if (F->isExternal()) { void *Addr = getPointerToNamedFunction(F->getName()); |

