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)
131 for (
auto *
N : this->Nodes)
132 N->setSchedBundle(*
this);
139 for (
auto *
N : this->Nodes)
140 N->clearSchedBundle();
142 bool empty()
const {
return Nodes.empty(); }
162 return all_of(Nodes, [Dir](
const auto *
N) {
187 std::optional<BasicBlock::iterator> ScheduleTopItOpt;
193 std::optional<Context::CallbackID> CreateInstrCB;
207 void scheduleAndUpdateReadyList(
SchedBundle &Bndl);
209 enum class BndlSchedState {
213 TemporarilyScheduled,
236 CreateInstrCB = Ctx.registerCreateInstrCallback(
241 Ctx.unregisterCreateInstrCallback(*CreateInstrCB);
244 assert(Bndls.empty() && DAG.empty() && ReadyList.empty() &&
245 !ScheduleTopItOpt && ScheduledBB ==
nullptr &&
246 "We can't change the direction during scheduling!");
261 ScheduleTopItOpt = std::nullopt;
262 ScheduledBB =
nullptr;
263 assert(Bndls.empty() && DAG.empty() && ReadyList.empty() &&
264 !ScheduleTopItOpt && ScheduledBB ==
nullptr &&
265 "Expected empty state!");
282 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.
PostRA Machine Instruction Scheduler
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.
A wrapper around a string literal that serves as a proxy for constructing global tables of StringRefs...
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 ...
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.
bool ready(SchedDirection Dir) const
\Returns true if all nodes in the bundle are ready.
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)
void setDirection(SchedDirection NewDir)
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.
StringLiteral schedDirectionToStr(SchedDirection Dir)
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.