OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #ifndef RUNTIME_VM_OBJECT_H_ | 5 #ifndef RUNTIME_VM_OBJECT_H_ |
6 #define RUNTIME_VM_OBJECT_H_ | 6 #define RUNTIME_VM_OBJECT_H_ |
7 | 7 |
8 #include "include/dart_api.h" | 8 #include "include/dart_api.h" |
9 #include "platform/assert.h" | 9 #include "platform/assert.h" |
10 #include "platform/utils.h" | 10 #include "platform/utils.h" |
(...skipping 227 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
238 #define MINT_OBJECT_IMPLEMENTATION(object, rettype, super) \ | 238 #define MINT_OBJECT_IMPLEMENTATION(object, rettype, super) \ |
239 FINAL_HEAP_OBJECT_IMPLEMENTATION_HELPER(object, rettype, super) | 239 FINAL_HEAP_OBJECT_IMPLEMENTATION_HELPER(object, rettype, super) |
240 | 240 |
241 class Object { | 241 class Object { |
242 public: | 242 public: |
243 virtual ~Object() {} | 243 virtual ~Object() {} |
244 | 244 |
245 RawObject* raw() const { return raw_; } | 245 RawObject* raw() const { return raw_; } |
246 void operator=(RawObject* value) { initializeHandle(this, value); } | 246 void operator=(RawObject* value) { initializeHandle(this, value); } |
247 | 247 |
248 uword CompareAndSwapTags(uword old_tags, uword new_tags) const { | 248 uint32_t CompareAndSwapTags(uint32_t old_tags, uint32_t new_tags) const { |
249 return AtomicOperations::CompareAndSwapWord(&raw()->ptr()->tags_, old_tags, | 249 return AtomicOperations::CompareAndSwapUint32(&raw()->ptr()->tags_, |
250 new_tags); | 250 old_tags, new_tags); |
251 } | 251 } |
252 bool IsCanonical() const { return raw()->IsCanonical(); } | 252 bool IsCanonical() const { return raw()->IsCanonical(); } |
253 void SetCanonical() const { raw()->SetCanonical(); } | 253 void SetCanonical() const { raw()->SetCanonical(); } |
254 void ClearCanonical() const { raw()->ClearCanonical(); } | 254 void ClearCanonical() const { raw()->ClearCanonical(); } |
255 intptr_t GetClassId() const { | 255 intptr_t GetClassId() const { |
256 return !raw()->IsHeapObject() ? static_cast<intptr_t>(kSmiCid) | 256 return !raw()->IsHeapObject() ? static_cast<intptr_t>(kSmiCid) |
257 : raw()->GetClassId(); | 257 : raw()->GetClassId(); |
258 } | 258 } |
259 inline RawClass* clazz() const; | 259 inline RawClass* clazz() const; |
260 static intptr_t tags_offset() { return OFFSET_OF(RawObject, tags_); } | 260 static intptr_t tags_offset() { return OFFSET_OF(RawObject, tags_); } |
(...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
427 } | 427 } |
428 // Value marking that we are transitioning from sentinel, e.g., computing | 428 // Value marking that we are transitioning from sentinel, e.g., computing |
429 // a field value. Used to detect circular initialization. | 429 // a field value. Used to detect circular initialization. |
430 static const Instance& transition_sentinel() { | 430 static const Instance& transition_sentinel() { |
431 ASSERT(transition_sentinel_ != NULL); | 431 ASSERT(transition_sentinel_ != NULL); |
432 return *transition_sentinel_; | 432 return *transition_sentinel_; |
433 } | 433 } |
434 | 434 |
435 #if defined(HASH_IN_OBJECT_HEADER) | 435 #if defined(HASH_IN_OBJECT_HEADER) |
436 static uint32_t GetCachedHash(const RawObject* obj) { | 436 static uint32_t GetCachedHash(const RawObject* obj) { |
437 uword tags = obj->ptr()->tags_; | 437 return obj->ptr()->hash_; |
438 return tags >> 32; | |
439 } | 438 } |
440 | 439 |
441 static void SetCachedHash(RawObject* obj, uintptr_t hash) { | 440 static void SetCachedHash(RawObject* obj, uint32_t hash) { |
442 ASSERT(hash >> 32 == 0); | 441 obj->ptr()->hash_ = hash; |
443 obj->ptr()->tags_ |= hash << 32; | |
444 } | 442 } |
445 #endif | 443 #endif |
446 | 444 |
447 // Compiler's constant propagation constants. | 445 // Compiler's constant propagation constants. |
448 static const Instance& unknown_constant() { | 446 static const Instance& unknown_constant() { |
449 ASSERT(unknown_constant_ != NULL); | 447 ASSERT(unknown_constant_ != NULL); |
450 return *unknown_constant_; | 448 return *unknown_constant_; |
451 } | 449 } |
452 static const Instance& non_constant() { | 450 static const Instance& non_constant() { |
453 ASSERT(non_constant_ != NULL); | 451 ASSERT(non_constant_ != NULL); |
(...skipping 6370 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
6824 intptr_t Hash() const { | 6822 intptr_t Hash() const { |
6825 intptr_t result = GetCachedHash(raw()); | 6823 intptr_t result = GetCachedHash(raw()); |
6826 if (result != 0) { | 6824 if (result != 0) { |
6827 return result; | 6825 return result; |
6828 } | 6826 } |
6829 result = String::Hash(*this, 0, this->Length()); | 6827 result = String::Hash(*this, 0, this->Length()); |
6830 SetCachedHash(raw(), result); | 6828 SetCachedHash(raw(), result); |
6831 return result; | 6829 return result; |
6832 } | 6830 } |
6833 | 6831 |
| 6832 static intptr_t Hash(RawString* raw); |
| 6833 |
6834 bool HasHash() const { | 6834 bool HasHash() const { |
6835 ASSERT(Smi::New(0) == NULL); | 6835 ASSERT(Smi::New(0) == NULL); |
6836 return GetCachedHash(raw()) != 0; | 6836 return GetCachedHash(raw()) != 0; |
6837 } | 6837 } |
6838 | 6838 |
6839 #if defined(HASH_IN_OBJECT_HEADER) | |
6840 static intptr_t hash_offset() { return kInt32Size; } // Wrong for big-endian? | |
6841 #else | |
6842 static intptr_t hash_offset() { return OFFSET_OF(RawString, hash_); } | 6839 static intptr_t hash_offset() { return OFFSET_OF(RawString, hash_); } |
6843 #endif | |
6844 static intptr_t Hash(const String& str, intptr_t begin_index, intptr_t len); | 6840 static intptr_t Hash(const String& str, intptr_t begin_index, intptr_t len); |
6845 static intptr_t Hash(const char* characters, intptr_t len); | 6841 static intptr_t Hash(const char* characters, intptr_t len); |
6846 static intptr_t Hash(const uint16_t* characters, intptr_t len); | 6842 static intptr_t Hash(const uint16_t* characters, intptr_t len); |
6847 static intptr_t Hash(const int32_t* characters, intptr_t len); | 6843 static intptr_t Hash(const int32_t* characters, intptr_t len); |
6848 static intptr_t HashRawSymbol(const RawString* symbol) { | 6844 static intptr_t HashRawSymbol(const RawString* symbol) { |
6849 ASSERT(symbol->IsCanonical()); | 6845 ASSERT(symbol->IsCanonical()); |
6850 intptr_t result = GetCachedHash(symbol); | 6846 intptr_t result = GetCachedHash(symbol); |
6851 ASSERT(result != 0); | 6847 ASSERT(result != 0); |
6852 return result; | 6848 return result; |
6853 } | 6849 } |
(...skipping 2204 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
9058 | 9054 |
9059 inline void TypeArguments::SetHash(intptr_t value) const { | 9055 inline void TypeArguments::SetHash(intptr_t value) const { |
9060 // This is only safe because we create a new Smi, which does not cause | 9056 // This is only safe because we create a new Smi, which does not cause |
9061 // heap allocation. | 9057 // heap allocation. |
9062 StoreSmi(&raw_ptr()->hash_, Smi::New(value)); | 9058 StoreSmi(&raw_ptr()->hash_, Smi::New(value)); |
9063 } | 9059 } |
9064 | 9060 |
9065 } // namespace dart | 9061 } // namespace dart |
9066 | 9062 |
9067 #endif // RUNTIME_VM_OBJECT_H_ | 9063 #endif // RUNTIME_VM_OBJECT_H_ |
OLD | NEW |