mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	* Code Cleanups
* Introduce RAV to allow stream I/O instead of using printValue git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1710 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -16,7 +16,7 @@ struct LiveVarSet : public ValueSet { | ||||
|   // This function applies a machine instr to a live var set (accepts OutSet) | ||||
|   // and makes necessary changes to it (produces InSet). | ||||
|   // | ||||
|   void applyTranferFuncForMInst(const MachineInstr *const MInst); | ||||
|   void applyTranferFuncForMInst(const MachineInstr *MInst); | ||||
| }; | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -8,13 +8,20 @@ | ||||
| #ifndef VALUE_SET_H | ||||
| #define VALUE_SET_H | ||||
|  | ||||
| class Value; | ||||
| #include <set> | ||||
| class Value; | ||||
|  | ||||
| // RAV - Used to print values in a form used by the register allocator.   | ||||
| // | ||||
| struct RAV {  // Register Allocator Value | ||||
|   const Value *V; | ||||
|   RAV(const Value *v) : V(v) {} | ||||
| }; | ||||
| ostream &operator<<(ostream &out, RAV Val); | ||||
|  | ||||
|  | ||||
| //------------------- Class Definition for ValueSet -------------------------- | ||||
|  | ||||
| void printValue( const Value *v);  // func to print a Value  | ||||
|  | ||||
| struct ValueSet : public std::set<const Value*> { | ||||
|   bool setUnion( const ValueSet *const set1);     // for performing set union | ||||
|   void setSubtract( const ValueSet *const set1);  // for performing set diff | ||||
|   | ||||
| @@ -8,13 +8,20 @@ | ||||
| #ifndef VALUE_SET_H | ||||
| #define VALUE_SET_H | ||||
|  | ||||
| class Value; | ||||
| #include <set> | ||||
| class Value; | ||||
|  | ||||
| // RAV - Used to print values in a form used by the register allocator.   | ||||
| // | ||||
| struct RAV {  // Register Allocator Value | ||||
|   const Value *V; | ||||
|   RAV(const Value *v) : V(v) {} | ||||
| }; | ||||
| ostream &operator<<(ostream &out, RAV Val); | ||||
|  | ||||
|  | ||||
| //------------------- Class Definition for ValueSet -------------------------- | ||||
|  | ||||
| void printValue( const Value *v);  // func to print a Value  | ||||
|  | ||||
| struct ValueSet : public std::set<const Value*> { | ||||
|   bool setUnion( const ValueSet *const set1);     // for performing set union | ||||
|   void setSubtract( const ValueSet *const set1);  // for performing set diff | ||||
|   | ||||
| @@ -70,13 +70,9 @@ void BBLiveVar::calcDefUseSets() { | ||||
| 	   | ||||
| 	  PhiArgMap[ArgVal] = cast<BasicBlock>(BBVal);  | ||||
| 	   | ||||
| 	  if (DEBUG_LV > 1) { | ||||
| 	    cerr << "   - phi operand ";  | ||||
| 	    printValue(ArgVal);  | ||||
| 	    cerr << " came from BB ";  | ||||
| 	    printValue(PhiArgMap[ArgVal]);  | ||||
| 	    cerr << "\n"; | ||||
| 	  } | ||||
| 	  if (DEBUG_LV > 1) | ||||
| 	    cerr << "   - phi operand " << RAV(ArgVal) << " came from BB " | ||||
|                  << RAV(PhiArgMap[ArgVal]) << "\n"; | ||||
| 	} // if( IsPhi ) | ||||
|       } // if a use | ||||
|     } // for all operands | ||||
| @@ -105,9 +101,7 @@ void  BBLiveVar::addDef(const Value *Op) { | ||||
|   InSet.erase(Op);       // this definition kills any uses | ||||
|   InSetChanged = true;  | ||||
|  | ||||
|   if (DEBUG_LV > 1) { | ||||
|     cerr << "  +Def: "; printValue( Op ); cerr << "\n"; | ||||
|   } | ||||
|   if (DEBUG_LV > 1) cerr << "  +Def: " << RAV(Op) << "\n"; | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -119,9 +113,7 @@ void  BBLiveVar::addUse(const Value *Op) { | ||||
|   OutSet.erase(Op);   // remove if there is a def below this use | ||||
|   InSetChanged = true;  | ||||
|  | ||||
|   if (DEBUG_LV > 1) { | ||||
|     cerr << "   Use: "; printValue( Op ); cerr << "\n"; | ||||
|   } | ||||
|   if (DEBUG_LV > 1) cerr << "   Use: " << RAV(Op) << "\n"; | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -62,7 +62,7 @@ void MethodLiveVarInfo::constructBBs(const Method *M) { | ||||
|       BBI != BBE; ++BBI, ++POId) {  | ||||
|     const BasicBlock *BB = *BBI;        // get the current BB  | ||||
|  | ||||
|     if (DEBUG_LV) { std::cerr << " For BB "; printValue(BB); cerr << ":\n"; } | ||||
|     if (DEBUG_LV) std::cerr << " For BB " << RAV(BB) << ":\n"; | ||||
|  | ||||
|     // create a new BBLiveVar | ||||
|     BBLiveVar *LVBB = new BBLiveVar(BB, POId);   | ||||
|   | ||||
| @@ -1,64 +1,42 @@ | ||||
|  | ||||
|  | ||||
|  | ||||
| #include "llvm/Analysis/LiveVar/ValueSet.h" | ||||
| #include "llvm/ConstantVals.h" | ||||
| #include <algorithm> | ||||
| #include <iostream> | ||||
| using std::cerr; | ||||
| using std::endl; | ||||
| using std::pair; | ||||
| using std::hash_set; | ||||
|  | ||||
| void printValue(const Value *v) { // func to print a Value  | ||||
| ostream &operator<<(ostream &O, RAV V) { // func to print a Value  | ||||
|   const Value *v = V.V; | ||||
|   if (v->hasName()) | ||||
|     cerr << v << "(" << v->getName() << ") "; | ||||
|     return O << v << "(" << v->getName() << ") "; | ||||
|   else if (Constant *C = dyn_cast<Constant>(v)) | ||||
|     cerr << v << "(" << C->getStrValue() << ") "; | ||||
|     return O << v << "(" << C->getStrValue() << ") "; | ||||
|   else | ||||
|     cerr << v  << " "; | ||||
|     return O << v  << " "; | ||||
| } | ||||
|  | ||||
| bool ValueSet::setUnion( const ValueSet *S) {    | ||||
|   bool Changed = false; | ||||
|  | ||||
| //---------------- Method implementations -------------------------- | ||||
|                                              // for performing two set unions | ||||
| bool ValueSet::setUnion( const ValueSet *set1) {    | ||||
|   pair<iterator, bool> result; | ||||
|   bool changed = false; | ||||
|   for (const_iterator SI = S->begin(), SE = S->end(); SI != SE; ++SI) | ||||
|     if (insert(*SI).second) | ||||
|       Changed = true; | ||||
|  | ||||
|   for(const_iterator set1it = set1->begin() ; set1it != set1->end(); ++set1it) { | ||||
|                                              // for all all elements in set1 | ||||
|     result = insert(*set1it);                // insert to this set | ||||
|     if(result.second == true) changed = true; | ||||
|   } | ||||
|  | ||||
|   return changed; | ||||
|   return Changed; | ||||
| } | ||||
|  | ||||
|  | ||||
|                                              // for performing set difference | ||||
| void ValueSet::setDifference( const ValueSet *const set1,  | ||||
| 			      const ValueSet *const set2) {  | ||||
|  | ||||
|   const_iterator set1it, set2it; | ||||
|   for( set1it = set1->begin() ; set1it != set1->end(); ++set1it) {   | ||||
|                                              // for all elements in set1 | ||||
|     iterator set2it = set2->find( *set1it ); // find wether the elem is in set2 | ||||
|     if( set2it == set2->end() )              // if the element is not in set2 | ||||
|       insert( *set1it );                     // insert to this set | ||||
|   } | ||||
| void ValueSet::setDifference(const ValueSet *S1, const ValueSet *S2) { | ||||
|   for (const_iterator SI = S1->begin(), SE = S1->end() ; SI != SE; ++SI) | ||||
|     if (S2->find(*SI) == S2->end())       // if the element is not in set2 | ||||
|       insert(*SI); | ||||
| } | ||||
|  | ||||
|  | ||||
|                                         // for performing set subtraction | ||||
| void ValueSet::setSubtract( const ValueSet *const set1) {  | ||||
|   const_iterator set1it; | ||||
|   for( set1it = set1->begin() ; set1it != set1->end(); ++set1it)   | ||||
|                                         // for all elements in set1 | ||||
|     erase( *set1it );                   // erase that element from this set | ||||
| void ValueSet::setSubtract(const ValueSet *S) {  | ||||
|   for (const_iterator SI = S->begin() ; SI != S->end(); ++SI)   | ||||
|     erase(*SI); | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| void ValueSet::printSet()  const {     // for printing a live variable set | ||||
|   for_each(begin(), end(), printValue); | ||||
| void ValueSet::printSet() const { | ||||
|   for (const_iterator I = begin(), E = end(); I != E; ++I) | ||||
|     std::cerr << RAV(*I); | ||||
| } | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| /* Title:   LiveRange.h   -*- C++ -*- | ||||
|    Author:  Ruchira Sasanka | ||||
|    Date:    July 25, 01 | ||||
|    Purpose: To keep info about a live range.  | ||||
|    Asuumptions: | ||||
|  | ||||
|    Since the Value pointed by a use is the same as of its def, it is sufficient | ||||
|    to keep only defs in a LiveRange. | ||||
| */ | ||||
| //===-- LiveRange.h - Store info about a live range --------------*- C++ -*--=// | ||||
| // | ||||
| // Implements a live range using a ValueSet. A LiveRange is a simple set | ||||
| // of Values.  | ||||
| // | ||||
| // Since the Value pointed by a use is the same as of its def, it is sufficient | ||||
| // to keep only defs in a LiveRange. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef LIVE_RANGE_H | ||||
| #define LIVE_RANGE_H | ||||
| @@ -18,149 +18,120 @@ | ||||
| class RegClass; | ||||
| class IGNode; | ||||
|  | ||||
|  | ||||
| //---------------------------------------------------------------------------- | ||||
| // Class LiveRange | ||||
| // | ||||
| // Implements a live range using a ValueSet. A LiveRange is a simple set | ||||
| // of Values.  | ||||
| //---------------------------------------------------------------------------- | ||||
|  | ||||
| class LiveRange : public ValueSet { | ||||
|   RegClass *MyRegClass;       // register classs (e.g., int, FP) for this LR | ||||
|  | ||||
|   bool doesSpanAcrossCalls; | ||||
|   // | ||||
|   // Does this live range span across calls?  | ||||
|   // doesSpanAcrossCalls - Does this live range span across calls?  | ||||
|   // This information is used by graph | ||||
|   // coloring algo to avoid allocating volatile colors to live ranges | ||||
|   // that span across calls (since they have to be saved/restored) | ||||
|    | ||||
|   // | ||||
|   bool doesSpanAcrossCalls; | ||||
|  | ||||
|   IGNode *UserIGNode;         // IGNode which uses this LR | ||||
|  | ||||
|   int Color;                  // color assigned to this live range | ||||
|  | ||||
|   bool mustSpill;             // whether this LR must be spilt | ||||
|  | ||||
|  | ||||
|   // mustSaveAcrossCalls - whether this LR must be saved accross calls | ||||
|   // ***TODO REMOVE this | ||||
|   // | ||||
|   bool mustSaveAcrossCalls;         | ||||
|   // | ||||
|   // whether this LR must be saved accross calls ***TODO REMOVE this | ||||
|    | ||||
|   // SuggestedColor - if this LR has a suggested color, can it be | ||||
|   // really alloated?  A suggested color cannot be allocated when the | ||||
|   // suggested color is volatile and when there are call | ||||
|   // interferences. | ||||
|   // | ||||
|   int SuggestedColor;        // The suggested color for this LR | ||||
|   // | ||||
|   // if this LR has a suggested color, can it be really alloated? | ||||
|   // A suggested color cannot be allocated when the suggested color is | ||||
|   // volatile and when there are call interferences. | ||||
|  | ||||
|   bool CanUseSuggestedCol; | ||||
|   // CanUseSuggestedCol - It is possible that a suggested color for | ||||
|   // this live range is not available before graph coloring (e.g., it | ||||
|   // can be allocated to another live range which interferes with | ||||
|   // this) | ||||
|   //  | ||||
|   // It is possible that a suggested color for this live range is not | ||||
|   // available before graph coloring (e.g., it can be allocated to another | ||||
|   // live range which interferes with this) | ||||
|   bool CanUseSuggestedCol; | ||||
|  | ||||
|   // SpilledStackOffsetFromFP - If this LR is spilled, its stack | ||||
|   // offset from *FP*. The spilled offsets must always be relative to | ||||
|   // the FP. | ||||
|   // | ||||
|   int SpilledStackOffsetFromFP; | ||||
|   // | ||||
|   // if this LR is spilled, its stack offset from *FP*. The spilled offsets | ||||
|   // must always be relative to the FP. | ||||
|  | ||||
|   // HasSpillOffset 0 Whether this live range has a spill offset | ||||
|   // | ||||
|   bool HasSpillOffset; | ||||
|   // | ||||
|   // Whether this live range has a spill offset | ||||
|  | ||||
|   unsigned SpillCost; | ||||
|   // | ||||
|   // The spill cost of this live range. Calculated using loop depth of | ||||
|   // each reference to each Value in the live range | ||||
|  | ||||
|  public: | ||||
|  | ||||
|   // constructor | ||||
|   // | ||||
|   LiveRange() : ValueSet() { | ||||
|   unsigned SpillCost; | ||||
|  | ||||
| public: | ||||
|   LiveRange() { | ||||
|     Color = SuggestedColor = -1;        // not yet colored  | ||||
|     mustSpill = mustSaveAcrossCalls = false; | ||||
|     MyRegClass = NULL; | ||||
|     UserIGNode = NULL; | ||||
|     MyRegClass = 0; | ||||
|     UserIGNode = 0; | ||||
|     doesSpanAcrossCalls = false; | ||||
|     CanUseSuggestedCol = true; | ||||
|     HasSpillOffset  = false; | ||||
|     HasSpillOffset = false; | ||||
|     SpillCost = 0; | ||||
|   } | ||||
|  | ||||
|   // empty destructor since there are nothing to be deleted | ||||
|   // | ||||
|   ~LiveRange() {}           | ||||
|   void setRegClass(RegClass *RC) { MyRegClass = RC; } | ||||
|  | ||||
|   RegClass *getRegClass() const { assert(MyRegClass); return MyRegClass; } | ||||
|  | ||||
|   void setRegClass(RegClass *const RC)  | ||||
|     { MyRegClass = RC; } | ||||
|  | ||||
|   inline RegClass *const getRegClass() const  | ||||
|     { assert(MyRegClass); return MyRegClass; }  | ||||
|  | ||||
|   inline bool hasColor() const  | ||||
|     { return Color != -1; } | ||||
|   bool hasColor() const { return Color != -1; } | ||||
|    | ||||
|   inline unsigned int getColor() const  | ||||
|     { assert( Color != -1); return (unsigned) Color ; } | ||||
|   unsigned getColor() const { assert(Color != -1); return (unsigned)Color; } | ||||
|  | ||||
|   inline void setColor(unsigned int Col)  | ||||
|     { Color = (int) Col ; } | ||||
|   void setColor(unsigned Col) { Color = (int)Col; } | ||||
|  | ||||
|    | ||||
|   inline void setCallInterference() {  | ||||
|     doesSpanAcrossCalls = 1; | ||||
|   } | ||||
|  | ||||
|  | ||||
|   inline bool isCallInterference() const {  | ||||
|     return (doesSpanAcrossCalls == 1);  | ||||
|     return doesSpanAcrossCalls == 1;  | ||||
|   }  | ||||
|  | ||||
|   inline void markForSpill() { mustSpill = true; } | ||||
|  | ||||
|   inline bool isMarkedForSpill() { return  mustSpill; } | ||||
|   inline bool isMarkedForSpill() { return mustSpill; } | ||||
|  | ||||
|   inline void setSpillOffFromFP(int StackOffset) { | ||||
|     assert( mustSpill && "This LR is not spilled"); | ||||
|     assert(mustSpill && "This LR is not spilled"); | ||||
|     SpilledStackOffsetFromFP = StackOffset; | ||||
|     HasSpillOffset = true; | ||||
|   } | ||||
|  | ||||
|   inline void modifySpillOffFromFP(int StackOffset) { | ||||
|     assert( mustSpill && "This LR is not spilled"); | ||||
|     assert(mustSpill && "This LR is not spilled"); | ||||
|     SpilledStackOffsetFromFP = StackOffset; | ||||
|     HasSpillOffset = true; | ||||
|   } | ||||
|  | ||||
|  | ||||
|  | ||||
|   inline bool hasSpillOffset() const { | ||||
|     return  HasSpillOffset; | ||||
|     return HasSpillOffset; | ||||
|   } | ||||
|  | ||||
|  | ||||
|   inline int getSpillOffFromFP() const { | ||||
|     assert( HasSpillOffset && "This LR is not spilled"); | ||||
|     assert(HasSpillOffset && "This LR is not spilled"); | ||||
|     return SpilledStackOffsetFromFP; | ||||
|   } | ||||
|  | ||||
|  | ||||
|   inline void markForSaveAcrossCalls() { mustSaveAcrossCalls = true; } | ||||
|  | ||||
|    | ||||
|   inline void setUserIGNode( IGNode *const IGN)  | ||||
|     { assert( !UserIGNode); UserIGNode = IGN; } | ||||
|   inline void setUserIGNode(IGNode *IGN) { | ||||
|     assert(!UserIGNode); UserIGNode = IGN; | ||||
|   } | ||||
|  | ||||
|   inline IGNode * getUserIGNode() const  | ||||
|     { return UserIGNode; }    // NULL if the user is not allocated | ||||
|   // getUserIGNode - NULL if the user is not allocated | ||||
|   inline IGNode *getUserIGNode() const { return UserIGNode; } | ||||
|  | ||||
|   inline const Type* getType() const { | ||||
|     const Value *val = *begin(); | ||||
|     assert(val && "Can't find type - Live range is empty" ); | ||||
|     return val->getType(); | ||||
|   inline const Type *getType() const { | ||||
|     return (*begin())->getType();  // set's don't have a front | ||||
|   } | ||||
|    | ||||
|   inline Type::PrimitiveID getTypeID() const { | ||||
| @@ -168,9 +139,7 @@ class LiveRange : public ValueSet { | ||||
|   } | ||||
|  | ||||
|   inline void setSuggestedColor(int Col) { | ||||
|     //assert( (SuggestedColor == -1) && "Changing an already suggested color"); | ||||
|  | ||||
|     if(SuggestedColor == -1 ) | ||||
|     if (SuggestedColor == -1) | ||||
|       SuggestedColor = Col; | ||||
| #if 0 | ||||
|     else if (DEBUG_RA)  | ||||
| @@ -179,21 +148,21 @@ class LiveRange : public ValueSet { | ||||
|   } | ||||
|  | ||||
|   inline unsigned getSuggestedColor() const { | ||||
|     assert( SuggestedColor != -1);      // only a valid color is obtained | ||||
|     return (unsigned) SuggestedColor; | ||||
|     assert(SuggestedColor != -1);      // only a valid color is obtained | ||||
|     return (unsigned)SuggestedColor; | ||||
|   } | ||||
|  | ||||
|   inline bool hasSuggestedColor() const { | ||||
|     return ( SuggestedColor > -1); | ||||
|     return SuggestedColor != -1; | ||||
|   } | ||||
|  | ||||
|   inline bool isSuggestedColorUsable() const { | ||||
|     assert( hasSuggestedColor() && "No suggested color"); | ||||
|     assert(hasSuggestedColor() && "No suggested color"); | ||||
|     return CanUseSuggestedCol; | ||||
|   } | ||||
|  | ||||
|   inline void setSuggestedColorUsable(const bool val) { | ||||
|     assert( hasSuggestedColor() && "No suggested color"); | ||||
|   inline void setSuggestedColorUsable(bool val) { | ||||
|     assert(hasSuggestedColor() && "No suggested color"); | ||||
|     CanUseSuggestedCol = val; | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -118,8 +118,8 @@ void LiveRangeInfo::constructLiveRanges() | ||||
|  | ||||
|     			    | ||||
|     if( DEBUG_RA > 1) {      | ||||
|       cerr << " adding LiveRange for argument ";     | ||||
|       printValue((const Value *) *ArgIt); cerr << "\n"; | ||||
|       cerr << " adding LiveRange for argument " | ||||
|            << RAV((const Value *)*ArgIt) << "\n"; | ||||
|     } | ||||
|   } | ||||
|  | ||||
| @@ -163,11 +163,9 @@ void LiveRangeInfo::constructLiveRanges() | ||||
| 	  MachineOperand::MachineOperandType OpTyp =  | ||||
| 	    OpI.getMachineOperand().getOperandType(); | ||||
|  | ||||
| 	  if (OpTyp == MachineOperand::MO_CCRegister) { | ||||
| 	    cerr << "\n**CC reg found. Is Def=" << OpI.isDef() << " Val:"; | ||||
| 	    printValue( OpI.getMachineOperand().getVRegValue() ); | ||||
| 	    cerr << "\n"; | ||||
| 	  } | ||||
| 	  if (OpTyp == MachineOperand::MO_CCRegister) | ||||
| 	    cerr << "\n**CC reg found. Is Def=" << OpI.isDef() << " Val:" | ||||
|                  << RAV(OpI.getMachineOperand().getVRegValue()) << "\n"; | ||||
| 	} | ||||
|  | ||||
| 	// create a new LR iff this operand is a def | ||||
| @@ -175,9 +173,9 @@ void LiveRangeInfo::constructLiveRanges() | ||||
| 	  const Value *Def = *OpI; | ||||
|  | ||||
| 	  // Only instruction values are accepted for live ranges here | ||||
| 	  if( Def->getValueType() != Value::InstructionVal ) { | ||||
| 	    cerr << "\n**%%Error: Def is not an instruction val. Def="; | ||||
| 	    printValue( Def ); cerr << "\n"; | ||||
| 	  if (Def->getValueType() != Value::InstructionVal ) { | ||||
| 	    cerr << "\n**%%Error: Def is not an instruction val. Def=" | ||||
|                  << RAV(Def) << "\n"; | ||||
| 	    continue; | ||||
| 	  } | ||||
|  | ||||
| @@ -189,10 +187,8 @@ void LiveRangeInfo::constructLiveRanges() | ||||
| 	    DefRange->insert(Def);          // add the instruction (def) to it | ||||
| 	    LiveRangeMap[ Def ] = DefRange; // update the map | ||||
|  | ||||
| 	    if (DEBUG_RA > 1) { 	     | ||||
| 	      cerr << "  creating a LR for def: ";     | ||||
| 	      printValue(Def); cerr  << "\n"; | ||||
| 	    } | ||||
| 	    if (DEBUG_RA > 1) | ||||
| 	      cerr << "  creating a LR for def: " << RAV(Def) << "\n"; | ||||
|  | ||||
| 	    // set the register class of the new live range | ||||
| 	    //assert( RegClassList.size() ); | ||||
| @@ -204,24 +200,20 @@ void LiveRangeInfo::constructLiveRanges() | ||||
| 			    OpI.getMachineOperand().getVRegValue(), isCC ); | ||||
|  | ||||
|  | ||||
| 	    if(isCC && DEBUG_RA) { | ||||
| 	      cerr  << "\a**created a LR for a CC reg:"; | ||||
| 	      printValue( OpI.getMachineOperand().getVRegValue() ); | ||||
| 	    } | ||||
| 	    if (isCC && DEBUG_RA) | ||||
| 	      cerr  << "\a**created a LR for a CC reg:" | ||||
|                     << RAV(OpI.getMachineOperand().getVRegValue()); | ||||
|  | ||||
| 	    DefRange->setRegClass( RegClassList[ rcid ] ); | ||||
|  | ||||
| 	  } | ||||
| 	  else { | ||||
| 	    DefRange->setRegClass(RegClassList[rcid]); | ||||
| 	  } else { | ||||
| 	    DefRange->insert(Def);          // add the opearand to def range | ||||
|                                             // update the map - Operand points  | ||||
| 	                                    // to the merged set | ||||
| 	    LiveRangeMap[ Def ] = DefRange;  | ||||
| 	    LiveRangeMap[Def] = DefRange;  | ||||
|  | ||||
| 	    if( DEBUG_RA > 1) {  | ||||
| 	      cerr << "   added to an existing LR for def: ";   | ||||
| 	      printValue( Def ); cerr  << "\n"; | ||||
| 	    } | ||||
| 	    if (DEBUG_RA > 1) | ||||
| 	      cerr << "   added to an existing LR for def: " | ||||
|                    << RAV(Def) << "\n"; | ||||
| 	  } | ||||
|  | ||||
| 	} // if isDef() | ||||
| @@ -336,10 +328,8 @@ void LiveRangeInfo::coalesceLRs() | ||||
| 	    if( ! LROfUse ) {           // if LR of use is not found | ||||
|  | ||||
| 	      //don't warn about labels | ||||
| 	      if (!((*UseI)->getType())->isLabelType() && DEBUG_RA) { | ||||
| 		cerr<<" !! Warning: No LR for use "; printValue(*UseI); | ||||
| 		cerr << "\n"; | ||||
| 	      } | ||||
| 	      if (!((*UseI)->getType())->isLabelType() && DEBUG_RA) | ||||
| 		cerr << " !! Warning: No LR for use " << RAV(*UseI) << "\n"; | ||||
| 	      continue;                 // ignore and continue | ||||
| 	    } | ||||
|  | ||||
| @@ -398,13 +388,12 @@ void LiveRangeInfo::coalesceLRs() | ||||
| /*--------------------------- Debug code for printing ---------------*/ | ||||
|  | ||||
|  | ||||
| void LiveRangeInfo::printLiveRanges() | ||||
| { | ||||
| void LiveRangeInfo::printLiveRanges() { | ||||
|   LiveRangeMapType::iterator HMI = LiveRangeMap.begin();   // hash map iterator | ||||
|   cerr << "\nPrinting Live Ranges from Hash Map:\n"; | ||||
|   for( ; HMI != LiveRangeMap.end() ; ++HMI) { | ||||
|     if( HMI->first && HMI->second ) { | ||||
|       cerr <<" "; printValue((*HMI).first);  cerr << "\t: ";  | ||||
|   for( ; HMI != LiveRangeMap.end(); ++HMI) { | ||||
|     if (HMI->first && HMI->second) { | ||||
|       cerr << " " << RAV(HMI->first) << "\t: ";  | ||||
|       HMI->second->printSet(); cerr << "\n"; | ||||
|     } | ||||
|   } | ||||
|   | ||||
| @@ -118,8 +118,8 @@ void PhyRegAlloc::createIGNodeListsAndIGs() { | ||||
|       LiveRange *L = HMI->second;   // get the LiveRange | ||||
|       if (!L) {  | ||||
|         if( DEBUG_RA) { | ||||
|           cerr << "\n*?!?Warning: Null liver range found for: "; | ||||
|           printValue(HMI->first); cerr << "\n"; | ||||
|           cerr << "\n*?!?Warning: Null liver range found for: " | ||||
|                << RAV(HMI->first) << "\n"; | ||||
|         } | ||||
|         continue; | ||||
|       } | ||||
| @@ -170,14 +170,12 @@ void PhyRegAlloc::addInterference(const Value *const Def, | ||||
|   // | ||||
|   for( ; LIt != LVSet->end(); ++LIt) { | ||||
|  | ||||
|     if( DEBUG_RA > 1) { | ||||
|       cerr << "< Def="; printValue(Def);      | ||||
|       cerr << ", Lvar=";  printValue( *LIt); cerr  << "> "; | ||||
|     } | ||||
|     if (DEBUG_RA > 1) | ||||
|       cerr << "< Def=" << RAV(Def) << ", Lvar=" << RAV(*LIt) << "> "; | ||||
|  | ||||
|     //  get the live range corresponding to live var | ||||
|     // | ||||
|     LiveRange *const LROfVar = LRI.getLiveRangeForValue(*LIt );     | ||||
|     LiveRange *LROfVar = LRI.getLiveRangeForValue(*LIt); | ||||
|  | ||||
|     // LROfVar can be null if it is a const since a const  | ||||
|     // doesn't have a dominating def - see Assumptions above | ||||
| @@ -188,13 +186,12 @@ void PhyRegAlloc::addInterference(const Value *const Def, | ||||
|  | ||||
|       // if 2 reg classes are the same set interference | ||||
|       // | ||||
|       if(RCOfDef == LROfVar->getRegClass()) { | ||||
|       if (RCOfDef == LROfVar->getRegClass()) { | ||||
| 	RCOfDef->setInterference( LROfDef, LROfVar);   | ||||
|       } else if(DEBUG_RA > 1)  {  | ||||
|       } else if (DEBUG_RA > 1)  {  | ||||
|         // we will not have LRs for values not explicitly allocated in the | ||||
|         // instruction stream (e.g., constants) | ||||
|         cerr << " warning: no live range for " ;  | ||||
|         printValue(*LIt); cerr << "\n"; | ||||
|         cerr << " warning: no live range for " << RAV(*LIt) << "\n"; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| @@ -434,10 +431,9 @@ void PhyRegAlloc::addInterferencesForArgs() | ||||
|   for( ; ArgIt != ArgList.end() ; ++ArgIt) {  // for each argument | ||||
|     addInterference((Value*)*ArgIt, InSet, false); // add interferences between  | ||||
|                                               // args and LVars at start | ||||
|     if( DEBUG_RA > 1) { | ||||
|        cerr << " - %% adding interference for  argument ";     | ||||
|       printValue((const Value *)*ArgIt); cerr << "\n"; | ||||
|     } | ||||
|     if( DEBUG_RA > 1) | ||||
|       cerr << " - %% adding interference for  argument " | ||||
|            << RAV((const Value *)*ArgIt) << "\n"; | ||||
|   } | ||||
| } | ||||
|  | ||||
| @@ -1051,15 +1047,11 @@ void PhyRegAlloc::printMachineCode() | ||||
|      | ||||
|  | ||||
|       unsigned NumOfImpRefs =  MInst->getNumImplicitRefs(); | ||||
|       if(  NumOfImpRefs > 0 ) { | ||||
| 	 | ||||
|       if( NumOfImpRefs > 0) { | ||||
| 	cerr << "\tImplicit:"; | ||||
|  | ||||
| 	for(unsigned z=0; z < NumOfImpRefs; z++) { | ||||
| 	  printValue(  MInst->getImplicitRef(z) ); | ||||
| 	  cerr << "\t"; | ||||
| 	} | ||||
| 	 | ||||
| 	for(unsigned z=0; z < NumOfImpRefs; z++) | ||||
| 	  cerr << RAV(MInst->getImplicitRef(z)) << "\t"; | ||||
|       } | ||||
|  | ||||
|     } // for all machine instructions | ||||
|   | ||||
| @@ -70,13 +70,9 @@ void BBLiveVar::calcDefUseSets() { | ||||
| 	   | ||||
| 	  PhiArgMap[ArgVal] = cast<BasicBlock>(BBVal);  | ||||
| 	   | ||||
| 	  if (DEBUG_LV > 1) { | ||||
| 	    cerr << "   - phi operand ";  | ||||
| 	    printValue(ArgVal);  | ||||
| 	    cerr << " came from BB ";  | ||||
| 	    printValue(PhiArgMap[ArgVal]);  | ||||
| 	    cerr << "\n"; | ||||
| 	  } | ||||
| 	  if (DEBUG_LV > 1) | ||||
| 	    cerr << "   - phi operand " << RAV(ArgVal) << " came from BB " | ||||
|                  << RAV(PhiArgMap[ArgVal]) << "\n"; | ||||
| 	} // if( IsPhi ) | ||||
|       } // if a use | ||||
|     } // for all operands | ||||
| @@ -105,9 +101,7 @@ void  BBLiveVar::addDef(const Value *Op) { | ||||
|   InSet.erase(Op);       // this definition kills any uses | ||||
|   InSetChanged = true;  | ||||
|  | ||||
|   if (DEBUG_LV > 1) { | ||||
|     cerr << "  +Def: "; printValue( Op ); cerr << "\n"; | ||||
|   } | ||||
|   if (DEBUG_LV > 1) cerr << "  +Def: " << RAV(Op) << "\n"; | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -119,9 +113,7 @@ void  BBLiveVar::addUse(const Value *Op) { | ||||
|   OutSet.erase(Op);   // remove if there is a def below this use | ||||
|   InSetChanged = true;  | ||||
|  | ||||
|   if (DEBUG_LV > 1) { | ||||
|     cerr << "   Use: "; printValue( Op ); cerr << "\n"; | ||||
|   } | ||||
|   if (DEBUG_LV > 1) cerr << "   Use: " << RAV(Op) << "\n"; | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -62,7 +62,7 @@ void MethodLiveVarInfo::constructBBs(const Method *M) { | ||||
|       BBI != BBE; ++BBI, ++POId) {  | ||||
|     const BasicBlock *BB = *BBI;        // get the current BB  | ||||
|  | ||||
|     if (DEBUG_LV) { std::cerr << " For BB "; printValue(BB); cerr << ":\n"; } | ||||
|     if (DEBUG_LV) std::cerr << " For BB " << RAV(BB) << ":\n"; | ||||
|  | ||||
|     // create a new BBLiveVar | ||||
|     BBLiveVar *LVBB = new BBLiveVar(BB, POId);   | ||||
|   | ||||
| @@ -1,64 +1,42 @@ | ||||
|  | ||||
|  | ||||
|  | ||||
| #include "llvm/Analysis/LiveVar/ValueSet.h" | ||||
| #include "llvm/ConstantVals.h" | ||||
| #include <algorithm> | ||||
| #include <iostream> | ||||
| using std::cerr; | ||||
| using std::endl; | ||||
| using std::pair; | ||||
| using std::hash_set; | ||||
|  | ||||
| void printValue(const Value *v) { // func to print a Value  | ||||
| ostream &operator<<(ostream &O, RAV V) { // func to print a Value  | ||||
|   const Value *v = V.V; | ||||
|   if (v->hasName()) | ||||
|     cerr << v << "(" << v->getName() << ") "; | ||||
|     return O << v << "(" << v->getName() << ") "; | ||||
|   else if (Constant *C = dyn_cast<Constant>(v)) | ||||
|     cerr << v << "(" << C->getStrValue() << ") "; | ||||
|     return O << v << "(" << C->getStrValue() << ") "; | ||||
|   else | ||||
|     cerr << v  << " "; | ||||
|     return O << v  << " "; | ||||
| } | ||||
|  | ||||
| bool ValueSet::setUnion( const ValueSet *S) {    | ||||
|   bool Changed = false; | ||||
|  | ||||
| //---------------- Method implementations -------------------------- | ||||
|                                              // for performing two set unions | ||||
| bool ValueSet::setUnion( const ValueSet *set1) {    | ||||
|   pair<iterator, bool> result; | ||||
|   bool changed = false; | ||||
|   for (const_iterator SI = S->begin(), SE = S->end(); SI != SE; ++SI) | ||||
|     if (insert(*SI).second) | ||||
|       Changed = true; | ||||
|  | ||||
|   for(const_iterator set1it = set1->begin() ; set1it != set1->end(); ++set1it) { | ||||
|                                              // for all all elements in set1 | ||||
|     result = insert(*set1it);                // insert to this set | ||||
|     if(result.second == true) changed = true; | ||||
|   } | ||||
|  | ||||
|   return changed; | ||||
|   return Changed; | ||||
| } | ||||
|  | ||||
|  | ||||
|                                              // for performing set difference | ||||
| void ValueSet::setDifference( const ValueSet *const set1,  | ||||
| 			      const ValueSet *const set2) {  | ||||
|  | ||||
|   const_iterator set1it, set2it; | ||||
|   for( set1it = set1->begin() ; set1it != set1->end(); ++set1it) {   | ||||
|                                              // for all elements in set1 | ||||
|     iterator set2it = set2->find( *set1it ); // find wether the elem is in set2 | ||||
|     if( set2it == set2->end() )              // if the element is not in set2 | ||||
|       insert( *set1it );                     // insert to this set | ||||
|   } | ||||
| void ValueSet::setDifference(const ValueSet *S1, const ValueSet *S2) { | ||||
|   for (const_iterator SI = S1->begin(), SE = S1->end() ; SI != SE; ++SI) | ||||
|     if (S2->find(*SI) == S2->end())       // if the element is not in set2 | ||||
|       insert(*SI); | ||||
| } | ||||
|  | ||||
|  | ||||
|                                         // for performing set subtraction | ||||
| void ValueSet::setSubtract( const ValueSet *const set1) {  | ||||
|   const_iterator set1it; | ||||
|   for( set1it = set1->begin() ; set1it != set1->end(); ++set1it)   | ||||
|                                         // for all elements in set1 | ||||
|     erase( *set1it );                   // erase that element from this set | ||||
| void ValueSet::setSubtract(const ValueSet *S) {  | ||||
|   for (const_iterator SI = S->begin() ; SI != S->end(); ++SI)   | ||||
|     erase(*SI); | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| void ValueSet::printSet()  const {     // for printing a live variable set | ||||
|   for_each(begin(), end(), printValue); | ||||
| void ValueSet::printSet() const { | ||||
|   for (const_iterator I = begin(), E = end(); I != E; ++I) | ||||
|     std::cerr << RAV(*I); | ||||
| } | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| /* Title:   LiveRange.h   -*- C++ -*- | ||||
|    Author:  Ruchira Sasanka | ||||
|    Date:    July 25, 01 | ||||
|    Purpose: To keep info about a live range.  | ||||
|    Asuumptions: | ||||
|  | ||||
|    Since the Value pointed by a use is the same as of its def, it is sufficient | ||||
|    to keep only defs in a LiveRange. | ||||
| */ | ||||
| //===-- LiveRange.h - Store info about a live range --------------*- C++ -*--=// | ||||
| // | ||||
| // Implements a live range using a ValueSet. A LiveRange is a simple set | ||||
| // of Values.  | ||||
| // | ||||
| // Since the Value pointed by a use is the same as of its def, it is sufficient | ||||
| // to keep only defs in a LiveRange. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #ifndef LIVE_RANGE_H | ||||
| #define LIVE_RANGE_H | ||||
| @@ -18,149 +18,120 @@ | ||||
| class RegClass; | ||||
| class IGNode; | ||||
|  | ||||
|  | ||||
| //---------------------------------------------------------------------------- | ||||
| // Class LiveRange | ||||
| // | ||||
| // Implements a live range using a ValueSet. A LiveRange is a simple set | ||||
| // of Values.  | ||||
| //---------------------------------------------------------------------------- | ||||
|  | ||||
| class LiveRange : public ValueSet { | ||||
|   RegClass *MyRegClass;       // register classs (e.g., int, FP) for this LR | ||||
|  | ||||
|   bool doesSpanAcrossCalls; | ||||
|   // | ||||
|   // Does this live range span across calls?  | ||||
|   // doesSpanAcrossCalls - Does this live range span across calls?  | ||||
|   // This information is used by graph | ||||
|   // coloring algo to avoid allocating volatile colors to live ranges | ||||
|   // that span across calls (since they have to be saved/restored) | ||||
|    | ||||
|   // | ||||
|   bool doesSpanAcrossCalls; | ||||
|  | ||||
|   IGNode *UserIGNode;         // IGNode which uses this LR | ||||
|  | ||||
|   int Color;                  // color assigned to this live range | ||||
|  | ||||
|   bool mustSpill;             // whether this LR must be spilt | ||||
|  | ||||
|  | ||||
|   // mustSaveAcrossCalls - whether this LR must be saved accross calls | ||||
|   // ***TODO REMOVE this | ||||
|   // | ||||
|   bool mustSaveAcrossCalls;         | ||||
|   // | ||||
|   // whether this LR must be saved accross calls ***TODO REMOVE this | ||||
|    | ||||
|   // SuggestedColor - if this LR has a suggested color, can it be | ||||
|   // really alloated?  A suggested color cannot be allocated when the | ||||
|   // suggested color is volatile and when there are call | ||||
|   // interferences. | ||||
|   // | ||||
|   int SuggestedColor;        // The suggested color for this LR | ||||
|   // | ||||
|   // if this LR has a suggested color, can it be really alloated? | ||||
|   // A suggested color cannot be allocated when the suggested color is | ||||
|   // volatile and when there are call interferences. | ||||
|  | ||||
|   bool CanUseSuggestedCol; | ||||
|   // CanUseSuggestedCol - It is possible that a suggested color for | ||||
|   // this live range is not available before graph coloring (e.g., it | ||||
|   // can be allocated to another live range which interferes with | ||||
|   // this) | ||||
|   //  | ||||
|   // It is possible that a suggested color for this live range is not | ||||
|   // available before graph coloring (e.g., it can be allocated to another | ||||
|   // live range which interferes with this) | ||||
|   bool CanUseSuggestedCol; | ||||
|  | ||||
|   // SpilledStackOffsetFromFP - If this LR is spilled, its stack | ||||
|   // offset from *FP*. The spilled offsets must always be relative to | ||||
|   // the FP. | ||||
|   // | ||||
|   int SpilledStackOffsetFromFP; | ||||
|   // | ||||
|   // if this LR is spilled, its stack offset from *FP*. The spilled offsets | ||||
|   // must always be relative to the FP. | ||||
|  | ||||
|   // HasSpillOffset 0 Whether this live range has a spill offset | ||||
|   // | ||||
|   bool HasSpillOffset; | ||||
|   // | ||||
|   // Whether this live range has a spill offset | ||||
|  | ||||
|   unsigned SpillCost; | ||||
|   // | ||||
|   // The spill cost of this live range. Calculated using loop depth of | ||||
|   // each reference to each Value in the live range | ||||
|  | ||||
|  public: | ||||
|  | ||||
|   // constructor | ||||
|   // | ||||
|   LiveRange() : ValueSet() { | ||||
|   unsigned SpillCost; | ||||
|  | ||||
| public: | ||||
|   LiveRange() { | ||||
|     Color = SuggestedColor = -1;        // not yet colored  | ||||
|     mustSpill = mustSaveAcrossCalls = false; | ||||
|     MyRegClass = NULL; | ||||
|     UserIGNode = NULL; | ||||
|     MyRegClass = 0; | ||||
|     UserIGNode = 0; | ||||
|     doesSpanAcrossCalls = false; | ||||
|     CanUseSuggestedCol = true; | ||||
|     HasSpillOffset  = false; | ||||
|     HasSpillOffset = false; | ||||
|     SpillCost = 0; | ||||
|   } | ||||
|  | ||||
|   // empty destructor since there are nothing to be deleted | ||||
|   // | ||||
|   ~LiveRange() {}           | ||||
|   void setRegClass(RegClass *RC) { MyRegClass = RC; } | ||||
|  | ||||
|   RegClass *getRegClass() const { assert(MyRegClass); return MyRegClass; } | ||||
|  | ||||
|   void setRegClass(RegClass *const RC)  | ||||
|     { MyRegClass = RC; } | ||||
|  | ||||
|   inline RegClass *const getRegClass() const  | ||||
|     { assert(MyRegClass); return MyRegClass; }  | ||||
|  | ||||
|   inline bool hasColor() const  | ||||
|     { return Color != -1; } | ||||
|   bool hasColor() const { return Color != -1; } | ||||
|    | ||||
|   inline unsigned int getColor() const  | ||||
|     { assert( Color != -1); return (unsigned) Color ; } | ||||
|   unsigned getColor() const { assert(Color != -1); return (unsigned)Color; } | ||||
|  | ||||
|   inline void setColor(unsigned int Col)  | ||||
|     { Color = (int) Col ; } | ||||
|   void setColor(unsigned Col) { Color = (int)Col; } | ||||
|  | ||||
|    | ||||
|   inline void setCallInterference() {  | ||||
|     doesSpanAcrossCalls = 1; | ||||
|   } | ||||
|  | ||||
|  | ||||
|   inline bool isCallInterference() const {  | ||||
|     return (doesSpanAcrossCalls == 1);  | ||||
|     return doesSpanAcrossCalls == 1;  | ||||
|   }  | ||||
|  | ||||
|   inline void markForSpill() { mustSpill = true; } | ||||
|  | ||||
|   inline bool isMarkedForSpill() { return  mustSpill; } | ||||
|   inline bool isMarkedForSpill() { return mustSpill; } | ||||
|  | ||||
|   inline void setSpillOffFromFP(int StackOffset) { | ||||
|     assert( mustSpill && "This LR is not spilled"); | ||||
|     assert(mustSpill && "This LR is not spilled"); | ||||
|     SpilledStackOffsetFromFP = StackOffset; | ||||
|     HasSpillOffset = true; | ||||
|   } | ||||
|  | ||||
|   inline void modifySpillOffFromFP(int StackOffset) { | ||||
|     assert( mustSpill && "This LR is not spilled"); | ||||
|     assert(mustSpill && "This LR is not spilled"); | ||||
|     SpilledStackOffsetFromFP = StackOffset; | ||||
|     HasSpillOffset = true; | ||||
|   } | ||||
|  | ||||
|  | ||||
|  | ||||
|   inline bool hasSpillOffset() const { | ||||
|     return  HasSpillOffset; | ||||
|     return HasSpillOffset; | ||||
|   } | ||||
|  | ||||
|  | ||||
|   inline int getSpillOffFromFP() const { | ||||
|     assert( HasSpillOffset && "This LR is not spilled"); | ||||
|     assert(HasSpillOffset && "This LR is not spilled"); | ||||
|     return SpilledStackOffsetFromFP; | ||||
|   } | ||||
|  | ||||
|  | ||||
|   inline void markForSaveAcrossCalls() { mustSaveAcrossCalls = true; } | ||||
|  | ||||
|    | ||||
|   inline void setUserIGNode( IGNode *const IGN)  | ||||
|     { assert( !UserIGNode); UserIGNode = IGN; } | ||||
|   inline void setUserIGNode(IGNode *IGN) { | ||||
|     assert(!UserIGNode); UserIGNode = IGN; | ||||
|   } | ||||
|  | ||||
|   inline IGNode * getUserIGNode() const  | ||||
|     { return UserIGNode; }    // NULL if the user is not allocated | ||||
|   // getUserIGNode - NULL if the user is not allocated | ||||
|   inline IGNode *getUserIGNode() const { return UserIGNode; } | ||||
|  | ||||
|   inline const Type* getType() const { | ||||
|     const Value *val = *begin(); | ||||
|     assert(val && "Can't find type - Live range is empty" ); | ||||
|     return val->getType(); | ||||
|   inline const Type *getType() const { | ||||
|     return (*begin())->getType();  // set's don't have a front | ||||
|   } | ||||
|    | ||||
|   inline Type::PrimitiveID getTypeID() const { | ||||
| @@ -168,9 +139,7 @@ class LiveRange : public ValueSet { | ||||
|   } | ||||
|  | ||||
|   inline void setSuggestedColor(int Col) { | ||||
|     //assert( (SuggestedColor == -1) && "Changing an already suggested color"); | ||||
|  | ||||
|     if(SuggestedColor == -1 ) | ||||
|     if (SuggestedColor == -1) | ||||
|       SuggestedColor = Col; | ||||
| #if 0 | ||||
|     else if (DEBUG_RA)  | ||||
| @@ -179,21 +148,21 @@ class LiveRange : public ValueSet { | ||||
|   } | ||||
|  | ||||
|   inline unsigned getSuggestedColor() const { | ||||
|     assert( SuggestedColor != -1);      // only a valid color is obtained | ||||
|     return (unsigned) SuggestedColor; | ||||
|     assert(SuggestedColor != -1);      // only a valid color is obtained | ||||
|     return (unsigned)SuggestedColor; | ||||
|   } | ||||
|  | ||||
|   inline bool hasSuggestedColor() const { | ||||
|     return ( SuggestedColor > -1); | ||||
|     return SuggestedColor != -1; | ||||
|   } | ||||
|  | ||||
|   inline bool isSuggestedColorUsable() const { | ||||
|     assert( hasSuggestedColor() && "No suggested color"); | ||||
|     assert(hasSuggestedColor() && "No suggested color"); | ||||
|     return CanUseSuggestedCol; | ||||
|   } | ||||
|  | ||||
|   inline void setSuggestedColorUsable(const bool val) { | ||||
|     assert( hasSuggestedColor() && "No suggested color"); | ||||
|   inline void setSuggestedColorUsable(bool val) { | ||||
|     assert(hasSuggestedColor() && "No suggested color"); | ||||
|     CanUseSuggestedCol = val; | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -118,8 +118,8 @@ void LiveRangeInfo::constructLiveRanges() | ||||
|  | ||||
|     			    | ||||
|     if( DEBUG_RA > 1) {      | ||||
|       cerr << " adding LiveRange for argument ";     | ||||
|       printValue((const Value *) *ArgIt); cerr << "\n"; | ||||
|       cerr << " adding LiveRange for argument " | ||||
|            << RAV((const Value *)*ArgIt) << "\n"; | ||||
|     } | ||||
|   } | ||||
|  | ||||
| @@ -163,11 +163,9 @@ void LiveRangeInfo::constructLiveRanges() | ||||
| 	  MachineOperand::MachineOperandType OpTyp =  | ||||
| 	    OpI.getMachineOperand().getOperandType(); | ||||
|  | ||||
| 	  if (OpTyp == MachineOperand::MO_CCRegister) { | ||||
| 	    cerr << "\n**CC reg found. Is Def=" << OpI.isDef() << " Val:"; | ||||
| 	    printValue( OpI.getMachineOperand().getVRegValue() ); | ||||
| 	    cerr << "\n"; | ||||
| 	  } | ||||
| 	  if (OpTyp == MachineOperand::MO_CCRegister) | ||||
| 	    cerr << "\n**CC reg found. Is Def=" << OpI.isDef() << " Val:" | ||||
|                  << RAV(OpI.getMachineOperand().getVRegValue()) << "\n"; | ||||
| 	} | ||||
|  | ||||
| 	// create a new LR iff this operand is a def | ||||
| @@ -175,9 +173,9 @@ void LiveRangeInfo::constructLiveRanges() | ||||
| 	  const Value *Def = *OpI; | ||||
|  | ||||
| 	  // Only instruction values are accepted for live ranges here | ||||
| 	  if( Def->getValueType() != Value::InstructionVal ) { | ||||
| 	    cerr << "\n**%%Error: Def is not an instruction val. Def="; | ||||
| 	    printValue( Def ); cerr << "\n"; | ||||
| 	  if (Def->getValueType() != Value::InstructionVal ) { | ||||
| 	    cerr << "\n**%%Error: Def is not an instruction val. Def=" | ||||
|                  << RAV(Def) << "\n"; | ||||
| 	    continue; | ||||
| 	  } | ||||
|  | ||||
| @@ -189,10 +187,8 @@ void LiveRangeInfo::constructLiveRanges() | ||||
| 	    DefRange->insert(Def);          // add the instruction (def) to it | ||||
| 	    LiveRangeMap[ Def ] = DefRange; // update the map | ||||
|  | ||||
| 	    if (DEBUG_RA > 1) { 	     | ||||
| 	      cerr << "  creating a LR for def: ";     | ||||
| 	      printValue(Def); cerr  << "\n"; | ||||
| 	    } | ||||
| 	    if (DEBUG_RA > 1) | ||||
| 	      cerr << "  creating a LR for def: " << RAV(Def) << "\n"; | ||||
|  | ||||
| 	    // set the register class of the new live range | ||||
| 	    //assert( RegClassList.size() ); | ||||
| @@ -204,24 +200,20 @@ void LiveRangeInfo::constructLiveRanges() | ||||
| 			    OpI.getMachineOperand().getVRegValue(), isCC ); | ||||
|  | ||||
|  | ||||
| 	    if(isCC && DEBUG_RA) { | ||||
| 	      cerr  << "\a**created a LR for a CC reg:"; | ||||
| 	      printValue( OpI.getMachineOperand().getVRegValue() ); | ||||
| 	    } | ||||
| 	    if (isCC && DEBUG_RA) | ||||
| 	      cerr  << "\a**created a LR for a CC reg:" | ||||
|                     << RAV(OpI.getMachineOperand().getVRegValue()); | ||||
|  | ||||
| 	    DefRange->setRegClass( RegClassList[ rcid ] ); | ||||
|  | ||||
| 	  } | ||||
| 	  else { | ||||
| 	    DefRange->setRegClass(RegClassList[rcid]); | ||||
| 	  } else { | ||||
| 	    DefRange->insert(Def);          // add the opearand to def range | ||||
|                                             // update the map - Operand points  | ||||
| 	                                    // to the merged set | ||||
| 	    LiveRangeMap[ Def ] = DefRange;  | ||||
| 	    LiveRangeMap[Def] = DefRange;  | ||||
|  | ||||
| 	    if( DEBUG_RA > 1) {  | ||||
| 	      cerr << "   added to an existing LR for def: ";   | ||||
| 	      printValue( Def ); cerr  << "\n"; | ||||
| 	    } | ||||
| 	    if (DEBUG_RA > 1) | ||||
| 	      cerr << "   added to an existing LR for def: " | ||||
|                    << RAV(Def) << "\n"; | ||||
| 	  } | ||||
|  | ||||
| 	} // if isDef() | ||||
| @@ -336,10 +328,8 @@ void LiveRangeInfo::coalesceLRs() | ||||
| 	    if( ! LROfUse ) {           // if LR of use is not found | ||||
|  | ||||
| 	      //don't warn about labels | ||||
| 	      if (!((*UseI)->getType())->isLabelType() && DEBUG_RA) { | ||||
| 		cerr<<" !! Warning: No LR for use "; printValue(*UseI); | ||||
| 		cerr << "\n"; | ||||
| 	      } | ||||
| 	      if (!((*UseI)->getType())->isLabelType() && DEBUG_RA) | ||||
| 		cerr << " !! Warning: No LR for use " << RAV(*UseI) << "\n"; | ||||
| 	      continue;                 // ignore and continue | ||||
| 	    } | ||||
|  | ||||
| @@ -398,13 +388,12 @@ void LiveRangeInfo::coalesceLRs() | ||||
| /*--------------------------- Debug code for printing ---------------*/ | ||||
|  | ||||
|  | ||||
| void LiveRangeInfo::printLiveRanges() | ||||
| { | ||||
| void LiveRangeInfo::printLiveRanges() { | ||||
|   LiveRangeMapType::iterator HMI = LiveRangeMap.begin();   // hash map iterator | ||||
|   cerr << "\nPrinting Live Ranges from Hash Map:\n"; | ||||
|   for( ; HMI != LiveRangeMap.end() ; ++HMI) { | ||||
|     if( HMI->first && HMI->second ) { | ||||
|       cerr <<" "; printValue((*HMI).first);  cerr << "\t: ";  | ||||
|   for( ; HMI != LiveRangeMap.end(); ++HMI) { | ||||
|     if (HMI->first && HMI->second) { | ||||
|       cerr << " " << RAV(HMI->first) << "\t: ";  | ||||
|       HMI->second->printSet(); cerr << "\n"; | ||||
|     } | ||||
|   } | ||||
|   | ||||
| @@ -118,8 +118,8 @@ void PhyRegAlloc::createIGNodeListsAndIGs() { | ||||
|       LiveRange *L = HMI->second;   // get the LiveRange | ||||
|       if (!L) {  | ||||
|         if( DEBUG_RA) { | ||||
|           cerr << "\n*?!?Warning: Null liver range found for: "; | ||||
|           printValue(HMI->first); cerr << "\n"; | ||||
|           cerr << "\n*?!?Warning: Null liver range found for: " | ||||
|                << RAV(HMI->first) << "\n"; | ||||
|         } | ||||
|         continue; | ||||
|       } | ||||
| @@ -170,14 +170,12 @@ void PhyRegAlloc::addInterference(const Value *const Def, | ||||
|   // | ||||
|   for( ; LIt != LVSet->end(); ++LIt) { | ||||
|  | ||||
|     if( DEBUG_RA > 1) { | ||||
|       cerr << "< Def="; printValue(Def);      | ||||
|       cerr << ", Lvar=";  printValue( *LIt); cerr  << "> "; | ||||
|     } | ||||
|     if (DEBUG_RA > 1) | ||||
|       cerr << "< Def=" << RAV(Def) << ", Lvar=" << RAV(*LIt) << "> "; | ||||
|  | ||||
|     //  get the live range corresponding to live var | ||||
|     // | ||||
|     LiveRange *const LROfVar = LRI.getLiveRangeForValue(*LIt );     | ||||
|     LiveRange *LROfVar = LRI.getLiveRangeForValue(*LIt); | ||||
|  | ||||
|     // LROfVar can be null if it is a const since a const  | ||||
|     // doesn't have a dominating def - see Assumptions above | ||||
| @@ -188,13 +186,12 @@ void PhyRegAlloc::addInterference(const Value *const Def, | ||||
|  | ||||
|       // if 2 reg classes are the same set interference | ||||
|       // | ||||
|       if(RCOfDef == LROfVar->getRegClass()) { | ||||
|       if (RCOfDef == LROfVar->getRegClass()) { | ||||
| 	RCOfDef->setInterference( LROfDef, LROfVar);   | ||||
|       } else if(DEBUG_RA > 1)  {  | ||||
|       } else if (DEBUG_RA > 1)  {  | ||||
|         // we will not have LRs for values not explicitly allocated in the | ||||
|         // instruction stream (e.g., constants) | ||||
|         cerr << " warning: no live range for " ;  | ||||
|         printValue(*LIt); cerr << "\n"; | ||||
|         cerr << " warning: no live range for " << RAV(*LIt) << "\n"; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| @@ -434,10 +431,9 @@ void PhyRegAlloc::addInterferencesForArgs() | ||||
|   for( ; ArgIt != ArgList.end() ; ++ArgIt) {  // for each argument | ||||
|     addInterference((Value*)*ArgIt, InSet, false); // add interferences between  | ||||
|                                               // args and LVars at start | ||||
|     if( DEBUG_RA > 1) { | ||||
|        cerr << " - %% adding interference for  argument ";     | ||||
|       printValue((const Value *)*ArgIt); cerr << "\n"; | ||||
|     } | ||||
|     if( DEBUG_RA > 1) | ||||
|       cerr << " - %% adding interference for  argument " | ||||
|            << RAV((const Value *)*ArgIt) << "\n"; | ||||
|   } | ||||
| } | ||||
|  | ||||
| @@ -1051,15 +1047,11 @@ void PhyRegAlloc::printMachineCode() | ||||
|      | ||||
|  | ||||
|       unsigned NumOfImpRefs =  MInst->getNumImplicitRefs(); | ||||
|       if(  NumOfImpRefs > 0 ) { | ||||
| 	 | ||||
|       if( NumOfImpRefs > 0) { | ||||
| 	cerr << "\tImplicit:"; | ||||
|  | ||||
| 	for(unsigned z=0; z < NumOfImpRefs; z++) { | ||||
| 	  printValue(  MInst->getImplicitRef(z) ); | ||||
| 	  cerr << "\t"; | ||||
| 	} | ||||
| 	 | ||||
| 	for(unsigned z=0; z < NumOfImpRefs; z++) | ||||
| 	  cerr << RAV(MInst->getImplicitRef(z)) << "\t"; | ||||
|       } | ||||
|  | ||||
|     } // for all machine instructions | ||||
|   | ||||
| @@ -563,11 +563,8 @@ void UltraSparcRegInfo::suggestRegs4CallArgs(const MachineInstr *CallMI, | ||||
|  | ||||
|     // not possible to have a null LR since all args (even consts)   | ||||
|     // must be defined before | ||||
|     if( !LR ) {           | ||||
|       if( DEBUG_RA) { | ||||
| 	cerr << " ERROR: In call instr, no LR for arg:  " ; | ||||
| 	printValue(CallArg); cerr << "\n"; | ||||
|       } | ||||
|     if (!LR) {           | ||||
|       cerr << " ERROR: In call instr, no LR for arg: " << RAV(CallArg) << "\n"; | ||||
|       assert(0 && "NO LR for call arg");   | ||||
|     } | ||||
|      | ||||
| @@ -624,16 +621,12 @@ void UltraSparcRegInfo::colorCallArgs(const MachineInstr *CallMI, | ||||
|  | ||||
|   const Value *RetVal = getCallInstRetVal( CallMI ); | ||||
|  | ||||
|   if( RetVal ) { | ||||
|   if (RetVal) { | ||||
|     LiveRange *RetValLR = LRI.getLiveRangeForValue( RetVal ); | ||||
|  | ||||
|     LiveRange * RetValLR = LRI.getLiveRangeForValue( RetVal ); | ||||
|  | ||||
|     if( !RetValLR ) { | ||||
|       cerr << "\nNo LR for:"; | ||||
|       printValue( RetVal ); | ||||
|       cerr << "\n"; | ||||
|       assert( RetValLR && "ERR:No LR for non-void return value"); | ||||
|       //return; | ||||
|     if (!RetValLR) { | ||||
|       cerr << "\nNo LR for:" << RAV(RetVal) << "\n"; | ||||
|       assert(0 && "ERR:No LR for non-void return value"); | ||||
|     } | ||||
|  | ||||
|     unsigned RegClassID = (RetValLR->getRegClass())->getID();     | ||||
| @@ -755,13 +748,9 @@ void UltraSparcRegInfo::colorCallArgs(const MachineInstr *CallMI, | ||||
|  | ||||
|     // not possible to have a null LR since all args (even consts)   | ||||
|     // must be defined before | ||||
|     if( !LR ) {           | ||||
|       if( DEBUG_RA) { | ||||
| 	cerr << " ERROR: In call instr, no LR for arg:  " ; | ||||
| 	printValue(CallArg); cerr << "\n"; | ||||
|       } | ||||
|     if (!LR) {           | ||||
|       cerr << " ERROR: In call instr, no LR for arg:  " << RAV(CallArg) << "\n"; | ||||
|       assert(0 && "NO LR for call arg");   | ||||
|       // continue; | ||||
|     } | ||||
|  | ||||
|  | ||||
| @@ -942,13 +931,10 @@ void UltraSparcRegInfo::suggestReg4RetValue(const MachineInstr *RetMI, | ||||
|  | ||||
|     LiveRange *const LR = LRI.getLiveRangeForValue( RetVal );  | ||||
|  | ||||
|     if( !LR ) { | ||||
|      cerr << "\nNo LR for:"; | ||||
|      printValue( RetVal ); | ||||
|      cerr << "\n"; | ||||
|      assert( LR && "No LR for return value of non-void method"); | ||||
|      //return; | ||||
|    } | ||||
|     if (!LR) { | ||||
|       cerr << "\nNo LR for:" << RAV(RetVal) << "\n"; | ||||
|       assert(0 && "No LR for return value of non-void method"); | ||||
|     } | ||||
|  | ||||
|     unsigned RegClassID = (LR->getRegClass())->getID(); | ||||
|        | ||||
| @@ -981,12 +967,10 @@ void UltraSparcRegInfo::colorRetValue(const MachineInstr *RetMI, | ||||
|  | ||||
|     LiveRange *LR = LRI.getLiveRangeForValue(RetVal);  | ||||
|  | ||||
|     if( ! LR ) { | ||||
| 	cerr << "\nNo LR for:"; | ||||
| 	printValue( RetVal ); | ||||
| 	cerr << "\n"; | ||||
| 	// assert( LR && "No LR for return value of non-void method"); | ||||
| 	return; | ||||
|     if (!LR) { | ||||
|       cerr << "\nNo LR for:" << RAV(RetVal) << "\n"; | ||||
|       // assert( LR && "No LR for return value of non-void method"); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|     unsigned RegClassID =  getRegClassIDOfValue(RetVal); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user