• Leszek Swirski's avatar
    [offthread] Make publish merging and handle fixup atomic · bbc8f787
    Leszek Swirski authored
    Make sure that any GCs required for off-thread heap merging happen
    before any off-thread handle transferring (both transferring using
    OffThreadTransferHandle, and the handles created for the string slot
    fixups). This is to avoid the marker from walking Handle roots that
    point into off-thread pages which the sweeper doesn't see (and can't
    clear mark bits on)
    
    Now, the merging and handle creation is atomic as far as the GC is
    concerned. The merging is done before handle creation to avoid the
    incremental marker from entering off-thread pages, but we ensure that
    the raw objects pointers that point into the off-thread pages (which
    are used for creating the main-thread handles) stay valid until the
    handle creation completes.
    
    Since handle transfer now happens in the middle of publishing, this
    patch also moves the OffThreadTransferHandleStorage ownership over to
    OffThreadHeap. This requires some header juggling to avoid leaking
    OffThreadTransferHandleStorage into the off-thread-isolate header.
    
    Bug: chromium:1086478, chromium:1011762
    Change-Id: Id5e7622d6b5520400a4872c5f6ad396c74b30ca6
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2218058Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
    Reviewed-by: 's avatarToon Verwaest <verwaest@chromium.org>
    Auto-Submit: Leszek Swirski <leszeks@chromium.org>
    Commit-Queue: Toon Verwaest <verwaest@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#68043}
    bbc8f787
Name
Last commit
Last update
build_overrides Loading commit data...
custom_deps Loading commit data...
docs Loading commit data...
gni Loading commit data...
include Loading commit data...
infra Loading commit data...
samples Loading commit data...
src Loading commit data...
test Loading commit data...
testing Loading commit data...
third_party Loading commit data...
tools Loading commit data...
.clang-format Loading commit data...
.clang-tidy Loading commit data...
.editorconfig Loading commit data...
.flake8 Loading commit data...
.git-blame-ignore-revs Loading commit data...
.gitattributes Loading commit data...
.gitignore Loading commit data...
.gn Loading commit data...
.vpython Loading commit data...
.ycm_extra_conf.py Loading commit data...
AUTHORS Loading commit data...
BUILD.gn Loading commit data...
CODE_OF_CONDUCT.md Loading commit data...
COMMON_OWNERS Loading commit data...
DEPS Loading commit data...
ENG_REVIEW_OWNERS Loading commit data...
INFRA_OWNERS Loading commit data...
INTL_OWNERS Loading commit data...
LICENSE Loading commit data...
LICENSE.fdlibm Loading commit data...
LICENSE.strongtalk Loading commit data...
LICENSE.v8 Loading commit data...
LICENSE.valgrind Loading commit data...
MIPS_OWNERS Loading commit data...
OWNERS Loading commit data...
PPC_OWNERS Loading commit data...
PRESUBMIT.py Loading commit data...
README.md Loading commit data...
S390_OWNERS Loading commit data...
WATCHLISTS Loading commit data...
codereview.settings Loading commit data...