[jdk19] RFR: 8290250: Shenandoah: disable Loom for iu mode

Zhengyu Gu zgu at openjdk.org
Thu Jul 14 17:20:28 UTC 2022


On Wed, 13 Jul 2022 20:01:51 GMT, Erik Österlund <eosterlund at openjdk.org> wrote:

> > > Speaking of IU mode, how does Shenandoah IU mode deal with barrier elision on newly allocated objects? It was only valid in CMS because the entire young generation was traversed when terminating the concurrent marking, so that unvisited pointers could be found.
> > 
> > 
> > Shenandoah SATB/IU both elide barrier on newly allocated objects. SATB barrier should guarantee they can only refer marked objects. Do I miss anything?
> 
> Yes, I believe so. For a SATB collector, it is okay to elide the barrier on newly allocated objects, because they were not part of the snapshot-of-the-beginning, and all new objects are implicitly alive and don't need to be visited.
> 
> However, with an IU scheme, that property does not translate.
> 
> Consider that you have a particular object graph when marking starts, then one mutator loads an object from the graph, and clears the field such that it is only reachable from the roots of said murator thread. Then the mutator writes the object to a newly allocated object without barriers and discards the root. Now, the reference is only reachable from the newly allocated object.
> 
> So for this elision to be valid with IU, the GC has to visit newly allocated objects again before terminating, which e.g. CMS indeed did, by doing a young collection in the safepoint that terminated old marking, but I don't know that Shenandoah does anything like that.

Unfortunately, IU problem is beyond the barrier elision. Even I don't elide the barrier for IU, I still see failures.

-------------

PR: https://git.openjdk.org/jdk19/pull/140



More information about the hotspot-gc-dev mailing list