summaryrefslogtreecommitdiff
path: root/deps/v8/src/objects/tagged-impl-inl.h
diff options
context:
space:
mode:
Diffstat (limited to 'deps/v8/src/objects/tagged-impl-inl.h')
-rw-r--r--deps/v8/src/objects/tagged-impl-inl.h257
1 files changed, 257 insertions, 0 deletions
diff --git a/deps/v8/src/objects/tagged-impl-inl.h b/deps/v8/src/objects/tagged-impl-inl.h
new file mode 100644
index 0000000000..f735a241a8
--- /dev/null
+++ b/deps/v8/src/objects/tagged-impl-inl.h
@@ -0,0 +1,257 @@
+// Copyright 2019 the V8 project authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef V8_OBJECTS_TAGGED_IMPL_INL_H_
+#define V8_OBJECTS_TAGGED_IMPL_INL_H_
+
+#include "src/objects/tagged-impl.h"
+
+#ifdef V8_COMPRESS_POINTERS
+#include "src/execution/isolate.h"
+#endif
+#include "src/common/ptr-compr-inl.h"
+#include "src/objects/heap-object.h"
+#include "src/objects/smi.h"
+#include "src/roots/roots-inl.h"
+
+namespace v8 {
+namespace internal {
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::ToSmi(Smi* value) const {
+ if (HAS_SMI_TAG(ptr_)) {
+ *value = ToSmi();
+ return true;
+ }
+ return false;
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+Smi TaggedImpl<kRefType, StorageType>::ToSmi() const {
+ DCHECK(HAS_SMI_TAG(ptr_));
+ if (kIsFull) {
+ return Smi(ptr_);
+ }
+ // Implementation for compressed pointers.
+ return Smi(DecompressTaggedSigned(static_cast<Tagged_t>(ptr_)));
+}
+
+//
+// TaggedImpl::GetHeapObject(HeapObject* result) implementation.
+//
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::GetHeapObject(
+ HeapObject* result) const {
+ CHECK(kIsFull);
+ if (!IsStrongOrWeak()) return false;
+ *result = GetHeapObject();
+ return true;
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::GetHeapObject(
+ ROOT_PARAM, HeapObject* result) const {
+ if (kIsFull) return GetHeapObject(result);
+ // Implementation for compressed pointers.
+ if (!IsStrongOrWeak()) return false;
+ *result = GetHeapObject(ROOT_VALUE);
+ return true;
+}
+
+//
+// TaggedImpl::GetHeapObject(HeapObject* result,
+// HeapObjectReferenceType* reference_type)
+// implementation.
+//
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::GetHeapObject(
+ HeapObject* result, HeapObjectReferenceType* reference_type) const {
+ CHECK(kIsFull);
+ if (!IsStrongOrWeak()) return false;
+ *reference_type = IsWeakOrCleared() ? HeapObjectReferenceType::WEAK
+ : HeapObjectReferenceType::STRONG;
+ *result = GetHeapObject();
+ return true;
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::GetHeapObject(
+ ROOT_PARAM, HeapObject* result,
+ HeapObjectReferenceType* reference_type) const {
+ if (kIsFull) return GetHeapObject(result, reference_type);
+ // Implementation for compressed pointers.
+ if (!IsStrongOrWeak()) return false;
+ *reference_type = IsWeakOrCleared() ? HeapObjectReferenceType::WEAK
+ : HeapObjectReferenceType::STRONG;
+ *result = GetHeapObject(ROOT_VALUE);
+ return true;
+}
+
+//
+// TaggedImpl::GetHeapObjectIfStrong(HeapObject* result) implementation.
+//
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::GetHeapObjectIfStrong(
+ HeapObject* result) const {
+ CHECK(kIsFull);
+ if (IsStrong()) {
+ *result = HeapObject::cast(Object(ptr_));
+ return true;
+ }
+ return false;
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::GetHeapObjectIfStrong(
+ ROOT_PARAM, HeapObject* result) const {
+ if (kIsFull) return GetHeapObjectIfStrong(result);
+ // Implementation for compressed pointers.
+ if (IsStrong()) {
+ *result =
+ HeapObject::cast(Object(DecompressTaggedPointer(ROOT_VALUE, ptr_)));
+ return true;
+ }
+ return false;
+}
+
+//
+// TaggedImpl::GetHeapObjectAssumeStrong() implementation.
+//
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+HeapObject TaggedImpl<kRefType, StorageType>::GetHeapObjectAssumeStrong()
+ const {
+ CHECK(kIsFull);
+ DCHECK(IsStrong());
+ return HeapObject::cast(Object(ptr_));
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+HeapObject TaggedImpl<kRefType, StorageType>::GetHeapObjectAssumeStrong(
+ ROOT_PARAM) const {
+ if (kIsFull) return GetHeapObjectAssumeStrong();
+ // Implementation for compressed pointers.
+ DCHECK(IsStrong());
+ return HeapObject::cast(Object(DecompressTaggedPointer(ROOT_VALUE, ptr_)));
+}
+
+//
+// TaggedImpl::GetHeapObjectIfWeak(HeapObject* result) implementation
+//
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::GetHeapObjectIfWeak(
+ HeapObject* result) const {
+ CHECK(kIsFull);
+ if (kCanBeWeak) {
+ if (IsWeak()) {
+ *result = GetHeapObject();
+ return true;
+ }
+ return false;
+ } else {
+ DCHECK(!HAS_WEAK_HEAP_OBJECT_TAG(ptr_));
+ return false;
+ }
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+bool TaggedImpl<kRefType, StorageType>::GetHeapObjectIfWeak(
+ ROOT_PARAM, HeapObject* result) const {
+ if (kIsFull) return GetHeapObjectIfWeak(result);
+ // Implementation for compressed pointers.
+ if (kCanBeWeak) {
+ if (IsWeak()) {
+ *result = GetHeapObject(ROOT_VALUE);
+ return true;
+ }
+ return false;
+ } else {
+ DCHECK(!HAS_WEAK_HEAP_OBJECT_TAG(ptr_));
+ return false;
+ }
+}
+
+//
+// TaggedImpl::GetHeapObjectAssumeWeak() implementation.
+//
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+HeapObject TaggedImpl<kRefType, StorageType>::GetHeapObjectAssumeWeak() const {
+ CHECK(kIsFull);
+ DCHECK(IsWeak());
+ return GetHeapObject();
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+HeapObject TaggedImpl<kRefType, StorageType>::GetHeapObjectAssumeWeak(
+ ROOT_PARAM) const {
+ if (kIsFull) return GetHeapObjectAssumeWeak();
+ // Implementation for compressed pointers.
+ DCHECK(IsWeak());
+ return GetHeapObject(ROOT_VALUE);
+}
+
+//
+// TaggedImpl::GetHeapObject() implementation.
+//
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+HeapObject TaggedImpl<kRefType, StorageType>::GetHeapObject() const {
+ CHECK(kIsFull);
+ DCHECK(!IsSmi());
+ if (kCanBeWeak) {
+ DCHECK(!IsCleared());
+ return HeapObject::cast(Object(ptr_ & ~kWeakHeapObjectMask));
+ } else {
+ DCHECK(!HAS_WEAK_HEAP_OBJECT_TAG(ptr_));
+ return HeapObject::cast(Object(ptr_));
+ }
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+HeapObject TaggedImpl<kRefType, StorageType>::GetHeapObject(ROOT_PARAM) const {
+ if (kIsFull) return GetHeapObject();
+ // Implementation for compressed pointers.
+ DCHECK(!IsSmi());
+ if (kCanBeWeak) {
+ DCHECK(!IsCleared());
+ return HeapObject::cast(Object(
+ DecompressTaggedPointer(ROOT_VALUE, ptr_ & ~kWeakHeapObjectMask)));
+ } else {
+ DCHECK(!HAS_WEAK_HEAP_OBJECT_TAG(ptr_));
+ return HeapObject::cast(Object(DecompressTaggedPointer(ROOT_VALUE, ptr_)));
+ }
+}
+
+//
+// TaggedImpl::GetHeapObjectOrSmi() implementation.
+//
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+Object TaggedImpl<kRefType, StorageType>::GetHeapObjectOrSmi() const {
+ CHECK(kIsFull);
+ if (IsSmi()) {
+ return Object(ptr_);
+ }
+ return GetHeapObject();
+}
+
+template <HeapObjectReferenceType kRefType, typename StorageType>
+Object TaggedImpl<kRefType, StorageType>::GetHeapObjectOrSmi(ROOT_PARAM) const {
+ if (kIsFull) return GetHeapObjectOrSmi();
+ // Implementation for compressed pointers.
+ if (IsSmi()) {
+ return Object(DecompressTaggedSigned(ptr_));
+ }
+ return GetHeapObject(ROOT_VALUE);
+}
+
+} // namespace internal
+} // namespace v8
+
+#endif // V8_OBJECTS_TAGGED_IMPL_INL_H_