• Clemens Backes's avatar
    [wasm][serialization] Use Jobs to avoid blocking · 902e181d
    Clemens Backes authored
    We did spawn exactly one task for each of copy&reloc and publishing.
    Those tasks did block until work is available. This can block background
    threads which could otherwise execute other component's work.
    Switching to the Job API allows us to easily avoid that blocking, and
    just respawning a task when more work is available.
    Is always avoid code duplication for participating in the work in the
    main thread. Instead we just {Join()} the existing job, which makes the
    current thread participate in work.
    
    For now, both Jobs set a maximum concurrency of one, so the main thread
    will only do work if no background thread is currently running. This can
    be lifted in a follow-up CL to see the performance impact of both
    changes independently.
    
    R=thibaudm@chromium.org
    
    Bug: v8:11164
    Change-Id: I032153eb933648a750b113f5d766feb85b87070a
    Cq-Include-Trybots: luci.v8.try:v8_linux64_tsan_rel_ng
    Cq-Include-Trybots: luci.v8.try:v8_linux64_tsan_isolates_rel_ng
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2643393Reviewed-by: 's avatarThibaud Michaud <thibaudm@chromium.org>
    Commit-Queue: Clemens Backes <clemensb@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#72288}
    902e181d
Name
Last commit
Last update
..
api Loading commit data...
asmjs Loading commit data...
ast Loading commit data...
base Loading commit data...
builtins Loading commit data...
codegen Loading commit data...
common Loading commit data...
compiler Loading commit data...
compiler-dispatcher Loading commit data...
d8 Loading commit data...
date Loading commit data...
debug Loading commit data...
deoptimizer Loading commit data...
diagnostics Loading commit data...
execution Loading commit data...
extensions Loading commit data...
flags Loading commit data...
handles Loading commit data...
heap Loading commit data...
ic Loading commit data...
init Loading commit data...
inspector Loading commit data...
interpreter Loading commit data...
json Loading commit data...
libplatform Loading commit data...
libsampler Loading commit data...
logging Loading commit data...
numbers Loading commit data...
objects Loading commit data...
parsing Loading commit data...
profiler Loading commit data...
protobuf Loading commit data...
regexp Loading commit data...
roots Loading commit data...
runtime Loading commit data...
sanitizer Loading commit data...
snapshot Loading commit data...
strings Loading commit data...
tasks Loading commit data...
third_party Loading commit data...
torque Loading commit data...
tracing Loading commit data...
trap-handler Loading commit data...
utils Loading commit data...
wasm Loading commit data...
zone Loading commit data...
DEPS Loading commit data...
DIR_METADATA Loading commit data...
OWNERS Loading commit data...