public class org.graalvm.compiler.core.test.DeepUnrollingTest extends org.graalvm.compiler.core.test.SubprocessTest
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.core.test.DeepUnrollingTest
  super_class: org.graalvm.compiler.core.test.SubprocessTest
{
  private static final int ACCEPTABLE_FACTOR;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 100

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
         0: .line 37
            aload 0 /* this */
            invokespecial org.graalvm.compiler.core.test.SubprocessTest.<init>:()V
            return
        end local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/core/test/DeepUnrollingTest;

  public static void loops();
    descriptor: ()V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=4, args_size=0
         0: .line 40
            iconst_0
            istore 0 /* i */
        start local 0 // int i
         1: goto 15
         2: .line 41
      StackMap locals: int
      StackMap stack:
            iconst_2
            istore 1 /* n */
        start local 1 // int n
         3: goto 13
         4: .line 42
      StackMap locals: int
      StackMap stack:
            iconst_1
            istore 2 /* j */
        start local 2 // int j
         5: goto 11
         6: .line 43
      StackMap locals: int
      StackMap stack:
            iconst_1
            istore 3 /* k */
        start local 3 // int k
         7: goto 9
      StackMap locals: int
      StackMap stack:
         8: iinc 3 /* k */ 1
      StackMap locals:
      StackMap stack:
         9: iload 3 /* k */
            iload 2 /* j */
            if_icmple 8
        end local 3 // int k
        10: .line 42
            iinc 2 /* j */ 1
      StackMap locals:
      StackMap stack:
        11: iload 2 /* j */
            iload 1 /* n */
            if_icmple 6
        end local 2 // int j
        12: .line 41
            iinc 1 /* n */ 1
      StackMap locals:
      StackMap stack:
        13: iload 1 /* n */
            bipush 30
            if_icmplt 4
        end local 1 // int n
        14: .line 40
            iinc 0 /* i */ 1
      StackMap locals:
      StackMap stack:
        15: iload 0 /* i */
            bipush 6
            if_icmplt 2
        end local 0 // int i
        16: .line 49
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            1   16     0     i  I
            3   14     1     n  I
            5   12     2     j  I
            7   10     3     k  I

  public static int reference(int, int);
    descriptor: (II)I
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // int a
        start local 1 // int n
         0: .line 52
            iload 0 /* a */
            istore 2 /* v */
        start local 2 // int v
         1: .line 53
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         2: goto 8
         3: .line 54
      StackMap locals: int int
      StackMap stack:
            iload 2 /* v */
            iconst_2
            irem
            ifne 6
         4: .line 55
            iload 2 /* v */
            iconst_2
            idiv
            istore 2 /* v */
         5: .line 56
            goto 7
         6: .line 57
      StackMap locals:
      StackMap stack:
            iconst_3
            iload 2 /* v */
            imul
            iconst_1
            iadd
            istore 2 /* v */
         7: .line 53
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 3 /* i */
            iload 1 /* n */
            if_icmplt 3
        end local 3 // int i
         9: .line 60
            iload 2 /* v */
            ireturn
        end local 2 // int v
        end local 1 // int n
        end local 0 // int a
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0     a  I
            0   10     1     n  I
            1   10     2     v  I
            2    9     3     i  I
    MethodParameters:
      Name  Flags
      a     
      n     

  public void loopTest();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=1
        start local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
         0: .line 67
            aload 0 /* this */
            ldc "reference"
            invokevirtual org.graalvm.compiler.core.test.DeepUnrollingTest.timeStream:(Ljava/lang/String;)Ljava/util/stream/LongStream;
            ldc 5
            invokeinterface java.util.stream.LongStream.limit:(J)Ljava/util/stream/LongStream;
            invokeinterface java.util.stream.LongStream.sum:()J
            pop2
         1: .line 68
            aload 0 /* this */
            ldc "loops"
            invokevirtual org.graalvm.compiler.core.test.DeepUnrollingTest.timeStream:(Ljava/lang/String;)Ljava/util/stream/LongStream;
            ldc 5
            invokeinterface java.util.stream.LongStream.limit:(J)Ljava/util/stream/LongStream;
            invokeinterface java.util.stream.LongStream.sum:()J
            pop2
         2: .line 70
            aload 0 /* this */
            ldc "reference"
            invokevirtual org.graalvm.compiler.core.test.DeepUnrollingTest.timeStream:(Ljava/lang/String;)Ljava/util/stream/LongStream;
            ldc 5
            invokeinterface java.util.stream.LongStream.limit:(J)Ljava/util/stream/LongStream;
            invokeinterface java.util.stream.LongStream.max:()Ljava/util/OptionalLong;
            invokevirtual java.util.OptionalLong.getAsLong:()J
            lstore 1 /* reference */
        start local 1 // long reference
         3: .line 71
            aload 0 /* this */
            ldc "loops"
            invokevirtual org.graalvm.compiler.core.test.DeepUnrollingTest.timeStream:(Ljava/lang/String;)Ljava/util/stream/LongStream;
            ldc 5
            invokeinterface java.util.stream.LongStream.limit:(J)Ljava/util/stream/LongStream;
            invokeinterface java.util.stream.LongStream.min:()Ljava/util/OptionalLong;
            invokevirtual java.util.OptionalLong.getAsLong:()J
            lstore 3 /* loops */
        start local 3 // long loops
         4: .line 73
            lload 3 /* loops */
            lload 1 /* reference */
            ldc 100
            lmul
            lcmp
            ifle 6
         5: .line 74
            ldc "Compilation of the loop nest is too slow. loops: %dms > %d * reference: %dms"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            lload 3 /* loops */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_1
            bipush 100
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_2
            lload 1 /* reference */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            invokestatic org.graalvm.compiler.core.test.DeepUnrollingTest.fail:(Ljava/lang/String;[Ljava/lang/Object;)V
         6: .line 76
      StackMap locals: long long
      StackMap stack:
            return
        end local 3 // long loops
        end local 1 // long reference
        end local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Lorg/graalvm/compiler/core/test/DeepUnrollingTest;
            3    7     1  reference  J
            4    7     3      loops  J

  public java.util.stream.LongStream timeStream(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/stream/LongStream;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
        start local 1 // java.lang.String methodName
         0: .line 79
            aload 0 /* this */
            aload 1 /* methodName */
            invokedynamic getAsLong(Lorg/graalvm/compiler/core/test/DeepUnrollingTest;Ljava/lang/String;)Ljava/util/function/LongSupplier;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()J
                  org/graalvm/compiler/core/test/DeepUnrollingTest.lambda$0(Ljava/lang/String;)J (7)
                  ()J
            invokestatic java.util.stream.LongStream.generate:(Ljava/util/function/LongSupplier;)Ljava/util/stream/LongStream;
            areturn
        end local 1 // java.lang.String methodName
        end local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/graalvm/compiler/core/test/DeepUnrollingTest;
            0    1     1  methodName  Ljava/lang/String;
    MethodParameters:
            Name  Flags
      methodName  

  public long time(java.lang.String);
    descriptor: (Ljava/lang/String;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=8, args_size=2
        start local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
        start local 1 // java.lang.String methodName
         0: .line 83
            aload 0 /* this */
            aload 1 /* methodName */
            invokevirtual org.graalvm.compiler.core.test.DeepUnrollingTest.getResolvedJavaMethod:(Ljava/lang/String;)Ljdk/vm/ci/meta/ResolvedJavaMethod;
            astore 2 /* method */
        start local 2 // jdk.vm.ci.meta.ResolvedJavaMethod method
         1: .line 84
            new org.graalvm.compiler.options.OptionValues
            dup
            invokestatic org.graalvm.compiler.core.test.DeepUnrollingTest.getInitialOptions:()Lorg/graalvm/compiler/options/OptionValues;
         2: .line 85
            getstatic org.graalvm.compiler.core.common.GraalOptions.FullUnroll:Lorg/graalvm/compiler/options/OptionKey;
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
         3: .line 84
            iconst_0
            anewarray java.lang.Object
            invokespecial org.graalvm.compiler.options.OptionValues.<init>:(Lorg/graalvm/compiler/options/OptionValues;Lorg/graalvm/compiler/options/OptionKey;Ljava/lang/Object;[Ljava/lang/Object;)V
            astore 3 /* options */
        start local 3 // org.graalvm.compiler.options.OptionValues options
         4: .line 86
            invokestatic java.lang.System.nanoTime:()J
            lstore 4 /* start */
        start local 4 // long start
         5: .line 87
            aload 0 /* this */
            aload 2 /* method */
            aconst_null
            iconst_1
            iconst_0
            aload 3 /* options */
            invokevirtual org.graalvm.compiler.core.test.DeepUnrollingTest.getCode:(Ljdk/vm/ci/meta/ResolvedJavaMethod;Lorg/graalvm/compiler/nodes/StructuredGraph;ZZLorg/graalvm/compiler/options/OptionValues;)Ljdk/vm/ci/code/InstalledCode;
            pop
         6: .line 88
            invokestatic java.lang.System.nanoTime:()J
            lstore 6 /* end */
        start local 6 // long end
         7: .line 89
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            lload 6 /* end */
            lload 4 /* start */
            lsub
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            lreturn
        end local 6 // long end
        end local 4 // long start
        end local 3 // org.graalvm.compiler.options.OptionValues options
        end local 2 // jdk.vm.ci.meta.ResolvedJavaMethod method
        end local 1 // java.lang.String methodName
        end local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    8     0        this  Lorg/graalvm/compiler/core/test/DeepUnrollingTest;
            0    8     1  methodName  Ljava/lang/String;
            1    8     2      method  Ljdk/vm/ci/meta/ResolvedJavaMethod;
            4    8     3     options  Lorg/graalvm/compiler/options/OptionValues;
            5    8     4       start  J
            7    8     6         end  J
    MethodParameters:
            Name  Flags
      methodName  

  public void test();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
         0: .line 94
            aload 0 /* this */
            aload 0 /* this */
            invokedynamic run(Lorg/graalvm/compiler/core/test/DeepUnrollingTest;)Ljava/lang/Runnable;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()V
                  org/graalvm/compiler/core/test/DeepUnrollingTest.loopTest()V (5)
                  ()V
            invokevirtual org.graalvm.compiler.core.test.DeepUnrollingTest.launchSubprocess:(Ljava/lang/Runnable;)V
         1: .line 95
            return
        end local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/graalvm/compiler/core/test/DeepUnrollingTest;
    Exceptions:
      throws java.io.IOException, java.lang.InterruptedException
    RuntimeVisibleAnnotations: 
      org.junit.Test()

  private long lambda$0(java.lang.String);
    descriptor: (Ljava/lang/String;)J
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
         0: .line 79
            aload 0 /* this */
            aload 1
            invokevirtual org.graalvm.compiler.core.test.DeepUnrollingTest.time:(Ljava/lang/String;)J
            lreturn
        end local 0 // org.graalvm.compiler.core.test.DeepUnrollingTest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/core/test/DeepUnrollingTest;
}
SourceFile: "DeepUnrollingTest.java"
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles