diff options
| author | Dan Gohman <gohman@apple.com> | 2009-01-26 04:35:06 +0000 | 
|---|---|---|
| committer | Dan Gohman <gohman@apple.com> | 2009-01-26 04:35:06 +0000 | 
| commit | 8e4ac9b71ab2bd9149b9d27b4f76b9065f957786 (patch) | |
| tree | 13b5325c74e24546cdf738f84c92fce6766f65ab /llvm/lib/CodeGen/SelectionDAG | |
| parent | ad13cf4e7a3ca27f2303156ee15c6eb06430cbde (diff) | |
| download | bcm5719-llvm-8e4ac9b71ab2bd9149b9d27b4f76b9065f957786.tar.gz bcm5719-llvm-8e4ac9b71ab2bd9149b9d27b4f76b9065f957786.zip | |
Take the next steps in making SDUse more consistent with LLVM Use, and
tidy up SDUse and related code.
 - Replace the operator= member functions with a set method, like
   LLVM Use has, and variants setInitial and setNode, which take
   care up updating use lists, like LLVM Use's does. This simplifies
   code that calls these functions.
 - getSDValue() is renamed to get(), as in LLVM Use, though most
   places can either use the implicit conversion to SDValue or the
   convenience functions instead.
 - Fix some more node vs. value terminology issues.
