mirror of
https://github.com/dart-lang/sdk
synced 2024-09-05 00:13:50 +00:00
06b2967188
The main purpose of the low-level [PortMap] is to coordinate between ports being opened & closed and concurrent message senders. That's the only thing it should do. Each isolate owns [ReceivePort]s. Only the isolate mutator can create ports, delete them or change their "keeps-isolate-alive" state. Right now it requires going via [PortMap] (which acquires lock) and [MessageHandler] (which acquires lock) to change the "keeps-isolate-alive" state of a port. We'll move information whether a dart [ReceivePort] is closed and whether it keeps the isolate alive into the [ReceivePort] object itself. => Changing the "keeps-isolate-alive" state of the port no longer requires any locks. We could even avoid the runtime call itself in a future CL. Isolates are kept alive if there's any open receive ports (that have not been marked as "does not keep isolate alive"). This is a property of an isolate not of the message handler. For native message handlers we do have a 1<->1 correspondence between port and handler (i.e. there's no "number of open ports" tracking needed). => We'll move the logic of counting open receive ports and ports that keep the isolate alive to the [Isolate]. => We'll also remove locking around incrementing/decrementing or accessing the counts. => The [IsolateMessageHandler] will ask the [Isolate] whether there's any open ports for determining whether to shut down. => For native ports, the `Dart_NewNativePort()` & `Dart_CloseNativePort()` functions will manage the lifetime (as their name also suggests). Overall this makes the [Isolate] responsible for creation of dart [ReceivePort]s and tracking whether the isolate should be kept alive: * Isolate::CreateReceivePort() * Isolate::SetReceivePortKeepAliveState() * Isolate::CloseReceivePort() TEST=ci Change-Id: I847ae357c26254d3810cc277962e05deca18a1de Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/317960 Reviewed-by: Alexander Aprelev <aam@google.com> Reviewed-by: Ryan Macnak <rmacnak@google.com> Commit-Queue: Martin Kustermann <kustermann@google.com> |
||
---|---|---|
.. | ||
array.cc | ||
async.cc | ||
async_sources.gni | ||
bool.cc | ||
convert_sources.gni | ||
core_sources.gni | ||
date.cc | ||
developer.cc | ||
developer_sources.gni | ||
double.cc | ||
errors.cc | ||
ffi.cc | ||
ffi_dynamic_library.cc | ||
ffi_sources.gni | ||
function.cc | ||
growable_array.cc | ||
identical.cc | ||
integers.cc | ||
integers.h | ||
invocation_mirror.h | ||
isolate.cc | ||
isolate_sources.gni | ||
libgen_in.cc | ||
math.cc | ||
math_sources.gni | ||
mirrors.cc | ||
mirrors.h | ||
mirrors_sources.gni | ||
object.cc | ||
profiler.cc | ||
profiler_sources.gni | ||
regexp.cc | ||
simd128.cc | ||
stacktrace.cc | ||
stacktrace.h | ||
stopwatch.cc | ||
string.cc | ||
timeline.cc | ||
typed_data.cc | ||
typed_data_sources.gni | ||
uri.cc | ||
vmservice.cc | ||
vmservice_sources.gni |