aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Target')
-rw-r--r--lib/Target/SparcV9/RegAlloc/PhyRegAlloc.cpp98
1 files changed, 79 insertions, 19 deletions
diff --git a/lib/Target/SparcV9/RegAlloc/PhyRegAlloc.cpp b/lib/Target/SparcV9/RegAlloc/PhyRegAlloc.cpp
index c99f1a1..780f70d 100644
--- a/lib/Target/SparcV9/RegAlloc/PhyRegAlloc.cpp
+++ b/lib/Target/SparcV9/RegAlloc/PhyRegAlloc.cpp
@@ -565,40 +565,100 @@ void PhyRegAlloc::updateMachineCode()
// If there are instructions to be added *after* this machine
// instruction, add them now
- if( AddedInstrMap[ MInst ] ) {
+ if( AddedInstrMap[ MInst ] &&
+ ! (AddedInstrMap[ MInst ]->InstrnsAfter).empty() ) {
- deque<MachineInstr *> &IAft = (AddedInstrMap[MInst])->InstrnsAfter;
+ // if there are delay slots for this instruction, the instructions
+ // added after it must really go after the delayed instruction(s)
+ // So, we move the InstrAfter of the current instruction to the
+ // corresponding delayed instruction
+
+ unsigned delay;
+ if((delay=TM.getInstrInfo().getNumDelaySlots(MInst->getOpCode())) >0){
+ move2DelayedInstr(MInst, *(MInstIterator+delay) );
- if( ! IAft.empty() ) {
+ if(DEBUG_RA) cout<< "\nMoved an added instr after the delay slot";
+ }
+
+ else {
+
- deque<MachineInstr *>::iterator AdIt;
+ // Here we can add the "instructions after" to the current
+ // instruction since there are no delay slots for this instruction
- ++MInstIterator; // advance to the next instruction
+ deque<MachineInstr *> &IAft = (AddedInstrMap[MInst])->InstrnsAfter;
+
+ if( ! IAft.empty() ) {
+
+ deque<MachineInstr *>::iterator AdIt;
+
+ ++MInstIterator; // advance to the next instruction
+
+ for( AdIt = IAft.begin(); AdIt != IAft.end() ; ++AdIt ) {
+
+ if(DEBUG_RA)
+ cerr << " *#* APPENDed instr opcode: " << *AdIt << endl;
+
+ MInstIterator = MIVec.insert( MInstIterator, *AdIt );
+ ++MInstIterator;
+ }
+
+ // MInsterator already points to the next instr. Since the
+ // for loop also increments it, decrement it to point to the
+ // instruction added last
+ --MInstIterator;
+
+ }
+
+ } // if not delay
+
+ }
+
+ } // for each machine instruction
+ }
+}
- for( AdIt = IAft.begin(); AdIt != IAft.end() ; ++AdIt ) {
- if(DEBUG_RA)
- cerr << " *#* APPENDed instr opcode: " << *AdIt << endl;
+//----------------------------------------------------------------------------
+//
+// If there are delay slots for an instruction, the instructions
+// added after it must really go after the delayed instruction(s).
+// So, we move the InstrAfter of that instruction to the
+// corresponding delayed instruction using the following method.
- MInstIterator = MIVec.insert( MInstIterator, *AdIt );
- ++MInstIterator;
- }
+//----------------------------------------------------------------------------
+void PhyRegAlloc:: move2DelayedInstr(const MachineInstr *OrigMI,
+ const MachineInstr *DelayedMI) {
- // MInsterator already points to the next instr. Since the
- // for loop also increments it, decrement it to point to the
- // instruction added last
- --MInstIterator;
- }
+ // "added after" instructions of the original instr
+ deque<MachineInstr *> &OrigAft = (AddedInstrMap[OrigMI])->InstrnsAfter;
- }
+ // "added instructions" of the delayed instr
+ AddedInstrns *DelayAdI = AddedInstrMap[DelayedMI];
- } // for each machine instruction
+ if(! DelayAdI ) { // create a new "added after" if necessary
+ DelayAdI = new AddedInstrns();
+ AddedInstrMap[DelayedMI] = DelayAdI;
}
-}
+ // "added after" instructions of the delayed instr
+ deque<MachineInstr *> &DelayedAft = DelayAdI->InstrnsAfter;
+ // go thru all the "added after instructions" of the original instruction
+ // and append them to the "addded after instructions" of the delayed
+ // instructions
+ deque<MachineInstr *>::iterator OrigAdIt;
+
+ for( OrigAdIt = OrigAft.begin(); OrigAdIt != OrigAft.end() ; ++OrigAdIt ) {
+ DelayedAft.push_back( *OrigAdIt );
+ }
+
+ // empty the "added after instructions" of the original instruction
+ OrigAft.clear();
+
+}
//----------------------------------------------------------------------------
// This method prints the code with registers after register allocation is