Chromium Code Reviews| Index: runtime/vm/flow_graph_type_propagator.h |
| diff --git a/runtime/vm/flow_graph_type_propagator.h b/runtime/vm/flow_graph_type_propagator.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c68a4ff40932856eb5975b505ae45eef0e534e39 |
| --- /dev/null |
| +++ b/runtime/vm/flow_graph_type_propagator.h |
| @@ -0,0 +1,77 @@ |
| +// Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| +// for details. All rights reserved. Use of this source code is governed by a |
| +// BSD-style license that can be found in the LICENSE file. |
| + |
| +#ifndef VM_FLOW_GRAPH_TYPE_PROPAGATOR_H_ |
| +#define VM_FLOW_GRAPH_TYPE_PROPAGATOR_H_ |
| + |
| +#include "vm/flow_graph.h" |
| +#include "vm/intermediate_language.h" |
| + |
| +namespace dart { |
| + |
| +class FlowGraphTypePropagator : public FlowGraphVisitor { |
| + public: |
| + explicit FlowGraphTypePropagator(FlowGraph* flow_graph); |
| + |
| + void Propagate(); |
| + |
| + private: |
| + void PropagateRecursive(BlockEntryInstr* block); |
| + |
| + void VisitValue(Value* value); |
| + |
| + virtual void VisitJoinEntry(JoinEntryInstr* instr); |
| + virtual void VisitCheckSmi(CheckSmiInstr* instr); |
| + virtual void VisitCheckClass(CheckClassInstr* instr); |
| + |
| + // Current reaching type of the definition. Valid only during dominator tree |
| + // traversal. |
| + CompileType* TypeOf(Definition* def); |
| + |
| + // Mark definition as having given compile type in all dominated instructions. |
| + void SetTypeOf(Definition* def, CompileType* type); |
| + |
| + // Mark definition as having given class id in all dominated instructions. |
| + void SetCid(Definition* value, intptr_t cid); |
| + |
| + void AddToWorklist(Definition* defn); |
| + Definition* RemoveLastFromWorklist(); |
| + |
| + FlowGraph* flow_graph_; |
| + |
| + // Mapping between SSA values and their current reaching types. Valid |
| + // only during dominator tree traversal. |
| + GrowableArray<CompileType*> types_; |
| + |
| + // Worklist for fixpoint computation. |
| + GrowableArray<Definition*> worklist_; |
| + BitVector* in_worklist_; |
| + |
| + // RollbackEntry is used to track and rollback changed in the types_ array |
| + // done during dominator tree traversal. |
| + struct RollbackEntry { |
| + public: |
|
Florian Schneider
2013/02/13 15:39:18
struct has default public members, so you could sa
Vyacheslav Egorov (Google)
2013/02/13 16:18:46
changed to class.
|
| + // Default constructor needed for the container. |
| + RollbackEntry() |
|
Florian Schneider
2013/02/13 15:39:18
Strange line breaks. Maybe all in one line?
Vyacheslav Egorov (Google)
2013/02/13 16:18:46
I wanted it to match the next constructor.
|
| + : index_(), type_() { |
| + } |
| + |
| + RollbackEntry(intptr_t index, CompileType* type) |
| + : index_(index), type_(type) { |
| + } |
| + |
| + intptr_t index() const { return index_; } |
| + CompileType* type() const { return type_; } |
| + |
| + private: |
| + intptr_t index_; |
| + CompileType* type_; |
| + }; |
| + |
| + GrowableArray<RollbackEntry> rollback_; |
| +}; |
| + |
| +} // namespace dart |
| + |
| +#endif // VM_FLOW_GRAPH_TYPE_PROPAGATOR_H_ |