21#ifndef LLVM_TRANSFORMS_VECTORIZE_SANDBOXVECTORIZER_SCHEDULER_H
22#define LLVM_TRANSFORMS_VECTORIZE_SANDBOXVECTORIZER_SCHEDULER_H
39 bool IsTerm1 = I1->isTerminator();
40 bool IsTerm2 = I2->isTerminator();
41 if (IsTerm1 != IsTerm2)
43 return IsTerm1 > IsTerm2;
48 return IsPHI1 < IsPHI2;
50 return I2->comesBefore(I1);
61 std::priority_queue<DGNode *, std::vector<DGNode *>,
PriorityCmp> List;
67 assert(!
N->scheduled() &&
"Don't insert a scheduled node!");
69 while (!ListCopy.empty()) {
70 DGNode *Top = ListCopy.top();
72 assert(Top !=
N &&
"Node already exists in ready list!");
78 auto *Back = List.top();
82 bool empty()
const {
return List.empty(); }
89 Keep.reserve(List.size());
90 while (!List.empty()) {
91 auto *Top = List.top();
97 for (
auto *KeepN :
Keep)
123 for (
auto *
N : this->Nodes)
124 N->setSchedBundle(*
this);
131 for (
auto *
N : this->Nodes)
132 N->clearSchedBundle();
134 bool empty()
const {
return Nodes.empty(); }
154 return all_of(Nodes, [](
const auto *
N) {
return N->ready(); });
176 std::optional<BasicBlock::iterator> ScheduleTopItOpt;
182 std::optional<Context::CallbackID> CreateInstrCB;
196 void scheduleAndUpdateReadyList(
SchedBundle &Bndl);
198 enum class BndlSchedState {
202 TemporarilyScheduled,
222 CreateInstrCB = Ctx.registerCreateInstrCallback(
227 Ctx.unregisterCreateInstrCallback(*CreateInstrCB);
241 ScheduleTopItOpt = std::nullopt;
242 ScheduledBB =
nullptr;
243 assert(Bndls.empty() && DAG.empty() && ReadyList.empty() &&
244 !ScheduleTopItOpt && ScheduledBB ==
nullptr &&
245 "Expected empty state!");
262 return Sched.getBndlSchedState(Instrs);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
Machine Instruction Scheduler
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
InstListType::iterator iterator
Instruction iterators...
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
This class implements an extremely fast bulk output stream that can only output to a stream.
A DependencyGraph Node that points to an Instruction and contains memory dependency edges.
void setSchedBundle(SchedBundle &SB)
Instruction * getInstruction() const
A sandboxir::User with operands, opcode and linked with previous/next instructions in an instruction ...
bool operator()(const DGNode *N1, const DGNode *N2)
The list holding nodes that are ready to schedule. Used by the scheduler.
LLVM_DUMP_METHOD void dump() const
void remove(DGNode *N)
\Removes N if found in the ready list.
The nodes that need to be scheduled back-to-back in a single scheduling cycle form a SchedBundle.
LLVM_ABI DGNode * getBot() const
\Returns the bundle node that comes after the others in program order.
SchedBundle(ContainerTy &&Nodes)
SchedBundle & operator=(const SchedBundle &Other)=delete
Copy Assignment (unimplemented).
LLVM_ABI DGNode * getTop() const
\Returns the bundle node that comes before the others in program order.
bool isSingleton() const
Singleton bundles are created when scheduling instructions temporarily to fill in the schedule until ...
bool ready() const
\Returns true if all nodes in the bundle are ready.
SmallVector< DGNode *, 4 > ContainerTy
const_iterator begin() const
LLVM_DUMP_METHOD void dump() const
SchedBundle(const SchedBundle &Other)=delete
Copy CTOR (unimplemented).
ContainerTy::iterator iterator
const_iterator end() const
ContainerTy::const_iterator const_iterator
LLVM_ABI void cluster(BasicBlock::iterator Where)
Move all bundle instructions to Where back-to-back.
A client-attorney class for accessing the Scheduler's internals (used for unit tests).
static BndlSchedState getBndlSchedState(const Scheduler &Sched, ArrayRef< Instruction * > Instrs)
Scheduler::BndlSchedState BndlSchedState
static DependencyGraph & getDAG(Scheduler &Sched)
friend class SchedulerInternalsAttorney
LLVM_DUMP_METHOD void dump() const
LLVM_ABI bool trySchedule(ArrayRef< Instruction * > Instrs)
Tries to build a schedule that includes all of Instrs scheduled at the same scheduling cycle.
void clear()
Clear the scheduler's state, including the DAG.
Scheduler(AAResults &AA, Context &Ctx)
Abstract Attribute helper functions.
BasicBlock(llvm::BasicBlock *BB, Context &SBCtx)
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
void erase(Container &C, ValueType V)
Wrapper function to remove a value from a container:
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
@ Keep
No function return thunk.
Implement std::hash so that hash_code can be used in STL containers.