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 start local 1 start local 2 start local 3 start local 4 0: aload 0
aload 1
invokespecial org.graalvm.compiler.lir.aarch64.AArch64LIRInstruction.<init>:(Lorg/graalvm/compiler/lir/LIRInstructionClass;)V
1: aload 0
aload 2
putfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.kind:Ljdk/vm/ci/aarch64/AArch64Kind;
2: aload 0
aload 3
putfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.addressValue:Lorg/graalvm/compiler/lir/aarch64/AArch64AddressValue;
3: aload 0
aload 4
putfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
4: return
end local 4 end local 3 end local 2 end local 1 end local 0 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 start local 1 start local 2 0: aload 2
invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.position:()I
istore 3
start local 3 1: aload 0
aload 1
aload 2
invokevirtual org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.emitMemAccess:(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;)V
2: aload 0
getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
ifnull 9
3: iload 3
istore 4
start local 4 4: aload 0
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
aload 2
invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.position:()I
if_icmpne 8
aload 2
invokevirtual org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler.isImmLoadStoreMerged:()Z
ifeq 8
5: iload 3
iconst_4
isub
istore 4
6: aload 1
iload 4
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isImplicitExceptionExist:(I)Z
ifeq 8
7: return
8: StackMap locals: int int
StackMap stack:
aload 1
iload 4
aload 0
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 9: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 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 start local 1 start local 2 start local 3 0: aload 0
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
start local 4 1: aload 0
getfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
ifnonnull 4
aload 1
aload 0
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
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
iflt 4
iload 4
iload 3
if_icmpge 4
2: aload 0
aload 2
putfield org.graalvm.compiler.lir.aarch64.AArch64Move$MemOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
3: iconst_1
ireturn
4: StackMap locals: int
StackMap stack:
iconst_0
ireturn
end local 4 end local 3 end local 2 end local 1 end local 0 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