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_SIMPLIFIED_LOWERING_H_ | 5 #ifndef V8_COMPILER_SIMPLIFIED_LOWERING_H_ |
6 #define V8_COMPILER_SIMPLIFIED_LOWERING_H_ | 6 #define V8_COMPILER_SIMPLIFIED_LOWERING_H_ |
7 | 7 |
8 #include "src/compiler/js-graph.h" | 8 #include "src/compiler/js-graph.h" |
9 #include "src/compiler/machine-operator.h" | 9 #include "src/compiler/machine-operator.h" |
10 #include "src/compiler/node.h" | 10 #include "src/compiler/node.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 class SimplifiedLowering final { | 21 class SimplifiedLowering final { |
22 public: | 22 public: |
23 SimplifiedLowering(JSGraph* jsgraph, Zone* zone, | 23 SimplifiedLowering(JSGraph* jsgraph, Zone* zone, |
24 SourcePositionTable* source_positions) | 24 SourcePositionTable* source_positions) |
25 : jsgraph_(jsgraph), zone_(zone), source_positions_(source_positions) {} | 25 : jsgraph_(jsgraph), zone_(zone), source_positions_(source_positions) {} |
26 ~SimplifiedLowering() {} | 26 ~SimplifiedLowering() {} |
27 | 27 |
28 void LowerAllNodes(); | 28 void LowerAllNodes(); |
29 | 29 |
30 // TODO(titzer): These are exposed for direct testing. Use a friend class. | 30 // TODO(titzer): These are exposed for direct testing. Use a friend class. |
| 31 void DoAllocate(Node* node); |
31 void DoLoadField(Node* node); | 32 void DoLoadField(Node* node); |
32 void DoStoreField(Node* node); | 33 void DoStoreField(Node* node); |
33 // TODO(turbofan): The output_type can be removed once the result of the | 34 // TODO(turbofan): The output_type can be removed once the result of the |
34 // representation analysis is stored in the node bounds. | 35 // representation analysis is stored in the node bounds. |
35 void DoLoadBuffer(Node* node, MachineType output_type, | 36 void DoLoadBuffer(Node* node, MachineType output_type, |
36 RepresentationChanger* changer); | 37 RepresentationChanger* changer); |
37 void DoStoreBuffer(Node* node); | 38 void DoStoreBuffer(Node* node); |
38 void DoLoadElement(Node* node); | 39 void DoLoadElement(Node* node); |
39 void DoStoreElement(Node* node); | 40 void DoStoreElement(Node* node); |
40 void DoStringAdd(Node* node); | 41 void DoStringAdd(Node* node); |
(...skipping 30 matching lines...) Expand all Loading... |
71 Graph* graph() { return jsgraph()->graph(); } | 72 Graph* graph() { return jsgraph()->graph(); } |
72 CommonOperatorBuilder* common() { return jsgraph()->common(); } | 73 CommonOperatorBuilder* common() { return jsgraph()->common(); } |
73 MachineOperatorBuilder* machine() { return jsgraph()->machine(); } | 74 MachineOperatorBuilder* machine() { return jsgraph()->machine(); } |
74 }; | 75 }; |
75 | 76 |
76 } // namespace compiler | 77 } // namespace compiler |
77 } // namespace internal | 78 } // namespace internal |
78 } // namespace v8 | 79 } // namespace v8 |
79 | 80 |
80 #endif // V8_COMPILER_SIMPLIFIED_LOWERING_H_ | 81 #endif // V8_COMPILER_SIMPLIFIED_LOWERING_H_ |
OLD | NEW |