| Index: runtime/vm/intermediate_language.h
|
| diff --git a/runtime/vm/intermediate_language.h b/runtime/vm/intermediate_language.h
|
| index 1d70a291fb7b5f59b0aa6dd7475c2d8e15a2a291..5f3be97cd6c08304c708f3b139d12c6c9b44bae1 100644
|
| --- a/runtime/vm/intermediate_language.h
|
| +++ b/runtime/vm/intermediate_language.h
|
| @@ -77,6 +77,121 @@ RECOGNIZED_LIST(DEFINE_ENUM_LIST)
|
| };
|
|
|
|
|
| +// CompileType describes type of the value produced by the definition.
|
| +//
|
| +// It captures the following properties:
|
| +// - whether value can potentially be null or it is definitely not null;
|
| +// - concrete class id of the value or kDynamicCid if unknown statically;
|
| +// - abstract super type of the value, concrete type of the value in runtime
|
| +// is guaranteed to be sub type of this type.
|
| +//
|
| +// Values of CompileType form a lattice with a None type as a bottom and a
|
| +// nullable Dynamic type as a top element. Method Union provides a join
|
| +// operation for the lattice.
|
| +class CompileType : public ZoneAllocated {
|
| + public:
|
| + static const bool kNullable = true;
|
| + static const bool kNonNullable = false;
|
| +
|
| + // Return type such that concrete value's type in runtime is guaranteed to
|
| + // be subtype of it.
|
| + const AbstractType* ToAbstractType();
|
| +
|
| + // Return class id such that it is either kDynamicCid or in runtime
|
| + // value is guaranteed to have an equal class id.
|
| + intptr_t ToCid();
|
| +
|
| + // Return class id such that it is either kDynamicCid or in runtime
|
| + // value is guaranteed to be either null or have an equal class id.
|
| + intptr_t ToNullableCid();
|
| +
|
| + // Returns true if the value is guaranteed to be not-null or is known to be
|
| + // always null.
|
| + bool HasDecidableNullability();
|
| +
|
| + // Returns true if the value is known to be always null.
|
| + bool IsNull();
|
| +
|
| + // Returns true if this type is more specific than given type.
|
| + bool IsMoreSpecificThan(const AbstractType& other);
|
| +
|
| + // Returns true if value of this type is assignable to a location of the
|
| + // given type.
|
| + bool IsAssignableTo(const AbstractType& type) {
|
| + bool is_instance;
|
| + return CanComputeIsInstanceOf(type, kNullable, &is_instance) &&
|
| + is_instance;
|
| + }
|
| +
|
| + // Create a new CompileType representing given combination of class id and
|
| + // abstract type. The pair is assumed to be coherent.
|
| + static CompileType* New(intptr_t cid, const AbstractType& type);
|
| +
|
| + // Create a new CompileType representing given abstract type. By default
|
| + // values as assumed to be nullable.
|
| + static CompileType* FromAbstractType(const AbstractType& type,
|
| + bool is_nullable = kNullable);
|
| +
|
| + // Create a new CompileType representing an value with the given class id.
|
| + // Resulting CompileType is nullable only if cid is kDynamicCid or kNullCid.
|
| + static CompileType* FromCid(intptr_t cid);
|
| +
|
| + // Create None CompileType. It is the bottom of the lattice and is used to
|
| + // represent type of the phi that was not yet inferred.
|
| + static CompileType* None() {
|
| + return new CompileType(true, kIllegalCid, NULL);
|
| + }
|
| +
|
| + // Create Dynamic CompileType. It is the top of the lattice and is used to
|
| + // represent unknown type.
|
| + static CompileType* Dynamic();
|
| +
|
| + static CompileType* Null();
|
| +
|
| + // Create non-nullable Bool type.
|
| + static CompileType* Bool();
|
| +
|
| + // Create non-nullable Int type.
|
| + static CompileType* Int();
|
| +
|
| + // Perform a join operation over the type lattice.
|
| + void Union(CompileType* other);
|
| +
|
| + // Returns true if this and other types are the same.
|
| + bool IsEqualTo(CompileType* other) {
|
| + return (is_nullable_ == other->is_nullable_) &&
|
| + (ToNullableCid() == other->ToNullableCid()) &&
|
| + (ToAbstractType()->Equals(*other->ToAbstractType()));
|
| + }
|
| +
|
| + // Replaces this type with other.
|
| + void ReplaceWith(CompileType* other) {
|
| + is_nullable_ = other->is_nullable_;
|
| + cid_ = other->cid_;
|
| + type_ = other->type_;
|
| + }
|
| +
|
| + bool IsNone() const {
|
| + return (cid_ == kIllegalCid) && (type_ == NULL);
|
| + }
|
| +
|
| + void PrintTo(BufferFormatter* f) const;
|
| + const char* ToCString() const;
|
| +
|
| + private:
|
| + CompileType(bool is_nullable, intptr_t cid, const AbstractType* type)
|
| + : is_nullable_(is_nullable), cid_(cid), type_(type) { }
|
| +
|
| + bool CanComputeIsInstanceOf(const AbstractType& type,
|
| + bool is_nullable,
|
| + bool* is_instance);
|
| +
|
| + bool is_nullable_;
|
| + intptr_t cid_;
|
| + const AbstractType* type_;
|
| +};
|
| +
|
| +
|
| class Value : public ZoneAllocated {
|
| public:
|
| // A forward iterator that allows removing the current value from the
|
| @@ -102,7 +217,7 @@ class Value : public ZoneAllocated {
|
| next_use_(NULL),
|
| instruction_(NULL),
|
| use_index_(-1),
|
| - reaching_cid_(kIllegalCid) { }
|
| + reaching_type_(NULL) { }
|
|
|
| Definition* definition() const { return definition_; }
|
| void set_definition(Definition* definition) { definition_ = definition; }
|
| @@ -124,8 +239,11 @@ class Value : public ZoneAllocated {
|
|
|
| Value* Copy() { return new Value(definition_); }
|
|
|
| - RawAbstractType* CompileType() const;
|
| - intptr_t ResultCid() const;
|
| + CompileType* Type();
|
| +
|
| + void SetReachingType(CompileType* type) {
|
| + reaching_type_ = type;
|
| + }
|
|
|
| void PrintTo(BufferFormatter* f) const;
|
|
|
| @@ -140,24 +258,12 @@ class Value : public ZoneAllocated {
|
| // Assert if BindsToConstant() is false, otherwise returns the constant value.
|
| const Object& BoundConstant() const;
|
|
|
| - // Compute a run-time null test at compile-time and set result in is_null.
|
| - // Return false if the computation is not possible at compile time.
|
| - bool CanComputeIsNull(bool* is_null) const;
|
| -
|
| - // Compute a run-time type test at compile-time and set result in is_instance.
|
| - // Return false if the computation is not possible at compile time.
|
| - bool CanComputeIsInstanceOf(const AbstractType& type,
|
| - bool* is_instance) const;
|
| -
|
| // Compile time constants, Bool, Smi and Nulls do not need to update
|
| // the store buffer.
|
| - bool NeedsStoreBuffer() const;
|
| + bool NeedsStoreBuffer();
|
|
|
| bool Equals(Value* other) const;
|
|
|
| - void set_reaching_cid(intptr_t cid) { reaching_cid_ = cid; }
|
| - intptr_t reaching_cid() const { return reaching_cid_; }
|
| -
|
| private:
|
| Definition* definition_;
|
| Value* previous_use_;
|
| @@ -165,7 +271,7 @@ class Value : public ZoneAllocated {
|
| Instruction* instruction_;
|
| intptr_t use_index_;
|
|
|
| - intptr_t reaching_cid_;
|
| + CompileType* reaching_type_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(Value);
|
| };
|
| @@ -1094,37 +1200,24 @@ class Definition : public Instruction {
|
|
|
| // Compile time type of the definition, which may be requested before type
|
| // propagation during graph building.
|
| - virtual RawAbstractType* CompileType() const = 0;
|
| -
|
| - virtual intptr_t ResultCid() const = 0;
|
| -
|
| - bool HasPropagatedType() const {
|
| - return !propagated_type_.IsNull();
|
| - }
|
| - RawAbstractType* PropagatedType() const {
|
| - ASSERT(HasPropagatedType());
|
| - return propagated_type_.raw();
|
| - }
|
| - // Returns true if the propagated type has changed.
|
| - bool SetPropagatedType(const AbstractType& propagated_type) {
|
| - if (propagated_type.IsNull()) {
|
| - // Not a typed definition, e.g. access to a VM field.
|
| - return false;
|
| + CompileType* Type() {
|
| + if (type_ == NULL) {
|
| + type_ = ComputeInitialType();
|
| }
|
| - const bool changed =
|
| - propagated_type_.IsNull() || !propagated_type.Equals(propagated_type_);
|
| - propagated_type_ = propagated_type.raw();
|
| - return changed;
|
| + return type_;
|
| }
|
|
|
| - bool has_propagated_cid() const { return propagated_cid_ != kIllegalCid; }
|
| - intptr_t propagated_cid() const { return propagated_cid_; }
|
| -
|
| - // May compute and set propagated cid.
|
| - virtual intptr_t GetPropagatedCid();
|
| + // Compute initial compile type for this definition. It is safe to use this
|
| + // approximation even before type propagator was run (e.g. during graph
|
| + // building).
|
| + virtual CompileType* ComputeInitialType() const {
|
| + return CompileType::Dynamic();
|
| + }
|
|
|
| - // Returns true if the propagated cid has changed.
|
| - bool SetPropagatedCid(intptr_t cid);
|
| + // Update CompileType of the definition. Returns true if the type has changed.
|
| + virtual bool RecomputeType() {
|
| + return false;
|
| + }
|
|
|
| bool HasUses() const {
|
| return (input_use_list_ != NULL) || (env_use_list_ != NULL);
|
| @@ -1193,14 +1286,11 @@ class Definition : public Instruction {
|
| friend class RangeAnalysis;
|
|
|
| Range* range_;
|
| + CompileType* type_;
|
|
|
| private:
|
| intptr_t temp_index_;
|
| intptr_t ssa_temp_index_;
|
| - // TODO(regis): GrowableArray<const AbstractType*> propagated_types_;
|
| - // For now:
|
| - AbstractType& propagated_type_;
|
| - intptr_t propagated_cid_;
|
| Value* input_use_list_;
|
| Value* env_use_list_;
|
| UseKind use_kind_;
|
| @@ -1228,8 +1318,8 @@ class PhiInstr : public Definition {
|
| virtual BlockEntryInstr* GetBlock() const { return block(); }
|
| JoinEntryInstr* block() const { return block_; }
|
|
|
| - virtual RawAbstractType* CompileType() const;
|
| - virtual intptr_t GetPropagatedCid();
|
| + virtual CompileType* ComputeInitialType() const;
|
| + virtual bool RecomputeType();
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| @@ -1243,9 +1333,6 @@ class PhiInstr : public Definition {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - // TODO(regis): This helper will be removed once we support type sets.
|
| - RawAbstractType* LeastSpecificInputType() const;
|
| -
|
| // Phi is alive if it reaches a non-environment use.
|
| bool is_alive() const { return is_alive_; }
|
| void mark_alive() { is_alive_ = true; }
|
| @@ -1268,11 +1355,6 @@ class PhiInstr : public Definition {
|
| return 0;
|
| }
|
|
|
| - virtual intptr_t ResultCid() const {
|
| - UNREACHABLE();
|
| - return kIllegalCid;
|
| - }
|
| -
|
| DECLARE_INSTRUCTION(Phi)
|
|
|
| virtual void PrintTo(BufferFormatter* f) const;
|
| @@ -1313,12 +1395,6 @@ class ParameterInstr : public Definition {
|
| // Get the block entry for that instruction.
|
| virtual BlockEntryInstr* GetBlock() const { return block_; }
|
|
|
| - // Compile type of the passed-in parameter.
|
| - virtual RawAbstractType* CompileType() const;
|
| -
|
| - // No known propagated cid for parameters.
|
| - virtual intptr_t GetPropagatedCid();
|
| -
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| intptr_t InputCount() const { return 0; }
|
| @@ -1337,13 +1413,10 @@ class ParameterInstr : public Definition {
|
| return 0;
|
| }
|
|
|
| - virtual intptr_t ResultCid() const {
|
| - UNREACHABLE();
|
| - return kIllegalCid;
|
| - }
|
| -
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| + virtual CompileType* ComputeInitialType() const;
|
| +
|
| private:
|
| const intptr_t index_;
|
| GraphEntryInstr* block_;
|
| @@ -1373,12 +1446,7 @@ class PushArgumentInstr : public Definition {
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| - virtual RawAbstractType* CompileType() const;
|
| - virtual intptr_t GetPropagatedCid() { return propagated_cid(); }
|
| - virtual intptr_t ResultCid() const {
|
| - UNREACHABLE();
|
| - return kIllegalCid;
|
| - }
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| Value* value() const { return value_; }
|
|
|
| @@ -1599,7 +1667,6 @@ class StoreContextInstr : public TemplateInstruction<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(StoreContext);
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| @@ -1818,16 +1885,12 @@ class ConstraintInstr : public TemplateDefinition<2> {
|
| return (inputs_[1] == NULL) ? 1 : 2;
|
| }
|
|
|
| - virtual RawAbstractType* CompileType() const {
|
| - return Type::SmiType();
|
| - }
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual bool CanDeoptimize() const { return false; }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kSmiCid; }
|
| -
|
| virtual bool AttributesEqual(Instruction* other) const {
|
| UNREACHABLE();
|
| return false;
|
| @@ -1869,7 +1932,7 @@ class ConstantInstr : public TemplateDefinition<0> {
|
| : value_(value) { }
|
|
|
| DECLARE_INSTRUCTION(Constant)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| const Object& value() const { return value_; }
|
|
|
| @@ -1879,8 +1942,6 @@ class ConstantInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| virtual bool AttributesEqual(Instruction* other) const;
|
| virtual bool AffectedBySideEffect() const { return false; }
|
|
|
| @@ -1903,8 +1964,7 @@ class AssertAssignableInstr : public TemplateDefinition<3> {
|
| const String& dst_name)
|
| : token_pos_(token_pos),
|
| dst_type_(AbstractType::ZoneHandle(dst_type.raw())),
|
| - dst_name_(dst_name),
|
| - is_eliminated_(false) {
|
| + dst_name_(dst_name) {
|
| ASSERT(value != NULL);
|
| ASSERT(instantiator != NULL);
|
| ASSERT(instantiator_type_arguments != NULL);
|
| @@ -1916,7 +1976,8 @@ class AssertAssignableInstr : public TemplateDefinition<3> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(AssertAssignable)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
| + virtual bool RecomputeType();
|
|
|
| Value* value() const { return inputs_[0]; }
|
| Value* instantiator() const { return inputs_[1]; }
|
| @@ -1929,14 +1990,6 @@ class AssertAssignableInstr : public TemplateDefinition<3> {
|
| }
|
| const String& dst_name() const { return dst_name_; }
|
|
|
| - bool is_eliminated() const {
|
| - return is_eliminated_;
|
| - }
|
| - void eliminate() {
|
| - ASSERT(!is_eliminated_);
|
| - is_eliminated_ = true;
|
| - }
|
| -
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| virtual bool CanDeoptimize() const { return true; }
|
| @@ -1946,16 +1999,12 @@ class AssertAssignableInstr : public TemplateDefinition<3> {
|
| virtual bool AffectedBySideEffect() const { return false; }
|
| virtual bool AttributesEqual(Instruction* other) const;
|
|
|
| - virtual intptr_t ResultCid() const { return value()->ResultCid(); }
|
| - virtual intptr_t GetPropagatedCid();
|
| -
|
| virtual Definition* Canonicalize(FlowGraphOptimizer* optimizer);
|
|
|
| private:
|
| const intptr_t token_pos_;
|
| AbstractType& dst_type_;
|
| const String& dst_name_;
|
| - bool is_eliminated_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(AssertAssignableInstr);
|
| };
|
| @@ -1964,26 +2013,17 @@ class AssertAssignableInstr : public TemplateDefinition<3> {
|
| class AssertBooleanInstr : public TemplateDefinition<1> {
|
| public:
|
| AssertBooleanInstr(intptr_t token_pos, Value* value)
|
| - : token_pos_(token_pos),
|
| - is_eliminated_(false) {
|
| + : token_pos_(token_pos) {
|
| ASSERT(value != NULL);
|
| inputs_[0] = value;
|
| }
|
|
|
| DECLARE_INSTRUCTION(AssertBoolean)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| intptr_t token_pos() const { return token_pos_; }
|
| Value* value() const { return inputs_[0]; }
|
|
|
| - bool is_eliminated() const {
|
| - return is_eliminated_;
|
| - }
|
| - void eliminate() {
|
| - ASSERT(!is_eliminated_);
|
| - is_eliminated_ = true;
|
| - }
|
| -
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| virtual bool CanDeoptimize() const { return true; }
|
| @@ -1993,13 +2033,10 @@ class AssertBooleanInstr : public TemplateDefinition<1> {
|
| virtual bool AffectedBySideEffect() const { return false; }
|
| virtual bool AttributesEqual(Instruction* other) const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kBoolCid; }
|
| -
|
| virtual Definition* Canonicalize(FlowGraphOptimizer* optimizer);
|
|
|
| private:
|
| const intptr_t token_pos_;
|
| - bool is_eliminated_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(AssertBooleanInstr);
|
| };
|
| @@ -2015,7 +2052,7 @@ class ArgumentDefinitionTestInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(ArgumentDefinitionTest)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| intptr_t token_pos() const { return ast_node_.token_pos(); }
|
| intptr_t formal_parameter_index() const {
|
| @@ -2024,6 +2061,7 @@ class ArgumentDefinitionTestInstr : public TemplateDefinition<1> {
|
| const String& formal_parameter_name() const {
|
| return ast_node_.formal_parameter_name();
|
| }
|
| +
|
| Value* saved_arguments_descriptor() const { return inputs_[0]; }
|
|
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
| @@ -2032,8 +2070,6 @@ class ArgumentDefinitionTestInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kBoolCid; }
|
| -
|
| private:
|
| const ArgumentDefinitionTestNode& ast_node_;
|
|
|
| @@ -2048,14 +2084,12 @@ class CurrentContextInstr : public TemplateDefinition<0> {
|
| CurrentContextInstr() { }
|
|
|
| DECLARE_INSTRUCTION(CurrentContext)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual bool CanDeoptimize() const { return false; }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| DISALLOW_COPY_AND_ASSIGN(CurrentContextInstr);
|
| };
|
| @@ -2069,7 +2103,6 @@ class ClosureCallInstr : public TemplateDefinition<0> {
|
| arguments_(arguments) { }
|
|
|
| DECLARE_INSTRUCTION(ClosureCall)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| const Array& argument_names() const { return ast_node_.arguments()->names(); }
|
| intptr_t token_pos() const { return ast_node_.token_pos(); }
|
| @@ -2085,8 +2118,6 @@ class ClosureCallInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const ClosureCallNode& ast_node_;
|
| ZoneGrowableArray<PushArgumentInstr*>* arguments_;
|
| @@ -2123,7 +2154,6 @@ class InstanceCallInstr : public TemplateDefinition<0> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(InstanceCall)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| const ICData* ic_data() const { return ic_data_; }
|
| bool HasICData() const {
|
| @@ -2149,8 +2179,6 @@ class InstanceCallInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| protected:
|
| friend class FlowGraphOptimizer;
|
| void set_ic_data(ICData* value) { ic_data_ = value; }
|
| @@ -2190,7 +2218,6 @@ class PolymorphicInstanceCallInstr : public TemplateDefinition<0> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(PolymorphicInstanceCall)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| const ICData& ic_data() const { return ic_data_; }
|
|
|
| @@ -2198,8 +2225,6 @@ class PolymorphicInstanceCallInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| private:
|
| @@ -2296,7 +2321,7 @@ class StrictCompareInstr : public ComparisonInstr {
|
| StrictCompareInstr(Token::Kind kind, Value* left, Value* right);
|
|
|
| DECLARE_INSTRUCTION(StrictCompare)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| @@ -2309,8 +2334,6 @@ class StrictCompareInstr : public ComparisonInstr {
|
|
|
| virtual Definition* Canonicalize(FlowGraphOptimizer* optimizer);
|
|
|
| - virtual intptr_t ResultCid() const { return kBoolCid; }
|
| -
|
| virtual void EmitBranchCode(FlowGraphCompiler* compiler,
|
| BranchInstr* branch);
|
|
|
| @@ -2341,7 +2364,7 @@ class EqualityCompareInstr : public ComparisonInstr {
|
| }
|
|
|
| DECLARE_INSTRUCTION(EqualityCompare)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| const ICData* ic_data() const { return ic_data_; }
|
| bool HasICData() const {
|
| @@ -2354,21 +2377,22 @@ class EqualityCompareInstr : public ComparisonInstr {
|
| void set_receiver_class_id(intptr_t value) { receiver_class_id_ = value; }
|
| intptr_t receiver_class_id() const { return receiver_class_id_; }
|
|
|
| + bool IsInlinedNumericComparison() const {
|
| + return (receiver_class_id() == kDoubleCid)
|
| + || (receiver_class_id() == kMintCid)
|
| + || (receiver_class_id() == kSmiCid);
|
| + }
|
| +
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| virtual bool CanDeoptimize() const {
|
| - return (receiver_class_id() != kDoubleCid)
|
| - && (receiver_class_id() != kMintCid)
|
| - && (receiver_class_id() != kSmiCid);
|
| + return !IsInlinedNumericComparison();
|
| }
|
| +
|
| virtual bool HasSideEffect() const {
|
| - return (receiver_class_id() != kDoubleCid)
|
| - && (receiver_class_id() != kMintCid)
|
| - && (receiver_class_id() != kSmiCid);
|
| + return !IsInlinedNumericComparison();
|
| }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| virtual void EmitBranchCode(FlowGraphCompiler* compiler,
|
| BranchInstr* branch);
|
|
|
| @@ -2409,7 +2433,7 @@ class RelationalOpInstr : public ComparisonInstr {
|
| }
|
|
|
| DECLARE_INSTRUCTION(RelationalOp)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| const ICData* ic_data() const { return ic_data_; }
|
| bool HasICData() const {
|
| @@ -2426,21 +2450,21 @@ class RelationalOpInstr : public ComparisonInstr {
|
|
|
| intptr_t operands_class_id() const { return operands_class_id_; }
|
|
|
| + bool IsInlinedNumericComparison() const {
|
| + return (operands_class_id() == kDoubleCid)
|
| + || (operands_class_id() == kMintCid)
|
| + || (operands_class_id() == kSmiCid);
|
| + }
|
| +
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| virtual bool CanDeoptimize() const {
|
| - return (operands_class_id() != kDoubleCid)
|
| - && (operands_class_id() != kMintCid)
|
| - && (operands_class_id() != kSmiCid);
|
| + return !IsInlinedNumericComparison();
|
| }
|
| virtual bool HasSideEffect() const {
|
| - return (operands_class_id() != kDoubleCid)
|
| - && (operands_class_id() != kMintCid)
|
| - && (operands_class_id() != kSmiCid);
|
| + return !IsInlinedNumericComparison();
|
| }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| virtual void EmitBranchCode(FlowGraphCompiler* compiler,
|
| BranchInstr* branch);
|
|
|
| @@ -2482,7 +2506,7 @@ class StaticCallInstr : public TemplateDefinition<0> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(StaticCall)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| // Accessors forwarded to the AST node.
|
| const Function& function() const { return function_; }
|
| @@ -2500,7 +2524,6 @@ class StaticCallInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return result_cid_; }
|
| void set_result_cid(intptr_t value) { result_cid_ = value; }
|
|
|
| bool is_known_constructor() const { return is_known_constructor_; }
|
| @@ -2518,7 +2541,6 @@ class StaticCallInstr : public TemplateDefinition<0> {
|
| // Some library constructors have known semantics.
|
| bool is_known_constructor_;
|
|
|
| -
|
| DISALLOW_COPY_AND_ASSIGN(StaticCallInstr);
|
| };
|
|
|
| @@ -2530,7 +2552,7 @@ class LoadLocalInstr : public TemplateDefinition<0> {
|
| context_level_(context_level) { }
|
|
|
| DECLARE_INSTRUCTION(LoadLocal)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| const LocalVariable& local() const { return local_; }
|
| intptr_t context_level() const { return context_level_; }
|
| @@ -2544,8 +2566,6 @@ class LoadLocalInstr : public TemplateDefinition<0> {
|
| return false;
|
| }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const LocalVariable& local_;
|
| const intptr_t context_level_;
|
| @@ -2566,7 +2586,7 @@ class StoreLocalInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(StoreLocal)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| const LocalVariable& local() const { return local_; }
|
| Value* value() const { return inputs_[0]; }
|
| @@ -2584,8 +2604,6 @@ class StoreLocalInstr : public TemplateDefinition<1> {
|
| return false;
|
| }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const LocalVariable& local_;
|
| const intptr_t context_level_;
|
| @@ -2600,7 +2618,6 @@ class NativeCallInstr : public TemplateDefinition<0> {
|
| : ast_node_(*node) {}
|
|
|
| DECLARE_INSTRUCTION(NativeCall)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| intptr_t token_pos() const { return ast_node_.token_pos(); }
|
|
|
| @@ -2620,8 +2637,6 @@ class NativeCallInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const NativeBodyNode& ast_node_;
|
|
|
| @@ -2643,7 +2658,7 @@ class StoreInstanceFieldInstr : public TemplateDefinition<2> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(StoreInstanceField)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| const Field& field() const { return field_; }
|
|
|
| @@ -2659,8 +2674,6 @@ class StoreInstanceFieldInstr : public TemplateDefinition<2> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const Field& field_;
|
| const bool emit_store_barrier_;
|
| @@ -2674,7 +2687,7 @@ class LoadStaticFieldInstr : public TemplateDefinition<0> {
|
| explicit LoadStaticFieldInstr(const Field& field) : field_(field) {}
|
|
|
| DECLARE_INSTRUCTION(LoadStaticField);
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| const Field& field() const { return field_; }
|
|
|
| @@ -2684,8 +2697,6 @@ class LoadStaticFieldInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| virtual bool AffectedBySideEffect() const { return !field().is_final(); }
|
| virtual bool AttributesEqual(Instruction* other) const;
|
|
|
| @@ -2706,7 +2717,7 @@ class StoreStaticFieldInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(StoreStaticField);
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| const Field& field() const { return field_; }
|
| Value* value() const { return inputs_[0]; }
|
| @@ -2717,8 +2728,6 @@ class StoreStaticFieldInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const Field& field_;
|
|
|
| @@ -2742,7 +2751,7 @@ class LoadIndexedInstr : public TemplateDefinition<2> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(LoadIndexed)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| Value* array() const { return inputs_[0]; }
|
| Value* index() const { return inputs_[1]; }
|
| @@ -2755,8 +2764,6 @@ class LoadIndexedInstr : public TemplateDefinition<2> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| virtual Representation representation() const;
|
|
|
| virtual bool AttributesEqual(Instruction* other) const;
|
| @@ -2785,7 +2792,7 @@ class StringFromCharCodeInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(StringFromCharCode)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| Value* char_code() const { return inputs_[0]; }
|
|
|
| @@ -2793,8 +2800,6 @@ class StringFromCharCodeInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return cid_; }
|
| -
|
| virtual bool AttributesEqual(Instruction* other) const { return true; }
|
|
|
| virtual bool AffectedBySideEffect() const { return false; }
|
| @@ -2826,7 +2831,6 @@ class StoreIndexedInstr : public TemplateDefinition<3> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(StoreIndexed)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| Value* array() const { return inputs_[0]; }
|
| Value* index() const { return inputs_[1]; }
|
| @@ -2841,8 +2845,6 @@ class StoreIndexedInstr : public TemplateDefinition<3> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| virtual Representation RequiredInputRepresentation(intptr_t idx) const;
|
|
|
| virtual intptr_t DeoptimizationTarget() const {
|
| @@ -2869,7 +2871,7 @@ class BooleanNegateInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(BooleanNegate)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| Value* value() const { return inputs_[0]; }
|
|
|
| @@ -2877,8 +2879,6 @@ class BooleanNegateInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kBoolCid; }
|
| -
|
| private:
|
| DISALLOW_COPY_AND_ASSIGN(BooleanNegateInstr);
|
| };
|
| @@ -2905,7 +2905,7 @@ class InstanceOfInstr : public TemplateDefinition<3> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(InstanceOf)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| Value* value() const { return inputs_[0]; }
|
| Value* instantiator() const { return inputs_[1]; }
|
| @@ -2921,8 +2921,6 @@ class InstanceOfInstr : public TemplateDefinition<3> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kBoolCid; }
|
| -
|
| private:
|
| const intptr_t token_pos_;
|
| Value* value_;
|
| @@ -2947,7 +2945,7 @@ class AllocateObjectInstr : public TemplateDefinition<0> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(AllocateObject)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return arguments_->length(); }
|
| PushArgumentInstr* ArgumentAt(intptr_t index) const {
|
| @@ -2963,8 +2961,6 @@ class AllocateObjectInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return cid_; }
|
| -
|
| private:
|
| const ConstructorCallNode& ast_node_;
|
| ZoneGrowableArray<PushArgumentInstr*>* const arguments_;
|
| @@ -2987,7 +2983,6 @@ class AllocateObjectWithBoundsCheckInstr : public TemplateDefinition<2> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(AllocateObjectWithBoundsCheck)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| const Function& constructor() const { return ast_node_.constructor(); }
|
| intptr_t token_pos() const { return ast_node_.token_pos(); }
|
| @@ -2998,8 +2993,6 @@ class AllocateObjectWithBoundsCheckInstr : public TemplateDefinition<2> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const ConstructorCallNode& ast_node_;
|
|
|
| @@ -3029,7 +3022,7 @@ class CreateArrayInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(CreateArray)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return arguments_->length(); }
|
|
|
| @@ -3044,8 +3037,6 @@ class CreateArrayInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kArrayCid; }
|
| -
|
| private:
|
| const intptr_t token_pos_;
|
| ZoneGrowableArray<PushArgumentInstr*>* const arguments_;
|
| @@ -3065,7 +3056,7 @@ class CreateClosureInstr : public TemplateDefinition<0> {
|
| token_pos_(token_pos) { }
|
|
|
| DECLARE_INSTRUCTION(CreateClosure)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| intptr_t token_pos() const { return token_pos_; }
|
| const Function& function() const { return function_; }
|
| @@ -3081,8 +3072,6 @@ class CreateClosureInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const Function& function_;
|
| ZoneGrowableArray<PushArgumentInstr*>* arguments_;
|
| @@ -3109,7 +3098,7 @@ class LoadFieldInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(LoadField)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| Value* value() const { return inputs_[0]; }
|
| intptr_t offset_in_bytes() const { return offset_in_bytes_; }
|
| @@ -3122,8 +3111,6 @@ class LoadFieldInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return result_cid_; }
|
| -
|
| virtual bool AttributesEqual(Instruction* other) const;
|
|
|
| virtual bool AffectedBySideEffect() const { return !immutable_; }
|
| @@ -3171,7 +3158,7 @@ class StoreVMFieldInstr : public TemplateDefinition<2> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(StoreVMField)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| Value* value() const { return inputs_[0]; }
|
| Value* dest() const { return inputs_[1]; }
|
| @@ -3184,8 +3171,6 @@ class StoreVMFieldInstr : public TemplateDefinition<2> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const intptr_t offset_in_bytes_;
|
| const AbstractType& type_;
|
| @@ -3207,7 +3192,6 @@ class InstantiateTypeArgumentsInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(InstantiateTypeArguments)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| Value* instantiator() const { return inputs_[0]; }
|
| const AbstractTypeArguments& type_arguments() const {
|
| @@ -3221,8 +3205,6 @@ class InstantiateTypeArgumentsInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const intptr_t token_pos_;
|
| const AbstractTypeArguments& type_arguments_;
|
| @@ -3244,7 +3226,6 @@ class ExtractConstructorTypeArgumentsInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(ExtractConstructorTypeArguments)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| Value* instantiator() const { return inputs_[0]; }
|
| const AbstractTypeArguments& type_arguments() const {
|
| @@ -3258,8 +3239,6 @@ class ExtractConstructorTypeArgumentsInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const intptr_t token_pos_;
|
| const AbstractTypeArguments& type_arguments_;
|
| @@ -3278,7 +3257,6 @@ class ExtractConstructorInstantiatorInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(ExtractConstructorInstantiator)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| Value* instantiator() const { return inputs_[0]; }
|
| const AbstractTypeArguments& type_arguments() const {
|
| @@ -3291,8 +3269,6 @@ class ExtractConstructorInstantiatorInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const ConstructorCallNode& ast_node_;
|
|
|
| @@ -3308,7 +3284,7 @@ class AllocateContextInstr : public TemplateDefinition<0> {
|
| num_context_variables_(num_context_variables) {}
|
|
|
| DECLARE_INSTRUCTION(AllocateContext);
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| intptr_t token_pos() const { return token_pos_; }
|
| intptr_t num_context_variables() const { return num_context_variables_; }
|
| @@ -3319,8 +3295,6 @@ class AllocateContextInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| const intptr_t token_pos_;
|
| const intptr_t num_context_variables_;
|
| @@ -3337,7 +3311,6 @@ class ChainContextInstr : public TemplateInstruction<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(ChainContext)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| @@ -3364,14 +3337,12 @@ class CloneContextInstr : public TemplateDefinition<1> {
|
| Value* context_value() const { return inputs_[0]; }
|
|
|
| DECLARE_INSTRUCTION(CloneContext)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual bool CanDeoptimize() const { return true; }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kContextCid; }
|
| -
|
| private:
|
| const intptr_t token_pos_;
|
|
|
| @@ -3389,7 +3360,6 @@ class CatchEntryInstr : public TemplateInstruction<0> {
|
| const LocalVariable& stacktrace_var() const { return stacktrace_var_; }
|
|
|
| DECLARE_INSTRUCTION(CatchEntry)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| @@ -3420,7 +3390,6 @@ class CheckEitherNonSmiInstr : public TemplateInstruction<2> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(CheckEitherNonSmi)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| @@ -3462,15 +3431,13 @@ class BoxDoubleInstr : public TemplateDefinition<1> {
|
| virtual bool AffectedBySideEffect() const { return false; }
|
| virtual bool AttributesEqual(Instruction* other) const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| virtual Representation RequiredInputRepresentation(intptr_t idx) const {
|
| ASSERT(idx == 0);
|
| return kUnboxedDouble;
|
| }
|
|
|
| DECLARE_INSTRUCTION(BoxDouble)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| private:
|
| const intptr_t token_pos_;
|
| @@ -3495,15 +3462,13 @@ class BoxIntegerInstr : public TemplateDefinition<1> {
|
| virtual bool AffectedBySideEffect() const { return false; }
|
| virtual bool AttributesEqual(Instruction* other) const { return true; }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| virtual Representation RequiredInputRepresentation(intptr_t idx) const {
|
| ASSERT(idx == 0);
|
| return kUnboxedMint;
|
| }
|
|
|
| DECLARE_INSTRUCTION(BoxInteger)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| private:
|
| DISALLOW_COPY_AND_ASSIGN(BoxIntegerInstr);
|
| @@ -3521,15 +3486,12 @@ class UnboxDoubleInstr : public TemplateDefinition<1> {
|
| Value* value() const { return inputs_[0]; }
|
|
|
| virtual bool CanDeoptimize() const {
|
| - return (value()->ResultCid() != kDoubleCid)
|
| - && (value()->ResultCid() != kSmiCid);
|
| + return (value()->Type()->ToCid() != kDoubleCid)
|
| + && (value()->Type()->ToCid() != kSmiCid);
|
| }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - // The output is not an instance but when it is boxed it becomes double.
|
| - virtual intptr_t ResultCid() const { return kDoubleCid; }
|
| -
|
| virtual Representation representation() const {
|
| return kUnboxedDouble;
|
| }
|
| @@ -3538,7 +3500,7 @@ class UnboxDoubleInstr : public TemplateDefinition<1> {
|
| virtual bool AttributesEqual(Instruction* other) const { return true; }
|
|
|
| DECLARE_INSTRUCTION(UnboxDouble)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| private:
|
| DISALLOW_COPY_AND_ASSIGN(UnboxDoubleInstr);
|
| @@ -3556,15 +3518,13 @@ class UnboxIntegerInstr : public TemplateDefinition<1> {
|
| Value* value() const { return inputs_[0]; }
|
|
|
| virtual bool CanDeoptimize() const {
|
| - return (value()->ResultCid() != kMintCid)
|
| - && (value()->ResultCid() != kSmiCid);
|
| + return (value()->Type()->ToCid() != kSmiCid)
|
| + && (value()->Type()->ToCid() != kMintCid);
|
| }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual Representation representation() const {
|
| return kUnboxedMint;
|
| @@ -3599,9 +3559,6 @@ class MathSqrtInstr : public TemplateDefinition<1> {
|
| return true;
|
| }
|
|
|
| - // The output is not an instance but when it is boxed it becomes double.
|
| - virtual intptr_t ResultCid() const { return kDoubleCid; }
|
| -
|
| virtual Representation representation() const {
|
| return kUnboxedDouble;
|
| }
|
| @@ -3618,7 +3575,7 @@ class MathSqrtInstr : public TemplateDefinition<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(MathSqrt)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| private:
|
| DISALLOW_COPY_AND_ASSIGN(MathSqrtInstr);
|
| @@ -3656,8 +3613,6 @@ class BinaryDoubleOpInstr : public TemplateDefinition<2> {
|
| return op_kind() == other->AsBinaryDoubleOp()->op_kind();
|
| }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| virtual Representation representation() const {
|
| return kUnboxedDouble;
|
| }
|
| @@ -3674,7 +3629,7 @@ class BinaryDoubleOpInstr : public TemplateDefinition<2> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(BinaryDoubleOp)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual Definition* Canonicalize(FlowGraphOptimizer* optimizer);
|
|
|
| @@ -3718,8 +3673,7 @@ class BinaryMintOpInstr : public TemplateDefinition<2> {
|
| return op_kind() == other->AsBinaryMintOp()->op_kind();
|
| }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual Representation representation() const {
|
| return kUnboxedMint;
|
| @@ -3779,8 +3733,7 @@ class ShiftMintOpInstr : public TemplateDefinition<2> {
|
| return op_kind() == other->AsShiftMintOp()->op_kind();
|
| }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual Representation representation() const {
|
| return kUnboxedMint;
|
| @@ -3834,8 +3787,7 @@ class UnaryMintOpInstr : public TemplateDefinition<1> {
|
| return op_kind() == other->AsUnaryMintOp()->op_kind();
|
| }
|
|
|
| - virtual intptr_t ResultCid() const;
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual Representation representation() const {
|
| return kUnboxedMint;
|
| @@ -3890,7 +3842,7 @@ class BinarySmiOpInstr : public TemplateDefinition<2> {
|
|
|
| DECLARE_INSTRUCTION(BinarySmiOp)
|
|
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual bool CanDeoptimize() const;
|
|
|
| @@ -3899,8 +3851,6 @@ class BinarySmiOpInstr : public TemplateDefinition<2> {
|
| virtual bool AffectedBySideEffect() const { return false; }
|
| virtual bool AttributesEqual(Instruction* other) const;
|
|
|
| - virtual intptr_t ResultCid() const;
|
| -
|
| void set_overflow(bool overflow) {
|
| overflow_ = overflow;
|
| }
|
| @@ -3943,14 +3893,12 @@ class UnarySmiOpInstr : public TemplateDefinition<1> {
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| DECLARE_INSTRUCTION(UnarySmiOp)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual bool CanDeoptimize() const { return op_kind() == Token::kNEGATE; }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kSmiCid; }
|
| -
|
| private:
|
| const Token::Kind op_kind_;
|
|
|
| @@ -3966,7 +3914,6 @@ class CheckStackOverflowInstr : public TemplateInstruction<0> {
|
| intptr_t token_pos() const { return token_pos_; }
|
|
|
| DECLARE_INSTRUCTION(CheckStackOverflow)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| @@ -3989,7 +3936,7 @@ class SmiToDoubleInstr : public TemplateDefinition<0> {
|
| InstanceCallInstr* instance_call() const { return instance_call_; }
|
|
|
| DECLARE_INSTRUCTION(SmiToDouble)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 1; }
|
|
|
| @@ -3997,8 +3944,6 @@ class SmiToDoubleInstr : public TemplateDefinition<0> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDoubleCid; }
|
| -
|
| private:
|
| InstanceCallInstr* instance_call_;
|
|
|
| @@ -4018,7 +3963,7 @@ class DoubleToIntegerInstr : public TemplateDefinition<1> {
|
| InstanceCallInstr* instance_call() const { return instance_call_; }
|
|
|
| DECLARE_INSTRUCTION(DoubleToInteger)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 1; }
|
|
|
| @@ -4026,9 +3971,6 @@ class DoubleToIntegerInstr : public TemplateDefinition<1> {
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - // Result could be any of the int types.
|
| - virtual intptr_t ResultCid() const { return kDynamicCid; }
|
| -
|
| private:
|
| InstanceCallInstr* instance_call_;
|
|
|
| @@ -4049,14 +3991,12 @@ class DoubleToSmiInstr : public TemplateDefinition<1> {
|
| Value* value() const { return inputs_[0]; }
|
|
|
| DECLARE_INSTRUCTION(DoubleToSmi)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual bool CanDeoptimize() const { return true; }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kSmiCid; }
|
| -
|
| virtual Representation RequiredInputRepresentation(intptr_t idx) const {
|
| ASSERT(idx == 0);
|
| return kUnboxedDouble;
|
| @@ -4085,14 +4025,12 @@ class DoubleToDoubleInstr : public TemplateDefinition<1> {
|
| MethodRecognizer::Kind recognized_kind() const { return recognized_kind_; }
|
|
|
| DECLARE_INSTRUCTION(DoubleToDouble)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
|
|
| virtual bool CanDeoptimize() const { return false; }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDoubleCid; }
|
| -
|
| virtual Representation representation() const {
|
| return kUnboxedDouble;
|
| }
|
| @@ -4128,15 +4066,13 @@ class InvokeMathCFunctionInstr : public Definition {
|
| MethodRecognizer::Kind recognized_kind() const { return recognized_kind_; }
|
|
|
| DECLARE_INSTRUCTION(InvokeMathCFunction)
|
| - virtual RawAbstractType* CompileType() const;
|
| + virtual CompileType* ComputeInitialType() const;
|
| virtual void PrintOperandsTo(BufferFormatter* f) const;
|
|
|
| virtual bool CanDeoptimize() const { return false; }
|
|
|
| virtual bool HasSideEffect() const { return false; }
|
|
|
| - virtual intptr_t ResultCid() const { return kDoubleCid; }
|
| -
|
| virtual Representation representation() const {
|
| return kUnboxedDouble;
|
| }
|
| @@ -4188,7 +4124,6 @@ class CheckClassInstr : public TemplateInstruction<1> {
|
| const ICData& unary_checks);
|
|
|
| DECLARE_INSTRUCTION(CheckClass)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| @@ -4225,7 +4160,6 @@ class CheckSmiInstr : public TemplateInstruction<1> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(CheckSmi)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
| @@ -4261,7 +4195,6 @@ class CheckArrayBoundInstr : public TemplateInstruction<2> {
|
| }
|
|
|
| DECLARE_INSTRUCTION(CheckArrayBound)
|
| - virtual RawAbstractType* CompileType() const;
|
|
|
| virtual intptr_t ArgumentCount() const { return 0; }
|
|
|
|
|