RFR: 8210233: Prepare Klass::is_loader_alive() for concurrent class unloading
Kim Barrett
kim.barrett at oracle.com
Thu Aug 30 19:27:03 UTC 2018
> On Aug 30, 2018, at 2:56 PM, Erik Österlund <erik.osterlund at oracle.com> wrote:
>
> Hi,
>
> The Klass::is_loader_alive() facility currently assumes that CLDs are set to unloading before giving a correct answer. This is a problem for concurrent class unloading. This needs to instead be evaluated in a more concurrency friendly fashion, so that it will give the right answer even in concurrent contexts.
>
> The proposed solution is to stop using the cached unloading value, and instead ask the CLD if it is_alive(), which utilizes a phantom load on the CLD holder, and is concurrency friendly.
>
> Webrev:
> http://cr.openjdk.java.net/~eosterlund/8210233/webrev.00/
>
> Bug:
> https://bugs.openjdk.java.net/browse/JDK-8210233
>
> Thanks,
> /Erik
Nearby comments involving "unloading" should be updated.
More information about the hotspot-runtime-dev
mailing list