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

Side by Side Diff: test/cctest/compiler/test-osr.cc

Issue 930003003: [turbofan] Transfer types from loop phis to OSR values. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 5 years, 10 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
« src/compiler/osr.cc ('K') | « src/compiler/typer.cc ('k') | 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/codegen.h" 5 #include "src/codegen.h"
6 #include "src/compiler/common-operator.h" 6 #include "src/compiler/common-operator.h"
7 #include "src/compiler/diamond.h" 7 #include "src/compiler/diamond.h"
8 #include "src/compiler/graph.h" 8 #include "src/compiler/graph.h"
9 #include "src/compiler/js-graph.h" 9 #include "src/compiler/js-graph.h"
10 #include "src/compiler/js-operator.h" 10 #include "src/compiler/js-operator.h"
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after
141 141
142 OsrHelper helper(0, 0); 142 OsrHelper helper(0, 0);
143 helper.Deconstruct(&T.jsgraph, &T.common, T.main_zone()); 143 helper.Deconstruct(&T.jsgraph, &T.common, T.main_zone());
144 144
145 CheckInputs(loop, T.start, loop); 145 CheckInputs(loop, T.start, loop);
146 CheckInputs(osr_phi, T.osr_values[0], T.jsgraph.ZeroConstant(), loop); 146 CheckInputs(osr_phi, T.osr_values[0], T.jsgraph.ZeroConstant(), loop);
147 CheckInputs(ret, osr_phi, T.start, loop); 147 CheckInputs(ret, osr_phi, T.start, loop);
148 } 148 }
149 149
150 150
151 TEST(Deconstruct_osr1_type) {
152 OsrDeconstructorTester T(1);
153
154 Node* loop = T.NewOsrLoop(1);
155 Node* osr_phi =
156 T.NewOsrPhi(loop, T.jsgraph.OneConstant(), 0, T.jsgraph.ZeroConstant());
157 Type* type = Type::Signed32();
158 NodeProperties::SetBounds(osr_phi, Bounds(type, type));
159
160 Node* ret = T.graph.NewNode(T.common.Return(), osr_phi, T.start, loop);
161 T.graph.SetEnd(ret);
162
163 OsrHelper helper(0, 0);
164 helper.Deconstruct(&T.jsgraph, &T.common, T.main_zone());
165
166 CHECK_EQ(type, NodeProperties::GetBounds(T.osr_values[0]).lower);
167 CHECK_EQ(type, NodeProperties::GetBounds(T.osr_values[0]).upper);
168
169 CheckInputs(loop, T.start, loop);
170 CheckInputs(osr_phi, T.osr_values[0], T.jsgraph.ZeroConstant(), loop);
171 CheckInputs(ret, osr_phi, T.start, loop);
172 }
173
174
151 TEST(Deconstruct_osr_remove_prologue) { 175 TEST(Deconstruct_osr_remove_prologue) {
152 OsrDeconstructorTester T(1); 176 OsrDeconstructorTester T(1);
153 Diamond d(&T.graph, &T.common, T.p0); 177 Diamond d(&T.graph, &T.common, T.p0);
154 d.Chain(T.osr_normal_entry); 178 d.Chain(T.osr_normal_entry);
155 179
156 Node* loop = T.NewOsrLoop(1, d.merge); 180 Node* loop = T.NewOsrLoop(1, d.merge);
157 Node* osr_phi = 181 Node* osr_phi =
158 T.NewOsrPhi(loop, T.jsgraph.OneConstant(), 0, T.jsgraph.ZeroConstant()); 182 T.NewOsrPhi(loop, T.jsgraph.OneConstant(), 0, T.jsgraph.ZeroConstant());
159 183
160 Node* ret = T.graph.NewNode(T.common.Return(), osr_phi, T.start, loop); 184 Node* ret = T.graph.NewNode(T.common.Return(), osr_phi, T.start, loop);
(...skipping 287 matching lines...) Expand 10 before | Expand all | Expand 10 after
448 472
449 // Check structure of inner loop. 473 // Check structure of inner loop.
450 Node* new_inner_loop = FindSuccessor(new_outer_if_true, IrOpcode::kLoop); 474 Node* new_inner_loop = FindSuccessor(new_outer_if_true, IrOpcode::kLoop);
451 Node* new_inner_phi = FindSuccessor(new_inner_loop, IrOpcode::kPhi); 475 Node* new_inner_phi = FindSuccessor(new_inner_loop, IrOpcode::kPhi);
452 476
453 CheckInputs(new_inner_phi, T.jsgraph.OneConstant(), T.jsgraph.ZeroConstant(), 477 CheckInputs(new_inner_phi, T.jsgraph.OneConstant(), T.jsgraph.ZeroConstant(),
454 new_inner_loop); 478 new_inner_loop);
455 CheckInputs(new_outer_phi, new_entry_phi, new_inner_phi, 479 CheckInputs(new_outer_phi, new_entry_phi, new_inner_phi,
456 T.jsgraph.ZeroConstant(), new_outer_loop); 480 T.jsgraph.ZeroConstant(), new_outer_loop);
457 } 481 }
OLDNEW
« src/compiler/osr.cc ('K') | « src/compiler/typer.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698