RFR: 8256658: Shenandoah: Deadlock between nmethod_entry_barrier and concurrent code root evacuator

Roman Kennke rkennke at openjdk.java.net
Fri Nov 20 14:52:03 UTC 2020


On Fri, 20 Nov 2020 14:36:23 GMT, Zhengyu Gu <zgu at openjdk.org> wrote:

> Nightly tests revealed a deadlock after JDK-8256415.
> 
> The new concurrent code root evacuating/updating task sets up EvacOOM scope on the top level. If OOM occurs and nmethod_entry_barrier holds per-nmethod lock, while concurrent code root evacuating/updating task tries to acquire the exact per-nmethod lock, we deadlock.
> 
> The solution is to move EvacOOM scope under per-nmethod lock.
> 
> Test:
> - [x] hotspot_gc_shenandoah
> - [x] nightly tests

Looks good to me! Thanks!

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

Marked as reviewed by rkennke (Reviewer).

PR: https://git.openjdk.java.net/jdk/pull/1352


More information about the shenandoah-dev mailing list