Improving the scalability of the evac OOM protocol
Aleksey Shipilev
shade at redhat.com
Tue Oct 4 14:42:11 UTC 2022
On 10/4/22 14:56, Nick Gasson wrote:
> I tried fixing this in a fairly simple way by replicating the counter N
> times on separate cache lines (N=64, somewhat arbitrarily). See the
> draft patch below:
>
> https://github.com/nick-arm/jdk/commit/ca78e77f0c6
>
> Each thread hashes to a particular counter based on its Thread*.
Yes, stripped counter works here fine.
> I've also tested SPECjbb on a fastdebug build with
> -XX:+ShenandoahOOMDuringEvacALot and didn't see any errors.
make test TEST=hotspot_gc_shenandoah exercises evac paths a lot, consider running it on affected
platforms.
> I experimented with taking this to its logical conclusion and giving
> each thread its own counter in ShenandoahThreadLocalData, but it's
> difficult to avoid races with thread creation and this simple approach
> seems to give most of the benefit anyway.
>
> Any thoughts on this?
Looks very good, please PR this. There are minor improvements we can do to this patch.
--
Thanks,
-Aleksey
More information about the shenandoah-dev
mailing list