mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 07:34:33 +00:00
the bytecode reader supports dematerializeFunction
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@35475 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
cb2df95c88
commit
f735f7b3ac
@ -1636,8 +1636,6 @@ bool BytecodeReader::ParseFunction(Function* Func, std::string* ErrMsg) {
|
||||
BlockEnd = Fi->second.EndBuf;
|
||||
assert(Fi->first == Func && "Found wrong function?");
|
||||
|
||||
LazyFunctionLoadMap.erase(Fi);
|
||||
|
||||
this->ParseFunctionBody(Func);
|
||||
return false;
|
||||
}
|
||||
@ -1668,7 +1666,6 @@ bool BytecodeReader::ParseAllFunctionBodies(std::string* ErrMsg) {
|
||||
ParseFunctionBody(Func);
|
||||
++Fi;
|
||||
}
|
||||
LazyFunctionLoadMap.clear();
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -154,20 +154,38 @@ public:
|
||||
bool ParseAllFunctionBodies(std::string* ErrMsg);
|
||||
|
||||
/// @brief Parse the next function of specific type
|
||||
bool ParseFunction(Function* Func, std::string* ErrMsg) ;
|
||||
bool ParseFunction(Function* Func, std::string* ErrMsg);
|
||||
|
||||
/// This method is abstract in the parent ModuleProvider class. Its
|
||||
/// implementation is identical to the ParseFunction method.
|
||||
/// @see ParseFunction
|
||||
/// @brief Make a specific function materialize.
|
||||
virtual bool materializeFunction(Function *F, std::string *ErrMsg = 0) {
|
||||
LazyFunctionMap::iterator Fi = LazyFunctionLoadMap.find(F);
|
||||
if (Fi == LazyFunctionLoadMap.end())
|
||||
return false;
|
||||
// If it already is material, ignore the request.
|
||||
if (!F->hasNotBeenReadFromBytecode()) return false;
|
||||
|
||||
assert(LazyFunctionLoadMap.count(F) &&
|
||||
"not materialized but I don't know about it?");
|
||||
if (ParseFunction(F,ErrMsg))
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
/// dematerializeFunction - If the given function is read in, and if the
|
||||
/// module provider supports it, release the memory for the function, and set
|
||||
/// it up to be materialized lazily. If the provider doesn't support this
|
||||
/// capability, this method is a noop.
|
||||
///
|
||||
virtual void dematerializeFunction(Function *F) {
|
||||
// If the function is not materialized, or if it is a prototype, ignore.
|
||||
if (F->hasNotBeenReadFromBytecode() ||
|
||||
F->isDeclaration())
|
||||
return;
|
||||
|
||||
// Just forget the function body, we can remat it later.
|
||||
F->deleteBody();
|
||||
F->setLinkage(GlobalValue::GhostLinkage);
|
||||
}
|
||||
|
||||
/// This method is abstract in the parent ModuleProvider class. Its
|
||||
/// implementation is identical to ParseAllFunctionBodies.
|
||||
|
Loading…
x
Reference in New Issue
Block a user