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

Side by Side Diff: src/compiler/ast-graph-builder.cc

Issue 2126233002: Devirtualize AstNode and subclasses, except for visiting-related methods. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: And call again Created 4 years, 5 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
OLDNEW
1 // Copyright 2014 the V8 project authors. All rights reserved. 1 // Copyright 2014 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/ast-graph-builder.h" 5 #include "src/compiler/ast-graph-builder.h"
6 6
7 #include "src/ast/scopes.h" 7 #include "src/ast/scopes.h"
8 #include "src/compiler.h" 8 #include "src/compiler.h"
9 #include "src/compiler/ast-loop-assignment-analyzer.h" 9 #include "src/compiler/ast-loop-assignment-analyzer.h"
10 #include "src/compiler/control-builders.h" 10 #include "src/compiler/control-builders.h"
(...skipping 1317 matching lines...) Expand 10 before | Expand all | Expand 10 after
1328 compare_switch.EndCase(); 1328 compare_switch.EndCase();
1329 } 1329 }
1330 1330
1331 compare_switch.EndSwitch(); 1331 compare_switch.EndSwitch();
1332 } 1332 }
1333 1333
1334 1334
1335 void AstGraphBuilder::VisitDoWhileStatement(DoWhileStatement* stmt) { 1335 void AstGraphBuilder::VisitDoWhileStatement(DoWhileStatement* stmt) {
1336 LoopBuilder while_loop(this); 1336 LoopBuilder while_loop(this);
1337 while_loop.BeginLoop(GetVariablesAssignedInLoop(stmt), CheckOsrEntry(stmt)); 1337 while_loop.BeginLoop(GetVariablesAssignedInLoop(stmt), CheckOsrEntry(stmt));
1338 VisitIterationBody(stmt, &while_loop); 1338 VisitIterationBody(stmt, &while_loop, stmt->StackCheckId());
1339 while_loop.EndBody(); 1339 while_loop.EndBody();
1340 VisitForTest(stmt->cond()); 1340 VisitForTest(stmt->cond());
1341 Node* condition = environment()->Pop(); 1341 Node* condition = environment()->Pop();
1342 while_loop.BreakUnless(condition); 1342 while_loop.BreakUnless(condition);
1343 while_loop.EndLoop(); 1343 while_loop.EndLoop();
1344 } 1344 }
1345 1345
1346 1346
1347 void AstGraphBuilder::VisitWhileStatement(WhileStatement* stmt) { 1347 void AstGraphBuilder::VisitWhileStatement(WhileStatement* stmt) {
1348 LoopBuilder while_loop(this); 1348 LoopBuilder while_loop(this);
1349 while_loop.BeginLoop(GetVariablesAssignedInLoop(stmt), CheckOsrEntry(stmt)); 1349 while_loop.BeginLoop(GetVariablesAssignedInLoop(stmt), CheckOsrEntry(stmt));
1350 VisitForTest(stmt->cond()); 1350 VisitForTest(stmt->cond());
1351 Node* condition = environment()->Pop(); 1351 Node* condition = environment()->Pop();
1352 while_loop.BreakUnless(condition); 1352 while_loop.BreakUnless(condition);
1353 VisitIterationBody(stmt, &while_loop); 1353 VisitIterationBody(stmt, &while_loop, stmt->StackCheckId());
1354 while_loop.EndBody(); 1354 while_loop.EndBody();
1355 while_loop.EndLoop(); 1355 while_loop.EndLoop();
1356 } 1356 }
1357 1357
1358 1358
1359 void AstGraphBuilder::VisitForStatement(ForStatement* stmt) { 1359 void AstGraphBuilder::VisitForStatement(ForStatement* stmt) {
1360 LoopBuilder for_loop(this); 1360 LoopBuilder for_loop(this);
1361 VisitIfNotNull(stmt->init()); 1361 VisitIfNotNull(stmt->init());
1362 for_loop.BeginLoop(GetVariablesAssignedInLoop(stmt), CheckOsrEntry(stmt)); 1362 for_loop.BeginLoop(GetVariablesAssignedInLoop(stmt), CheckOsrEntry(stmt));
1363 if (stmt->cond() != nullptr) { 1363 if (stmt->cond() != nullptr) {
1364 VisitForTest(stmt->cond()); 1364 VisitForTest(stmt->cond());
1365 Node* condition = environment()->Pop(); 1365 Node* condition = environment()->Pop();
1366 for_loop.BreakUnless(condition); 1366 for_loop.BreakUnless(condition);
1367 } else { 1367 } else {
1368 for_loop.BreakUnless(jsgraph()->TrueConstant()); 1368 for_loop.BreakUnless(jsgraph()->TrueConstant());
1369 } 1369 }
1370 VisitIterationBody(stmt, &for_loop); 1370 VisitIterationBody(stmt, &for_loop, stmt->StackCheckId());
1371 for_loop.EndBody(); 1371 for_loop.EndBody();
1372 VisitIfNotNull(stmt->next()); 1372 VisitIfNotNull(stmt->next());
1373 for_loop.EndLoop(); 1373 for_loop.EndLoop();
1374 } 1374 }
1375 1375
1376 1376
1377 void AstGraphBuilder::VisitForInStatement(ForInStatement* stmt) { 1377 void AstGraphBuilder::VisitForInStatement(ForInStatement* stmt) {
1378 VisitForValue(stmt->subject()); 1378 VisitForValue(stmt->subject());
1379 Node* object = environment()->Pop(); 1379 Node* object = environment()->Pop();
1380 BlockBuilder for_block(this); 1380 BlockBuilder for_block(this);
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
1437 test_value.Else(); 1437 test_value.Else();
1438 { 1438 {
1439 environment()->Push(value); 1439 environment()->Push(value);
1440 PrepareEagerCheckpoint(stmt->FilterId()); 1440 PrepareEagerCheckpoint(stmt->FilterId());
1441 value = environment()->Pop(); 1441 value = environment()->Pop();
1442 // Bind value and do loop body. 1442 // Bind value and do loop body.
1443 VectorSlotPair feedback = 1443 VectorSlotPair feedback =
1444 CreateVectorSlotPair(stmt->EachFeedbackSlot()); 1444 CreateVectorSlotPair(stmt->EachFeedbackSlot());
1445 VisitForInAssignment(stmt->each(), value, feedback, 1445 VisitForInAssignment(stmt->each(), value, feedback,
1446 stmt->AssignmentId()); 1446 stmt->AssignmentId());
1447 VisitIterationBody(stmt, &for_loop); 1447 VisitIterationBody(stmt, &for_loop, stmt->StackCheckId());
1448 } 1448 }
1449 test_value.End(); 1449 test_value.End();
1450 for_loop.EndBody(); 1450 for_loop.EndBody();
1451 1451
1452 // Increment counter and continue. 1452 // Increment counter and continue.
1453 index = environment()->Peek(0); 1453 index = environment()->Peek(0);
1454 index = NewNode(javascript()->ForInStep(), index); 1454 index = NewNode(javascript()->ForInStep(), index);
1455 environment()->Poke(0, index); 1455 environment()->Poke(0, index);
1456 } 1456 }
1457 for_loop.EndLoop(); 1457 for_loop.EndLoop();
1458 environment()->Drop(5); 1458 environment()->Drop(5);
1459 } 1459 }
1460 for_block.EndBlock(); 1460 for_block.EndBlock();
1461 } 1461 }
1462 1462
1463 1463
1464 void AstGraphBuilder::VisitForOfStatement(ForOfStatement* stmt) { 1464 void AstGraphBuilder::VisitForOfStatement(ForOfStatement* stmt) {
1465 LoopBuilder for_loop(this); 1465 LoopBuilder for_loop(this);
1466 VisitForEffect(stmt->assign_iterator()); 1466 VisitForEffect(stmt->assign_iterator());
1467 for_loop.BeginLoop(GetVariablesAssignedInLoop(stmt), CheckOsrEntry(stmt)); 1467 for_loop.BeginLoop(GetVariablesAssignedInLoop(stmt), CheckOsrEntry(stmt));
1468 VisitForEffect(stmt->next_result()); 1468 VisitForEffect(stmt->next_result());
1469 VisitForTest(stmt->result_done()); 1469 VisitForTest(stmt->result_done());
1470 Node* condition = environment()->Pop(); 1470 Node* condition = environment()->Pop();
1471 for_loop.BreakWhen(condition); 1471 for_loop.BreakWhen(condition);
1472 VisitForEffect(stmt->assign_each()); 1472 VisitForEffect(stmt->assign_each());
1473 VisitIterationBody(stmt, &for_loop); 1473 VisitIterationBody(stmt, &for_loop, stmt->StackCheckId());
1474 for_loop.EndBody(); 1474 for_loop.EndBody();
1475 for_loop.EndLoop(); 1475 for_loop.EndLoop();
1476 } 1476 }
1477 1477
1478 1478
1479 void AstGraphBuilder::VisitTryCatchStatement(TryCatchStatement* stmt) { 1479 void AstGraphBuilder::VisitTryCatchStatement(TryCatchStatement* stmt) {
1480 TryCatchBuilder try_control(this); 1480 TryCatchBuilder try_control(this);
1481 1481
1482 // Evaluate the try-block inside a control scope. This simulates a handler 1482 // Evaluate the try-block inside a control scope. This simulates a handler
1483 // that is intercepting 'throw' control commands. 1483 // that is intercepting 'throw' control commands.
(...skipping 1475 matching lines...) Expand 10 before | Expand all | Expand 10 after
2959 Visit(stmt); 2959 Visit(stmt);
2960 } 2960 }
2961 2961
2962 2962
2963 void AstGraphBuilder::VisitInScope(Statement* stmt, Scope* s, Node* context) { 2963 void AstGraphBuilder::VisitInScope(Statement* stmt, Scope* s, Node* context) {
2964 ContextScope scope(this, s, context); 2964 ContextScope scope(this, s, context);
2965 DCHECK(s->declarations()->is_empty()); 2965 DCHECK(s->declarations()->is_empty());
2966 Visit(stmt); 2966 Visit(stmt);
2967 } 2967 }
2968 2968
2969
2970 void AstGraphBuilder::VisitIterationBody(IterationStatement* stmt, 2969 void AstGraphBuilder::VisitIterationBody(IterationStatement* stmt,
2971 LoopBuilder* loop) { 2970 LoopBuilder* loop,
2971 BailoutId stack_check_id) {
2972 ControlScopeForIteration scope(this, stmt, loop); 2972 ControlScopeForIteration scope(this, stmt, loop);
2973 if (FLAG_turbo_loop_stackcheck || !info()->shared_info()->asm_function()) { 2973 if (FLAG_turbo_loop_stackcheck || !info()->shared_info()->asm_function()) {
2974 Node* node = NewNode(javascript()->StackCheck()); 2974 Node* node = NewNode(javascript()->StackCheck());
2975 PrepareFrameState(node, stmt->StackCheckId()); 2975 PrepareFrameState(node, stack_check_id);
2976 } 2976 }
2977 Visit(stmt->body()); 2977 Visit(stmt->body());
2978 } 2978 }
2979 2979
2980 2980
2981 void AstGraphBuilder::VisitDelete(UnaryOperation* expr) { 2981 void AstGraphBuilder::VisitDelete(UnaryOperation* expr) {
2982 Node* value; 2982 Node* value;
2983 if (expr->expression()->IsVariableProxy()) { 2983 if (expr->expression()->IsVariableProxy()) {
2984 // Delete of an unqualified identifier is only allowed in classic mode but 2984 // Delete of an unqualified identifier is only allowed in classic mode but
2985 // deleting "this" is allowed in all language modes. 2985 // deleting "this" is allowed in all language modes.
(...skipping 1383 matching lines...) Expand 10 before | Expand all | Expand 10 after
4369 // Phi does not exist yet, introduce one. 4369 // Phi does not exist yet, introduce one.
4370 value = NewPhi(inputs, value, control); 4370 value = NewPhi(inputs, value, control);
4371 value->ReplaceInput(inputs - 1, other); 4371 value->ReplaceInput(inputs - 1, other);
4372 } 4372 }
4373 return value; 4373 return value;
4374 } 4374 }
4375 4375
4376 } // namespace compiler 4376 } // namespace compiler
4377 } // namespace internal 4377 } // namespace internal
4378 } // namespace v8 4378 } // namespace v8
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698