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); | |
25 }; | 21 }; |
26 | 22 |
27 } // namespace compiler | 23 } // namespace compiler |
28 } // namespace internal | 24 } // namespace internal |
29 } // namespace v8 | 25 } // namespace v8 |
30 | 26 |
31 #endif // V8_COMPILER_CHECKPOINT_ELIMINATION_H_ | 27 #endif // V8_COMPILER_CHECKPOINT_ELIMINATION_H_ |
OLD | NEW |