summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Bytecode
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2006-01-23 07:39:03 +0000
committerReid Spencer <rspencer@reidspencer.com>2006-01-23 07:39:03 +0000
commit95c05bf1b47d0b91bddb4aac509c4b1b62a89dca (patch)
treed925b53d0ded8d2df147df771c405ff880c50503 /llvm/lib/Bytecode
parent763dfd772314d19b33bc7e004ddff0d16295f1e7 (diff)
downloadbcm5719-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.cpp19
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!");
OpenPOWER on IntegriCloud