• Ulan Degenbaev's avatar
    [heap] Fix black allocation. · 97b2a814
    Ulan Degenbaev authored
    This patch ensures that an object returned by AllocateRaw is marked
    black if black allocation starts during the object allocation.
    
    This fixes the following issue:
    1) Generated code requests allocation of size N for folded allocation.
    2) Runtime gets a free list node at address A of size N+M and sets up
       a linear allocation area with top = A+N and limit = A+N+M.
    3) Runtime invokes the allocation observer that starts incremental marking
       and start black allocation. The area [A+N, A+N+M) is marked black.
    4) Runtime returns a white object at address A as the allocation result.
    5) Generated code moves the top pointer to A and does bump pointer
       allocations of white objects from A to A+N+M.
    6) Object allocated new A+N can have the impossible marbit pattern.
    
    Bug: chromium:694255
    Change-Id: I09ceebc97a510fa5fe4ff20706bc46a99f8b7cf4
    Reviewed-on: https://chromium-review.googlesource.com/638338
    Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
    Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#48005}
    97b2a814
Name
Last commit
Last update
..
OWNERS Loading commit data...
array-buffer-tracker-inl.h Loading commit data...
array-buffer-tracker.cc Loading commit data...
array-buffer-tracker.h Loading commit data...
barrier.h Loading commit data...
code-stats.cc Loading commit data...
code-stats.h Loading commit data...
concurrent-marking.cc Loading commit data...
concurrent-marking.h Loading commit data...
embedder-tracing.cc Loading commit data...
embedder-tracing.h Loading commit data...
gc-idle-time-handler.cc Loading commit data...
gc-idle-time-handler.h Loading commit data...
gc-tracer.cc Loading commit data...
gc-tracer.h Loading commit data...
heap-inl.h Loading commit data...
heap.cc Loading commit data...
heap.h Loading commit data...
incremental-marking-inl.h Loading commit data...
incremental-marking-job.cc Loading commit data...
incremental-marking-job.h Loading commit data...
incremental-marking.cc Loading commit data...
incremental-marking.h Loading commit data...
invalidated-slots-inl.h Loading commit data...
invalidated-slots.cc Loading commit data...
invalidated-slots.h Loading commit data...
item-parallel-job.h Loading commit data...
local-allocator.h Loading commit data...
mark-compact-inl.h Loading commit data...
mark-compact.cc Loading commit data...
mark-compact.h Loading commit data...
marking.cc Loading commit data...
marking.h Loading commit data...
memory-reducer.cc Loading commit data...
memory-reducer.h Loading commit data...
object-stats.cc Loading commit data...
object-stats.h Loading commit data...
objects-visiting-inl.h Loading commit data...
objects-visiting.cc Loading commit data...
objects-visiting.h Loading commit data...
remembered-set.h Loading commit data...
scavenge-job.cc Loading commit data...
scavenge-job.h Loading commit data...
scavenger-inl.h Loading commit data...
scavenger.cc Loading commit data...
scavenger.h Loading commit data...
sequential-marking-deque.cc Loading commit data...
sequential-marking-deque.h Loading commit data...
setup-heap-internal.cc Loading commit data...
slot-set.h Loading commit data...
spaces-inl.h Loading commit data...
spaces.cc Loading commit data...
spaces.h Loading commit data...
store-buffer.cc Loading commit data...
store-buffer.h Loading commit data...
worklist.h Loading commit data...