This occurs when an attempt to produce a heap dump conflicts with a concurrent 
cycle. The heap dump vm operation attempts to run a cycle directly on the VM 
thread with no regard for the state of the concurrent collection. Although 
Shenandoah _is_ technically capable of running an entire _full_ GCs on the vm 
thread, I would rather not add another dependency on full GCs, nor would I like 
to cancel an in-progress concurrent GC. Instead, Shenandoah will follow the 
pattern established ZGC in which the calling thread waits for a concurrent 
cycle to complete before taking the heap dump.

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

Commit messages:
 - Fix whitespace
 - Do not let heap inspection/dump run GC on VM thread

Changes: https://git.openjdk.org/jdk/pull/23186/files
  Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=23186&range=00
  Issue: https://bugs.openjdk.org/browse/JDK-8345750
  Stats: 23 lines in 4 files changed: 15 ins; 1 del; 7 mod
  Patch: https://git.openjdk.org/jdk/pull/23186.diff
  Fetch: git fetch https://git.openjdk.org/jdk.git pull/23186/head:pull/23186

PR: https://git.openjdk.org/jdk/pull/23186

Reply via email to