|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | instruction index across each part. Instruction indices are used
to make live range queries, and live ranges can extend beyond
scheduling region boundaries.
Refactor the ScheduleDAGSDNodes class some more so that it
doesn't have to worry about this additional information.
llvm-svn: 64288 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | scheduling, and generalize is so that preserves state across
scheduling regions. This fixes incorrect live-range information around
terminators and labels, which are effective region boundaries.
In place of looking for terminators to anchor inter-block dependencies,
introduce special entry and exit scheduling units for this purpose.
llvm-svn: 64254 | 
| | 
| 
| 
| 
| 
| 
| | that previously included this header should include
SchedulerRegistry.h instead.
llvm-svn: 63937 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and into the ScheduleDAGInstrs class, so that they don't get
destructed and re-constructed for each block. This fixes a
compile-time hot spot in the post-pass scheduler.
To help facilitate this, tidy and do some minor reorganization
in the scheduler constructor functions.
llvm-svn: 62275 | 
| | 
| 
| 
| 
| 
| 
| 
| | register to a virtual register unless it requires an expensive cross class copy. That means we are only treating "expensive to copy" register dependency as physical register dependency.
Also future proof the scheduler to handle "normal" physical register dependencies. The code is not exercised yet.
llvm-svn: 62074 | 
| | 
| 
| 
| 
| 
| | code in ScheduleDAGSDNodes' BuildSchedGraph into separate functions.
llvm-svn: 61376 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | computation code. Also, avoid adding output-depenency edges when both
defs are dead, which frequently happens with EFLAGS defs.
Compute Depth and Height lazily, and always in terms of edge latency
values. For the schedulers that don't care about latency, edge latencies
are set to 1.
Eliminate Cycle and CycleBound, and LatencyPriorityQueue's Latencies array.
These are all subsumed by the Depth and Height fields.
llvm-svn: 61073 | 
| | 
| 
| 
| 
| 
| | currently used by anything.
llvm-svn: 61066 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The Cost field is removed. It was only being used in a very limited way,
to indicate when the scheduler should attempt to protect a live register,
and it isn't really needed to do that. If we ever want the scheduler to
start inserting copies in non-prohibitive situations, we'll have to
rethink some things anyway.
A Latency field is added. Instead of giving each node a single
fixed latency, each edge can have its own latency. This will eventually
be used to model various micro-architecture properties more accurately.
The PointerIntPair class and an internal union are now used, which
reduce the overall size.
llvm-svn: 60806 | 
| | 
| 
| 
| 
| 
| 
| | to removePred because an SUnit can both data-depend and anti-depend
on the same SUnit.
llvm-svn: 59969 | 
| | 
| 
| 
| | llvm-svn: 59785 | 
| | 
| 
| 
| 
| 
| | less mysterious.
llvm-svn: 59782 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | the RR scheduler actually does look at latency values, but it
doesn't use a hazard recognizer so it has no way to know when
a no-op is needed, as opposed to just stalling and incrementing
the cycle count.
llvm-svn: 59759 | 
| | 
| 
| 
| 
| 
| | and CreateClone don't add any extra value.
llvm-svn: 59679 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | is currently off by default, and can be enabled with
-disable-post-RA-scheduler=false.
This doesn't have a significant impact on most code yet because it doesn't
yet do anything to address anti-dependencies and it doesn't attempt to
disambiguate memory references. Also, several popular targets
don't have pipeline descriptions yet.
The majority of the changes here are splitting the SelectionDAG-specific
code out of ScheduleDAG, so that ScheduleDAG can be moved to
libLLVMCodeGen.a. The interface between ScheduleDAG-using code and
the rest of the scheduling code is somewhat rough and will evolve.
llvm-svn: 59676 | 
| | 
| 
| 
| 
| 
| | consistent with ScheduleNodeTopDown methods.
llvm-svn: 59550 | 
| | 
| 
| 
| 
| 
| | a SelectionDAG*.
llvm-svn: 59488 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | new CycleBound value. Instead, just update CycleBound on each call.
Also, make ReleasePred and ReleaseSucc methods more consistent accross
the various schedulers.
This also happens to make ScheduleDAGRRList's CycleBound computation
somewhat more interesting, though it still doesn't have any noticeable
effect, because no current targets that use the register-pressure
reduction scheduler provide pipeline models.
llvm-svn: 59475 | 
| | 
| 
| 
| | llvm-svn: 59461 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | to carry a SmallVector of flagged nodes, just calculate the flagged nodes
dynamically when they are needed.
The local-liveness change is due to a trivial scheduling change where
the scheduler arbitrary decision differently.
llvm-svn: 59273 | 
| | 
| 
| 
| | llvm-svn: 59264 | 
| | 
| 
| 
| 
| 
| | for the possibility of scheduling without a SelectionDAG being present.
llvm-svn: 59263 | 
| | 
| 
| 
| 
| 
| 
| | argument instead of taking the SelectionDAG's TargetMachine. This is
needed for some upcoming scheduler changes.
llvm-svn: 59055 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | instead of requiring all "short description" strings to begin with
two spaces. This makes these strings less mysterious, and it fixes
some cases where short description strings mistakenly did not
begin with two spaces.
llvm-svn: 57521 | 
| | 
| 
| 
| 
| 
| 
| | track of the number of live registers, which is all the set was
being used for.
llvm-svn: 56498 | 
|  | copy of the BURRList scheduler, but with several parts ripped
out, such as backtracking, online topological sort maintenance
(needed by backtracking), the priority queue, and Sethi-Ullman
number computation and maintenance (needed by the priority
queue). As a result of all this, it generates somewhat lower
quality code, but that's its tradeoff for running about 30%
faster than list-burr in -fast mode in many cases.
This is somewhat experimental. Moving forward, major pieces of
this can be refactored with pieces in common with
ScheduleDAGRRList.cpp.
llvm-svn: 56307 |