diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2006-01-23 07:39:03 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2006-01-23 07:39:03 +0000 |
commit | 95c05bf1b47d0b91bddb4aac509c4b1b62a89dca (patch) | |
tree | d925b53d0ded8d2df147df771c405ff880c50503 /llvm/lib/Bytecode | |
parent | 763dfd772314d19b33bc7e004ddff0d16295f1e7 (diff) | |
download | bcm5719-llvm-95c05bf1b47d0b91bddb4aac509c4b1b62a89dca.tar.gz bcm5719-llvm-95c05bf1b47d0b91bddb4aac509c4b1b62a89dca.zip |
For PR411:
Don't try to be smart about fixing intrinsic functions when they're read
in, just fix them after the module is read when all names are resolved.
llvm-svn: 25539
Diffstat (limited to 'llvm/lib/Bytecode')
-rw-r--r-- | llvm/lib/Bytecode/Reader/Reader.cpp | 19 |
1 files changed, 5 insertions, 14 deletions
diff --git a/llvm/lib/Bytecode/Reader/Reader.cpp b/llvm/lib/Bytecode/Reader/Reader.cpp index 6c91a4ad6a7..397082752f1 100644 --- a/llvm/lib/Bytecode/Reader/Reader.cpp +++ b/llvm/lib/Bytecode/Reader/Reader.cpp @@ -1033,13 +1033,6 @@ 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; @@ -2032,13 +2025,6 @@ 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. @@ -2402,6 +2388,11 @@ 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!"); |