Also, eliminate the one remaining use of SDOperandPtr, and
SDOperandPtr itself.
llvm-svn: 62995
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 143 | 
3 files changed, 65 insertions, 82 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp index e4b24f1aaff..d1759c1ab0e 100644 --- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp @@ -4138,7 +4138,7 @@ SDValue DAGCombiner::visitFP_EXTEND(SDNode *N) {    // If this is fp_round(fpextend), don't fold it, allow ourselves to be folded.    if (N->hasOneUse() &&  -      N->use_begin().getUse().getSDValue().getOpcode() == ISD::FP_ROUND) +      N->use_begin()->getOpcode() == ISD::FP_ROUND)      return SDValue();    // fold (fp_extend c1fp) -> c1fp diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.cpp index a4f3917b18a..4c5dd030c7a 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.cpp @@ -81,7 +81,7 @@ void DAGTypeLegalizer::PerformExpensiveChecks() {          // Check that remapped values are only used by nodes marked NewNode.          for (SDNode::use_iterator UI = I->use_begin(), UE = I->use_end();               UI != UE; ++UI) -          if (UI.getUse().getSDValue().getResNo() == i) +          if (UI.getUse().getResNo() == i)              assert(UI->getNodeId() == NewNode &&                     "Remapped value has non-trivial use!"); diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index ab222c4f2fa..7fd50aca401 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -342,8 +342,8 @@ static void AddNodeIDOperands(FoldingSetNodeID &ID,  static void AddNodeIDOperands(FoldingSetNodeID &ID,                                const SDUse *Ops, unsigned NumOps) {    for (; NumOps; --NumOps, ++Ops) { -    ID.AddPointer(Ops->getVal()); -    ID.AddInteger(Ops->getSDValue().getResNo()); +    ID.AddPointer(Ops->getNode()); +    ID.AddInteger(Ops->getResNo());    }  } @@ -538,8 +538,7 @@ void SelectionDAG::RemoveDeadNodes(SmallVectorImpl<SDNode *> &DeadNodes,    // Process the worklist, deleting the nodes and adding their uses to the    // worklist.    while (!DeadNodes.empty()) { -    SDNode *N = DeadNodes.back(); -    DeadNodes.pop_back(); +    SDNode *N = DeadNodes.pop_back_val();      if (UpdateListener)        UpdateListener->NodeDeleted(N, 0); @@ -549,10 +548,11 @@ void SelectionDAG::RemoveDeadNodes(SmallVectorImpl<SDNode *> &DeadNodes,      // Next, brutally remove the operand list.  This is safe to do, as there are      // no cycles in the graph. -    for (SDNode::op_iterator I = N->op_begin(), E = N->op_end(); I != E; ++I) { -      SDNode *Operand = I->getVal(); -      Operand->removeUser(std::distance(N->op_begin(), I), N); -       +    for (SDNode::op_iterator I = N->op_begin(), E = N->op_end(); I != E; ) { +      SDUse &Use = *I++; +      SDNode *Operand = Use.getNode(); +      Use.set(SDValue()); +        // Now that we removed this operand, see if there are no uses of it left.        if (Operand->use_empty())          DeadNodes.push_back(Operand); @@ -581,8 +581,7 @@ void SelectionDAG::DeleteNodeNotInCSEMaps(SDNode *N) {    assert(N->use_empty() && "Cannot delete a node that is not dead!");    // Drop all of the operands and decrement used node's use counts. -  for (SDNode::op_iterator I = N->op_begin(), E = N->op_end(); I != E; ++I) -    I->getVal()->removeUser(std::distance(N->op_begin(), I), N); +  N->DropOperands();    DeallocateNode(N);  } @@ -763,7 +762,7 @@ void SelectionDAG::VerifyNode(SDNode *N) {      // following checks at least makes it possible to legalize most of the time.  //    MVT EltVT = N->getValueType(0).getVectorElementType();  //    for (SDNode::op_iterator I = N->op_begin(), E = N->op_end(); I != E; ++I) -//      assert(I->getSDValue().getValueType() == EltVT && +//      assert(I->getValueType() == EltVT &&  //             "Wrong operand type!");      break;    } @@ -819,7 +818,7 @@ void SelectionDAG::clear() {    std::fill(ValueTypeNodes.begin(), ValueTypeNodes.end(),              static_cast<SDNode*>(0)); -  EntryNode.Uses = 0; +  EntryNode.UseList = 0;    AllNodes.push_back(&EntryNode);    Root = getEntryNode();  } @@ -3915,9 +3914,7 @@ SDValue SelectionDAG::UpdateNodeOperands(SDValue InN, SDValue Op) {        InsertPos = 0;    // Now we update the operands. -  N->OperandList[0].getVal()->removeUser(0, N); -  N->OperandList[0].getSDValue() = Op; -  Op.getNode()->addUser(0, N); +  N->OperandList[0].set(Op);    // If this gets put into a CSE map, add it.    if (InsertPos) CSEMap.InsertNode(N, InsertPos); @@ -3944,16 +3941,10 @@ UpdateNodeOperands(SDValue InN, SDValue Op1, SDValue Op2) {        InsertPos = 0;    // Now we update the operands. -  if (N->OperandList[0] != Op1) { -    N->OperandList[0].getVal()->removeUser(0, N); -    N->OperandList[0].getSDValue() = Op1; -    Op1.getNode()->addUser(0, N); -  } -  if (N->OperandList[1] != Op2) { -    N->OperandList[1].getVal()->removeUser(1, N); -    N->OperandList[1].getSDValue() = Op2; -    Op2.getNode()->addUser(1, N); -  } +  if (N->OperandList[0] != Op1) +    N->OperandList[0].set(Op1); +  if (N->OperandList[1] != Op2) +    N->OperandList[1].set(Op2);    // If this gets put into a CSE map, add it.    if (InsertPos) CSEMap.InsertNode(N, InsertPos); @@ -4009,13 +4000,9 @@ UpdateNodeOperands(SDValue InN, const SDValue *Ops, unsigned NumOps) {        InsertPos = 0;    // Now we update the operands. -  for (unsigned i = 0; i != NumOps; ++i) { -    if (N->OperandList[i] != Ops[i]) { -      N->OperandList[i].getVal()->removeUser(i, N); -      N->OperandList[i].getSDValue() = Ops[i]; -      Ops[i].getNode()->addUser(i, N); -    } -  } +  for (unsigned i = 0; i != NumOps; ++i) +    if (N->OperandList[i] != Ops[i]) +      N->OperandList[i].set(Ops[i]);    // If this gets put into a CSE map, add it.    if (InsertPos) CSEMap.InsertNode(N, InsertPos); @@ -4027,10 +4014,10 @@ UpdateNodeOperands(SDValue InN, const SDValue *Ops, unsigned NumOps) {  void SDNode::DropOperands() {    // Unlike the code in MorphNodeTo that does this, we don't need to    // watch for dead nodes here. -  for (op_iterator I = op_begin(), E = op_end(); I != E; ++I) -    I->getVal()->removeUser(std::distance(op_begin(), I), this); - -  NumOperands = 0; +  for (op_iterator I = op_begin(), E = op_end(); I != E; ) { +    SDUse &Use = *I++; +    Use.set(SDValue()); +  }  }  /// SelectNodeTo - These are wrappers around MorphNodeTo that accept a @@ -4255,10 +4242,10 @@ SDNode *SelectionDAG::MorphNodeTo(SDNode *N, unsigned Opc,    // Clear the operands list, updating used nodes to remove this from their    // use list.  Keep track of any operands that become dead as a result.    SmallPtrSet<SDNode*, 16> DeadNodeSet; -  for (SDNode::op_iterator B = N->op_begin(), I = B, E = N->op_end(); -       I != E; ++I) { -    SDNode *Used = I->getVal(); -    Used->removeUser(std::distance(B, I), N); +  for (SDNode::op_iterator I = N->op_begin(), E = N->op_end(); I != E; ) { +    SDUse &Use = *I++; +    SDNode *Used = Use.getNode(); +    Use.set(SDValue());      if (Used->use_empty())        DeadNodeSet.insert(Used);    } @@ -4284,10 +4271,8 @@ SDNode *SelectionDAG::MorphNodeTo(SDNode *N, unsigned Opc,    // Assign the new operands.    N->NumOperands = NumOps;    for (unsigned i = 0, e = NumOps; i != e; ++i) { -    N->OperandList[i].getSDValue() = Ops[i];      N->OperandList[i].setUser(N); -    SDNode *ToUse = N->OperandList[i].getVal(); -    ToUse->addUser(i, N); +    N->OperandList[i].setInitial(Ops[i]);    }    // Delete any nodes that are still dead after adding the uses for the @@ -4441,11 +4426,9 @@ void SelectionDAG::ReplaceAllUsesWith(SDValue FromN, SDValue To,      // To help reduce the number of CSE recomputations, process all      // the uses of this user that we can find this way.      do { -      unsigned operandNum = UI.getOperandNo(); +      SDUse &Use = UI.getUse();        ++UI; -      From->removeUser(operandNum, User); -      User->OperandList[operandNum].getSDValue() = To; -      To.getNode()->addUser(operandNum, User); +      Use.set(To);      } while (UI != UE && *UI == User);      // Now that we have modified User, add it back to the CSE maps.  If it @@ -4484,11 +4467,9 @@ void SelectionDAG::ReplaceAllUsesWith(SDNode *From, SDNode *To,      // To help reduce the number of CSE recomputations, process all      // the uses of this user that we can find this way.      do { -      unsigned operandNum = UI.getOperandNo(); +      SDUse &Use = UI.getUse();        ++UI; -      From->removeUser(operandNum, User); -      User->OperandList[operandNum].getSDValue().setNode(To); -      To->addUser(operandNum, User); +      Use.setNode(To);      } while (UI != UE && *UI == User);      // Now that we have modified User, add it back to the CSE maps.  If it @@ -4522,13 +4503,10 @@ void SelectionDAG::ReplaceAllUsesWith(SDNode *From,      // To help reduce the number of CSE recomputations, process all      // the uses of this user that we can find this way.      do { -      unsigned operandNum = UI.getOperandNo(); -      const SDValue &ToOp = -        To[User->OperandList[operandNum].getSDValue().getResNo()]; +      SDUse &Use = UI.getUse(); +      const SDValue &ToOp = To[Use.getResNo()];        ++UI; -      From->removeUser(operandNum, User); -      User->OperandList[operandNum].getSDValue() = ToOp; -      ToOp.getNode()->addUser(operandNum, User); +      Use.set(ToOp);      } while (UI != UE && *UI == User);      // Now that we have modified User, add it back to the CSE maps.  If it @@ -4538,8 +4516,8 @@ void SelectionDAG::ReplaceAllUsesWith(SDNode *From,  }  /// ReplaceAllUsesOfValueWith - Replace any uses of From with To, leaving -/// uses of other values produced by From.getVal() alone.  The Deleted vector is -/// handled the same way as for ReplaceAllUsesWith. +/// uses of other values produced by From.getNode() alone.  The Deleted +/// vector is handled the same way as for ReplaceAllUsesWith.  void SelectionDAG::ReplaceAllUsesOfValueWith(SDValue From, SDValue To,                                               DAGUpdateListener *UpdateListener){    // Handle the really simple, really trivial case efficiently. @@ -4564,11 +4542,10 @@ void SelectionDAG::ReplaceAllUsesOfValueWith(SDValue From, SDValue To,      // To help reduce the number of CSE recomputations, process all      // the uses of this user that we can find this way.      do { -      unsigned operandNum = UI.getOperandNo(); +      SDUse &Use = UI.getUse();        // Skip uses of different values from the same node. -      if (User->OperandList[operandNum].getSDValue().getResNo() != -            From.getResNo()) { +      if (Use.getResNo() != From.getResNo()) {          ++UI;          continue;        } @@ -4581,9 +4558,7 @@ void SelectionDAG::ReplaceAllUsesOfValueWith(SDValue From, SDValue To,        }        ++UI; -      From.getNode()->removeUser(operandNum, User); -      User->OperandList[operandNum].getSDValue() = To; -      To.getNode()->addUser(operandNum, User); +      Use.set(To);      } while (UI != UE && *UI == User);      // We are iterating over all uses of the From node, so if a use @@ -4603,13 +4578,18 @@ namespace {    struct UseMemo {      SDNode *User;      unsigned Index; -    unsigned operandNum; +    SDUse *Use;    }; + +  /// operator< - Sort Memos by User. +  bool operator<(const UseMemo &L, const UseMemo &R) { +    return (intptr_t)L.User < (intptr_t)R.User; +  }  }  /// ReplaceAllUsesOfValuesWith - Replace any uses of From with To, leaving -/// uses of other values produced by From.getVal() alone.  The same value may -/// appear in both the From and To list.  The Deleted vector is +/// uses of other values produced by From.getNode() alone.  The same value +/// may appear in both the From and To list.  The Deleted vector is  /// handled the same way as for ReplaceAllUsesWith.  void SelectionDAG::ReplaceAllUsesOfValuesWith(const SDValue *From,                                                const SDValue *To, @@ -4627,13 +4607,18 @@ void SelectionDAG::ReplaceAllUsesOfValuesWith(const SDValue *From,      unsigned FromResNo = From[i].getResNo();      SDNode *FromNode = From[i].getNode();      for (SDNode::use_iterator UI = FromNode->use_begin(),  -         E = FromNode->use_end(); UI != E; ++UI) -      if (UI.getUse().getSDValue().getResNo() == FromResNo) { -        UseMemo Memo = { *UI, i, UI.getOperandNo() }; +         E = FromNode->use_end(); UI != E; ++UI) { +      SDUse &Use = UI.getUse(); +      if (Use.getResNo() == FromResNo) { +        UseMemo Memo = { *UI, i, &Use };          Uses.push_back(Memo);        } +    }    } +  // Sort the uses, so that all the uses from a given User are together. +  std::sort(Uses.begin(), Uses.end()); +    for (unsigned UseIndex = 0, UseIndexEnd = Uses.size();         UseIndex != UseIndexEnd; ) {      // We know that this user uses some value of From.  If it is the right @@ -4643,18 +4628,16 @@ void SelectionDAG::ReplaceAllUsesOfValuesWith(const SDValue *From,      // This node is about to morph, remove its old self from the CSE maps.      RemoveNodeFromCSEMaps(User); -    // A user can appear in a use list multiple times, and when this -    // happens the uses are usually next to each other in the list. +    // The Uses array is sorted, so all the uses for a given User +    // are next to each other in the list.      // To help reduce the number of CSE recomputations, process all      // the uses of this user that we can find this way.      do {        unsigned i = Uses[UseIndex].Index; -      unsigned operandNum = Uses[UseIndex].operandNum; +      SDUse &Use = *Uses[UseIndex].Use;        ++UseIndex; -      From[i].getNode()->removeUser(operandNum, User); -      User->OperandList[operandNum].getSDValue() = To[i]; -      To[i].getNode()->addUser(operandNum, User); +      Use.set(To[i]);      } while (UseIndex != UseIndexEnd && Uses[UseIndex].User == User);      // Now that we have modified User, add it back to the CSE maps.  If it @@ -4839,7 +4822,7 @@ bool SDNode::hasNUsesOfValue(unsigned NUses, unsigned Value) const {    // TODO: Only iterate over uses of a given value of the node    for (SDNode::use_iterator UI = use_begin(), E = use_end(); UI != E; ++UI) { -    if (UI.getUse().getSDValue().getResNo() == Value) { +    if (UI.getUse().getResNo() == Value) {        if (NUses == 0)          return false;        --NUses; @@ -4857,7 +4840,7 @@ bool SDNode::hasAnyUseOfValue(unsigned Value) const {    assert(Value < getNumValues() && "Bad value!");    for (SDNode::use_iterator UI = use_begin(), E = use_end(); UI != E; ++UI) -    if (UI.getUse().getSDValue().getResNo() == Value) +    if (UI.getUse().getResNo() == Value)        return true;    return false; @@ -4890,7 +4873,7 @@ bool SDValue::isOperandOf(SDNode *N) const {  bool SDNode::isOperandOf(SDNode *N) const {    for (unsigned i = 0, e = N->NumOperands; i != e; ++i) -    if (this == N->OperandList[i].getVal()) +    if (this == N->OperandList[i].getNode())        return true;    return false;  } | 

