summaryrefslogtreecommitdiffstats
path: root/llvm/lib/ExecutionEngine/JIT
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-11-15 23:18:09 +0000
committerChris Lattner <sabre@nondot.org>2004-11-15 23:18:09 +0000
commitb264f7f428ef69b1eff9b99029c509d6cf484e62 (patch)
treecde66140dd9977a3d25a84dbaf658c08cab51fa8 /llvm/lib/ExecutionEngine/JIT
parent9cc2dac7c14d19c7da6923483df1cd5d09c48072 (diff)
downloadbcm5719-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/JIT')
-rw-r--r--llvm/lib/ExecutionEngine/JIT/JIT.cpp21
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());
OpenPOWER on IntegriCloud