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.CounterKey CORRECTED_PROBABILITIES;
    descriptor: Lorg/graalvm/compiler/debug/CounterKey;
    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 87
            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 88
            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 90
            ldc "CorrectedProbabilities"
            invokestatic org.graalvm.compiler.debug.DebugContext.counter:(Ljava/lang/CharSequence;)Lorg/graalvm/compiler/debug/CounterKey;
            putstatic org.graalvm.compiler.nodes.IfNode.CORRECTED_PROBABILITIES:Lorg/graalvm/compiler/debug/CounterKey;
            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 98
            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 102
            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 103
            aload 0 /* this */
            aload 1 /* x */
            putfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
         2: .line 104
            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 107
            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 108
            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 111
            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 112
            aload 0 /* this */
            aload 1 /* condition */
            putfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
         2: .line 113
            aload 0 /* this */
            aload 3 /* falseSuccessor */
            putfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         3: .line 114
            aload 0 /* this */
            aload 2 /* trueSuccessor */
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         4: .line 115
            aload 0 /* this */
            dload 4 /* trueSuccessorProbability */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
         5: .line 116
            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 124
            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 133
            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 137
            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 141
            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 142
            aload 0 /* this */
            aload 1 /* node */
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         2: .line 143
            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 146
            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 147
            aload 0 /* this */
            aload 1 /* node */
            putfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         2: .line 148
            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 157
            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 161
            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 162
      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 163
            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 167
            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 172
            aload 1 /* gen */
            aload 0 /* this */
            invokeinterface org.graalvm.compiler.nodes.spi.NodeLIRBuilderTool.emitIf:(Lorg/graalvm/compiler/nodes/IfNode;)V
         1: .line 173
            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 177
            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 178
            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 179
            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 180
            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;

  private boolean compareCallContext(org.graalvm.compiler.graph.NodeSourcePosition);
    descriptor: (Lorg/graalvm/compiler/graph/NodeSourcePosition;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.NodeSourcePosition successorPosition
         0: .line 184
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            astore 2 /* position */
        start local 2 // org.graalvm.compiler.graph.NodeSourcePosition position
         1: .line 185
            aload 1 /* successorPosition */
            astore 3 /* successor */
        start local 3 // org.graalvm.compiler.graph.NodeSourcePosition successor
         2: .line 186
            goto 6
         3: .line 187
      StackMap locals: org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack:
            aload 0 /* this */
            aload 2 /* position */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getMethod:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            aload 3 /* successor */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getMethod:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            invokestatic java.util.Objects.equals:(Ljava/lang/Object;Ljava/lang/Object;)Z
            ldc "method mismatch"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
         4: .line 188
            aload 2 /* position */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getCaller:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            astore 2 /* position */
         5: .line 189
            aload 3 /* successor */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getCaller:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            astore 3 /* successor */
         6: .line 186
      StackMap locals:
      StackMap stack:
            aload 2 /* position */
            ifnonnull 3
         7: .line 191
            aload 0 /* this */
            aload 3 /* successor */
            ifnonnull 8
            iconst_1
            goto 9
      StackMap locals:
      StackMap stack: org.graalvm.compiler.nodes.IfNode
         8: iconst_0
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack: org.graalvm.compiler.nodes.IfNode int
         9: ldc "successor position has more methods"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
        10: .line 192
            iconst_1
            ireturn
        end local 3 // org.graalvm.compiler.graph.NodeSourcePosition successor
        end local 2 // org.graalvm.compiler.graph.NodeSourcePosition position
        end local 1 // org.graalvm.compiler.graph.NodeSourcePosition successorPosition
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   11     0               this  Lorg/graalvm/compiler/nodes/IfNode;
            0   11     1  successorPosition  Lorg/graalvm/compiler/graph/NodeSourcePosition;
            1   11     2           position  Lorg/graalvm/compiler/graph/NodeSourcePosition;
            2   11     3          successor  Lorg/graalvm/compiler/graph/NodeSourcePosition;
    MethodParameters:
                   Name  Flags
      successorPosition  

  public boolean verifySourcePosition();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=11, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 197
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            astore 1 /* sourcePosition */
        start local 1 // org.graalvm.compiler.graph.NodeSourcePosition sourcePosition
         1: .line 198
            aload 0 /* this */
            aload 1 /* sourcePosition */
            ifnull 2
            iconst_1
            goto 3
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack: org.graalvm.compiler.nodes.IfNode
         2: iconst_0
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack: org.graalvm.compiler.nodes.IfNode int
         3: ldc "missing IfNode source position"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
         4: .line 200
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            astore 2 /* trueSuccessorPosition */
        start local 2 // org.graalvm.compiler.graph.NodeSourcePosition trueSuccessorPosition
         5: .line 201
            aload 0 /* this */
            aload 2 /* trueSuccessorPosition */
            ifnull 6
            iconst_1
            goto 7
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack: org.graalvm.compiler.nodes.IfNode
         6: iconst_0
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack: org.graalvm.compiler.nodes.IfNode int
         7: ldc "missing IfNode true successor source position"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
         8: .line 203
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            astore 3 /* falseSuccessorPosition */
        start local 3 // org.graalvm.compiler.graph.NodeSourcePosition falseSuccessorPosition
         9: .line 204
            aload 0 /* this */
            aload 3 /* falseSuccessorPosition */
            ifnull 10
            iconst_1
            goto 11
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack: org.graalvm.compiler.nodes.IfNode
        10: iconst_0
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack: org.graalvm.compiler.nodes.IfNode int
        11: ldc "missing IfNode false successor source position"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
        12: .line 206
            aload 1 /* sourcePosition */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getBCI:()I
            istore 4 /* bci */
        start local 4 // int bci
        13: .line 207
            aload 1 /* sourcePosition */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getMethod:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
            astore 5 /* method */
        start local 5 // jdk.vm.ci.meta.ResolvedJavaMethod method
        14: .line 208
            aload 5 /* method */
            iload 4 /* bci */
            invokestatic org.graalvm.compiler.bytecode.BytecodeDisassembler.getBytecodeAt:(Ljdk/vm/ci/meta/ResolvedJavaMethod;I)I
            istore 6 /* bytecode */
        start local 6 // int bytecode
        15: .line 210
            iload 6 /* bytecode */
            invokestatic org.graalvm.compiler.bytecode.Bytecodes.isIfBytecode:(I)Z
            ifne 17
        16: .line 211
            iconst_1
            ireturn
        17: .line 214
      StackMap locals: int jdk.vm.ci.meta.ResolvedJavaMethod int
      StackMap stack:
            new org.graalvm.compiler.bytecode.ResolvedJavaMethodBytecode
            dup
            aload 5 /* method */
            invokespecial org.graalvm.compiler.bytecode.ResolvedJavaMethodBytecode.<init>:(Ljdk/vm/ci/meta/ResolvedJavaMethod;)V
            invokevirtual org.graalvm.compiler.bytecode.ResolvedJavaMethodBytecode.getCode:()[B
            astore 7 /* code */
        start local 7 // byte[] code
        18: .line 215
            iload 4 /* bci */
            aload 7 /* code */
            iload 4 /* bci */
            iconst_1
            iadd
            invokestatic org.graalvm.compiler.bytecode.Bytes.beS2:([BI)I
            iadd
            istore 8 /* targetBCI */
        start local 8 // int targetBCI
        19: .line 216
            iload 4 /* bci */
            iload 6 /* bytecode */
            invokestatic org.graalvm.compiler.bytecode.Bytecodes.lengthOf:(I)I
            iadd
            istore 9 /* nextBCI */
        start local 9 // int nextBCI
        20: .line 220
            iconst_0
            istore 10 /* matchingSuccessorFound */
        start local 10 // boolean matchingSuccessorFound
        21: .line 221
            aload 2 /* trueSuccessorPosition */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getBCI:()I
            iload 9 /* nextBCI */
            if_icmpeq 22
            aload 2 /* trueSuccessorPosition */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getBCI:()I
            iload 8 /* targetBCI */
            if_icmpne 24
        22: .line 222
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition int jdk.vm.ci.meta.ResolvedJavaMethod int byte[] int int int
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 2 /* trueSuccessorPosition */
            invokevirtual org.graalvm.compiler.nodes.IfNode.compareCallContext:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)Z
            ldc "call context different from IfNode in trueSuccessor"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
        23: .line 223
            iconst_1
            istore 10 /* matchingSuccessorFound */
        24: .line 226
      StackMap locals:
      StackMap stack:
            aload 3 /* falseSuccessorPosition */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getBCI:()I
            iload 9 /* nextBCI */
            if_icmpeq 25
            aload 3 /* falseSuccessorPosition */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getBCI:()I
            iload 8 /* targetBCI */
            if_icmpne 27
        25: .line 227
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 3 /* falseSuccessorPosition */
            invokevirtual org.graalvm.compiler.nodes.IfNode.compareCallContext:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)Z
            ldc "call context different from IfNode in falseSuccessor"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
        26: .line 228
            iconst_1
            istore 10 /* matchingSuccessorFound */
        27: .line 231
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 10 /* matchingSuccessorFound */
            ldc "no matching successor position found in IfNode"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
        28: .line 232
            aload 0 /* this */
            aload 2 /* trueSuccessorPosition */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getBCI:()I
            aload 3 /* falseSuccessorPosition */
            invokevirtual org.graalvm.compiler.graph.NodeSourcePosition.getBCI:()I
            if_icmpeq 29
            iconst_1
            goto 30
      StackMap locals:
      StackMap stack: org.graalvm.compiler.nodes.IfNode
        29: iconst_0
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition org.graalvm.compiler.graph.NodeSourcePosition int jdk.vm.ci.meta.ResolvedJavaMethod int byte[] int int int
      StackMap stack: org.graalvm.compiler.nodes.IfNode int
        30: ldc "successor positions same in IfNode"
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.nodes.IfNode.assertTrue:(ZLjava/lang/String;[Ljava/lang/Object;)Z
            pop
        31: .line 234
            iconst_1
            ireturn
        end local 10 // boolean matchingSuccessorFound
        end local 9 // int nextBCI
        end local 8 // int targetBCI
        end local 7 // byte[] code
        end local 6 // int bytecode
        end local 5 // jdk.vm.ci.meta.ResolvedJavaMethod method
        end local 4 // int bci
        end local 3 // org.graalvm.compiler.graph.NodeSourcePosition falseSuccessorPosition
        end local 2 // org.graalvm.compiler.graph.NodeSourcePosition trueSuccessorPosition
        end local 1 // org.graalvm.compiler.graph.NodeSourcePosition sourcePosition
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0   32     0                    this  Lorg/graalvm/compiler/nodes/IfNode;
            1   32     1          sourcePosition  Lorg/graalvm/compiler/graph/NodeSourcePosition;
            5   32     2   trueSuccessorPosition  Lorg/graalvm/compiler/graph/NodeSourcePosition;
            9   32     3  falseSuccessorPosition  Lorg/graalvm/compiler/graph/NodeSourcePosition;
           13   32     4                     bci  I
           14   32     5                  method  Ljdk/vm/ci/meta/ResolvedJavaMethod;
           15   32     6                bytecode  I
           18   32     7                    code  [B
           19   32     8               targetBCI  I
           20   32     9                 nextBCI  I
           21   32    10  matchingSuccessorFound  Z

  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 238
            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 239
            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 240
            aload 0 /* this */
            aload 2 /* oldFalseSuccessor */
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         3: .line 241
            aload 0 /* this */
            aload 1 /* oldTrueSuccessor */
            putfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
         4: .line 242
            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 243
            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 244
            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=10, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 248
            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 249
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_0
            dcmpl
            ifeq 9
         2: .line 250
            getstatic org.graalvm.compiler.nodes.IfNode.CORRECTED_PROBABILITIES:Lorg/graalvm/compiler/debug/CounterKey;
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getDebug:()Lorg/graalvm/compiler/debug/DebugContext;
            invokeinterface org.graalvm.compiler.debug.CounterKey.increment:(Lorg/graalvm/compiler/debug/DebugContext;)V
         3: .line 251
            aload 0 /* this */
            dconst_0
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
         4: .line 253
            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 254
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_1
            dcmpl
            ifeq 9
         7: .line 255
            getstatic org.graalvm.compiler.nodes.IfNode.CORRECTED_PROBABILITIES:Lorg/graalvm/compiler/debug/CounterKey;
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getDebug:()Lorg/graalvm/compiler/debug/DebugContext;
            invokeinterface org.graalvm.compiler.debug.CounterKey.increment:(Lorg/graalvm/compiler/debug/DebugContext;)V
         8: .line 256
            aload 0 /* this */
            dconst_1
            putfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
         9: .line 260
      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 261
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.eliminateNegation:()V
        11: .line 263
      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 264
            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 265
            aload 2 /* c */
            invokevirtual org.graalvm.compiler.nodes.LogicConstantNode.getValue:()Z
            ifeq 18
        14: .line 266
            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 267
            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 268
            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 269
            goto 21
        18: .line 270
      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 271
            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 272
            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 274
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.graalvm.compiler.nodes.LogicConstantNode c
        22: .line 276
      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 278
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.pushNodesThroughIf:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        24: .line 280
            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 281
      StackMap locals:
      StackMap stack:
            return
        26: .line 285
      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 286
            return
        28: .line 289
      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 290
            return
        30: .line 293
      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 294
            return
        32: .line 297
      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 57
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifne 57
            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 57
        33: .line 298
            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 299
            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 300
            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 301
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dload 4 /* probabilityB */
            dcmpg
            ifge 57
        37: .line 304
            aload 1 /* tool */
            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:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/LogicNode;)Z
            ifeq 57
        38: .line 306
            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 307
      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 308
            aload 3 /* nextIf */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        41: .line 309
            aload 2 /* intermediateBegin */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        42: .line 310
            aload 0 /* this */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        43: .line 312
            aload 0 /* this */
            aload 3 /* nextIf */
            invokevirtual org.graalvm.compiler.nodes.IfNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        44: .line 313
            aload 3 /* nextIf */
            aload 2 /* intermediateBegin */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        45: .line 314
            aload 2 /* intermediateBegin */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        46: .line 315
            aload 0 /* this */
            aload 6 /* bothFalseBegin */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        47: .line 317
            aload 2 /* intermediateBegin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            astore 7 /* intermediateBeginPosition */
        start local 7 // org.graalvm.compiler.graph.NodeSourcePosition intermediateBeginPosition
        48: .line 318
            aload 2 /* intermediateBegin */
            aload 6 /* bothFalseBegin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        49: .line 319
            aload 6 /* bothFalseBegin */
            aload 7 /* intermediateBeginPosition */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        50: .line 321
            aload 3 /* nextIf */
            dload 4 /* probabilityB */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        51: .line 322
            dload 4 /* probabilityB */
            dconst_1
            dcmpl
            ifne 54
        52: .line 323
            aload 0 /* this */
            dconst_0
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        53: .line 324
            goto 56
        54: .line 325
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.graph.NodeSourcePosition
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_1
            dload 4 /* probabilityB */
            dsub
            ddiv
            dstore 8 /* newProbability */
        start local 8 // double newProbability
        55: .line 326
            aload 0 /* this */
            dconst_1
            dload 8 /* newProbability */
            invokestatic java.lang.Math.min:(DD)D
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        end local 8 // double newProbability
        56: .line 328
      StackMap locals:
      StackMap stack:
            return
        end local 7 // org.graalvm.compiler.graph.NodeSourcePosition intermediateBeginPosition
        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
        57: .line 333
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool
      StackMap stack:
            aload 0 /* this */
            aload 1 /* tool */
            invokevirtual org.graalvm.compiler.nodes.IfNode.tryEliminateBoxedReferenceEquals:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
            ifeq 59
        58: .line 334
            return
        59: .line 336
      StackMap locals:
      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   60     0                       this  Lorg/graalvm/compiler/nodes/IfNode;
            0   60     1                       tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
           13   22     2                          c  Lorg/graalvm/compiler/nodes/LogicConstantNode;
           34   57     2          intermediateBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           35   57     3                     nextIf  Lorg/graalvm/compiler/nodes/IfNode;
           36   57     4               probabilityB  D
           40   57     6             bothFalseBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           48   57     7  intermediateBeginPosition  Lorg/graalvm/compiler/graph/NodeSourcePosition;
           55   56     8             newProbability  D
    MethodParameters:
      Name  Flags
      tool  

  private boolean isUnboxedFrom(jdk.vm.ci.meta.MetaAccessProvider, org.graalvm.compiler.nodes.NodeView, org.graalvm.compiler.nodes.ValueNode, org.graalvm.compiler.nodes.ValueNode);
    descriptor: (Ljdk/vm/ci/meta/MetaAccessProvider;Lorg/graalvm/compiler/nodes/NodeView;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=7, args_size=5
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // jdk.vm.ci.meta.MetaAccessProvider meta
        start local 2 // org.graalvm.compiler.nodes.NodeView view
        start local 3 // org.graalvm.compiler.nodes.ValueNode x
        start local 4 // org.graalvm.compiler.nodes.ValueNode src
         0: .line 339
            aload 3 /* x */
            aload 4 /* src */
            if_acmpne 2
         1: .line 340
            iconst_1
            ireturn
         2: .line 341
      StackMap locals:
      StackMap stack:
            aload 3 /* x */
            instanceof org.graalvm.compiler.nodes.extended.UnboxNode
            ifeq 4
         3: .line 342
            aload 0 /* this */
            aload 1 /* meta */
            aload 2 /* view */
            aload 3 /* x */
            checkcast org.graalvm.compiler.nodes.extended.UnboxNode
            invokevirtual org.graalvm.compiler.nodes.extended.UnboxNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* src */
            invokevirtual org.graalvm.compiler.nodes.IfNode.isUnboxedFrom:(Ljdk/vm/ci/meta/MetaAccessProvider;Lorg/graalvm/compiler/nodes/NodeView;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ireturn
         4: .line 343
      StackMap locals:
      StackMap stack:
            aload 3 /* x */
            instanceof org.graalvm.compiler.nodes.PiNode
            ifeq 7
         5: .line 344
            aload 3 /* x */
            checkcast org.graalvm.compiler.nodes.PiNode
            astore 5 /* pi */
        start local 5 // org.graalvm.compiler.nodes.PiNode pi
         6: .line 345
            aload 0 /* this */
            aload 1 /* meta */
            aload 2 /* view */
            aload 5 /* pi */
            invokevirtual org.graalvm.compiler.nodes.PiNode.getOriginalNode:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* src */
            invokevirtual org.graalvm.compiler.nodes.IfNode.isUnboxedFrom:(Ljdk/vm/ci/meta/MetaAccessProvider;Lorg/graalvm/compiler/nodes/NodeView;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ireturn
        end local 5 // org.graalvm.compiler.nodes.PiNode pi
         7: .line 346
      StackMap locals:
      StackMap stack:
            aload 3 /* x */
            instanceof org.graalvm.compiler.nodes.java.LoadFieldNode
            ifeq 13
         8: .line 347
            aload 3 /* x */
            checkcast org.graalvm.compiler.nodes.java.LoadFieldNode
            astore 5 /* load */
        start local 5 // org.graalvm.compiler.nodes.java.LoadFieldNode load
         9: .line 348
            aload 1 /* meta */
            ldc Ljava/lang/Integer;
            invokeinterface jdk.vm.ci.meta.MetaAccessProvider.lookupJavaType:(Ljava/lang/Class;)Ljdk/vm/ci/meta/ResolvedJavaType;
            astore 6 /* integerType */
        start local 6 // jdk.vm.ci.meta.ResolvedJavaType integerType
        10: .line 349
            aload 5 /* load */
            invokevirtual org.graalvm.compiler.nodes.java.LoadFieldNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            aload 1 /* meta */
            invokevirtual org.graalvm.compiler.core.common.type.Stamp.javaType:(Ljdk/vm/ci/meta/MetaAccessProvider;)Ljdk/vm/ci/meta/ResolvedJavaType;
            aload 6 /* integerType */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 12
        11: .line 350
            aload 0 /* this */
            aload 1 /* meta */
            aload 2 /* view */
            aload 5 /* load */
            invokevirtual org.graalvm.compiler.nodes.java.LoadFieldNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* src */
            invokevirtual org.graalvm.compiler.nodes.IfNode.isUnboxedFrom:(Ljdk/vm/ci/meta/MetaAccessProvider;Lorg/graalvm/compiler/nodes/NodeView;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ireturn
        12: .line 352
      StackMap locals: org.graalvm.compiler.nodes.java.LoadFieldNode jdk.vm.ci.meta.ResolvedJavaType
      StackMap stack:
            iconst_0
            ireturn
        end local 6 // jdk.vm.ci.meta.ResolvedJavaType integerType
        end local 5 // org.graalvm.compiler.nodes.java.LoadFieldNode load
        13: .line 355
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // org.graalvm.compiler.nodes.ValueNode src
        end local 3 // org.graalvm.compiler.nodes.ValueNode x
        end local 2 // org.graalvm.compiler.nodes.NodeView view
        end local 1 // jdk.vm.ci.meta.MetaAccessProvider meta
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   14     0         this  Lorg/graalvm/compiler/nodes/IfNode;
            0   14     1         meta  Ljdk/vm/ci/meta/MetaAccessProvider;
            0   14     2         view  Lorg/graalvm/compiler/nodes/NodeView;
            0   14     3            x  Lorg/graalvm/compiler/nodes/ValueNode;
            0   14     4          src  Lorg/graalvm/compiler/nodes/ValueNode;
            6    7     5           pi  Lorg/graalvm/compiler/nodes/PiNode;
            9   13     5         load  Lorg/graalvm/compiler/nodes/java/LoadFieldNode;
           10   13     6  integerType  Ljdk/vm/ci/meta/ResolvedJavaType;
    MethodParameters:
      Name  Flags
      meta  
      view  
      x     
      src   

  private boolean tryEliminateBoxedReferenceEquals(org.graalvm.compiler.graph.spi.SimplifierTool);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=14, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 381
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.ObjectEqualsNode
            ifne 2
         1: .line 382
            iconst_0
            ireturn
         2: .line 385
      StackMap locals:
      StackMap stack:
            aload 1 /* tool */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.getMetaAccess:()Ljdk/vm/ci/meta/MetaAccessProvider;
            astore 2 /* meta */
        start local 2 // jdk.vm.ci.meta.MetaAccessProvider meta
         3: .line 386
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.ObjectEqualsNode
            astore 3 /* equalsCondition */
        start local 3 // org.graalvm.compiler.nodes.calc.ObjectEqualsNode equalsCondition
         4: .line 387
            aload 3 /* equalsCondition */
            invokevirtual org.graalvm.compiler.nodes.calc.ObjectEqualsNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 4 /* x */
        start local 4 // org.graalvm.compiler.nodes.ValueNode x
         5: .line 388
            aload 3 /* equalsCondition */
            invokevirtual org.graalvm.compiler.nodes.calc.ObjectEqualsNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 5 /* y */
        start local 5 // org.graalvm.compiler.nodes.ValueNode y
         6: .line 389
            aload 2 /* meta */
            ldc Ljava/lang/Integer;
            invokeinterface jdk.vm.ci.meta.MetaAccessProvider.lookupJavaType:(Ljava/lang/Class;)Ljdk/vm/ci/meta/ResolvedJavaType;
            astore 6 /* integerType */
        start local 6 // jdk.vm.ci.meta.ResolvedJavaType integerType
         7: .line 392
            aload 1 /* tool */
            invokestatic org.graalvm.compiler.nodes.NodeView.from:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;)Lorg/graalvm/compiler/nodes/NodeView;
            astore 7 /* view */
        start local 7 // org.graalvm.compiler.nodes.NodeView view
         8: .line 393
            aload 4 /* x */
            aload 7 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            aload 2 /* meta */
            invokevirtual org.graalvm.compiler.core.common.type.Stamp.javaType:(Ljdk/vm/ci/meta/MetaAccessProvider;)Ljdk/vm/ci/meta/ResolvedJavaType;
            aload 6 /* integerType */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifne 10
            aload 5 /* y */
            aload 7 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            aload 2 /* meta */
            invokevirtual org.graalvm.compiler.core.common.type.Stamp.javaType:(Ljdk/vm/ci/meta/MetaAccessProvider;)Ljdk/vm/ci/meta/ResolvedJavaType;
            aload 6 /* integerType */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifne 10
         9: .line 394
            iconst_0
            ireturn
        10: .line 400
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool jdk.vm.ci.meta.MetaAccessProvider org.graalvm.compiler.nodes.calc.ObjectEqualsNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode jdk.vm.ci.meta.ResolvedJavaType org.graalvm.compiler.nodes.NodeView
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getTrueSuccessorProbability:()D
            ldc 0.4
            dcmpl
            ifle 12
        11: .line 401
            iconst_0
            ireturn
        12: .line 405
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            instanceof org.graalvm.compiler.nodes.BeginNode
            ifne 13
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 15
        13: .line 406
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield 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.EndNode
            ifne 16
        14: .line 409
            iconst_0
            ireturn
        15: .line 412
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        16: .line 416
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* unbox */
        start local 8 // org.graalvm.compiler.nodes.extended.UnboxNode unbox
        17: .line 417
            aconst_null
            astore 9 /* unboxCheck */
        start local 9 // org.graalvm.compiler.nodes.FixedGuardNode unboxCheck
        18: .line 418
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getBlockNodes:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 11
            goto 37
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool jdk.vm.ci.meta.MetaAccessProvider org.graalvm.compiler.nodes.calc.ObjectEqualsNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode jdk.vm.ci.meta.ResolvedJavaType org.graalvm.compiler.nodes.NodeView org.graalvm.compiler.nodes.extended.UnboxNode org.graalvm.compiler.nodes.FixedGuardNode top java.util.Iterator
      StackMap stack:
        19: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.FixedNode
            astore 10 /* node */
        start local 10 // org.graalvm.compiler.nodes.FixedNode node
        20: .line 419
            aload 10 /* node */
            instanceof org.graalvm.compiler.nodes.BeginNode
            ifne 23
            aload 10 /* node */
            instanceof org.graalvm.compiler.nodes.extended.UnboxNode
            ifne 23
            aload 10 /* node */
            instanceof org.graalvm.compiler.nodes.FixedGuardNode
            ifne 23
            aload 10 /* node */
            instanceof org.graalvm.compiler.nodes.EndNode
            ifne 23
        21: .line 420
            aload 10 /* node */
            instanceof org.graalvm.compiler.nodes.java.LoadFieldNode
            ifne 23
            aload 10 /* node */
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifne 23
        22: .line 421
            iconst_0
            ireturn
        23: .line 423
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool jdk.vm.ci.meta.MetaAccessProvider org.graalvm.compiler.nodes.calc.ObjectEqualsNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode jdk.vm.ci.meta.ResolvedJavaType org.graalvm.compiler.nodes.NodeView org.graalvm.compiler.nodes.extended.UnboxNode org.graalvm.compiler.nodes.FixedGuardNode org.graalvm.compiler.nodes.FixedNode java.util.Iterator
      StackMap stack:
            aload 10 /* node */
            instanceof org.graalvm.compiler.nodes.extended.UnboxNode
            ifeq 28
        24: .line 424
            aload 8 /* unbox */
            ifnonnull 27
        25: .line 425
            aload 10 /* node */
            checkcast org.graalvm.compiler.nodes.extended.UnboxNode
            astore 8 /* unbox */
        26: .line 426
            goto 28
        27: .line 427
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        28: .line 430
      StackMap locals:
      StackMap stack:
            aload 10 /* node */
            instanceof org.graalvm.compiler.nodes.FixedGuardNode
            ifne 30
        29: .line 431
            goto 37
        30: .line 433
      StackMap locals:
      StackMap stack:
            aload 10 /* node */
            checkcast org.graalvm.compiler.nodes.FixedGuardNode
            astore 12 /* fixed */
        start local 12 // org.graalvm.compiler.nodes.FixedGuardNode fixed
        31: .line 434
            aload 12 /* fixed */
            invokevirtual org.graalvm.compiler.nodes.FixedGuardNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.IntegerEqualsNode
            ifne 33
        32: .line 435
            goto 37
        33: .line 437
      StackMap locals: org.graalvm.compiler.nodes.FixedGuardNode
      StackMap stack:
            aload 12 /* fixed */
            invokevirtual org.graalvm.compiler.nodes.FixedGuardNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerEqualsNode
            astore 13 /* equals */
        start local 13 // org.graalvm.compiler.nodes.calc.IntegerEqualsNode equals
        34: .line 438
            aload 0 /* this */
            aload 2 /* meta */
            aload 7 /* view */
            aload 13 /* equals */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerEqualsNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* x */
            invokevirtual org.graalvm.compiler.nodes.IfNode.isUnboxedFrom:(Ljdk/vm/ci/meta/MetaAccessProvider;Lorg/graalvm/compiler/nodes/NodeView;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 35
            aload 0 /* this */
            aload 2 /* meta */
            aload 7 /* view */
            aload 13 /* equals */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerEqualsNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* y */
            invokevirtual org.graalvm.compiler.nodes.IfNode.isUnboxedFrom:(Ljdk/vm/ci/meta/MetaAccessProvider;Lorg/graalvm/compiler/nodes/NodeView;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifne 36
        35: .line 439
      StackMap locals: org.graalvm.compiler.nodes.calc.IntegerEqualsNode
      StackMap stack:
            aload 0 /* this */
            aload 2 /* meta */
            aload 7 /* view */
            aload 13 /* equals */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerEqualsNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* y */
            invokevirtual org.graalvm.compiler.nodes.IfNode.isUnboxedFrom:(Ljdk/vm/ci/meta/MetaAccessProvider;Lorg/graalvm/compiler/nodes/NodeView;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 37
            aload 0 /* this */
            aload 2 /* meta */
            aload 7 /* view */
            aload 13 /* equals */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerEqualsNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* x */
            invokevirtual org.graalvm.compiler.nodes.IfNode.isUnboxedFrom:(Ljdk/vm/ci/meta/MetaAccessProvider;Lorg/graalvm/compiler/nodes/NodeView;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 37
        36: .line 440
      StackMap locals:
      StackMap stack:
            aload 12 /* fixed */
            astore 9 /* unboxCheck */
        end local 13 // org.graalvm.compiler.nodes.calc.IntegerEqualsNode equals
        end local 12 // org.graalvm.compiler.nodes.FixedGuardNode fixed
        end local 10 // org.graalvm.compiler.nodes.FixedNode node
        37: .line 418
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool jdk.vm.ci.meta.MetaAccessProvider org.graalvm.compiler.nodes.calc.ObjectEqualsNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode jdk.vm.ci.meta.ResolvedJavaType org.graalvm.compiler.nodes.NodeView org.graalvm.compiler.nodes.extended.UnboxNode org.graalvm.compiler.nodes.FixedGuardNode top java.util.Iterator
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 19
        38: .line 443
            aload 8 /* unbox */
            ifnull 39
            aload 9 /* unboxCheck */
            ifnonnull 40
        39: .line 444
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool jdk.vm.ci.meta.MetaAccessProvider org.graalvm.compiler.nodes.calc.ObjectEqualsNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode jdk.vm.ci.meta.ResolvedJavaType org.graalvm.compiler.nodes.NodeView org.graalvm.compiler.nodes.extended.UnboxNode org.graalvm.compiler.nodes.FixedGuardNode
      StackMap stack:
            iconst_0
            ireturn
        40: .line 448
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            invokestatic org.graalvm.compiler.nodes.LogicConstantNode.contradiction:()Lorg/graalvm/compiler/nodes/LogicConstantNode;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.addOrUniqueWithInputs:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            invokevirtual org.graalvm.compiler.nodes.IfNode.setCondition:(Lorg/graalvm/compiler/nodes/LogicNode;)V
        41: .line 450
            iconst_1
            ireturn
        end local 9 // org.graalvm.compiler.nodes.FixedGuardNode unboxCheck
        end local 8 // org.graalvm.compiler.nodes.extended.UnboxNode unbox
        end local 7 // org.graalvm.compiler.nodes.NodeView view
        end local 6 // jdk.vm.ci.meta.ResolvedJavaType integerType
        end local 5 // org.graalvm.compiler.nodes.ValueNode y
        end local 4 // org.graalvm.compiler.nodes.ValueNode x
        end local 3 // org.graalvm.compiler.nodes.calc.ObjectEqualsNode equalsCondition
        end local 2 // jdk.vm.ci.meta.MetaAccessProvider meta
        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   42     0             this  Lorg/graalvm/compiler/nodes/IfNode;
            0   42     1             tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            3   42     2             meta  Ljdk/vm/ci/meta/MetaAccessProvider;
            4   42     3  equalsCondition  Lorg/graalvm/compiler/nodes/calc/ObjectEqualsNode;
            5   42     4                x  Lorg/graalvm/compiler/nodes/ValueNode;
            6   42     5                y  Lorg/graalvm/compiler/nodes/ValueNode;
            7   42     6      integerType  Ljdk/vm/ci/meta/ResolvedJavaType;
            8   42     7             view  Lorg/graalvm/compiler/nodes/NodeView;
           17   42     8            unbox  Lorg/graalvm/compiler/nodes/extended/UnboxNode;
           18   42     9       unboxCheck  Lorg/graalvm/compiler/nodes/FixedGuardNode;
           20   37    10             node  Lorg/graalvm/compiler/nodes/FixedNode;
           31   37    12            fixed  Lorg/graalvm/compiler/nodes/FixedGuardNode;
           34   37    13           equals  Lorg/graalvm/compiler/nodes/calc/IntegerEqualsNode;
    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=5, locals=10, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 457
            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 24
            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 24
         1: .line 458
            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 459
            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 460
            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 461
            iconst_0
            ireturn
         5: .line 463
      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 464
            iconst_0
            ireturn
         7: .line 466
      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 467
            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 468
      StackMap locals: org.graalvm.compiler.nodes.MergeNode
      StackMap stack:
            iconst_0
            ireturn
        10: .line 471
      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.anchored:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isNotEmpty:()Z
            ifne 11
            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.isNotEmpty:()Z
            ifeq 12
        11: .line 472
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        12: .line 475
      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
        13: .line 476
            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
        14: .line 477
            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
        15: .line 479
            aload 1 /* tool */
            invokestatic org.graalvm.compiler.nodes.NodeView.from:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;)Lorg/graalvm/compiler/nodes/NodeView;
            astore 8 /* view */
        start local 8 // org.graalvm.compiler.nodes.NodeView view
        16: .line 480
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            aload 7 /* trueValue */
            aload 6 /* falseValue */
            aload 5 /* phi */
            aload 8 /* view */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            aload 8 /* view */
            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/NodeView;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 9 /* result */
        start local 9 // org.graalvm.compiler.nodes.ValueNode result
        17: .line 481
            aload 9 /* result */
            ifnull 24
        18: .line 485
            aload 9 /* result */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            ifnonnull 20
        19: .line 486
            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.ValueNode
            astore 9 /* result */
        20: .line 488
      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.NodeView org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
            aload 0 /* this */
            aload 9 /* result */
            invokevirtual org.graalvm.compiler.nodes.IfNode.proxyReplacement:(Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 9 /* result */
        21: .line 493
            aload 5 /* phi */
            aload 2 /* trueEnd */
            aload 9 /* result */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.setValueAt:(Lorg/graalvm/compiler/nodes/AbstractEndNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
        22: .line 494
            aload 0 /* this */
            aload 1 /* tool */
            aload 4 /* merge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.removeThroughFalseBranch:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
        23: .line 495
            iconst_1
            ireturn
        end local 9 // org.graalvm.compiler.nodes.ValueNode result
        end local 8 // org.graalvm.compiler.nodes.NodeView view
        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
        24: .line 499
      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   25     0        this  Lorg/graalvm/compiler/nodes/IfNode;
            0   25     1        tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            2   24     2     trueEnd  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            3   24     3    falseEnd  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            8   24     4       merge  Lorg/graalvm/compiler/nodes/MergeNode;
           13   24     5         phi  Lorg/graalvm/compiler/nodes/PhiNode;
           14   24     6  falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
           15   24     7   trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
           16   24     8        view  Lorg/graalvm/compiler/nodes/NodeView;
           17   24     9      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 503
            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 506
      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 507
            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 508
            aload 2 /* trueSucc */
            instanceof org.graalvm.compiler.nodes.BeginNode
            ifeq 27
            aload 3 /* falseSucc */
            instanceof org.graalvm.compiler.nodes.BeginNode
            ifeq 27
            aload 2 /* trueSucc */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.FixedWithNextNode
            ifeq 27
            aload 3 /* falseSucc */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
            instanceof org.graalvm.compiler.nodes.FixedWithNextNode
            ifeq 27
         5: .line 509
            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 510
            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 511
            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 512
            aload 4 /* trueNext */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            aload 5 /* falseNext */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            if_acmpne 27
         9: .line 513
            aload 4 /* trueNext */
            instanceof org.graalvm.compiler.nodes.AbstractBeginNode
            ifne 27
        10: .line 516
            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 27
            aload 4 /* trueNext */
            aload 5 /* falseNext */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.valueEquals:(Lorg/graalvm/compiler/graph/Node;)Z
            ifeq 27
        11: .line 517
            aload 5 /* falseNext */
            aload 4 /* trueNext */
            invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.replaceAtUsages:(Lorg/graalvm/compiler/graph/Node;)V
        12: .line 518
            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
        13: .line 519
            aload 4 /* trueNext */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.unlinkFixedNode:(Lorg/graalvm/compiler/nodes/FixedWithNextNode;)V
        14: .line 520
            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
        15: .line 521
            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 25
      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:
        16: 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
        17: .line 522
            aload 7 /* usage */
            invokevirtual org.graalvm.compiler.graph.Node.isAlive:()Z
            ifeq 25
        18: .line 523
            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
        19: .line 524
            aload 9 /* usageNodeClass */
            invokevirtual org.graalvm.compiler.graph.NodeClass.valueNumberable:()Z
            ifeq 23
            aload 9 /* usageNodeClass */
            invokevirtual org.graalvm.compiler.graph.NodeClass.isLeafNode:()Z
            ifne 23
        20: .line 525
            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
        21: .line 526
            aload 10 /* newNode */
            ifnull 23
        22: .line 527
            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
        23: .line 530
      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 25
        24: .line 531
            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
        25: .line 521
      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 16
        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
        26: .line 540
            goto 2
        27: .line 541
      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   28     0            this  Lorg/graalvm/compiler/nodes/IfNode;
            0   28     1            tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            3   26     2        trueSucc  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            4   26     3       falseSucc  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            6   26     4        trueNext  Lorg/graalvm/compiler/nodes/FixedWithNextNode;
            7   26     5       falseNext  Lorg/graalvm/compiler/nodes/FixedWithNextNode;
            8   26     6       nodeClass  Lorg/graalvm/compiler/graph/NodeClass<*>;
           17   25     7           usage  Lorg/graalvm/compiler/graph/Node;
           19   25     9  usageNodeClass  Lorg/graalvm/compiler/graph/NodeClass<*>;
           21   23    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=14, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.graph.spi.SimplifierTool tool
         0: .line 551
            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 552
      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 44
         3: .line 553
            aload 1 /* tool */
            invokestatic org.graalvm.compiler.nodes.NodeView.from:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;)Lorg/graalvm/compiler/nodes/NodeView;
            astore 2 /* view */
        start local 2 // org.graalvm.compiler.nodes.NodeView view
         4: .line 554
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            astore 3 /* lessThan */
        start local 3 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan
         5: .line 555
            aload 3 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            invokevirtual org.graalvm.compiler.core.common.type.Stamp.asConstant:()Ljdk/vm/ci/meta/Constant;
            astore 4 /* y */
        start local 4 // jdk.vm.ci.meta.Constant y
         6: .line 556
            aload 4 /* y */
            instanceof jdk.vm.ci.meta.PrimitiveConstant
            ifeq 44
            aload 4 /* y */
            checkcast jdk.vm.ci.meta.PrimitiveConstant
            invokevirtual jdk.vm.ci.meta.PrimitiveConstant.asLong:()J
            lconst_0
            lcmp
            ifne 44
            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 44
         7: .line 557
            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 5 /* ifNode2 */
        start local 5 // org.graalvm.compiler.nodes.IfNode ifNode2
         8: .line 558
            aload 5 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            ifeq 44
         9: .line 559
            aload 5 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            astore 6 /* lessThan2 */
        start local 6 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan2
        10: .line 560
            aload 5 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 7 /* falseSucc */
        start local 7 // org.graalvm.compiler.nodes.AbstractBeginNode falseSucc
        11: .line 561
            aload 5 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 8 /* trueSucc */
        start local 8 // org.graalvm.compiler.nodes.AbstractBeginNode trueSucc
        12: .line 562
            aconst_null
            astore 9 /* below */
        start local 9 // org.graalvm.compiler.nodes.calc.IntegerBelowNode below
        13: .line 567
            aload 6 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 3 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 21
            aload 6 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            instanceof org.graalvm.compiler.core.common.type.IntegerStamp
            ifeq 21
        14: .line 568
            aload 6 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)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 21
        15: .line 569
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 5 /* 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 21
        16: .line 570
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.calc.IntegerBelowNode
            dup
            aload 6 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* 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 9 /* below */
        17: .line 572
            aload 7 /* falseSucc */
            astore 10 /* tmp */
        start local 10 // org.graalvm.compiler.nodes.AbstractBeginNode tmp
        18: .line 573
            aload 8 /* trueSucc */
            astore 7 /* falseSucc */
        19: .line 574
            aload 10 /* tmp */
            astore 8 /* trueSucc */
        end local 10 // org.graalvm.compiler.nodes.AbstractBeginNode tmp
        20: .line 575
            goto 26
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.NodeView 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:
        21: aload 6 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 3 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 26
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 5 /* 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 26
        22: .line 582
            aload 6 /* 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 10 /* positive */
        start local 10 // jdk.vm.ci.meta.JavaConstant positive
        23: .line 583
            aload 10 /* positive */
            ifnull 26
            aload 10 /* positive */
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            lconst_0
            lcmp
            ifle 26
            aload 10 /* positive */
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            aload 10 /* positive */
            invokeinterface jdk.vm.ci.meta.JavaConstant.getJavaKind:()Ljdk/vm/ci/meta/JavaKind;
            invokevirtual jdk.vm.ci.meta.JavaKind.getMaxValue:()J
            lcmp
            ifge 26
        24: .line 584
            aload 6 /* lessThan2 */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 2 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            aload 10 /* 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 11 /* newLimit */
        start local 11 // org.graalvm.compiler.nodes.ConstantNode newLimit
        25: .line 585
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.calc.IntegerBelowNode
            dup
            aload 3 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 11 /* 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 9 /* below */
        end local 11 // org.graalvm.compiler.nodes.ConstantNode newLimit
        end local 10 // jdk.vm.ci.meta.JavaConstant positive
        26: .line 588
      StackMap locals:
      StackMap stack:
            aload 9 /* below */
            ifnull 44
        27: .line 589
            aconst_null
            astore 10
            aconst_null
            astore 11
        28: aload 5 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.withNodeSourcePosition:()Lorg/graalvm/compiler/debug/DebugCloseable;
            astore 12 /* position */
        start local 12 // org.graalvm.compiler.debug.DebugCloseable position
        29: .line 590
            aload 5 /* ifNode2 */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        30: .line 591
            aload 5 /* ifNode2 */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        31: .line 593
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.IfNode
            dup
            aload 9 /* below */
            aload 7 /* falseSucc */
            aload 8 /* 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 13 /* newIfNode */
        start local 13 // org.graalvm.compiler.nodes.IfNode newIfNode
        32: .line 595
            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
        33: .line 596
            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
        34: .line 599
            aload 5 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            aload 5 /* ifNode2 */
            aload 13 /* newIfNode */
            invokevirtual org.graalvm.compiler.graph.Node.replaceFirstSuccessor:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)V
        35: .line 600
            aload 5 /* ifNode2 */
            invokevirtual org.graalvm.compiler.nodes.IfNode.safeDelete:()V
        36: .line 602
            aload 12 /* position */
            ifnull 37
            aload 12 /* position */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
        37: .line 601
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.NodeView 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 java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.IfNode
      StackMap stack:
            iconst_1
            ireturn
        end local 13 // org.graalvm.compiler.nodes.IfNode newIfNode
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.NodeView 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 java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable
      StackMap stack: java.lang.Throwable
        38: astore 10
        39: .line 602
            aload 12 /* position */
            ifnull 40
            aload 12 /* position */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
        end local 12 // org.graalvm.compiler.debug.DebugCloseable position
      StackMap locals:
      StackMap stack:
        40: aload 10
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        41: astore 11
            aload 10
            ifnonnull 42
            aload 11
            astore 10
            goto 43
      StackMap locals:
      StackMap stack:
        42: aload 10
            aload 11
            if_acmpeq 43
            aload 10
            aload 11
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        43: aload 10
            athrow
        end local 9 // org.graalvm.compiler.nodes.calc.IntegerBelowNode below
        end local 8 // org.graalvm.compiler.nodes.AbstractBeginNode trueSucc
        end local 7 // org.graalvm.compiler.nodes.AbstractBeginNode falseSucc
        end local 6 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan2
        end local 5 // org.graalvm.compiler.nodes.IfNode ifNode2
        end local 4 // jdk.vm.ci.meta.Constant y
        end local 3 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan
        end local 2 // org.graalvm.compiler.nodes.NodeView view
        44: .line 607
      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   45     0       this  Lorg/graalvm/compiler/nodes/IfNode;
            0   45     1       tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            4   44     2       view  Lorg/graalvm/compiler/nodes/NodeView;
            5   44     3   lessThan  Lorg/graalvm/compiler/nodes/calc/IntegerLessThanNode;
            6   44     4          y  Ljdk/vm/ci/meta/Constant;
            8   44     5    ifNode2  Lorg/graalvm/compiler/nodes/IfNode;
           10   44     6  lessThan2  Lorg/graalvm/compiler/nodes/calc/IntegerLessThanNode;
           11   44     7  falseSucc  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           12   44     8   trueSucc  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           13   44     9      below  Lorg/graalvm/compiler/nodes/calc/IntegerBelowNode;
           18   20    10        tmp  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           23   26    10   positive  Ljdk/vm/ci/meta/JavaConstant;
           25   26    11   newLimit  Lorg/graalvm/compiler/nodes/ConstantNode;
           29   40    12   position  Lorg/graalvm/compiler/debug/DebugCloseable;
           32   38    13  newIfNode  Lorg/graalvm/compiler/nodes/IfNode;
      Exception table:
        from    to  target  type
          29    36      38  any
          28    37      41  any
          38    41      41  any
    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 615
            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 616
            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 617
            aload 2 /* next1 */
            instanceof org.graalvm.compiler.nodes.EndNode
            ifeq 12
            aload 3 /* next2 */
            instanceof org.graalvm.compiler.nodes.EndNode
            ifeq 12
         3: .line 618
            aload 2 /* next1 */
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 4 /* end1 */
        start local 4 // org.graalvm.compiler.nodes.EndNode end1
         4: .line 619
            aload 3 /* next2 */
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 5 /* end2 */
        start local 5 // org.graalvm.compiler.nodes.EndNode end2
         5: .line 620
            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 621
            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 622
            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 623
            iconst_0
            ireturn
        end local 6 // org.graalvm.compiler.nodes.PhiNode phi
        10: .line 621
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        11: .line 627
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.EndNode end2
        end local 4 // org.graalvm.compiler.nodes.EndNode end1
        12: .line 629
      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 630
            aload 2 /* next1 */
            checkcast org.graalvm.compiler.nodes.DeoptimizeNode
            astore 4 /* deopt1 */
        start local 4 // org.graalvm.compiler.nodes.DeoptimizeNode deopt1
        14: .line 631
            aload 3 /* next2 */
            checkcast org.graalvm.compiler.nodes.DeoptimizeNode
            astore 5 /* deopt2 */
        start local 5 // org.graalvm.compiler.nodes.DeoptimizeNode deopt2
        15: .line 632
            aload 4 /* deopt1 */
            invokevirtual org.graalvm.compiler.nodes.DeoptimizeNode.getReason:()Ljdk/vm/ci/meta/DeoptimizationReason;
            aload 5 /* deopt2 */
            invokevirtual org.graalvm.compiler.nodes.DeoptimizeNode.getReason:()Ljdk/vm/ci/meta/DeoptimizationReason;
            if_acmpne 27
            aload 4 /* deopt1 */
            invokevirtual org.graalvm.compiler.nodes.DeoptimizeNode.getAction:()Ljdk/vm/ci/meta/DeoptimizationAction;
            aload 5 /* deopt2 */
            invokevirtual org.graalvm.compiler.nodes.DeoptimizeNode.getAction:()Ljdk/vm/ci/meta/DeoptimizationAction;
            if_acmpne 27
        16: .line 634
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.DeoptimizeNode deopt2
        end local 4 // org.graalvm.compiler.nodes.DeoptimizeNode deopt1
        17: .line 636
      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 637
            aload 2 /* next1 */
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            astore 4 /* exit1 */
        start local 4 // org.graalvm.compiler.nodes.LoopExitNode exit1
        19: .line 638
            aload 3 /* next2 */
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            astore 5 /* exit2 */
        start local 5 // org.graalvm.compiler.nodes.LoopExitNode exit2
        20: .line 639
            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 641
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.LoopExitNode exit2
        end local 4 // org.graalvm.compiler.nodes.LoopExitNode exit1
        22: .line 643
      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 644
            aload 2 /* next1 */
            checkcast org.graalvm.compiler.nodes.ReturnNode
            astore 4 /* exit1 */
        start local 4 // org.graalvm.compiler.nodes.ReturnNode exit1
        24: .line 645
            aload 3 /* next2 */
            checkcast org.graalvm.compiler.nodes.ReturnNode
            astore 5 /* exit2 */
        start local 5 // org.graalvm.compiler.nodes.ReturnNode exit2
        25: .line 646
            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 648
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.ReturnNode exit2
        end local 4 // org.graalvm.compiler.nodes.ReturnNode exit1
        27: .line 651
      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(org.graalvm.compiler.graph.spi.SimplifierTool, org.graalvm.compiler.nodes.LogicNode, org.graalvm.compiler.nodes.LogicNode);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/LogicNode;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=10, args_size=3
        start local 0 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        start local 1 // org.graalvm.compiler.nodes.LogicNode a
        start local 2 // org.graalvm.compiler.nodes.LogicNode b
         0: .line 655
            aload 1 /* a */
            invokevirtual org.graalvm.compiler.nodes.LogicNode.getDebug:()Lorg/graalvm/compiler/debug/DebugContext;
            astore 3 /* debug */
        start local 3 // org.graalvm.compiler.debug.DebugContext debug
         1: .line 656
            aload 1 /* a */
            instanceof org.graalvm.compiler.nodes.java.InstanceOfNode
            ifeq 14
         2: .line 657
            aload 1 /* a */
            checkcast org.graalvm.compiler.nodes.java.InstanceOfNode
            astore 4 /* instanceOfA */
        start local 4 // org.graalvm.compiler.nodes.java.InstanceOfNode instanceOfA
         3: .line 658
            aload 2 /* b */
            instanceof org.graalvm.compiler.nodes.calc.IsNullNode
            ifeq 8
         4: .line 659
            aload 2 /* b */
            checkcast org.graalvm.compiler.nodes.calc.IsNullNode
            astore 5 /* isNullNode */
        start local 5 // org.graalvm.compiler.nodes.calc.IsNullNode isNullNode
         5: .line 660
            aload 5 /* isNullNode */
            invokevirtual org.graalvm.compiler.nodes.calc.IsNullNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 54
         6: .line 661
            aload 3 /* debug */
            ldc "Can swap instanceof and isnull if"
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(Ljava/lang/String;)V
         7: .line 662
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.calc.IsNullNode isNullNode
         8: .line 664
      StackMap locals: org.graalvm.compiler.debug.DebugContext org.graalvm.compiler.nodes.java.InstanceOfNode
      StackMap stack:
            aload 2 /* b */
            instanceof org.graalvm.compiler.nodes.java.InstanceOfNode
            ifeq 54
         9: .line 665
            aload 2 /* b */
            checkcast org.graalvm.compiler.nodes.java.InstanceOfNode
            astore 5 /* instanceOfB */
        start local 5 // org.graalvm.compiler.nodes.java.InstanceOfNode instanceOfB
        10: .line 666
            aload 4 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 5 /* instanceOfB */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.getValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 54
            aload 4 /* 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 54
            aload 5 /* 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 54
        11: .line 667
            aload 4 /* 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 5 /* 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 54
            aload 5 /* 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 4 /* 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 54
        12: .line 669
            aload 3 /* debug */
            ldc "Can swap instanceof for types %s and %s"
            aload 4 /* instanceOfA */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            aload 5 /* instanceOfB */
            invokevirtual org.graalvm.compiler.nodes.java.InstanceOfNode.type:()Lorg/graalvm/compiler/core/common/type/TypeReference;
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        13: .line 670
            iconst_1
            ireturn
        end local 5 // org.graalvm.compiler.nodes.java.InstanceOfNode instanceOfB
        end local 4 // org.graalvm.compiler.nodes.java.InstanceOfNode instanceOfA
        14: .line 673
      StackMap locals:
      StackMap stack:
            aload 1 /* a */
            instanceof org.graalvm.compiler.nodes.calc.CompareNode
            ifeq 54
        15: .line 674
            aload 1 /* a */
            checkcast org.graalvm.compiler.nodes.calc.CompareNode
            astore 4 /* compareA */
        start local 4 // org.graalvm.compiler.nodes.calc.CompareNode compareA
        16: .line 675
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.condition:()Lorg/graalvm/compiler/core/common/calc/CanonicalCondition;
            invokevirtual org.graalvm.compiler.core.common.calc.CanonicalCondition.asCondition:()Lorg/graalvm/compiler/core/common/calc/Condition;
            astore 5 /* conditionA */
        start local 5 // org.graalvm.compiler.core.common.calc.Condition conditionA
        17: .line 676
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.unorderedIsTrue:()Z
            ifeq 19
        18: .line 677
            iconst_0
            ireturn
        19: .line 679
      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 54
        20: .line 680
            aload 2 /* b */
            checkcast org.graalvm.compiler.nodes.calc.CompareNode
            astore 6 /* compareB */
        start local 6 // org.graalvm.compiler.nodes.calc.CompareNode compareB
        21: .line 681
            aload 4 /* compareA */
            aload 6 /* compareB */
            if_acmpne 24
        22: .line 682
            aload 3 /* debug */
            ldc "Same conditions => do not swap and leave the work for global value numbering."
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(Ljava/lang/String;)V
        23: .line 683
            iconst_0
            ireturn
        24: .line 685
      StackMap locals: org.graalvm.compiler.nodes.calc.CompareNode
      StackMap stack:
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.unorderedIsTrue:()Z
            ifeq 26
        25: .line 686
            iconst_0
            ireturn
        26: .line 688
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 7 /* comparableCondition */
        start local 7 // org.graalvm.compiler.core.common.calc.Condition comparableCondition
        27: .line 689
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.condition:()Lorg/graalvm/compiler/core/common/calc/CanonicalCondition;
            invokevirtual org.graalvm.compiler.core.common.calc.CanonicalCondition.asCondition:()Lorg/graalvm/compiler/core/common/calc/Condition;
            astore 8 /* conditionB */
        start local 8 // org.graalvm.compiler.core.common.calc.Condition conditionB
        28: .line 690
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 31
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 31
        29: .line 691
            aload 8 /* conditionB */
            astore 7 /* comparableCondition */
        30: .line 692
            goto 33
      StackMap locals: org.graalvm.compiler.core.common.calc.Condition org.graalvm.compiler.core.common.calc.Condition
      StackMap stack:
        31: aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 33
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 33
        32: .line 693
            aload 8 /* conditionB */
            invokevirtual org.graalvm.compiler.core.common.calc.Condition.mirror:()Lorg/graalvm/compiler/core/common/calc/Condition;
            astore 7 /* comparableCondition */
        33: .line 696
      StackMap locals:
      StackMap stack:
            aload 7 /* comparableCondition */
            ifnull 38
        34: .line 697
            aload 5 /* conditionA */
            aload 7 /* 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 9 /* combined */
        start local 9 // org.graalvm.compiler.core.common.calc.Condition combined
        35: .line 698
            aload 9 /* combined */
            ifnonnull 54
        36: .line 700
            aload 3 /* debug */
            ldc "Can swap disjoint coditions on same values: %s and %s"
            aload 5 /* conditionA */
            aload 7 /* comparableCondition */
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        37: .line 701
            iconst_1
            ireturn
        end local 9 // org.graalvm.compiler.core.common.calc.Condition combined
        38: .line 703
      StackMap locals:
      StackMap stack:
            aload 5 /* conditionA */
            getstatic org.graalvm.compiler.core.common.calc.Condition.EQ:Lorg/graalvm/compiler/core/common/calc/Condition;
            if_acmpne 54
            aload 8 /* conditionB */
            getstatic org.graalvm.compiler.core.common.calc.Condition.EQ:Lorg/graalvm/compiler/core/common/calc/Condition;
            if_acmpne 54
        39: .line 704
            iconst_0
            istore 9 /* canSwap */
        start local 9 // boolean canSwap
        40: .line 705
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 43
            aload 0 /* tool */
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.valuesDistinct:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 43
        41: .line 706
            iconst_1
            istore 9 /* canSwap */
        42: .line 707
            goto 51
      StackMap locals: int
      StackMap stack:
        43: aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 46
            aload 0 /* tool */
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.valuesDistinct:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 46
        44: .line 708
            iconst_1
            istore 9 /* canSwap */
        45: .line 709
            goto 51
      StackMap locals:
      StackMap stack:
        46: aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 49
            aload 0 /* tool */
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.valuesDistinct:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 49
        47: .line 710
            iconst_1
            istore 9 /* canSwap */
        48: .line 711
            goto 51
      StackMap locals:
      StackMap stack:
        49: aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 51
            aload 0 /* tool */
            aload 4 /* compareA */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 6 /* compareB */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokestatic org.graalvm.compiler.nodes.IfNode.valuesDistinct:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
            ifeq 51
        50: .line 712
            iconst_1
            istore 9 /* canSwap */
        51: .line 715
      StackMap locals:
      StackMap stack:
            iload 9 /* canSwap */
            ifeq 54
        52: .line 716
            aload 3 /* debug */
            ldc "Can swap equality condition with one shared and one disjoint value."
            invokevirtual org.graalvm.compiler.debug.DebugContext.log:(Ljava/lang/String;)V
        53: .line 717
            iconst_1
            ireturn
        end local 9 // boolean canSwap
        end local 8 // org.graalvm.compiler.core.common.calc.Condition conditionB
        end local 7 // org.graalvm.compiler.core.common.calc.Condition comparableCondition
        end local 6 // org.graalvm.compiler.nodes.calc.CompareNode compareB
        end local 5 // org.graalvm.compiler.core.common.calc.Condition conditionA
        end local 4 // org.graalvm.compiler.nodes.calc.CompareNode compareA
        54: .line 723
      StackMap locals: org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.debug.DebugContext
      StackMap stack:
            iconst_0
            ireturn
        end local 3 // org.graalvm.compiler.debug.DebugContext debug
        end local 2 // org.graalvm.compiler.nodes.LogicNode b
        end local 1 // org.graalvm.compiler.nodes.LogicNode a
        end local 0 // org.graalvm.compiler.graph.spi.SimplifierTool tool
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   55     0                 tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            0   55     1                    a  Lorg/graalvm/compiler/nodes/LogicNode;
            0   55     2                    b  Lorg/graalvm/compiler/nodes/LogicNode;
            1   55     3                debug  Lorg/graalvm/compiler/debug/DebugContext;
            3   14     4          instanceOfA  Lorg/graalvm/compiler/nodes/java/InstanceOfNode;
            5    8     5           isNullNode  Lorg/graalvm/compiler/nodes/calc/IsNullNode;
           10   14     5          instanceOfB  Lorg/graalvm/compiler/nodes/java/InstanceOfNode;
           16   54     4             compareA  Lorg/graalvm/compiler/nodes/calc/CompareNode;
           17   54     5           conditionA  Lorg/graalvm/compiler/core/common/calc/Condition;
           21   54     6             compareB  Lorg/graalvm/compiler/nodes/calc/CompareNode;
           27   54     7  comparableCondition  Lorg/graalvm/compiler/core/common/calc/Condition;
           28   54     8           conditionB  Lorg/graalvm/compiler/core/common/calc/Condition;
           35   38     9             combined  Lorg/graalvm/compiler/core/common/calc/Condition;
           40   54     9              canSwap  Z
    MethodParameters:
      Name  Flags
      tool  
      a     
      b     

  private static boolean valuesDistinct(org.graalvm.compiler.graph.spi.SimplifierTool, org.graalvm.compiler.nodes.ValueNode, org.graalvm.compiler.nodes.ValueNode);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=3
        start local 0 // org.graalvm.compiler.graph.spi.SimplifierTool tool
        start local 1 // org.graalvm.compiler.nodes.ValueNode a
        start local 2 // org.graalvm.compiler.nodes.ValueNode b
         0: .line 727
            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 728
            aload 0 /* tool */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.getConstantReflection:()Ljdk/vm/ci/meta/ConstantReflectionProvider;
            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 729
            aload 3 /* equal */
            ifnull 6
         3: .line 730
            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 734
      StackMap locals:
      StackMap stack:
            aload 0 /* tool */
            invokestatic org.graalvm.compiler.nodes.NodeView.from:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;)Lorg/graalvm/compiler/nodes/NodeView;
            astore 3 /* view */
        start local 3 // org.graalvm.compiler.nodes.NodeView view
         7: .line 735
            aload 1 /* a */
            aload 3 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            astore 4 /* stampA */
        start local 4 // org.graalvm.compiler.core.common.type.Stamp stampA
         8: .line 736
            aload 2 /* b */
            aload 3 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            astore 5 /* stampB */
        start local 5 // org.graalvm.compiler.core.common.type.Stamp stampB
         9: .line 737
            aload 4 /* stampA */
            aload 5 /* stampB */
            invokevirtual org.graalvm.compiler.core.common.type.Stamp.alwaysDistinct:(Lorg/graalvm/compiler/core/common/type/Stamp;)Z
            ireturn
        end local 5 // org.graalvm.compiler.core.common.type.Stamp stampB
        end local 4 // org.graalvm.compiler.core.common.type.Stamp stampA
        end local 3 // org.graalvm.compiler.nodes.NodeView view
        end local 2 // org.graalvm.compiler.nodes.ValueNode b
        end local 1 // org.graalvm.compiler.nodes.ValueNode a
        end local 0 // org.graalvm.compiler.graph.spi.SimplifierTool tool
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            0   10     1       a  Lorg/graalvm/compiler/nodes/ValueNode;
            0   10     2       b  Lorg/graalvm/compiler/nodes/ValueNode;
            2    6     3   equal  Ljava/lang/Boolean;
            7   10     3    view  Lorg/graalvm/compiler/nodes/NodeView;
            8   10     4  stampA  Lorg/graalvm/compiler/core/common/type/Stamp;
            9   10     5  stampB  Lorg/graalvm/compiler/core/common/type/Stamp;
    MethodParameters:
      Name  Flags
      tool  
      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 746
            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 747
      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 29
            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 29
         3: .line 748
            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 749
            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 750
            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 751
            aload 4 /* merge */
            aload 3 /* falseEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractEndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            if_acmpne 29
            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 29
            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 29
         7: .line 752
            aconst_null
            astore 5 /* singlePhi */
        start local 5 // org.graalvm.compiler.nodes.PhiNode singlePhi
         8: .line 753
            iconst_0
            istore 6 /* distinct */
        start local 6 // int distinct
         9: .line 754
            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 755
            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 756
            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 757
            aload 9 /* trueValue */
            aload 10 /* falseValue */
            if_acmpeq 16
        14: .line 758
            iinc 6 /* distinct */ 1
        15: .line 759
            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 754
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        17: .line 762
            iload 6 /* distinct */
            ifne 20
        18: .line 767
            aload 0 /* this */
            aload 1 /* tool */
            aload 4 /* merge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.removeThroughFalseBranch:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
        19: .line 768
            iconst_1
            ireturn
        20: .line 769
      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 29
        21: .line 770
            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 771
            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 772
            aload 0 /* this */
            aload 1 /* tool */
            aload 7 /* trueValue */
            aload 8 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.IfNode.canonicalizeConditionalCascade:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 9 /* conditional */
        start local 9 // org.graalvm.compiler.nodes.ValueNode conditional
        24: .line 773
            aload 9 /* conditional */
            ifnull 29
        25: .line 774
            aload 0 /* this */
            aload 9 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.IfNode.proxyReplacement:(Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 9 /* conditional */
        26: .line 775
            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
        27: .line 776
            aload 0 /* this */
            aload 1 /* tool */
            aload 4 /* merge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.removeThroughFalseBranch:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
        28: .line 777
            iconst_1
            ireturn
        end local 9 // org.graalvm.compiler.nodes.ValueNode 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
        29: .line 782
      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 46
            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 46
        30: .line 783
            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
        31: .line 784
            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
        32: .line 785
            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
        33: .line 786
            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
        34: .line 787
            aconst_null
            astore 6 /* value */
        start local 6 // org.graalvm.compiler.nodes.ValueNode value
        35: .line 788
            aload 4 /* trueValue */
            ifnull 42
        36: .line 789
            aload 4 /* trueValue */
            aload 5 /* falseValue */
            if_acmpne 39
        37: .line 790
            aload 4 /* trueValue */
            astore 6 /* value */
        38: .line 791
            goto 42
        39: .line 792
      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 1 /* tool */
            aload 4 /* trueValue */
            aload 5 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.IfNode.canonicalizeConditionalCascade:(Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/ValueNode;
            astore 6 /* value */
        40: .line 793
            aload 6 /* value */
            ifnonnull 42
        41: .line 794
            iconst_0
            ireturn
        42: .line 798
      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
        43: .line 799
            aload 0 /* this */
            aload 7 /* newReturn */
            invokevirtual org.graalvm.compiler.nodes.IfNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        44: .line 800
            aload 0 /* this */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        45: .line 801
            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
        46: .line 803
      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   47     0         this  Lorg/graalvm/compiler/nodes/IfNode;
            0   47     1         tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            4   29     2      trueEnd  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            5   29     3     falseEnd  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            6   29     4        merge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            8   29     5    singlePhi  Lorg/graalvm/compiler/nodes/PhiNode;
            9   29     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   29     7    trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
           23   29     8   falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
           24   29     9  conditional  Lorg/graalvm/compiler/nodes/ValueNode;
           31   46     2      trueEnd  Lorg/graalvm/compiler/nodes/ReturnNode;
           32   46     3     falseEnd  Lorg/graalvm/compiler/nodes/ReturnNode;
           33   46     4    trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
           34   46     5   falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
           35   46     6        value  Lorg/graalvm/compiler/nodes/ValueNode;
           43   46     7    newReturn  Lorg/graalvm/compiler/nodes/ReturnNode;
    MethodParameters:
      Name  Flags
      tool  

  private org.graalvm.compiler.nodes.ValueNode proxyReplacement(org.graalvm.compiler.nodes.ValueNode);
    descriptor: (Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/ValueNode;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.ValueNode replacement
         0: .line 826
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.hasValueProxies:()Z
            ifeq 6
         1: .line 827
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 6
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 6
         2: .line 828
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 3
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            invokevirtual org.graalvm.compiler.nodes.LoopExitNode.loopBegin:()Lorg/graalvm/compiler/nodes/LoopBeginNode;
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            invokevirtual org.graalvm.compiler.nodes.LoopExitNode.loopBegin:()Lorg/graalvm/compiler/nodes/LoopBeginNode;
            if_acmpeq 3
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 829
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 5
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isEmpty:()Z
            ifeq 4
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.falseSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isEmpty:()Z
            ifne 5
      StackMap locals:
      StackMap stack:
         4: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         5: .line 830
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.ValueProxyNode
            dup
            aload 1 /* replacement */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessor:Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            invokespecial org.graalvm.compiler.nodes.ValueProxyNode.<init>:(Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/LoopExitNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.addOrUnique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.ValueNode
            areturn
         6: .line 833
      StackMap locals:
      StackMap stack:
            aload 1 /* replacement */
            areturn
        end local 1 // org.graalvm.compiler.nodes.ValueNode replacement
        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  replacement  Lorg/graalvm/compiler/nodes/ValueNode;
    MethodParameters:
             Name  Flags
      replacement  

  protected void removeThroughFalseBranch(org.graalvm.compiler.graph.spi.SimplifierTool, org.graalvm.compiler.nodes.AbstractMergeNode);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=8, 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.AbstractMergeNode merge
         0: .line 837
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 3 /* trueBegin */
        start local 3 // org.graalvm.compiler.nodes.AbstractBeginNode trueBegin
         1: .line 838
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            astore 4 /* conditionNode */
        start local 4 // org.graalvm.compiler.nodes.LogicNode conditionNode
         2: .line 839
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 0 /* this */
            aload 3 /* trueBegin */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.removeSplitPropagate:(Lorg/graalvm/compiler/nodes/ControlSplitNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
         3: .line 840
            aload 1 /* tool */
            aload 3 /* trueBegin */
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.addToWorkList:(Lorg/graalvm/compiler/graph/Node;)V
         4: .line 841
            aload 4 /* conditionNode */
            ifnull 6
         5: .line 842
            aload 4 /* conditionNode */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.tryKillUnused:(Lorg/graalvm/compiler/graph/Node;)Z
            pop
         6: .line 844
      StackMap locals: org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.LogicNode
      StackMap stack:
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.isAlive:()Z
            ifeq 16
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndCount:()I
            iconst_1
            if_icmple 16
         7: .line 845
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEnds:()Lorg/graalvm/compiler/graph/NodeInputList;
            invokevirtual org.graalvm.compiler.graph.NodeInputList.iterator:()Ljava/util/Iterator;
            astore 6
            goto 15
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.LogicNode top java.util.Iterator
      StackMap stack:
         8: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.FixedNode
            astore 5 /* end */
        start local 5 // org.graalvm.compiler.nodes.FixedNode end
         9: .line 846
            aload 5 /* end */
            astore 7 /* cur */
        start local 7 // org.graalvm.compiler.graph.Node cur
        10: .line 847
            goto 12
        11: .line 848
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.FixedNode java.util.Iterator org.graalvm.compiler.graph.Node
      StackMap stack:
            aload 7 /* cur */
            invokevirtual org.graalvm.compiler.graph.Node.predecessor:()Lorg/graalvm/compiler/graph/Node;
            astore 7 /* cur */
        12: .line 847
      StackMap locals:
      StackMap stack:
            aload 7 /* cur */
            ifnull 13
            aload 7 /* cur */
            invokevirtual org.graalvm.compiler.graph.Node.predecessor:()Lorg/graalvm/compiler/graph/Node;
            instanceof org.graalvm.compiler.nodes.BeginNode
            ifne 11
        13: .line 850
      StackMap locals:
      StackMap stack:
            aload 7 /* cur */
            ifnull 15
            aload 7 /* cur */
            invokevirtual org.graalvm.compiler.graph.Node.predecessor:()Lorg/graalvm/compiler/graph/Node;
            instanceof org.graalvm.compiler.nodes.IfNode
            ifeq 15
        14: .line 851
            aload 1 /* tool */
            aload 7 /* cur */
            invokevirtual org.graalvm.compiler.graph.Node.predecessor:()Lorg/graalvm/compiler/graph/Node;
            invokeinterface org.graalvm.compiler.graph.spi.SimplifierTool.addToWorkList:(Lorg/graalvm/compiler/graph/Node;)V
        end local 7 // org.graalvm.compiler.graph.Node cur
        end local 5 // org.graalvm.compiler.nodes.FixedNode end
        15: .line 845
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.LogicNode top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 8
        16: .line 855
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.LogicNode
      StackMap stack:
            return
        end local 4 // org.graalvm.compiler.nodes.LogicNode conditionNode
        end local 3 // org.graalvm.compiler.nodes.AbstractBeginNode trueBegin
        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   17     0           this  Lorg/graalvm/compiler/nodes/IfNode;
            0   17     1           tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            0   17     2          merge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            1   17     3      trueBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            2   17     4  conditionNode  Lorg/graalvm/compiler/nodes/LogicNode;
            9   15     5            end  Lorg/graalvm/compiler/nodes/FixedNode;
           10   15     7            cur  Lorg/graalvm/compiler/graph/Node;
    MethodParameters:
       Name  Flags
      tool   
      merge  

  private org.graalvm.compiler.nodes.ValueNode canonicalizeConditionalCascade(org.graalvm.compiler.graph.spi.SimplifierTool, org.graalvm.compiler.nodes.ValueNode, org.graalvm.compiler.nodes.ValueNode);
    descriptor: (Lorg/graalvm/compiler/graph/spi/SimplifierTool;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)Lorg/graalvm/compiler/nodes/ValueNode;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=12, args_size=4
        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.ValueNode trueValue
        start local 3 // org.graalvm.compiler.nodes.ValueNode falseValue
         0: .line 858
            aload 2 /* trueValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.getStackKind:()Ljdk/vm/ci/meta/JavaKind;
            aload 3 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.getStackKind:()Ljdk/vm/ci/meta/JavaKind;
            if_acmpeq 2
         1: .line 859
            aconst_null
            areturn
         2: .line 861
      StackMap locals:
      StackMap stack:
            aload 2 /* 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 2 /* 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 862
            aconst_null
            areturn
         4: .line 864
      StackMap locals:
      StackMap stack:
            aload 2 /* trueValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 6
            aload 3 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 6
         5: .line 865
            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 2 /* trueValue */
            aload 3 /* 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.ValueNode
            areturn
         6: .line 866
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.isAfterExpandLogic:()Z
            ifne 51
         7: .line 867
            aconst_null
            astore 4 /* conditional */
        start local 4 // org.graalvm.compiler.nodes.calc.ConditionalNode conditional
         8: .line 868
            aconst_null
            astore 5 /* constant */
        start local 5 // org.graalvm.compiler.nodes.ValueNode constant
         9: .line 870
            aload 2 /* trueValue */
            instanceof org.graalvm.compiler.nodes.calc.ConditionalNode
            ifeq 14
            aload 3 /* falseValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 14
        10: .line 871
            aload 2 /* trueValue */
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            astore 4 /* conditional */
        11: .line 872
            aload 3 /* falseValue */
            astore 5 /* constant */
        12: .line 873
            iconst_1
            istore 6 /* negateCondition */
        start local 6 // boolean negateCondition
        13: .line 874
            goto 20
        end local 6 // boolean negateCondition
      StackMap locals: org.graalvm.compiler.nodes.calc.ConditionalNode org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
        14: aload 3 /* falseValue */
            instanceof org.graalvm.compiler.nodes.calc.ConditionalNode
            ifeq 19
            aload 2 /* trueValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 19
        15: .line 875
            aload 3 /* falseValue */
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            astore 4 /* conditional */
        16: .line 876
            aload 2 /* trueValue */
            astore 5 /* constant */
        17: .line 877
            iconst_0
            istore 6 /* negateCondition */
        start local 6 // boolean negateCondition
        18: .line 878
            goto 20
        end local 6 // boolean negateCondition
        19: .line 879
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        start local 6 // boolean negateCondition
        20: .line 881
      StackMap locals: int
      StackMap stack:
            iconst_0
            istore 7 /* negateConditionalCondition */
        start local 7 // boolean negateConditionalCondition
        21: .line 882
            aconst_null
            astore 8 /* otherValue */
        start local 8 // org.graalvm.compiler.nodes.ValueNode otherValue
        22: .line 883
            aload 5 /* constant */
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 26
        23: .line 884
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.falseValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 8 /* otherValue */
        24: .line 885
            iconst_0
            istore 7 /* negateConditionalCondition */
        25: .line 886
            goto 29
      StackMap locals: int org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
        26: aload 5 /* constant */
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.falseValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 29
        27: .line 887
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 8 /* otherValue */
        28: .line 888
            iconst_1
            istore 7 /* negateConditionalCondition */
        29: .line 890
      StackMap locals:
      StackMap stack:
            aload 8 /* otherValue */
            ifnull 33
            aload 8 /* otherValue */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 33
        30: .line 891
            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 9 /* shortCutProbability */
        start local 9 // double shortCutProbability
        31: .line 892
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            iload 6 /* negateCondition */
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            iload 7 /* negateConditionalCondition */
            dload 9 /* 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 11 /* newCondition */
        start local 11 // org.graalvm.compiler.nodes.LogicNode newCondition
        32: .line 893
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.calc.ConditionalNode
            dup
            aload 11 /* newCondition */
            aload 5 /* constant */
            aload 8 /* 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.ValueNode
            areturn
        end local 11 // org.graalvm.compiler.nodes.LogicNode newCondition
        end local 9 // double shortCutProbability
        33: .line 894
      StackMap locals:
      StackMap stack:
            iload 6 /* negateCondition */
            ifne 51
            aload 5 /* constant */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isJavaConstant:()Z
            ifeq 51
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isJavaConstant:()Z
            ifeq 51
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.falseValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isJavaConstant:()Z
            ifeq 51
        34: .line 895
            aconst_null
            astore 9 /* lessThan */
        start local 9 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan
        35: .line 896
            aconst_null
            astore 10 /* equals */
        start local 10 // org.graalvm.compiler.nodes.calc.IntegerEqualsNode equals
        36: .line 897
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            ifeq 41
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.IntegerEqualsNode
            ifeq 41
            aload 5 /* constant */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asJavaConstant:()Ljdk/vm/ci/meta/JavaConstant;
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            ldc -1
            lcmp
            ifne 41
        37: .line 898
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asJavaConstant:()Ljdk/vm/ci/meta/JavaConstant;
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            lconst_0
            lcmp
            ifne 41
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.falseValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asJavaConstant:()Ljdk/vm/ci/meta/JavaConstant;
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            lconst_1
            lcmp
            ifne 41
        38: .line 899
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            astore 9 /* lessThan */
        39: .line 900
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerEqualsNode
            astore 10 /* equals */
        40: .line 901
            goto 45
      StackMap locals: org.graalvm.compiler.nodes.calc.IntegerLessThanNode org.graalvm.compiler.nodes.calc.IntegerEqualsNode
      StackMap stack:
        41: aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.IntegerEqualsNode
            ifeq 45
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            instanceof org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            ifeq 45
            aload 5 /* constant */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asJavaConstant:()Ljdk/vm/ci/meta/JavaConstant;
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            lconst_0
            lcmp
            ifne 45
        42: .line 902
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asJavaConstant:()Ljdk/vm/ci/meta/JavaConstant;
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            ldc -1
            lcmp
            ifne 45
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.falseValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            invokevirtual org.graalvm.compiler.nodes.ValueNode.asJavaConstant:()Ljdk/vm/ci/meta/JavaConstant;
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
            lconst_1
            lcmp
            ifne 45
        43: .line 903
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerLessThanNode
            astore 9 /* lessThan */
        44: .line 904
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.condition:()Lorg/graalvm/compiler/nodes/LogicNode;
            checkcast org.graalvm.compiler.nodes.calc.IntegerEqualsNode
            astore 10 /* equals */
        45: .line 906
      StackMap locals:
      StackMap stack:
            aload 9 /* lessThan */
            ifnull 51
        46: .line 907
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 47
            aload 10 /* equals */
            ifnonnull 47
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        47: .line 908
      StackMap locals:
      StackMap stack:
            aload 1 /* tool */
            invokestatic org.graalvm.compiler.nodes.NodeView.from:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;)Lorg/graalvm/compiler/nodes/NodeView;
            astore 11 /* view */
        start local 11 // org.graalvm.compiler.nodes.NodeView view
        48: .line 909
            aload 9 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 10 /* equals */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerEqualsNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 49
            aload 9 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 10 /* equals */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerEqualsNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpeq 50
      StackMap locals: org.graalvm.compiler.nodes.NodeView
      StackMap stack:
        49: aload 9 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 10 /* equals */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerEqualsNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 51
            aload 9 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 10 /* equals */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerEqualsNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            if_acmpne 51
        50: .line 910
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.calc.NormalizeCompareNode
            dup
            aload 9 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getX:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 9 /* lessThan */
            invokevirtual org.graalvm.compiler.nodes.calc.IntegerLessThanNode.getY:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            aload 11 /* view */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            invokevirtual org.graalvm.compiler.core.common.type.Stamp.getStackKind:()Ljdk/vm/ci/meta/JavaKind;
            iconst_0
            invokespecial org.graalvm.compiler.nodes.calc.NormalizeCompareNode.<init>:(Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;Ljdk/vm/ci/meta/JavaKind;Z)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.ValueNode
            areturn
        end local 11 // org.graalvm.compiler.nodes.NodeView view
        end local 10 // org.graalvm.compiler.nodes.calc.IntegerEqualsNode equals
        end local 9 // org.graalvm.compiler.nodes.calc.IntegerLessThanNode lessThan
        end local 8 // org.graalvm.compiler.nodes.ValueNode otherValue
        end local 7 // boolean negateConditionalCondition
        end local 6 // boolean negateCondition
        end local 5 // org.graalvm.compiler.nodes.ValueNode constant
        end local 4 // org.graalvm.compiler.nodes.calc.ConditionalNode conditional
        51: .line 915
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode
      StackMap stack:
            aconst_null
            areturn
        end local 3 // org.graalvm.compiler.nodes.ValueNode falseValue
        end local 2 // org.graalvm.compiler.nodes.ValueNode trueValue
        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   52     0                        this  Lorg/graalvm/compiler/nodes/IfNode;
            0   52     1                        tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            0   52     2                   trueValue  Lorg/graalvm/compiler/nodes/ValueNode;
            0   52     3                  falseValue  Lorg/graalvm/compiler/nodes/ValueNode;
            8   51     4                 conditional  Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
            9   51     5                    constant  Lorg/graalvm/compiler/nodes/ValueNode;
           13   14     6             negateCondition  Z
           18   19     6             negateCondition  Z
           20   51     6             negateCondition  Z
           21   51     7  negateConditionalCondition  Z
           22   51     8                  otherValue  Lorg/graalvm/compiler/nodes/ValueNode;
           31   33     9         shortCutProbability  D
           32   33    11                newCondition  Lorg/graalvm/compiler/nodes/LogicNode;
           35   51     9                    lessThan  Lorg/graalvm/compiler/nodes/calc/IntegerLessThanNode;
           36   51    10                      equals  Lorg/graalvm/compiler/nodes/calc/IntegerEqualsNode;
           48   51    11                        view  Lorg/graalvm/compiler/nodes/NodeView;
    MethodParameters:
            Name  Flags
      tool        
      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 927
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.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.areFrameStatesAtSideEffects:()Z
            ifeq 2
         1: .line 929
            iconst_0
            ireturn
         2: .line 932
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
            instanceof org.graalvm.compiler.nodes.MergeNode
            ifne 4
         3: .line 933
            iconst_0
            ireturn
         4: .line 935
      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
         5: .line 936
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.forwardEndCount:()I
            iconst_1
            if_icmpne 7
         6: .line 938
            iconst_0
            ireturn
         7: .line 940
      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 8
            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 9
         8: .line 941
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         9: .line 943
      StackMap locals:
      StackMap stack:
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnull 11
        10: .line 945
            iconst_0
            ireturn
        11: .line 947
      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
        12: .line 948
            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 14
        13: .line 953
            iconst_0
            ireturn
        14: .line 960
      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 16
        15: .line 961
            iconst_0
            ireturn
        16: .line 971
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* trueMerge */
        start local 4 // org.graalvm.compiler.nodes.MergeNode trueMerge
        17: .line 972
            aconst_null
            astore 5 /* falseMerge */
        start local 5 // org.graalvm.compiler.nodes.MergeNode falseMerge
        18: .line 973
            getstatic org.graalvm.compiler.nodes.IfNode.$assertionsDisabled:Z
            ifne 19
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnull 19
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        19: .line 975
      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 55
      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:
        20: 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
        21: .line 976
            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
        22: .line 977
            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
        23: .line 978
            aload 9 /* result */
            instanceof org.graalvm.compiler.nodes.LogicConstantNode
            ifeq 34
        24: .line 979
            aload 2 /* merge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.removeEnd:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)V
        25: .line 980
            aload 9 /* result */
            checkcast org.graalvm.compiler.nodes.LogicConstantNode
            invokevirtual org.graalvm.compiler.nodes.LogicConstantNode.getValue:()Z
            ifeq 30
        26: .line 981
            aload 4 /* trueMerge */
            ifnonnull 28
        27: .line 982
            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 */
        28: .line 984
      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
        29: .line 985
            goto 55
        30: .line 986
      StackMap locals:
      StackMap stack:
            aload 5 /* falseMerge */
            ifnonnull 32
        31: .line 987
            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 */
        32: .line 989
      StackMap locals:
      StackMap stack:
            aload 5 /* falseMerge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        33: .line 991
            goto 55
      StackMap locals:
      StackMap stack:
        34: aload 9 /* result */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            if_acmpeq 55
        35: .line 993
            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
        36: .line 994
            aload 10 /* trueBegin */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.BeginNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        37: .line 995
            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
        38: .line 996
            aload 11 /* falseBegin */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.BeginNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        39: .line 998
            aload 9 /* result */
            invokevirtual org.graalvm.compiler.nodes.LogicNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            ifnonnull 42
        40: .line 999
            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 */
        41: .line 1000
            aload 9 /* result */
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.condition:Lorg/graalvm/compiler/nodes/LogicNode;
            invokevirtual org.graalvm.compiler.nodes.LogicNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.LogicNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        42: .line 1002
      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
        43: .line 1003
            aload 12 /* newIfNode */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.IfNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        44: .line 1004
            aload 2 /* merge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.removeEnd:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)V
        45: .line 1005
            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
        46: .line 1007
            aload 4 /* trueMerge */
            ifnonnull 48
        47: .line 1008
            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 */
        48: .line 1010
      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
        49: .line 1011
            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
        50: .line 1013
            aload 5 /* falseMerge */
            ifnonnull 52
        51: .line 1014
            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 */
        52: .line 1016
      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
        53: .line 1017
            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
        54: .line 1019
            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
        55: .line 975
      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 20
        56: .line 1023
            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
        57: .line 1024
            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
        58: .line 1026
            aload 0 /* this */
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.cleanupMerge:(Lorg/graalvm/compiler/nodes/MergeNode;)V
        59: .line 1027
            aload 0 /* this */
            aload 4 /* trueMerge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.cleanupMerge:(Lorg/graalvm/compiler/nodes/MergeNode;)V
        60: .line 1028
            aload 0 /* this */
            aload 5 /* falseMerge */
            invokevirtual org.graalvm.compiler.nodes.IfNode.cleanupMerge:(Lorg/graalvm/compiler/nodes/MergeNode;)V
        61: .line 1030
            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   62     0        this  Lorg/graalvm/compiler/nodes/IfNode;
            0   62     1        tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            5   62     2       merge  Lorg/graalvm/compiler/nodes/MergeNode;
           12   62     3         phi  Lorg/graalvm/compiler/nodes/PhiNode;
           17   62     4   trueMerge  Lorg/graalvm/compiler/nodes/MergeNode;
           18   62     5  falseMerge  Lorg/graalvm/compiler/nodes/MergeNode;
           21   55     6         end  Lorg/graalvm/compiler/nodes/EndNode;
           22   55     8       value  Lorg/graalvm/compiler/graph/Node;
           23   55     9      result  Lorg/graalvm/compiler/nodes/LogicNode;
           36   55    10   trueBegin  Lorg/graalvm/compiler/nodes/BeginNode;
           38   55    11  falseBegin  Lorg/graalvm/compiler/nodes/BeginNode;
           43   55    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 1041
            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 1042
            iconst_0
            ireturn
         2: .line 1044
      StackMap locals:
      StackMap stack:
            aload 0 /* condition */
            instanceof org.graalvm.compiler.nodes.ShortCircuitOrNode
            ifeq 7
         3: .line 1045
            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 1052
            aload 0 /* condition */
            checkcast org.graalvm.compiler.nodes.ShortCircuitOrNode
            astore 2 /* orNode */
        start local 2 // org.graalvm.compiler.nodes.ShortCircuitOrNode orNode
         5: .line 1053
            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 1055
      StackMap locals:
      StackMap stack:
            aload 0 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable$Unary
            ifeq 11
         8: .line 1056
            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 1057
            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 1058
      StackMap locals:
      StackMap stack:
            aload 0 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable$Binary
            ifeq 15
        12: .line 1059
            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 1060
            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 1062
      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 1076
            aload 1 /* condition */
            instanceof org.graalvm.compiler.nodes.ShortCircuitOrNode
            ifeq 14
         1: .line 1077
            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
            aload 1 /* condition */
            invokevirtual org.graalvm.compiler.nodes.LogicNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.isAfterExpandLogic:()Z
            ifne 24
         2: .line 1078
            aload 1 /* condition */
            checkcast org.graalvm.compiler.nodes.ShortCircuitOrNode
            astore 4 /* orNode */
        start local 4 // org.graalvm.compiler.nodes.ShortCircuitOrNode orNode
         3: .line 1079
            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 1080
            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 1081
            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 1082
      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 1083
            aload 7 /* result */
            aload 4 /* orNode */
            if_acmpeq 9
         8: .line 1084
            aload 7 /* result */
            areturn
         9: .line 1089
      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 1090
            aload 4 /* orNode */
            getfield org.graalvm.compiler.nodes.ShortCircuitOrNode.yNegated:Z
            aload 4 /* orNode */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.getShortCircuitProbability:()D
        11: .line 1089
            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 1091
            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 1093
      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 1095
      StackMap locals:
      StackMap stack:
            aload 1 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable$Binary
            ifeq 20
        15: .line 1096
            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 1097
            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 1098
            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 1099
      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 1100
            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 1102
      StackMap locals:
      StackMap stack:
            aload 1 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable$Unary
            ifeq 24
        21: .line 1103
            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 1104
            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 1105
            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 1108
      StackMap locals:
      StackMap stack:
            aload 1 /* condition */
            instanceof org.graalvm.compiler.graph.spi.Canonicalizable
            ifeq 26
        25: .line 1109
            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 1111
      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 1115
            aload 0 /* successor */
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 6
            aload 1 /* falseMerge */
            ifnull 6
         1: .line 1116
            aload 0 /* successor */
            checkcast org.graalvm.compiler.nodes.LoopExitNode
            astore 2 /* loopExitNode */
        start local 2 // org.graalvm.compiler.nodes.LoopExitNode loopExitNode
         2: .line 1117
            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 1118
            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 1117
      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 1121
      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.nodes.MergeNode);
    descriptor: (Lorg/graalvm/compiler/nodes/MergeNode;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.MergeNode merge
         0: .line 1124
            aload 1 /* merge */
            ifnull 6
            aload 1 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.isAlive:()Z
            ifeq 6
         1: .line 1125
            aload 1 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.forwardEndCount:()I
            ifne 4
         2: .line 1126
            aload 1 /* merge */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
         3: .line 1127
            goto 6
      StackMap locals:
      StackMap stack:
         4: aload 1 /* merge */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.forwardEndCount:()I
            iconst_1
            if_icmpne 6
         5: .line 1128
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            aload 1 /* merge */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.reduceTrivialMerge:(Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
         6: .line 1131
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.graalvm.compiler.nodes.MergeNode merge
        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  merge  Lorg/graalvm/compiler/nodes/MergeNode;
    MethodParameters:
       Name  Flags
      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=7, args_size=2
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.AbstractBeginNode begin
         0: .line 1135
            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 1136
            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 1137
            aconst_null
            astore 3 /* before */
        start local 3 // java.lang.Object before
         3: .line 1138
            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 1139
            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 1140
            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 1141
            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 1144
      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 1145
            aload 1 /* begin */
            instanceof org.graalvm.compiler.nodes.LoopExitNode
            ifeq 20
         9: .line 1147
            aconst_null
            astore 4
            aconst_null
            astore 5
        10: aload 1 /* begin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.withNodeSourcePosition:()Lorg/graalvm/compiler/debug/DebugCloseable;
            astore 6 /* position */
        start local 6 // org.graalvm.compiler.debug.DebugCloseable position
        11: .line 1148
            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 */
        12: .line 1149
            aload 1 /* begin */
            aload 3 /* theBegin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        13: .line 1150
            aload 3 /* theBegin */
            aload 1 /* begin */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        14: .line 1151
            aload 6 /* position */
            ifnull 20
            aload 6 /* position */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
            goto 20
      StackMap locals: org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.MergeNode org.graalvm.compiler.nodes.AbstractBeginNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable
      StackMap stack: java.lang.Throwable
        15: astore 4
            aload 6 /* position */
            ifnull 16
            aload 6 /* position */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
        end local 6 // org.graalvm.compiler.debug.DebugCloseable position
      StackMap locals:
      StackMap stack:
        16: aload 4
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        17: astore 5
            aload 4
            ifnonnull 18
            aload 5
            astore 4
            goto 19
      StackMap locals:
      StackMap stack:
        18: aload 4
            aload 5
            if_acmpeq 19
            aload 4
            aload 5
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        19: aload 4
            athrow
        20: .line 1153
      StackMap locals:
      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
        21: .line 1154
            aload 4 /* next */
            aload 2 /* merge */
            invokevirtual org.graalvm.compiler.nodes.FixedNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        22: .line 1155
            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
        23: .line 1156
            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
        24: .line 1157
            aload 2 /* merge */
            aload 4 /* next */
            invokevirtual org.graalvm.compiler.nodes.MergeNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        25: .line 1158
            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   26     0      this  Lorg/graalvm/compiler/nodes/IfNode;
            0   26     1     begin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            1   26     2     merge  Lorg/graalvm/compiler/nodes/MergeNode;
            3    7     3    before  Ljava/lang/Object;
            8   26     3  theBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           11   16     6  position  Lorg/graalvm/compiler/debug/DebugCloseable;
           21   26     4      next  Lorg/graalvm/compiler/nodes/FixedNode;
      Exception table:
        from    to  target  type
          11    14      15  any
          10    17      17  any
    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 1207
            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 1208
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         2: .line 1210
      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 1212
            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 1213
            iconst_0
            ireturn
         5: .line 1216
      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 1217
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.getUsageCount:()I
            iconst_1
            if_icmpeq 8
         7: .line 1218
            iconst_0
            ireturn
         8: .line 1223
      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 1224
            aload 4 /* mergeUsages */
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_1
            if_icmpeq 11
        10: .line 1225
            iconst_0
            ireturn
        11: .line 1227
      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 1228
            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 1229
      StackMap locals: org.graalvm.compiler.graph.Node
      StackMap stack:
            iconst_0
            ireturn
        14: .line 1233
      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 1234
            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 1235
            aload 7 /* phiUsages */
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
            iconst_2
            if_icmple 18
        17: .line 1236
            iconst_0
            ireturn
        18: .line 1238
      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 1239
            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 1240
            iconst_0
            ireturn
        end local 8 // org.graalvm.compiler.graph.Node usage
        22: .line 1238
      StackMap locals:
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 19
        23: .line 1244
            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 1245
            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 1247
      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 1248
            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 1249
            aload 9 /* xs */
            ifnull 28
            aload 10 /* ys */
            ifnonnull 29
        28: .line 1250
      StackMap locals: jdk.vm.ci.meta.Constant[] jdk.vm.ci.meta.Constant[]
      StackMap stack:
            iconst_0
            ireturn
        29: .line 1254
      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 1255
            iconst_0
            ireturn
        31: .line 1258
      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 1259
            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 1260
            getstatic jdk.internal.vm.compiler.collections.Equivalence.IDENTITY:Ljdk/internal/vm/compiler/collections/Equivalence;
            aload 8 /* mergePredecessors */
            invokeinterface java.util.List.size:()I
            invokestatic jdk.internal.vm.compiler.collections.EconomicMap.create:(Ljdk/internal/vm/compiler/collections/Equivalence;I)Ljdk/internal/vm/compiler/collections/EconomicMap;
            astore 13 /* phiValues */
        start local 13 // jdk.internal.vm.compiler.collections.EconomicMap phiValues
        34: .line 1262
            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 1263
            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 1265
            aload 0 /* this */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setFalseSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        37: .line 1266
            aload 0 /* this */
            aconst_null
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessor:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
        38: .line 1268
            aload 8 /* mergePredecessors */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 16 /* ends */
        start local 16 // java.util.Iterator ends
        39: .line 1269
            iconst_0
            istore 17 /* i */
        start local 17 // int i
        40: goto 48
        41: .line 1270
      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 jdk.internal.vm.compiler.collections.EconomicMap 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 1271
            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 jdk.internal.vm.compiler.collections.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        43: .line 1272
            aload 3 /* compare */
            invokevirtual org.graalvm.compiler.nodes.calc.CompareNode.condition:()Lorg/graalvm/compiler/core/common/calc/CanonicalCondition;
            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.CanonicalCondition.foldCondition:(Ljdk/vm/ci/meta/Constant;Ljdk/vm/ci/meta/Constant;Ljdk/vm/ci/meta/ConstantReflectionProvider;Z)Z
            ifeq 46
        44: .line 1273
            aload 12 /* trueEnds */
            aload 18 /* end */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        45: .line 1274
            goto 47
        46: .line 1275
      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 1269
      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 1278
            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 1279
      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 1281
      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;Ljdk/internal/vm/compiler/collections/EconomicMap;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        52: .line 1282
            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;Ljdk/internal/vm/compiler/collections/EconomicMap;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractMergeNode;Lorg/graalvm/compiler/graph/spi/SimplifierTool;)V
        53: .line 1284
            aload 0 /* this */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_0
            dcmpl
            ifne 58
        54: .line 1285
            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 jdk.internal.vm.compiler.collections.EconomicMap 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 1286
            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 1285
      StackMap locals:
      StackMap stack:
            aload 18
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 55
        58: .line 1290
      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 jdk.internal.vm.compiler.collections.EconomicMap 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 1291
            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 jdk.internal.vm.compiler.collections.EconomicMap 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 1292
            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 1291
      StackMap locals:
      StackMap stack:
            aload 18
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 60
        63: .line 1300
      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 jdk.internal.vm.compiler.collections.EconomicMap 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 1301
            aload 14 /* oldFalseSuccessor */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        65: .line 1303
      StackMap locals:
      StackMap stack:
            aload 12 /* trueEnds */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 67
        66: .line 1304
            aload 15 /* oldTrueSuccessor */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        67: .line 1306
      StackMap locals:
      StackMap stack:
            aload 2 /* merge */
            invokestatic org.graalvm.compiler.nodes.util.GraphUtil.killCFG:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        68: .line 1308
            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 1309
      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 1310
      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 1311
      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 1313
      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 // jdk.internal.vm.compiler.collections.EconomicMap 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  Ljdk/internal/vm/compiler/collections/EconomicMap<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 1317
            aconst_null
            astore 2 /* prev */
        start local 2 // org.graalvm.compiler.graph.Node prev
         1: .line 1318
            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 1319
            aload 3 /* node */
            instanceof org.graalvm.compiler.nodes.IfNode
            ifeq 20
         4: .line 1320
            aload 3 /* node */
            checkcast org.graalvm.compiler.nodes.IfNode
            astore 5 /* ifNode */
        start local 5 // org.graalvm.compiler.nodes.IfNode ifNode
         5: .line 1321
            aload 5 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            aload 2 /* prev */
            if_acmpne 12
         6: .line 1322
            aload 5 /* ifNode */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_0
            dcmpl
            ifne 8
         7: .line 1323
            return
         8: .line 1324
      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 1325
            goto 27
        10: .line 1327
      StackMap locals:
      StackMap stack:
            aload 5 /* ifNode */
            dconst_0
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        11: .line 1328
            return
        12: .line 1330
      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 1331
            aload 5 /* ifNode */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_1
            dcmpl
            ifne 15
        14: .line 1332
            return
        15: .line 1333
      StackMap locals:
      StackMap stack:
            aload 5 /* ifNode */
            getfield org.graalvm.compiler.nodes.IfNode.trueSuccessorProbability:D
            dconst_0
            dcmpl
            ifne 17
        16: .line 1334
            goto 27
        17: .line 1336
      StackMap locals:
      StackMap stack:
            aload 5 /* ifNode */
            dconst_1
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
        18: .line 1337
            return
        19: .line 1340
      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 1342
      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 1343
            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 1344
            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 1343
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 22
        25: .line 1346
            return
        26: .line 1348
      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 1318
      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 1350
            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 1353
            aload 0 /* start */
            astore 1 /* node */
        start local 1 // org.graalvm.compiler.nodes.FixedNode node
         1: .line 1355
      StackMap locals: org.graalvm.compiler.nodes.FixedNode
      StackMap stack:
            aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.AbstractMergeNode
            ifeq 6
         2: .line 1356
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.AbstractMergeNode
            astore 2 /* mergeNode */
        start local 2 // org.graalvm.compiler.nodes.AbstractMergeNode mergeNode
         3: .line 1357
            aload 2 /* mergeNode */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnonnull 5
         4: .line 1358
            iconst_0
            ireturn
         5: .line 1360
      StackMap locals: org.graalvm.compiler.nodes.AbstractMergeNode
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // org.graalvm.compiler.nodes.AbstractMergeNode mergeNode
         6: .line 1362
      StackMap locals:
      StackMap stack:
            aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.StateSplit
            ifeq 10
         7: .line 1363
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.StateSplit
            astore 2 /* stateSplitNode */
        start local 2 // org.graalvm.compiler.nodes.StateSplit stateSplitNode
         8: .line 1364
            aload 2 /* stateSplitNode */
            invokeinterface org.graalvm.compiler.nodes.StateSplit.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            ifnull 10
         9: .line 1365
            iconst_1
            ireturn
        end local 2 // org.graalvm.compiler.nodes.StateSplit stateSplitNode
        10: .line 1369
      StackMap locals:
      StackMap stack:
            aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.ControlSplitNode
            ifeq 18
        11: .line 1370
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.ControlSplitNode
            astore 2 /* controlSplitNode */
        start local 2 // org.graalvm.compiler.nodes.ControlSplitNode controlSplitNode
        12: .line 1371
            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 1372
            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 1373
            iconst_1
            ireturn
        end local 3 // org.graalvm.compiler.graph.Node succ
        16: .line 1371
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        17: .line 1376
            iconst_0
            ireturn
        end local 2 // org.graalvm.compiler.nodes.ControlSplitNode controlSplitNode
        18: .line 1377
      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 1378
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.FixedWithNextNode
            astore 2 /* fixedWithNextNode */
        start local 2 // org.graalvm.compiler.nodes.FixedWithNextNode fixedWithNextNode
        20: .line 1379
            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 1380
            goto 1
      StackMap locals:
      StackMap stack:
        22: aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.AbstractEndNode
            ifeq 26
        23: .line 1381
            aload 1 /* node */
            checkcast org.graalvm.compiler.nodes.AbstractEndNode
            astore 2 /* endNode */
        start local 2 // org.graalvm.compiler.nodes.AbstractEndNode endNode
        24: .line 1382
            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 1383
            goto 1
      StackMap locals:
      StackMap stack:
        26: aload 1 /* node */
            instanceof org.graalvm.compiler.nodes.ControlSinkNode
            ifeq 28
        27: .line 1384
            iconst_1
            ireturn
        28: .line 1386
      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>, jdk.internal.vm.compiler.collections.EconomicMap<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;Ljdk/internal/vm/compiler/collections/EconomicMap;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=12, args_size=6
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // java.util.List ends
        start local 2 // jdk.internal.vm.compiler.collections.EconomicMap 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 1400
            aload 1 /* ends */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 23
         1: .line 1401
            aload 1 /* ends */
            invokeinterface java.util.List.size:()I
            iconst_1
            if_icmpne 7
         2: .line 1402
            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 1403
            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 1404
            aload 4 /* oldMerge */
            aload 6 /* end */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.removeEnd:(Lorg/graalvm/compiler/nodes/AbstractEndNode;)V
         5: .line 1405
            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 1406
            goto 22
         7: .line 1409
      StackMap locals:
      StackMap stack:
            aload 5 /* tool */
            invokestatic org.graalvm.compiler.nodes.NodeView.from:(Lorg/graalvm/compiler/graph/spi/CanonicalizerTool;)Lorg/graalvm/compiler/nodes/NodeView;
            astore 6 /* view */
        start local 6 // org.graalvm.compiler.nodes.NodeView view
         8: .line 1410
            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 7 /* newMerge */
        start local 7 // org.graalvm.compiler.nodes.AbstractMergeNode newMerge
         9: .line 1411
            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 8 /* oldPhi */
        start local 8 // org.graalvm.compiler.nodes.PhiNode oldPhi
        10: .line 1412
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            new org.graalvm.compiler.nodes.ValuePhiNode
            dup
            aload 8 /* oldPhi */
            aload 6 /* view */
            invokevirtual org.graalvm.compiler.nodes.PhiNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            aload 7 /* 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 9 /* newPhi */
        start local 9 // org.graalvm.compiler.nodes.PhiNode newPhi
        11: .line 1414
            aload 1 /* ends */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 11
            goto 15
      StackMap locals: org.graalvm.compiler.nodes.IfNode java.util.List jdk.internal.vm.compiler.collections.EconomicMap org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.NodeView org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.PhiNode top java.util.Iterator
      StackMap stack:
        12: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 10 /* end */
        start local 10 // org.graalvm.compiler.nodes.EndNode end
        13: .line 1415
            aload 9 /* newPhi */
            aload 2 /* phiValues */
            aload 10 /* end */
            invokeinterface jdk.internal.vm.compiler.collections.EconomicMap.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
        14: .line 1416
            aload 7 /* newMerge */
            aload 10 /* end */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        end local 10 // org.graalvm.compiler.nodes.EndNode end
        15: .line 1414
      StackMap locals:
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        16: .line 1419
            aload 4 /* oldMerge */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.stateAfter:()Lorg/graalvm/compiler/nodes/FrameState;
            astore 10 /* stateAfter */
        start local 10 // org.graalvm.compiler.nodes.FrameState stateAfter
        17: .line 1420
            aload 10 /* stateAfter */
            ifnull 21
        18: .line 1421
            aload 10 /* stateAfter */
            invokevirtual org.graalvm.compiler.nodes.FrameState.duplicate:()Lorg/graalvm/compiler/nodes/FrameState;
            astore 10 /* stateAfter */
        19: .line 1422
            aload 10 /* stateAfter */
            aload 8 /* oldPhi */
            aload 9 /* newPhi */
            invokevirtual org.graalvm.compiler.nodes.FrameState.replaceFirstInput:(Lorg/graalvm/compiler/graph/Node;Lorg/graalvm/compiler/graph/Node;)V
        20: .line 1423
            aload 7 /* newMerge */
            aload 10 /* stateAfter */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.setStateAfter:(Lorg/graalvm/compiler/nodes/FrameState;)V
        21: .line 1426
      StackMap locals: org.graalvm.compiler.nodes.IfNode java.util.List jdk.internal.vm.compiler.collections.EconomicMap org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.graph.spi.SimplifierTool org.graalvm.compiler.nodes.NodeView org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.PhiNode org.graalvm.compiler.nodes.FrameState
      StackMap stack:
            aload 7 /* newMerge */
            aload 3 /* successor */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        end local 10 // org.graalvm.compiler.nodes.FrameState stateAfter
        end local 9 // org.graalvm.compiler.nodes.PhiNode newPhi
        end local 8 // org.graalvm.compiler.nodes.PhiNode oldPhi
        end local 7 // org.graalvm.compiler.nodes.AbstractMergeNode newMerge
        end local 6 // org.graalvm.compiler.nodes.NodeView view
        22: .line 1428
      StackMap locals: org.graalvm.compiler.nodes.IfNode java.util.List jdk.internal.vm.compiler.collections.EconomicMap 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
        23: .line 1430
      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 // jdk.internal.vm.compiler.collections.EconomicMap phiValues
        end local 1 // java.util.List ends
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   24     0        this  Lorg/graalvm/compiler/nodes/IfNode;
            0   24     1        ends  Ljava/util/List<Lorg/graalvm/compiler/nodes/EndNode;>;
            0   24     2   phiValues  Ljdk/internal/vm/compiler/collections/EconomicMap<Lorg/graalvm/compiler/nodes/AbstractEndNode;Lorg/graalvm/compiler/nodes/ValueNode;>;
            0   24     3   successor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            0   24     4    oldMerge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
            0   24     5        tool  Lorg/graalvm/compiler/graph/spi/SimplifierTool;
            3    6     6         end  Lorg/graalvm/compiler/nodes/AbstractEndNode;
            8   22     6        view  Lorg/graalvm/compiler/nodes/NodeView;
            9   22     7    newMerge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
           10   22     8      oldPhi  Lorg/graalvm/compiler/nodes/PhiNode;
           11   22     9      newPhi  Lorg/graalvm/compiler/nodes/PhiNode;
           13   15    10         end  Lorg/graalvm/compiler/nodes/EndNode;
           17   22    10  stateAfter  Lorg/graalvm/compiler/nodes/FrameState;
    Signature: (Ljava/util/List<Lorg/graalvm/compiler/nodes/EndNode;>;Ljdk/internal/vm/compiler/collections/EconomicMap<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 1441
            aload 0 /* node */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifeq 4
         1: .line 1442
            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 1443
            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 1444
            aload 3 /* result */
            areturn
        end local 3 // jdk.vm.ci.meta.Constant[] result
         4: .line 1447
      StackMap locals:
      StackMap stack:
            aload 0 /* node */
            instanceof org.graalvm.compiler.nodes.PhiNode
            ifeq 16
         5: .line 1448
            aload 0 /* node */
            checkcast org.graalvm.compiler.nodes.PhiNode
            astore 3 /* phi */
        start local 3 // org.graalvm.compiler.nodes.PhiNode phi
         6: .line 1449
            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 1450
            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 1451
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         9: .line 1452
            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 1453
            iload 2 /* allowNull */
            ifne 13
            aload 6 /* n */
            invokevirtual org.graalvm.compiler.nodes.ValueNode.isConstant:()Z
            ifne 13
        12: .line 1454
            aconst_null
            areturn
        13: .line 1456
      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 1452
      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 1458
            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 1462
      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 1467
            aconst_null
            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 1471
            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  

  public boolean setProbability(org.graalvm.compiler.nodes.AbstractBeginNode, double);
    descriptor: (Lorg/graalvm/compiler/nodes/AbstractBeginNode;D)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.graalvm.compiler.nodes.IfNode this
        start local 1 // org.graalvm.compiler.nodes.AbstractBeginNode successor
        start local 2 // double value
         0: .line 1476
            aload 1 /* successor */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            if_acmpne 3
         1: .line 1477
            aload 0 /* this */
            dload 2 /* value */
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
         2: .line 1478
            iconst_1
            ireturn
         3: .line 1479
      StackMap locals:
      StackMap stack:
            aload 1 /* successor */
            aload 0 /* this */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            if_acmpne 6
         4: .line 1480
            aload 0 /* this */
            dconst_1
            dload 2 /* value */
            dsub
            invokevirtual org.graalvm.compiler.nodes.IfNode.setTrueSuccessorProbability:(D)V
         5: .line 1481
            iconst_1
            ireturn
         6: .line 1483
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // double value
        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    7     0       this  Lorg/graalvm/compiler/nodes/IfNode;
            0    7     1  successor  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            0    7     2      value  D
    MethodParameters:
           Name  Flags
      successor  
      value      

  public int getSuccessorCount();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.nodes.IfNode this
         0: .line 1488
            iconst_2
            ireturn
        end local 0 // org.graalvm.compiler.nodes.IfNode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/nodes/IfNode;
}
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_1:Lorg/graalvm/compiler/nodeinfo/NodeCycles;, size = org.graalvm.compiler.nodeinfo.NodeSize.SIZE_2:Lorg/graalvm/compiler/nodeinfo/NodeSize;, sizeRationale = "2 jmps")