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/js-operator.h" | 5 #include "src/compiler/js-operator.h" |
6 | 6 |
7 #include <limits> | 7 #include <limits> |
8 | 8 |
9 #include "src/base/lazy-instance.h" | 9 #include "src/base/lazy-instance.h" |
10 #include "src/compiler/opcodes.h" | 10 #include "src/compiler/opcodes.h" |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
47 | 47 |
48 | 48 |
49 ToBooleanHints ToBooleanHintsOf(Operator const* op) { | 49 ToBooleanHints ToBooleanHintsOf(Operator const* op) { |
50 DCHECK_EQ(IrOpcode::kJSToBoolean, op->opcode()); | 50 DCHECK_EQ(IrOpcode::kJSToBoolean, op->opcode()); |
51 return OpParameter<ToBooleanHints>(op); | 51 return OpParameter<ToBooleanHints>(op); |
52 } | 52 } |
53 | 53 |
54 | 54 |
55 bool operator==(CallConstructParameters const& lhs, | 55 bool operator==(CallConstructParameters const& lhs, |
56 CallConstructParameters const& rhs) { | 56 CallConstructParameters const& rhs) { |
57 return lhs.arity() == rhs.arity() && lhs.feedback() == rhs.feedback(); | 57 return lhs.arity() == rhs.arity() && lhs.frequency() == rhs.frequency() && |
| 58 lhs.feedback() == rhs.feedback(); |
58 } | 59 } |
59 | 60 |
60 | 61 |
61 bool operator!=(CallConstructParameters const& lhs, | 62 bool operator!=(CallConstructParameters const& lhs, |
62 CallConstructParameters const& rhs) { | 63 CallConstructParameters const& rhs) { |
63 return !(lhs == rhs); | 64 return !(lhs == rhs); |
64 } | 65 } |
65 | 66 |
66 | 67 |
67 size_t hash_value(CallConstructParameters const& p) { | 68 size_t hash_value(CallConstructParameters const& p) { |
68 return base::hash_combine(p.arity(), p.feedback()); | 69 return base::hash_combine(p.arity(), p.frequency(), p.feedback()); |
69 } | 70 } |
70 | 71 |
71 | 72 |
72 std::ostream& operator<<(std::ostream& os, CallConstructParameters const& p) { | 73 std::ostream& operator<<(std::ostream& os, CallConstructParameters const& p) { |
73 return os << p.arity(); | 74 return os << p.arity() << ", " << p.frequency(); |
74 } | 75 } |
75 | 76 |
76 | 77 |
77 CallConstructParameters const& CallConstructParametersOf(Operator const* op) { | 78 CallConstructParameters const& CallConstructParametersOf(Operator const* op) { |
78 DCHECK_EQ(IrOpcode::kJSCallConstruct, op->opcode()); | 79 DCHECK_EQ(IrOpcode::kJSCallConstruct, op->opcode()); |
79 return OpParameter<CallConstructParameters>(op); | 80 return OpParameter<CallConstructParameters>(op); |
80 } | 81 } |
81 | 82 |
82 | 83 |
83 std::ostream& operator<<(std::ostream& os, CallFunctionParameters const& p) { | 84 std::ostream& operator<<(std::ostream& os, CallFunctionParameters const& p) { |
84 os << p.arity() << ", " << p.convert_mode() << ", " << p.tail_call_mode(); | 85 os << p.arity() << ", " << p.frequency() << ", " << p.convert_mode() << ", " |
| 86 << p.tail_call_mode(); |
85 return os; | 87 return os; |
86 } | 88 } |
87 | 89 |
88 | 90 |
89 const CallFunctionParameters& CallFunctionParametersOf(const Operator* op) { | 91 const CallFunctionParameters& CallFunctionParametersOf(const Operator* op) { |
90 DCHECK_EQ(IrOpcode::kJSCallFunction, op->opcode()); | 92 DCHECK_EQ(IrOpcode::kJSCallFunction, op->opcode()); |
91 return OpParameter<CallFunctionParameters>(op); | 93 return OpParameter<CallFunctionParameters>(op); |
92 } | 94 } |
93 | 95 |
94 | 96 |
(...skipping 488 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
583 const Operator* JSOperatorBuilder::ToBoolean(ToBooleanHints hints) { | 585 const Operator* JSOperatorBuilder::ToBoolean(ToBooleanHints hints) { |
584 // TODO(turbofan): Cache most important versions of this operator. | 586 // TODO(turbofan): Cache most important versions of this operator. |
585 return new (zone()) Operator1<ToBooleanHints>( //-- | 587 return new (zone()) Operator1<ToBooleanHints>( //-- |
586 IrOpcode::kJSToBoolean, Operator::kPure, // opcode | 588 IrOpcode::kJSToBoolean, Operator::kPure, // opcode |
587 "JSToBoolean", // name | 589 "JSToBoolean", // name |
588 1, 0, 0, 1, 0, 0, // inputs/outputs | 590 1, 0, 0, 1, 0, 0, // inputs/outputs |
589 hints); // parameter | 591 hints); // parameter |
590 } | 592 } |
591 | 593 |
592 const Operator* JSOperatorBuilder::CallFunction( | 594 const Operator* JSOperatorBuilder::CallFunction( |
593 size_t arity, VectorSlotPair const& feedback, | 595 size_t arity, float frequency, VectorSlotPair const& feedback, |
594 ConvertReceiverMode convert_mode, TailCallMode tail_call_mode) { | 596 ConvertReceiverMode convert_mode, TailCallMode tail_call_mode) { |
595 CallFunctionParameters parameters(arity, feedback, tail_call_mode, | 597 CallFunctionParameters parameters(arity, frequency, feedback, tail_call_mode, |
596 convert_mode); | 598 convert_mode); |
597 return new (zone()) Operator1<CallFunctionParameters>( // -- | 599 return new (zone()) Operator1<CallFunctionParameters>( // -- |
598 IrOpcode::kJSCallFunction, Operator::kNoProperties, // opcode | 600 IrOpcode::kJSCallFunction, Operator::kNoProperties, // opcode |
599 "JSCallFunction", // name | 601 "JSCallFunction", // name |
600 parameters.arity(), 1, 1, 1, 1, 2, // inputs/outputs | 602 parameters.arity(), 1, 1, 1, 1, 2, // inputs/outputs |
601 parameters); // parameter | 603 parameters); // parameter |
602 } | 604 } |
603 | 605 |
604 | 606 |
605 const Operator* JSOperatorBuilder::CallRuntime(Runtime::FunctionId id) { | 607 const Operator* JSOperatorBuilder::CallRuntime(Runtime::FunctionId id) { |
(...skipping 13 matching lines...) Expand all Loading... |
619 size_t arity) { | 621 size_t arity) { |
620 CallRuntimeParameters parameters(f->function_id, arity); | 622 CallRuntimeParameters parameters(f->function_id, arity); |
621 DCHECK(f->nargs == -1 || f->nargs == static_cast<int>(parameters.arity())); | 623 DCHECK(f->nargs == -1 || f->nargs == static_cast<int>(parameters.arity())); |
622 return new (zone()) Operator1<CallRuntimeParameters>( // -- | 624 return new (zone()) Operator1<CallRuntimeParameters>( // -- |
623 IrOpcode::kJSCallRuntime, Operator::kNoProperties, // opcode | 625 IrOpcode::kJSCallRuntime, Operator::kNoProperties, // opcode |
624 "JSCallRuntime", // name | 626 "JSCallRuntime", // name |
625 parameters.arity(), 1, 1, f->result_size, 1, 2, // inputs/outputs | 627 parameters.arity(), 1, 1, f->result_size, 1, 2, // inputs/outputs |
626 parameters); // parameter | 628 parameters); // parameter |
627 } | 629 } |
628 | 630 |
629 | |
630 const Operator* JSOperatorBuilder::CallConstruct( | 631 const Operator* JSOperatorBuilder::CallConstruct( |
631 size_t arity, VectorSlotPair const& feedback) { | 632 uint32_t arity, float frequency, VectorSlotPair const& feedback) { |
632 CallConstructParameters parameters(arity, feedback); | 633 CallConstructParameters parameters(arity, frequency, feedback); |
633 return new (zone()) Operator1<CallConstructParameters>( // -- | 634 return new (zone()) Operator1<CallConstructParameters>( // -- |
634 IrOpcode::kJSCallConstruct, Operator::kNoProperties, // opcode | 635 IrOpcode::kJSCallConstruct, Operator::kNoProperties, // opcode |
635 "JSCallConstruct", // name | 636 "JSCallConstruct", // name |
636 parameters.arity(), 1, 1, 1, 1, 2, // counts | 637 parameters.arity(), 1, 1, 1, 1, 2, // counts |
637 parameters); // parameter | 638 parameters); // parameter |
638 } | 639 } |
639 | 640 |
640 | 641 |
641 const Operator* JSOperatorBuilder::ConvertReceiver( | 642 const Operator* JSOperatorBuilder::ConvertReceiver( |
642 ConvertReceiverMode convert_mode) { | 643 ConvertReceiverMode convert_mode) { |
(...skipping 230 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
873 return new (zone()) Operator1<Handle<ScopeInfo>>( // -- | 874 return new (zone()) Operator1<Handle<ScopeInfo>>( // -- |
874 IrOpcode::kJSCreateScriptContext, Operator::kNoProperties, // opcode | 875 IrOpcode::kJSCreateScriptContext, Operator::kNoProperties, // opcode |
875 "JSCreateScriptContext", // name | 876 "JSCreateScriptContext", // name |
876 1, 1, 1, 1, 1, 2, // counts | 877 1, 1, 1, 1, 1, 2, // counts |
877 scpope_info); // parameter | 878 scpope_info); // parameter |
878 } | 879 } |
879 | 880 |
880 } // namespace compiler | 881 } // namespace compiler |
881 } // namespace internal | 882 } // namespace internal |
882 } // namespace v8 | 883 } // namespace v8 |
OLD | NEW |