Index: src/compiler/js-operator.h |
diff --git a/src/compiler/js-operator.h b/src/compiler/js-operator.h |
index cfc46738d6673eb5c689d2bc286b1c059c4da02e..222383f0eced94d69eb71b0772e1bca93b9e93e6 100644 |
--- a/src/compiler/js-operator.h |
+++ b/src/compiler/js-operator.h |
@@ -17,23 +17,56 @@ class Operator; |
struct JSOperatorGlobalCache; |
+// Defines a pair of {TypeFeedbackVector} and {TypeFeedbackVectorICSlot}, which |
+// is used to access the type feedback for a certain {Node}. |
+class VectorSlotPair { |
+ public: |
+ VectorSlotPair() : slot_(FeedbackVectorICSlot::Invalid()) {} |
+ VectorSlotPair(Handle<TypeFeedbackVector> vector, FeedbackVectorICSlot slot) |
+ : vector_(vector), slot_(slot) {} |
+ |
+ bool IsValid() const { return !vector_.is_null(); } |
+ |
+ MaybeHandle<TypeFeedbackVector> vector() const { return vector_; } |
+ FeedbackVectorICSlot slot() const { return slot_; } |
+ |
+ int index() const { |
+ Handle<TypeFeedbackVector> vector; |
+ return vector_.ToHandle(&vector) ? vector->GetIndex(slot_) : -1; |
+ } |
+ |
+ private: |
+ const MaybeHandle<TypeFeedbackVector> vector_; |
+ const FeedbackVectorICSlot slot_; |
+}; |
+ |
+bool operator==(VectorSlotPair const&, VectorSlotPair const&); |
+bool operator!=(VectorSlotPair const&, VectorSlotPair const&); |
+ |
+size_t hash_value(VectorSlotPair const&); |
+ |
+ |
// Defines the arity and the call flags for a JavaScript function call. This is |
// used as a parameter by JSCallFunction operators. |
class CallFunctionParameters final { |
public: |
CallFunctionParameters(size_t arity, CallFunctionFlags flags, |
- LanguageMode language_mode) |
+ LanguageMode language_mode, |
+ VectorSlotPair const& feedback) |
: bit_field_(ArityField::encode(arity) | FlagsField::encode(flags) | |
- LanguageModeField::encode(language_mode)) {} |
+ LanguageModeField::encode(language_mode)), |
+ feedback_(feedback) {} |
size_t arity() const { return ArityField::decode(bit_field_); } |
CallFunctionFlags flags() const { return FlagsField::decode(bit_field_); } |
LanguageMode language_mode() const { |
return LanguageModeField::decode(bit_field_); |
} |
+ VectorSlotPair const& feedback() const { return feedback_; } |
bool operator==(CallFunctionParameters const& that) const { |
- return this->bit_field_ == that.bit_field_; |
+ return this->bit_field_ == that.bit_field_ && |
+ this->feedback_ == that.feedback_; |
} |
bool operator!=(CallFunctionParameters const& that) const { |
return !(*this == that); |
@@ -41,7 +74,7 @@ class CallFunctionParameters final { |
private: |
friend size_t hash_value(CallFunctionParameters const& p) { |
- return p.bit_field_; |
+ return base::hash_combine(p.bit_field_, p.feedback_); |
} |
typedef BitField<size_t, 0, 28> ArityField; |
@@ -49,6 +82,7 @@ class CallFunctionParameters final { |
typedef BitField<LanguageMode, 30, 2> LanguageModeField; |
const uint32_t bit_field_; |
+ const VectorSlotPair feedback_; |
}; |
size_t hash_value(CallFunctionParameters const&); |
@@ -112,42 +146,17 @@ std::ostream& operator<<(std::ostream&, ContextAccess const&); |
ContextAccess const& ContextAccessOf(Operator const*); |
-// A ResolvedFeedbackSlot needs to query the type feedback vector to get it's |
-// index in the vector. |
-class ResolvedFeedbackSlot { |
- public: |
- ResolvedFeedbackSlot(Handle<TypeFeedbackVector> vector, |
- FeedbackVectorICSlot slot) |
- : slot_(slot), |
- index_(slot == FeedbackVectorICSlot::Invalid() ? -1 : vector->GetIndex( |
- slot)) {} |
- ResolvedFeedbackSlot() : slot_(FeedbackVectorICSlot::Invalid()), index_(-1) {} |
- |
- FeedbackVectorICSlot slot() const { return slot_; } |
- int index() const { return index_; } |
- |
- private: |
- const FeedbackVectorICSlot slot_; |
- const int index_; |
-}; |
- |
- |
-bool operator==(ResolvedFeedbackSlot const& lhs, |
- ResolvedFeedbackSlot const& rhs); |
- |
- |
// Defines the name for a dynamic variable lookup. The {check_bitset} allows to |
// inline checks whether the lookup yields in a global variable. This is used as |
// a parameter by JSLoadDynamicGlobal and JSStoreDynamicGlobal operators. |
class DynamicGlobalAccess final { |
public: |
DynamicGlobalAccess(const Handle<String>& name, uint32_t check_bitset, |
- const ResolvedFeedbackSlot& feedback, |
- ContextualMode mode); |
+ const VectorSlotPair& feedback, ContextualMode mode); |
const Handle<String>& name() const { return name_; } |
uint32_t check_bitset() const { return check_bitset_; } |
- const ResolvedFeedbackSlot& feedback() const { return feedback_; } |
+ const VectorSlotPair& feedback() const { return feedback_; } |
ContextualMode mode() const { return mode_; } |
// Indicates that an inline check is disabled. |
@@ -164,7 +173,7 @@ class DynamicGlobalAccess final { |
private: |
const Handle<String> name_; |
const uint32_t check_bitset_; |
- const ResolvedFeedbackSlot feedback_; |
+ const VectorSlotPair feedback_; |
const ContextualMode mode_; |
}; |
@@ -221,19 +230,18 @@ DynamicContextAccess const& DynamicContextAccessOf(Operator const*); |
// used as a parameter by JSLoadNamed operators. |
class LoadNamedParameters final { |
public: |
- LoadNamedParameters(const Unique<Name>& name, |
- const ResolvedFeedbackSlot& feedback, |
+ LoadNamedParameters(const Unique<Name>& name, const VectorSlotPair& feedback, |
ContextualMode contextual_mode) |
: name_(name), feedback_(feedback), contextual_mode_(contextual_mode) {} |
const Unique<Name>& name() const { return name_; } |
ContextualMode contextual_mode() const { return contextual_mode_; } |
- const ResolvedFeedbackSlot& feedback() const { return feedback_; } |
+ const VectorSlotPair& feedback() const { return feedback_; } |
private: |
const Unique<Name> name_; |
- const ResolvedFeedbackSlot feedback_; |
+ const VectorSlotPair feedback_; |
const ContextualMode contextual_mode_; |
}; |
@@ -251,13 +259,13 @@ const LoadNamedParameters& LoadNamedParametersOf(const Operator* op); |
// used as a parameter by JSLoadProperty operators. |
class LoadPropertyParameters final { |
public: |
- explicit LoadPropertyParameters(const ResolvedFeedbackSlot& feedback) |
+ explicit LoadPropertyParameters(const VectorSlotPair& feedback) |
: feedback_(feedback) {} |
- const ResolvedFeedbackSlot& feedback() const { return feedback_; } |
+ const VectorSlotPair& feedback() const { return feedback_; } |
private: |
- const ResolvedFeedbackSlot feedback_; |
+ const VectorSlotPair feedback_; |
}; |
bool operator==(LoadPropertyParameters const&, LoadPropertyParameters const&); |
@@ -275,18 +283,17 @@ const LoadPropertyParameters& LoadPropertyParametersOf(const Operator* op); |
class StoreNamedParameters final { |
public: |
StoreNamedParameters(LanguageMode language_mode, |
- const ResolvedFeedbackSlot& feedback, |
- const Unique<Name>& name) |
+ const VectorSlotPair& feedback, const Unique<Name>& name) |
: language_mode_(language_mode), name_(name), feedback_(feedback) {} |
LanguageMode language_mode() const { return language_mode_; } |
- const ResolvedFeedbackSlot& feedback() const { return feedback_; } |
+ const VectorSlotPair& feedback() const { return feedback_; } |
const Unique<Name>& name() const { return name_; } |
private: |
const LanguageMode language_mode_; |
const Unique<Name> name_; |
- const ResolvedFeedbackSlot feedback_; |
+ const VectorSlotPair feedback_; |
}; |
bool operator==(StoreNamedParameters const&, StoreNamedParameters const&); |
@@ -304,15 +311,15 @@ const StoreNamedParameters& StoreNamedParametersOf(const Operator* op); |
class StorePropertyParameters final { |
public: |
StorePropertyParameters(LanguageMode language_mode, |
- const ResolvedFeedbackSlot& feedback) |
+ const VectorSlotPair& feedback) |
: language_mode_(language_mode), feedback_(feedback) {} |
LanguageMode language_mode() const { return language_mode_; } |
- const ResolvedFeedbackSlot& feedback() const { return feedback_; } |
+ const VectorSlotPair& feedback() const { return feedback_; } |
private: |
const LanguageMode language_mode_; |
- const ResolvedFeedbackSlot feedback_; |
+ const VectorSlotPair feedback_; |
}; |
bool operator==(StorePropertyParameters const&, StorePropertyParameters const&); |
@@ -392,22 +399,23 @@ class JSOperatorBuilder final : public ZoneObject { |
const Operator* CreateLiteralArray(int literal_flags); |
const Operator* CreateLiteralObject(int literal_flags); |
- const Operator* CallFunction(size_t arity, CallFunctionFlags flags, |
- LanguageMode language_mode); |
+ const Operator* CallFunction( |
+ size_t arity, CallFunctionFlags flags, LanguageMode language_mode, |
+ VectorSlotPair const& feedback = VectorSlotPair()); |
const Operator* CallRuntime(Runtime::FunctionId id, size_t arity); |
const Operator* CallConstruct(int arguments); |
- const Operator* LoadProperty(const ResolvedFeedbackSlot& feedback); |
+ const Operator* LoadProperty(const VectorSlotPair& feedback); |
const Operator* LoadNamed(const Unique<Name>& name, |
- const ResolvedFeedbackSlot& feedback, |
+ const VectorSlotPair& feedback, |
ContextualMode contextual_mode = NOT_CONTEXTUAL); |
const Operator* StoreProperty(LanguageMode language_mode, |
- const ResolvedFeedbackSlot& feedback); |
+ const VectorSlotPair& feedback); |
const Operator* StoreNamed(LanguageMode language_mode, |
const Unique<Name>& name, |
- const ResolvedFeedbackSlot& feedback); |
+ const VectorSlotPair& feedback); |
const Operator* DeleteProperty(LanguageMode language_mode); |
@@ -418,7 +426,7 @@ class JSOperatorBuilder final : public ZoneObject { |
const Operator* LoadDynamicGlobal(const Handle<String>& name, |
uint32_t check_bitset, |
- const ResolvedFeedbackSlot& feedback, |
+ const VectorSlotPair& feedback, |
ContextualMode mode); |
const Operator* LoadDynamicContext(const Handle<String>& name, |
uint32_t check_bitset, size_t depth, |