There is no reason to try to materialize the function from bytecode if it

already has been.  This may be a small speedup.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17863 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner
2004-11-15 23:18:09 +00:00
parent 5aa3ed92de
commit 0050ef8319

View File

@ -239,15 +239,18 @@ void *JIT::getPointerToFunction(Function *F) {
return Addr; // Check if function already code gen'd return Addr; // Check if function already code gen'd
// Make sure we read in the function if it exists in this Module // Make sure we read in the function if it exists in this Module
try { if (F->hasNotBeenReadFromBytecode())
MP->materializeFunction(F); try {
} catch ( std::string& errmsg ) { MP->materializeFunction(F);
std::cerr << "Error reading bytecode file: " << errmsg << "\n"; } catch ( std::string& errmsg ) {
abort(); std::cerr << "Error reading function '" << F->getName()
} catch (...) { << "' from bytecode file: " << errmsg << "\n";
std::cerr << "Error reading bytecode file!\n"; abort();
abort(); } catch (...) {
} std::cerr << "Error reading function '" << F->getName()
<< "from bytecode file!\n";
abort();
}
if (F->isExternal()) { if (F->isExternal()) {
void *Addr = getPointerToNamedFunction(F->getName()); void *Addr = getPointerToNamedFunction(F->getName());