Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1)

Side by Side Diff: src/compiler/escape-analysis.cc

Issue 2599793002: [turbofan] fix another divergence in escape analysis (Closed)
Patch Set: Created 3 years, 12 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 the V8 project authors. All rights reserved. 1 // Copyright 2015 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "src/compiler/escape-analysis.h" 5 #include "src/compiler/escape-analysis.h"
6 6
7 #include <limits> 7 #include <limits>
8 8
9 #include "src/base/flags.h" 9 #include "src/base/flags.h"
10 #include "src/bootstrapper.h" 10 #include "src/bootstrapper.h"
(...skipping 150 matching lines...) Expand 10 before | Expand all | Expand 10 after
161 fields_.resize(field_number); 161 fields_.resize(field_number);
162 phi_.resize(field_number, false); 162 phi_.resize(field_number, false);
163 } 163 }
164 164
165 Node* GetField(size_t offset) { return fields_[offset]; } 165 Node* GetField(size_t offset) { return fields_[offset]; }
166 166
167 bool IsCreatedPhi(size_t offset) { return phi_[offset]; } 167 bool IsCreatedPhi(size_t offset) { return phi_[offset]; }
168 168
169 void SetField(size_t offset, Node* node, bool created_phi = false) { 169 void SetField(size_t offset, Node* node, bool created_phi = false) {
170 fields_[offset] = node; 170 fields_[offset] = node;
171 phi_[offset] = created_phi; 171 phi_[offset] = phi_[offset] || created_phi;
172 } 172 }
173 bool IsTracked() const { return status_ & kTracked; } 173 bool IsTracked() const { return status_ & kTracked; }
174 bool IsInitialized() const { return status_ & kInitialized; } 174 bool IsInitialized() const { return status_ & kInitialized; }
175 bool SetInitialized() { return status_ |= kInitialized; } 175 bool SetInitialized() { return status_ |= kInitialized; }
176 VirtualState* owner() const { return owner_; } 176 VirtualState* owner() const { return owner_; }
177 177
178 Node** fields_array() { return &fields_.front(); } 178 Node** fields_array() { return &fields_.front(); }
179 size_t field_count() { return fields_.size(); } 179 size_t field_count() { return fields_.size(); }
180 bool ResizeFields(size_t field_count) { 180 bool ResizeFields(size_t field_count) {
181 if (field_count > fields_.size()) { 181 if (field_count > fields_.size()) {
(...skipping 305 matching lines...) Expand 10 before | Expand all | Expand 10 after
487 for (size_t i = 0; i < field_count(); ++i) { 487 for (size_t i = 0; i < field_count(); ++i) {
488 Node* field = cache->GetFields(i); 488 Node* field = cache->GetFields(i);
489 if (field && !IsCreatedPhi(i)) { 489 if (field && !IsCreatedPhi(i)) {
490 changed = changed || GetField(i) != field; 490 changed = changed || GetField(i) != field;
491 SetField(i, field); 491 SetField(i, field);
492 TRACE(" Field %zu agree on rep #%d\n", i, field->id()); 492 TRACE(" Field %zu agree on rep #%d\n", i, field->id());
493 } else { 493 } else {
494 size_t arity = at->opcode() == IrOpcode::kEffectPhi 494 size_t arity = at->opcode() == IrOpcode::kEffectPhi
495 ? at->op()->EffectInputCount() 495 ? at->op()->EffectInputCount()
496 : at->op()->ValueInputCount(); 496 : at->op()->ValueInputCount();
497 if (cache->fields().size() == arity) { 497 if (cache->fields().size() == arity &&
498 (GetField(i) || !IsCreatedPhi(i))) {
498 changed = MergeFields(i, at, cache, graph, common) || changed; 499 changed = MergeFields(i, at, cache, graph, common) || changed;
499 } else { 500 } else {
500 if (GetField(i) != nullptr) { 501 if (GetField(i) != nullptr) {
501 TRACE(" Field %zu cleared\n", i); 502 TRACE(" Field %zu cleared\n", i);
502 changed = true; 503 changed = true;
503 } 504 }
504 SetField(i, nullptr); 505 SetField(i, nullptr);
505 } 506 }
506 } 507 }
507 } 508 }
(...skipping 1188 matching lines...) Expand 10 before | Expand all | Expand 10 after
1696 } 1697 }
1697 } 1698 }
1698 return false; 1699 return false;
1699 } 1700 }
1700 1701
1701 Graph* EscapeAnalysis::graph() const { return status_analysis_->graph(); } 1702 Graph* EscapeAnalysis::graph() const { return status_analysis_->graph(); }
1702 1703
1703 } // namespace compiler 1704 } // namespace compiler
1704 } // namespace internal 1705 } // namespace internal
1705 } // namespace v8 1706 } // namespace v8
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698