diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2006-01-23 08:11:03 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2006-01-23 08:11:03 +0000 |
commit | 49e732c5f2d8a4c1605b16eaf2eaabb74d286169 (patch) | |
tree | 9b6b0c87bd5dea99eac169e4529dee86c651c970 /lib/Bytecode/Reader/Reader.cpp | |
parent | c79925a395b769cdb582518f90b47ecbc513b702 (diff) |
Revert last patch because it messes up the JIT, amongst other things.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25541 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bytecode/Reader/Reader.cpp')
-rw-r--r-- | lib/Bytecode/Reader/Reader.cpp | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/lib/Bytecode/Reader/Reader.cpp b/lib/Bytecode/Reader/Reader.cpp index 397082752f..6c91a4ad6a 100644 --- a/lib/Bytecode/Reader/Reader.cpp +++ b/lib/Bytecode/Reader/Reader.cpp @@ -1033,6 +1033,13 @@ void BytecodeReader::ParseInstruction(std::vector<unsigned> &Oprnds, BB->getInstList().push_back(Result); + if (this->hasUpgradedIntrinsicFunctions && isCall) + if (Instruction* inst = UpgradeIntrinsicCall(cast<CallInst>(Result))) { + Result->replaceAllUsesWith(inst); + Result->eraseFromParent(); + Result = inst; + } + unsigned TypeSlot; if (Result->getType() == InstTy) TypeSlot = iType; @@ -2025,6 +2032,13 @@ void BytecodeReader::ParseModuleGlobalInfo() { Function *Func = new Function(FTy, GlobalValue::ExternalLinkage, "", TheModule); + // Replace with upgraded intrinsic function, if applicable. + if (Function* upgrdF = UpgradeIntrinsicFunction(Func)) { + hasUpgradedIntrinsicFunctions = true; + Func->eraseFromParent(); + Func = upgrdF; + } + insertValue(Func, (FnSignature & (~0U >> 1)) >> 5, ModuleValues); // Flags are not used yet. @@ -2388,11 +2402,6 @@ void BytecodeReader::ParseBytecode(BufPtr Buf, unsigned Length, // Parse the module contents this->ParseModule(); - // Look for intrinsic functions and CallInst that need to be upgraded - for (Module::iterator FI = TheModule->begin(), FE = TheModule->end(); - FI != FE; ++FI) - UpgradeCallsToIntrinsic(FI); - // Check for missing functions if (hasFunctions()) error("Function expected, but bytecode stream ended!"); |