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

Side by Side Diff: src/compiler/ia32/instruction-selector-ia32.cc

Issue 2682143002: [compiler] Pass deoptimization_kind through DeoptimizeParameters and FlagsContinuation (Closed)
Patch Set: fix Created 3 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
« no previous file with comments | « src/compiler/ia32/code-generator-ia32.cc ('k') | src/compiler/instruction.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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/base/adapters.h" 5 #include "src/base/adapters.h"
6 #include "src/compiler/instruction-selector-impl.h" 6 #include "src/compiler/instruction-selector-impl.h"
7 #include "src/compiler/node-matchers.h" 7 #include "src/compiler/node-matchers.h"
8 #include "src/compiler/node-properties.h" 8 #include "src/compiler/node-properties.h"
9 9
10 namespace v8 { 10 namespace v8 {
(...skipping 502 matching lines...) Expand 10 before | Expand all | Expand 10 after
513 } 513 }
514 514
515 DCHECK_NE(0u, input_count); 515 DCHECK_NE(0u, input_count);
516 DCHECK_NE(0u, output_count); 516 DCHECK_NE(0u, output_count);
517 DCHECK_GE(arraysize(inputs), input_count); 517 DCHECK_GE(arraysize(inputs), input_count);
518 DCHECK_GE(arraysize(outputs), output_count); 518 DCHECK_GE(arraysize(outputs), output_count);
519 519
520 opcode = cont->Encode(opcode); 520 opcode = cont->Encode(opcode);
521 if (cont->IsDeoptimize()) { 521 if (cont->IsDeoptimize()) {
522 selector->EmitDeoptimize(opcode, output_count, outputs, input_count, inputs, 522 selector->EmitDeoptimize(opcode, output_count, outputs, input_count, inputs,
523 cont->reason(), cont->frame_state()); 523 cont->kind(), cont->reason(), cont->frame_state());
524 } else { 524 } else {
525 selector->Emit(opcode, output_count, outputs, input_count, inputs); 525 selector->Emit(opcode, output_count, outputs, input_count, inputs);
526 } 526 }
527 } 527 }
528 528
529 529
530 // Shared routine for multiple binary operations. 530 // Shared routine for multiple binary operations.
531 void VisitBinop(InstructionSelector* selector, Node* node, 531 void VisitBinop(InstructionSelector* selector, Node* node,
532 InstructionCode opcode) { 532 InstructionCode opcode) {
533 FlagsContinuation cont; 533 FlagsContinuation cont;
(...skipping 548 matching lines...) Expand 10 before | Expand all | Expand 10 after
1082 opcode |= AddressingModeField::encode(addressing_mode); 1082 opcode |= AddressingModeField::encode(addressing_mode);
1083 opcode = cont->Encode(opcode); 1083 opcode = cont->Encode(opcode);
1084 inputs[input_count++] = right; 1084 inputs[input_count++] = right;
1085 1085
1086 if (cont->IsBranch()) { 1086 if (cont->IsBranch()) {
1087 inputs[input_count++] = g.Label(cont->true_block()); 1087 inputs[input_count++] = g.Label(cont->true_block());
1088 inputs[input_count++] = g.Label(cont->false_block()); 1088 inputs[input_count++] = g.Label(cont->false_block());
1089 selector->Emit(opcode, 0, nullptr, input_count, inputs); 1089 selector->Emit(opcode, 0, nullptr, input_count, inputs);
1090 } else if (cont->IsDeoptimize()) { 1090 } else if (cont->IsDeoptimize()) {
1091 selector->EmitDeoptimize(opcode, 0, nullptr, input_count, inputs, 1091 selector->EmitDeoptimize(opcode, 0, nullptr, input_count, inputs,
1092 cont->reason(), cont->frame_state()); 1092 cont->kind(), cont->reason(), cont->frame_state());
1093 } else if (cont->IsSet()) { 1093 } else if (cont->IsSet()) {
1094 InstructionOperand output = g.DefineAsRegister(cont->result()); 1094 InstructionOperand output = g.DefineAsRegister(cont->result());
1095 selector->Emit(opcode, 1, &output, input_count, inputs); 1095 selector->Emit(opcode, 1, &output, input_count, inputs);
1096 } else { 1096 } else {
1097 DCHECK(cont->IsTrap()); 1097 DCHECK(cont->IsTrap());
1098 inputs[input_count++] = g.UseImmediate(cont->trap_id()); 1098 inputs[input_count++] = g.UseImmediate(cont->trap_id());
1099 selector->Emit(opcode, 0, nullptr, input_count, inputs); 1099 selector->Emit(opcode, 0, nullptr, input_count, inputs);
1100 } 1100 }
1101 } 1101 }
1102 1102
1103 // Shared routine for multiple compare operations. 1103 // Shared routine for multiple compare operations.
1104 void VisitCompare(InstructionSelector* selector, InstructionCode opcode, 1104 void VisitCompare(InstructionSelector* selector, InstructionCode opcode,
1105 InstructionOperand left, InstructionOperand right, 1105 InstructionOperand left, InstructionOperand right,
1106 FlagsContinuation* cont) { 1106 FlagsContinuation* cont) {
1107 IA32OperandGenerator g(selector); 1107 IA32OperandGenerator g(selector);
1108 opcode = cont->Encode(opcode); 1108 opcode = cont->Encode(opcode);
1109 if (cont->IsBranch()) { 1109 if (cont->IsBranch()) {
1110 selector->Emit(opcode, g.NoOutput(), left, right, 1110 selector->Emit(opcode, g.NoOutput(), left, right,
1111 g.Label(cont->true_block()), g.Label(cont->false_block())); 1111 g.Label(cont->true_block()), g.Label(cont->false_block()));
1112 } else if (cont->IsDeoptimize()) { 1112 } else if (cont->IsDeoptimize()) {
1113 selector->EmitDeoptimize(opcode, g.NoOutput(), left, right, cont->reason(), 1113 selector->EmitDeoptimize(opcode, g.NoOutput(), left, right, cont->kind(),
1114 cont->frame_state()); 1114 cont->reason(), cont->frame_state());
1115 } else if (cont->IsSet()) { 1115 } else if (cont->IsSet()) {
1116 selector->Emit(opcode, g.DefineAsByteRegister(cont->result()), left, right); 1116 selector->Emit(opcode, g.DefineAsByteRegister(cont->result()), left, right);
1117 } else { 1117 } else {
1118 DCHECK(cont->IsTrap()); 1118 DCHECK(cont->IsTrap());
1119 selector->Emit(opcode, g.NoOutput(), left, right, 1119 selector->Emit(opcode, g.NoOutput(), left, right,
1120 g.UseImmediate(cont->trap_id())); 1120 g.UseImmediate(cont->trap_id()));
1121 } 1121 }
1122 } 1122 }
1123 1123
1124 1124
(...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after
1289 ExternalReference js_stack_limit = 1289 ExternalReference js_stack_limit =
1290 ExternalReference::address_of_stack_limit(selector->isolate()); 1290 ExternalReference::address_of_stack_limit(selector->isolate());
1291 if (mleft.object().Is(js_stack_limit) && mleft.index().Is(0)) { 1291 if (mleft.object().Is(js_stack_limit) && mleft.index().Is(0)) {
1292 // Compare(Load(js_stack_limit), LoadStackPointer) 1292 // Compare(Load(js_stack_limit), LoadStackPointer)
1293 if (!node->op()->HasProperty(Operator::kCommutative)) cont->Commute(); 1293 if (!node->op()->HasProperty(Operator::kCommutative)) cont->Commute();
1294 InstructionCode opcode = cont->Encode(kIA32StackCheck); 1294 InstructionCode opcode = cont->Encode(kIA32StackCheck);
1295 if (cont->IsBranch()) { 1295 if (cont->IsBranch()) {
1296 selector->Emit(opcode, g.NoOutput(), g.Label(cont->true_block()), 1296 selector->Emit(opcode, g.NoOutput(), g.Label(cont->true_block()),
1297 g.Label(cont->false_block())); 1297 g.Label(cont->false_block()));
1298 } else if (cont->IsDeoptimize()) { 1298 } else if (cont->IsDeoptimize()) {
1299 selector->EmitDeoptimize(opcode, 0, nullptr, 0, nullptr, cont->reason(), 1299 selector->EmitDeoptimize(opcode, 0, nullptr, 0, nullptr, cont->kind(),
1300 cont->frame_state()); 1300 cont->reason(), cont->frame_state());
1301 } else { 1301 } else {
1302 DCHECK(cont->IsSet()); 1302 DCHECK(cont->IsSet());
1303 selector->Emit(opcode, g.DefineAsRegister(cont->result())); 1303 selector->Emit(opcode, g.DefineAsRegister(cont->result()));
1304 } 1304 }
1305 return; 1305 return;
1306 } 1306 }
1307 } 1307 }
1308 VisitWordCompare(selector, node, kIA32Cmp, cont); 1308 VisitWordCompare(selector, node, kIA32Cmp, cont);
1309 } 1309 }
1310 1310
(...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after
1402 1402
1403 } // namespace 1403 } // namespace
1404 1404
1405 void InstructionSelector::VisitBranch(Node* branch, BasicBlock* tbranch, 1405 void InstructionSelector::VisitBranch(Node* branch, BasicBlock* tbranch,
1406 BasicBlock* fbranch) { 1406 BasicBlock* fbranch) {
1407 FlagsContinuation cont(kNotEqual, tbranch, fbranch); 1407 FlagsContinuation cont(kNotEqual, tbranch, fbranch);
1408 VisitWordCompareZero(this, branch, branch->InputAt(0), &cont); 1408 VisitWordCompareZero(this, branch, branch->InputAt(0), &cont);
1409 } 1409 }
1410 1410
1411 void InstructionSelector::VisitDeoptimizeIf(Node* node) { 1411 void InstructionSelector::VisitDeoptimizeIf(Node* node) {
1412 DeoptimizeParameters p = DeoptimizeParametersOf(node->op());
1412 FlagsContinuation cont = FlagsContinuation::ForDeoptimize( 1413 FlagsContinuation cont = FlagsContinuation::ForDeoptimize(
1413 kNotEqual, DeoptimizeReasonOf(node->op()), node->InputAt(1)); 1414 kNotEqual, p.kind(), p.reason(), node->InputAt(1));
1414 VisitWordCompareZero(this, node, node->InputAt(0), &cont); 1415 VisitWordCompareZero(this, node, node->InputAt(0), &cont);
1415 } 1416 }
1416 1417
1417 void InstructionSelector::VisitDeoptimizeUnless(Node* node) { 1418 void InstructionSelector::VisitDeoptimizeUnless(Node* node) {
1419 DeoptimizeParameters p = DeoptimizeParametersOf(node->op());
1418 FlagsContinuation cont = FlagsContinuation::ForDeoptimize( 1420 FlagsContinuation cont = FlagsContinuation::ForDeoptimize(
1419 kEqual, DeoptimizeReasonOf(node->op()), node->InputAt(1)); 1421 kEqual, p.kind(), p.reason(), node->InputAt(1));
1420 VisitWordCompareZero(this, node, node->InputAt(0), &cont); 1422 VisitWordCompareZero(this, node, node->InputAt(0), &cont);
1421 } 1423 }
1422 1424
1423 void InstructionSelector::VisitTrapIf(Node* node, Runtime::FunctionId func_id) { 1425 void InstructionSelector::VisitTrapIf(Node* node, Runtime::FunctionId func_id) {
1424 FlagsContinuation cont = 1426 FlagsContinuation cont =
1425 FlagsContinuation::ForTrap(kNotEqual, func_id, node->InputAt(1)); 1427 FlagsContinuation::ForTrap(kNotEqual, func_id, node->InputAt(1));
1426 VisitWordCompareZero(this, node, node->InputAt(0), &cont); 1428 VisitWordCompareZero(this, node, node->InputAt(0), &cont);
1427 } 1429 }
1428 1430
1429 void InstructionSelector::VisitTrapUnless(Node* node, 1431 void InstructionSelector::VisitTrapUnless(Node* node,
(...skipping 236 matching lines...) Expand 10 before | Expand all | Expand 10 after
1666 // static 1668 // static
1667 MachineOperatorBuilder::AlignmentRequirements 1669 MachineOperatorBuilder::AlignmentRequirements
1668 InstructionSelector::AlignmentRequirements() { 1670 InstructionSelector::AlignmentRequirements() {
1669 return MachineOperatorBuilder::AlignmentRequirements:: 1671 return MachineOperatorBuilder::AlignmentRequirements::
1670 FullUnalignedAccessSupport(); 1672 FullUnalignedAccessSupport();
1671 } 1673 }
1672 1674
1673 } // namespace compiler 1675 } // namespace compiler
1674 } // namespace internal 1676 } // namespace internal
1675 } // namespace v8 1677 } // namespace v8
OLDNEW
« no previous file with comments | « src/compiler/ia32/code-generator-ia32.cc ('k') | src/compiler/instruction.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698