Chromium Code Reviews| OLD | NEW |
|---|---|
| 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/simplified-lowering.h" | 5 #include "src/compiler/simplified-lowering.h" |
| 6 | 6 |
| 7 #include <limits> | 7 #include <limits> |
| 8 | 8 |
| 9 #include "src/base/bits.h" | 9 #include "src/base/bits.h" |
| 10 #include "src/code-factory.h" | 10 #include "src/code-factory.h" |
| (...skipping 337 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 348 MachineType use_type = | 348 MachineType use_type = |
| 349 static_cast<MachineType>((use & kTypeMask) | propagate); | 349 static_cast<MachineType>((use & kTypeMask) | propagate); |
| 350 for (Node::Inputs::iterator iter(inputs.begin()); iter != inputs.end(); | 350 for (Node::Inputs::iterator iter(inputs.begin()); iter != inputs.end(); |
| 351 ++iter, --values) { | 351 ++iter, --values) { |
| 352 // TODO(titzer): it'd be nice to have distinguished edge kinds here. | 352 // TODO(titzer): it'd be nice to have distinguished edge kinds here. |
| 353 ProcessInput(node, iter.index(), values > 0 ? use_type : 0); | 353 ProcessInput(node, iter.index(), values > 0 ? use_type : 0); |
| 354 } | 354 } |
| 355 } | 355 } |
| 356 } | 356 } |
| 357 | 357 |
| 358 void VisitIsSmi(Node* node) { | |
| 359 ProcessInput(node, 0, kMachAnyTagged); | |
| 360 if (lower()) { | |
| 361 Node* is_tagged = jsgraph_->graph()->NewNode( | |
| 362 jsgraph_->machine()->WordAnd(), node->InputAt(0), | |
| 363 jsgraph_->Int32Constant(static_cast<int>(kSmiTagMask))); | |
| 364 Node* is_smi = jsgraph_->graph()->NewNode( | |
|
Michael Starzinger
2014/10/15 13:03:17
For posterity: There might be a more optimal lower
sigurds
2014/10/15 14:59:58
Acknowledged.
| |
| 365 jsgraph_->machine()->WordEqual(), is_tagged, | |
| 366 jsgraph_->Int32Constant(kSmiTag)); | |
| 367 DeferReplacement(node, is_smi); | |
| 368 } | |
| 369 SetOutput(node, kRepBit | kTypeBool); | |
| 370 } | |
| 371 | |
| 372 void VisitIsNonNegativeSmi(Node* node) { | |
| 373 ProcessInput(node, 0, kMachAnyTagged); | |
| 374 if (lower()) { | |
| 375 Node* is_tagged = jsgraph_->graph()->NewNode( | |
| 376 jsgraph_->machine()->WordAnd(), node->InputAt(0), | |
| 377 jsgraph_->Int32Constant(static_cast<int>(kSmiTagMask))); | |
| 378 Node* is_smi = jsgraph_->graph()->NewNode( | |
| 379 jsgraph_->machine()->WordEqual(), is_tagged, | |
| 380 jsgraph_->Int32Constant(kSmiTag)); | |
| 381 Node* is_non_neg = jsgraph_->graph()->NewNode( | |
| 382 jsgraph_->machine()->Is32() | |
|
Michael Starzinger
2014/10/15 13:03:17
nit: There already should be IntLessThanOrEqual()
sigurds
2014/10/15 14:59:58
Done.
| |
| 383 ? jsgraph_->machine()->Int32LessThanOrEqual() | |
| 384 : jsgraph_->machine()->Int64LessThanOrEqual(), | |
| 385 jsgraph_->Int32Constant(0), node->InputAt(0)); | |
| 386 Node* is_non_neg_smi = jsgraph_->graph()->NewNode( | |
| 387 jsgraph_->machine()->Word32And(), is_smi, is_non_neg); | |
| 388 DeferReplacement(node, is_non_neg_smi); | |
| 389 } | |
| 390 SetOutput(node, kRepBit | kTypeBool); | |
| 391 } | |
| 392 | |
| 358 const Operator* Int32Op(Node* node) { | 393 const Operator* Int32Op(Node* node) { |
| 359 return changer_->Int32OperatorFor(node->opcode()); | 394 return changer_->Int32OperatorFor(node->opcode()); |
| 360 } | 395 } |
| 361 | 396 |
| 362 const Operator* Uint32Op(Node* node) { | 397 const Operator* Uint32Op(Node* node) { |
| 363 return changer_->Uint32OperatorFor(node->opcode()); | 398 return changer_->Uint32OperatorFor(node->opcode()); |
| 364 } | 399 } |
| 365 | 400 |
| 366 const Operator* Float64Op(Node* node) { | 401 const Operator* Float64Op(Node* node) { |
| 367 return changer_->Float64OperatorFor(node->opcode()); | 402 return changer_->Float64OperatorFor(node->opcode()); |
| (...skipping 458 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 826 case IrOpcode::kFloat64LessThanOrEqual: | 861 case IrOpcode::kFloat64LessThanOrEqual: |
| 827 return VisitFloat64Cmp(node); | 862 return VisitFloat64Cmp(node); |
| 828 case IrOpcode::kLoadStackPointer: | 863 case IrOpcode::kLoadStackPointer: |
| 829 return VisitLeaf(node, kMachPtr); | 864 return VisitLeaf(node, kMachPtr); |
| 830 case IrOpcode::kStateValues: | 865 case IrOpcode::kStateValues: |
| 831 for (int i = 0; i < node->InputCount(); i++) { | 866 for (int i = 0; i < node->InputCount(); i++) { |
| 832 ProcessInput(node, i, kTypeAny); | 867 ProcessInput(node, i, kTypeAny); |
| 833 } | 868 } |
| 834 SetOutput(node, kMachAnyTagged); | 869 SetOutput(node, kMachAnyTagged); |
| 835 break; | 870 break; |
| 871 case IrOpcode::kIsSmi: | |
| 872 return VisitIsSmi(node); | |
|
Michael Starzinger
2014/10/15 13:03:17
Please move this into the section for simplified o
sigurds
2014/10/15 14:59:58
Done. Did not create DoIsSmi/DoIsNonNegativeSmi.
| |
| 873 case IrOpcode::kIsNonNegativeSmi: | |
| 874 return VisitIsNonNegativeSmi(node); | |
| 836 default: | 875 default: |
| 837 VisitInputs(node); | 876 VisitInputs(node); |
| 838 break; | 877 break; |
| 839 } | 878 } |
| 840 } | 879 } |
| 841 | 880 |
| 842 void DeferReplacement(Node* node, Node* replacement) { | 881 void DeferReplacement(Node* node, Node* replacement) { |
| 843 if (FLAG_trace_representation) { | 882 if (FLAG_trace_representation) { |
| 844 TRACE(("defer replacement #%d:%s with #%d:%s\n", node->id(), | 883 TRACE(("defer replacement #%d:%s with #%d:%s\n", node->id(), |
| 845 node->op()->mnemonic(), replacement->id(), | 884 node->op()->mnemonic(), replacement->id(), |
| (...skipping 287 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1133 void SimplifiedLowering::DoStringLessThanOrEqual(Node* node) { | 1172 void SimplifiedLowering::DoStringLessThanOrEqual(Node* node) { |
| 1134 node->set_op(machine()->IntLessThanOrEqual()); | 1173 node->set_op(machine()->IntLessThanOrEqual()); |
| 1135 node->ReplaceInput(0, StringComparison(node, true)); | 1174 node->ReplaceInput(0, StringComparison(node, true)); |
| 1136 node->ReplaceInput(1, jsgraph()->SmiConstant(EQUAL)); | 1175 node->ReplaceInput(1, jsgraph()->SmiConstant(EQUAL)); |
| 1137 } | 1176 } |
| 1138 | 1177 |
| 1139 | 1178 |
| 1140 } // namespace compiler | 1179 } // namespace compiler |
| 1141 } // namespace internal | 1180 } // namespace internal |
| 1142 } // namespace v8 | 1181 } // namespace v8 |
| OLD | NEW |