RFR: 8258380: [JVMCI] don't clear InstalledCode reference when unloading JVMCI nmethods

Tom Rodriguez never at openjdk.java.net
Tue Dec 15 07:06:04 UTC 2020


We have been getting crashes running our unit tests in our gates with JDK15. The crashes are mostly in nmethod::is_unloaded because IsUnloadingBehaviour::current() is null. It seemed like there was some inconsistency in the notion of is_unloading for JVMCI nmethods that was leading to the crashes. I noticed that the is_unloading path rescans the nmethod using a closure to determine if it's unloading and since make_unloaded will clear the InstalledCode reference at the end if you ran the closure again it might return false since the oop is now null instead of being an unmarked oop. There's no point in the clearly the oop in this path anyway since the nmethod is dead and leaving the oop around seem to solve this crash. We're only see this crash in 15 but I don't see why it couldn't occur in 11 or later.

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

Commit messages:
 - 8258380: [JVMCI] don't clear InstalledCode reference when unloading JVMCI nmethods

Changes: https://git.openjdk.java.net/jdk/pull/1777/files
 Webrev: https://webrevs.openjdk.java.net/?repo=jdk&pr=1777&range=00
  Issue: https://bugs.openjdk.java.net/browse/JDK-8258380
  Stats: 7 lines in 2 files changed: 6 ins; 1 del; 0 mod
  Patch: https://git.openjdk.java.net/jdk/pull/1777.diff
  Fetch: git fetch https://git.openjdk.java.net/jdk pull/1777/head:pull/1777

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


More information about the hotspot-compiler-dev mailing list