mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-17 06:33:21 +00:00
Remove the -compact-regions flag.
It has been enabled by default for a while, it was only there to allow performance comparisons. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@139501 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
708d06f7fb
commit
a16a25ddea
@ -51,8 +51,6 @@ STATISTIC(NumGlobalSplits, "Number of split global live ranges");
|
|||||||
STATISTIC(NumLocalSplits, "Number of split local live ranges");
|
STATISTIC(NumLocalSplits, "Number of split local live ranges");
|
||||||
STATISTIC(NumEvicted, "Number of interferences evicted");
|
STATISTIC(NumEvicted, "Number of interferences evicted");
|
||||||
|
|
||||||
static cl::opt<bool> CompactRegions("compact-regions", cl::init(true));
|
|
||||||
|
|
||||||
static cl::opt<SplitEditor::ComplementSpillMode>
|
static cl::opt<SplitEditor::ComplementSpillMode>
|
||||||
SplitSpillMode("split-spill-mode", cl::Hidden,
|
SplitSpillMode("split-spill-mode", cl::Hidden,
|
||||||
cl::desc("Spill mode for splitting live ranges"),
|
cl::desc("Spill mode for splitting live ranges"),
|
||||||
@ -410,15 +408,11 @@ void RAGreedy::enqueue(LiveInterval *LI) {
|
|||||||
|
|
||||||
if (ExtraRegInfo[Reg].Stage == RS_Split) {
|
if (ExtraRegInfo[Reg].Stage == RS_Split) {
|
||||||
// Unsplit ranges that couldn't be allocated immediately are deferred until
|
// Unsplit ranges that couldn't be allocated immediately are deferred until
|
||||||
// everything else has been allocated. Long ranges are allocated last so
|
// everything else has been allocated.
|
||||||
// they are split against realistic interference.
|
Prio = Size;
|
||||||
if (CompactRegions)
|
|
||||||
Prio = Size;
|
|
||||||
else
|
|
||||||
Prio = (1u << 31) - Size;
|
|
||||||
} else {
|
} else {
|
||||||
// Everything else is allocated in long->short order. Long ranges that don't
|
// Everything is allocated in long->short order. Long ranges that don't fit
|
||||||
// fit should be spilled ASAP so they don't create interference.
|
// should be spilled (or split) ASAP so they don't create interference.
|
||||||
Prio = (1u << 31) + Size;
|
Prio = (1u << 31) + Size;
|
||||||
|
|
||||||
// Boost ranges that have a physical register hint.
|
// Boost ranges that have a physical register hint.
|
||||||
@ -1092,7 +1086,7 @@ unsigned RAGreedy::tryRegionSplit(LiveInterval &VirtReg, AllocationOrder &Order,
|
|||||||
SmallVector<unsigned, 8> UsedCands;
|
SmallVector<unsigned, 8> UsedCands;
|
||||||
|
|
||||||
// Check if we can split this live range around a compact region.
|
// Check if we can split this live range around a compact region.
|
||||||
bool HasCompact = CompactRegions && calcCompactRegion(GlobalCand.front());
|
bool HasCompact = calcCompactRegion(GlobalCand.front());
|
||||||
if (HasCompact) {
|
if (HasCompact) {
|
||||||
// Yes, keep GlobalCand[0] as the compact region candidate.
|
// Yes, keep GlobalCand[0] as the compact region candidate.
|
||||||
NumCands = 1;
|
NumCands = 1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user