| OLD | NEW |
| 1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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_SCHEDULE_H_ | 5 #ifndef V8_COMPILER_SCHEDULE_H_ |
| 6 #define V8_COMPILER_SCHEDULE_H_ | 6 #define V8_COMPILER_SCHEDULE_H_ |
| 7 | 7 |
| 8 #include <iosfwd> | 8 #include <iosfwd> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 138 // Accessors. | 138 // Accessors. |
| 139 Control control() const { return control_; } | 139 Control control() const { return control_; } |
| 140 void set_control(Control control); | 140 void set_control(Control control); |
| 141 | 141 |
| 142 Node* control_input() const { return control_input_; } | 142 Node* control_input() const { return control_input_; } |
| 143 void set_control_input(Node* control_input); | 143 void set_control_input(Node* control_input); |
| 144 | 144 |
| 145 bool deferred() const { return deferred_; } | 145 bool deferred() const { return deferred_; } |
| 146 void set_deferred(bool deferred) { deferred_ = deferred; } | 146 void set_deferred(bool deferred) { deferred_ = deferred; } |
| 147 | 147 |
| 148 int32_t dominator_depth() const { return dominator_depth_; } |
| 149 void set_dominator_depth(int32_t dominator_depth); |
| 150 |
| 148 BasicBlock* dominator() const { return dominator_; } | 151 BasicBlock* dominator() const { return dominator_; } |
| 149 void set_dominator(BasicBlock* dominator); | 152 void set_dominator(BasicBlock* dominator); |
| 150 | 153 |
| 151 BasicBlock* loop_header() const { return loop_header_; } | 154 BasicBlock* loop_header() const { return loop_header_; } |
| 152 void set_loop_header(BasicBlock* loop_header); | 155 void set_loop_header(BasicBlock* loop_header); |
| 153 | 156 |
| 157 BasicBlock* loop_end() const { return loop_end_; } |
| 158 void set_loop_end(BasicBlock* loop_end); |
| 159 |
| 154 int32_t loop_depth() const { return loop_depth_; } | 160 int32_t loop_depth() const { return loop_depth_; } |
| 155 void set_loop_depth(int32_t loop_depth); | 161 void set_loop_depth(int32_t loop_depth); |
| 156 | 162 |
| 157 int32_t loop_end() const { return loop_end_; } | |
| 158 void set_loop_end(int32_t loop_end); | |
| 159 | |
| 160 RpoNumber GetAoNumber() const { return RpoNumber::FromInt(ao_number_); } | 163 RpoNumber GetAoNumber() const { return RpoNumber::FromInt(ao_number_); } |
| 161 int32_t ao_number() const { return ao_number_; } | 164 int32_t ao_number() const { return ao_number_; } |
| 162 void set_ao_number(int32_t ao_number) { ao_number_ = ao_number; } | 165 void set_ao_number(int32_t ao_number) { ao_number_ = ao_number; } |
| 163 | 166 |
| 164 RpoNumber GetRpoNumber() const { return RpoNumber::FromInt(rpo_number_); } | 167 RpoNumber GetRpoNumber() const { return RpoNumber::FromInt(rpo_number_); } |
| 165 int32_t rpo_number() const { return rpo_number_; } | 168 int32_t rpo_number() const { return rpo_number_; } |
| 166 void set_rpo_number(int32_t rpo_number); | 169 void set_rpo_number(int32_t rpo_number); |
| 167 | 170 |
| 168 // Loop membership helpers. | 171 // Loop membership helpers. |
| 169 inline bool IsLoopHeader() const { return loop_end_ >= 0; } | 172 inline bool IsLoopHeader() const { return loop_end_ != NULL; } |
| 170 bool LoopContains(BasicBlock* block) const; | 173 bool LoopContains(BasicBlock* block) const; |
| 171 | 174 |
| 172 private: | 175 private: |
| 173 int32_t ao_number_; // assembly order number of the block. | 176 int32_t ao_number_; // assembly order number of the block. |
| 174 int32_t rpo_number_; // special RPO number of the block. | 177 int32_t rpo_number_; // special RPO number of the block. |
| 175 bool deferred_; // true if the block contains deferred code. | 178 bool deferred_; // true if the block contains deferred code. |
| 179 int32_t dominator_depth_; // Depth within the dominator tree. |
| 176 BasicBlock* dominator_; // Immediate dominator of the block. | 180 BasicBlock* dominator_; // Immediate dominator of the block. |
| 177 BasicBlock* loop_header_; // Pointer to dominating loop header basic block, | 181 BasicBlock* loop_header_; // Pointer to dominating loop header basic block, |
| 178 // NULL if none. For loop headers, this points to | 182 // NULL if none. For loop headers, this points to |
| 179 // enclosing loop header. | 183 // enclosing loop header. |
| 184 BasicBlock* loop_end_; // end of the loop, if this block is a loop header. |
| 180 int32_t loop_depth_; // loop nesting, 0 is top-level | 185 int32_t loop_depth_; // loop nesting, 0 is top-level |
| 181 int32_t loop_end_; // end of the loop, if this block is a loop header. | |
| 182 | 186 |
| 183 Control control_; // Control at the end of the block. | 187 Control control_; // Control at the end of the block. |
| 184 Node* control_input_; // Input value for control. | 188 Node* control_input_; // Input value for control. |
| 185 NodeVector nodes_; // nodes of this block in forward order. | 189 NodeVector nodes_; // nodes of this block in forward order. |
| 186 | 190 |
| 187 Successors successors_; | 191 Successors successors_; |
| 188 Predecessors predecessors_; | 192 Predecessors predecessors_; |
| 189 Id id_; | 193 Id id_; |
| 190 | 194 |
| 191 DISALLOW_COPY_AND_ASSIGN(BasicBlock); | 195 DISALLOW_COPY_AND_ASSIGN(BasicBlock); |
| (...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 281 DISALLOW_COPY_AND_ASSIGN(Schedule); | 285 DISALLOW_COPY_AND_ASSIGN(Schedule); |
| 282 }; | 286 }; |
| 283 | 287 |
| 284 std::ostream& operator<<(std::ostream& os, const Schedule& s); | 288 std::ostream& operator<<(std::ostream& os, const Schedule& s); |
| 285 | 289 |
| 286 } // namespace compiler | 290 } // namespace compiler |
| 287 } // namespace internal | 291 } // namespace internal |
| 288 } // namespace v8 | 292 } // namespace v8 |
| 289 | 293 |
| 290 #endif // V8_COMPILER_SCHEDULE_H_ | 294 #endif // V8_COMPILER_SCHEDULE_H_ |
| OLD | NEW |