5 #ifndef V8_ELEMENTS_KIND_H_ 6 #define V8_ELEMENTS_KIND_H_ 8 #include "src/base/macros.h" 9 #include "src/checks.h" 15 #define TYPED_ARRAYS(V) \ 16 V(Uint8, uint8, UINT8, uint8_t) \ 17 V(Int8, int8, INT8, int8_t) \ 18 V(Uint16, uint16, UINT16, uint16_t) \ 19 V(Int16, int16, INT16, int16_t) \ 20 V(Uint32, uint32, UINT32, uint32_t) \ 21 V(Int32, int32, INT32, int32_t) \ 22 V(Float32, float32, FLOAT32, float) \ 23 V(Float64, float64, FLOAT64, double) \ 24 V(Uint8Clamped, uint8_clamped, UINT8_CLAMPED, uint8_t) \ 25 V(BigUint64, biguint64, BIGUINT64, uint64_t) \ 26 V(BigInt64, bigint64, BIGINT64, int64_t) 28 enum ElementsKind : uint8_t {
41 PACKED_DOUBLE_ELEMENTS,
42 HOLEY_DOUBLE_ELEMENTS,
48 FAST_SLOPPY_ARGUMENTS_ELEMENTS,
49 SLOW_SLOPPY_ARGUMENTS_ELEMENTS,
53 FAST_STRING_WRAPPER_ELEMENTS,
54 SLOW_STRING_WRAPPER_ELEMENTS,
57 #define TYPED_ARRAY_ELEMENTS_KIND(Type, type, TYPE, ctype) TYPE##_ELEMENTS, 58 TYPED_ARRAYS(TYPED_ARRAY_ELEMENTS_KIND)
59 #undef TYPED_ARRAY_ELEMENTS_KIND 65 FIRST_ELEMENTS_KIND = PACKED_SMI_ELEMENTS,
66 LAST_ELEMENTS_KIND = BIGINT64_ELEMENTS,
67 FIRST_FAST_ELEMENTS_KIND = PACKED_SMI_ELEMENTS,
68 LAST_FAST_ELEMENTS_KIND = HOLEY_DOUBLE_ELEMENTS,
69 FIRST_FIXED_TYPED_ARRAY_ELEMENTS_KIND = UINT8_ELEMENTS,
70 LAST_FIXED_TYPED_ARRAY_ELEMENTS_KIND = BIGINT64_ELEMENTS,
71 TERMINAL_FAST_ELEMENTS_KIND = HOLEY_ELEMENTS
74 constexpr
int kElementsKindCount = LAST_ELEMENTS_KIND - FIRST_ELEMENTS_KIND + 1;
75 constexpr
int kFastElementsKindCount =
76 LAST_FAST_ELEMENTS_KIND - FIRST_FAST_ELEMENTS_KIND + 1;
79 constexpr
int kFastElementsKindPackedToHoley =
80 HOLEY_SMI_ELEMENTS - PACKED_SMI_ELEMENTS;
82 int ElementsKindToShiftSize(ElementsKind elements_kind);
83 int ElementsKindToByteSize(ElementsKind elements_kind);
84 int GetDefaultHeaderSizeForElementsKind(ElementsKind elements_kind);
85 const char* ElementsKindToString(ElementsKind kind);
87 inline ElementsKind GetInitialFastElementsKind() {
return PACKED_SMI_ELEMENTS; }
89 ElementsKind GetFastElementsKindFromSequenceIndex(
int sequence_number);
90 int GetSequenceIndexFromFastElementsKind(ElementsKind elements_kind);
92 ElementsKind GetNextTransitionElementsKind(ElementsKind elements_kind);
94 inline bool IsDictionaryElementsKind(ElementsKind kind) {
95 return kind == DICTIONARY_ELEMENTS;
98 inline bool IsSloppyArgumentsElementsKind(ElementsKind kind) {
99 return kind == FAST_SLOPPY_ARGUMENTS_ELEMENTS ||
100 kind == SLOW_SLOPPY_ARGUMENTS_ELEMENTS;
103 inline bool IsStringWrapperElementsKind(ElementsKind kind) {
104 return kind == FAST_STRING_WRAPPER_ELEMENTS ||
105 kind == SLOW_STRING_WRAPPER_ELEMENTS;
108 inline bool IsFixedTypedArrayElementsKind(ElementsKind kind) {
109 return kind >= FIRST_FIXED_TYPED_ARRAY_ELEMENTS_KIND &&
110 kind <= LAST_FIXED_TYPED_ARRAY_ELEMENTS_KIND;
113 inline bool IsTerminalElementsKind(ElementsKind kind) {
114 return kind == TERMINAL_FAST_ELEMENTS_KIND ||
115 IsFixedTypedArrayElementsKind(kind);
118 inline bool IsFastElementsKind(ElementsKind kind) {
119 STATIC_ASSERT(FIRST_FAST_ELEMENTS_KIND == 0);
120 return kind <= HOLEY_DOUBLE_ELEMENTS;
123 inline bool IsTransitionElementsKind(ElementsKind kind) {
124 return IsFastElementsKind(kind) || IsFixedTypedArrayElementsKind(kind) ||
125 kind == FAST_SLOPPY_ARGUMENTS_ELEMENTS ||
126 kind == FAST_STRING_WRAPPER_ELEMENTS;
129 inline bool IsDoubleElementsKind(ElementsKind kind) {
130 return kind == PACKED_DOUBLE_ELEMENTS || kind == HOLEY_DOUBLE_ELEMENTS;
134 inline bool IsFixedFloatElementsKind(ElementsKind kind) {
135 return kind == FLOAT32_ELEMENTS || kind == FLOAT64_ELEMENTS;
139 inline bool IsDoubleOrFloatElementsKind(ElementsKind kind) {
140 return IsDoubleElementsKind(kind) || IsFixedFloatElementsKind(kind);
143 inline bool IsSmiOrObjectElementsKind(ElementsKind kind) {
144 return kind == PACKED_SMI_ELEMENTS || kind == HOLEY_SMI_ELEMENTS ||
145 kind == PACKED_ELEMENTS || kind == HOLEY_ELEMENTS;
148 inline bool IsSmiElementsKind(ElementsKind kind) {
149 return kind == PACKED_SMI_ELEMENTS || kind == HOLEY_SMI_ELEMENTS;
152 inline bool IsFastNumberElementsKind(ElementsKind kind) {
153 return IsSmiElementsKind(kind) || IsDoubleElementsKind(kind);
156 inline bool IsObjectElementsKind(ElementsKind kind) {
157 return kind == PACKED_ELEMENTS || kind == HOLEY_ELEMENTS;
160 inline bool IsHoleyElementsKind(ElementsKind kind) {
161 return kind == HOLEY_SMI_ELEMENTS || kind == HOLEY_DOUBLE_ELEMENTS ||
162 kind == HOLEY_ELEMENTS;
165 inline bool IsHoleyOrDictionaryElementsKind(ElementsKind kind) {
166 return IsHoleyElementsKind(kind) || kind == DICTIONARY_ELEMENTS;
170 inline bool IsFastPackedElementsKind(ElementsKind kind) {
171 return kind == PACKED_SMI_ELEMENTS || kind == PACKED_DOUBLE_ELEMENTS ||
172 kind == PACKED_ELEMENTS;
176 inline ElementsKind GetPackedElementsKind(ElementsKind holey_kind) {
177 if (holey_kind == HOLEY_SMI_ELEMENTS) {
178 return PACKED_SMI_ELEMENTS;
180 if (holey_kind == HOLEY_DOUBLE_ELEMENTS) {
181 return PACKED_DOUBLE_ELEMENTS;
183 if (holey_kind == HOLEY_ELEMENTS) {
184 return PACKED_ELEMENTS;
190 inline ElementsKind GetHoleyElementsKind(ElementsKind packed_kind) {
191 if (packed_kind == PACKED_SMI_ELEMENTS) {
192 return HOLEY_SMI_ELEMENTS;
194 if (packed_kind == PACKED_DOUBLE_ELEMENTS) {
195 return HOLEY_DOUBLE_ELEMENTS;
197 if (packed_kind == PACKED_ELEMENTS) {
198 return HOLEY_ELEMENTS;
203 inline bool UnionElementsKindUptoPackedness(ElementsKind* a_out,
206 static_assert(PACKED_SMI_ELEMENTS < HOLEY_SMI_ELEMENTS,
207 "ElementsKind union not computable via std::max.");
208 static_assert(PACKED_ELEMENTS < HOLEY_ELEMENTS,
209 "ElementsKind union not computable via std::max.");
210 static_assert(PACKED_DOUBLE_ELEMENTS < HOLEY_DOUBLE_ELEMENTS,
211 "ElementsKind union not computable via std::max.");
212 ElementsKind a = *a_out;
214 case HOLEY_SMI_ELEMENTS:
215 case PACKED_SMI_ELEMENTS:
216 if (b == PACKED_SMI_ELEMENTS || b == HOLEY_SMI_ELEMENTS) {
217 *a_out = std::max(a, b);
221 case PACKED_ELEMENTS:
223 if (b == PACKED_ELEMENTS || b == HOLEY_ELEMENTS) {
224 *a_out = std::max(a, b);
228 case PACKED_DOUBLE_ELEMENTS:
229 case HOLEY_DOUBLE_ELEMENTS:
230 if (b == PACKED_DOUBLE_ELEMENTS || b == HOLEY_DOUBLE_ELEMENTS) {
231 *a_out = std::max(a, b);
241 bool UnionElementsKindUptoSize(ElementsKind* a_out, ElementsKind b);
243 inline ElementsKind FastSmiToObjectElementsKind(ElementsKind from_kind) {
244 DCHECK(IsSmiElementsKind(from_kind));
245 return (from_kind == PACKED_SMI_ELEMENTS) ? PACKED_ELEMENTS : HOLEY_ELEMENTS;
249 inline bool IsSimpleMapChangeTransition(ElementsKind from_kind,
250 ElementsKind to_kind) {
251 return (GetHoleyElementsKind(from_kind) == to_kind) ||
252 (IsSmiElementsKind(from_kind) && IsObjectElementsKind(to_kind));
256 bool IsMoreGeneralElementsKindTransition(ElementsKind from_kind,
257 ElementsKind to_kind);
260 inline ElementsKind GetMoreGeneralElementsKind(ElementsKind from_kind,
261 ElementsKind to_kind) {
262 if (IsMoreGeneralElementsKindTransition(from_kind, to_kind)) {
269 inline bool IsTransitionableFastElementsKind(ElementsKind from_kind) {
270 return IsFastElementsKind(from_kind) &&
271 from_kind != TERMINAL_FAST_ELEMENTS_KIND;
274 inline bool ElementsKindEqual(ElementsKind a, ElementsKind b) {
return a == b; }
279 #endif // V8_ELEMENTS_KIND_H_