• Andreas Haas's avatar
    [wasm][lazy] Avoid validation in case of a prefix_cache_hit · 2b50e9ce
    Andreas Haas authored
    If the same WebAssembly module gets compiled multiple times, the
    compilation result of the first compilation gets reused for later
    compilations. With streaming compilation functions get compiled before
    the whole module got downloaded, so it cannot be determined if the
    currently compiled module has already been compiled or not. Therefore,
    to check if the WebAssembly module has already been compiled, we compare
    if the hash of the header section matches the hash of any of the already
    compiled modules. If so, no function gets compiled until all bytes were
    received. Then a full module check can be done, and either an existing
    module can be reused, or the whole module gets compiled.
    
    While compilation is avoided after a prefix_cache_hit, decoding still has
    to happen. In the existing implementation, validation for lazy
    compilation also happened in addition to decoding. This lead to the
    problem that validation of lazy compilation could post a foreground task
    when an error was detected, and later another foreground task got posted
    when all bytes were received to do the full module check. Having two
    foreground tasks at the same time violates an invariant in the
    AsyncCompileJob.
    
    With this CL we avoid the initial function validation after a
    prefix_cache_hit to avoid the task for the error handling. Validation
    will anyways happen again if the full module check fails later, or
    validation is unnecessary if the full module check succeeds, as the
    module has already been validated before.
    
    R=clemensb@chromium.org
    
    Bug: v8:13147, v8:12852
    Change-Id: Iae24c056057f3a5dfd2f61accd1f9f0d35412996
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3812038
    Commit-Queue: Andreas Haas <ahaas@chromium.org>
    Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
    Cr-Commit-Position: refs/heads/main@{#82218}
    2b50e9ce
Name
Last commit
Last update
..
baseline Loading commit data...
DEPS Loading commit data...
DIR_METADATA Loading commit data...
OWNERS Loading commit data...
assembler-buffer-cache.cc Loading commit data...
assembler-buffer-cache.h Loading commit data...
branch-hint-map.h Loading commit data...
c-api.cc Loading commit data...
c-api.h Loading commit data...
canonical-types.cc Loading commit data...
canonical-types.h Loading commit data...
code-space-access.cc Loading commit data...
code-space-access.h Loading commit data...
compilation-environment.h Loading commit data...
constant-expression-interface.cc Loading commit data...
constant-expression-interface.h Loading commit data...
constant-expression.cc Loading commit data...
constant-expression.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-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-impl.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...
names-provider.cc Loading commit data...
names-provider.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...
stacks.h Loading commit data...
streaming-decoder.cc Loading commit data...
streaming-decoder.h Loading commit data...
string-builder-multiline.h Loading commit data...
string-builder.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-disassembler-impl.h Loading commit data...
wasm-disassembler.cc Loading commit data...
wasm-disassembler.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.cc 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...