summaryrefslogtreecommitdiff
path: root/lib/Transforms/Utils/InlineFunction.cpp
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2008-03-10 18:22:16 +0000
committerDevang Patel <dpatel@apple.com>2008-03-10 18:22:16 +0000
commit641ca93cff0f957fc5fb9dfb05d2a4a340aa8af7 (patch)
tree020d23c1c218423576f455981c104b5b1b4c347f /lib/Transforms/Utils/InlineFunction.cpp
parent7498f9092613b91f882ace99c41a9f42a5905a62 (diff)
downloadllvm-641ca93cff0f957fc5fb9dfb05d2a4a340aa8af7.tar.gz
llvm-641ca93cff0f957fc5fb9dfb05d2a4a340aa8af7.tar.bz2
llvm-641ca93cff0f957fc5fb9dfb05d2a4a340aa8af7.tar.xz
Simplify
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48161 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Utils/InlineFunction.cpp')
-rw-r--r--lib/Transforms/Utils/InlineFunction.cpp33
1 files changed, 15 insertions, 18 deletions
diff --git a/lib/Transforms/Utils/InlineFunction.cpp b/lib/Transforms/Utils/InlineFunction.cpp
index 9ccc918aca..87e43e62f5 100644
--- a/lib/Transforms/Utils/InlineFunction.cpp
+++ b/lib/Transforms/Utils/InlineFunction.cpp
@@ -22,6 +22,7 @@
#include "llvm/Analysis/CallGraph.h"
#include "llvm/Target/TargetData.h"
#include "llvm/ADT/SmallVector.h"
+#include "llvm/ADT/StringExtras.h"
#include "llvm/Support/CallSite.h"
using namespace llvm;
@@ -531,9 +532,11 @@ bool llvm::InlineFunction(CallSite CS, CallGraph *CG, const TargetData *TD) {
unsigned NumRetVals = STy->getNumElements();
// Create new phi nodes such that phi node number in the PHIs vector
// match corresponding return value operand number.
+ Instruction *InsertPt = AfterCallBB->begin();
for (unsigned i = 0; i < NumRetVals; ++i) {
PHINode *PHI = new PHINode(STy->getElementType(i),
- TheCall->getName(), AfterCallBB->begin());
+ TheCall->getName() + "." + utostr(i),
+ InsertPt);
PHIs.push_back(PHI);
}
// TheCall results are used by GetResult instructions.
@@ -555,25 +558,19 @@ bool llvm::InlineFunction(CallSite CS, CallGraph *CG, const TargetData *TD) {
// appropriate.
if (!PHIs.empty()) {
const Type *RTy = CalledFunc->getReturnType();
- if (const StructType *STy = dyn_cast<StructType>(RTy)) {
- unsigned NumRetVals = STy->getNumElements();
- for (unsigned j = 0; j < NumRetVals; ++j) {
- PHINode *PHI = PHIs[j];
- // Each PHI node will receive one value from each return instruction.
- for(unsigned i = 0, e = Returns.size(); i != e; ++i) {
- ReturnInst *RI = Returns[i];
- PHI->addIncoming(RI->getReturnValue(j /*PHI number matches operand number*/),
- RI->getParent());
- }
- }
- } else {
- for (unsigned i = 0, e = Returns.size(); i != e; ++i) {
+ // There is atleast one return value.
+ unsigned NumRetVals = 1;
+ if (const StructType *STy = dyn_cast<StructType>(RTy))
+ NumRetVals = STy->getNumElements();
+ for (unsigned j = 0; j < NumRetVals; ++j) {
+ PHINode *PHI = PHIs[j];
+ // Each PHI node will receive one value from each return instruction.
+ for(unsigned i = 0, e = Returns.size(); i != e; ++i) {
ReturnInst *RI = Returns[i];
- assert(PHIs.size() == 1 && "Invalid number of PHI nodes");
- assert(RI->getReturnValue() && "Ret should have value!");
- assert(RI->getReturnValue()->getType() == PHIs[0]->getType() &&
+ assert(RI->getReturnValue(j)->getType() == PHI->getType() &&
"Ret value not consistent in function!");
- PHIs[0]->addIncoming(RI->getReturnValue(), RI->getParent());
+ PHI->addIncoming(RI->getReturnValue(j /*PHI number matches operand number*/),
+ RI->getParent());
}
}
}