Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-8293431

G1: Investigate stalling allocating threads during shutdown instead of doing GC

XMLWordPrintable

    • Icon: Enhancement Enhancement
    • Resolution: Unresolved
    • Icon: P4 P4
    • tbd
    • 20
    • hotspot
    • gc

      After G1 stops concurrent threads during VM shutdown, particularly during concurrent clear bitmap, data structures may be in an inconsistent state:

      The bitmap still contains marks but the concurrent cycle state is indicated as idle.

      This means that some code relying on that consistency (basically that the bitmap is clear) needs to take extra precaution about this - JDK-8291725 and JDK-8274007 are the cases for young gc and full gc respectively where this issue cropped up.

      ZGC, instead of trying to take care of this problem during GC, just stalls the java threads that want to allocate at that time.

      Investigate whether stalling allocating threads that would otherwise cause a (GC) safepoint would be possible/reasonable for G1 too.

            Unassigned Unassigned
            tschatzl Thomas Schatzl
            Votes:
            0 Vote for this issue
            Watchers:
            2 Start watching this issue

              Created:
              Updated: