• Dominik Inführ's avatar
    Use list of invalidated objects for old-to-new refs · 60843b42
    Dominik Inführ authored
    Instead of inserting "deletion" entries into the store buffer, keep a
    list of invalidated objects to filter out invalid old-to-new slots.
    
    The first CL https://crrev.com/c/1704109 got reverted because both the
    sweeper and the main task were modifying the invalidated slots data
    structure concurrently. This CL changes this, such that the sweeper
    only modifies the invalidated slots during the final atomic pause when
    the main thread is not running. The sweeper does not need to clean this
    data structure after the pause, since the "update pointers" phase
    already removed all invalidated slots.
    
    The second CL https://crrev.com/c/1733081 got reverted because the
    sweeper might find more free space than the full GC before it. If an
    object shrinks after the pause but before the sweep, the invalidated
    object might span free memory and potentially new allocated objects.
    Therefore shrink invalidated objects when processing swept pages on
    the main thread. Also clean recorded slots in the gap.
    
    TBR=petermarshall@chromium.org
    
    Bug: v8:9454
    Change-Id: I80d1fa3bbc24e97f7c97a373aaad66f105456f12
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1751795
    Commit-Queue: Dominik Inführ <dinfuehr@chromium.org>
    Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#63239}
    60843b42
heap.cc 223 KB