v8/src/handles/local-handles-inl.h
Leszek Swirski f1589bbe11 [offthread] Change OffThreadIsolate to LocalIsolate
This patch introduces a new LocalIsolate and LocalFactory, which use
LocalHeap and replace OffThreadIsolate and OffThreadFactory. This allows
us to remove those classes, as well as the related OffThreadSpace,
OffThreadLargeObjectSpace, OffThreadHeap, and OffThreadTransferHandle.
OffThreadLogger becomes LocalLogger.

LocalHeap behaves more like Heap than OffThreadHeap did, so this allows
us to additionally remove the concept of "Finish" and "Publish" that the
OffThreadIsolate had, and allows us to internalize strings directly with
the newly-concurrent string table (where the implementation can now move
to FactoryBase).

This patch also removes the off-thread support from the deserializer
entirely, as well as removing the LocalIsolateWrapper which allowed
run-time distinction between Isolate and OffThreadIsolate. LocalHeap
doesn't support the reservation model used by the deserializer, and we
will likely move the deserializer to use LocalIsolate unconditionally
once we figure out the details of how to do this.

Bug: chromium:1011762

Change-Id: I1a1a0a72952b19a8a4c167c11a863c153a1252fc
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2315990
Commit-Queue: Andreas Haas <ahaas@chromium.org>
Auto-Submit: Leszek Swirski <leszeks@chromium.org>
Reviewed-by: Andreas Haas <ahaas@chromium.org>
Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
Reviewed-by: Jakob Gruber <jgruber@chromium.org>
Reviewed-by: Dominik Inführ <dinfuehr@chromium.org>
Cr-Commit-Position: refs/heads/master@{#69397}
2020-08-14 10:57:27 +00:00

90 lines
2.7 KiB
C++

// Copyright 2020 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_HANDLES_LOCAL_HANDLES_INL_H_
#define V8_HANDLES_LOCAL_HANDLES_INL_H_
#include "src/execution/local-isolate.h"
#include "src/handles/local-handles.h"
#include "src/sanitizer/msan.h"
namespace v8 {
namespace internal {
// static
V8_INLINE Address* LocalHandleScope::GetHandle(LocalHeap* local_heap,
Address value) {
LocalHandles* handles = local_heap->handles();
Address* result = handles->scope_.next;
if (result == handles->scope_.limit) {
result = handles->AddBlock();
}
DCHECK_LT(result, handles->scope_.limit);
handles->scope_.next++;
*result = value;
return result;
}
LocalHandleScope::LocalHandleScope(LocalIsolate* local_isolate)
: LocalHandleScope(local_isolate->heap()) {}
LocalHandleScope::LocalHandleScope(LocalHeap* local_heap) {
LocalHandles* handles = local_heap->handles();
local_heap_ = local_heap;
prev_next_ = handles->scope_.next;
prev_limit_ = handles->scope_.limit;
handles->scope_.level++;
}
LocalHandleScope::~LocalHandleScope() {
if (local_heap_ == nullptr) return;
CloseScope(local_heap_, prev_next_, prev_limit_);
}
template <typename T>
Handle<T> LocalHandleScope::CloseAndEscape(Handle<T> handle_value) {
HandleScopeData* current = &local_heap_->handles()->scope_;
T value = *handle_value;
// Throw away all handles in the current scope.
CloseScope(local_heap_, prev_next_, prev_limit_);
// Allocate one handle in the parent scope.
DCHECK(current->level > current->sealed_level);
Handle<T> result(value, local_heap_);
// Reinitialize the current scope (so that it's ready
// to be used or closed again).
prev_next_ = current->next;
prev_limit_ = current->limit;
current->level++;
return result;
}
void LocalHandleScope::CloseScope(LocalHeap* local_heap, Address* prev_next,
Address* prev_limit) {
LocalHandles* handles = local_heap->handles();
Address* old_limit = handles->scope_.limit;
handles->scope_.next = prev_next;
handles->scope_.limit = prev_limit;
handles->scope_.level--;
if (old_limit != handles->scope_.limit) {
handles->RemoveUnusedBlocks();
old_limit = handles->scope_.limit;
}
#ifdef ENABLE_HANDLE_ZAPPING
LocalHandles::ZapRange(handles->scope_.next, old_limit);
#endif
MSAN_ALLOCATED_UNINITIALIZED_MEMORY(
handles->scope_.next,
static_cast<size_t>(reinterpret_cast<Address>(old_limit) -
reinterpret_cast<Address>(handles->scope_.next)));
}
} // namespace internal
} // namespace v8
#endif // V8_HANDLES_LOCAL_HANDLES_INL_H_