public final class com.oracle.svm.core.genscavenge.GCAccounting
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: com.oracle.svm.core.genscavenge.GCAccounting
  super_class: java.lang.Object
{
  private long incrementalCollectionCount;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private long incrementalCollectionTotalNanos;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private long completeCollectionCount;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private long completeCollectionTotalNanos;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord collectedTotalChunkBytes;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord allocatedChunkBytes;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord promotedTotalChunkBytes;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord copiedTotalChunkBytes;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord youngChunkBytesBefore;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord youngChunkBytesAfter;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord oldChunkBytesBefore;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord oldChunkBytesAfter;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord lastCollectionPromotedChunkBytes;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord collectedTotalObjectBytes;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord youngObjectBytesBefore;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord oldObjectBytesBefore;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  private org.graalvm.word.UnsignedWord allocatedObjectBytes;
    descriptor: Lorg/graalvm/word/UnsignedWord;
    flags: (0x0002) ACC_PRIVATE

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 68
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 42
            aload 0 /* this */
            lconst_0
            putfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionCount:J
         2: .line 43
            aload 0 /* this */
            lconst_0
            putfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionTotalNanos:J
         3: .line 44
            aload 0 /* this */
            lconst_0
            putfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionCount:J
         4: .line 45
            aload 0 /* this */
            lconst_0
            putfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionTotalNanos:J
         5: .line 46
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.collectedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
         6: .line 47
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.allocatedChunkBytes:Lorg/graalvm/word/UnsignedWord;
         7: .line 48
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.promotedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
         8: .line 49
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.copiedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
         9: .line 52
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
        10: .line 53
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
        11: .line 54
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
        12: .line 55
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
        13: .line 56
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.lastCollectionPromotedChunkBytes:Lorg/graalvm/word/UnsignedWord;
        14: .line 62
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.collectedTotalObjectBytes:Lorg/graalvm/word/UnsignedWord;
        15: .line 63
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.youngObjectBytesBefore:Lorg/graalvm/word/UnsignedWord;
        16: .line 64
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.oldObjectBytesBefore:Lorg/graalvm/word/UnsignedWord;
        17: .line 65
            aload 0 /* this */
            invokestatic org.graalvm.word.WordFactory.zero:()Lorg/graalvm/word/WordBase;
            checkcast org.graalvm.word.UnsignedWord
            putfield com.oracle.svm.core.genscavenge.GCAccounting.allocatedObjectBytes:Lorg/graalvm/word/UnsignedWord;
        18: .line 69
            return
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   19     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;
    RuntimeVisibleAnnotations: 
      org.graalvm.nativeimage.Platforms(value = {Lorg/graalvm/nativeimage/Platform$HOSTED_ONLY;})

  public long getIncrementalCollectionCount();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 72
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionCount:J
            lreturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  public long getIncrementalCollectionTotalNanos();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 76
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionTotalNanos:J
            lreturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  org.graalvm.word.UnsignedWord getAllocatedChunkBytes();
    descriptor: ()Lorg/graalvm/word/UnsignedWord;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 80
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.allocatedChunkBytes:Lorg/graalvm/word/UnsignedWord;
            areturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  public long getCompleteCollectionCount();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 84
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionCount:J
            lreturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  public long getCompleteCollectionTotalNanos();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 88
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionTotalNanos:J
            lreturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  org.graalvm.word.UnsignedWord getCollectedTotalChunkBytes();
    descriptor: ()Lorg/graalvm/word/UnsignedWord;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 92
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.collectedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
            areturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  org.graalvm.word.UnsignedWord getCollectedTotalObjectBytes();
    descriptor: ()Lorg/graalvm/word/UnsignedWord;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 96
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.collectedTotalObjectBytes:Lorg/graalvm/word/UnsignedWord;
            areturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  org.graalvm.word.UnsignedWord getAllocatedObjectBytes();
    descriptor: ()Lorg/graalvm/word/UnsignedWord;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 100
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.allocatedObjectBytes:Lorg/graalvm/word/UnsignedWord;
            areturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  public org.graalvm.word.UnsignedWord getOldGenerationAfterChunkBytes();
    descriptor: ()Lorg/graalvm/word/UnsignedWord;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 104
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
            areturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  org.graalvm.word.UnsignedWord getYoungChunkBytesAfter();
    descriptor: ()Lorg/graalvm/word/UnsignedWord;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 108
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
            areturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  public static org.graalvm.word.UnsignedWord getSurvivorSpaceAfterChunkBytes(int);
    descriptor: (I)Lorg/graalvm/word/UnsignedWord;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // int survivorIndex
         0: .line 112
            invokestatic com.oracle.svm.core.genscavenge.HeapImpl.getHeapImpl:()Lcom/oracle/svm/core/genscavenge/HeapImpl;
            invokevirtual com.oracle.svm.core.genscavenge.HeapImpl.getYoungGeneration:()Lcom/oracle/svm/core/genscavenge/YoungGeneration;
            iload 0 /* survivorIndex */
            invokevirtual com.oracle.svm.core.genscavenge.YoungGeneration.getSurvivorFromSpaceAt:(I)Lcom/oracle/svm/core/genscavenge/Space;
            invokevirtual com.oracle.svm.core.genscavenge.Space.getChunkBytes:()Lorg/graalvm/word/UnsignedWord;
            areturn
        end local 0 // int survivorIndex
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    1     0  survivorIndex  I
    MethodParameters:
               Name  Flags
      survivorIndex  

  org.graalvm.word.UnsignedWord getLastCollectionPromotedChunkBytes();
    descriptor: ()Lorg/graalvm/word/UnsignedWord;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 116
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.lastCollectionPromotedChunkBytes:Lorg/graalvm/word/UnsignedWord;
            areturn
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/svm/core/genscavenge/GCAccounting;

  void beforeCollection();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 120
            invokestatic com.oracle.svm.core.log.Log.noopLog:()Lcom/oracle/svm/core/log/Log;
            ldc "[GCImpl.Accounting.beforeCollection:"
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            invokevirtual com.oracle.svm.core.log.Log.newline:()Lcom/oracle/svm/core/log/Log;
            astore 1 /* trace */
        start local 1 // com.oracle.svm.core.log.Log trace
         1: .line 122
            invokestatic com.oracle.svm.core.genscavenge.HeapImpl.getHeapImpl:()Lcom/oracle/svm/core/genscavenge/HeapImpl;
            astore 2 /* heap */
        start local 2 // com.oracle.svm.core.genscavenge.HeapImpl heap
         2: .line 123
            aload 2 /* heap */
            invokevirtual com.oracle.svm.core.genscavenge.HeapImpl.getYoungGeneration:()Lcom/oracle/svm/core/genscavenge/YoungGeneration;
            astore 3 /* youngGen */
        start local 3 // com.oracle.svm.core.genscavenge.YoungGeneration youngGen
         3: .line 124
            aload 0 /* this */
            aload 3 /* youngGen */
            invokevirtual com.oracle.svm.core.genscavenge.YoungGeneration.getChunkBytes:()Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
         4: .line 126
            aload 2 /* heap */
            invokevirtual com.oracle.svm.core.genscavenge.HeapImpl.getOldGeneration:()Lcom/oracle/svm/core/genscavenge/OldGeneration;
            invokevirtual com.oracle.svm.core.genscavenge.OldGeneration.getFromSpace:()Lcom/oracle/svm/core/genscavenge/Space;
            astore 4 /* oldSpace */
        start local 4 // com.oracle.svm.core.genscavenge.Space oldSpace
         5: .line 127
            aload 0 /* this */
            aload 4 /* oldSpace */
            invokevirtual com.oracle.svm.core.genscavenge.Space.getChunkBytes:()Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
         6: .line 129
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.allocatedChunkBytes:Lorg/graalvm/word/UnsignedWord;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.allocatedChunkBytes:Lorg/graalvm/word/UnsignedWord;
         7: .line 130
            getstatic com.oracle.svm.core.genscavenge.HeapOptions.PrintGCSummary:Lcom/oracle/svm/core/option/RuntimeOptionKey;
            invokevirtual com.oracle.svm.core.option.RuntimeOptionKey.getValue:()Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 11
         8: .line 131
            aload 0 /* this */
            aload 3 /* youngGen */
            invokevirtual com.oracle.svm.core.genscavenge.YoungGeneration.computeObjectBytes:()Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.youngObjectBytesBefore:Lorg/graalvm/word/UnsignedWord;
         9: .line 132
            aload 0 /* this */
            aload 4 /* oldSpace */
            invokevirtual com.oracle.svm.core.genscavenge.Space.computeObjectBytes:()Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.oldObjectBytesBefore:Lorg/graalvm/word/UnsignedWord;
        10: .line 133
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.allocatedObjectBytes:Lorg/graalvm/word/UnsignedWord;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.youngObjectBytesBefore:Lorg/graalvm/word/UnsignedWord;
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.allocatedObjectBytes:Lorg/graalvm/word/UnsignedWord;
        11: .line 135
      StackMap locals: com.oracle.svm.core.genscavenge.GCAccounting com.oracle.svm.core.log.Log com.oracle.svm.core.genscavenge.HeapImpl com.oracle.svm.core.genscavenge.YoungGeneration com.oracle.svm.core.genscavenge.Space
      StackMap stack:
            aload 1 /* trace */
            ldc "  youngChunkBytesBefore: "
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
            invokevirtual com.oracle.svm.core.log.Log.unsigned:(Lorg/graalvm/word/WordBase;)Lcom/oracle/svm/core/log/Log;
        12: .line 136
            ldc "  oldChunkBytesBefore: "
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
            invokevirtual com.oracle.svm.core.log.Log.unsigned:(Lorg/graalvm/word/WordBase;)Lcom/oracle/svm/core/log/Log;
            pop
        13: .line 137
            aload 1 /* trace */
            ldc "]"
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            invokevirtual com.oracle.svm.core.log.Log.newline:()Lcom/oracle/svm/core/log/Log;
            pop
        14: .line 138
            return
        end local 4 // com.oracle.svm.core.genscavenge.Space oldSpace
        end local 3 // com.oracle.svm.core.genscavenge.YoungGeneration youngGen
        end local 2 // com.oracle.svm.core.genscavenge.HeapImpl heap
        end local 1 // com.oracle.svm.core.log.Log trace
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   15     0      this  Lcom/oracle/svm/core/genscavenge/GCAccounting;
            1   15     1     trace  Lcom/oracle/svm/core/log/Log;
            2   15     2      heap  Lcom/oracle/svm/core/genscavenge/HeapImpl;
            3   15     3  youngGen  Lcom/oracle/svm/core/genscavenge/YoungGeneration;
            5   15     4  oldSpace  Lcom/oracle/svm/core/genscavenge/Space;

  void afterCollection(boolean, com.oracle.svm.core.genscavenge.Timer);
    descriptor: (ZLcom/oracle/svm/core/genscavenge/Timer;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
        start local 1 // boolean completeCollection
        start local 2 // com.oracle.svm.core.genscavenge.Timer collectionTimer
         0: .line 141
            iload 1 /* completeCollection */
            ifeq 3
         1: .line 142
            aload 0 /* this */
            aload 2 /* collectionTimer */
            invokevirtual com.oracle.svm.core.genscavenge.GCAccounting.afterCompleteCollection:(Lcom/oracle/svm/core/genscavenge/Timer;)V
         2: .line 143
            goto 4
         3: .line 144
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* collectionTimer */
            invokevirtual com.oracle.svm.core.genscavenge.GCAccounting.afterIncrementalCollection:(Lcom/oracle/svm/core/genscavenge/Timer;)V
         4: .line 146
      StackMap locals:
      StackMap stack:
            return
        end local 2 // com.oracle.svm.core.genscavenge.Timer collectionTimer
        end local 1 // boolean completeCollection
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    5     0                this  Lcom/oracle/svm/core/genscavenge/GCAccounting;
            0    5     1  completeCollection  Z
            0    5     2     collectionTimer  Lcom/oracle/svm/core/genscavenge/Timer;
    MethodParameters:
                    Name  Flags
      completeCollection  
      collectionTimer     

  private void afterIncrementalCollection(com.oracle.svm.core.genscavenge.Timer);
    descriptor: (Lcom/oracle/svm/core/genscavenge/Timer;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
        start local 1 // com.oracle.svm.core.genscavenge.Timer collectionTimer
         0: .line 149
            invokestatic com.oracle.svm.core.log.Log.noopLog:()Lcom/oracle/svm/core/log/Log;
            ldc "[GCImpl.Accounting.afterIncrementalCollection:"
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            astore 2 /* trace */
        start local 2 // com.oracle.svm.core.log.Log trace
         1: .line 155
            aload 0 /* this */
            dup
            getfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionCount:J
            lconst_1
            ladd
            putfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionCount:J
         2: .line 156
            aload 0 /* this */
            invokevirtual com.oracle.svm.core.genscavenge.GCAccounting.afterCollectionCommon:()V
         3: .line 158
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
            invokeinterface org.graalvm.word.UnsignedWord.subtract:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.lastCollectionPromotedChunkBytes:Lorg/graalvm/word/UnsignedWord;
         4: .line 159
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.promotedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.lastCollectionPromotedChunkBytes:Lorg/graalvm/word/UnsignedWord;
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.promotedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
         5: .line 160
            aload 0 /* this */
            dup
            getfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionTotalNanos:J
            aload 1 /* collectionTimer */
            invokevirtual com.oracle.svm.core.genscavenge.Timer.getMeasuredNanos:()J
            ladd
            putfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionTotalNanos:J
         6: .line 161
            aload 2 /* trace */
            ldc "  incrementalCollectionCount: "
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.incrementalCollectionCount:J
            invokevirtual com.oracle.svm.core.log.Log.signed:(J)Lcom/oracle/svm/core/log/Log;
         7: .line 162
            ldc "  oldChunkBytesAfter: "
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
            invokevirtual com.oracle.svm.core.log.Log.unsigned:(Lorg/graalvm/word/WordBase;)Lcom/oracle/svm/core/log/Log;
         8: .line 163
            ldc "  oldChunkBytesBefore: "
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
            invokevirtual com.oracle.svm.core.log.Log.unsigned:(Lorg/graalvm/word/WordBase;)Lcom/oracle/svm/core/log/Log;
         9: .line 164
            ldc "  promotedChunkBytes: "
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.lastCollectionPromotedChunkBytes:Lorg/graalvm/word/UnsignedWord;
            invokevirtual com.oracle.svm.core.log.Log.unsigned:(Lorg/graalvm/word/WordBase;)Lcom/oracle/svm/core/log/Log;
            pop
        10: .line 165
            aload 2 /* trace */
            ldc "]"
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            invokevirtual com.oracle.svm.core.log.Log.newline:()Lcom/oracle/svm/core/log/Log;
            pop
        11: .line 166
            return
        end local 2 // com.oracle.svm.core.log.Log trace
        end local 1 // com.oracle.svm.core.genscavenge.Timer collectionTimer
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   12     0             this  Lcom/oracle/svm/core/genscavenge/GCAccounting;
            0   12     1  collectionTimer  Lcom/oracle/svm/core/genscavenge/Timer;
            1   12     2            trace  Lcom/oracle/svm/core/log/Log;
    MethodParameters:
                 Name  Flags
      collectionTimer  

  private void afterCompleteCollection(com.oracle.svm.core.genscavenge.Timer);
    descriptor: (Lcom/oracle/svm/core/genscavenge/Timer;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
        start local 1 // com.oracle.svm.core.genscavenge.Timer collectionTimer
         0: .line 169
            invokestatic com.oracle.svm.core.log.Log.noopLog:()Lcom/oracle/svm/core/log/Log;
            ldc "[GCImpl.Accounting.afterCompleteCollection:"
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            astore 2 /* trace */
        start local 2 // com.oracle.svm.core.log.Log trace
         1: .line 170
            aload 0 /* this */
            dup
            getfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionCount:J
            lconst_1
            ladd
            putfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionCount:J
         2: .line 171
            aload 0 /* this */
            invokevirtual com.oracle.svm.core.genscavenge.GCAccounting.afterCollectionCommon:()V
         3: .line 173
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.copiedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.copiedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
         4: .line 174
            aload 0 /* this */
            dup
            getfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionTotalNanos:J
            aload 1 /* collectionTimer */
            invokevirtual com.oracle.svm.core.genscavenge.Timer.getMeasuredNanos:()J
            ladd
            putfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionTotalNanos:J
         5: .line 175
            aload 2 /* trace */
            ldc "  completeCollectionCount: "
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.completeCollectionCount:J
            invokevirtual com.oracle.svm.core.log.Log.signed:(J)Lcom/oracle/svm/core/log/Log;
         6: .line 176
            ldc "  oldChunkBytesAfter: "
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
            invokevirtual com.oracle.svm.core.log.Log.unsigned:(Lorg/graalvm/word/WordBase;)Lcom/oracle/svm/core/log/Log;
            pop
         7: .line 177
            aload 2 /* trace */
            ldc "]"
            invokevirtual com.oracle.svm.core.log.Log.string:(Ljava/lang/String;)Lcom/oracle/svm/core/log/Log;
            invokevirtual com.oracle.svm.core.log.Log.newline:()Lcom/oracle/svm/core/log/Log;
            pop
         8: .line 178
            return
        end local 2 // com.oracle.svm.core.log.Log trace
        end local 1 // com.oracle.svm.core.genscavenge.Timer collectionTimer
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    9     0             this  Lcom/oracle/svm/core/genscavenge/GCAccounting;
            0    9     1  collectionTimer  Lcom/oracle/svm/core/genscavenge/Timer;
            1    9     2            trace  Lcom/oracle/svm/core/log/Log;
    MethodParameters:
                 Name  Flags
      collectionTimer  

  void afterCollectionCommon();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=11, args_size=1
        start local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
         0: .line 181
            invokestatic com.oracle.svm.core.genscavenge.HeapImpl.getHeapImpl:()Lcom/oracle/svm/core/genscavenge/HeapImpl;
            astore 1 /* heap */
        start local 1 // com.oracle.svm.core.genscavenge.HeapImpl heap
         1: .line 183
            aload 1 /* heap */
            invokevirtual com.oracle.svm.core.genscavenge.HeapImpl.getYoungGeneration:()Lcom/oracle/svm/core/genscavenge/YoungGeneration;
            astore 2 /* youngGen */
        start local 2 // com.oracle.svm.core.genscavenge.YoungGeneration youngGen
         2: .line 184
            aload 0 /* this */
            aload 2 /* youngGen */
            invokevirtual com.oracle.svm.core.genscavenge.YoungGeneration.getChunkBytes:()Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
         3: .line 185
            aload 1 /* heap */
            invokevirtual com.oracle.svm.core.genscavenge.HeapImpl.getOldGeneration:()Lcom/oracle/svm/core/genscavenge/OldGeneration;
            invokevirtual com.oracle.svm.core.genscavenge.OldGeneration.getFromSpace:()Lcom/oracle/svm/core/genscavenge/Space;
            astore 3 /* oldSpace */
        start local 3 // com.oracle.svm.core.genscavenge.Space oldSpace
         4: .line 186
            aload 0 /* this */
            aload 3 /* oldSpace */
            invokevirtual com.oracle.svm.core.genscavenge.Space.getChunkBytes:()Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
         5: .line 187
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesBefore:Lorg/graalvm/word/UnsignedWord;
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            astore 4 /* beforeChunkBytes */
        start local 4 // org.graalvm.word.UnsignedWord beforeChunkBytes
         6: .line 188
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.youngChunkBytesAfter:Lorg/graalvm/word/UnsignedWord;
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            astore 5 /* afterChunkBytes */
        start local 5 // org.graalvm.word.UnsignedWord afterChunkBytes
         7: .line 189
            aload 4 /* beforeChunkBytes */
            aload 5 /* afterChunkBytes */
            invokeinterface org.graalvm.word.UnsignedWord.subtract:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            astore 6 /* collectedChunkBytes */
        start local 6 // org.graalvm.word.UnsignedWord collectedChunkBytes
         8: .line 190
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.collectedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
            aload 6 /* collectedChunkBytes */
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.collectedTotalChunkBytes:Lorg/graalvm/word/UnsignedWord;
         9: .line 191
            getstatic com.oracle.svm.core.genscavenge.HeapOptions.PrintGCSummary:Lcom/oracle/svm/core/option/RuntimeOptionKey;
            invokevirtual com.oracle.svm.core.option.RuntimeOptionKey.getValue:()Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 15
        10: .line 192
            aload 2 /* youngGen */
            invokevirtual com.oracle.svm.core.genscavenge.YoungGeneration.computeObjectBytes:()Lorg/graalvm/word/UnsignedWord;
            astore 7 /* youngObjectBytesAfter */
        start local 7 // org.graalvm.word.UnsignedWord youngObjectBytesAfter
        11: .line 193
            aload 3 /* oldSpace */
            invokevirtual com.oracle.svm.core.genscavenge.Space.computeObjectBytes:()Lorg/graalvm/word/UnsignedWord;
            astore 8 /* oldObjectBytesAfter */
        start local 8 // org.graalvm.word.UnsignedWord oldObjectBytesAfter
        12: .line 194
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.youngObjectBytesBefore:Lorg/graalvm/word/UnsignedWord;
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.oldObjectBytesBefore:Lorg/graalvm/word/UnsignedWord;
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            astore 9 /* beforeObjectBytes */
        start local 9 // org.graalvm.word.UnsignedWord beforeObjectBytes
        13: .line 195
            aload 9 /* beforeObjectBytes */
            aload 8 /* oldObjectBytesAfter */
            invokeinterface org.graalvm.word.UnsignedWord.subtract:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            aload 7 /* youngObjectBytesAfter */
            invokeinterface org.graalvm.word.UnsignedWord.subtract:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            astore 10 /* collectedObjectBytes */
        start local 10 // org.graalvm.word.UnsignedWord collectedObjectBytes
        14: .line 196
            aload 0 /* this */
            aload 0 /* this */
            getfield com.oracle.svm.core.genscavenge.GCAccounting.collectedTotalObjectBytes:Lorg/graalvm/word/UnsignedWord;
            aload 10 /* collectedObjectBytes */
            invokeinterface org.graalvm.word.UnsignedWord.add:(Lorg/graalvm/word/UnsignedWord;)Lorg/graalvm/word/UnsignedWord;
            putfield com.oracle.svm.core.genscavenge.GCAccounting.collectedTotalObjectBytes:Lorg/graalvm/word/UnsignedWord;
        end local 10 // org.graalvm.word.UnsignedWord collectedObjectBytes
        end local 9 // org.graalvm.word.UnsignedWord beforeObjectBytes
        end local 8 // org.graalvm.word.UnsignedWord oldObjectBytesAfter
        end local 7 // org.graalvm.word.UnsignedWord youngObjectBytesAfter
        15: .line 198
      StackMap locals: com.oracle.svm.core.genscavenge.GCAccounting com.oracle.svm.core.genscavenge.HeapImpl com.oracle.svm.core.genscavenge.YoungGeneration com.oracle.svm.core.genscavenge.Space org.graalvm.word.UnsignedWord org.graalvm.word.UnsignedWord org.graalvm.word.UnsignedWord
      StackMap stack:
            return
        end local 6 // org.graalvm.word.UnsignedWord collectedChunkBytes
        end local 5 // org.graalvm.word.UnsignedWord afterChunkBytes
        end local 4 // org.graalvm.word.UnsignedWord beforeChunkBytes
        end local 3 // com.oracle.svm.core.genscavenge.Space oldSpace
        end local 2 // com.oracle.svm.core.genscavenge.YoungGeneration youngGen
        end local 1 // com.oracle.svm.core.genscavenge.HeapImpl heap
        end local 0 // com.oracle.svm.core.genscavenge.GCAccounting this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   16     0                   this  Lcom/oracle/svm/core/genscavenge/GCAccounting;
            1   16     1                   heap  Lcom/oracle/svm/core/genscavenge/HeapImpl;
            2   16     2               youngGen  Lcom/oracle/svm/core/genscavenge/YoungGeneration;
            4   16     3               oldSpace  Lcom/oracle/svm/core/genscavenge/Space;
            6   16     4       beforeChunkBytes  Lorg/graalvm/word/UnsignedWord;
            7   16     5        afterChunkBytes  Lorg/graalvm/word/UnsignedWord;
            8   16     6    collectedChunkBytes  Lorg/graalvm/word/UnsignedWord;
           11   15     7  youngObjectBytesAfter  Lorg/graalvm/word/UnsignedWord;
           12   15     8    oldObjectBytesAfter  Lorg/graalvm/word/UnsignedWord;
           13   15     9      beforeObjectBytes  Lorg/graalvm/word/UnsignedWord;
           14   15    10   collectedObjectBytes  Lorg/graalvm/word/UnsignedWord;
}
SourceFile: "GCAccounting.java"