diff options
| author | Vikram S. Adve <vadve@cs.uiuc.edu> | 2003-08-12 22:22:24 +0000 | 
|---|---|---|
| committer | Vikram S. Adve <vadve@cs.uiuc.edu> | 2003-08-12 22:22:24 +0000 | 
| commit | 7dc5b6707cef992cc7c0ab7594e4145fb0f4aaaa (patch) | |
| tree | 6dcd6b1d0fa984a58508e97dd3e0c987ae5fdc17 /llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp | |
| parent | 869b11b7c467cab037aa9a9f6e62e65b99a873af (diff) | |
| download | bcm5719-llvm-7dc5b6707cef992cc7c0ab7594e4145fb0f4aaaa.tar.gz bcm5719-llvm-7dc5b6707cef992cc7c0ab7594e4145fb0f4aaaa.zip | |
For instructions in a delay slot of another instruction,
we no longer need to find the live-before set of the delayed
branch since that set is now included the live-before/after
set of the instructions in each delay slot.  Just assert that instead.
llvm-svn: 7796
Diffstat (limited to 'llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp | 28 | 
1 files changed, 16 insertions, 12 deletions
| diff --git a/llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp b/llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp index 791421babf3..fa81e9e33f6 100644 --- a/llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp +++ b/llvm/lib/CodeGen/RegAlloc/PhyRegAlloc.cpp @@ -24,6 +24,7 @@  #include "llvm/Type.h"  #include "llvm/iOther.h"  #include "Support/STLExtras.h" +#include "Support/SetOperations.h"  #include "Support/CommandLine.h"  #include <math.h>  using std::cerr; @@ -747,18 +748,21 @@ void PhyRegAlloc::insertCode4SpilledLR(const LiveRange *LR,    RegClass *RC = LR->getRegClass();    // Get the live-variable set to find registers free before this instr. -  // If this instr. is in the delay slot of a branch or return, use the live -  // var set before that branch or return -- we don't want to trample those! +  const ValueSet &LVSetBef = LVI->getLiveVarSetBeforeMInst(MInst, BB); + +#ifndef NDEBUG +  // If this instr. is in the delay slot of a branch or return, we need to +  // include all live variables before that branch or return -- we don't want to +  // trample those!  Verify that the set is included in the LV set before MInst.    //  -  MachineInstr *LiveBeforeThisMI = MInst;    if (MII != MBB.begin()) {      MachineInstr *PredMI = *(MII-1); -    if (unsigned DS = TM.getInstrInfo().getNumDelaySlots(PredMI->getOpCode())) { -      assert(DS == 1 && "Only checking immediate pred. for delay slots!"); -      LiveBeforeThisMI = PredMI; -    } +    if (unsigned DS = TM.getInstrInfo().getNumDelaySlots(PredMI->getOpCode())) +      assert(set_difference(LVI->getLiveVarSetBeforeMInst(PredMI), LVSetBef) +             .empty() && "Live-var set before branch should be included in " +             "live-var set of each delay slot instruction!");    } -  const ValueSet &LVSetBef = LVI->getLiveVarSetBeforeMInst(LiveBeforeThisMI,BB); +#endif    MF.getInfo()->pushTempValue(MRI.getSpilledRegSize(RegType) ); @@ -1204,14 +1208,14 @@ void PhyRegAlloc::setRelRegsUsedByThisInst(RegClass *RC, int RegType,  void PhyRegAlloc::move2DelayedInstr(const MachineInstr *OrigMI,                                      const MachineInstr *DelayedMI)  { -  if (DEBUG_RA) { +  // "added after" instructions of the original instr +  std::vector<MachineInstr *> &OrigAft = AddedInstrMap[OrigMI].InstrnsAfter; + +  if (DEBUG_RA && OrigAft.size() > 0) {      cerr << "\nRegAlloc: Moved InstrnsAfter for: " << *OrigMI;      cerr << "         to last delay slot instrn: " << *DelayedMI;    } -  // "added after" instructions of the original instr -  std::vector<MachineInstr *> &OrigAft = AddedInstrMap[OrigMI].InstrnsAfter; -    // "added after" instructions of the delayed instr    std::vector<MachineInstr *> &DelayedAft=AddedInstrMap[DelayedMI].InstrnsAfter; | 

