public final class org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp extends org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp
  super_class: org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction
{
  public static final org.graalvm.compiler.lir.LIRInstructionClass<org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp> TYPE;
    descriptor: Lorg/graalvm/compiler/lir/LIRInstructionClass;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/compiler/lir/LIRInstructionClass<Lorg/graalvm/compiler/lir/aarch64/AArch64AtomicMove$AtomicReadAndWriteOp;>;

  private final jdk.vm.ci.aarch64.AArch64Kind accessKind;
    descriptor: Ljdk/vm/ci/aarch64/AArch64Kind;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  protected jdk.vm.ci.meta.AllocatableValue resultValue;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Def()

  protected jdk.vm.ci.meta.AllocatableValue addressValue;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Alive()

  protected jdk.vm.ci.meta.AllocatableValue newValue;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Alive()

  protected jdk.vm.ci.meta.AllocatableValue scratchValue;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Temp()

  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 217
            ldc Lorg/graalvm/compiler/lir/aarch64/AArch64AtomicMove;
            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.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.$assertionsDisabled:Z
         3: .line 218
            ldc Lorg/graalvm/compiler/lir/aarch64/AArch64AtomicMove$AtomicReadAndWriteOp;
            invokestatic org.graalvm.compiler.lir.LIRInstructionClass.create:(Ljava/lang/Class;)Lorg/graalvm/compiler/lir/LIRInstructionClass;
            putstatic org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(jdk.vm.ci.aarch64.AArch64Kind, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue);
    descriptor: (Ljdk/vm/ci/aarch64/AArch64Kind;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/AllocatableValue;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=6
        start local 0 // org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp this
        start local 1 // jdk.vm.ci.aarch64.AArch64Kind kind
        start local 2 // jdk.vm.ci.meta.AllocatableValue result
        start local 3 // jdk.vm.ci.meta.AllocatableValue address
        start local 4 // jdk.vm.ci.meta.AllocatableValue newValue
        start local 5 // jdk.vm.ci.meta.AllocatableValue scratch
         0: .line 228
            aload 0 /* this */
            getstatic org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
            invokespecial org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction.<init>:(Lorg/graalvm/compiler/lir/LIRInstructionClass;)V
         1: .line 229
            aload 0 /* this */
            aload 1 /* kind */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.accessKind:Ljdk/vm/ci/aarch64/AArch64Kind;
         2: .line 230
            aload 0 /* this */
            aload 2 /* result */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.resultValue:Ljdk/vm/ci/meta/AllocatableValue;
         3: .line 231
            aload 0 /* this */
            aload 3 /* address */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.addressValue:Ljdk/vm/ci/meta/AllocatableValue;
         4: .line 232
            aload 0 /* this */
            aload 4 /* newValue */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.newValue:Ljdk/vm/ci/meta/AllocatableValue;
         5: .line 233
            aload 0 /* this */
            aload 5 /* scratch */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.scratchValue:Ljdk/vm/ci/meta/AllocatableValue;
         6: .line 234
            return
        end local 5 // jdk.vm.ci.meta.AllocatableValue scratch
        end local 4 // jdk.vm.ci.meta.AllocatableValue newValue
        end local 3 // jdk.vm.ci.meta.AllocatableValue address
        end local 2 // jdk.vm.ci.meta.AllocatableValue result
        end local 1 // jdk.vm.ci.aarch64.AArch64Kind kind
        end local 0 // org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/graalvm/compiler/lir/aarch64/AArch64AtomicMove$AtomicReadAndWriteOp;
            0    7     1      kind  Ljdk/vm/ci/aarch64/AArch64Kind;
            0    7     2    result  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     3   address  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     4  newValue  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     5   scratch  Ljdk/vm/ci/meta/AllocatableValue;
    MethodParameters:
          Name  Flags
      kind      
      result    
      address   
      newValue  
      scratch   

  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=7, locals=9, args_size=3
        start local 0 // org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler masm
         0: .line 238
            getstatic org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.accessKind:Ljdk/vm/ci/aarch64/AArch64Kind;
            invokevirtual jdk.vm.ci.aarch64.AArch64Kind.isInteger:()Z
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 239
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.accessKind:Ljdk/vm/ci/aarch64/AArch64Kind;
            invokevirtual jdk.vm.ci.aarch64.AArch64Kind.getSizeInBytes:()I
            bipush 8
            imul
            istore 3 /* size */
        start local 3 // int size
         2: .line 241
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.addressValue:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            astore 4 /* address */
        start local 4 // jdk.vm.ci.code.Register address
         3: .line 242
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.newValue:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            astore 5 /* value */
        start local 5 // jdk.vm.ci.code.Register value
         4: .line 243
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.resultValue:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            astore 6 /* result */
        start local 6 // jdk.vm.ci.code.Register result
         5: .line 245
            aload 2 /* masm */
            getfield org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.target:Ljdk/vm/ci/code/TargetDescription;
            getfield jdk.vm.ci.code.TargetDescription.arch:Ljdk/vm/ci/code/Architecture;
            invokestatic org.graalvm.compiler.lir.aarch64.AArch64LIRFlagsVersioned.useLSE:(Ljdk/vm/ci/code/Architecture;)Z
            ifeq 8
         6: .line 246
            aload 2 /* masm */
            iload 3 /* size */
            aload 5 /* value */
            aload 6 /* result */
            aload 4 /* address */
            iconst_1
            iconst_1
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.swp:(ILjdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;ZZ)V
         7: .line 247
            goto 14
         8: .line 248
      StackMap locals: org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp org.graalvm.compiler.lir.asm.CompilationResultBuilder org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler int jdk.vm.ci.code.Register jdk.vm.ci.code.Register jdk.vm.ci.code.Register
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp.scratchValue:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            astore 7 /* scratch */
        start local 7 // jdk.vm.ci.code.Register scratch
         9: .line 249
            new org.graalvm.compiler.asm.Label
            dup
            invokespecial org.graalvm.compiler.asm.Label.<init>:()V
            astore 8 /* retry */
        start local 8 // org.graalvm.compiler.asm.Label retry
        10: .line 250
            aload 2 /* masm */
            aload 8 /* retry */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.bind:(Lorg/graalvm/compiler/asm/Label;)V
        11: .line 251
            aload 2 /* masm */
            iload 3 /* size */
            aload 6 /* result */
            aload 4 /* address */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.ldaxr:(ILjdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
        12: .line 252
            aload 2 /* masm */
            iload 3 /* size */
            aload 7 /* scratch */
            aload 5 /* value */
            aload 4 /* address */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.stlxr:(ILjdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
        13: .line 254
            aload 2 /* masm */
            bipush 32
            aload 7 /* scratch */
            aload 8 /* retry */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.cbnz:(ILjdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/Label;)V
        end local 8 // org.graalvm.compiler.asm.Label retry
        end local 7 // jdk.vm.ci.code.Register scratch
        14: .line 256
      StackMap locals:
      StackMap stack:
            return
        end local 6 // jdk.vm.ci.code.Register result
        end local 5 // jdk.vm.ci.code.Register value
        end local 4 // jdk.vm.ci.code.Register address
        end local 3 // int size
        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.AArch64AtomicMove$AtomicReadAndWriteOp this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   15     0     this  Lorg/graalvm/compiler/lir/aarch64/AArch64AtomicMove$AtomicReadAndWriteOp;
            0   15     1      crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   15     2     masm  Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;
            2   15     3     size  I
            3   15     4  address  Ljdk/vm/ci/code/Register;
            4   15     5    value  Ljdk/vm/ci/code/Register;
            5   15     6   result  Ljdk/vm/ci/code/Register;
            9   14     7  scratch  Ljdk/vm/ci/code/Register;
           10   14     8    retry  Lorg/graalvm/compiler/asm/Label;
    MethodParameters:
      Name  Flags
      crb   
      masm  
}
SourceFile: "AArch64AtomicMove.java"
NestHost: org.graalvm.compiler.lir.aarch64.AArch64AtomicMove
InnerClasses:
  public abstract Alive = org.graalvm.compiler.lir.LIRInstruction$Alive of org.graalvm.compiler.lir.LIRInstruction
  public abstract Def = org.graalvm.compiler.lir.LIRInstruction$Def of org.graalvm.compiler.lir.LIRInstruction
  public abstract Temp = org.graalvm.compiler.lir.LIRInstruction$Temp of org.graalvm.compiler.lir.LIRInstruction
  public final AtomicReadAndWriteOp = org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$AtomicReadAndWriteOp of org.graalvm.compiler.lir.aarch64.AArch64AtomicMove
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.Opcode(value = "ATOMIC_READ_AND_WRITE")