abstract class org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp extends org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction implements org.graalvm.compiler.lir.StandardOp$ImplicitNullCheck
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp
  super_class: org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction
{
  protected final jdk.vm.ci.aarch64.AArch64Kind kind;
    descriptor: Ljdk/vm/ci/aarch64/AArch64Kind;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected org.graalvm.compiler.lir.aarch64.AArch64AddressValue addressValue;
    descriptor: Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Use(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.COMPOSITE:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  protected org.graalvm.compiler.lir.LIRFrameState state;
    descriptor: Lorg/graalvm/compiler/lir/LIRFrameState;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$State()

  void <init>(org.graalvm.compiler.lir.LIRInstructionClass<? extends org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp>, jdk.vm.ci.aarch64.AArch64Kind, org.graalvm.compiler.lir.aarch64.AArch64AddressValue, org.graalvm.compiler.lir.LIRFrameState);
    descriptor: (Lorg/graalvm/compiler/lir/LIRInstructionClass;Ljdk/vm/ci/aarch64/AArch64Kind;Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;Lorg/graalvm/compiler/lir/LIRFrameState;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=5, args_size=5
        start local 0 // org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp this
        start local 1 // org.graalvm.compiler.lir.LIRInstructionClass c
        start local 2 // jdk.vm.ci.aarch64.AArch64Kind kind
        start local 3 // org.graalvm.compiler.lir.aarch64.AArch64AddressValue address
        start local 4 // org.graalvm.compiler.lir.LIRFrameState state
         0: .line 248
            aload 0 /* this */
            aload 1 /* c */
            invokespecial org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction.<init>:(Lorg/graalvm/compiler/lir/LIRInstructionClass;)V
         1: .line 249
            aload 0 /* this */
            aload 2 /* kind */
            putfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.kind:Ljdk/vm/ci/aarch64/AArch64Kind;
         2: .line 250
            aload 0 /* this */
            aload 3 /* address */
            putfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.addressValue:Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;
         3: .line 251
            aload 0 /* this */
            aload 4 /* state */
            putfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
         4: .line 252
            return
        end local 4 // org.graalvm.compiler.lir.LIRFrameState state
        end local 3 // org.graalvm.compiler.lir.aarch64.AArch64AddressValue address
        end local 2 // jdk.vm.ci.aarch64.AArch64Kind kind
        end local 1 // org.graalvm.compiler.lir.LIRInstructionClass c
        end local 0 // org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lorg/graalvm/compiler/lir/aarch64/AArch64Move$MemOp;
            0    5     1        c  Lorg/graalvm/compiler/lir/LIRInstructionClass<+Lorg/graalvm/compiler/lir/aarch64/AArch64Move$MemOp;>;
            0    5     2     kind  Ljdk/vm/ci/aarch64/AArch64Kind;
            0    5     3  address  Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;
            0    5     4    state  Lorg/graalvm/compiler/lir/LIRFrameState;
    Signature: (Lorg/graalvm/compiler/lir/LIRInstructionClass<+Lorg/graalvm/compiler/lir/aarch64/AArch64Move$MemOp;>;Ljdk/vm/ci/aarch64/AArch64Kind;Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;Lorg/graalvm/compiler/lir/LIRFrameState;)V
    MethodParameters:
         Name  Flags
      c        
      kind     
      address  
      state    

  protected abstract void emitMemAccess(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;)V
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    MethodParameters:
      Name  Flags
      crb   
      masm  

  public void emitCode(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler masm
         0: .line 258
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.position:()I
            istore 3 /* prePosition */
        start local 3 // int prePosition
         1: .line 259
            aload 0 /* this */
            aload 1 /* crb */
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.emitMemAccess:(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;)V
         2: .line 260
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
            ifnull 9
         3: .line 261
            iload 3 /* prePosition */
            istore 4 /* implicitExceptionPosition */
        start local 4 // int implicitExceptionPosition
         4: .line 263
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.kind:Ljdk/vm/ci/aarch64/AArch64Kind;
            invokevirtual jdk.vm.ci.aarch64.AArch64Kind.isInteger:()Z
            ifeq 8
            iload 3 /* prePosition */
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.position:()I
            if_icmpne 8
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.isImmLoadStoreMerged:()Z
            ifeq 8
         5: .line 264
            iload 3 /* prePosition */
            iconst_4
            isub
            istore 4 /* implicitExceptionPosition */
         6: .line 265
            aload 1 /* crb */
            iload 4 /* implicitExceptionPosition */
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isImplicitExceptionExist:(I)Z
            ifeq 8
         7: .line 266
            return
         8: .line 269
      StackMap locals: int int
      StackMap stack:
            aload 1 /* crb */
            iload 4 /* implicitExceptionPosition */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.recordImplicitException:(ILorg/graalvm/compiler/lir/LIRFrameState;)V
        end local 4 // int implicitExceptionPosition
         9: .line 271
      StackMap locals:
      StackMap stack:
            return
        end local 3 // int prePosition
        end local 2 // org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler masm
        end local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        end local 0 // org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp this
      LocalVariableTable:
        Start  End  Slot                       Name  Signature
            0   10     0                       this  Lorg/graalvm/compiler/lir/aarch64/AArch64Move$MemOp;
            0   10     1                        crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   10     2                       masm  Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;
            1   10     3                prePosition  I
            4    9     4  implicitExceptionPosition  I
    MethodParameters:
      Name  Flags
      crb   
      masm  

  public boolean makeNullCheckFor(jdk.vm.ci.meta.Value, org.graalvm.compiler.lir.LIRFrameState, int);
    descriptor: (Ljdk/vm/ci/meta/Value;Lorg/graalvm/compiler/lir/LIRFrameState;I)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=4
        start local 0 // org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp this
        start local 1 // jdk.vm.ci.meta.Value value
        start local 2 // org.graalvm.compiler.lir.LIRFrameState nullCheckState
        start local 3 // int implicitNullCheckLimit
         0: .line 275
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.addressValue:Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;
            invokevirtual org.graalvm.compiler.lir.aarch64.AArch64AddressValue.getDisplacement:()I
            istore 4 /* displacement */
        start local 4 // int displacement
         1: .line 276
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
            ifnonnull 4
            aload 1 /* value */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.addressValue:Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;
            invokevirtual org.graalvm.compiler.lir.aarch64.AArch64AddressValue.getBase:()Ljdk/vm/ci/meta/AllocatableValue;
            invokevirtual jdk.vm.ci.meta.Value.equals:(Ljava/lang/Object;)Z
            ifeq 4
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.addressValue:Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;
            invokevirtual org.graalvm.compiler.lir.aarch64.AArch64AddressValue.getOffset:()Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.meta.Value.ILLEGAL:Ljdk/vm/ci/meta/AllocatableValue;
            invokevirtual jdk.vm.ci.meta.AllocatableValue.equals:(Ljava/lang/Object;)Z
            ifeq 4
            iload 4 /* displacement */
            iflt 4
            iload 4 /* displacement */
            iload 3 /* implicitNullCheckLimit */
            if_icmpge 4
         2: .line 277
            aload 0 /* this */
            aload 2 /* nullCheckState */
            putfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
         3: .line 278
            iconst_1
            ireturn
         4: .line 280
      StackMap locals: int
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // int displacement
        end local 3 // int implicitNullCheckLimit
        end local 2 // org.graalvm.compiler.lir.LIRFrameState nullCheckState
        end local 1 // jdk.vm.ci.meta.Value value
        end local 0 // org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp this
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0    5     0                    this  Lorg/graalvm/compiler/lir/aarch64/AArch64Move$MemOp;
            0    5     1                   value  Ljdk/vm/ci/meta/Value;
            0    5     2          nullCheckState  Lorg/graalvm/compiler/lir/LIRFrameState;
            0    5     3  implicitNullCheckLimit  I
            1    5     4            displacement  I
    MethodParameters:
                        Name  Flags
      value                   
      nullCheckState          
      implicitNullCheckLimit  
}
SourceFile: "AArch64Move.java"
NestHost: org.graalvm.compiler.lir.aarch64.AArch64Move
InnerClasses:
  public final OperandFlag = org.graalvm.compiler.lir.LIRInstruction$OperandFlag of org.graalvm.compiler.lir.LIRInstruction
  public abstract State = org.graalvm.compiler.lir.LIRInstruction$State of org.graalvm.compiler.lir.LIRInstruction
  public abstract Use = org.graalvm.compiler.lir.LIRInstruction$Use of org.graalvm.compiler.lir.LIRInstruction
  public abstract ImplicitNullCheck = org.graalvm.compiler.lir.StandardOp$ImplicitNullCheck of org.graalvm.compiler.lir.StandardOp
  abstract MemOp = org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp of org.graalvm.compiler.lir.aarch64.AArch64Move