diff options
author | Chris Lattner <sabre@nondot.org> | 2004-08-12 03:17:02 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-08-12 03:17:02 +0000 |
commit | 7f1c7ede5b134845a0f98d38dcfe253ebd9991b4 (patch) | |
tree | 442f5d13cf3bab66d2f21641b68431e89022e5a3 /llvm/lib/Transforms/Utils | |
parent | 58040a63ee8563117199fc222ae6d101d3277673 (diff) | |
download | bcm5719-llvm-7f1c7ede5b134845a0f98d38dcfe253ebd9991b4.tar.gz bcm5719-llvm-7f1c7ede5b134845a0f98d38dcfe253ebd9991b4.zip |
Fix code extraction of unwind blocks. This fixed bugs that bugpoint can
run into. This should go into 1.3
llvm-svn: 15679
Diffstat (limited to 'llvm/lib/Transforms/Utils')
-rw-r--r-- | llvm/lib/Transforms/Utils/CodeExtractor.cpp | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/llvm/lib/Transforms/Utils/CodeExtractor.cpp b/llvm/lib/Transforms/Utils/CodeExtractor.cpp index dbc358bf61d..b3de38a5db3 100644 --- a/llvm/lib/Transforms/Utils/CodeExtractor.cpp +++ b/llvm/lib/Transforms/Utils/CodeExtractor.cpp @@ -513,21 +513,24 @@ emitCallAndSwitchStatement(Function *newFunction, BasicBlock *codeReplacer, } // Now that we've done the deed, simplify the switch instruction. + const Type *OldFnRetTy = TheSwitch->getParent()->getParent()->getReturnType(); switch (NumExitBlocks) { case 0: - // There is only 1 successor (the block containing the switch itself), which + // There are no successors (the block containing the switch itself), which // means that previously this was the last part of the function, and hence // this should be rewritten as a `ret' // Check if the function should return a value - if (TheSwitch->getParent()->getParent()->getReturnType() != Type::VoidTy && - TheSwitch->getParent()->getParent()->getReturnType() == - TheSwitch->getCondition()->getType()) + if (OldFnRetTy == Type::VoidTy) { + new ReturnInst(0, TheSwitch); // Return void + } else if (OldFnRetTy == TheSwitch->getCondition()->getType()) { // return what we have new ReturnInst(TheSwitch->getCondition(), TheSwitch); - else - // just return - new ReturnInst(0, TheSwitch); + } else { + // Otherwise we must have code extracted an unwind or something, just + // return whatever we want. + new ReturnInst(Constant::getNullValue(OldFnRetTy), TheSwitch); + } TheSwitch->getParent()->getInstList().erase(TheSwitch); break; @@ -583,8 +586,8 @@ void CodeExtractor::moveCodeToFunction(Function *newFunction) { /// for each scalar output in the function: at every exit, store intermediate /// computed result back into memory. /// -Function *CodeExtractor::ExtractCodeRegion(const std::vector<BasicBlock*> &code) -{ +Function *CodeExtractor:: +ExtractCodeRegion(const std::vector<BasicBlock*> &code) { if (!isEligible(code)) return 0; |