• Leszek Swirski's avatar
    [snapshot] Guard against flushing when installing native IET · eec3f923
    Leszek Swirski authored
    CreateInterpreterDataForDeserializedCode checks for bytecode, copies the
    InterpreterEntryTrampoline, and installs that and the bytecode on
    InterpreterData. However, the bytecode can be flushed when the IET is
    copied, which results in a failure to read it afterward.
    
    Add an IsCompiledScope to guard against this.
    
    As a drive-by, guard against baseline code being installed on the
    function. This shouldn't happen in normal execution, but could
    theoretically happen with some extra support for --always-sparkplug.
    
    Bug: chromium:1308178
    Change-Id: Ia5e81b376bff2aaa19e9c6007242629ab8b0d4a8
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3545171Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
    Auto-Submit: Leszek Swirski <leszeks@chromium.org>
    Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
    Commit-Queue: Michael Lippautz <mlippautz@chromium.org>
    Cr-Commit-Position: refs/heads/main@{#79580}
    eec3f923
code-serializer.cc 27.6 KB