OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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_TYPES_H_ | 5 #ifndef V8_TYPES_H_ |
6 #define V8_TYPES_H_ | 6 #define V8_TYPES_H_ |
7 | 7 |
8 #include "src/conversions.h" | 8 #include "src/conversions.h" |
9 #include "src/handles.h" | 9 #include "src/handles.h" |
10 #include "src/objects.h" | 10 #include "src/objects.h" |
(...skipping 189 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
200 V(Negative31, 1u << 5 | REPRESENTATION(kTagged | kUntaggedNumber)) \ | 200 V(Negative31, 1u << 5 | REPRESENTATION(kTagged | kUntaggedNumber)) \ |
201 V(Null, 1u << 6 | REPRESENTATION(kTaggedPointer)) \ | 201 V(Null, 1u << 6 | REPRESENTATION(kTaggedPointer)) \ |
202 V(Undefined, 1u << 7 | REPRESENTATION(kTaggedPointer)) \ | 202 V(Undefined, 1u << 7 | REPRESENTATION(kTaggedPointer)) \ |
203 V(Boolean, 1u << 8 | REPRESENTATION(kTaggedPointer)) \ | 203 V(Boolean, 1u << 8 | REPRESENTATION(kTaggedPointer)) \ |
204 V(Unsigned30, 1u << 9 | REPRESENTATION(kTagged | kUntaggedNumber)) \ | 204 V(Unsigned30, 1u << 9 | REPRESENTATION(kTagged | kUntaggedNumber)) \ |
205 V(MinusZero, 1u << 10 | REPRESENTATION(kTagged | kUntaggedNumber)) \ | 205 V(MinusZero, 1u << 10 | REPRESENTATION(kTagged | kUntaggedNumber)) \ |
206 V(NaN, 1u << 11 | REPRESENTATION(kTagged | kUntaggedNumber)) \ | 206 V(NaN, 1u << 11 | REPRESENTATION(kTagged | kUntaggedNumber)) \ |
207 V(Symbol, 1u << 12 | REPRESENTATION(kTaggedPointer)) \ | 207 V(Symbol, 1u << 12 | REPRESENTATION(kTaggedPointer)) \ |
208 V(InternalizedString, 1u << 13 | REPRESENTATION(kTaggedPointer)) \ | 208 V(InternalizedString, 1u << 13 | REPRESENTATION(kTaggedPointer)) \ |
209 V(OtherString, 1u << 14 | REPRESENTATION(kTaggedPointer)) \ | 209 V(OtherString, 1u << 14 | REPRESENTATION(kTaggedPointer)) \ |
210 V(Undetectable, 1u << 15 | REPRESENTATION(kTaggedPointer)) \ | 210 V(Simd, 1u << 15 | REPRESENTATION(kTaggedPointer)) \ |
211 /* Unused semantic bit 1u << 16 in case you are looking for a bit. */ \ | 211 V(Undetectable, 1u << 16 | REPRESENTATION(kTaggedPointer)) \ |
212 V(OtherObject, 1u << 17 | REPRESENTATION(kTaggedPointer)) \ | 212 V(OtherObject, 1u << 17 | REPRESENTATION(kTaggedPointer)) \ |
213 V(Proxy, 1u << 18 | REPRESENTATION(kTaggedPointer)) \ | 213 V(Proxy, 1u << 18 | REPRESENTATION(kTaggedPointer)) \ |
214 V(Internal, 1u << 19 | REPRESENTATION(kTagged | kUntagged)) \ | 214 V(Internal, 1u << 19 | REPRESENTATION(kTagged | kUntagged)) \ |
215 \ | 215 \ |
216 V(Signed31, kUnsigned30 | kNegative31) \ | 216 V(Signed31, kUnsigned30 | kNegative31) \ |
217 V(Signed32, kSigned31 | kOtherUnsigned31 | kOtherSigned32) \ | 217 V(Signed32, kSigned31 | kOtherUnsigned31 | kOtherSigned32) \ |
218 V(Negative32, kNegative31 | kOtherSigned32) \ | 218 V(Negative32, kNegative31 | kOtherSigned32) \ |
219 V(Unsigned31, kUnsigned30 | kOtherUnsigned31) \ | 219 V(Unsigned31, kUnsigned30 | kOtherUnsigned31) \ |
220 V(Unsigned32, kUnsigned30 | kOtherUnsigned31 | kOtherUnsigned32) \ | 220 V(Unsigned32, kUnsigned30 | kOtherUnsigned31 | kOtherUnsigned32) \ |
221 V(Integral32, kSigned32 | kUnsigned32) \ | 221 V(Integral32, kSigned32 | kUnsigned32) \ |
222 V(PlainNumber, kIntegral32 | kOtherNumber) \ | 222 V(PlainNumber, kIntegral32 | kOtherNumber) \ |
223 V(OrderedNumber, kPlainNumber | kMinusZero) \ | 223 V(OrderedNumber, kPlainNumber | kMinusZero) \ |
224 V(MinusZeroOrNaN, kMinusZero | kNaN) \ | 224 V(MinusZeroOrNaN, kMinusZero | kNaN) \ |
225 V(Number, kOrderedNumber | kNaN) \ | 225 V(Number, kOrderedNumber | kNaN) \ |
226 V(String, kInternalizedString | kOtherString) \ | 226 V(String, kInternalizedString | kOtherString) \ |
227 V(UniqueName, kSymbol | kInternalizedString) \ | 227 V(UniqueName, kSymbol | kInternalizedString) \ |
228 V(Name, kSymbol | kString) \ | 228 V(Name, kSymbol | kString) \ |
229 V(BooleanOrNumber, kBoolean | kNumber) \ | 229 V(BooleanOrNumber, kBoolean | kNumber) \ |
230 V(NullOrUndefined, kNull | kUndefined) \ | 230 V(NullOrUndefined, kNull | kUndefined) \ |
231 V(NumberOrString, kNumber | kString) \ | 231 V(NumberOrString, kNumber | kString) \ |
232 V(NumberOrUndefined, kNumber | kUndefined) \ | 232 V(NumberOrUndefined, kNumber | kUndefined) \ |
233 V(PlainPrimitive, kNumberOrString | kBoolean | kNullOrUndefined) \ | 233 V(PlainPrimitive, kNumberOrString | kBoolean | kNullOrUndefined) \ |
234 V(Primitive, kSymbol | kPlainPrimitive) \ | 234 V(Primitive, kSymbol | kSimd | kPlainPrimitive) \ |
235 V(DetectableReceiver, kOtherObject | kProxy) \ | 235 V(DetectableReceiver, kOtherObject | kProxy) \ |
236 V(Detectable, kDetectableReceiver | kNumber | kName) \ | 236 V(Detectable, kDetectableReceiver | kNumber | kName) \ |
237 V(Object, kOtherObject | kUndetectable) \ | 237 V(Object, kOtherObject | kUndetectable) \ |
238 V(Receiver, kObject | kProxy) \ | 238 V(Receiver, kObject | kProxy) \ |
239 V(ReceiverOrUndefined, kReceiver | kUndefined) \ | 239 V(ReceiverOrUndefined, kReceiver | kUndefined) \ |
240 V(StringOrReceiver, kString | kReceiver) \ | 240 V(StringOrReceiver, kString | kReceiver) \ |
241 V(Unique, kBoolean | kUniqueName | kNull | kUndefined | \ | 241 V(Unique, kBoolean | kUniqueName | kNull | kUndefined | \ |
242 kReceiver) \ | 242 kReceiver) \ |
243 V(NonNumber, kUnique | kString | kInternal) \ | 243 V(NonNumber, kUnique | kString | kInternal) \ |
244 V(Any, 0xfffffffeu) | 244 V(Any, 0xfffffffeu) |
(...skipping 25 matching lines...) Expand all Loading... |
270 // ----------------------------------------------------------------------------- | 270 // ----------------------------------------------------------------------------- |
271 // The abstract Type class, parameterized over the low-level representation. | 271 // The abstract Type class, parameterized over the low-level representation. |
272 | 272 |
273 // struct Config { | 273 // struct Config { |
274 // typedef TypeImpl<Config> Type; | 274 // typedef TypeImpl<Config> Type; |
275 // typedef Base; | 275 // typedef Base; |
276 // typedef Struct; | 276 // typedef Struct; |
277 // typedef Range; | 277 // typedef Range; |
278 // typedef Region; | 278 // typedef Region; |
279 // template<class> struct Handle { typedef type; } // No template typedefs... | 279 // template<class> struct Handle { typedef type; } // No template typedefs... |
| 280 // |
280 // template<class T> static Handle<T>::type null_handle(); | 281 // template<class T> static Handle<T>::type null_handle(); |
281 // template<class T> static Handle<T>::type handle(T* t); // !is_bitset(t) | 282 // template<class T> static Handle<T>::type handle(T* t); // !is_bitset(t) |
282 // template<class T> static Handle<T>::type cast(Handle<Type>::type); | 283 // template<class T> static Handle<T>::type cast(Handle<Type>::type); |
283 // | 284 // |
284 // static bool is_bitset(Type*); | 285 // static bool is_bitset(Type*); |
285 // static bool is_class(Type*); | 286 // static bool is_class(Type*); |
286 // static bool is_struct(Type*, int tag); | 287 // static bool is_struct(Type*, int tag); |
287 // static bool is_range(Type*); | 288 // static bool is_range(Type*); |
288 // | 289 // |
289 // static bitset as_bitset(Type*); | 290 // static bitset as_bitset(Type*); |
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
416 } | 417 } |
417 static TypeHandle Function(TypeHandle result, int arity, TypeHandle* params, | 418 static TypeHandle Function(TypeHandle result, int arity, TypeHandle* params, |
418 Region* region) { | 419 Region* region) { |
419 FunctionHandle function = Function(result, Any(region), arity, region); | 420 FunctionHandle function = Function(result, Any(region), arity, region); |
420 for (int i = 0; i < arity; ++i) { | 421 for (int i = 0; i < arity; ++i) { |
421 function->InitParameter(i, params[i]); | 422 function->InitParameter(i, params[i]); |
422 } | 423 } |
423 return function; | 424 return function; |
424 } | 425 } |
425 | 426 |
| 427 #define CONSTRUCT_SIMD_TYPE(NAME, Name, name, lane_count, lane_type) \ |
| 428 static TypeHandle Name(Isolate* isolate, Region* region); |
| 429 SIMD128_TYPES(CONSTRUCT_SIMD_TYPE) |
| 430 #undef CONSTRUCT_SIMD_TYPE |
| 431 |
426 static TypeHandle Union(TypeHandle type1, TypeHandle type2, Region* reg); | 432 static TypeHandle Union(TypeHandle type1, TypeHandle type2, Region* reg); |
427 static TypeHandle Intersect(TypeHandle type1, TypeHandle type2, Region* reg); | 433 static TypeHandle Intersect(TypeHandle type1, TypeHandle type2, Region* reg); |
428 static TypeImpl* Union(TypeImpl* type1, TypeImpl* type2) { | 434 static TypeImpl* Union(TypeImpl* type1, TypeImpl* type2) { |
429 return BitsetType::New(type1->AsBitset() | type2->AsBitset()); | 435 return BitsetType::New(type1->AsBitset() | type2->AsBitset()); |
430 } | 436 } |
431 static TypeImpl* Intersect(TypeImpl* type1, TypeImpl* type2) { | 437 static TypeImpl* Intersect(TypeImpl* type1, TypeImpl* type2) { |
432 return BitsetType::New(type1->AsBitset() & type2->AsBitset()); | 438 return BitsetType::New(type1->AsBitset() & type2->AsBitset()); |
433 } | 439 } |
434 | 440 |
435 static TypeHandle Of(double value, Region* region) { | 441 static TypeHandle Of(double value, Region* region) { |
(...skipping 729 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1165 bool Narrows(BoundsImpl that) { | 1171 bool Narrows(BoundsImpl that) { |
1166 return that.lower->Is(this->lower) && this->upper->Is(that.upper); | 1172 return that.lower->Is(this->lower) && this->upper->Is(that.upper); |
1167 } | 1173 } |
1168 }; | 1174 }; |
1169 | 1175 |
1170 typedef BoundsImpl<ZoneTypeConfig> Bounds; | 1176 typedef BoundsImpl<ZoneTypeConfig> Bounds; |
1171 | 1177 |
1172 } } // namespace v8::internal | 1178 } } // namespace v8::internal |
1173 | 1179 |
1174 #endif // V8_TYPES_H_ | 1180 #endif // V8_TYPES_H_ |
OLD | NEW |