Commit 131ba0a0 authored by Nico Hartmann's avatar Nico Hartmann Committed by Commit Bot

Revert "Reland "Delay setting up deserialized JSArrayBuffer""

This reverts commit ff7acbd6.

Reason for revert: https://ci.chromium.org/p/chromium/builders/try/win_optional_gpu_tests_rel/34257

Original change's description:
> Reland "Delay setting up deserialized JSArrayBuffer"
> 
> This is a reland of 83786cb4
> 
> Original change's description:
> > Delay setting up deserialized JSArrayBuffer
> >
> > Setting up JSArrayBuffer may trigger GC. Delay this until we
> > are done with deserialization.
> >
> > R=ulan@chromium.org
> >
> > Bug: chromium:1033395
> > Change-Id: I6c79bc47421bc2662dc1906534fc8e820c351ced
> > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1965580
> > Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
> > Commit-Queue: Yang Guo <yangguo@chromium.org>
> > Cr-Commit-Position: refs/heads/master@{#65441}
> 
> Tbr: yangguo@chromium.org
> Bug: chromium:1033395, chromium:1034059
> Change-Id: I89d05768f52a480400d9c6f5aaaa233c5d5ba126
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1969896
> Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
> Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#65484}

TBR=ulan@chromium.org,yangguo@chromium.org,petermarshall@chromium.org

# Not skipping CQ checks because original CL landed > 1 day ago.

Bug: chromium:1033395, chromium:1034059
Change-Id: I3ad17293bfeba8a817346f57f885c7ba95739d36
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1975751Reviewed-by: 's avatarNico Hartmann <nicohartmann@chromium.org>
Commit-Queue: Nico Hartmann <nicohartmann@chromium.org>
Cr-Commit-Position: refs/heads/master@{#65516}
parent 7f1aaa76
...@@ -8058,14 +8058,12 @@ void BigInt::ToWordsArray(int* sign_bit, int* word_count, ...@@ -8058,14 +8058,12 @@ void BigInt::ToWordsArray(int* sign_bit, int* word_count,
void Isolate::ReportExternalAllocationLimitReached() { void Isolate::ReportExternalAllocationLimitReached() {
i::Heap* heap = reinterpret_cast<i::Isolate*>(this)->heap(); i::Heap* heap = reinterpret_cast<i::Isolate*>(this)->heap();
if (heap->gc_state() != i::Heap::NOT_IN_GC) return; if (heap->gc_state() != i::Heap::NOT_IN_GC) return;
DCHECK(i::AllowHeapAllocation::IsAllowed());
heap->ReportExternalMemoryPressure(); heap->ReportExternalMemoryPressure();
} }
void Isolate::CheckMemoryPressure() { void Isolate::CheckMemoryPressure() {
i::Heap* heap = reinterpret_cast<i::Isolate*>(this)->heap(); i::Heap* heap = reinterpret_cast<i::Isolate*>(this)->heap();
if (heap->gc_state() != i::Heap::NOT_IN_GC) return; if (heap->gc_state() != i::Heap::NOT_IN_GC) return;
DCHECK(i::AllowHeapAllocation::IsAllowed());
heap->CheckMemoryPressure(); heap->CheckMemoryPressure();
} }
......
...@@ -274,16 +274,9 @@ HeapObject Deserializer::PostProcessNewObject(HeapObject obj, ...@@ -274,16 +274,9 @@ HeapObject Deserializer::PostProcessNewObject(HeapObject obj,
} else if (obj.IsJSDataView()) { } else if (obj.IsJSDataView()) {
JSDataView data_view = JSDataView::cast(obj); JSDataView data_view = JSDataView::cast(obj);
JSArrayBuffer buffer = JSArrayBuffer::cast(data_view.buffer()); JSArrayBuffer buffer = JSArrayBuffer::cast(data_view.buffer());
void* backing_store = nullptr; data_view.set_data_pointer(
if (buffer.backing_store() != nullptr) { reinterpret_cast<uint8_t*>(buffer.backing_store()) +
// The backing store of the JSArrayBuffer has not been correctly restored data_view.byte_offset());
// yet, as that may trigger GC. The backing_store field currently contains
// a numbered reference to an already deserialized backing store.
size_t store_index = reinterpret_cast<size_t>(buffer.backing_store());
backing_store = backing_stores_[store_index]->buffer_start();
}
data_view.set_data_pointer(reinterpret_cast<uint8_t*>(backing_store) +
data_view.byte_offset());
} else if (obj.IsJSTypedArray()) { } else if (obj.IsJSTypedArray()) {
JSTypedArray typed_array = JSTypedArray::cast(obj); JSTypedArray typed_array = JSTypedArray::cast(obj);
// Fixup typed array pointers. // Fixup typed array pointers.
...@@ -301,9 +294,15 @@ HeapObject Deserializer::PostProcessNewObject(HeapObject obj, ...@@ -301,9 +294,15 @@ HeapObject Deserializer::PostProcessNewObject(HeapObject obj,
} }
} else if (obj.IsJSArrayBuffer()) { } else if (obj.IsJSArrayBuffer()) {
JSArrayBuffer buffer = JSArrayBuffer::cast(obj); JSArrayBuffer buffer = JSArrayBuffer::cast(obj);
// Only fixup for the off-heap case. This may trigger GC. // Only fixup for the off-heap case.
if (buffer.backing_store() != nullptr) { if (buffer.backing_store() != nullptr) {
new_off_heap_array_buffers_.push_back(handle(buffer, isolate_)); // Serializer writes backing store ref in |backing_store| field.
size_t store_index = reinterpret_cast<size_t>(buffer.backing_store());
auto backing_store = backing_stores_[store_index];
SharedFlag shared = backing_store && backing_store->is_shared()
? SharedFlag::kShared
: SharedFlag::kNotShared;
buffer.Setup(shared, backing_store);
} }
} else if (obj.IsBytecodeArray()) { } else if (obj.IsBytecodeArray()) {
// TODO(mythria): Remove these once we store the default values for these // TODO(mythria): Remove these once we store the default values for these
......
...@@ -76,10 +76,6 @@ class V8_EXPORT_PRIVATE Deserializer : public SerializerDeserializer { ...@@ -76,10 +76,6 @@ class V8_EXPORT_PRIVATE Deserializer : public SerializerDeserializer {
attached_objects_.push_back(attached_object); attached_objects_.push_back(attached_object);
} }
void CheckNoArrayBufferBackingStores() {
CHECK_EQ(new_off_heap_array_buffers().size(), 0);
}
Isolate* isolate() const { return isolate_; } Isolate* isolate() const { return isolate_; }
SnapshotByteSource* source() { return &source_; } SnapshotByteSource* source() { return &source_; }
const std::vector<AllocationSite>& new_allocation_sites() const { const std::vector<AllocationSite>& new_allocation_sites() const {
...@@ -102,14 +98,6 @@ class V8_EXPORT_PRIVATE Deserializer : public SerializerDeserializer { ...@@ -102,14 +98,6 @@ class V8_EXPORT_PRIVATE Deserializer : public SerializerDeserializer {
return new_scripts_; return new_scripts_;
} }
const std::vector<Handle<JSArrayBuffer>>& new_off_heap_array_buffers() const {
return new_off_heap_array_buffers_;
}
std::shared_ptr<BackingStore> backing_store(size_t i) {
return backing_stores_[i];
}
DeserializerAllocator* allocator() { return &allocator_; } DeserializerAllocator* allocator() { return &allocator_; }
bool deserializing_user_code() const { return deserializing_user_code_; } bool deserializing_user_code() const { return deserializing_user_code_; }
bool can_rehash() const { return can_rehash_; } bool can_rehash() const { return can_rehash_; }
...@@ -184,7 +172,6 @@ class V8_EXPORT_PRIVATE Deserializer : public SerializerDeserializer { ...@@ -184,7 +172,6 @@ class V8_EXPORT_PRIVATE Deserializer : public SerializerDeserializer {
std::vector<CallHandlerInfo> call_handler_infos_; std::vector<CallHandlerInfo> call_handler_infos_;
std::vector<Handle<String>> new_internalized_strings_; std::vector<Handle<String>> new_internalized_strings_;
std::vector<Handle<Script>> new_scripts_; std::vector<Handle<Script>> new_scripts_;
std::vector<Handle<JSArrayBuffer>> new_off_heap_array_buffers_;
std::vector<std::shared_ptr<BackingStore>> backing_stores_; std::vector<std::shared_ptr<BackingStore>> backing_stores_;
DeserializerAllocator allocator_; DeserializerAllocator allocator_;
......
...@@ -90,15 +90,6 @@ void ObjectDeserializer::CommitPostProcessedObjects() { ...@@ -90,15 +90,6 @@ void ObjectDeserializer::CommitPostProcessedObjects() {
MaybeObjectHandle::Weak(script)); MaybeObjectHandle::Weak(script));
heap->SetRootScriptList(*list); heap->SetRootScriptList(*list);
} }
for (Handle<JSArrayBuffer> buffer : new_off_heap_array_buffers()) {
// Serializer writes backing store ref in |backing_store| field.
size_t store_index = reinterpret_cast<size_t>(buffer->backing_store());
auto bs = backing_store(store_index);
SharedFlag shared =
bs && bs->is_shared() ? SharedFlag::kShared : SharedFlag::kNotShared;
buffer->Setup(shared, bs);
}
} }
void ObjectDeserializer::LinkAllocationSites() { void ObjectDeserializer::LinkAllocationSites() {
......
...@@ -37,46 +37,27 @@ MaybeHandle<Object> PartialDeserializer::Deserialize( ...@@ -37,46 +37,27 @@ MaybeHandle<Object> PartialDeserializer::Deserialize(
AddAttachedObject(global_proxy); AddAttachedObject(global_proxy);
Handle<Object> result; DisallowHeapAllocation no_gc;
{ // Keep track of the code space start and end pointers in case new
DisallowHeapAllocation no_gc; // code objects were unserialized
// Keep track of the code space start and end pointers in case new CodeSpace* code_space = isolate->heap()->code_space();
// code objects were unserialized Address start_address = code_space->top();
CodeSpace* code_space = isolate->heap()->code_space(); Object root;
Address start_address = code_space->top(); VisitRootPointer(Root::kPartialSnapshotCache, nullptr, FullObjectSlot(&root));
Object root; DeserializeDeferredObjects();
VisitRootPointer(Root::kPartialSnapshotCache, nullptr, DeserializeEmbedderFields(embedder_fields_deserializer);
FullObjectSlot(&root));
DeserializeDeferredObjects(); allocator()->RegisterDeserializedObjectsForBlackAllocation();
DeserializeEmbedderFields(embedder_fields_deserializer);
// There's no code deserialized here. If this assert fires then that's
allocator()->RegisterDeserializedObjectsForBlackAllocation(); // changed and logging should be added to notify the profiler et al of the
// new code, which also has to be flushed from instruction cache.
// There's no code deserialized here. If this assert fires then that's CHECK_EQ(start_address, code_space->top());
// changed and logging should be added to notify the profiler et al of the
// new code, which also has to be flushed from instruction cache. if (FLAG_rehash_snapshot && can_rehash()) Rehash();
CHECK_EQ(start_address, code_space->top()); LogNewMapEvents();
if (FLAG_rehash_snapshot && can_rehash()) Rehash(); return Handle<Object>(root, isolate);
LogNewMapEvents();
result = handle(root, isolate);
}
SetupOffHeapArrayBufferBackingStores();
return result;
}
void PartialDeserializer::SetupOffHeapArrayBufferBackingStores() {
for (Handle<JSArrayBuffer> buffer : new_off_heap_array_buffers()) {
// Serializer writes backing store ref in |backing_store| field.
size_t store_index = reinterpret_cast<size_t>(buffer->backing_store());
auto bs = backing_store(store_index);
SharedFlag shared =
bs && bs->is_shared() ? SharedFlag::kShared : SharedFlag::kNotShared;
buffer->Setup(shared, bs);
}
} }
void PartialDeserializer::DeserializeEmbedderFields( void PartialDeserializer::DeserializeEmbedderFields(
......
...@@ -33,8 +33,6 @@ class V8_EXPORT_PRIVATE PartialDeserializer final : public Deserializer { ...@@ -33,8 +33,6 @@ class V8_EXPORT_PRIVATE PartialDeserializer final : public Deserializer {
void DeserializeEmbedderFields( void DeserializeEmbedderFields(
v8::DeserializeEmbedderFieldsCallback embedder_fields_deserializer); v8::DeserializeEmbedderFieldsCallback embedder_fields_deserializer);
void SetupOffHeapArrayBufferBackingStores();
}; };
} // namespace internal } // namespace internal
......
...@@ -51,7 +51,6 @@ void ReadOnlyDeserializer::DeserializeInto(Isolate* isolate) { ...@@ -51,7 +51,6 @@ void ReadOnlyDeserializer::DeserializeInto(Isolate* isolate) {
if (object->IsUndefined(roots)) break; if (object->IsUndefined(roots)) break;
} }
DeserializeDeferredObjects(); DeserializeDeferredObjects();
CheckNoArrayBufferBackingStores();
} }
if (FLAG_rehash_snapshot && can_rehash()) { if (FLAG_rehash_snapshot && can_rehash()) {
......
...@@ -44,8 +44,6 @@ void StartupDeserializer::DeserializeInto(Isolate* isolate) { ...@@ -44,8 +44,6 @@ void StartupDeserializer::DeserializeInto(Isolate* isolate) {
FlushICache(); FlushICache();
} }
CheckNoArrayBufferBackingStores();
isolate->heap()->set_native_contexts_list( isolate->heap()->set_native_contexts_list(
ReadOnlyRoots(isolate).undefined_value()); ReadOnlyRoots(isolate).undefined_value());
// The allocation site list is build during root iteration, but if no sites // The allocation site list is build during root iteration, but if no sites
......
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