public final class org.graalvm.compiler.nodes.IfNode extends org.graalvm.compiler.nodes.ControlSplitNode implements org.graalvm.compiler.graph.spi.Simplifiable, org.graalvm.compiler.nodes.spi.LIRLowerable
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.graalvm.compiler.nodes.IfNode
  super_class: org.graalvm.compiler.nodes.ControlSplitNode
{
  public static final org.graalvm.compiler.graph.NodeClass<org.graalvm.compiler.nodes.IfNode> TYPE;
    descriptor: Lorg/graalvm/compiler/graph/NodeClass;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/compiler/graph/NodeClass<Lorg/graalvm/compiler/nodes/IfNode;>;

  private static final org.graalvm.compiler.debug.DebugCounter CORRECTED_PROBABILITIES;
    descriptor: Lorg/graalvm/compiler/debug/DebugCounter;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  org.graalvm.compiler.nodes.AbstractBeginNode trueSuccessor;
    descriptor: Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    flags: (0x0000) 
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.graph.Node$Successor()

  org.graalvm.compiler.nodes.AbstractBeginNode falseSuccessor;
    descriptor: Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    flags: (0x0000) 
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.graph.Node$Successor()

  org.graalvm.compiler.nodes.LogicNode condition;
    descriptor: Lorg/graalvm/compiler/nodes/LogicNode;
    flags: (0x0000) 
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.graph.Node$Input(value = org.graalvm.compiler.nodeinfo.InputType.Condition:Lorg/graalvm/compiler/nodeinfo/InputType;)

  protected double trueSuccessorProbability;
    descriptor: D
    flags: (0x0004) ACC_PROTECTED

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 71
            ldc Lorg/graalvm/compiler/nodes/IfNode;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
         3: .line 72
            ldc Lorg/graalvm/compiler/nodes/IfNode;
            invokestatic org.graalvm.compiler.graph.NodeClass.create:(Ljava/lang/Class;)Lorg/graalvm/compiler/graph/NodeClass;
            putstatic org.graalvm.compiler.nodes.IfNode.TYPE:Lorg/graalvm/compiler/graph/NodeClass;
         4: .line 74
            ldc "CorrectedProbabilities"
            invokestatic org.graalvm.compiler.debug.Debug.counter:(Ljava/lang/CharSequence;)Lorg/graalvm/compiler/debug/DebugCounter;
            putstatic org.graalvm.compiler.nodes.IfNode.CORRECTED_PROBABILITIES:Lorg/graalvm/compiler/debug/DebugCounter;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public org.graalvm.compiler.nodes.LogicNode condition();
    descriptor: ()Lorg/graalvm/compiler/nodes/LogicNode;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 82
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            areturn
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/nodes/IfNode;

  public void setCondition(org.graalvm.compiler.nodes.LogicNode);
    descriptor: (Lorg/graalvm/compiler/nodes/LogicNode;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.LogicNode x
         0: .line 86
            aload 0 /* this */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            aload 1 /* x */
            invokevirtual org.graalvm.compiler.nodes.IfNode.updateUsages:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)V
         1: .line 87
            aload 0 /* this */
            aload 1 /* x */
            putfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
         2: .line 88
            return
        end local 1 // org.graalvm.compiler.nodes.LogicNode x
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/graalvm/compiler/nodes/IfNode;
            0    3     1     x  Lorg/graalvm/compiler/nodes/LogicNode;
    MethodParameters:
      Name  Flags
      x     

  public void <init>(org.graalvm.compiler.nodes.LogicNode, org.graalvm.compiler.nodes.FixedNode, org.graalvm.compiler.nodes.FixedNode, double);
    descriptor: (Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/FixedNode;Lorg/graalvm/compiler/nodes/FixedNode;D)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=5
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.LogicNode condition
        start local 2 // org.graalvm.compiler.nodes.FixedNode trueSuccessor
        start local 3 // org.graalvm.compiler.nodes.FixedNode falseSuccessor
        start local 4 // double trueSuccessorProbability
         0: .line 91
            aload 0 /* this */
            aload 1 /* condition */
            aload 2 /* trueSuccessor */
            invokestatic org.graalvm.compiler.nodes.BeginNode.begin:(Lorg/graalvm/compiler/nodes/FixedNode;)Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 3 /* falseSuccessor */
            invokestatic org.graalvm.compiler.nodes.BeginNode.begin:(Lorg/graalvm/compiler/nodes/FixedNode;)Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            dload 4 /* trueSuccessorProbability */
            invokespecial org.graalvm.compiler.nodes.IfNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;D)V
         1: .line 92
            return
        end local 4 // double trueSuccessorProbability
        end local 3 // org.graalvm.compiler.nodes.FixedNode falseSuccessor
        end local 2 // org.graalvm.compiler.nodes.FixedNode trueSuccessor
        end local 1 // org.graalvm.compiler.nodes.LogicNode condition
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0    2     0                      this  Lorg/graalvm/compiler/nodes/IfNode;
            0    2     1                 condition  Lorg/graalvm/compiler/nodes/LogicNode;
            0    2     2             trueSuccessor  Lorg/graalvm/compiler/nodes/FixedNode;
            0    2     3            falseSuccessor  Lorg/graalvm/compiler/nodes/FixedNode;
            0    2     4  trueSuccessorProbability  D
    MethodParameters:
                          Name  Flags
      condition                 
      trueSuccessor             
      falseSuccessor            
      trueSuccessorProbability  

  public void <init>(org.graalvm.compiler.nodes.LogicNode, org.graalvm.compiler.nodes.AbstractBeginNode, org.graalvm.compiler.nodes.AbstractBeginNode, double);
    descriptor: (Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;D)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=5
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.LogicNode condition
        start local 2 // org.graalvm.compiler.nodes.AbstractBeginNode trueSuccessor
        start local 3 // org.graalvm.compiler.nodes.AbstractBeginNode falseSuccessor
        start local 4 // double trueSuccessorProbability
         0: .line 95
            aload 0 /* this */
            getstatic org.graalvm.compiler.nodes.IfNode.TYPE:Lorg/graalvm/compiler/graph/NodeClass;
            invokestatic org.graalvm.compiler.core.common.type.StampFactory.forVoid:()Lorg/graalvm/compiler/core/common/type/Stamp;
            invokespecial org.graalvm.compiler.nodes.ControlSplitNode.<init>:(Lorg/graalvm/compiler/graph/NodeClass;Lorg/graalvm/compiler/core/common/type/Stamp;)V
         1: .line 96
            aload 0 /* this */
            aload 1 /* condition */
            putfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
         2: .line 97
            aload 0 /* this */
            aload 3 /* falseSuccessor */
            putfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         3: .line 98
            aload 0 /* this */
            aload 2 /* trueSuccessor */
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         4: .line 99
            aload 0 /* this */
            dload 4 /* trueSuccessorProbability */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
         5: .line 100
            return
        end local 4 // double trueSuccessorProbability
        end local 3 // org.graalvm.compiler.nodes.AbstractBeginNode falseSuccessor
        end local 2 // org.graalvm.compiler.nodes.AbstractBeginNode trueSuccessor
        end local 1 // org.graalvm.compiler.nodes.LogicNode condition
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0    6     0                      this  Lorg/graalvm/compiler/nodes/IfNode;
            0    6     1                 condition  Lorg/graalvm/compiler/nodes/LogicNode;
            0    6     2             trueSuccessor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            0    6     3            falseSuccessor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            0    6     4  trueSuccessorProbability  D
    MethodParameters:
                          Name  Flags
      condition                 
      trueSuccessor             
      falseSuccessor            
      trueSuccessorProbability  

  public org.graalvm.compiler.nodes.AbstractBeginNode trueSuccessor();
    descriptor: ()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 108
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            areturn
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/nodes/IfNode;

  public org.graalvm.compiler.nodes.AbstractBeginNode falseSuccessor();
    descriptor: ()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 117
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            areturn
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/nodes/IfNode;

  public double getTrueSuccessorProbability();
    descriptor: ()D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 121
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dreturn
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/nodes/IfNode;

  public void setTrueSuccessor(org.graalvm.compiler.nodes.AbstractBeginNode);
    descriptor: (Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.AbstractBeginNode node
         0: .line 125
            aload 0 /* this */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 1 /* node */
            invokevirtual org.graalvm.compiler.nodes.IfNode.updatePredecessor:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)V
         1: .line 126
            aload 0 /* this */
            aload 1 /* node */
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         2: .line 127
            return
        end local 1 // org.graalvm.compiler.nodes.AbstractBeginNode node
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/graalvm/compiler/nodes/IfNode;
            0    3     1  node  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    MethodParameters:
      Name  Flags
      node  

  public void setFalseSuccessor(org.graalvm.compiler.nodes.AbstractBeginNode);
    descriptor: (Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.AbstractBeginNode node
         0: .line 130
            aload 0 /* this */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 1 /* node */
            invokevirtual org.graalvm.compiler.nodes.IfNode.updatePredecessor:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)V
         1: .line 131
            aload 0 /* this */
            aload 1 /* node */
            putfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         2: .line 132
            return
        end local 1 // org.graalvm.compiler.nodes.AbstractBeginNode node
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/graalvm/compiler/nodes/IfNode;
            0    3     1  node  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    MethodParameters:
      Name  Flags
      node  

  public org.graalvm.compiler.nodes.AbstractBeginNode successor(boolean);
    descriptor: (Z)Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // boolean istrue
         0: .line 141
            iload 1 /* istrue */
            ifeq 1
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
      StackMap locals:
      StackMap stack: org.graalvm.compiler.nodes.AbstractBeginNode
         2: areturn
        end local 1 // boolean istrue
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/graalvm/compiler/nodes/IfNode;
            0    3     1  istrue  Z
    MethodParameters:
        Name  Flags
      istrue  

  public void setTrueSuccessorProbability(double);
    descriptor: (D)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=3, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // double prob
         0: .line 145
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 2
            dload 1 /* prob */
            ldc -1.0E-9
            dcmpl
            iflt 1
            dload 1 /* prob */
            ldc 1.000000001
            dcmpg
            ifle 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "Probability out of bounds: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            dload 1 /* prob */
            invokevirtual java.lang.StringBuilder.append:(D)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 146
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dconst_1
            dconst_0
            dload 1 /* prob */
            invokestatic java.lang.Math.max:(DD)D
            invokestatic java.lang.Math.min:(DD)D
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
         3: .line 147
            return
        end local 1 // double prob
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/graalvm/compiler/nodes/IfNode;
            0    4     1  prob  D
    MethodParameters:
      Name  Flags
      prob  

  public double probability(org.graalvm.compiler.nodes.AbstractBeginNode);
    descriptor: (Lorg/graalvm/compiler/nodes/AbstractBeginNode;)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.AbstractBeginNode successor
         0: .line 151
            aload 1 /* successor */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            if_acmpne 1
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            goto 2
      StackMap locals:
      StackMap stack:
         1: dconst_1
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dsub
      StackMap locals:
      StackMap stack: double
         2: dreturn
        end local 1 // org.graalvm.compiler.nodes.AbstractBeginNode successor
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lorg/graalvm/compiler/nodes/IfNode;
            0    3     1  successor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    MethodParameters:
           Name  Flags
      successor  

  public void generate(org.graalvm.compiler.nodes.spi.NodeLIRBuilderTool);
    descriptor: (Lorg/graalvm/compiler/nodes/spi/NodeLIRBuilderTool;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.spi.NodeLIRBuilderTool gen
         0: .line 156
            aload 1 /* gen */
            aload 0 /* this */
            invokeinterface org.graalvm.compiler.nodes.spi.NodeLIRBuilderTool.emitIf:(Lorg/graalvm/compiler/nodes/IfNode;)V
         1: .line 157
            return
        end local 1 // org.graalvm.compiler.nodes.spi.NodeLIRBuilderTool gen
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/graalvm/compiler/nodes/IfNode;
            0    2     1   gen  Lorg/graalvm/compiler/nodes/spi/NodeLIRBuilderTool;
    MethodParameters:
      Name  Flags
      gen   

  public boolean verify();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 161
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            ifnull 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack: org.graalvm.compiler.nodes.IfNode
         1: iconst_0
      StackMap locals: org.graalvm.compiler.nodes.IfNode
      StackMap stack: org.graalvm.compiler.nodes.IfNode int
         2: ldc "missing condition"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
         3: .line 162
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            ifnull 4
            iconst_1
            goto 5
      StackMap locals:
      StackMap stack: org.graalvm.compiler.nodes.IfNode
         4: iconst_0
      StackMap locals: org.graalvm.compiler.nodes.IfNode
      StackMap stack: org.graalvm.compiler.nodes.IfNode int
         5: ldc "missing trueSuccessor"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
         6: .line 163
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            ifnull 7
            iconst_1
            goto 8
      StackMap locals:
      StackMap stack: org.graalvm.compiler.nodes.IfNode
         7: iconst_0
      StackMap locals: org.graalvm.compiler.nodes.IfNode
      StackMap stack: org.graalvm.compiler.nodes.IfNode int
         8: ldc "missing falseSuccessor"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
         9: .line 164
            aload 0 /* this */
            invokespecial org.graalvm.compiler.nodes.ControlSplitNode.verify:()Z
            ireturn
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lorg/graalvm/compiler/nodes/IfNode;

  public void eliminateNegation();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 168
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 1 /* oldTrueSuccessor */
        start local 1 // org.graalvm.compiler.nodes.AbstractBeginNode oldTrueSuccessor
         1: .line 169
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 2 /* oldFalseSuccessor */
        start local 2 // org.graalvm.compiler.nodes.AbstractBeginNode oldFalseSuccessor
         2: .line 170
            aload 0 /* this */
            aload 2 /* oldFalseSuccessor */
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         3: .line 171
            aload 0 /* this */
            aload 1 /* oldTrueSuccessor */
            putfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         4: .line 172
            aload 0 /* this */
            dconst_1
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dsub
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
         5: .line 173
            aload 0 /* this */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.LogicNegationNode
            invokevirtual org.graalvm.compiler.nodes.LogicNegationNode.getValue:()Lorg/graalvm/compiler/nodes/LogicNode;
            invokevirtual org.graalvm.compiler.nodes.IfNode.setCondition:(Lorg/graalvm/compiler/nodes/LogicNode;)V
         6: .line 174
            return
        end local 2 // org.graalvm.compiler.nodes.AbstractBeginNode oldFalseSuccessor
        end local 1 // org.graalvm.compiler.nodes.AbstractBeginNode oldTrueSuccessor
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    7     0               this  Lorg/graalvm/compiler/nodes/IfNode;
            1    7     1   oldTrueSuccessor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            2    7     2  oldFalseSuccessor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;

  public void simplify(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=9, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 178
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.DeoptimizeNode
            ifeq 5
         1: .line 179
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_0
            dcmpl
            ifeq 9
         2: .line 180
            getstatic org.graalvm.compiler.nodes.IfNode.CORRECTED_PROBABILITIES:Lorg/graalvm/compiler/debug/DebugCounter;
            invokeinterface org.graalvm.compiler.debug.DebugCounter.increment:()V
         3: .line 181
            aload 0 /* this */
            dconst_0
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
         4: .line 183
            goto 9
      StackMap locals:
      StackMap stack:
         5: aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.DeoptimizeNode
            ifeq 9
         6: .line 184
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_1
            dcmpl
            ifeq 9
         7: .line 185
            getstatic org.graalvm.compiler.nodes.IfNode.CORRECTED_PROBABILITIES:Lorg/graalvm/compiler/debug/DebugCounter;
            invokeinterface org.graalvm.compiler.debug.DebugCounter.increment:()V
         8: .line 186
            aload 0 /* this */
            dconst_1
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
         9: .line 190
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.LogicNegationNode
            ifeq 11
        10: .line 191
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.eliminateNegation:()V
        11: .line 193
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.LogicConstantNode
            ifeq 22
        12: .line 194
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.LogicConstantNode
            astore 2 /* c */
        start local 2 // org.graalvm.compiler.nodes.LogicConstantNode c
        13: .line 195
            aload 2 /* c */
            invokevirtual org.graalvm.compiler.nodes.LogicConstantNode.getValue:()Z
            ifeq 18
        14: .line 196
            aload 1 /* tool */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.deleteBranch:(Lorg/graalvm/compiler/graph/Node;)V
        15: .line 197
            aload 1 /* tool */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.addToWorkList:(Lorg/graalvm/compiler/graph/Node;)V
        16: .line 198
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.removeSplit:(Lorg/graalvm/compiler/nodes/ControlSplitNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        17: .line 199
            goto 21
        18: .line 200
      StackMap locals: org.graalvm.compiler.nodes.LogicConstantNode
      StackMap stack:
            aload 1 /* tool */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.deleteBranch:(Lorg/graalvm/compiler/graph/Node;)V
        19: .line 201
            aload 1 /* tool */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.addToWorkList:(Lorg/graalvm/compiler/graph/Node;)V
        20: .line 202
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.removeSplit:(Lorg/graalvm/compiler/nodes/ControlSplitNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        21: .line 204
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.graalvm.compiler.nodes.LogicConstantNode c
        22: .line 206
      StackMap locals:
      StackMap stack:
            aload 1 /* tool */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.allUsagesAvailable:()Z
            ifeq 26
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifeq 26
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifeq 26
        23: .line 208
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.pushNodesThroughIf:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        24: .line 210
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.checkForUnsignedCompare:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
            ifne 25
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.removeOrMaterializeIf:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
            ifeq 26
        25: .line 211
      StackMap locals:
      StackMap stack:
            return
        26: .line 215
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.removeIntermediateMaterialization:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
            ifeq 28
        27: .line 216
            return
        28: .line 219
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.splitIfAtPhi:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
            ifeq 30
        29: .line 220
            return
        30: .line 223
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.conditionalNodeOptimization:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
            ifeq 32
        31: .line 224
            return
        32: .line 227
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifeq 54
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifne 54
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.IfNode
            ifeq 54
        33: .line 228
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 2 /* intermediateBegin */
        start local 2 // org.graalvm.compiler.nodes.AbstractBeginNode intermediateBegin
        34: .line 229
            aload 2 /* intermediateBegin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.IfNode
            astore 3 /* nextIf */
        start local 3 // org.graalvm.compiler.nodes.IfNode nextIf
        35: .line 230
            dconst_1
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dsub
            aload 3 /* nextIf */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dmul
            dstore 4 /* probabilityB */
        start local 4 // double probabilityB
        36: .line 231
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dload 4 /* probabilityB */
            dcmpg
            ifge 54
        37: .line 234
            aload 1 /* tool */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.getConstantReflection:()Ljdk/vm/ci/meta/ConstantReflectionProvider;
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            aload 3 /* nextIf */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.prepareForSwap:(Ljdk/vm/ci/meta/ConstantReflectionProvider;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/LogicNode;)Z
            ifeq 54
        38: .line 236
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 39
            aload 2 /* intermediateBegin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            aload 3 /* nextIf */
            if_acmpeq 39
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        39: .line 237
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.IfNode double
      StackMap stack:
            aload 3 /* nextIf */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 6 /* bothFalseBegin */
        start local 6 // org.graalvm.compiler.nodes.AbstractBeginNode bothFalseBegin
        40: .line 238
            aload 3 /* nextIf */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        41: .line 239
            aload 2 /* intermediateBegin */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        42: .line 240
            aload 0 /* this */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        43: .line 242
            aload 0 /* this */
            aload 3 /* nextIf */
            invokevirtual org.graalvm.compiler.nodes.IfNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        44: .line 243
            aload 3 /* nextIf */
            aload 2 /* intermediateBegin */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        45: .line 244
            aload 2 /* intermediateBegin */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        46: .line 245
            aload 0 /* this */
            aload 6 /* bothFalseBegin */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        47: .line 246
            aload 3 /* nextIf */
            dload 4 /* probabilityB */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        48: .line 247
            dload 4 /* probabilityB */
            dconst_1
            dcmpl
            ifne 51
        49: .line 248
            aload 0 /* this */
            dconst_0
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        50: .line 249
            goto 53
        51: .line 250
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_1
            dload 4 /* probabilityB */
            dsub
            ddiv
            dstore 7 /* newProbability */
        start local 7 // double newProbability
        52: .line 251
            aload 0 /* this */
            dconst_1
            dload 7 /* newProbability */
            invokestatic java.lang.Math.min:(DD)D
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        end local 7 // double newProbability
        53: .line 253
      StackMap locals:
      StackMap stack:
            return
        end local 6 // org.graalvm.compiler.nodes.AbstractBeginNode bothFalseBegin
        end local 4 // double probabilityB
        end local 3 // org.graalvm.compiler.nodes.IfNode nextIf
        end local 2 // org.graalvm.compiler.nodes.AbstractBeginNode intermediateBegin
        54: .line 257
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool
      StackMap stack:
            return
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   55     0               this  Lorg/graalvm/compiler/nodes/IfNode;
            0   55     1               tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
           13   22     2                  c  Lorg/graalvm/compiler/nodes/LogicConstantNode;
           34   54     2  intermediateBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           35   54     3             nextIf  Lorg/graalvm/compiler/nodes/IfNode;
           36   54     4       probabilityB  D
           40   54     6     bothFalseBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           52   53     7     newProbability  D
    MethodParameters:
      Name  Flags
      tool  

  private boolean conditionalNodeOptimization(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=9, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 263
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.AbstractEndNode
            ifeq 20
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.AbstractEndNode
            ifeq 20
         1: .line 264
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 2 /* trueEnd */
        start local 2 // org.graalvm.compiler.nodes.AbstractEndNode trueEnd
         2: .line 265
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 3 /* falseEnd */
        start local 3 // org.graalvm.compiler.nodes.AbstractEndNode falseEnd
         3: .line 266
            aload 2 /* trueEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            aload 3 /* falseEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            if_acmpeq 5
         4: .line 267
            iconst_0
            ireturn
         5: .line 269
      StackMap locals: org.graalvm.compiler.nodes.AbstractEndNode org.graalvm.compiler.nodes.AbstractEndNode
      StackMap stack:
            aload 2 /* trueEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            instanceof org.graalvm.compiler.nodes.MergeNode
            ifne 7
         6: .line 270
            iconst_0
            ireturn
         7: .line 272
      StackMap locals:
      StackMap stack:
            aload 2 /* trueEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            checkcast org.graalvm.compiler.nodes.MergeNode
            astore 4 /* merge */
        start local 4 // org.graalvm.compiler.nodes.MergeNode merge
         8: .line 273
            aload 4 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_1
            if_icmpne 9
            aload 4 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.phis:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_1
            if_icmpeq 10
         9: .line 274
      StackMap locals: org.graalvm.compiler.nodes.MergeNode
      StackMap stack:
            iconst_0
            ireturn
        10: .line 276
      StackMap locals:
      StackMap stack:
            aload 4 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.phis:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.first:()Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.PhiNode
            astore 5 /* phi */
        start local 5 // org.graalvm.compiler.nodes.PhiNode phi
        11: .line 277
            aload 5 /* phi */
            aload 3 /* falseEnd */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 6 /* falseValue */
        start local 6 // org.graalvm.compiler.nodes.ValueNode falseValue
        12: .line 278
            aload 5 /* phi */
            aload 2 /* trueEnd */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 7 /* trueValue */
        start local 7 // org.graalvm.compiler.nodes.ValueNode trueValue
        13: .line 280
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            aload 7 /* trueValue */
            aload 6 /* falseValue */
            aload 5 /* phi */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.stamp:()Lorg/graalvm/compiler/core/common/type/Stamp;
            invokestatic org.graalvm.compiler.nodes.calc.ConditionalNode.canonicalizeConditional:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/core/common/type/Stamp;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 8 /* result */
        start local 8 // org.graalvm.compiler.nodes.ValueNode result
        14: .line 281
            aload 8 /* result */
            ifnull 20
        15: .line 285
            aload 8 /* result */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            ifnonnull 17
        16: .line 286
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 8 /* result */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.addOrUniqueWithInputs:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.ValueNode
            astore 8 /* result */
        17: .line 292
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractEndNode org.graalvm.compiler.nodes.AbstractEndNode org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
            aload 5 /* phi */
            aload 2 /* trueEnd */
            aload 8 /* result */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.setValueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
        18: .line 293
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.removeThroughFalseBranch:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        19: .line 294
            iconst_1
            ireturn
        end local 8 // org.graalvm.compiler.nodes.ValueNode result
        end local 7 // org.graalvm.compiler.nodes.ValueNode trueValue
        end local 6 // org.graalvm.compiler.nodes.ValueNode falseValue
        end local 5 // org.graalvm.compiler.nodes.PhiNode phi
        end local 4 // org.graalvm.compiler.nodes.MergeNode merge
        end local 3 // org.graalvm.compiler.nodes.AbstractEndNode falseEnd
        end local 2 // org.graalvm.compiler.nodes.AbstractEndNode trueEnd
        20: .line 298
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   21     0        this  Lorg/graalvm/compiler/nodes/IfNode;
            0   21     1        tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            2   20     2     trueEnd  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            3   20     3    falseEnd  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            8   20     4       merge  Lorg/graalvm/compiler/nodes/MergeNode;
           11   20     5         phi  Lorg/graalvm/compiler/nodes/PhiNode;
           12   20     6  falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
           13   20     7   trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
           14   20     8      result  Lorg/graalvm/compiler/nodes/ValueNode;
    MethodParameters:
      Name  Flags
      tool  

  private void pushNodesThroughIf(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=11, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 302
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifeq 1
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifne 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 305
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 2 /* trueSucc */
        start local 2 // org.graalvm.compiler.nodes.AbstractBeginNode trueSucc
         3: .line 306
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 3 /* falseSucc */
        start local 3 // org.graalvm.compiler.nodes.AbstractBeginNode falseSucc
         4: .line 307
            aload 2 /* trueSucc */
            instanceof org.graalvm.compiler.nodes.BeginNode
            ifeq 26
            aload 3 /* falseSucc */
            instanceof org.graalvm.compiler.nodes.BeginNode
            ifeq 26
            aload 2 /* trueSucc */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.FixedWithNextNode
            ifeq 26
            aload 3 /* falseSucc */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.FixedWithNextNode
            ifeq 26
         5: .line 308
            aload 2 /* trueSucc */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.FixedWithNextNode
            astore 4 /* trueNext */
        start local 4 // org.graalvm.compiler.nodes.FixedWithNextNode trueNext
         6: .line 309
            aload 3 /* falseSucc */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.FixedWithNextNode
            astore 5 /* falseNext */
        start local 5 // org.graalvm.compiler.nodes.FixedWithNextNode falseNext
         7: .line 310
            aload 4 /* trueNext */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.getNodeClass:()Lorg/graalvm/compiler/graph/NodeClass;
            astore 6 /* nodeClass */
        start local 6 // org.graalvm.compiler.graph.NodeClass nodeClass
         8: .line 311
            aload 4 /* trueNext */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            aload 5 /* falseNext */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            if_acmpne 26
         9: .line 312
            aload 6 /* nodeClass */
            aload 4 /* trueNext */
            aload 5 /* falseNext */
            invokevirtual org.graalvm.compiler.graph.NodeClass.equalInputs:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)Z
            ifeq 26
            aload 4 /* trueNext */
            aload 5 /* falseNext */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.valueEquals:(Lorg/graalvm/compiler/graph/Node;)Z
            ifeq 26
        10: .line 313
            aload 5 /* falseNext */
            aload 4 /* trueNext */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.replaceAtUsages:(Lorg/graalvm/compiler/graph/Node;)V
        11: .line 314
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 5 /* falseNext */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.removeFixed:(Lorg/graalvm/compiler/nodes/FixedWithNextNode;)V
        12: .line 315
            aload 4 /* trueNext */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.unlinkFixedNode:(Lorg/graalvm/compiler/nodes/FixedWithNextNode;)V
        13: .line 316
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 0 /* this */
            aload 4 /* trueNext */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.addBeforeFixed:(Lorg/graalvm/compiler/nodes/FixedNode;Lorg/graalvm/compiler/nodes/FixedWithNextNode;)V
        14: .line 317
            aload 4 /* trueNext */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.snapshot:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 24
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.FixedWithNextNode org.graalvm.compiler.nodes.FixedWithNextNode org.graalvm.compiler.graph.NodeClass top java.util.Iterator
      StackMap stack:
        15: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 7 /* usage */
        start local 7 // org.graalvm.compiler.graph.Node usage
        16: .line 318
            aload 7 /* usage */
            invokevirtual org.graalvm.compiler.graph.Node.isAlive:()Z
            ifeq 24
        17: .line 319
            aload 7 /* usage */
            invokevirtual org.graalvm.compiler.graph.Node.getNodeClass:()Lorg/graalvm/compiler/graph/NodeClass;
            astore 9 /* usageNodeClass */
        start local 9 // org.graalvm.compiler.graph.NodeClass usageNodeClass
        18: .line 320
            aload 9 /* usageNodeClass */
            invokevirtual org.graalvm.compiler.graph.NodeClass.valueNumberable:()Z
            ifeq 22
            aload 9 /* usageNodeClass */
            invokevirtual org.graalvm.compiler.graph.NodeClass.isLeafNode:()Z
            ifne 22
        19: .line 321
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 7 /* usage */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.findDuplicate:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            astore 10 /* newNode */
        start local 10 // org.graalvm.compiler.graph.Node newNode
        20: .line 322
            aload 10 /* newNode */
            ifnull 22
        21: .line 323
            aload 7 /* usage */
            aload 10 /* newNode */
            invokevirtual org.graalvm.compiler.graph.Node.replaceAtUsagesAndDelete:(Lorg/graalvm/compiler/graph/Node;)V
        end local 10 // org.graalvm.compiler.graph.Node newNode
        22: .line 326
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.FixedWithNextNode org.graalvm.compiler.nodes.FixedWithNextNode org.graalvm.compiler.graph.NodeClass org.graalvm.compiler.graph.Node java.util.Iterator org.graalvm.compiler.graph.NodeClass
      StackMap stack:
            aload 7 /* usage */
            invokevirtual org.graalvm.compiler.graph.Node.isAlive:()Z
            ifeq 24
        23: .line 327
            aload 1 /* tool */
            aload 7 /* usage */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.addToWorkList:(Lorg/graalvm/compiler/graph/Node;)V
        end local 9 // org.graalvm.compiler.graph.NodeClass usageNodeClass
        end local 7 // org.graalvm.compiler.graph.Node usage
        24: .line 317
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.FixedWithNextNode org.graalvm.compiler.nodes.FixedWithNextNode org.graalvm.compiler.graph.NodeClass top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 15
        end local 6 // org.graalvm.compiler.graph.NodeClass nodeClass
        end local 5 // org.graalvm.compiler.nodes.FixedWithNextNode falseNext
        end local 4 // org.graalvm.compiler.nodes.FixedWithNextNode trueNext
        end local 3 // org.graalvm.compiler.nodes.AbstractBeginNode falseSucc
        end local 2 // org.graalvm.compiler.nodes.AbstractBeginNode trueSucc
        25: .line 336
            goto 2
        26: .line 337
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool
      StackMap stack:
            return
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   27     0            this  Lorg/graalvm/compiler/nodes/IfNode;
            0   27     1            tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            3   25     2        trueSucc  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            4   25     3       falseSucc  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            6   25     4        trueNext  Lorg/graalvm/compiler/nodes/FixedWithNextNode;
            7   25     5       falseNext  Lorg/graalvm/compiler/nodes/FixedWithNextNode;
            8   25     6       nodeClass  Lorg/graalvm/compiler/graph/NodeClass<*>;
           16   24     7           usage  Lorg/graalvm/compiler/graph/Node;
           18   24     9  usageNodeClass  Lorg/graalvm/compiler/graph/NodeClass<*>;
           20   22    10         newNode  Lorg/graalvm/compiler/graph/Node;
    MethodParameters:
      Name  Flags
      tool  

  private boolean checkForUnsignedCompare(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=10, locals=11, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 346
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifeq 1
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifne 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 347
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            ifeq 33
         3: .line 348
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            astore 2 /* lessThan */
        start local 2 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan
         4: .line 349
            aload 2 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:()Lorg/graalvm/compiler/core/common/type/Stamp;
            invokevirtual org.graalvm.compiler.core.common.type.Stamp.asConstant:()Ljdk/vm/ci/meta/Constant;
            astore 3 /* y */
        start local 3 // jdk.vm.ci.meta.Constant y
         5: .line 350
            aload 3 /* y */
            instanceof jdk.vm.ci.meta.PrimitiveConstant
            ifeq 33
            aload 3 /* y */
            checkcast jdk.vm.ci.meta.PrimitiveConstant
            invokevirtual jdk.vm.ci.meta.PrimitiveConstant.asLong:()J
            lconst_0
            lcmp
            ifne 33
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.IfNode
            ifeq 33
         6: .line 351
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.IfNode
            astore 4 /* ifNode2 */
        start local 4 // org.graalvm.compiler.nodes.IfNode ifNode2
         7: .line 352
            aload 4 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            ifeq 33
         8: .line 353
            aload 4 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            astore 5 /* lessThan2 */
        start local 5 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan2
         9: .line 354
            aload 4 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 6 /* falseSucc */
        start local 6 // org.graalvm.compiler.nodes.AbstractBeginNode falseSucc
        10: .line 355
            aload 4 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 7 /* trueSucc */
        start local 7 // org.graalvm.compiler.nodes.AbstractBeginNode trueSucc
        11: .line 356
            aconst_null
            astore 8 /* below */
        start local 8 // org.graalvm.compiler.nodes.calc.IntegerBelowNode below
        12: .line 361
            aload 5 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 19
            aload 5 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:()Lorg/graalvm/compiler/core/common/type/Stamp;
            instanceof org.graalvm.compiler.core.common.type.IntegerStamp
            ifeq 19
            aload 5 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:()Lorg/graalvm/compiler/core/common/type/Stamp;
            checkcast org.graalvm.compiler.core.common.type.IntegerStamp
            invokevirtual org.graalvm.compiler.core.common.type.IntegerStamp.isPositive:()Z
            ifeq 19
        13: .line 362
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 4 /* ifNode2 */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.sameDestination:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Z
            ifeq 19
        14: .line 363
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.calc.IntegerBelowNode
            dup
            aload 5 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokespecial org.graalvm.compiler.nodes.calc.IntegerBelowNode.<init>:(Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.calc.IntegerBelowNode
            astore 8 /* below */
        15: .line 365
            aload 6 /* falseSucc */
            astore 9 /* tmp */
        start local 9 // org.graalvm.compiler.nodes.AbstractBeginNode tmp
        16: .line 366
            aload 7 /* trueSucc */
            astore 6 /* falseSucc */
        17: .line 367
            aload 9 /* tmp */
            astore 7 /* trueSucc */
        end local 9 // org.graalvm.compiler.nodes.AbstractBeginNode tmp
        18: .line 368
            goto 24
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.calc.IntegerLessThanNode jdk.vm.ci.meta.Constant org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.calc.IntegerLessThanNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.calc.IntegerBelowNode
      StackMap stack:
        19: aload 5 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 24
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 4 /* ifNode2 */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.sameDestination:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Z
            ifeq 24
        20: .line 375
            aload 5 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asJavaConstant:()Ljdk/vm/ci/meta/JavaConstant;
            astore 9 /* positive */
        start local 9 // jdk.vm.ci.meta.JavaConstant positive
        21: .line 376
            aload 9 /* positive */
            ifnull 24
            aload 9 /* positive */
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            lconst_0
            lcmp
            ifle 24
            aload 9 /* positive */
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            aload 9 /* positive */
            invokeinterface jdk.vm.ci.meta.JavaConstant.getJavaKind:()Ljdk/vm/ci/meta/JavaKind;
            invokevirtual jdk.vm.ci.meta.JavaKind.getMaxValue:()J
            lcmp
            ifge 24
        22: .line 377
            aload 5 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:()Lorg/graalvm/compiler/core/common/type/Stamp;
            aload 9 /* positive */
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            lconst_1
            ladd
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            invokestatic org.graalvm.compiler.nodes.ConstantNode.forIntegerStamp:(Lorg/graalvm/compiler/core/common/type/Stamp;JLorg/graalvm/compiler/nodes/StructuredGraph;)Lorg/graalvm/compiler/nodes/ConstantNode;
            astore 10 /* newLimit */
        start local 10 // org.graalvm.compiler.nodes.ConstantNode newLimit
        23: .line 378
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.calc.IntegerBelowNode
            dup
            aload 2 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 10 /* newLimit */
            invokespecial org.graalvm.compiler.nodes.calc.IntegerBelowNode.<init>:(Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.calc.IntegerBelowNode
            astore 8 /* below */
        end local 10 // org.graalvm.compiler.nodes.ConstantNode newLimit
        end local 9 // jdk.vm.ci.meta.JavaConstant positive
        24: .line 381
      StackMap locals:
      StackMap stack:
            aload 8 /* below */
            ifnull 33
        25: .line 382
            aload 4 /* ifNode2 */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        26: .line 383
            aload 4 /* ifNode2 */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        27: .line 385
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.IfNode
            dup
            aload 8 /* below */
            aload 6 /* falseSucc */
            aload 7 /* trueSucc */
            dconst_1
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dsub
            invokespecial org.graalvm.compiler.nodes.IfNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;D)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.IfNode
            astore 9 /* newIfNode */
        start local 9 // org.graalvm.compiler.nodes.IfNode newIfNode
        28: .line 387
            aload 1 /* tool */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.deleteBranch:(Lorg/graalvm/compiler/graph/Node;)V
        29: .line 388
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 0 /* this */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.removeSplit:(Lorg/graalvm/compiler/nodes/ControlSplitNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        30: .line 391
            aload 4 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            aload 4 /* ifNode2 */
            aload 9 /* newIfNode */
            invokevirtual org.graalvm.compiler.graph.Node.replaceFirstSuccessor:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)V
        31: .line 392
            aload 4 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.safeDelete:()V
        32: .line 393
            iconst_1
            ireturn
        end local 9 // org.graalvm.compiler.nodes.IfNode newIfNode
        end local 8 // org.graalvm.compiler.nodes.calc.IntegerBelowNode below
        end local 7 // org.graalvm.compiler.nodes.AbstractBeginNode trueSucc
        end local 6 // org.graalvm.compiler.nodes.AbstractBeginNode falseSucc
        end local 5 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan2
        end local 4 // org.graalvm.compiler.nodes.IfNode ifNode2
        end local 3 // jdk.vm.ci.meta.Constant y
        end local 2 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan
        33: .line 398
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   34     0       this  Lorg/graalvm/compiler/nodes/IfNode;
            0   34     1       tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            4   33     2   lessThan  Lorg/graalvm/compiler/nodes/calc/IntegerLessThanNode;
            5   33     3          y  Ljdk/vm/ci/meta/Constant;
            7   33     4    ifNode2  Lorg/graalvm/compiler/nodes/IfNode;
            9   33     5  lessThan2  Lorg/graalvm/compiler/nodes/calc/IntegerLessThanNode;
           10   33     6  falseSucc  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           11   33     7   trueSucc  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           12   33     8      below  Lorg/graalvm/compiler/nodes/calc/IntegerBelowNode;
           16   18     9        tmp  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           21   24     9   positive  Ljdk/vm/ci/meta/JavaConstant;
           23   24    10   newLimit  Lorg/graalvm/compiler/nodes/ConstantNode;
           28   33     9  newIfNode  Lorg/graalvm/compiler/nodes/IfNode;
    MethodParameters:
      Name  Flags
      tool  

  private static boolean sameDestination(org.graalvm.compiler.nodes.AbstractBeginNode, org.graalvm.compiler.nodes.AbstractBeginNode);
    descriptor: (Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=8, args_size=2
        start local 0 // org.graalvm.compiler.nodes.AbstractBeginNode succ1
        start local 1 // org.graalvm.compiler.nodes.AbstractBeginNode succ2
         0: .line 406
            aload 0 /* succ1 */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            astore 2 /* next1 */
        start local 2 // org.graalvm.compiler.graph.Node next1
         1: .line 407
            aload 1 /* succ2 */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            astore 3 /* next2 */
        start local 3 // org.graalvm.compiler.graph.Node next2
         2: .line 408
            aload 2 /* next1 */
            instanceof org.graalvm.compiler.nodes.EndNode
            ifeq 12
            aload 3 /* next2 */
            instanceof org.graalvm.compiler.nodes.EndNode
            ifeq 12
         3: .line 409
            aload 2 /* next1 */
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 4 /* end1 */
        start local 4 // org.graalvm.compiler.nodes.EndNode end1
         4: .line 410
            aload 3 /* next2 */
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 5 /* end2 */
        start local 5 // org.graalvm.compiler.nodes.EndNode end2
         5: .line 411
            aload 4 /* end1 */
            invokevirtual org.graalvm.compiler.nodes.EndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            aload 5 /* end2 */
            invokevirtual org.graalvm.compiler.nodes.EndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            if_acmpne 27
         6: .line 412
            aload 4 /* end1 */
            invokevirtual org.graalvm.compiler.nodes.EndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.phis:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 7
            goto 10
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.graph.Node org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode top java.util.Iterator
      StackMap stack:
         7: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.PhiNode
            astore 6 /* phi */
        start local 6 // org.graalvm.compiler.nodes.PhiNode phi
         8: .line 413
            aload 6 /* phi */
            aload 4 /* end1 */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* phi */
            aload 5 /* end2 */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpeq 10
         9: .line 414
            iconst_0
            ireturn
        end local 6 // org.graalvm.compiler.nodes.PhiNode phi
        10: .line 412
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        11: .line 418
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.EndNode end2
        end local 4 // org.graalvm.compiler.nodes.EndNode end1
        12: .line 420
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.graph.Node org.graalvm.compiler.graph.Node
      StackMap stack:
            aload 2 /* next1 */
            instanceof org.graalvm.compiler.nodes.DeoptimizeNode
            ifeq 17
            aload 3 /* next2 */
            instanceof org.graalvm.compiler.nodes.DeoptimizeNode
            ifeq 17
        13: .line 421
            aload 2 /* next1 */
            checkcast org.graalvm.compiler.nodes.DeoptimizeNode
            astore 4 /* deopt1 */
        start local 4 // org.graalvm.compiler.nodes.DeoptimizeNode deopt1
        14: .line 422
            aload 3 /* next2 */
            checkcast org.graalvm.compiler.nodes.DeoptimizeNode
            astore 5 /* deopt2 */
        start local 5 // org.graalvm.compiler.nodes.DeoptimizeNode deopt2
        15: .line 423
            aload 4 /* deopt1 */
            invokevirtual org.graalvm.compiler.nodes.DeoptimizeNode.reason:()Ljdk/vm/ci/meta/DeoptimizationReason;
            aload 5 /* deopt2 */
            invokevirtual org.graalvm.compiler.nodes.DeoptimizeNode.reason:()Ljdk/vm/ci/meta/DeoptimizationReason;
            if_acmpne 27
            aload 4 /* deopt1 */
            invokevirtual org.graalvm.compiler.nodes.DeoptimizeNode.action:()Ljdk/vm/ci/meta/DeoptimizationAction;
            aload 5 /* deopt2 */
            invokevirtual org.graalvm.compiler.nodes.DeoptimizeNode.action:()Ljdk/vm/ci/meta/DeoptimizationAction;
            if_acmpne 27
        16: .line 425
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.DeoptimizeNode deopt2
        end local 4 // org.graalvm.compiler.nodes.DeoptimizeNode deopt1
        17: .line 427
      StackMap locals:
      StackMap stack:
            aload 2 /* next1 */
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 22
            aload 3 /* next2 */
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 22
        18: .line 428
            aload 2 /* next1 */
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            astore 4 /* exit1 */
        start local 4 // org.graalvm.compiler.nodes.LoopExitNode exit1
        19: .line 429
            aload 3 /* next2 */
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            astore 5 /* exit2 */
        start local 5 // org.graalvm.compiler.nodes.LoopExitNode exit2
        20: .line 430
            aload 4 /* exit1 */
            invokevirtual org.graalvm.compiler.nodes.LoopExitNode.loopBegin:()Lorg/graalvm/compiler/nodes/LoopBeginNode;
            aload 5 /* exit2 */
            invokevirtual org.graalvm.compiler.nodes.LoopExitNode.loopBegin:()Lorg/graalvm/compiler/nodes/LoopBeginNode;
            if_acmpne 27
            aload 4 /* exit1 */
            invokevirtual org.graalvm.compiler.nodes.LoopExitNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            aload 5 /* exit2 */
            invokevirtual org.graalvm.compiler.nodes.LoopExitNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            if_acmpne 27
            aload 4 /* exit1 */
            invokevirtual org.graalvm.compiler.nodes.LoopExitNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnonnull 27
            aload 4 /* exit1 */
            aload 5 /* exit2 */
            invokestatic org.graalvm.compiler.nodes.IfNode.sameDestination:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Z
            ifeq 27
        21: .line 432
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.LoopExitNode exit2
        end local 4 // org.graalvm.compiler.nodes.LoopExitNode exit1
        22: .line 434
      StackMap locals:
      StackMap stack:
            aload 2 /* next1 */
            instanceof org.graalvm.compiler.nodes.ReturnNode
            ifeq 27
            aload 3 /* next2 */
            instanceof org.graalvm.compiler.nodes.ReturnNode
            ifeq 27
        23: .line 435
            aload 2 /* next1 */
            checkcast org.graalvm.compiler.nodes.ReturnNode
            astore 4 /* exit1 */
        start local 4 // org.graalvm.compiler.nodes.ReturnNode exit1
        24: .line 436
            aload 3 /* next2 */
            checkcast org.graalvm.compiler.nodes.ReturnNode
            astore 5 /* exit2 */
        start local 5 // org.graalvm.compiler.nodes.ReturnNode exit2
        25: .line 437
            aload 4 /* exit1 */
            invokevirtual org.graalvm.compiler.nodes.ReturnNode.result:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* exit2 */
            invokevirtual org.graalvm.compiler.nodes.ReturnNode.result:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 27
        26: .line 439
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.ReturnNode exit2
        end local 4 // org.graalvm.compiler.nodes.ReturnNode exit1
        27: .line 442
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 3 // org.graalvm.compiler.graph.Node next2
        end local 2 // org.graalvm.compiler.graph.Node next1
        end local 1 // org.graalvm.compiler.nodes.AbstractBeginNode succ2
        end local 0 // org.graalvm.compiler.nodes.AbstractBeginNode succ1
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   28     0   succ1  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            0   28     1   succ2  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            1   28     2   next1  Lorg/graalvm/compiler/graph/Node;
            2   28     3   next2  Lorg/graalvm/compiler/graph/Node;
            4   12     4    end1  Lorg/graalvm/compiler/nodes/EndNode;
            5   12     5    end2  Lorg/graalvm/compiler/nodes/EndNode;
            8   10     6     phi  Lorg/graalvm/compiler/nodes/PhiNode;
           14   17     4  deopt1  Lorg/graalvm/compiler/nodes/DeoptimizeNode;
           15   17     5  deopt2  Lorg/graalvm/compiler/nodes/DeoptimizeNode;
           19   22     4   exit1  Lorg/graalvm/compiler/nodes/LoopExitNode;
           20   22     5   exit2  Lorg/graalvm/compiler/nodes/LoopExitNode;
           24   27     4   exit1  Lorg/graalvm/compiler/nodes/ReturnNode;
           25   27     5   exit2  Lorg/graalvm/compiler/nodes/ReturnNode;
    MethodParameters:
       Name  Flags
      succ1  
      succ2  

  private static boolean prepareForSwap(jdk.vm.ci.meta.ConstantReflectionProvider, org.graalvm.compiler.nodes.LogicNode, org.graalvm.compiler.nodes.LogicNode);
    descriptor: (Ljdk/vm/ci/meta/ConstantReflectionProvider;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/LogicNode;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=9, args_size=3
        start local 0 // jdk.vm.ci.meta.ConstantReflectionProvider constantReflection
        start local 1 // org.graalvm.compiler.nodes.LogicNode a
        start local 2 // org.graalvm.compiler.nodes.LogicNode b
         0: .line 446
            aload 1 /* a */
            instanceof org.graalvm.compiler.nodes.java.InstanceOfNode
            ifeq 13
         1: .line 447
            aload 1 /* a */
            checkcast org.graalvm.compiler.nodes.java.InstanceOfNode
            astore 3 /* instanceOfA */
        start local 3 // org.graalvm.compiler.nodes.java.InstanceOfNode instanceOfA
         2: .line 448
            aload 2 /* b */
            instanceof org.graalvm.compiler.nodes.calc.IsNullNode
            ifeq 7
         3: .line 449
            aload 2 /* b */
            checkcast org.graalvm.compiler.nodes.calc.IsNullNode
            astore 4 /* isNullNode */
        start local 4 // org.graalvm.compiler.nodes.calc.IsNullNode isNullNode
         4: .line 450
            aload 4 /* isNullNode */
            invokevirtual org.graalvm.compiler.nodes.calc.IsNullNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 3 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 53
         5: .line 451
            ldc "Can swap instanceof and isnull if"
            invokestatic org.graalvm.compiler.debug.Debug.log:(Ljava/lang/String;)V
         6: .line 452
            iconst_1
            ireturn
        end local 4 // org.graalvm.compiler.nodes.calc.IsNullNode isNullNode
         7: .line 454
      StackMap locals: org.graalvm.compiler.nodes.java.InstanceOfNode
      StackMap stack:
            aload 2 /* b */
            instanceof org.graalvm.compiler.nodes.java.InstanceOfNode
            ifeq 53
         8: .line 455
            aload 2 /* b */
            checkcast org.graalvm.compiler.nodes.java.InstanceOfNode
            astore 4 /* instanceOfB */
        start local 4 // org.graalvm.compiler.nodes.java.InstanceOfNode instanceOfB
         9: .line 456
            aload 3 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* instanceOfB */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 53
            aload 3 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            invokevirtual org.graalvm.compiler.core.common.type.TypeReference.getType:()Ljdk/vm/ci/meta/ResolvedJavaType;
            invokeinterface jdk.vm.ci.meta.ResolvedJavaType.isInterface:()Z
            ifne 53
            aload 4 /* instanceOfB */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            invokevirtual org.graalvm.compiler.core.common.type.TypeReference.getType:()Ljdk/vm/ci/meta/ResolvedJavaType;
            invokeinterface jdk.vm.ci.meta.ResolvedJavaType.isInterface:()Z
            ifne 53
        10: .line 457
            aload 3 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            invokevirtual org.graalvm.compiler.core.common.type.TypeReference.getType:()Ljdk/vm/ci/meta/ResolvedJavaType;
            aload 4 /* instanceOfB */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            invokevirtual org.graalvm.compiler.core.common.type.TypeReference.getType:()Ljdk/vm/ci/meta/ResolvedJavaType;
            invokeinterface jdk.vm.ci.meta.ResolvedJavaType.isAssignableFrom:(Ljdk/vm/ci/meta/ResolvedJavaType;)Z
            ifne 53
            aload 4 /* instanceOfB */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            invokevirtual org.graalvm.compiler.core.common.type.TypeReference.getType:()Ljdk/vm/ci/meta/ResolvedJavaType;
            aload 3 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            invokevirtual org.graalvm.compiler.core.common.type.TypeReference.getType:()Ljdk/vm/ci/meta/ResolvedJavaType;
            invokeinterface jdk.vm.ci.meta.ResolvedJavaType.isAssignableFrom:(Ljdk/vm/ci/meta/ResolvedJavaType;)Z
            ifne 53
        11: .line 459
            ldc "Can swap instanceof for types %s and %s"
            aload 3 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            aload 4 /* instanceOfB */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            invokestatic org.graalvm.compiler.debug.Debug.log:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        12: .line 460
            iconst_1
            ireturn
        end local 4 // org.graalvm.compiler.nodes.java.InstanceOfNode instanceOfB
        end local 3 // org.graalvm.compiler.nodes.java.InstanceOfNode instanceOfA
        13: .line 463
      StackMap locals:
      StackMap stack:
            aload 1 /* a */
            instanceof org.graalvm.compiler.nodes.calc.CompareNode
            ifeq 53
        14: .line 464
            aload 1 /* a */
            checkcast org.graalvm.compiler.nodes.calc.CompareNode
            astore 3 /* compareA */
        start local 3 // org.graalvm.compiler.nodes.calc.CompareNode compareA
        15: .line 465
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.condition:()Lorg/graalvm/compiler/core/common/calc/Condition;
            astore 4 /* conditionA */
        start local 4 // org.graalvm.compiler.core.common.calc.Condition conditionA
        16: .line 466
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.unorderedIsTrue:()Z
            ifeq 18
        17: .line 467
            iconst_0
            ireturn
        18: .line 469
      StackMap locals: org.graalvm.compiler.nodes.calc.CompareNode org.graalvm.compiler.core.common.calc.Condition
      StackMap stack:
            aload 2 /* b */
            instanceof org.graalvm.compiler.nodes.calc.CompareNode
            ifeq 53
        19: .line 470
            aload 2 /* b */
            checkcast org.graalvm.compiler.nodes.calc.CompareNode
            astore 5 /* compareB */
        start local 5 // org.graalvm.compiler.nodes.calc.CompareNode compareB
        20: .line 471
            aload 3 /* compareA */
            aload 5 /* compareB */
            if_acmpne 23
        21: .line 472
            ldc "Same conditions => do not swap and leave the work for global value numbering."
            invokestatic org.graalvm.compiler.debug.Debug.log:(Ljava/lang/String;)V
        22: .line 473
            iconst_0
            ireturn
        23: .line 475
      StackMap locals: org.graalvm.compiler.nodes.calc.CompareNode
      StackMap stack:
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.unorderedIsTrue:()Z
            ifeq 25
        24: .line 476
            iconst_0
            ireturn
        25: .line 478
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 6 /* comparableCondition */
        start local 6 // org.graalvm.compiler.core.common.calc.Condition comparableCondition
        26: .line 479
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.condition:()Lorg/graalvm/compiler/core/common/calc/Condition;
            astore 7 /* conditionB */
        start local 7 // org.graalvm.compiler.core.common.calc.Condition conditionB
        27: .line 480
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 30
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 30
        28: .line 481
            aload 7 /* conditionB */
            astore 6 /* comparableCondition */
        29: .line 482
            goto 32
      StackMap locals: org.graalvm.compiler.core.common.calc.Condition org.graalvm.compiler.core.common.calc.Condition
      StackMap stack:
        30: aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 32
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 32
        31: .line 483
            aload 7 /* conditionB */
            invokevirtual org.graalvm.compiler.core.common.calc.Condition.mirror:()Lorg/graalvm/compiler/core/common/calc/Condition;
            astore 6 /* comparableCondition */
        32: .line 486
      StackMap locals:
      StackMap stack:
            aload 6 /* comparableCondition */
            ifnull 37
        33: .line 487
            aload 4 /* conditionA */
            aload 6 /* comparableCondition */
            invokevirtual org.graalvm.compiler.core.common.calc.Condition.join:(Lorg/graalvm/compiler/core/common/calc/Condition;)Lorg/graalvm/compiler/core/common/calc/Condition;
            astore 8 /* combined */
        start local 8 // org.graalvm.compiler.core.common.calc.Condition combined
        34: .line 488
            aload 8 /* combined */
            ifnonnull 53
        35: .line 490
            ldc "Can swap disjoint coditions on same values: %s and %s"
            aload 4 /* conditionA */
            aload 6 /* comparableCondition */
            invokestatic org.graalvm.compiler.debug.Debug.log:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        36: .line 491
            iconst_1
            ireturn
        end local 8 // org.graalvm.compiler.core.common.calc.Condition combined
        37: .line 493
      StackMap locals:
      StackMap stack:
            aload 4 /* conditionA */
            getstatic org.graalvm.compiler.core.common.calc.Condition.EQ:Lorg/graalvm/compiler/core/common/calc/Condition;
            if_acmpne 53
            aload 7 /* conditionB */
            getstatic org.graalvm.compiler.core.common.calc.Condition.EQ:Lorg/graalvm/compiler/core/common/calc/Condition;
            if_acmpne 53
        38: .line 494
            iconst_0
            istore 8 /* canSwap */
        start local 8 // boolean canSwap
        39: .line 495
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 42
            aload 0 /* constantReflection */
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.valuesDistinct:(Ljdk/vm/ci/meta/ConstantReflectionProvider;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 42
        40: .line 496
            iconst_1
            istore 8 /* canSwap */
        41: .line 497
            goto 50
      StackMap locals: int
      StackMap stack:
        42: aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 45
            aload 0 /* constantReflection */
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.valuesDistinct:(Ljdk/vm/ci/meta/ConstantReflectionProvider;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 45
        43: .line 498
            iconst_1
            istore 8 /* canSwap */
        44: .line 499
            goto 50
      StackMap locals:
      StackMap stack:
        45: aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 48
            aload 0 /* constantReflection */
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.valuesDistinct:(Ljdk/vm/ci/meta/ConstantReflectionProvider;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 48
        46: .line 500
            iconst_1
            istore 8 /* canSwap */
        47: .line 501
            goto 50
      StackMap locals:
      StackMap stack:
        48: aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 50
            aload 0 /* constantReflection */
            aload 3 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.valuesDistinct:(Ljdk/vm/ci/meta/ConstantReflectionProvider;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 50
        49: .line 502
            iconst_1
            istore 8 /* canSwap */
        50: .line 505
      StackMap locals:
      StackMap stack:
            iload 8 /* canSwap */
            ifeq 53
        51: .line 506
            ldc "Can swap equality condition with one shared and one disjoint value."
            invokestatic org.graalvm.compiler.debug.Debug.log:(Ljava/lang/String;)V
        52: .line 507
            iconst_1
            ireturn
        end local 8 // boolean canSwap
        end local 7 // org.graalvm.compiler.core.common.calc.Condition conditionB
        end local 6 // org.graalvm.compiler.core.common.calc.Condition comparableCondition
        end local 5 // org.graalvm.compiler.nodes.calc.CompareNode compareB
        end local 4 // org.graalvm.compiler.core.common.calc.Condition conditionA
        end local 3 // org.graalvm.compiler.nodes.calc.CompareNode compareA
        53: .line 513
      StackMap locals: jdk.vm.ci.meta.ConstantReflectionProvider org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.LogicNode
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // org.graalvm.compiler.nodes.LogicNode b
        end local 1 // org.graalvm.compiler.nodes.LogicNode a
        end local 0 // jdk.vm.ci.meta.ConstantReflectionProvider constantReflection
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   54     0   constantReflection  Ljdk/vm/ci/meta/ConstantReflectionProvider;
            0   54     1                    a  Lorg/graalvm/compiler/nodes/LogicNode;
            0   54     2                    b  Lorg/graalvm/compiler/nodes/LogicNode;
            2   13     3          instanceOfA  Lorg/graalvm/compiler/nodes/java/InstanceOfNode;
            4    7     4           isNullNode  Lorg/graalvm/compiler/nodes/calc/IsNullNode;
            9   13     4          instanceOfB  Lorg/graalvm/compiler/nodes/java/InstanceOfNode;
           15   53     3             compareA  Lorg/graalvm/compiler/nodes/calc/CompareNode;
           16   53     4           conditionA  Lorg/graalvm/compiler/core/common/calc/Condition;
           20   53     5             compareB  Lorg/graalvm/compiler/nodes/calc/CompareNode;
           26   53     6  comparableCondition  Lorg/graalvm/compiler/core/common/calc/Condition;
           27   53     7           conditionB  Lorg/graalvm/compiler/core/common/calc/Condition;
           34   37     8             combined  Lorg/graalvm/compiler/core/common/calc/Condition;
           39   53     8              canSwap  Z
    MethodParameters:
                    Name  Flags
      constantReflection  
      a                   
      b                   

  private static boolean valuesDistinct(jdk.vm.ci.meta.ConstantReflectionProvider, org.graalvm.compiler.nodes.ValueNode, org.graalvm.compiler.nodes.ValueNode);
    descriptor: (Ljdk/vm/ci/meta/ConstantReflectionProvider;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // jdk.vm.ci.meta.ConstantReflectionProvider constantReflection
        start local 1 // org.graalvm.compiler.nodes.ValueNode a
        start local 2 // org.graalvm.compiler.nodes.ValueNode b
         0: .line 517
            aload 1 /* a */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 6
            aload 2 /* b */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 6
         1: .line 518
            aload 0 /* constantReflection */
            aload 1 /* a */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asConstant:()Ljdk/vm/ci/meta/Constant;
            aload 2 /* b */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asConstant:()Ljdk/vm/ci/meta/Constant;
            invokeinterface jdk.vm.ci.meta.ConstantReflectionProvider.constantEquals:(Ljdk/vm/ci/meta/Constant;Ljdk/vm/ci/meta/Constant;)Ljava/lang/Boolean;
            astore 3 /* equal */
        start local 3 // java.lang.Boolean equal
         2: .line 519
            aload 3 /* equal */
            ifnull 6
         3: .line 520
            aload 3 /* equal */
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 4
            iconst_0
            goto 5
      StackMap locals: java.lang.Boolean
      StackMap stack:
         4: iconst_1
      StackMap locals:
      StackMap stack: int
         5: ireturn
        end local 3 // java.lang.Boolean equal
         6: .line 524
      StackMap locals:
      StackMap stack:
            aload 1 /* a */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:()Lorg/graalvm/compiler/core/common/type/Stamp;
            astore 3 /* stampA */
        start local 3 // org.graalvm.compiler.core.common.type.Stamp stampA
         7: .line 525
            aload 2 /* b */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:()Lorg/graalvm/compiler/core/common/type/Stamp;
            astore 4 /* stampB */
        start local 4 // org.graalvm.compiler.core.common.type.Stamp stampB
         8: .line 526
            aload 3 /* stampA */
            aload 4 /* stampB */
            invokevirtual org.graalvm.compiler.core.common.type.Stamp.alwaysDistinct:(Lorg/graalvm/compiler/core/common/type/Stamp;)Z
            ireturn
        end local 4 // org.graalvm.compiler.core.common.type.Stamp stampB
        end local 3 // org.graalvm.compiler.core.common.type.Stamp stampA
        end local 2 // org.graalvm.compiler.nodes.ValueNode b
        end local 1 // org.graalvm.compiler.nodes.ValueNode a
        end local 0 // jdk.vm.ci.meta.ConstantReflectionProvider constantReflection
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    9     0  constantReflection  Ljdk/vm/ci/meta/ConstantReflectionProvider;
            0    9     1                   a  Lorg/graalvm/compiler/nodes/ValueNode;
            0    9     2                   b  Lorg/graalvm/compiler/nodes/ValueNode;
            2    6     3               equal  Ljava/lang/Boolean;
            7    9     3              stampA  Lorg/graalvm/compiler/core/common/type/Stamp;
            8    9     4              stampB  Lorg/graalvm/compiler/core/common/type/Stamp;
    MethodParameters:
                    Name  Flags
      constantReflection  
      a                   
      b                   

  private boolean removeOrMaterializeIf(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=11, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 535
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifeq 1
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.hasNoUsages:()Z
            ifne 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 536
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.AbstractEndNode
            ifeq 28
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.AbstractEndNode
            ifeq 28
         3: .line 537
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 2 /* trueEnd */
        start local 2 // org.graalvm.compiler.nodes.AbstractEndNode trueEnd
         4: .line 538
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 3 /* falseEnd */
        start local 3 // org.graalvm.compiler.nodes.AbstractEndNode falseEnd
         5: .line 539
            aload 2 /* trueEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            astore 4 /* merge */
        start local 4 // org.graalvm.compiler.nodes.AbstractMergeNode merge
         6: .line 540
            aload 4 /* merge */
            aload 3 /* falseEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            if_acmpne 28
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.anchored:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isEmpty:()Z
            ifeq 28
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.anchored:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isEmpty:()Z
            ifeq 28
         7: .line 541
            aconst_null
            astore 5 /* singlePhi */
        start local 5 // org.graalvm.compiler.nodes.PhiNode singlePhi
         8: .line 542
            iconst_0
            istore 6 /* distinct */
        start local 6 // int distinct
         9: .line 543
            aload 4 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.phis:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 8
            goto 16
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractEndNode org.graalvm.compiler.nodes.AbstractEndNode org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.PhiNode int top java.util.Iterator
      StackMap stack:
        10: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.PhiNode
            astore 7 /* phi */
        start local 7 // org.graalvm.compiler.nodes.PhiNode phi
        11: .line 544
            aload 7 /* phi */
            aload 2 /* trueEnd */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 9 /* trueValue */
        start local 9 // org.graalvm.compiler.nodes.ValueNode trueValue
        12: .line 545
            aload 7 /* phi */
            aload 3 /* falseEnd */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 10 /* falseValue */
        start local 10 // org.graalvm.compiler.nodes.ValueNode falseValue
        13: .line 546
            aload 9 /* trueValue */
            aload 10 /* falseValue */
            if_acmpeq 16
        14: .line 547
            iinc 6 /* distinct */ 1
        15: .line 548
            aload 7 /* phi */
            astore 5 /* singlePhi */
        end local 10 // org.graalvm.compiler.nodes.ValueNode falseValue
        end local 9 // org.graalvm.compiler.nodes.ValueNode trueValue
        end local 7 // org.graalvm.compiler.nodes.PhiNode phi
        16: .line 543
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        17: .line 551
            iload 6 /* distinct */
            ifne 20
        18: .line 556
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.removeThroughFalseBranch:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        19: .line 557
            iconst_1
            ireturn
        20: .line 558
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractEndNode org.graalvm.compiler.nodes.AbstractEndNode org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.PhiNode int
      StackMap stack:
            iload 6 /* distinct */
            iconst_1
            if_icmpne 28
        21: .line 559
            aload 5 /* singlePhi */
            aload 2 /* trueEnd */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 7 /* trueValue */
        start local 7 // org.graalvm.compiler.nodes.ValueNode trueValue
        22: .line 560
            aload 5 /* singlePhi */
            aload 3 /* falseEnd */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 8 /* falseValue */
        start local 8 // org.graalvm.compiler.nodes.ValueNode falseValue
        23: .line 561
            aload 0 /* this */
            aload 7 /* trueValue */
            aload 8 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.IfNode.canonicalizeConditionalCascade:(Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
            astore 9 /* conditional */
        start local 9 // org.graalvm.compiler.nodes.calc.ConditionalNode conditional
        24: .line 562
            aload 9 /* conditional */
            ifnull 28
        25: .line 563
            aload 5 /* singlePhi */
            aload 2 /* trueEnd */
            aload 9 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.setValueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
        26: .line 564
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.removeThroughFalseBranch:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        27: .line 565
            iconst_1
            ireturn
        end local 9 // org.graalvm.compiler.nodes.calc.ConditionalNode conditional
        end local 8 // org.graalvm.compiler.nodes.ValueNode falseValue
        end local 7 // org.graalvm.compiler.nodes.ValueNode trueValue
        end local 6 // int distinct
        end local 5 // org.graalvm.compiler.nodes.PhiNode singlePhi
        end local 4 // org.graalvm.compiler.nodes.AbstractMergeNode merge
        end local 3 // org.graalvm.compiler.nodes.AbstractEndNode falseEnd
        end local 2 // org.graalvm.compiler.nodes.AbstractEndNode trueEnd
        28: .line 570
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.ReturnNode
            ifeq 45
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.ReturnNode
            ifeq 45
        29: .line 571
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.ReturnNode
            astore 2 /* trueEnd */
        start local 2 // org.graalvm.compiler.nodes.ReturnNode trueEnd
        30: .line 572
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.ReturnNode
            astore 3 /* falseEnd */
        start local 3 // org.graalvm.compiler.nodes.ReturnNode falseEnd
        31: .line 573
            aload 2 /* trueEnd */
            invokevirtual org.graalvm.compiler.nodes.ReturnNode.result:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 4 /* trueValue */
        start local 4 // org.graalvm.compiler.nodes.ValueNode trueValue
        32: .line 574
            aload 3 /* falseEnd */
            invokevirtual org.graalvm.compiler.nodes.ReturnNode.result:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 5 /* falseValue */
        start local 5 // org.graalvm.compiler.nodes.ValueNode falseValue
        33: .line 575
            aconst_null
            astore 6 /* value */
        start local 6 // org.graalvm.compiler.nodes.ValueNode value
        34: .line 576
            aload 4 /* trueValue */
            ifnull 41
        35: .line 577
            aload 4 /* trueValue */
            aload 5 /* falseValue */
            if_acmpne 38
        36: .line 578
            aload 4 /* trueValue */
            astore 6 /* value */
        37: .line 579
            goto 41
        38: .line 580
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.ReturnNode org.graalvm.compiler.nodes.ReturnNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
            aload 0 /* this */
            aload 4 /* trueValue */
            aload 5 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.IfNode.canonicalizeConditionalCascade:(Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
            astore 6 /* value */
        39: .line 581
            aload 6 /* value */
            ifnonnull 41
        40: .line 582
            iconst_0
            ireturn
        41: .line 586
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.ReturnNode
            dup
            aload 6 /* value */
            invokespecial org.graalvm.compiler.nodes.ReturnNode.<init>:(Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.ReturnNode
            astore 7 /* newReturn */
        start local 7 // org.graalvm.compiler.nodes.ReturnNode newReturn
        42: .line 587
            aload 0 /* this */
            aload 7 /* newReturn */
            invokevirtual org.graalvm.compiler.nodes.IfNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        43: .line 588
            aload 0 /* this */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        44: .line 589
            iconst_1
            ireturn
        end local 7 // org.graalvm.compiler.nodes.ReturnNode newReturn
        end local 6 // org.graalvm.compiler.nodes.ValueNode value
        end local 5 // org.graalvm.compiler.nodes.ValueNode falseValue
        end local 4 // org.graalvm.compiler.nodes.ValueNode trueValue
        end local 3 // org.graalvm.compiler.nodes.ReturnNode falseEnd
        end local 2 // org.graalvm.compiler.nodes.ReturnNode trueEnd
        45: .line 591
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   46     0         this  Lorg/graalvm/compiler/nodes/IfNode;
            0   46     1         tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            4   28     2      trueEnd  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            5   28     3     falseEnd  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            6   28     4        merge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            8   28     5    singlePhi  Lorg/graalvm/compiler/nodes/PhiNode;
            9   28     6     distinct  I
           11   16     7          phi  Lorg/graalvm/compiler/nodes/PhiNode;
           12   16     9    trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
           13   16    10   falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
           22   28     7    trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
           23   28     8   falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
           24   28     9  conditional  Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
           30   45     2      trueEnd  Lorg/graalvm/compiler/nodes/ReturnNode;
           31   45     3     falseEnd  Lorg/graalvm/compiler/nodes/ReturnNode;
           32   45     4    trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
           33   45     5   falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
           34   45     6        value  Lorg/graalvm/compiler/nodes/ValueNode;
           42   45     7    newReturn  Lorg/graalvm/compiler/nodes/ReturnNode;
    MethodParameters:
      Name  Flags
      tool  

  protected void removeThroughFalseBranch(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 595
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 2 /* trueBegin */
        start local 2 // org.graalvm.compiler.nodes.AbstractBeginNode trueBegin
         1: .line 596
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 0 /* this */
            aload 2 /* trueBegin */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.removeSplitPropagate:(Lorg/graalvm/compiler/nodes/ControlSplitNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
         2: .line 597
            aload 1 /* tool */
            aload 2 /* trueBegin */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.addToWorkList:(Lorg/graalvm/compiler/graph/Node;)V
         3: .line 598
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            ifnull 5
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            invokevirtual org.graalvm.compiler.nodes.LogicNode.isAlive:()Z
            ifeq 5
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            invokevirtual org.graalvm.compiler.nodes.LogicNode.hasNoUsages:()Z
            ifeq 5
         4: .line 599
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killWithUnusedFloatingInputs:(Lorg/graalvm/compiler/graph/Node;)V
         5: .line 601
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack:
            return
        end local 2 // org.graalvm.compiler.nodes.AbstractBeginNode trueBegin
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lorg/graalvm/compiler/nodes/IfNode;
            0    6     1       tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            1    6     2  trueBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    MethodParameters:
      Name  Flags
      tool  

  private org.graalvm.compiler.nodes.calc.ConditionalNode canonicalizeConditionalCascade(org.graalvm.compiler.nodes.ValueNode, org.graalvm.compiler.nodes.ValueNode);
    descriptor: (Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=11, args_size=3
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.ValueNode trueValue
        start local 2 // org.graalvm.compiler.nodes.ValueNode falseValue
         0: .line 604
            aload 1 /* trueValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.getStackKind:()Ljdk/vm/ci/meta/JavaKind;
            aload 2 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.getStackKind:()Ljdk/vm/ci/meta/JavaKind;
            if_acmpeq 2
         1: .line 605
            aconst_null
            areturn
         2: .line 607
      StackMap locals:
      StackMap stack:
            aload 1 /* trueValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.getStackKind:()Ljdk/vm/ci/meta/JavaKind;
            getstatic jdk.vm.ci.meta.JavaKind.Int:Ljdk/vm/ci/meta/JavaKind;
            if_acmpeq 4
            aload 1 /* trueValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.getStackKind:()Ljdk/vm/ci/meta/JavaKind;
            getstatic jdk.vm.ci.meta.JavaKind.Long:Ljdk/vm/ci/meta/JavaKind;
            if_acmpeq 4
         3: .line 608
            aconst_null
            areturn
         4: .line 610
      StackMap locals:
      StackMap stack:
            aload 1 /* trueValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 6
            aload 2 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 6
         5: .line 611
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.calc.ConditionalNode
            dup
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            aload 1 /* trueValue */
            aload 2 /* falseValue */
            invokespecial org.graalvm.compiler.nodes.calc.ConditionalNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            areturn
         6: .line 613
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 3 /* conditional */
        start local 3 // org.graalvm.compiler.nodes.calc.ConditionalNode conditional
         7: .line 614
            aconst_null
            astore 4 /* constant */
        start local 4 // org.graalvm.compiler.nodes.ValueNode constant
         8: .line 616
            aload 1 /* trueValue */
            instanceof org.graalvm.compiler.nodes.calc.ConditionalNode
            ifeq 13
            aload 2 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 13
         9: .line 617
            aload 1 /* trueValue */
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            astore 3 /* conditional */
        10: .line 618
            aload 2 /* falseValue */
            astore 4 /* constant */
        11: .line 619
            iconst_1
            istore 5 /* negateCondition */
        start local 5 // boolean negateCondition
        12: .line 620
            goto 19
        end local 5 // boolean negateCondition
      StackMap locals: org.graalvm.compiler.nodes.calc.ConditionalNode org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
        13: aload 2 /* falseValue */
            instanceof org.graalvm.compiler.nodes.calc.ConditionalNode
            ifeq 18
            aload 1 /* trueValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 18
        14: .line 621
            aload 2 /* falseValue */
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            astore 3 /* conditional */
        15: .line 622
            aload 1 /* trueValue */
            astore 4 /* constant */
        16: .line 623
            iconst_0
            istore 5 /* negateCondition */
        start local 5 // boolean negateCondition
        17: .line 624
            goto 19
        end local 5 // boolean negateCondition
        18: .line 625
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        start local 5 // boolean negateCondition
        19: .line 629
      StackMap locals: int
      StackMap stack:
            aload 4 /* constant */
            aload 3 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 23
        20: .line 630
            aload 3 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.falseValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 7 /* otherValue */
        start local 7 // org.graalvm.compiler.nodes.ValueNode otherValue
        21: .line 631
            iconst_0
            istore 6 /* negateConditionalCondition */
        start local 6 // boolean negateConditionalCondition
        22: .line 632
            goto 28
        end local 7 // org.graalvm.compiler.nodes.ValueNode otherValue
        end local 6 // boolean negateConditionalCondition
      StackMap locals:
      StackMap stack:
        23: aload 4 /* constant */
            aload 3 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.falseValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 27
        24: .line 633
            aload 3 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 7 /* otherValue */
        start local 7 // org.graalvm.compiler.nodes.ValueNode otherValue
        25: .line 634
            iconst_1
            istore 6 /* negateConditionalCondition */
        start local 6 // boolean negateConditionalCondition
        26: .line 635
            goto 28
        end local 7 // org.graalvm.compiler.nodes.ValueNode otherValue
        end local 6 // boolean negateConditionalCondition
        27: .line 636
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        start local 6 // boolean negateConditionalCondition
        start local 7 // org.graalvm.compiler.nodes.ValueNode otherValue
        28: .line 638
      StackMap locals: int org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
            aload 7 /* otherValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 32
        29: .line 639
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.IfNode.probability:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)D
            dstore 8 /* shortCutProbability */
        start local 8 // double shortCutProbability
        30: .line 640
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            iload 5 /* negateCondition */
            aload 3 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            iload 6 /* negateConditionalCondition */
            dload 8 /* shortCutProbability */
            invokestatic org.graalvm.compiler.nodes.LogicNode.or:(Lorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/LogicNode;ZD)Lorg/graalvm/compiler/nodes/LogicNode;
            astore 10 /* newCondition */
        start local 10 // org.graalvm.compiler.nodes.LogicNode newCondition
        31: .line 641
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.calc.ConditionalNode
            dup
            aload 10 /* newCondition */
            aload 4 /* constant */
            aload 7 /* otherValue */
            invokespecial org.graalvm.compiler.nodes.calc.ConditionalNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            areturn
        end local 10 // org.graalvm.compiler.nodes.LogicNode newCondition
        end local 8 // double shortCutProbability
        end local 7 // org.graalvm.compiler.nodes.ValueNode otherValue
        end local 6 // boolean negateConditionalCondition
        end local 5 // boolean negateCondition
        end local 4 // org.graalvm.compiler.nodes.ValueNode constant
        end local 3 // org.graalvm.compiler.nodes.calc.ConditionalNode conditional
        32: .line 644
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
            aconst_null
            areturn
        end local 2 // org.graalvm.compiler.nodes.ValueNode falseValue
        end local 1 // org.graalvm.compiler.nodes.ValueNode trueValue
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot                        Name  Signature
            0   33     0                        this  Lorg/graalvm/compiler/nodes/IfNode;
            0   33     1                   trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
            0   33     2                  falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
            7   32     3                 conditional  Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
            8   32     4                    constant  Lorg/graalvm/compiler/nodes/ValueNode;
           12   13     5             negateCondition  Z
           17   18     5             negateCondition  Z
           19   32     5             negateCondition  Z
           22   23     6  negateConditionalCondition  Z
           26   27     6  negateConditionalCondition  Z
           28   32     6  negateConditionalCondition  Z
           21   23     7                  otherValue  Lorg/graalvm/compiler/nodes/ValueNode;
           25   27     7                  otherValue  Lorg/graalvm/compiler/nodes/ValueNode;
           28   32     7                  otherValue  Lorg/graalvm/compiler/nodes/ValueNode;
           30   32     8         shortCutProbability  D
           31   32    10                newCondition  Lorg/graalvm/compiler/nodes/LogicNode;
    MethodParameters:
            Name  Flags
      trueValue   
      falseValue  

  private boolean splitIfAtPhi(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=13, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 655
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            instanceof org.graalvm.compiler.nodes.MergeNode
            ifne 2
         1: .line 656
            iconst_0
            ireturn
         2: .line 658
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.MergeNode
            astore 2 /* merge */
        start local 2 // org.graalvm.compiler.nodes.MergeNode merge
         3: .line 659
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.forwardEndCount:()I
            iconst_1
            if_icmpne 5
         4: .line 661
            iconst_0
            ireturn
         5: .line 663
      StackMap locals: org.graalvm.compiler.nodes.MergeNode
      StackMap stack:
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_1
            if_icmpne 6
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.phis:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_1
            if_icmpeq 7
         6: .line 664
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         7: .line 666
      StackMap locals:
      StackMap stack:
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnull 9
         8: .line 668
            iconst_0
            ireturn
         9: .line 670
      StackMap locals:
      StackMap stack:
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.phis:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.first:()Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.PhiNode
            astore 3 /* phi */
        start local 3 // org.graalvm.compiler.nodes.PhiNode phi
        10: .line 671
            aload 3 /* phi */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_1
            if_icmpeq 12
        11: .line 676
            iconst_0
            ireturn
        12: .line 683
      StackMap locals: org.graalvm.compiler.nodes.PhiNode
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            aload 3 /* phi */
            invokestatic org.graalvm.compiler.nodes.IfNode.conditionUses:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/PhiNode;)Z
            ifne 14
        13: .line 684
            iconst_0
            ireturn
        14: .line 694
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* trueMerge */
        start local 4 // org.graalvm.compiler.nodes.MergeNode trueMerge
        15: .line 695
            aconst_null
            astore 5 /* falseMerge */
        start local 5 // org.graalvm.compiler.nodes.MergeNode falseMerge
        16: .line 696
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 17
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnull 17
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        17: .line 698
      StackMap locals: org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.MergeNode
      StackMap stack:
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.forwardEnds:()Lorg/graalvm/compiler/graph/NodeInputList;
            invokevirtual org.graalvm.compiler.graph.NodeInputList.snapshot:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 49
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.MergeNode top java.util.Iterator
      StackMap stack:
        18: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 6 /* end */
        start local 6 // org.graalvm.compiler.nodes.EndNode end
        19: .line 699
            aload 3 /* phi */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 8 /* value */
        start local 8 // org.graalvm.compiler.graph.Node value
        20: .line 700
            aload 1 /* tool */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            aload 3 /* phi */
            aload 8 /* value */
            invokestatic org.graalvm.compiler.nodes.IfNode.computeCondition:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/PhiNode;Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/nodes/LogicNode;
            astore 9 /* result */
        start local 9 // org.graalvm.compiler.nodes.LogicNode result
        21: .line 701
            aload 9 /* result */
            instanceof org.graalvm.compiler.nodes.LogicConstantNode
            ifeq 32
        22: .line 702
            aload 2 /* merge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.removeEnd:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)V
        23: .line 703
            aload 9 /* result */
            checkcast org.graalvm.compiler.nodes.LogicConstantNode
            invokevirtual org.graalvm.compiler.nodes.LogicConstantNode.getValue:()Z
            ifeq 28
        24: .line 704
            aload 4 /* trueMerge */
            ifnonnull 26
        25: .line 705
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.IfNode.insertMerge:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Lorg/graalvm/compiler/nodes/MergeNode;
            astore 4 /* trueMerge */
        26: .line 707
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.EndNode java.util.Iterator org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.LogicNode
      StackMap stack:
            aload 4 /* trueMerge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        27: .line 708
            goto 49
        28: .line 709
      StackMap locals:
      StackMap stack:
            aload 5 /* falseMerge */
            ifnonnull 30
        29: .line 710
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.IfNode.insertMerge:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Lorg/graalvm/compiler/nodes/MergeNode;
            astore 5 /* falseMerge */
        30: .line 712
      StackMap locals:
      StackMap stack:
            aload 5 /* falseMerge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        31: .line 714
            goto 49
      StackMap locals:
      StackMap stack:
        32: aload 9 /* result */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            if_acmpeq 49
        33: .line 716
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.BeginNode
            dup
            invokespecial org.graalvm.compiler.nodes.BeginNode.<init>:()V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.BeginNode
            astore 10 /* trueBegin */
        start local 10 // org.graalvm.compiler.nodes.BeginNode trueBegin
        34: .line 717
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.BeginNode
            dup
            invokespecial org.graalvm.compiler.nodes.BeginNode.<init>:()V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.BeginNode
            astore 11 /* falseBegin */
        start local 11 // org.graalvm.compiler.nodes.BeginNode falseBegin
        35: .line 719
            aload 9 /* result */
            invokevirtual org.graalvm.compiler.nodes.LogicNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            ifnonnull 37
        36: .line 720
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 9 /* result */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.addOrUniqueWithInputs:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            astore 9 /* result */
        37: .line 722
      StackMap locals: org.graalvm.compiler.nodes.BeginNode org.graalvm.compiler.nodes.BeginNode
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.IfNode
            dup
            aload 9 /* result */
            aload 10 /* trueBegin */
            aload 11 /* falseBegin */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            invokespecial org.graalvm.compiler.nodes.IfNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;D)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.IfNode
            astore 12 /* newIfNode */
        start local 12 // org.graalvm.compiler.nodes.IfNode newIfNode
        38: .line 723
            aload 2 /* merge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.removeEnd:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)V
        39: .line 724
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.EndNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.FixedWithNextNode
            aload 12 /* newIfNode */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        40: .line 726
            aload 4 /* trueMerge */
            ifnonnull 42
        41: .line 727
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.IfNode.insertMerge:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Lorg/graalvm/compiler/nodes/MergeNode;
            astore 4 /* trueMerge */
        42: .line 729
      StackMap locals: org.graalvm.compiler.nodes.IfNode
      StackMap stack:
            aload 10 /* trueBegin */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.EndNode
            dup
            invokespecial org.graalvm.compiler.nodes.EndNode.<init>:()V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.FixedNode
            invokevirtual org.graalvm.compiler.nodes.BeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        43: .line 730
            aload 4 /* trueMerge */
            aload 10 /* trueBegin */
            invokevirtual org.graalvm.compiler.nodes.BeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.EndNode
            invokevirtual org.graalvm.compiler.nodes.MergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        44: .line 732
            aload 5 /* falseMerge */
            ifnonnull 46
        45: .line 733
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.IfNode.insertMerge:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Lorg/graalvm/compiler/nodes/MergeNode;
            astore 5 /* falseMerge */
        46: .line 735
      StackMap locals:
      StackMap stack:
            aload 11 /* falseBegin */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.EndNode
            dup
            invokespecial org.graalvm.compiler.nodes.EndNode.<init>:()V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.FixedNode
            invokevirtual org.graalvm.compiler.nodes.BeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        47: .line 736
            aload 5 /* falseMerge */
            aload 11 /* falseBegin */
            invokevirtual org.graalvm.compiler.nodes.BeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.EndNode
            invokevirtual org.graalvm.compiler.nodes.MergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        48: .line 738
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.EndNode.safeDelete:()V
        end local 12 // org.graalvm.compiler.nodes.IfNode newIfNode
        end local 11 // org.graalvm.compiler.nodes.BeginNode falseBegin
        end local 10 // org.graalvm.compiler.nodes.BeginNode trueBegin
        end local 9 // org.graalvm.compiler.nodes.LogicNode result
        end local 8 // org.graalvm.compiler.graph.Node value
        end local 6 // org.graalvm.compiler.nodes.EndNode end
        49: .line 698
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.MergeNode top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 18
        50: .line 741
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 4 /* trueMerge */
            invokestatic org.graalvm.compiler.nodes.IfNode.transferProxies:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/MergeNode;)V
        51: .line 742
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 5 /* falseMerge */
            invokestatic org.graalvm.compiler.nodes.IfNode.transferProxies:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/MergeNode;)V
        52: .line 744
            aload 0 /* this */
            aload 1 /* tool */
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.cleanupMerge:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/MergeNode;)V
        53: .line 745
            aload 0 /* this */
            aload 1 /* tool */
            aload 4 /* trueMerge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.cleanupMerge:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/MergeNode;)V
        54: .line 746
            aload 0 /* this */
            aload 1 /* tool */
            aload 5 /* falseMerge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.cleanupMerge:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/MergeNode;)V
        55: .line 748
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.MergeNode falseMerge
        end local 4 // org.graalvm.compiler.nodes.MergeNode trueMerge
        end local 3 // org.graalvm.compiler.nodes.PhiNode phi
        end local 2 // org.graalvm.compiler.nodes.MergeNode merge
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   56     0        this  Lorg/graalvm/compiler/nodes/IfNode;
            0   56     1        tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            3   56     2       merge  Lorg/graalvm/compiler/nodes/MergeNode;
           10   56     3         phi  Lorg/graalvm/compiler/nodes/PhiNode;
           15   56     4   trueMerge  Lorg/graalvm/compiler/nodes/MergeNode;
           16   56     5  falseMerge  Lorg/graalvm/compiler/nodes/MergeNode;
           19   49     6         end  Lorg/graalvm/compiler/nodes/EndNode;
           20   49     8       value  Lorg/graalvm/compiler/graph/Node;
           21   49     9      result  Lorg/graalvm/compiler/nodes/LogicNode;
           34   49    10   trueBegin  Lorg/graalvm/compiler/nodes/BeginNode;
           35   49    11  falseBegin  Lorg/graalvm/compiler/nodes/BeginNode;
           38   49    12   newIfNode  Lorg/graalvm/compiler/nodes/IfNode;
    MethodParameters:
      Name  Flags
      tool  

  private static boolean conditionUses(org.graalvm.compiler.nodes.LogicNode, org.graalvm.compiler.nodes.PhiNode);
    descriptor: (Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/PhiNode;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.graalvm.compiler.nodes.LogicNode condition
        start local 1 // org.graalvm.compiler.nodes.PhiNode phi
         0: .line 759
            aload 0 /* condition */
            invokevirtual org.graalvm.compiler.nodes.LogicNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_1
            if_icmpeq 2
         1: .line 760
            iconst_0
            ireturn
         2: .line 762
      StackMap locals:
      StackMap stack:
            aload 0 /* condition */
            instanceof org.graalvm.compiler.nodes.ShortCircuitOrNode
            ifeq 7
         3: .line 763
            aload 0 /* condition */
            invokevirtual org.graalvm.compiler.nodes.LogicNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getGuardsStage:()Lorg/graalvm/compiler/nodes/StructuredGraph$GuardsStage;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph$GuardsStage.areDeoptsFixed:()Z
            ifeq 15
         4: .line 770
            aload 0 /* condition */
            checkcast org.graalvm.compiler.nodes.ShortCircuitOrNode
            astore 2 /* orNode */
        start local 2 // org.graalvm.compiler.nodes.ShortCircuitOrNode orNode
         5: .line 771
            aload 2 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.x:Lorg/graalvm/compiler/nodes/LogicNode;
            aload 1 /* phi */
            invokestatic org.graalvm.compiler.nodes.IfNode.conditionUses:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/PhiNode;)Z
            ifne 6
            aload 2 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.y:Lorg/graalvm/compiler/nodes/LogicNode;
            aload 1 /* phi */
            invokestatic org.graalvm.compiler.nodes.IfNode.conditionUses:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/PhiNode;)Z
            ifne 6
            iconst_0
            ireturn
      StackMap locals: org.graalvm.compiler.nodes.ShortCircuitOrNode
      StackMap stack:
         6: iconst_1
            ireturn
        end local 2 // org.graalvm.compiler.nodes.ShortCircuitOrNode orNode
         7: .line 773
      StackMap locals:
      StackMap stack:
            aload 0 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable$Unary
            ifeq 11
         8: .line 774
            aload 0 /* condition */
            checkcast org.graalvm.compiler.graph.spi.Canonicalizable$Unary
            astore 2 /* unary */
        start local 2 // org.graalvm.compiler.graph.spi.Canonicalizable$Unary unary
         9: .line 775
            aload 2 /* unary */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Unary.getValue:()Lorg/graalvm/compiler/graph/Node;
            aload 1 /* phi */
            if_acmpne 10
            iconst_1
            ireturn
      StackMap locals: org.graalvm.compiler.graph.spi.Canonicalizable$Unary
      StackMap stack:
        10: iconst_0
            ireturn
        end local 2 // org.graalvm.compiler.graph.spi.Canonicalizable$Unary unary
        11: .line 776
      StackMap locals:
      StackMap stack:
            aload 0 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable$Binary
            ifeq 15
        12: .line 777
            aload 0 /* condition */
            checkcast org.graalvm.compiler.graph.spi.Canonicalizable$Binary
            astore 2 /* binary */
        start local 2 // org.graalvm.compiler.graph.spi.Canonicalizable$Binary binary
        13: .line 778
            aload 2 /* binary */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Binary.getX:()Lorg/graalvm/compiler/graph/Node;
            aload 1 /* phi */
            if_acmpeq 14
            aload 2 /* binary */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Binary.getY:()Lorg/graalvm/compiler/graph/Node;
            aload 1 /* phi */
            if_acmpeq 14
            iconst_0
            ireturn
      StackMap locals: org.graalvm.compiler.graph.spi.Canonicalizable$Binary
      StackMap stack:
        14: iconst_1
            ireturn
        end local 2 // org.graalvm.compiler.graph.spi.Canonicalizable$Binary binary
        15: .line 780
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // org.graalvm.compiler.nodes.PhiNode phi
        end local 0 // org.graalvm.compiler.nodes.LogicNode condition
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   16     0  condition  Lorg/graalvm/compiler/nodes/LogicNode;
            0   16     1        phi  Lorg/graalvm/compiler/nodes/PhiNode;
            5    7     2     orNode  Lorg/graalvm/compiler/nodes/ShortCircuitOrNode;
            9   11     2      unary  Lorg/graalvm/compiler/graph/spi/Canonicalizable$Unary<*>;
           13   15     2     binary  Lorg/graalvm/compiler/graph/spi/Canonicalizable$Binary<*>;
    MethodParameters:
           Name  Flags
      condition  
      phi        

  private static org.graalvm.compiler.nodes.LogicNode computeCondition(org.graalvm.compiler.graph.spi.SimplifierTool, org.graalvm.compiler.nodes.LogicNode, org.graalvm.compiler.nodes.PhiNode, org.graalvm.compiler.graph.Node);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/PhiNode;Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/nodes/LogicNode;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=9, args_size=4
        start local 0 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        start local 1 // org.graalvm.compiler.nodes.LogicNode condition
        start local 2 // org.graalvm.compiler.nodes.PhiNode phi
        start local 3 // org.graalvm.compiler.graph.Node value
         0: .line 794
            aload 1 /* condition */
            instanceof org.graalvm.compiler.nodes.ShortCircuitOrNode
            ifeq 14
         1: .line 795
            aload 1 /* condition */
            invokevirtual org.graalvm.compiler.nodes.LogicNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getGuardsStage:()Lorg/graalvm/compiler/nodes/StructuredGraph$GuardsStage;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph$GuardsStage.areDeoptsFixed:()Z
            ifeq 24
         2: .line 796
            aload 1 /* condition */
            checkcast org.graalvm.compiler.nodes.ShortCircuitOrNode
            astore 4 /* orNode */
        start local 4 // org.graalvm.compiler.nodes.ShortCircuitOrNode orNode
         3: .line 797
            aload 0 /* tool */
            aload 4 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.x:Lorg/graalvm/compiler/nodes/LogicNode;
            aload 2 /* phi */
            aload 3 /* value */
            invokestatic org.graalvm.compiler.nodes.IfNode.computeCondition:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/PhiNode;Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/nodes/LogicNode;
            astore 5 /* resultX */
        start local 5 // org.graalvm.compiler.nodes.LogicNode resultX
         4: .line 798
            aload 0 /* tool */
            aload 4 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.y:Lorg/graalvm/compiler/nodes/LogicNode;
            aload 2 /* phi */
            aload 3 /* value */
            invokestatic org.graalvm.compiler.nodes.IfNode.computeCondition:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/PhiNode;Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/nodes/LogicNode;
            astore 6 /* resultY */
        start local 6 // org.graalvm.compiler.nodes.LogicNode resultY
         5: .line 799
            aload 5 /* resultX */
            aload 4 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.x:Lorg/graalvm/compiler/nodes/LogicNode;
            if_acmpne 6
            aload 6 /* resultY */
            aload 4 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.y:Lorg/graalvm/compiler/nodes/LogicNode;
            if_acmpeq 13
         6: .line 800
      StackMap locals: org.graalvm.compiler.nodes.ShortCircuitOrNode org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.LogicNode
      StackMap stack:
            aload 4 /* orNode */
            aload 0 /* tool */
            aload 5 /* resultX */
            aload 6 /* resultY */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.canonical:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/LogicNode;)Lorg/graalvm/compiler/nodes/LogicNode;
            astore 7 /* result */
        start local 7 // org.graalvm.compiler.nodes.LogicNode result
         7: .line 801
            aload 7 /* result */
            aload 4 /* orNode */
            if_acmpeq 9
         8: .line 802
            aload 7 /* result */
            areturn
         9: .line 807
      StackMap locals: org.graalvm.compiler.nodes.LogicNode
      StackMap stack:
            new org.graalvm.compiler.nodes.ShortCircuitOrNode
            dup
            aload 5 /* resultX */
            aload 4 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.xNegated:Z
            aload 6 /* resultY */
        10: .line 808
            aload 4 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.yNegated:Z
            aload 4 /* orNode */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.getShortCircuitProbability:()D
        11: .line 807
            invokespecial org.graalvm.compiler.nodes.ShortCircuitOrNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/LogicNode;ZD)V
            astore 8 /* newOr */
        start local 8 // org.graalvm.compiler.nodes.ShortCircuitOrNode newOr
        12: .line 809
            aload 8 /* newOr */
            aload 0 /* tool */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.canonical:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            areturn
        end local 8 // org.graalvm.compiler.nodes.ShortCircuitOrNode newOr
        end local 7 // org.graalvm.compiler.nodes.LogicNode result
        13: .line 811
      StackMap locals:
      StackMap stack:
            aload 4 /* orNode */
            areturn
        end local 6 // org.graalvm.compiler.nodes.LogicNode resultY
        end local 5 // org.graalvm.compiler.nodes.LogicNode resultX
        end local 4 // org.graalvm.compiler.nodes.ShortCircuitOrNode orNode
        14: .line 813
      StackMap locals:
      StackMap stack:
            aload 1 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable$Binary
            ifeq 20
        15: .line 814
            aload 1 /* condition */
            checkcast org.graalvm.compiler.graph.spi.Canonicalizable$Binary
            astore 4 /* compare */
        start local 4 // org.graalvm.compiler.graph.spi.Canonicalizable$Binary compare
        16: .line 815
            aload 4 /* compare */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Binary.getX:()Lorg/graalvm/compiler/graph/Node;
            aload 2 /* phi */
            if_acmpne 18
        17: .line 816
            aload 4 /* compare */
            aload 0 /* tool */
            aload 3 /* value */
            aload 4 /* compare */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Binary.getY:()Lorg/graalvm/compiler/graph/Node;
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Binary.canonical:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            areturn
        18: .line 817
      StackMap locals: org.graalvm.compiler.graph.spi.Canonicalizable$Binary
      StackMap stack:
            aload 4 /* compare */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Binary.getY:()Lorg/graalvm/compiler/graph/Node;
            aload 2 /* phi */
            if_acmpne 24
        19: .line 818
            aload 4 /* compare */
            aload 0 /* tool */
            aload 4 /* compare */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Binary.getX:()Lorg/graalvm/compiler/graph/Node;
            aload 3 /* value */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Binary.canonical:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            areturn
        end local 4 // org.graalvm.compiler.graph.spi.Canonicalizable$Binary compare
        20: .line 820
      StackMap locals:
      StackMap stack:
            aload 1 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable$Unary
            ifeq 24
        21: .line 821
            aload 1 /* condition */
            checkcast org.graalvm.compiler.graph.spi.Canonicalizable$Unary
            astore 4 /* compare */
        start local 4 // org.graalvm.compiler.graph.spi.Canonicalizable$Unary compare
        22: .line 822
            aload 4 /* compare */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Unary.getValue:()Lorg/graalvm/compiler/graph/Node;
            aload 2 /* phi */
            if_acmpne 24
        23: .line 823
            aload 4 /* compare */
            aload 0 /* tool */
            aload 3 /* value */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable$Unary.canonical:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            areturn
        end local 4 // org.graalvm.compiler.graph.spi.Canonicalizable$Unary compare
        24: .line 826
      StackMap locals:
      StackMap stack:
            aload 1 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable
            ifeq 26
        25: .line 827
            aload 1 /* condition */
            checkcast org.graalvm.compiler.graph.spi.Canonicalizable
            aload 0 /* tool */
            invokeinterface org.graalvm.compiler.graph.spi.Canonicalizable.canonical:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            areturn
        26: .line 829
      StackMap locals:
      StackMap stack:
            aload 1 /* condition */
            areturn
        end local 3 // org.graalvm.compiler.graph.Node value
        end local 2 // org.graalvm.compiler.nodes.PhiNode phi
        end local 1 // org.graalvm.compiler.nodes.LogicNode condition
        end local 0 // org.graalvm.compiler.graph.spi.SimplifierTool tool
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   27     0       tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            0   27     1  condition  Lorg/graalvm/compiler/nodes/LogicNode;
            0   27     2        phi  Lorg/graalvm/compiler/nodes/PhiNode;
            0   27     3      value  Lorg/graalvm/compiler/graph/Node;
            3   14     4     orNode  Lorg/graalvm/compiler/nodes/ShortCircuitOrNode;
            4   14     5    resultX  Lorg/graalvm/compiler/nodes/LogicNode;
            5   14     6    resultY  Lorg/graalvm/compiler/nodes/LogicNode;
            7   13     7     result  Lorg/graalvm/compiler/nodes/LogicNode;
           12   13     8      newOr  Lorg/graalvm/compiler/nodes/ShortCircuitOrNode;
           16   20     4    compare  Lorg/graalvm/compiler/graph/spi/Canonicalizable$Binary<Lorg/graalvm/compiler/graph/Node;>;
           22   24     4    compare  Lorg/graalvm/compiler/graph/spi/Canonicalizable$Unary<Lorg/graalvm/compiler/graph/Node;>;
    MethodParameters:
           Name  Flags
      tool       
      condition  
      phi        
      value      

  private static void transferProxies(org.graalvm.compiler.nodes.AbstractBeginNode, org.graalvm.compiler.nodes.MergeNode);
    descriptor: (Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/MergeNode;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // org.graalvm.compiler.nodes.AbstractBeginNode successor
        start local 1 // org.graalvm.compiler.nodes.MergeNode falseMerge
         0: .line 833
            aload 0 /* successor */
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 6
            aload 1 /* falseMerge */
            ifnull 6
         1: .line 834
            aload 0 /* successor */
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            astore 2 /* loopExitNode */
        start local 2 // org.graalvm.compiler.nodes.LoopExitNode loopExitNode
         2: .line 835
            aload 2 /* loopExitNode */
            invokevirtual org.graalvm.compiler.nodes.LoopExitNode.proxies:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.snapshot:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 5
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.LoopExitNode top java.util.Iterator
      StackMap stack:
         3: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.ProxyNode
            astore 3 /* proxy */
        start local 3 // org.graalvm.compiler.nodes.ProxyNode proxy
         4: .line 836
            aload 3 /* proxy */
            aload 0 /* successor */
            aload 1 /* falseMerge */
            invokevirtual org.graalvm.compiler.nodes.ProxyNode.replaceFirstInput:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)V
        end local 3 // org.graalvm.compiler.nodes.ProxyNode proxy
         5: .line 835
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        end local 2 // org.graalvm.compiler.nodes.LoopExitNode loopExitNode
         6: .line 839
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.MergeNode
      StackMap stack:
            return
        end local 1 // org.graalvm.compiler.nodes.MergeNode falseMerge
        end local 0 // org.graalvm.compiler.nodes.AbstractBeginNode successor
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    7     0     successor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            0    7     1    falseMerge  Lorg/graalvm/compiler/nodes/MergeNode;
            2    6     2  loopExitNode  Lorg/graalvm/compiler/nodes/LoopExitNode;
            4    5     3         proxy  Lorg/graalvm/compiler/nodes/ProxyNode;
    MethodParameters:
            Name  Flags
      successor   
      falseMerge  

  private void cleanupMerge(org.graalvm.compiler.graph.spi.SimplifierTool, org.graalvm.compiler.nodes.MergeNode);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/MergeNode;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        start local 2 // org.graalvm.compiler.nodes.MergeNode merge
         0: .line 842
            aload 2 /* merge */
            ifnull 6
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.isAlive:()Z
            ifeq 6
         1: .line 843
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.forwardEndCount:()I
            ifne 4
         2: .line 844
            aload 2 /* merge */
            aload 1 /* tool */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
         3: .line 845
            goto 6
      StackMap locals:
      StackMap stack:
         4: aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.forwardEndCount:()I
            iconst_1
            if_icmpne 6
         5: .line 846
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.reduceTrivialMerge:(Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
         6: .line 849
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.graalvm.compiler.nodes.MergeNode merge
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   this  Lorg/graalvm/compiler/nodes/IfNode;
            0    7     1   tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            0    7     2  merge  Lorg/graalvm/compiler/nodes/MergeNode;
    MethodParameters:
       Name  Flags
      tool   
      merge  

  private org.graalvm.compiler.nodes.MergeNode insertMerge(org.graalvm.compiler.nodes.AbstractBeginNode);
    descriptor: (Lorg/graalvm/compiler/nodes/AbstractBeginNode;)Lorg/graalvm/compiler/nodes/MergeNode;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.AbstractBeginNode begin
         0: .line 852
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.MergeNode
            dup
            invokespecial org.graalvm.compiler.nodes.MergeNode.<init>:()V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.MergeNode
            astore 2 /* merge */
        start local 2 // org.graalvm.compiler.nodes.MergeNode merge
         1: .line 853
            aload 1 /* begin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.anchored:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isEmpty:()Z
            ifne 7
         2: .line 854
            aconst_null
            astore 3 /* before */
        start local 3 // java.lang.Object before
         3: .line 855
            aload 1 /* begin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.anchored:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.snapshot:()Ljava/util/List;
            astore 3 /* before */
         4: .line 856
            aload 1 /* begin */
            getstatic org.graalvm.compiler.nodeinfo.InputType.Guard:Lorg/graalvm/compiler/nodeinfo/InputType;
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.replaceAtUsages:(Lorg/graalvm/compiler/nodeinfo/InputType;Lorg/graalvm/compiler/graph/Node;)V
         5: .line 857
            aload 1 /* begin */
            getstatic org.graalvm.compiler.nodeinfo.InputType.Anchor:Lorg/graalvm/compiler/nodeinfo/InputType;
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.replaceAtUsages:(Lorg/graalvm/compiler/nodeinfo/InputType;Lorg/graalvm/compiler/graph/Node;)V
         6: .line 858
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 7
            aload 1 /* begin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.anchored:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isEmpty:()Z
            ifne 7
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 3 /* before */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* begin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.anchored:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.snapshot:()Ljava/util/List;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        end local 3 // java.lang.Object before
         7: .line 861
      StackMap locals: org.graalvm.compiler.nodes.MergeNode
      StackMap stack:
            aload 1 /* begin */
            astore 3 /* theBegin */
        start local 3 // org.graalvm.compiler.nodes.AbstractBeginNode theBegin
         8: .line 862
            aload 1 /* begin */
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 12
         9: .line 864
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.BeginNode
            dup
            invokespecial org.graalvm.compiler.nodes.BeginNode.<init>:()V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.AbstractBeginNode
            astore 3 /* theBegin */
        10: .line 865
            aload 1 /* begin */
            aload 3 /* theBegin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        11: .line 866
            aload 3 /* theBegin */
            aload 1 /* begin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        12: .line 868
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack:
            aload 3 /* theBegin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            astore 4 /* next */
        start local 4 // org.graalvm.compiler.nodes.FixedNode next
        13: .line 869
            aload 4 /* next */
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.FixedNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        14: .line 870
            aload 3 /* theBegin */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.EndNode
            dup
            invokespecial org.graalvm.compiler.nodes.EndNode.<init>:()V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.FixedNode
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        15: .line 871
            aload 2 /* merge */
            aload 3 /* theBegin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            checkcast org.graalvm.compiler.nodes.EndNode
            invokevirtual org.graalvm.compiler.nodes.MergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        16: .line 872
            aload 2 /* merge */
            aload 4 /* next */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        17: .line 873
            aload 2 /* merge */
            areturn
        end local 4 // org.graalvm.compiler.nodes.FixedNode next
        end local 3 // org.graalvm.compiler.nodes.AbstractBeginNode theBegin
        end local 2 // org.graalvm.compiler.nodes.MergeNode merge
        end local 1 // org.graalvm.compiler.nodes.AbstractBeginNode begin
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   18     0      this  Lorg/graalvm/compiler/nodes/IfNode;
            0   18     1     begin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            1   18     2     merge  Lorg/graalvm/compiler/nodes/MergeNode;
            3    7     3    before  Ljava/lang/Object;
            8   18     3  theBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           13   18     4      next  Lorg/graalvm/compiler/nodes/FixedNode;
    MethodParameters:
       Name  Flags
      begin  

  private boolean removeIntermediateMaterialization(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=19, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 922
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            instanceof org.graalvm.compiler.nodes.AbstractMergeNode
            ifeq 1
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            instanceof org.graalvm.compiler.nodes.LoopBeginNode
            ifeq 2
         1: .line 923
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         2: .line 925
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.AbstractMergeNode
            astore 2 /* merge */
        start local 2 // org.graalvm.compiler.nodes.AbstractMergeNode merge
         3: .line 927
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.CompareNode
            ifne 5
         4: .line 928
            iconst_0
            ireturn
         5: .line 931
      StackMap locals: org.graalvm.compiler.nodes.AbstractMergeNode
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.CompareNode
            astore 3 /* compare */
        start local 3 // org.graalvm.compiler.nodes.calc.CompareNode compare
         6: .line 932
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getUsageCount:()I
            iconst_1
            if_icmpeq 8
         7: .line 933
            iconst_0
            ireturn
         8: .line 938
      StackMap locals: org.graalvm.compiler.nodes.calc.CompareNode
      StackMap stack:
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            astore 4 /* mergeUsages */
        start local 4 // org.graalvm.compiler.graph.iterators.NodeIterable mergeUsages
         9: .line 939
            aload 4 /* mergeUsages */
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_1
            if_icmpeq 11
        10: .line 940
            iconst_0
            ireturn
        11: .line 942
      StackMap locals: org.graalvm.compiler.graph.iterators.NodeIterable
      StackMap stack:
            aload 4 /* mergeUsages */
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.first:()Lorg/graalvm/compiler/graph/Node;
            astore 5 /* singleUsage */
        start local 5 // org.graalvm.compiler.graph.Node singleUsage
        12: .line 943
            aload 5 /* singleUsage */
            instanceof org.graalvm.compiler.nodes.ValuePhiNode
            ifeq 13
            aload 5 /* singleUsage */
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpeq 14
            aload 5 /* singleUsage */
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpeq 14
        13: .line 944
      StackMap locals: org.graalvm.compiler.graph.Node
      StackMap stack:
            iconst_0
            ireturn
        14: .line 948
      StackMap locals:
      StackMap stack:
            aload 5 /* singleUsage */
            checkcast org.graalvm.compiler.nodes.ValuePhiNode
            astore 6 /* phi */
        start local 6 // org.graalvm.compiler.nodes.ValuePhiNode phi
        15: .line 949
            aload 6 /* phi */
            invokevirtual org.graalvm.compiler.nodes.ValuePhiNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            astore 7 /* phiUsages */
        start local 7 // org.graalvm.compiler.graph.iterators.NodeIterable phiUsages
        16: .line 950
            aload 7 /* phiUsages */
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_2
            if_icmple 18
        17: .line 951
            iconst_0
            ireturn
        18: .line 953
      StackMap locals: org.graalvm.compiler.nodes.ValuePhiNode org.graalvm.compiler.graph.iterators.NodeIterable
      StackMap stack:
            aload 7 /* phiUsages */
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 9
            goto 22
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.calc.CompareNode org.graalvm.compiler.graph.iterators.NodeIterable org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.ValuePhiNode org.graalvm.compiler.graph.iterators.NodeIterable top java.util.Iterator
      StackMap stack:
        19: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 8 /* usage */
        start local 8 // org.graalvm.compiler.graph.Node usage
        20: .line 954
            aload 8 /* usage */
            aload 3 /* compare */
            if_acmpeq 22
            aload 8 /* usage */
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            if_acmpeq 22
        21: .line 955
            iconst_0
            ireturn
        end local 8 // org.graalvm.compiler.graph.Node usage
        22: .line 953
      StackMap locals:
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 19
        23: .line 959
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.cfgPredecessors:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.snapshot:()Ljava/util/List;
            astore 8 /* mergePredecessors */
        start local 8 // java.util.List mergePredecessors
        24: .line 960
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 25
            aload 6 /* phi */
            invokevirtual org.graalvm.compiler.nodes.ValuePhiNode.valueCount:()I
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndCount:()I
            if_icmpeq 25
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        25: .line 962
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.calc.CompareNode org.graalvm.compiler.graph.iterators.NodeIterable org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.ValuePhiNode org.graalvm.compiler.graph.iterators.NodeIterable java.util.List
      StackMap stack:
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* merge */
            iconst_0
            invokestatic org.graalvm.compiler.nodes.IfNode.constantValues:(Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Z)[Ljdk/vm/ci/meta/Constant;
            astore 9 /* xs */
        start local 9 // jdk.vm.ci.meta.Constant[] xs
        26: .line 963
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* merge */
            iconst_0
            invokestatic org.graalvm.compiler.nodes.IfNode.constantValues:(Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Z)[Ljdk/vm/ci/meta/Constant;
            astore 10 /* ys */
        start local 10 // jdk.vm.ci.meta.Constant[] ys
        27: .line 964
            aload 9 /* xs */
            ifnull 28
            aload 10 /* ys */
            ifnonnull 29
        28: .line 965
      StackMap locals: jdk.vm.ci.meta.Constant[] jdk.vm.ci.meta.Constant[]
      StackMap stack:
            iconst_0
            ireturn
        29: .line 969
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.checkFrameState:(Lorg/graalvm/compiler/nodes/FixedNode;)Z
            ifne 31
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.checkFrameState:(Lorg/graalvm/compiler/nodes/FixedNode;)Z
            ifne 31
        30: .line 970
            iconst_0
            ireturn
        31: .line 973
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            aload 8 /* mergePredecessors */
            invokeinterface java.util.List.size:()I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 11 /* falseEnds */
        start local 11 // java.util.List falseEnds
        32: .line 974
            new java.util.ArrayList
            dup
            aload 8 /* mergePredecessors */
            invokeinterface java.util.List.size:()I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 12 /* trueEnds */
        start local 12 // java.util.List trueEnds
        33: .line 975
            aload 8 /* mergePredecessors */
            invokeinterface java.util.List.size:()I
            invokestatic org.graalvm.compiler.core.common.CollectionsFactory.newMap:(I)Ljava/util/HashMap;
            astore 13 /* phiValues */
        start local 13 // java.util.Map phiValues
        34: .line 977
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 14 /* oldFalseSuccessor */
        start local 14 // org.graalvm.compiler.nodes.AbstractBeginNode oldFalseSuccessor
        35: .line 978
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 15 /* oldTrueSuccessor */
        start local 15 // org.graalvm.compiler.nodes.AbstractBeginNode oldTrueSuccessor
        36: .line 980
            aload 0 /* this */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        37: .line 981
            aload 0 /* this */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        38: .line 983
            aload 8 /* mergePredecessors */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 16 /* ends */
        start local 16 // java.util.Iterator ends
        39: .line 984
            iconst_0
            istore 17 /* i */
        start local 17 // int i
        40: goto 48
        41: .line 985
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.calc.CompareNode org.graalvm.compiler.graph.iterators.NodeIterable org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.ValuePhiNode org.graalvm.compiler.graph.iterators.NodeIterable java.util.List jdk.vm.ci.meta.Constant[] jdk.vm.ci.meta.Constant[] java.util.List java.util.List java.util.Map org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode java.util.Iterator int
      StackMap stack:
            aload 16 /* ends */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 18 /* end */
        start local 18 // org.graalvm.compiler.nodes.EndNode end
        42: .line 986
            aload 13 /* phiValues */
            aload 18 /* end */
            aload 6 /* phi */
            aload 18 /* end */
            invokevirtual org.graalvm.compiler.nodes.ValuePhiNode.valueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        43: .line 987
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.condition:()Lorg/graalvm/compiler/core/common/calc/Condition;
            aload 9 /* xs */
            iload 17 /* i */
            aaload
            aload 10 /* ys */
            iload 17 /* i */
            aaload
            aload 1 /* tool */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.getConstantReflection:()Ljdk/vm/ci/meta/ConstantReflectionProvider;
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.unorderedIsTrue:()Z
            invokevirtual org.graalvm.compiler.core.common.calc.Condition.foldCondition:(Ljdk/vm/ci/meta/Constant;Ljdk/vm/ci/meta/Constant;Ljdk/vm/ci/meta/ConstantReflectionProvider;Z)Z
            ifeq 46
        44: .line 988
            aload 12 /* trueEnds */
            aload 18 /* end */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        45: .line 989
            goto 47
        46: .line 990
      StackMap locals: org.graalvm.compiler.nodes.EndNode
      StackMap stack:
            aload 11 /* falseEnds */
            aload 18 /* end */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 18 // org.graalvm.compiler.nodes.EndNode end
        47: .line 984
      StackMap locals:
      StackMap stack:
            iinc 17 /* i */ 1
      StackMap locals:
      StackMap stack:
        48: iload 17 /* i */
            aload 9 /* xs */
            arraylength
            if_icmplt 41
        end local 17 // int i
        49: .line 993
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 50
            aload 16 /* ends */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifeq 50
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        50: .line 994
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 51
            aload 11 /* falseEnds */
            invokeinterface java.util.List.size:()I
            aload 12 /* trueEnds */
            invokeinterface java.util.List.size:()I
            iadd
            aload 9 /* xs */
            arraylength
            if_icmpeq 51
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        51: .line 996
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 11 /* falseEnds */
            aload 13 /* phiValues */
            aload 14 /* oldFalseSuccessor */
            aload 2 /* merge */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.connectEnds:(Ljava/util/List;Ljava/util/Map;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        52: .line 997
            aload 0 /* this */
            aload 12 /* trueEnds */
            aload 13 /* phiValues */
            aload 15 /* oldTrueSuccessor */
            aload 2 /* merge */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.connectEnds:(Ljava/util/List;Ljava/util/Map;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        53: .line 999
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_0
            dcmpl
            ifne 58
        54: .line 1000
            aload 12 /* trueEnds */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 18
            goto 57
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.calc.CompareNode org.graalvm.compiler.graph.iterators.NodeIterable org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.ValuePhiNode org.graalvm.compiler.graph.iterators.NodeIterable java.util.List jdk.vm.ci.meta.Constant[] jdk.vm.ci.meta.Constant[] java.util.List java.util.List java.util.Map org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode java.util.Iterator top java.util.Iterator
      StackMap stack:
        55: aload 18
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 17 /* endNode */
        start local 17 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        56: .line 1001
            aload 0 /* this */
            aload 17 /* endNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.propagateZeroProbability:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        end local 17 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        57: .line 1000
      StackMap locals:
      StackMap stack:
            aload 18
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 55
        58: .line 1005
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.calc.CompareNode org.graalvm.compiler.graph.iterators.NodeIterable org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.ValuePhiNode org.graalvm.compiler.graph.iterators.NodeIterable java.util.List jdk.vm.ci.meta.Constant[] jdk.vm.ci.meta.Constant[] java.util.List java.util.List java.util.Map org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_1
            dcmpl
            ifne 63
        59: .line 1006
            aload 11 /* falseEnds */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 18
            goto 62
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.calc.CompareNode org.graalvm.compiler.graph.iterators.NodeIterable org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.ValuePhiNode org.graalvm.compiler.graph.iterators.NodeIterable java.util.List jdk.vm.ci.meta.Constant[] jdk.vm.ci.meta.Constant[] java.util.List java.util.List java.util.Map org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode java.util.Iterator top java.util.Iterator
      StackMap stack:
        60: aload 18
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 17 /* endNode */
        start local 17 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        61: .line 1007
            aload 0 /* this */
            aload 17 /* endNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.propagateZeroProbability:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        end local 17 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        62: .line 1006
      StackMap locals:
      StackMap stack:
            aload 18
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 60
        63: .line 1015
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.calc.CompareNode org.graalvm.compiler.graph.iterators.NodeIterable org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.ValuePhiNode org.graalvm.compiler.graph.iterators.NodeIterable java.util.List jdk.vm.ci.meta.Constant[] jdk.vm.ci.meta.Constant[] java.util.List java.util.List java.util.Map org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode java.util.Iterator
      StackMap stack:
            aload 11 /* falseEnds */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 65
        64: .line 1016
            aload 14 /* oldFalseSuccessor */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        65: .line 1018
      StackMap locals:
      StackMap stack:
            aload 12 /* trueEnds */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 67
        66: .line 1019
            aload 15 /* oldTrueSuccessor */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        67: .line 1021
      StackMap locals:
      StackMap stack:
            aload 2 /* merge */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        68: .line 1023
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 69
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.isAlive:()Z
            ifeq 69
            new java.lang.AssertionError
            dup
            aload 2 /* merge */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        69: .line 1024
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 70
            aload 6 /* phi */
            invokevirtual org.graalvm.compiler.nodes.ValuePhiNode.isAlive:()Z
            ifeq 70
            new java.lang.AssertionError
            dup
            aload 6 /* phi */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        70: .line 1025
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 71
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.isAlive:()Z
            ifeq 71
            new java.lang.AssertionError
            dup
            aload 3 /* compare */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        71: .line 1026
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 72
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.isAlive:()Z
            ifeq 72
            new java.lang.AssertionError
            dup
            aload 0 /* this */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        72: .line 1028
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 16 // java.util.Iterator ends
        end local 15 // org.graalvm.compiler.nodes.AbstractBeginNode oldTrueSuccessor
        end local 14 // org.graalvm.compiler.nodes.AbstractBeginNode oldFalseSuccessor
        end local 13 // java.util.Map phiValues
        end local 12 // java.util.List trueEnds
        end local 11 // java.util.List falseEnds
        end local 10 // jdk.vm.ci.meta.Constant[] ys
        end local 9 // jdk.vm.ci.meta.Constant[] xs
        end local 8 // java.util.List mergePredecessors
        end local 7 // org.graalvm.compiler.graph.iterators.NodeIterable phiUsages
        end local 6 // org.graalvm.compiler.nodes.ValuePhiNode phi
        end local 5 // org.graalvm.compiler.graph.Node singleUsage
        end local 4 // org.graalvm.compiler.graph.iterators.NodeIterable mergeUsages
        end local 3 // org.graalvm.compiler.nodes.calc.CompareNode compare
        end local 2 // org.graalvm.compiler.nodes.AbstractMergeNode merge
        end local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   73     0               this  Lorg/graalvm/compiler/nodes/IfNode;
            0   73     1               tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            3   73     2              merge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            6   73     3            compare  Lorg/graalvm/compiler/nodes/calc/CompareNode;
            9   73     4        mergeUsages  Lorg/graalvm/compiler/graph/iterators/NodeIterable<Lorg/graalvm/compiler/graph/Node;>;
           12   73     5        singleUsage  Lorg/graalvm/compiler/graph/Node;
           15   73     6                phi  Lorg/graalvm/compiler/nodes/ValuePhiNode;
           16   73     7          phiUsages  Lorg/graalvm/compiler/graph/iterators/NodeIterable<Lorg/graalvm/compiler/graph/Node;>;
           20   22     8              usage  Lorg/graalvm/compiler/graph/Node;
           24   73     8  mergePredecessors  Ljava/util/List<Lorg/graalvm/compiler/nodes/EndNode;>;
           26   73     9                 xs  [Ljdk/vm/ci/meta/Constant;
           27   73    10                 ys  [Ljdk/vm/ci/meta/Constant;
           32   73    11          falseEnds  Ljava/util/List<Lorg/graalvm/compiler/nodes/EndNode;>;
           33   73    12           trueEnds  Ljava/util/List<Lorg/graalvm/compiler/nodes/EndNode;>;
           34   73    13          phiValues  Ljava/util/Map<Lorg/graalvm/compiler/nodes/AbstractEndNode;Lorg/graalvm/compiler/nodes/ValueNode;>;
           35   73    14  oldFalseSuccessor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           36   73    15   oldTrueSuccessor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           39   73    16               ends  Ljava/util/Iterator<Lorg/graalvm/compiler/nodes/EndNode;>;
           40   49    17                  i  I
           42   47    18                end  Lorg/graalvm/compiler/nodes/EndNode;
           56   57    17            endNode  Lorg/graalvm/compiler/nodes/AbstractEndNode;
           61   62    17            endNode  Lorg/graalvm/compiler/nodes/AbstractEndNode;
    MethodParameters:
      Name  Flags
      tool  

  private void propagateZeroProbability(org.graalvm.compiler.nodes.FixedNode);
    descriptor: (Lorg/graalvm/compiler/nodes/FixedNode;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.FixedNode startNode
         0: .line 1032
            aconst_null
            astore 2 /* prev */
        start local 2 // org.graalvm.compiler.graph.Node prev
         1: .line 1033
            aload 1 /* startNode */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.predecessorIterable:(Lorg/graalvm/compiler/nodes/FixedNode;)Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 4
            goto 27
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.FixedNode org.graalvm.compiler.graph.Node top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.FixedNode
            astore 3 /* node */
        start local 3 // org.graalvm.compiler.nodes.FixedNode node
         3: .line 1034
            aload 3 /* node */
            instanceof org.graalvm.compiler.nodes.IfNode
            ifeq 20
         4: .line 1035
            aload 3 /* node */
            checkcast org.graalvm.compiler.nodes.IfNode
            astore 5 /* ifNode */
        start local 5 // org.graalvm.compiler.nodes.IfNode ifNode
         5: .line 1036
            aload 5 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 2 /* prev */
            if_acmpne 12
         6: .line 1037
            aload 5 /* ifNode */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_0
            dcmpl
            ifne 8
         7: .line 1038
            return
         8: .line 1039
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.FixedNode org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.FixedNode java.util.Iterator org.graalvm.compiler.nodes.IfNode
      StackMap stack:
            aload 5 /* ifNode */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_1
            dcmpl
            ifne 10
         9: .line 1040
            goto 27
        10: .line 1042
      StackMap locals:
      StackMap stack:
            aload 5 /* ifNode */
            dconst_0
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        11: .line 1043
            return
        12: .line 1045
      StackMap locals:
      StackMap stack:
            aload 5 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 2 /* prev */
            if_acmpne 19
        13: .line 1046
            aload 5 /* ifNode */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_1
            dcmpl
            ifne 15
        14: .line 1047
            return
        15: .line 1048
      StackMap locals:
      StackMap stack:
            aload 5 /* ifNode */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_0
            dcmpl
            ifne 17
        16: .line 1049
            goto 27
        17: .line 1051
      StackMap locals:
      StackMap stack:
            aload 5 /* ifNode */
            dconst_1
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        18: .line 1052
            return
        19: .line 1055
      StackMap locals:
      StackMap stack:
            new org.graalvm.compiler.debug.GraalError
            dup
            ldc "Illegal state"
            invokespecial org.graalvm.compiler.debug.GraalError.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // org.graalvm.compiler.nodes.IfNode ifNode
        20: .line 1057
      StackMap locals:
      StackMap stack:
            aload 3 /* node */
            instanceof org.graalvm.compiler.nodes.AbstractMergeNode
            ifeq 26
            aload 3 /* node */
            instanceof org.graalvm.compiler.nodes.LoopBeginNode
            ifne 26
        21: .line 1058
            aload 3 /* node */
            checkcast org.graalvm.compiler.nodes.AbstractMergeNode
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.cfgPredecessors:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 6
            goto 24
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.FixedNode org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.FixedNode java.util.Iterator top java.util.Iterator
      StackMap stack:
        22: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 5 /* endNode */
        start local 5 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        23: .line 1059
            aload 0 /* this */
            aload 5 /* endNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.propagateZeroProbability:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        end local 5 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        24: .line 1058
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 22
        25: .line 1061
            return
        26: .line 1063
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.FixedNode org.graalvm.compiler.graph.Node org.graalvm.compiler.nodes.FixedNode java.util.Iterator
      StackMap stack:
            aload 3 /* node */
            astore 2 /* prev */
        end local 3 // org.graalvm.compiler.nodes.FixedNode node
        27: .line 1033
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.FixedNode org.graalvm.compiler.graph.Node top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        28: .line 1065
            return
        end local 2 // org.graalvm.compiler.graph.Node prev
        end local 1 // org.graalvm.compiler.nodes.FixedNode startNode
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   29     0       this  Lorg/graalvm/compiler/nodes/IfNode;
            0   29     1  startNode  Lorg/graalvm/compiler/nodes/FixedNode;
            1   29     2       prev  Lorg/graalvm/compiler/graph/Node;
            3   27     3       node  Lorg/graalvm/compiler/nodes/FixedNode;
            5   20     5     ifNode  Lorg/graalvm/compiler/nodes/IfNode;
           23   24     5    endNode  Lorg/graalvm/compiler/nodes/AbstractEndNode;
    MethodParameters:
           Name  Flags
      startNode  

  private static boolean checkFrameState(org.graalvm.compiler.nodes.FixedNode);
    descriptor: (Lorg/graalvm/compiler/nodes/FixedNode;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=5, args_size=1
        start local 0 // org.graalvm.compiler.nodes.FixedNode start
         0: .line 1068
            aload 0 /* start */
            astore 1 /* node */
        start local 1 // org.graalvm.compiler.nodes.FixedNode node
         1: .line 1070
      StackMap locals: org.graalvm.compiler.nodes.FixedNode
      StackMap stack:
            aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.AbstractMergeNode
            ifeq 6
         2: .line 1071
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.AbstractMergeNode
            astore 2 /* mergeNode */
        start local 2 // org.graalvm.compiler.nodes.AbstractMergeNode mergeNode
         3: .line 1072
            aload 2 /* mergeNode */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnonnull 5
         4: .line 1073
            iconst_0
            ireturn
         5: .line 1075
      StackMap locals: org.graalvm.compiler.nodes.AbstractMergeNode
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // org.graalvm.compiler.nodes.AbstractMergeNode mergeNode
         6: .line 1077
      StackMap locals:
      StackMap stack:
            aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.StateSplit
            ifeq 10
         7: .line 1078
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.StateSplit
            astore 2 /* stateSplitNode */
        start local 2 // org.graalvm.compiler.nodes.StateSplit stateSplitNode
         8: .line 1079
            aload 2 /* stateSplitNode */
            invokeinterface org.graalvm.compiler.nodes.StateSplit.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnull 10
         9: .line 1080
            iconst_1
            ireturn
        end local 2 // org.graalvm.compiler.nodes.StateSplit stateSplitNode
        10: .line 1084
      StackMap locals:
      StackMap stack:
            aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.ControlSplitNode
            ifeq 18
        11: .line 1085
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.ControlSplitNode
            astore 2 /* controlSplitNode */
        start local 2 // org.graalvm.compiler.nodes.ControlSplitNode controlSplitNode
        12: .line 1086
            aload 2 /* controlSplitNode */
            invokevirtual org.graalvm.compiler.nodes.ControlSplitNode.cfgSuccessors:()Ljava/lang/Iterable;
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 4
            goto 16
      StackMap locals: org.graalvm.compiler.nodes.FixedNode org.graalvm.compiler.nodes.FixedNode org.graalvm.compiler.nodes.ControlSplitNode top java.util.Iterator
      StackMap stack:
        13: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.graph.Node
            astore 3 /* succ */
        start local 3 // org.graalvm.compiler.graph.Node succ
        14: .line 1087
            aload 3 /* succ */
            checkcast org.graalvm.compiler.nodes.FixedNode
            invokestatic org.graalvm.compiler.nodes.IfNode.checkFrameState:(Lorg/graalvm/compiler/nodes/FixedNode;)Z
            ifeq 16
        15: .line 1088
            iconst_1
            ireturn
        end local 3 // org.graalvm.compiler.graph.Node succ
        16: .line 1086
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        17: .line 1091
            iconst_0
            ireturn
        end local 2 // org.graalvm.compiler.nodes.ControlSplitNode controlSplitNode
        18: .line 1092
      StackMap locals: org.graalvm.compiler.nodes.FixedNode org.graalvm.compiler.nodes.FixedNode
      StackMap stack:
            aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.FixedWithNextNode
            ifeq 22
        19: .line 1093
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.FixedWithNextNode
            astore 2 /* fixedWithNextNode */
        start local 2 // org.graalvm.compiler.nodes.FixedWithNextNode fixedWithNextNode
        20: .line 1094
            aload 2 /* fixedWithNextNode */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            astore 1 /* node */
        end local 2 // org.graalvm.compiler.nodes.FixedWithNextNode fixedWithNextNode
        21: .line 1095
            goto 1
      StackMap locals:
      StackMap stack:
        22: aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.AbstractEndNode
            ifeq 26
        23: .line 1096
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 2 /* endNode */
        start local 2 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        24: .line 1097
            aload 2 /* endNode */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            astore 1 /* node */
        end local 2 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        25: .line 1098
            goto 1
      StackMap locals:
      StackMap stack:
        26: aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.ControlSinkNode
            ifeq 28
        27: .line 1099
            iconst_1
            ireturn
        28: .line 1101
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // org.graalvm.compiler.nodes.FixedNode node
        end local 0 // org.graalvm.compiler.nodes.FixedNode start
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   29     0              start  Lorg/graalvm/compiler/nodes/FixedNode;
            1   29     1               node  Lorg/graalvm/compiler/nodes/FixedNode;
            3    6     2          mergeNode  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            8   10     2     stateSplitNode  Lorg/graalvm/compiler/nodes/StateSplit;
           12   18     2   controlSplitNode  Lorg/graalvm/compiler/nodes/ControlSplitNode;
           14   16     3               succ  Lorg/graalvm/compiler/graph/Node;
           20   21     2  fixedWithNextNode  Lorg/graalvm/compiler/nodes/FixedWithNextNode;
           24   25     2            endNode  Lorg/graalvm/compiler/nodes/AbstractEndNode;
    MethodParameters:
       Name  Flags
      start  

  private void connectEnds(java.util.List<org.graalvm.compiler.nodes.EndNode>, java.util.Map<org.graalvm.compiler.nodes.AbstractEndNode, org.graalvm.compiler.nodes.ValueNode>, org.graalvm.compiler.nodes.AbstractBeginNode, org.graalvm.compiler.nodes.AbstractMergeNode, org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Ljava/util/List;Ljava/util/Map;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=11, args_size=6
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // java.util.List ends
        start local 2 // java.util.Map phiValues
        start local 3 // org.graalvm.compiler.nodes.AbstractBeginNode successor
        start local 4 // org.graalvm.compiler.nodes.AbstractMergeNode oldMerge
        start local 5 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 1115
            aload 1 /* ends */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 22
         1: .line 1116
            aload 1 /* ends */
            invokeinterface java.util.List.size:()I
            iconst_1
            if_icmpne 7
         2: .line 1117
            aload 1 /* ends */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 6 /* end */
        start local 6 // org.graalvm.compiler.nodes.AbstractEndNode end
         3: .line 1118
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.FixedWithNextNode
            aload 3 /* successor */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
         4: .line 1119
            aload 4 /* oldMerge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.removeEnd:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)V
         5: .line 1120
            aload 6 /* end */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        end local 6 // org.graalvm.compiler.nodes.AbstractEndNode end
         6: .line 1121
            goto 21
         7: .line 1124
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.MergeNode
            dup
            invokespecial org.graalvm.compiler.nodes.MergeNode.<init>:()V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.AbstractMergeNode
            astore 6 /* newMerge */
        start local 6 // org.graalvm.compiler.nodes.AbstractMergeNode newMerge
         8: .line 1125
            aload 4 /* oldMerge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.first:()Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.PhiNode
            astore 7 /* oldPhi */
        start local 7 // org.graalvm.compiler.nodes.PhiNode oldPhi
         9: .line 1126
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.ValuePhiNode
            dup
            aload 7 /* oldPhi */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.stamp:()Lorg/graalvm/compiler/core/common/type/Stamp;
            aload 6 /* newMerge */
            invokespecial org.graalvm.compiler.nodes.ValuePhiNode.<init>:(Lorg/graalvm/compiler/core/common/type/Stamp;Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.addWithoutUnique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.PhiNode
            astore 8 /* newPhi */
        start local 8 // org.graalvm.compiler.nodes.PhiNode newPhi
        10: .line 1128
            aload 1 /* ends */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 10
            goto 14
      StackMap locals: org.graalvm.compiler.nodes.IfNode java.util.List java.util.Map org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.PhiNode top java.util.Iterator
      StackMap stack:
        11: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 9 /* end */
        start local 9 // org.graalvm.compiler.nodes.EndNode end
        12: .line 1129
            aload 8 /* newPhi */
            aload 2 /* phiValues */
            aload 9 /* end */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.ValueNode
            invokevirtual org.graalvm.compiler.nodes.PhiNode.addInput:(Lorg/graalvm/compiler/nodes/ValueNode;)V
        13: .line 1130
            aload 6 /* newMerge */
            aload 9 /* end */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        end local 9 // org.graalvm.compiler.nodes.EndNode end
        14: .line 1128
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        15: .line 1133
            aload 4 /* oldMerge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            astore 9 /* stateAfter */
        start local 9 // org.graalvm.compiler.nodes.FrameState stateAfter
        16: .line 1134
            aload 9 /* stateAfter */
            ifnull 20
        17: .line 1135
            aload 9 /* stateAfter */
            invokevirtual org.graalvm.compiler.nodes.FrameState.duplicate:()Lorg/graalvm/compiler/nodes/FrameState;
            astore 9 /* stateAfter */
        18: .line 1136
            aload 9 /* stateAfter */
            aload 7 /* oldPhi */
            aload 8 /* newPhi */
            invokevirtual org.graalvm.compiler.nodes.FrameState.replaceFirstInput:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)V
        19: .line 1137
            aload 6 /* newMerge */
            aload 9 /* stateAfter */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.setStateAfter:(Lorg/graalvm/compiler/nodes/FrameState;)V
        20: .line 1140
      StackMap locals: org.graalvm.compiler.nodes.IfNode java.util.List java.util.Map org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.FrameState
      StackMap stack:
            aload 6 /* newMerge */
            aload 3 /* successor */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        end local 9 // org.graalvm.compiler.nodes.FrameState stateAfter
        end local 8 // org.graalvm.compiler.nodes.PhiNode newPhi
        end local 7 // org.graalvm.compiler.nodes.PhiNode oldPhi
        end local 6 // org.graalvm.compiler.nodes.AbstractMergeNode newMerge
        21: .line 1142
      StackMap locals: org.graalvm.compiler.nodes.IfNode java.util.List java.util.Map org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.graph.spi.SimplifierTool
      StackMap stack:
            aload 5 /* tool */
            aload 3 /* successor */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.addToWorkList:(Lorg/graalvm/compiler/graph/Node;)V
        22: .line 1144
      StackMap locals:
      StackMap stack:
            return
        end local 5 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        end local 4 // org.graalvm.compiler.nodes.AbstractMergeNode oldMerge
        end local 3 // org.graalvm.compiler.nodes.AbstractBeginNode successor
        end local 2 // java.util.Map phiValues
        end local 1 // java.util.List ends
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   23     0        this  Lorg/graalvm/compiler/nodes/IfNode;
            0   23     1        ends  Ljava/util/List<Lorg/graalvm/compiler/nodes/EndNode;>;
            0   23     2   phiValues  Ljava/util/Map<Lorg/graalvm/compiler/nodes/AbstractEndNode;Lorg/graalvm/compiler/nodes/ValueNode;>;
            0   23     3   successor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            0   23     4    oldMerge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            0   23     5        tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            3    6     6         end  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            8   21     6    newMerge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            9   21     7      oldPhi  Lorg/graalvm/compiler/nodes/PhiNode;
           10   21     8      newPhi  Lorg/graalvm/compiler/nodes/PhiNode;
           12   14     9         end  Lorg/graalvm/compiler/nodes/EndNode;
           16   21     9  stateAfter  Lorg/graalvm/compiler/nodes/FrameState;
    Signature: (Ljava/util/List<Lorg/graalvm/compiler/nodes/EndNode;>;Ljava/util/Map<Lorg/graalvm/compiler/nodes/AbstractEndNode;Lorg/graalvm/compiler/nodes/ValueNode;>;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
    MethodParameters:
           Name  Flags
      ends       
      phiValues  
      successor  
      oldMerge   
      tool       

  public static jdk.vm.ci.meta.Constant[] constantValues(org.graalvm.compiler.nodes.ValueNode, org.graalvm.compiler.nodes.AbstractMergeNode, boolean);
    descriptor: (Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Z)[Ljdk/vm/ci/meta/Constant;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=8, args_size=3
        start local 0 // org.graalvm.compiler.nodes.ValueNode node
        start local 1 // org.graalvm.compiler.nodes.AbstractMergeNode merge
        start local 2 // boolean allowNull
         0: .line 1155
            aload 0 /* node */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 4
         1: .line 1156
            aload 1 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndCount:()I
            anewarray jdk.vm.ci.meta.Constant
            astore 3 /* result */
        start local 3 // jdk.vm.ci.meta.Constant[] result
         2: .line 1157
            aload 3 /* result */
            aload 0 /* node */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asConstant:()Ljdk/vm/ci/meta/Constant;
            invokestatic java.util.Arrays.fill:([Ljava/lang/Object;Ljava/lang/Object;)V
         3: .line 1158
            aload 3 /* result */
            areturn
        end local 3 // jdk.vm.ci.meta.Constant[] result
         4: .line 1161
      StackMap locals:
      StackMap stack:
            aload 0 /* node */
            instanceof org.graalvm.compiler.nodes.PhiNode
            ifeq 16
         5: .line 1162
            aload 0 /* node */
            checkcast org.graalvm.compiler.nodes.PhiNode
            astore 3 /* phi */
        start local 3 // org.graalvm.compiler.nodes.PhiNode phi
         6: .line 1163
            aload 3 /* phi */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            aload 1 /* merge */
            if_acmpne 16
            aload 3 /* phi */
            instanceof org.graalvm.compiler.nodes.ValuePhiNode
            ifeq 16
            aload 3 /* phi */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.valueCount:()I
            aload 1 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndCount:()I
            if_icmpne 16
         7: .line 1164
            aload 1 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndCount:()I
            anewarray jdk.vm.ci.meta.Constant
            astore 4 /* result */
        start local 4 // jdk.vm.ci.meta.Constant[] result
         8: .line 1165
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         9: .line 1166
            aload 3 /* phi */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.values:()Lorg/graalvm/compiler/graph/NodeInputList;
            invokevirtual org.graalvm.compiler.graph.NodeInputList.iterator:()Ljava/util/Iterator;
            astore 7
            goto 14
      StackMap locals: org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.AbstractMergeNode int org.graalvm.compiler.nodes.PhiNode jdk.vm.ci.meta.Constant[] int top java.util.Iterator
      StackMap stack:
        10: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.ValueNode
            astore 6 /* n */
        start local 6 // org.graalvm.compiler.nodes.ValueNode n
        11: .line 1167
            iload 2 /* allowNull */
            ifne 13
            aload 6 /* n */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifne 13
        12: .line 1168
            aconst_null
            areturn
        13: .line 1170
      StackMap locals: org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.AbstractMergeNode int org.graalvm.compiler.nodes.PhiNode jdk.vm.ci.meta.Constant[] int org.graalvm.compiler.nodes.ValueNode java.util.Iterator
      StackMap stack:
            aload 4 /* result */
            iload 5 /* i */
            iinc 5 /* i */ 1
            aload 6 /* n */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asConstant:()Ljdk/vm/ci/meta/Constant;
            aastore
        end local 6 // org.graalvm.compiler.nodes.ValueNode n
        14: .line 1166
      StackMap locals: org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.AbstractMergeNode int org.graalvm.compiler.nodes.PhiNode jdk.vm.ci.meta.Constant[] int top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        15: .line 1172
            aload 4 /* result */
            areturn
        end local 5 // int i
        end local 4 // jdk.vm.ci.meta.Constant[] result
        end local 3 // org.graalvm.compiler.nodes.PhiNode phi
        16: .line 1176
      StackMap locals: org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.AbstractMergeNode int
      StackMap stack:
            aconst_null
            areturn
        end local 2 // boolean allowNull
        end local 1 // org.graalvm.compiler.nodes.AbstractMergeNode merge
        end local 0 // org.graalvm.compiler.nodes.ValueNode node
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   17     0       node  Lorg/graalvm/compiler/nodes/ValueNode;
            0   17     1      merge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            0   17     2  allowNull  Z
            2    4     3     result  [Ljdk/vm/ci/meta/Constant;
            6   16     3        phi  Lorg/graalvm/compiler/nodes/PhiNode;
            8   16     4     result  [Ljdk/vm/ci/meta/Constant;
            9   16     5          i  I
           11   14     6          n  Lorg/graalvm/compiler/nodes/ValueNode;
    MethodParameters:
           Name  Flags
      node       
      merge      
      allowNull  

  public org.graalvm.compiler.nodes.AbstractBeginNode getPrimarySuccessor();
    descriptor: ()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 1181
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            areturn
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/nodes/IfNode;

  public org.graalvm.compiler.nodes.AbstractBeginNode getSuccessor(boolean);
    descriptor: (Z)Lorg/graalvm/compiler/nodes/AbstractBeginNode;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // boolean result
         0: .line 1185
            iload 1 /* result */
            ifeq 1
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
      StackMap locals:
      StackMap stack: org.graalvm.compiler.nodes.AbstractBeginNode
         2: areturn
        end local 1 // boolean result
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/graalvm/compiler/nodes/IfNode;
            0    3     1  result  Z
    MethodParameters:
        Name  Flags
      result  
}
SourceFile: "IfNode.java"
InnerClasses:
  public abstract Input = org.graalvm.compiler.graph.Node$Input of org.graalvm.compiler.graph.Node
  public abstract Successor = org.graalvm.compiler.graph.Node$Successor of org.graalvm.compiler.graph.Node
  public abstract ValueNumberable = org.graalvm.compiler.graph.Node$ValueNumberable of org.graalvm.compiler.graph.Node
  public abstract Binary = org.graalvm.compiler.graph.spi.Canonicalizable$Binary of org.graalvm.compiler.graph.spi.Canonicalizable
  public abstract Unary = org.graalvm.compiler.graph.spi.Canonicalizable$Unary of org.graalvm.compiler.graph.spi.Canonicalizable
  public final GuardsStage = org.graalvm.compiler.nodes.StructuredGraph$GuardsStage of org.graalvm.compiler.nodes.StructuredGraph
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.nodeinfo.NodeInfo(cycles = org.graalvm.compiler.nodeinfo.NodeCycles.CYCLES_2:Lorg/graalvm/compiler/nodeinfo/NodeCycles;, size = org.graalvm.compiler.nodeinfo.NodeSize.SIZE_2:Lorg/graalvm/compiler/nodeinfo/NodeSize;, sizeRationale = "2 jmps")