public class org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction extends org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatchableCodeAnnotation
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction
super_class: org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatchableCodeAnnotation
{
public final int srcSize;
descriptor: I
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
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: ldc Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler;
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.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction.$assertionsDisabled:Z
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(int, int);
descriptor: (II)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
iload 1
invokespecial org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatchableCodeAnnotation.<init>:(I)V
1: aload 0
iload 2
putfield org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction.srcSize:I
2: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler$AdrpLdrMacroInstruction;
0 3 1 position I
0 3 2 srcSize I
MethodParameters:
Name Flags
position
srcSize
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: ldc "ADRP_LDR"
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler$AdrpLdrMacroInstruction;
public void patch(int, int, byte[]);
descriptor: (II[B)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=15, args_size=4
start local 0 start local 1 start local 2 start local 3 0: iconst_0
istore 4
start local 4 1: aload 0
getfield org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction.srcSize:I
lookupswitch { // 4
8: 8
16: 6
32: 4
64: 2
default: 10
}
2: StackMap locals: int
StackMap stack:
iconst_3
istore 4
3: goto 11
4: StackMap locals:
StackMap stack:
iconst_2
istore 4
5: goto 11
6: StackMap locals:
StackMap stack:
iconst_1
istore 4
7: goto 11
8: StackMap locals:
StackMap stack:
iconst_0
istore 4
9: goto 11
10: StackMap locals:
StackMap stack:
getstatic org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction.$assertionsDisabled:Z
ifne 11
new java.lang.AssertionError
dup
ldc "srcSize must be either 8, 16, 32, or 64"
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
11: StackMap locals:
StackMap stack:
aload 0
getfield org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction.instructionPosition:I
istore 5
start local 5 12: iload 5
iload 2
iadd
istore 6
start local 6 13: getstatic org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction.$assertionsDisabled:Z
ifne 14
iload 4
ifeq 14
iload 6
iconst_1
iload 4
ishl
iconst_1
isub
iand
ifeq 14
new java.lang.AssertionError
dup
ldc "shift bits must be zero"
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
14: StackMap locals: int int
StackMap stack:
iload 6
iload 5
sipush 4096
invokestatic org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatcherUtil.computeRelativePageDifference:(III)I
istore 7
start local 7 15: iload 7
iconst_2
ishr
ldc 524287
iand
istore 8
start local 8 16: iconst_3
newarray 10
dup
iconst_0
iconst_3
iastore
dup
iconst_1
bipush 8
iastore
dup
iconst_2
bipush 8
iastore
astore 9
start local 9 17: iconst_3
newarray 10
dup
iconst_0
iconst_5
iastore
astore 10
start local 10 18: aload 3
iload 5
iload 8
aload 9
aload 10
invokestatic org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatcherUtil.writeBitSequence:([BII[I[I)V
19: iload 7
iconst_3
iand
istore 8
20: iconst_1
newarray 10
dup
iconst_0
iconst_2
iastore
astore 11
start local 11 21: iconst_1
newarray 10
dup
iconst_0
iconst_5
iastore
astore 12
start local 12 22: aload 3
iload 5
iconst_3
iadd
iload 8
aload 11
aload 12
invokestatic org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatcherUtil.writeBitSequence:([BII[I[I)V
23: iload 6
iload 4
ishr
sipush 511
iand
istore 8
24: iconst_2
newarray 10
dup
iconst_0
bipush 6
iastore
dup
iconst_1
bipush 6
iastore
astore 13
start local 13 25: iconst_2
newarray 10
dup
iconst_0
iconst_2
iastore
astore 14
start local 14 26: aload 3
iload 5
iconst_5
iadd
iload 8
aload 13
aload 14
invokestatic org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatcherUtil.writeBitSequence:([BII[I[I)V
27: return
end local 14 end local 13 end local 12 end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Lorg/graalvm/compiler/asm/aarch64/AArch64MacroAssembler$AdrpLdrMacroInstruction;
0 28 1 codePos I
0 28 2 relative I
0 28 3 code [B
1 28 4 shiftSize I
12 28 5 pos I
13 28 6 targetAddress I
15 28 7 relativePageDifference I
16 28 8 curValue I
17 28 9 adrHiBits [I
18 28 10 adrHiOffsets [I
21 28 11 adrLoBits [I
22 28 12 adrLoOffsets [I
25 28 13 ldrBits [I
26 28 14 ldrOffsets [I
MethodParameters:
Name Flags
codePos
relative
code
}
SourceFile: "AArch64MacroAssembler.java"
NestHost: org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler
InnerClasses:
public abstract PatchableCodeAnnotation = org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatchableCodeAnnotation of org.graalvm.compiler.asm.aarch64.AArch64Assembler
public PatcherUtil = org.graalvm.compiler.asm.aarch64.AArch64Assembler$PatcherUtil of org.graalvm.compiler.asm.aarch64.AArch64Assembler
public AdrpLdrMacroInstruction = org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler$AdrpLdrMacroInstruction of org.graalvm.compiler.asm.aarch64.AArch64MacroAssembler