|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The height on an instruction is the minimum number of cycles from the
instruction is issued to the end of the trace. Heights are computed for
all instructions in and below the trace center block.
The method for computing heights is different from the depth
computation. As we visit instructions in the trace bottom-up, heights of
used instructions are pushed upwards. This way, we avoid scanning long
use lists, looking for uses in the current trace.
At each basic block boundary, a list of live-in registers and their
minimum heights is saved in the trace block info. These live-in lists
are used when restarting depth computations on a trace that
converges with an already computed trace. They will also be used to
accurately compute the critical path length.
llvm-svn: 161138 | 
| | 
| 
| 
| | llvm-svn: 161115 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Assuming infinite issue width, compute the earliest each instruction in
the trace can issue, when considering the latency of data dependencies.
The issue cycle is record as a 'depth' from the beginning of the trace.
This is half the computation required to find the length of the critical
path through the trace. Heights are next.
llvm-svn: 161074 | 
| | 
| 
| 
| | llvm-svn: 161072 | 
| | 
| 
| 
| | llvm-svn: 161004 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This lets traces include the final iteration of a nested loop above the
center block, and the first iteration of a nested loop below the center
block.
We still don't allow traces to contain backedges, and traces are
truncated where they would leave a loop, as seen from the center block.
llvm-svn: 161003 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | When computing a trace, all the candidates for pred/succ must have been
visited. Filter out back-edges first, though. The PO traversal ignores
them.
Thanks to Andy for spotting this in review.
llvm-svn: 160995 | 
| | 
| 
| 
| 
| 
| 
| | By overriding Pass::verifyAnalysis(), the pass contents will be verified
by the pass manager.
llvm-svn: 160994 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is a cleaned up version of the isFree() function in
MachineTraceMetrics.cpp.
Transient instructions are very unlikely to produce any code in the
final output. Either because they get eliminated by RegisterCoalescing,
or because they are pseudo-instructions like labels and debug values.
llvm-svn: 160977 | 
| | 
| 
| 
| 
| 
| 
| | This function verifies the consistency of cached data in the
MachineTraceMetrics analysis.
llvm-svn: 160976 | 
| | 
| 
| 
| 
| 
| 
| | The MachineTraceMetrics analysis must be invalidated before modifying
the CFG. This will catch some of the violations of that rule.
llvm-svn: 160969 | 
| | 
| 
| 
| | llvm-svn: 160905 | 
| | 
| 
| 
| 
| 
| 
| | This makes it possible to quickly detect blocks that are outside the
trace.
llvm-svn: 160904 | 
| | 
| 
| 
| | llvm-svn: 160798 | 
|  | This is still a work in progress.
Out-of-order CPUs usually execute instructions from multiple basic
blocks simultaneously, so it is necessary to look at longer traces when
estimating the performance effects of code transformations.
The MachineTraceMetrics analysis will pick a typical trace through a
given basic block and provide performance metrics for the trace. Metrics
will include:
- Instruction count through the trace.
- Issue count per functional unit.
- Critical path length, and per-instruction 'slack'.
These metrics can be used to determine the performance limiting factor
when executing the trace, and how it will be affected by a code
transformation.
Initially, this will be used by the early if-conversion pass.
llvm-svn: 160796 |