diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2007-11-09 01:27:11 +0000 | 
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2007-11-09 01:27:11 +0000 | 
| commit | 1bf166312b1def41e00be550986a2c038ce228ff (patch) | |
| tree | 9b97d2fcdd94d0b8f4459238240fb96b377a0041 /llvm/lib | |
| parent | 0e7937654c7a17412ce751522d32a2234bd483b5 (diff) | |
| download | bcm5719-llvm-1bf166312b1def41e00be550986a2c038ce228ff.tar.gz bcm5719-llvm-1bf166312b1def41e00be550986a2c038ce228ff.zip | |
Bug fix. Passive nodes are not in SUnitMap.
llvm-svn: 43922
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 18 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp | 9 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp | 7 | 
3 files changed, 20 insertions, 14 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 6e58631f0c1..0731299f359 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -1599,21 +1599,17 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {        case 8: LD = DAG.getLoad(MVT::i64, Chain, Addr, NULL, 0); break;        } +      Addr = LD;        if (TLI.getTargetMachine().getRelocationModel() == Reloc::PIC_) {          // For PIC, the sequence is:          // BRIND(load(Jumptable + index) + RelocBase) -        // RelocBase is the JumpTable on PPC and X86, GOT on Alpha -        SDOperand Reloc; -        if (TLI.usesGlobalOffsetTable()) -          Reloc = DAG.getNode(ISD::GLOBAL_OFFSET_TABLE, PTy); -        else -          Reloc = Table; -        Addr = (PTy != MVT::i32) ? DAG.getNode(ISD::SIGN_EXTEND, PTy, LD) : LD; -        Addr = DAG.getNode(ISD::ADD, PTy, Addr, Reloc); -        Result = DAG.getNode(ISD::BRIND, MVT::Other, LD.getValue(1), Addr); -      } else { -        Result = DAG.getNode(ISD::BRIND, MVT::Other, LD.getValue(1), LD); +        // RelocBase can be JumpTable, GOT or some sort of global base. +        if (PTy != MVT::i32) +          Addr = DAG.getNode(ISD::SIGN_EXTEND, PTy, Addr); +        Addr = DAG.getNode(ISD::ADD, PTy, Addr, +                           TLI.getPICJumpTableRelocBase(Table, DAG));        } +      Result = DAG.getNode(ISD::BRIND, MVT::Other, LD.getValue(1), Addr);      }      }      break; diff --git a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp index 9c03b4e5b0f..1846bc96b75 100644 --- a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp @@ -156,7 +156,7 @@ void ScheduleDAGRRList::CommuteNodesToReducePressure() {            continue;          SDNode *OpN = SU->Node->getOperand(j).Val; -        SUnit *OpSU = SUnitMap[OpN][SU->InstanceNo]; +        SUnit *OpSU = isPassiveNode(OpN) ? NULL : SUnitMap[OpN][SU->InstanceNo];          if (OpSU && OperandSeen.count(OpSU) == 1) {            // Ok, so SU is not the last use of OpSU, but SU is two-address so            // it will clobber OpSU. Try to commute SU if no other source operands @@ -165,7 +165,7 @@ void ScheduleDAGRRList::CommuteNodesToReducePressure() {            for (unsigned k = 0; k < NumOps; ++k) {              if (k != j) {                OpN = SU->Node->getOperand(k).Val; -              OpSU = SUnitMap[OpN][SU->InstanceNo]; +              OpSU = isPassiveNode(OpN) ? NULL : SUnitMap[OpN][SU->InstanceNo];                if (OpSU && OperandSeen.count(OpSU) == 1) {                  DoCommute = false;                  break; @@ -1252,7 +1252,8 @@ bool BURegReductionPriorityQueue<SF>::canClobber(SUnit *SU, SUnit *Op) {      for (unsigned i = 0; i != NumOps; ++i) {        if (TII->getOperandConstraint(Opc, i+NumRes, TOI::TIED_TO) != -1) {          SDNode *DU = SU->Node->getOperand(i).Val; -        if (Op == (*SUnitMap)[DU][SU->InstanceNo]) +        if ((*SUnitMap).find(DU) != (*SUnitMap).end() && +            Op == (*SUnitMap)[DU][SU->InstanceNo])            return true;        }      } @@ -1298,6 +1299,8 @@ void BURegReductionPriorityQueue<SF>::AddPseudoTwoAddrDeps() {      for (unsigned j = 0; j != NumOps; ++j) {        if (TII->getOperandConstraint(Opc, j+NumRes, TOI::TIED_TO) != -1) {          SDNode *DU = SU->Node->getOperand(j).Val; +        if ((*SUnitMap).find(DU) == (*SUnitMap).end()) +          continue;          SUnit *DUSU = (*SUnitMap)[DU][SU->InstanceNo];          if (!DUSU) continue;          for (SUnit::succ_iterator I = DUSU->Succs.begin(),E = DUSU->Succs.end(); diff --git a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp index 3708b1cb9a7..eadfa1fbb29 100644 --- a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp @@ -393,6 +393,13 @@ unsigned TargetLowering::getVectorTypeBreakdown(MVT::ValueType VT,    return 1;  } +SDOperand TargetLowering::getPICJumpTableRelocBase(SDOperand Table, +                                                   SelectionDAG &DAG) const { +  if (usesGlobalOffsetTable()) +    return DAG.getNode(ISD::GLOBAL_OFFSET_TABLE, getPointerTy()); +  return Table; +} +  //===----------------------------------------------------------------------===//  //  Optimization Methods  //===----------------------------------------------------------------------===// | 

