diff options
author | Dan Gohman <gohman@apple.com> | 2008-06-17 23:38:43 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2008-06-17 23:38:43 +0000 |
commit | 44f6a2c951b0536c6e4ab6f576f82676ed97322c (patch) | |
tree | a6a6745d1cb4e72400652c5d1b0c2a2e26d2adb1 | |
parent | 80b9626ee30a2cb32641ed15d00c0c1a634e275a (diff) | |
download | external_llvm-44f6a2c951b0536c6e4ab6f576f82676ed97322c.zip external_llvm-44f6a2c951b0536c6e4ab6f576f82676ed97322c.tar.gz external_llvm-44f6a2c951b0536c6e4ab6f576f82676ed97322c.tar.bz2 |
Auto-upgrade code for multiple-value return statements. This code
isn't actually called yet.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52435 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/AutoUpgrade.h | 6 | ||||
-rw-r--r-- | lib/VMCore/AutoUpgrade.cpp | 24 |
2 files changed, 30 insertions, 0 deletions
diff --git a/include/llvm/AutoUpgrade.h b/include/llvm/AutoUpgrade.h index 3a97353..0235877 100644 --- a/include/llvm/AutoUpgrade.h +++ b/include/llvm/AutoUpgrade.h @@ -35,6 +35,12 @@ namespace llvm { /// so that it can update all calls to the old function. void UpgradeCallsToIntrinsic(Function* F); + /// This is an auto-upgrade hook for mutiple-value return statements. + /// This function auto-upgrades all such return statements in the given + /// function to use aggregate return values built with insertvalue + /// instructions. + void UpgradeMultipleReturnValues(Function *F); + } // End llvm namespace #endif diff --git a/lib/VMCore/AutoUpgrade.cpp b/lib/VMCore/AutoUpgrade.cpp index 2f1e07c..7b63692 100644 --- a/lib/VMCore/AutoUpgrade.cpp +++ b/lib/VMCore/AutoUpgrade.cpp @@ -391,3 +391,27 @@ void llvm::UpgradeCallsToIntrinsic(Function* F) { } } +/// This is an auto-upgrade hook for mutiple-value return statements. +/// This function auto-upgrades all such return statements in the given +/// function to use aggregate return values built with insertvalue +/// instructions. +void llvm::UpgradeMultipleReturnValues(Function *CurrentFunction) { + for (Function::iterator I = CurrentFunction->begin(), + E = CurrentFunction->end(); I != E; ++I) { + BasicBlock *BB = I; + if (ReturnInst *RI = dyn_cast<ReturnInst>(BB->getTerminator())) { + unsigned NumVals = RI->getNumOperands(); + if (NumVals > 1) { + std::vector<const Type *> Types(NumVals); + for (unsigned i = 0; i != NumVals; ++i) + Types[i] = RI->getOperand(i)->getType(); + const Type *ReturnType = StructType::get(Types); + Value *RV = UndefValue::get(ReturnType); + for (unsigned i = 0; i != NumVals; ++i) + RV = InsertValueInst::Create(RV, RI->getOperand(i), i, "mrv", RI); + ReturnInst::Create(RV, RI); + RI->eraseFromParent(); + } + } + } +} |