• Daniel Lehmann's avatar
    [wasm] publish TurboFan results in batches · 990c9386
    Daniel Lehmann authored
    With mprotect-based write protection of the WebAssembly code space,
    we switch page protection flags each time (at least) one compilation
    thread needs write access. Two such switches happen when TurboFan
    compilation results are available in {ExecuteCompilationUnits}: One
    switch happens when calling {NativeModule::AddCompiledCode} and one more
    when calling {NativeModule::PublishCode} via
    {SchedulePublishCompilationResults} and {PublishCompilationResults}.
    
    So far, each TurboFan result was published eagerly, i.e., as soon as it
    became available. This has the benefit that faster code is available
    immediately, and had no large cost or downside without write protection.
    However, with write protection switching permissions is expensive (an
    mprotect syscall) and needs to lock the
    {WasmCodeAllocator::allocation_mutex_} (which causes lock contention and
    under Linux many futex syscalls). Thus, immediately publishing each
    TurboFan result when using write protection can cause up to 10x slower
    compilation compared with not using write protection. In terms of
    syscalls we measured (non scientifically) with
    {sudo perf stat -e 'syscalls:sys_enter*' d8 ...} on the Unity benchmark:
    - mprotect: 10k vs. 44k syscalls (baseline vs. write protection)
    - futex: 31k vs. 112k syscalls (baseline vs. write protection)
    - sys time: 1.6s vs. 10s (baseline vs. write protection)
    All of those are clearly to high.
    
    The fix here is simply to batch togther multiple TurboFan functions into
    one publishing step when using write protection. The batching logic
    already exists for Liftoff, so we can just disable eager publishing for
    TurboFan when using write protection. Additionally, we publish once when
    all Liftoff results are available (even if the batch is not complete),
    such that time-to-execute is not regressed.
    
    R=clemensb@chromium.org
    CC=​​​​jkummerow@chromium.org
    
    Bug: v8:11663, chromium:932033
    Change-Id: Ibf6f28ecf4733b40322e62761e66046dec60a125
    Cq-Include-Trybots: luci.v8.try:v8_linux64_fyi_rel_ng
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2922114
    Commit-Queue: Daniel Lehmann <dlehmann@google.com>
    Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#74829}
    990c9386
Name
Last commit
Last update
..
baseline Loading commit data...
DEPS Loading commit data...
DIR_METADATA Loading commit data...
OWNERS Loading commit data...
branch-hint-map.h Loading commit data...
c-api.cc Loading commit data...
c-api.h Loading commit data...
code-space-access.h Loading commit data...
compilation-environment.h Loading commit data...
decoder.h Loading commit data...
function-body-decoder-impl.h Loading commit data...
function-body-decoder.cc Loading commit data...
function-body-decoder.h Loading commit data...
function-compiler.cc Loading commit data...
function-compiler.h Loading commit data...
graph-builder-interface.cc Loading commit data...
graph-builder-interface.h Loading commit data...
jump-table-assembler.cc Loading commit data...
jump-table-assembler.h Loading commit data...
leb-helper.h Loading commit data...
local-decl-encoder.cc Loading commit data...
local-decl-encoder.h Loading commit data...
memory-protection-key.cc Loading commit data...
memory-protection-key.h Loading commit data...
memory-tracing.cc Loading commit data...
memory-tracing.h Loading commit data...
module-compiler.cc Loading commit data...
module-compiler.h Loading commit data...
module-decoder.cc Loading commit data...
module-decoder.h Loading commit data...
module-instantiate.cc Loading commit data...
module-instantiate.h Loading commit data...
object-access.h Loading commit data...
signature-map.cc Loading commit data...
signature-map.h Loading commit data...
simd-shuffle.cc Loading commit data...
simd-shuffle.h Loading commit data...
streaming-decoder.cc Loading commit data...
streaming-decoder.h Loading commit data...
struct-types.h Loading commit data...
sync-streaming-decoder.cc Loading commit data...
value-type.cc Loading commit data...
value-type.h Loading commit data...
wasm-arguments.h Loading commit data...
wasm-code-manager.cc Loading commit data...
wasm-code-manager.h Loading commit data...
wasm-constants.h Loading commit data...
wasm-debug.cc Loading commit data...
wasm-debug.h Loading commit data...
wasm-engine.cc Loading commit data...
wasm-engine.h Loading commit data...
wasm-external-refs.cc Loading commit data...
wasm-external-refs.h Loading commit data...
wasm-feature-flags.h Loading commit data...
wasm-features.cc Loading commit data...
wasm-features.h Loading commit data...
wasm-import-wrapper-cache.cc Loading commit data...
wasm-import-wrapper-cache.h Loading commit data...
wasm-init-expr.h Loading commit data...
wasm-js.cc Loading commit data...
wasm-js.h Loading commit data...
wasm-limits.h Loading commit data...
wasm-linkage.h Loading commit data...
wasm-module-builder.cc Loading commit data...
wasm-module-builder.h Loading commit data...
wasm-module-sourcemap.cc Loading commit data...
wasm-module-sourcemap.h Loading commit data...
wasm-module.cc Loading commit data...
wasm-module.h Loading commit data...
wasm-objects-inl.h Loading commit data...
wasm-objects.cc Loading commit data...
wasm-objects.h Loading commit data...
wasm-objects.tq Loading commit data...
wasm-opcodes-inl.h Loading commit data...
wasm-opcodes.cc Loading commit data...
wasm-opcodes.h Loading commit data...
wasm-result.cc Loading commit data...
wasm-result.h Loading commit data...
wasm-serialization.cc Loading commit data...
wasm-serialization.h Loading commit data...
wasm-subtyping.cc Loading commit data...
wasm-subtyping.h Loading commit data...
wasm-tier.h Loading commit data...
wasm-value.h Loading commit data...