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 #ifndef V8_COMPILER_JS_TYPED_LOWERING_H_ | 5 #ifndef V8_COMPILER_JS_TYPED_LOWERING_H_ |
6 #define V8_COMPILER_JS_TYPED_LOWERING_H_ | 6 #define V8_COMPILER_JS_TYPED_LOWERING_H_ |
7 | 7 |
8 #include "src/compiler/graph-reducer.h" | 8 #include "src/compiler/graph-reducer.h" |
9 #include "src/compiler/opcodes.h" | 9 #include "src/compiler/opcodes.h" |
10 #include "src/compiler/simplified-operator.h" | 10 #include "src/compiler/simplified-operator.h" |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
58 Reduction ReduceJSCreateLiteralArray(Node* node); | 58 Reduction ReduceJSCreateLiteralArray(Node* node); |
59 Reduction ReduceJSCreateLiteralObject(Node* node); | 59 Reduction ReduceJSCreateLiteralObject(Node* node); |
60 Reduction ReduceJSCreateWithContext(Node* node); | 60 Reduction ReduceJSCreateWithContext(Node* node); |
61 Reduction ReduceJSCreateBlockContext(Node* node); | 61 Reduction ReduceJSCreateBlockContext(Node* node); |
62 Reduction ReduceNumberBinop(Node* node, const Operator* numberOp); | 62 Reduction ReduceNumberBinop(Node* node, const Operator* numberOp); |
63 Reduction ReduceInt32Binop(Node* node, const Operator* intOp); | 63 Reduction ReduceInt32Binop(Node* node, const Operator* intOp); |
64 Reduction ReduceUI32Shift(Node* node, Signedness left_signedness, | 64 Reduction ReduceUI32Shift(Node* node, Signedness left_signedness, |
65 const Operator* shift_op); | 65 const Operator* shift_op); |
66 | 66 |
67 Node* ConvertPrimitiveToNumber(Node* input); | 67 Node* ConvertPrimitiveToNumber(Node* input); |
68 template <IrOpcode::Value> | |
69 Node* FindConversion(Node* input); | |
70 void InsertConversion(Node* conversion); | |
71 | 68 |
72 Node* Word32Shl(Node* const lhs, int32_t const rhs); | 69 Node* Word32Shl(Node* const lhs, int32_t const rhs); |
73 | 70 |
74 Factory* factory() const; | 71 Factory* factory() const; |
75 Graph* graph() const; | 72 Graph* graph() const; |
76 JSGraph* jsgraph() const { return jsgraph_; } | 73 JSGraph* jsgraph() const { return jsgraph_; } |
77 JSOperatorBuilder* javascript() const; | 74 JSOperatorBuilder* javascript() const; |
78 CommonOperatorBuilder* common() const; | 75 CommonOperatorBuilder* common() const; |
79 SimplifiedOperatorBuilder* simplified() { return &simplified_; } | 76 SimplifiedOperatorBuilder* simplified() { return &simplified_; } |
80 MachineOperatorBuilder* machine() const; | 77 MachineOperatorBuilder* machine() const; |
81 | 78 |
82 // Limits up to which context allocations are inlined. | 79 // Limits up to which context allocations are inlined. |
83 static const int kBlockContextAllocationLimit = 16; | 80 static const int kBlockContextAllocationLimit = 16; |
84 | 81 |
85 JSGraph* jsgraph_; | 82 JSGraph* jsgraph_; |
86 SimplifiedOperatorBuilder simplified_; | 83 SimplifiedOperatorBuilder simplified_; |
87 ZoneVector<Node*> conversions_; // Cache inserted JSToXXX() conversions. | |
88 Type* zero_range_; | 84 Type* zero_range_; |
89 Type* one_range_; | 85 Type* one_range_; |
90 Type* zero_thirtyone_range_; | 86 Type* zero_thirtyone_range_; |
91 Type* shifted_int32_ranges_[4]; | 87 Type* shifted_int32_ranges_[4]; |
92 }; | 88 }; |
93 | 89 |
94 } // namespace compiler | 90 } // namespace compiler |
95 } // namespace internal | 91 } // namespace internal |
96 } // namespace v8 | 92 } // namespace v8 |
97 | 93 |
98 #endif // V8_COMPILER_JS_TYPED_LOWERING_H_ | 94 #endif // V8_COMPILER_JS_TYPED_LOWERING_H_ |
OLD | NEW |