summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorVikram S. Adve <vadve@cs.uiuc.edu>2002-05-19 15:31:08 +0000
committerVikram S. Adve <vadve@cs.uiuc.edu>2002-05-19 15:31:08 +0000
commit069d51612ff18c02aeb82e7126835811105627f4 (patch)
treeb239a9749f5b93253f8c9667e164c36d443173dc /llvm/lib/CodeGen
parent1e45411a31572eb98a4f2cc0618203a533224197 (diff)
downloadbcm5719-llvm-069d51612ff18c02aeb82e7126835811105627f4.tar.gz
bcm5719-llvm-069d51612ff18c02aeb82e7126835811105627f4.zip
cpValue2Value now needs a vector of MachineInstr to store return values.
llvm-svn: 2644
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/InstrSelection/InstrSelection.cpp36
1 files changed, 20 insertions, 16 deletions
diff --git a/llvm/lib/CodeGen/InstrSelection/InstrSelection.cpp b/llvm/lib/CodeGen/InstrSelection/InstrSelection.cpp
index 1724ce44896..0776b159747 100644
--- a/llvm/lib/CodeGen/InstrSelection/InstrSelection.cpp
+++ b/llvm/lib/CodeGen/InstrSelection/InstrSelection.cpp
@@ -207,26 +207,30 @@ InsertCode4AllPhisInMeth(Function *F, TargetMachine &target)
// for each incoming value of the phi, insert phi elimination
//
- for (unsigned i = 0; i < PN->getNumIncomingValues(); ++i) {
- // insert the copy instruction to the predecessor BB
- MachineInstr *CpMI =
- target.getRegInfo().cpValue2Value(PN->getIncomingValue(i),
- PhiCpRes);
-
- vector<MachineInstr*> CpVec = FixConstantOperandsForInstr(PN, CpMI,
- target);
- CpVec.push_back(CpMI);
-
- InsertPhiElimInstructions(PN->getIncomingBlock(i), CpVec);
- }
+ for (unsigned i = 0; i < PN->getNumIncomingValues(); ++i)
+ { // insert the copy instruction to the predecessor BB
+ vector<MachineInstr*> mvec, CpVec;
+ target.getRegInfo().cpValue2Value(PN->getIncomingValue(i), PhiCpRes,
+ mvec);
+ for (vector<MachineInstr*>::iterator MI=mvec.begin();
+ MI != mvec.end(); ++MI)
+ {
+ vector<MachineInstr*> CpVec2 =
+ FixConstantOperandsForInstr(PN, *MI, target);
+ CpVec2.push_back(*MI);
+ CpVec.insert(CpVec.end(), CpVec2.begin(), CpVec2.end());
+ }
+
+ InsertPhiElimInstructions(PN->getIncomingBlock(i), CpVec);
+ }
+
+ vector<MachineInstr*> mvec;
+ target.getRegInfo().cpValue2Value(PhiCpRes, PN, mvec);
- MachineInstr *CpMI2 =
- target.getRegInfo().cpValue2Value(PhiCpRes, PN);
-
// get an iterator to machine instructions in the BB
MachineCodeForBasicBlock& bbMvec = BB->getMachineInstrVec();
- bbMvec.insert( bbMvec.begin(), CpMI2);
+ bbMvec.insert( bbMvec.begin(), mvec.begin(), mvec.end());
}
else break; // since PHI nodes can only be at the top
OpenPOWER on IntegriCloud