OLD | NEW |
1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 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_CHECKPOINT_ELIMINATION_H_ | 5 #ifndef V8_COMPILER_CHECKPOINT_ELIMINATION_H_ |
6 #define V8_COMPILER_CHECKPOINT_ELIMINATION_H_ | 6 #define V8_COMPILER_CHECKPOINT_ELIMINATION_H_ |
7 | 7 |
8 #include "src/compiler/graph-reducer.h" | 8 #include "src/compiler/graph-reducer.h" |
9 | 9 |
10 namespace v8 { | 10 namespace v8 { |
11 namespace internal { | 11 namespace internal { |
12 namespace compiler { | 12 namespace compiler { |
13 | 13 |
14 // Performs elimination of redundant checkpoints within the graph. | 14 // Performs elimination of redundant checkpoints within the graph. |
15 class CheckpointElimination final : public AdvancedReducer { | 15 class CheckpointElimination final : public AdvancedReducer { |
16 public: | 16 public: |
17 explicit CheckpointElimination(Editor* editor); | 17 explicit CheckpointElimination(Editor* editor); |
18 ~CheckpointElimination() final {} | 18 ~CheckpointElimination() final {} |
19 | 19 |
20 Reduction Reduce(Node* node) final; | 20 Reduction Reduce(Node* node) final; |
| 21 |
| 22 private: |
| 23 Reduction ReduceCheckpoint(Node* node); |
| 24 Reduction ReduceReturn(Node* node); |
21 }; | 25 }; |
22 | 26 |
23 } // namespace compiler | 27 } // namespace compiler |
24 } // namespace internal | 28 } // namespace internal |
25 } // namespace v8 | 29 } // namespace v8 |
26 | 30 |
27 #endif // V8_COMPILER_CHECKPOINT_ELIMINATION_H_ | 31 #endif // V8_COMPILER_CHECKPOINT_ELIMINATION_H_ |
OLD | NEW |