Index: src/compiler/preprocess-live-ranges.cc |
diff --git a/src/compiler/preprocess-live-ranges.cc b/src/compiler/preprocess-live-ranges.cc |
deleted file mode 100644 |
index fee3a3d98c7ace09a2c0e0d8d753ac20afd5a026..0000000000000000000000000000000000000000 |
--- a/src/compiler/preprocess-live-ranges.cc |
+++ /dev/null |
@@ -1,169 +0,0 @@ |
-// Copyright 2015 the V8 project authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
- |
-#include "src/compiler/preprocess-live-ranges.h" |
-#include "src/compiler/register-allocator.h" |
- |
-namespace v8 { |
-namespace internal { |
-namespace compiler { |
- |
- |
-#define TRACE(...) \ |
- do { \ |
- if (FLAG_trace_alloc) PrintF(__VA_ARGS__); \ |
- } while (false) |
- |
- |
-namespace { |
- |
-LiveRange* Split(LiveRange* range, RegisterAllocationData* data, |
- LifetimePosition pos) { |
- DCHECK(range->Start() < pos && pos < range->End()); |
- DCHECK(pos.IsStart() || pos.IsGapPosition() || |
- (data->code() |
- ->GetInstructionBlock(pos.ToInstructionIndex()) |
- ->last_instruction_index() != pos.ToInstructionIndex())); |
- LiveRange* result = data->NewChildRangeFor(range); |
- range->SplitAt(pos, result, data->allocation_zone()); |
- TRACE("Split range %d(v%d) @%d => %d.\n", range->id(), |
- range->TopLevel()->id(), pos.ToInstructionIndex(), result->id()); |
- return result; |
-} |
- |
- |
-LifetimePosition GetSplitPositionForInstruction(const LiveRange* range, |
- int instruction_index) { |
- LifetimePosition ret = LifetimePosition::Invalid(); |
- |
- ret = LifetimePosition::GapFromInstructionIndex(instruction_index); |
- if (range->Start() >= ret || ret >= range->End()) { |
- return LifetimePosition::Invalid(); |
- } |
- return ret; |
-} |
- |
- |
-LiveRange* SplitRangeAfterBlock(LiveRange* range, RegisterAllocationData* data, |
- const InstructionBlock* block) { |
- const InstructionSequence* code = data->code(); |
- int last_index = block->last_instruction_index(); |
- int outside_index = static_cast<int>(code->instructions().size()); |
- bool has_handler = false; |
- for (auto successor_id : block->successors()) { |
- const InstructionBlock* successor = code->InstructionBlockAt(successor_id); |
- if (successor->IsHandler()) { |
- has_handler = true; |
- } |
- outside_index = Min(outside_index, successor->first_instruction_index()); |
- } |
- int split_at = has_handler ? outside_index : last_index; |
- LifetimePosition after_block = |
- GetSplitPositionForInstruction(range, split_at); |
- |
- if (after_block.IsValid()) { |
- return Split(range, data, after_block); |
- } |
- |
- return range; |
-} |
- |
- |
-int GetFirstInstructionIndex(const UseInterval* interval) { |
- int ret = interval->start().ToInstructionIndex(); |
- if (!interval->start().IsGapPosition() && !interval->start().IsStart()) { |
- ++ret; |
- } |
- return ret; |
-} |
- |
- |
-bool DoesSubsequenceClobber(const InstructionSequence* code, int start, |
- int end) { |
- for (int i = start; i <= end; ++i) { |
- if (code->InstructionAt(i)->IsCall()) return true; |
- } |
- return false; |
-} |
- |
- |
-void SplitRangeAtDeferredBlocksWithCalls(LiveRange* range, |
- RegisterAllocationData* data) { |
- DCHECK(!range->IsFixed()); |
- DCHECK(!range->spilled()); |
- if (range->TopLevel()->HasSpillOperand()) { |
- TRACE( |
- "Skipping deferred block analysis for live range %d because it has a " |
- "spill operand.\n", |
- range->TopLevel()->id()); |
- return; |
- } |
- |
- const InstructionSequence* code = data->code(); |
- LiveRange* current_subrange = range; |
- |
- UseInterval* interval = current_subrange->first_interval(); |
- |
- while (interval != nullptr) { |
- int first_index = GetFirstInstructionIndex(interval); |
- int last_index = interval->end().ToInstructionIndex(); |
- |
- if (last_index > code->LastInstructionIndex()) { |
- last_index = code->LastInstructionIndex(); |
- } |
- |
- interval = interval->next(); |
- |
- for (int index = first_index; index <= last_index;) { |
- const InstructionBlock* block = code->GetInstructionBlock(index); |
- int last_block_index = static_cast<int>(block->last_instruction_index()); |
- int last_covered_index = Min(last_index, last_block_index); |
- int working_index = index; |
- index = block->last_instruction_index() + 1; |
- |
- if (!block->IsDeferred() || |
- !DoesSubsequenceClobber(code, working_index, last_covered_index)) { |
- continue; |
- } |
- |
- TRACE("Deferred block B%d clobbers range %d(v%d).\n", |
- block->rpo_number().ToInt(), current_subrange->id(), |
- current_subrange->TopLevel()->id()); |
- LifetimePosition block_start = |
- GetSplitPositionForInstruction(current_subrange, working_index); |
- LiveRange* block_and_after = nullptr; |
- if (block_start.IsValid()) { |
- block_and_after = Split(current_subrange, data, block_start); |
- } else { |
- block_and_after = current_subrange; |
- } |
- LiveRange* next = SplitRangeAfterBlock(block_and_after, data, block); |
- if (next != current_subrange) interval = next->first_interval(); |
- current_subrange = next; |
- break; |
- } |
- } |
-} |
-} |
- |
- |
-void PreprocessLiveRanges::PreprocessRanges() { |
- SplitRangesAroundDeferredBlocks(); |
-} |
- |
- |
-void PreprocessLiveRanges::SplitRangesAroundDeferredBlocks() { |
- size_t live_range_count = data()->live_ranges().size(); |
- for (size_t i = 0; i < live_range_count; i++) { |
- LiveRange* range = data()->live_ranges()[i]; |
- if (range != nullptr && !range->IsEmpty() && !range->spilled() && |
- !range->IsFixed() && !range->IsChild()) { |
- SplitRangeAtDeferredBlocksWithCalls(range, data()); |
- } |
- } |
-} |
- |
-} // namespace compiler |
-} // namespace internal |
-} // namespace v8 |