Home
last modified time | relevance | path

Searched refs:SUnit (Results 1 – 25 of 40) sorted by relevance

12

/external/llvm/include/llvm/CodeGen/
DResourcePriorityQueue.h31 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 …]
DLatencyPriorityQueue.h25 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 …]
DScheduleDAG.h28 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 …]
DMachineScheduler.h193 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 …]
DScheduleDAGInstrs.h36 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 …]
DScheduleHazardRecognizer.h20 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
DDFAPacketizer.h41 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/
DR600MachineScheduler.h54 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 …]
DR600MachineScheduler.cpp46 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/
DScheduleDAG.cpp53 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 …]
DLatencyPriorityQueue.cpp23 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 …]
DScheduleDAGInstrs.cpp252 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 …]
DScheduleDAGPrinter.cpp43 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()
DMachineScheduler.cpp499 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 …]
DPostRASchedulerList.cpp113 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/
DScheduleDAGRRList.cpp125 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 …]
DResourcePriorityQueue.cpp72 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 …]
DScheduleDAGFast.cpp49 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 …]
DScheduleDAGSDNodes.h43 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,
DScheduleDAGVLIW.cpp61 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 …]
DScheduleDAGSDNodes.cpp69 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/
DHexagonMachineScheduler.h51 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 …]
DHexagonMachineScheduler.cpp25 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 …]
DHexagonVLIWPacketizer.cpp137 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/
DPPCHazardRecognizers.h28 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;

12