public class org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp extends org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp
  super_class: org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction
{
  public static final org.graalvm.compiler.lir.LIRInstructionClass<org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp> 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$CompareAndSwapOp;>;

  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.Value expectedValue;
    descriptor: Ljdk/vm/ci/meta/Value;
    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 addressValue;
    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 56
            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$CompareAndSwapOp.$assertionsDisabled:Z
         3: .line 57
            ldc Lorg/graalvm/compiler/lir/aarch64/AArch64AtomicMove$CompareAndSwapOp;
            invokestatic org.graalvm.compiler.lir.LIRInstructionClass.create:(Ljava/lang/Class;)Lorg/graalvm/compiler/lir/LIRInstructionClass;
            putstatic org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.Value, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue);
    descriptor: (Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/Value;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$CompareAndSwapOp this
        start local 1 // jdk.vm.ci.meta.AllocatableValue result
        start local 2 // jdk.vm.ci.meta.Value expectedValue
        start local 3 // jdk.vm.ci.meta.AllocatableValue newValue
        start local 4 // jdk.vm.ci.meta.AllocatableValue addressValue
        start local 5 // jdk.vm.ci.meta.AllocatableValue scratch
         0: .line 66
            aload 0 /* this */
            getstatic org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
            invokespecial org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction.<init>:(Lorg/graalvm/compiler/lir/LIRInstructionClass;)V
         1: .line 67
            aload 0 /* this */
            aload 1 /* result */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.resultValue:Ljdk/vm/ci/meta/AllocatableValue;
         2: .line 68
            aload 0 /* this */
            aload 2 /* expectedValue */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.expectedValue:Ljdk/vm/ci/meta/Value;
         3: .line 69
            aload 0 /* this */
            aload 3 /* newValue */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.newValue:Ljdk/vm/ci/meta/AllocatableValue;
         4: .line 70
            aload 0 /* this */
            aload 4 /* addressValue */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.addressValue:Ljdk/vm/ci/meta/AllocatableValue;
         5: .line 71
            aload 0 /* this */
            aload 5 /* scratch */
            putfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.scratchValue:Ljdk/vm/ci/meta/AllocatableValue;
         6: .line 72
            return
        end local 5 // jdk.vm.ci.meta.AllocatableValue scratch
        end local 4 // jdk.vm.ci.meta.AllocatableValue addressValue
        end local 3 // jdk.vm.ci.meta.AllocatableValue newValue
        end local 2 // jdk.vm.ci.meta.Value expectedValue
        end local 1 // jdk.vm.ci.meta.AllocatableValue result
        end local 0 // org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    7     0           this  Lorg/graalvm/compiler/lir/aarch64/AArch64AtomicMove$CompareAndSwapOp;
            0    7     1         result  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     2  expectedValue  Ljdk/vm/ci/meta/Value;
            0    7     3       newValue  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     4   addressValue  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     5        scratch  Ljdk/vm/ci/meta/AllocatableValue;
    MethodParameters:
               Name  Flags
      result         
      expectedValue  
      newValue       
      addressValue   
      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=11, args_size=3
        start local 0 // org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler masm
         0: .line 76
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.expectedValue:Ljdk/vm/ci/meta/Value;
            invokevirtual jdk.vm.ci.meta.Value.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            checkcast jdk.vm.ci.aarch64.AArch64Kind
            astore 3 /* kind */
        start local 3 // jdk.vm.ci.aarch64.AArch64Kind kind
         1: .line 77
            getstatic org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.$assertionsDisabled:Z
            ifne 2
            aload 3 /* kind */
            invokevirtual jdk.vm.ci.aarch64.AArch64Kind.isInteger:()Z
            ifne 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 78
      StackMap locals: jdk.vm.ci.aarch64.AArch64Kind
      StackMap stack:
            aload 3 /* kind */
            invokevirtual jdk.vm.ci.aarch64.AArch64Kind.getSizeInBytes:()I
            bipush 8
            imul
            istore 4 /* size */
        start local 4 // int size
         3: .line 80
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.addressValue:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            astore 5 /* address */
        start local 5 // jdk.vm.ci.code.Register address
         4: .line 81
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.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 82
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.newValue:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            astore 7 /* newVal */
        start local 7 // jdk.vm.ci.code.Register newVal
         6: .line 83
            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 12
         7: .line 84
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.expectedValue:Ljdk/vm/ci/meta/Value;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            astore 8 /* expected */
        start local 8 // jdk.vm.ci.code.Register expected
         8: .line 85
            aload 2 /* masm */
            iload 4 /* size */
            aload 6 /* result */
            aload 8 /* expected */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.mov:(ILjdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
         9: .line 86
            aload 2 /* masm */
            iload 4 /* size */
            aload 6 /* result */
            aload 7 /* newVal */
            aload 5 /* address */
            iconst_1
            iconst_1
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.cas:(ILjdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;ZZ)V
        10: .line 87
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.resultValue:Ljdk/vm/ci/meta/AllocatableValue;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.expectedValue:Ljdk/vm/ci/meta/Value;
            invokestatic org.graalvm.compiler.lir.aarch64.AArch64Compare.gpCompare:(Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/Value;)V
        end local 8 // jdk.vm.ci.code.Register expected
        11: .line 88
            goto 22
        12: .line 92
      StackMap locals: org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp org.graalvm.compiler.lir.asm.CompilationResultBuilder org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler jdk.vm.ci.aarch64.AArch64Kind 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$CompareAndSwapOp.scratchValue:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            astore 8 /* scratch */
        start local 8 // jdk.vm.ci.code.Register scratch
        13: .line 93
            new org.graalvm.compiler.asm.Label
            dup
            invokespecial org.graalvm.compiler.asm.Label.<init>:()V
            astore 9 /* retry */
        start local 9 // org.graalvm.compiler.asm.Label retry
        14: .line 94
            new org.graalvm.compiler.asm.Label
            dup
            invokespecial org.graalvm.compiler.asm.Label.<init>:()V
            astore 10 /* fail */
        start local 10 // org.graalvm.compiler.asm.Label fail
        15: .line 95
            aload 2 /* masm */
            aload 9 /* retry */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.bind:(Lorg/graalvm/compiler/asm/Label;)V
        16: .line 96
            aload 2 /* masm */
            iload 4 /* size */
            aload 6 /* result */
            aload 5 /* address */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.ldaxr:(ILjdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
        17: .line 97
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.resultValue:Ljdk/vm/ci/meta/AllocatableValue;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp.expectedValue:Ljdk/vm/ci/meta/Value;
            invokestatic org.graalvm.compiler.lir.aarch64.AArch64Compare.gpCompare:(Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/Value;)V
        18: .line 98
            aload 2 /* masm */
            getstatic org.graalvm.compiler.asm.aarch64.AArch64Assembler$ConditionFlag.NE:Lorg/graalvm/compiler/asm/aarch64/AArch64Assembler$ConditionFlag;
            aload 10 /* fail */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.branchConditionally:(Lorg/graalvm/compiler/asm/aarch64/AArch64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;)V
        19: .line 99
            aload 2 /* masm */
            iload 4 /* size */
            aload 8 /* scratch */
            aload 7 /* newVal */
            aload 5 /* 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
        20: .line 101
            aload 2 /* masm */
            bipush 32
            aload 8 /* scratch */
            aload 9 /* retry */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.cbnz:(ILjdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/Label;)V
        21: .line 102
            aload 2 /* masm */
            aload 10 /* fail */
            invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.bind:(Lorg/graalvm/compiler/asm/Label;)V
        end local 10 // org.graalvm.compiler.asm.Label fail
        end local 9 // org.graalvm.compiler.asm.Label retry
        end local 8 // jdk.vm.ci.code.Register scratch
        22: .line 104
      StackMap locals:
      StackMap stack:
            return
        end local 7 // jdk.vm.ci.code.Register newVal
        end local 6 // jdk.vm.ci.code.Register result
        end local 5 // jdk.vm.ci.code.Register address
        end local 4 // int size
        end local 3 // jdk.vm.ci.aarch64.AArch64Kind kind
        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$CompareAndSwapOp this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   23     0      this  Lorg/graalvm/compiler/lir/aarch64/AArch64AtomicMove$CompareAndSwapOp;
            0   23     1       crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   23     2      masm  Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;
            1   23     3      kind  Ljdk/vm/ci/aarch64/AArch64Kind;
            3   23     4      size  I
            4   23     5   address  Ljdk/vm/ci/code/Register;
            5   23     6    result  Ljdk/vm/ci/code/Register;
            6   23     7    newVal  Ljdk/vm/ci/code/Register;
            8   11     8  expected  Ljdk/vm/ci/code/Register;
           13   22     8   scratch  Ljdk/vm/ci/code/Register;
           14   22     9     retry  Lorg/graalvm/compiler/asm/Label;
           15   22    10      fail  Lorg/graalvm/compiler/asm/Label;
    MethodParameters:
      Name  Flags
      crb   
      masm  
}
SourceFile: "AArch64AtomicMove.java"
NestHost: org.graalvm.compiler.lir.aarch64.AArch64AtomicMove
InnerClasses:
  public final ConditionFlag = org.graalvm.compiler.asm.aarch64.AArch64Assembler$ConditionFlag of org.graalvm.compiler.asm.aarch64.AArch64Assembler
  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 CompareAndSwapOp = org.graalvm.compiler.lir.aarch64.AArch64AtomicMove$CompareAndSwapOp of org.graalvm.compiler.lir.aarch64.AArch64AtomicMove
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.Opcode(value = "CAS")