RFR: 8352299: GenShen: Young cycles that interrupt old cycles cannot be cancelled [v4]

William Kemper wkemper at openjdk.org
Tue Mar 25 17:51:41 UTC 2025


> The sequence of events that creates this state:
> 1. An old collection is trying to finish marking by flushing SATB buffers with a Handshake
> 2. The regulator thread cancels old marking to start a young collection
> 3. A mutator thread shortly follows and attempts to cancel the nascent young collection
> 4. Step `3` fails (because of this bug) and cancellation reason does _not_ become `allocation failure`
> 5. The mutator thread enters a tight loop in which it retries allocations without `waiting`
> 6. The mutator thread remains in the `thread_in_vm` state and prevents the VM thread from completing step `1`.

William Kemper has updated the pull request incrementally with one additional commit since the last revision:

  Stop casting GCCause to jbyte

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

Changes:
  - all: https://git.openjdk.org/jdk/pull/24105/files
  - new: https://git.openjdk.org/jdk/pull/24105/files/ca45ff02..abce0381

Webrevs:
 - full: https://webrevs.openjdk.org/?repo=jdk&pr=24105&range=03
 - incr: https://webrevs.openjdk.org/?repo=jdk&pr=24105&range=02-03

  Stats: 1 line in 1 file changed: 0 ins; 0 del; 1 mod
  Patch: https://git.openjdk.org/jdk/pull/24105.diff
  Fetch: git fetch https://git.openjdk.org/jdk.git pull/24105/head:pull/24105

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


More information about the shenandoah-dev mailing list