abstract class org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp extends org.graalvm.compiler.lir.amd64.AMD64LIRInstruction
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp
  super_class: org.graalvm.compiler.lir.amd64.AMD64LIRInstruction
{
  protected jdk.vm.ci.meta.AllocatableValue result;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Def(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;, org.graalvm.compiler.lir.LIRInstruction$OperandFlag.HINT:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  protected jdk.vm.ci.meta.AllocatableValue input;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Use(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  protected void <init>(org.graalvm.compiler.lir.LIRInstructionClass<? extends org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp>, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue);
    descriptor: (Lorg/graalvm/compiler/lir/LIRInstructionClass;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/AllocatableValue;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp this
        start local 1 // org.graalvm.compiler.lir.LIRInstructionClass type
        start local 2 // jdk.vm.ci.meta.AllocatableValue result
        start local 3 // jdk.vm.ci.meta.AllocatableValue input
         0: .line 951
            aload 0 /* this */
            aload 1 /* type */
            invokespecial org.graalvm.compiler.lir.amd64.AMD64LIRInstruction.<init>:(Lorg/graalvm/compiler/lir/LIRInstructionClass;)V
         1: .line 952
            aload 0 /* this */
            aload 2 /* result */
            putfield org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp.result:Ljdk/vm/ci/meta/AllocatableValue;
         2: .line 953
            aload 0 /* this */
            aload 3 /* input */
            putfield org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp.input:Ljdk/vm/ci/meta/AllocatableValue;
         3: .line 954
            return
        end local 3 // jdk.vm.ci.meta.AllocatableValue input
        end local 2 // jdk.vm.ci.meta.AllocatableValue result
        end local 1 // org.graalvm.compiler.lir.LIRInstructionClass type
        end local 0 // org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/graalvm/compiler/lir/amd64/AMD64Move$ZeroNullConversionOp;
            0    4     1    type  Lorg/graalvm/compiler/lir/LIRInstructionClass<+Lorg/graalvm/compiler/lir/amd64/AMD64Move$ZeroNullConversionOp;>;
            0    4     2  result  Ljdk/vm/ci/meta/AllocatableValue;
            0    4     3   input  Ljdk/vm/ci/meta/AllocatableValue;
    Signature: (Lorg/graalvm/compiler/lir/LIRInstructionClass<+Lorg/graalvm/compiler/lir/amd64/AMD64Move$ZeroNullConversionOp;>;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/AllocatableValue;)V
    MethodParameters:
        Name  Flags
      type    
      result  
      input   

  public void emitCode(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.amd64.AMD64MacroAssembler);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/amd64/AMD64MacroAssembler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.amd64.AMD64MacroAssembler masm
         0: .line 958
            aload 1 /* crb */
            getfield org.graalvm.compiler.lir.asm.CompilationResultBuilder.uncompressedNullRegister:Ljdk/vm/ci/code/Register;
            astore 3 /* nullRegister */
        start local 3 // jdk.vm.ci.code.Register nullRegister
         1: .line 959
            aload 3 /* nullRegister */
            getstatic jdk.vm.ci.code.Register.None:Ljdk/vm/ci/code/Register;
            invokevirtual jdk.vm.ci.code.Register.equals:(Ljava/lang/Object;)Z
            ifne 3
         2: .line 960
            aload 0 /* this */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp.input:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            aload 3 /* nullRegister */
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp.emitConversion:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64MacroAssembler;)V
         3: .line 962
      StackMap locals: jdk.vm.ci.code.Register
      StackMap stack:
            return
        end local 3 // jdk.vm.ci.code.Register nullRegister
        end local 2 // org.graalvm.compiler.asm.amd64.AMD64MacroAssembler masm
        end local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        end local 0 // org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    4     0          this  Lorg/graalvm/compiler/lir/amd64/AMD64Move$ZeroNullConversionOp;
            0    4     1           crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0    4     2          masm  Lorg/graalvm/compiler/asm/amd64/AMD64MacroAssembler;
            1    4     3  nullRegister  Ljdk/vm/ci/code/Register;
    MethodParameters:
      Name  Flags
      crb   
      masm  

  protected abstract void emitConversion(jdk.vm.ci.code.Register, jdk.vm.ci.code.Register, jdk.vm.ci.code.Register, org.graalvm.compiler.asm.amd64.AMD64MacroAssembler);
    descriptor: (Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64MacroAssembler;)V
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    MethodParameters:
                Name  Flags
      resultRegister  
      inputRegister   
      nullRegister    
      masm            
}
SourceFile: "AMD64Move.java"
NestHost: org.graalvm.compiler.lir.amd64.AMD64Move
InnerClasses:
  public abstract Def = org.graalvm.compiler.lir.LIRInstruction$Def of org.graalvm.compiler.lir.LIRInstruction
  public final OperandFlag = org.graalvm.compiler.lir.LIRInstruction$OperandFlag of org.graalvm.compiler.lir.LIRInstruction
  public abstract Use = org.graalvm.compiler.lir.LIRInstruction$Use of org.graalvm.compiler.lir.LIRInstruction
  private abstract ZeroNullConversionOp = org.graalvm.compiler.lir.amd64.AMD64Move$ZeroNullConversionOp of org.graalvm.compiler.lir.amd64.AMD64Move