| 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 |