Commit 8738ab80 authored by Jakob Kummerow's avatar Jakob Kummerow Committed by Commit Bot

[ptr-compr] Fix decompression functions in v8-internal.h

In the final version of our pointer compression scheme, decompression
uses zero-extension of the compressed value. The API copy of that code
erroneously still used a sign-extending decompression from an earlier
iteration of the scheme.

Bug: v8:9706, v8:10198
Change-Id: I17c3a52d26ce26bc0623627d725f686c379fbd6e
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2051954
Commit-Queue: Jakob Kummerow <jkummerow@chromium.org>
Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
Cr-Commit-Position: refs/heads/master@{#66256}
parent 6516b1cc
...@@ -308,9 +308,9 @@ class Internals { ...@@ -308,9 +308,9 @@ class Internals {
V8_INLINE static internal::Address ReadTaggedPointerField( V8_INLINE static internal::Address ReadTaggedPointerField(
internal::Address heap_object_ptr, int offset) { internal::Address heap_object_ptr, int offset) {
#ifdef V8_COMPRESS_POINTERS #ifdef V8_COMPRESS_POINTERS
int32_t value = ReadRawField<int32_t>(heap_object_ptr, offset); uint32_t value = ReadRawField<uint32_t>(heap_object_ptr, offset);
internal::Address root = GetRootFromOnHeapAddress(heap_object_ptr); internal::Address root = GetRootFromOnHeapAddress(heap_object_ptr);
return root + static_cast<internal::Address>(static_cast<intptr_t>(value)); return root + static_cast<internal::Address>(static_cast<uintptr_t>(value));
#else #else
return ReadRawField<internal::Address>(heap_object_ptr, offset); return ReadRawField<internal::Address>(heap_object_ptr, offset);
#endif #endif
...@@ -319,8 +319,8 @@ class Internals { ...@@ -319,8 +319,8 @@ class Internals {
V8_INLINE static internal::Address ReadTaggedSignedField( V8_INLINE static internal::Address ReadTaggedSignedField(
internal::Address heap_object_ptr, int offset) { internal::Address heap_object_ptr, int offset) {
#ifdef V8_COMPRESS_POINTERS #ifdef V8_COMPRESS_POINTERS
int32_t value = ReadRawField<int32_t>(heap_object_ptr, offset); uint32_t value = ReadRawField<uint32_t>(heap_object_ptr, offset);
return static_cast<internal::Address>(static_cast<intptr_t>(value)); return static_cast<internal::Address>(static_cast<uintptr_t>(value));
#else #else
return ReadRawField<internal::Address>(heap_object_ptr, offset); return ReadRawField<internal::Address>(heap_object_ptr, offset);
#endif #endif
...@@ -337,13 +337,9 @@ class Internals { ...@@ -337,13 +337,9 @@ class Internals {
} }
V8_INLINE static internal::Address DecompressTaggedAnyField( V8_INLINE static internal::Address DecompressTaggedAnyField(
internal::Address heap_object_ptr, int32_t value) { internal::Address heap_object_ptr, uint32_t value) {
internal::Address root_mask = static_cast<internal::Address>( internal::Address root = GetRootFromOnHeapAddress(heap_object_ptr);
-static_cast<intptr_t>(value & kSmiTagMask)); return root + static_cast<internal::Address>(static_cast<uintptr_t>(value));
internal::Address root_or_zero =
root_mask & GetRootFromOnHeapAddress(heap_object_ptr);
return root_or_zero +
static_cast<internal::Address>(static_cast<intptr_t>(value));
} }
#endif // V8_COMPRESS_POINTERS #endif // V8_COMPRESS_POINTERS
}; };
......
...@@ -11239,7 +11239,7 @@ Local<Value> Object::GetInternalField(int index) { ...@@ -11239,7 +11239,7 @@ Local<Value> Object::GetInternalField(int index) {
#ifdef V8_COMPRESS_POINTERS #ifdef V8_COMPRESS_POINTERS
// We read the full pointer value and then decompress it in order to avoid // We read the full pointer value and then decompress it in order to avoid
// dealing with potential endiannes issues. // dealing with potential endiannes issues.
value = I::DecompressTaggedAnyField(obj, static_cast<int32_t>(value)); value = I::DecompressTaggedAnyField(obj, static_cast<uint32_t>(value));
#endif #endif
internal::Isolate* isolate = internal::Isolate* isolate =
internal::IsolateFromNeverReadOnlySpaceObject(obj); internal::IsolateFromNeverReadOnlySpaceObject(obj);
...@@ -11883,7 +11883,7 @@ Local<Value> Context::GetEmbedderData(int index) { ...@@ -11883,7 +11883,7 @@ Local<Value> Context::GetEmbedderData(int index) {
// We read the full pointer value and then decompress it in order to avoid // We read the full pointer value and then decompress it in order to avoid
// dealing with potential endiannes issues. // dealing with potential endiannes issues.
value = value =
I::DecompressTaggedAnyField(embedder_data, static_cast<int32_t>(value)); I::DecompressTaggedAnyField(embedder_data, static_cast<uint32_t>(value));
#endif #endif
internal::Isolate* isolate = internal::IsolateFromNeverReadOnlySpaceObject( internal::Isolate* isolate = internal::IsolateFromNeverReadOnlySpaceObject(
*reinterpret_cast<A*>(this)); *reinterpret_cast<A*>(this));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment