/external/llvm/include/llvm/CodeGen/ |
D | ResourcePriorityQueue.h | 31 struct resource_sort : public std::binary_function<SUnit*, SUnit*, bool> { 35 bool operator()(const SUnit* left, const SUnit* right) const; 40 std::vector<SUnit> *SUnits; 49 std::vector<SUnit*> Queue; 71 std::vector<SUnit*> Packet; 86 void initNodes(std::vector<SUnit> &sunits) override; 88 void addNode(const SUnit *SU) override { in addNode() 92 void updateNode(const SUnit *SU) override {} in updateNode() 110 signed SUSchedulingCost (SUnit *SU); 114 void initNumRegDefsLeft(SUnit *SU); [all …]
|
D | LatencyPriorityQueue.h | 25 struct latency_sort : public std::binary_function<SUnit*, SUnit*, bool> { 29 bool operator()(const SUnit* left, const SUnit* right) const; 34 std::vector<SUnit> *SUnits; 43 std::vector<SUnit*> Queue; 52 void initNodes(std::vector<SUnit> &sunits) override { in initNodes() 57 void addNode(const SUnit *SU) override { in addNode() 61 void updateNode(const SUnit *SU) override { in updateNode() 80 void push(SUnit *U) override; 82 SUnit *pop() override; 84 void remove(SUnit *SU) override; [all …]
|
D | ScheduleDAG.h | 28 class SUnit; variable 76 PointerIntPair<SUnit *, 2, Kind> Dep; 101 SDep(SUnit *S, Kind kind, unsigned Reg) in SDep() 119 SDep(SUnit *S, OrderKind kind) in SDep() 160 SUnit *getSUnit() const { in getSUnit() 165 void setSUnit(SUnit *SU) { in setSUnit() 255 class SUnit { 262 SUnit *OrigNode; // If not this, the node from which 319 SUnit(SDNode *node, unsigned nodenum) 335 SUnit(MachineInstr *instr, unsigned nodenum) [all …]
|
D | MachineScheduler.h | 193 virtual SUnit *pickNode(bool &IsTopNode) = 0; 200 virtual void schedNode(SUnit *SU, bool IsTopNode) = 0; 204 virtual void releaseTopNode(SUnit *SU) = 0; 207 virtual void releaseBottomNode(SUnit *SU) = 0; 242 const SUnit *NextClusterPred; 243 const SUnit *NextClusterSucc; 279 bool canAddEdge(SUnit *SuccSU, SUnit *PredSU); 286 bool addEdge(SUnit *SuccSU, const SDep &PredDep); 307 const SUnit *getNextClusterPred() const { return NextClusterPred; } in getNextClusterPred() 309 const SUnit *getNextClusterSucc() const { return NextClusterSucc; } in getNextClusterSucc() [all …]
|
D | ScheduleDAGInstrs.h | 36 SUnit *SU; 38 VReg2SUnit(unsigned reg, SUnit *su): VirtReg(reg), SU(su) {} in VReg2SUnit() 48 SUnit *SU; 52 PhysRegSUOper(SUnit *su, int op, unsigned R): SU(su), OpIdx(op), Reg(R) {} in PhysRegSUOper() 119 DenseMap<MachineInstr*, SUnit*> MISUnitMap; 142 std::vector<SUnit *> PendingLoads; 174 const MCSchedClassDesc *getSchedClass(SUnit *SU) const { in getSchedClass() 187 SUnit *newSUnit(MachineInstr *MI); 190 SUnit *getSUnit(MachineInstr *MI) const; 233 void dumpNode(const SUnit *SU) const override; [all …]
|
D | ScheduleHazardRecognizer.h | 20 class SUnit; variable 60 virtual HazardType getHazardType(SUnit *m, int Stalls = 0) { 71 virtual void EmitInstruction(SUnit *) {} in EmitInstruction() argument 78 virtual unsigned PreEmitNoops(SUnit *) { in PreEmitNoops() argument 85 virtual bool ShouldPreferAnother(SUnit *) { in ShouldPreferAnother() argument
|
D | DFAPacketizer.h | 41 class SUnit; variable 107 std::map<MachineInstr*, SUnit*> MIToSUnit; 154 virtual bool isLegalToPacketizeTogether(SUnit *SUI, SUnit *SUJ) { in isLegalToPacketizeTogether() 160 virtual bool isLegalToPruneDependencies(SUnit *SUI, SUnit *SUJ) { in isLegalToPruneDependencies()
|
/external/llvm/lib/Target/R600/ |
D | R600MachineScheduler.h | 54 std::vector<SUnit *> Available[IDLast], Pending[IDLast]; 55 std::vector<SUnit *> AvailableAlus[AluLast]; 56 std::vector<SUnit *> PhysicalRegCopy; 77 SUnit *pickNode(bool &IsTopNode) override; 78 void schedNode(SUnit *SU, bool IsTopNode) override; 79 void releaseTopNode(SUnit *SU) override; 80 void releaseBottomNode(SUnit *SU) override; 86 int getInstKind(SUnit *SU); 88 AluKind getAluKind(SUnit *SU) const; 91 SUnit *AttemptFillSlot (unsigned Slot, bool AnyAlu); [all …]
|
D | R600MachineScheduler.cpp | 46 void R600SchedStrategy::MoveUnits(std::vector<SUnit *> &QSrc, in MoveUnits() 47 std::vector<SUnit *> &QDst) in MoveUnits() 59 SUnit* R600SchedStrategy::pickNode(bool &IsTopNode) { in pickNode() 60 SUnit *SU = nullptr; in pickNode() 132 const SUnit &S = DAG->SUnits[i]; in pickNode() 142 void R600SchedStrategy::schedNode(SUnit *SU, bool IsTopNode) { in schedNode() 190 void R600SchedStrategy::releaseTopNode(SUnit *SU) { in releaseTopNode() 194 void R600SchedStrategy::releaseBottomNode(SUnit *SU) { in releaseBottomNode() 220 R600SchedStrategy::AluKind R600SchedStrategy::getAluKind(SUnit *SU) const { in getAluKind() 294 int R600SchedStrategy::getInstKind(SUnit* SU) { in getInstKind() [all …]
|
/external/llvm/lib/CodeGen/ |
D | ScheduleDAG.cpp | 53 EntrySU = SUnit(); in clearDAG() 54 ExitSU = SUnit(); in clearDAG() 66 bool SUnit::addPred(const SDep &D, bool Required) { in addPred() 77 SUnit *PredSU = I->getSUnit(); in addPred() 96 SUnit *N = D.getSUnit(); in addPred() 134 void SUnit::removePred(const SDep &D) { in removePred() 142 SUnit *N = D.getSUnit(); in removePred() 179 void SUnit::setDepthDirty() { in setDepthDirty() 181 SmallVector<SUnit*, 8> WorkList; in setDepthDirty() 184 SUnit *SU = WorkList.pop_back_val(); in setDepthDirty() [all …]
|
D | LatencyPriorityQueue.cpp | 23 bool latency_sort::operator()(const SUnit *LHS, const SUnit *RHS) const { in operator ()() 56 SUnit *LatencyPriorityQueue::getSingleUnscheduledPred(SUnit *SU) { in getSingleUnscheduledPred() 57 SUnit *OnlyAvailablePred = nullptr; in getSingleUnscheduledPred() 58 for (SUnit::const_pred_iterator I = SU->Preds.begin(), E = SU->Preds.end(); in getSingleUnscheduledPred() 60 SUnit &Pred = *I->getSUnit(); in getSingleUnscheduledPred() 73 void LatencyPriorityQueue::push(SUnit *SU) { in push() 77 for (SUnit::const_succ_iterator I = SU->Succs.begin(), E = SU->Succs.end(); in push() 92 void LatencyPriorityQueue::scheduledNode(SUnit *SU) { in scheduledNode() 93 for (SUnit::const_succ_iterator I = SU->Succs.begin(), E = SU->Succs.end(); in scheduledNode() 105 void LatencyPriorityQueue::AdjustPriorityOfUnscheduledPreds(SUnit *SU) { in AdjustPriorityOfUnscheduledPreds() [all …]
|
D | ScheduleDAGInstrs.cpp | 252 void ScheduleDAGInstrs::addPhysRegDataDeps(SUnit *SU, unsigned OperIdx) { in addPhysRegDataDeps() 264 SUnit *UseSU = I->SU; in addPhysRegDataDeps() 295 void ScheduleDAGInstrs::addPhysRegDeps(SUnit *SU, unsigned OperIdx) { in addPhysRegDeps() 311 SUnit *DefSU = I->SU; in addPhysRegDeps() 376 void ScheduleDAGInstrs::addVRegDefDeps(SUnit *SU, unsigned OperIdx) { in addVRegDefDeps() 397 SUnit *DefSU = DefI->SU; in addVRegDefDeps() 414 void ScheduleDAGInstrs::addVRegUseDeps(SUnit *SU, unsigned OperIdx) { in addVRegUseDeps() 438 SUnit *DefSU = getSUnit(Def); in addVRegUseDeps() 577 SUnit *SUa, SUnit *SUb, SUnit *ExitSU, unsigned *Depth, in iterateChainSucc() 578 SmallPtrSet<const SUnit*, 16> &Visited) { in iterateChainSucc() argument [all …]
|
D | ScheduleDAGPrinter.cpp | 43 static bool isNodeHidden(const SUnit *Node) { in isNodeHidden() 47 static bool hasNodeAddressLabel(const SUnit *Node, in hasNodeAddressLabel() 54 static std::string getEdgeAttributes(const SUnit *Node, in getEdgeAttributes() 65 std::string getNodeLabel(const SUnit *Node, const ScheduleDAG *Graph); 66 static std::string getNodeAttributes(const SUnit *N, in getNodeAttributes() 78 std::string DOTGraphTraits<ScheduleDAG*>::getNodeLabel(const SUnit *SU, in getNodeLabel()
|
D | MachineScheduler.cpp | 499 bool ScheduleDAGMI::canAddEdge(SUnit *SuccSU, SUnit *PredSU) { in canAddEdge() 503 bool ScheduleDAGMI::addEdge(SUnit *SuccSU, const SDep &PredDep) { in addEdge() 520 void ScheduleDAGMI::releaseSucc(SUnit *SU, SDep *SuccEdge) { in releaseSucc() 521 SUnit *SuccSU = SuccEdge->getSUnit(); in releaseSucc() 548 void ScheduleDAGMI::releaseSuccessors(SUnit *SU) { in releaseSuccessors() 549 for (SUnit::succ_iterator I = SU->Succs.begin(), E = SU->Succs.end(); in releaseSuccessors() 559 void ScheduleDAGMI::releasePred(SUnit *SU, SDep *PredEdge) { in releasePred() 560 SUnit *PredSU = PredEdge->getSUnit(); in releasePred() 587 void ScheduleDAGMI::releasePredecessors(SUnit *SU) { in releasePredecessors() 588 for (SUnit::pred_iterator I = SU->Preds.begin(), E = SU->Preds.end(); in releasePredecessors() [all …]
|
D | PostRASchedulerList.cpp | 113 std::vector<SUnit*> PendingQueue; 125 std::vector<SUnit*> Sequence; 175 void ReleaseSucc(SUnit *SU, SDep *SuccEdge); 176 void ReleaseSuccessors(SUnit *SU); 177 void ScheduleNodeTopDown(SUnit *SU, unsigned CurCycle); 240 if (SUnit *SU = Sequence[i]) in dumpSchedule() 421 void SchedulePostRATDList::ReleaseSucc(SUnit *SU, SDep *SuccEdge) { in ReleaseSucc() 422 SUnit *SuccSU = SuccEdge->getSUnit(); in ReleaseSucc() 456 void SchedulePostRATDList::ReleaseSuccessors(SUnit *SU) { in ReleaseSuccessors() 457 for (SUnit::succ_iterator I = SU->Succs.begin(), E = SU->Succs.end(); in ReleaseSuccessors() [all …]
|
/external/llvm/lib/CodeGen/SelectionDAG/ |
D | ScheduleDAGRRList.cpp | 125 std::vector<SUnit*> PendingQueue; 144 std::vector<SUnit*> LiveRegDefs; 145 std::vector<SUnit*> LiveRegGens; 149 SmallVector<SUnit*, 4> Interferences; 150 typedef DenseMap<SUnit*, SmallVector<unsigned, 4> > LRegsMapT; 159 DenseMap<SUnit*, SUnit*> CallSeqEndForStart; 187 bool IsReachable(const SUnit *SU, const SUnit *TargetSU) { in IsReachable() 193 bool WillCreateCycle(SUnit *SU, SUnit *TargetSU) { in WillCreateCycle() 200 void AddPred(SUnit *SU, const SDep &D) { in AddPred() 208 void RemovePred(SUnit *SU, const SDep &D) { in RemovePred() [all …]
|
D | ResourcePriorityQueue.cpp | 72 ResourcePriorityQueue::numberRCValPredInSU(SUnit *SU, unsigned RCId) { in numberRCValPredInSU() 74 for (SUnit::pred_iterator I = SU->Preds.begin(), E = SU->Preds.end(); in numberRCValPredInSU() 79 SUnit *PredSU = I->getSUnit(); in numberRCValPredInSU() 109 unsigned ResourcePriorityQueue::numberRCValSuccInSU(SUnit *SU, in numberRCValSuccInSU() 112 for (SUnit::const_succ_iterator I = SU->Succs.begin(), E = SU->Succs.end(); in numberRCValSuccInSU() 117 SUnit *SuccSU = I->getSUnit(); in numberRCValSuccInSU() 147 static unsigned numberCtrlDepsInSU(SUnit *SU) { in numberCtrlDepsInSU() 149 for (SUnit::const_succ_iterator I = SU->Succs.begin(), E = SU->Succs.end(); in numberCtrlDepsInSU() 157 static unsigned numberCtrlPredInSU(SUnit *SU) { in numberCtrlPredInSU() 159 for (SUnit::pred_iterator I = SU->Preds.begin(), E = SU->Preds.end(); in numberCtrlPredInSU() [all …]
|
D | ScheduleDAGFast.cpp | 49 SmallVector<SUnit *, 16> Queue; 53 void push(SUnit *U) { in push() 57 SUnit *pop() { in pop() 59 SUnit *V = Queue.back(); in pop() 77 std::vector<SUnit*> LiveRegDefs; 88 void AddPred(SUnit *SU, const SDep &D) { in AddPred() 94 void RemovePred(SUnit *SU, const SDep &D) { in RemovePred() 99 void ReleasePred(SUnit *SU, SDep *PredEdge); 100 void ReleasePredecessors(SUnit *SU, unsigned CurCycle); 101 void ScheduleNodeBottomUp(SUnit*, unsigned); [all …]
|
D | ScheduleDAGSDNodes.h | 43 std::vector<SUnit*> Sequence; 75 SUnit *newSUnit(SDNode *N); 80 SUnit *Clone(SUnit *N); 92 void InitVRegCycleFlag(SUnit *SU); 96 void InitNumRegDefsLeft(SUnit *SU); 100 virtual void computeLatency(SUnit *SU); 120 void dumpNode(const SUnit *SU) const override; 124 std::string getGraphNodeLabel(const SUnit *SU) const override; 140 RegDefIter(const SUnit *SU, const ScheduleDAGSDNodes *SD); 180 void EmitPhysRegCopy(SUnit *SU, DenseMap<SUnit*, unsigned> &VRBaseMap,
|
D | ScheduleDAGVLIW.cpp | 61 std::vector<SUnit*> PendingQueue; 88 void releaseSucc(SUnit *SU, const SDep &D); 89 void releaseSuccessors(SUnit *SU); 90 void scheduleNodeTopDown(SUnit *SU, unsigned CurCycle); 117 void ScheduleDAGVLIW::releaseSucc(SUnit *SU, const SDep &D) { in releaseSucc() 118 SUnit *SuccSU = D.getSUnit(); in releaseSucc() 141 void ScheduleDAGVLIW::releaseSuccessors(SUnit *SU) { in releaseSuccessors() 143 for (SUnit::succ_iterator I = SU->Succs.begin(), E = SU->Succs.end(); in releaseSuccessors() 155 void ScheduleDAGVLIW::scheduleNodeTopDown(SUnit *SU, unsigned CurCycle) { in scheduleNodeTopDown() 187 std::vector<SUnit*> NotReady; in listScheduleTopDown() [all …]
|
D | ScheduleDAGSDNodes.cpp | 69 SUnit *ScheduleDAGSDNodes::newSUnit(SDNode *N) { in newSUnit() 71 const SUnit *Addr = nullptr; in newSUnit() 75 SUnits.push_back(SUnit(N, (unsigned)SUnits.size())); in newSUnit() 79 SUnit *SU = &SUnits.back(); in newSUnit() 90 SUnit *ScheduleDAGSDNodes::Clone(SUnit *Old) { in Clone() 91 SUnit *SU = newSUnit(Old->getNode()); in Clone() 336 SmallVector<SUnit*, 8> CallSUnits; in BuildSchedUnits() 351 SUnit *NodeSUnit = newSUnit(NI); in BuildSchedUnits() 414 SUnit *SU = CallSUnits.pop_back_val(); in BuildSchedUnits() 421 SUnit *SrcSU = &SUnits[SrcN->getNodeId()]; in BuildSchedUnits() [all …]
|
/external/llvm/lib/Target/Hexagon/ |
D | HexagonMachineScheduler.h | 51 std::vector<SUnit*> Packet; 87 bool isResourceAvailable(SUnit *SU); 88 bool reserveResources(SUnit *SU); 115 SUnit *SU; 176 bool checkHazard(SUnit *SU); 178 void releaseNode(SUnit *SU, unsigned ReadyCycle); 182 void bumpNode(SUnit *SU); 186 void removeReady(SUnit *SU); 188 SUnit *pickOnlyChoice(); 212 virtual SUnit *pickNode(bool &IsTopNode) override; [all …]
|
D | HexagonMachineScheduler.cpp | 25 SUnit* LastSequentialCall = nullptr; in postprocessDAG() 43 bool VLIWResourceModel::isResourceAvailable(SUnit *SU) { in isResourceAvailable() 68 for (SUnit::const_succ_iterator I = Packet[i]->Succs.begin(), in isResourceAvailable() 83 bool VLIWResourceModel::reserveResources(SUnit *SU) { in reserveResources() 156 SmallVector<SUnit*, 8> TopRoots, BotRoots; in schedule() 182 while (SUnit *SU = SchedImpl->pickNode(IsTopNode)) { in schedule() 223 void ConvergingVLIWScheduler::releaseTopNode(SUnit *SU) { in releaseTopNode() 227 for (SUnit::succ_iterator I = SU->Preds.begin(), E = SU->Preds.end(); in releaseTopNode() 240 void ConvergingVLIWScheduler::releaseBottomNode(SUnit *SU) { in releaseBottomNode() 246 for (SUnit::succ_iterator I = SU->Succs.begin(), E = SU->Succs.end(); in releaseBottomNode() [all …]
|
D | HexagonVLIWPacketizer.cpp | 137 bool isLegalToPacketizeTogether(SUnit *SUI, SUnit *SUJ) override; 141 bool isLegalToPruneDependencies(SUnit *SUI, SUnit *SUJ) override; 149 bool CanPromoteToDotNew(MachineInstr* MI, SUnit* PacketSU, 151 std::map <MachineInstr*, SUnit*> MIToSUnit, 154 bool CanPromoteToNewValue(MachineInstr* MI, SUnit* PacketSU, 156 std::map <MachineInstr*, SUnit*> MIToSUnit, 160 std::map <MachineInstr*, SUnit*> MIToSUnit); 163 std::map <MachineInstr*, SUnit*> MIToSUnit); 165 unsigned, std::map <MachineInstr*, SUnit*>); 541 std::map <MachineInstr*, SUnit*> MIToSUnit) { in CanPromoteToNewValueStore() [all …]
|
/external/llvm/lib/Target/PowerPC/ |
D | PPCHazardRecognizers.h | 28 SmallVector<SUnit *, 7> CurGroup; 31 bool isLoadAfterStore(SUnit *SU); 32 bool isBCTRAfterSet(SUnit *SU); 40 HazardType getHazardType(SUnit *SU, int Stalls) override; 41 bool ShouldPreferAnother(SUnit* SU) override; 42 unsigned PreEmitNoops(SUnit *SU) override; 43 void EmitInstruction(SUnit *SU) override; 79 virtual HazardType getHazardType(SUnit *SU, int Stalls) override; 80 virtual void EmitInstruction(SUnit *SU) override;
|