Commit 67d8b0c8 authored by Leszek Swirski's avatar Leszek Swirski Committed by Commit Bot

[turbofan] Remove OSR special case in loop assignment analysis

Now that OSR is done during graph building, we no longer have to
special-case OSR loops in the loop assignment analysis, as we no longer
have the restriction that registers are 'assigned' an OSRValue inside
the loop.

Bug: v8:6518
Change-Id: Ib4fa139091d77efa16246ddc6e63a10cbb877ee4
Reviewed-on: https://chromium-review.googlesource.com/615167Reviewed-by: 's avatarJaroslav Sevcik <jarin@chromium.org>
Commit-Queue: Leszek Swirski <leszeks@chromium.org>
Cr-Commit-Position: refs/heads/master@{#47367}
parent c3cf3d06
...@@ -42,7 +42,6 @@ void BytecodeLoopAssignments::AddList(interpreter::Register r, uint32_t count) { ...@@ -42,7 +42,6 @@ void BytecodeLoopAssignments::AddList(interpreter::Register r, uint32_t count) {
} }
} }
void BytecodeLoopAssignments::AddAll() { bit_vector_->AddAll(); }
void BytecodeLoopAssignments::Union(const BytecodeLoopAssignments& other) { void BytecodeLoopAssignments::Union(const BytecodeLoopAssignments& other) {
bit_vector_->Union(*other.bit_vector_); bit_vector_->Union(*other.bit_vector_);
...@@ -281,9 +280,6 @@ void BytecodeAnalysis::Analyze(BailoutId osr_bailout_id) { ...@@ -281,9 +280,6 @@ void BytecodeAnalysis::Analyze(BailoutId osr_bailout_id) {
if (is_osr_loop) { if (is_osr_loop) {
osr_entry_point_ = loop_header; osr_entry_point_ = loop_header;
// OSR "assigns" everything to OSR values on entry into an OSR loop, so
// we need to make sure to considered everything to be assigned.
loop_stack_.top().loop_info->assignments().AddAll();
} }
// Save the index so that we can do another pass later. // Save the index so that we can do another pass later.
......
...@@ -26,7 +26,6 @@ class V8_EXPORT_PRIVATE BytecodeLoopAssignments { ...@@ -26,7 +26,6 @@ class V8_EXPORT_PRIVATE BytecodeLoopAssignments {
void Add(interpreter::Register r); void Add(interpreter::Register r);
void AddList(interpreter::Register r, uint32_t count); void AddList(interpreter::Register r, uint32_t count);
void AddAll();
void Union(const BytecodeLoopAssignments& other); void Union(const BytecodeLoopAssignments& other);
bool ContainsParameter(int index) const; bool ContainsParameter(int index) const;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment