From: Chris Lattner Date: Mon, 9 Apr 2007 20:28:40 +0000 (+0000) Subject: Fix a bug where calling materializeModule could corrupt the module, reading X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=24e90d3c5b65844dcd0dbeb83a92a5b35f0de4c8;p=oota-llvm.git Fix a bug where calling materializeModule could corrupt the module, reading multiple copies of the function into the Function*. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@35831 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Bytecode/Reader/Reader.cpp b/lib/Bytecode/Reader/Reader.cpp index ffb731f3141..fd4a54920f4 100644 --- a/lib/Bytecode/Reader/Reader.cpp +++ b/lib/Bytecode/Reader/Reader.cpp @@ -1672,15 +1672,14 @@ bool BytecodeReader::ParseAllFunctionBodies(std::string* ErrMsg) { return true; } - LazyFunctionMap::iterator Fi = LazyFunctionLoadMap.begin(); - LazyFunctionMap::iterator Fe = LazyFunctionLoadMap.end(); - - while (Fi != Fe) { - Function* Func = Fi->first; - BlockStart = At = Fi->second.Buf; - BlockEnd = Fi->second.EndBuf; - ParseFunctionBody(Func); - ++Fi; + for (LazyFunctionMap::iterator I = LazyFunctionLoadMap.begin(), + E = LazyFunctionLoadMap.end(); I != E; ++I) { + Function *Func = I->first; + if (Func->hasNotBeenReadFromBytecode()) { + BlockStart = At = I->second.Buf; + BlockEnd = I->second.EndBuf; + ParseFunctionBody(Func); + } } return false; }