final class com.google.crypto.tink.subtle.Ed25519Constants
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: com.google.crypto.tink.subtle.Ed25519Constants
super_class: java.lang.Object
{
static final long[] D;
descriptor: [J
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final long[] D2;
descriptor: [J
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final long[] SQRTM1;
descriptor: [J
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final com.google.crypto.tink.subtle.Ed25519$CachedXYT[][] B_TABLE;
descriptor: [[Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final com.google.crypto.tink.subtle.Ed25519$CachedXYT[] B2;
descriptor: [Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
flags: (0x0018) ACC_STATIC, ACC_FINAL
private static final java.math.BigInteger P_BI;
descriptor: Ljava/math/BigInteger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.math.BigInteger D_BI;
descriptor: Ljava/math/BigInteger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.math.BigInteger D2_BI;
descriptor: Ljava/math/BigInteger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.math.BigInteger SQRTM1_BI;
descriptor: Ljava/math/BigInteger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=4, locals=5, args_size=0
0: ldc 2
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
sipush 255
invokevirtual java.math.BigInteger.pow:(I)Ljava/math/BigInteger;
ldc 19
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
1: putstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
2: ldc -121665
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
ldc 121666
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.modInverse:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
3: putstatic com.google.crypto.tink.subtle.Ed25519Constants.D_BI:Ljava/math/BigInteger;
4: ldc 2
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.D_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
putstatic com.google.crypto.tink.subtle.Ed25519Constants.D2_BI:Ljava/math/BigInteger;
5: ldc 2
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
getstatic java.math.BigInteger.ONE:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
ldc 4
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.divide:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.modPow:(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
6: putstatic com.google.crypto.tink.subtle.Ed25519Constants.SQRTM1_BI:Ljava/math/BigInteger;
7: new com.google.crypto.tink.subtle.Ed25519Constants$Point
dup
invokespecial com.google.crypto.tink.subtle.Ed25519Constants$Point.<init>:()V
astore 0
start local 0 8: aload 0
ldc 4
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
ldc 5
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.modInverse:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
putfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
9: aload 0
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.recoverX:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
putfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
10: getstatic com.google.crypto.tink.subtle.Ed25519Constants.D_BI:Ljava/math/BigInteger;
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.toLittleEndian:(Ljava/math/BigInteger;)[B
invokestatic com.google.crypto.tink.subtle.Field25519.expand:([B)[J
putstatic com.google.crypto.tink.subtle.Ed25519Constants.D:[J
11: getstatic com.google.crypto.tink.subtle.Ed25519Constants.D2_BI:Ljava/math/BigInteger;
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.toLittleEndian:(Ljava/math/BigInteger;)[B
invokestatic com.google.crypto.tink.subtle.Field25519.expand:([B)[J
putstatic com.google.crypto.tink.subtle.Ed25519Constants.D2:[J
12: getstatic com.google.crypto.tink.subtle.Ed25519Constants.SQRTM1_BI:Ljava/math/BigInteger;
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.toLittleEndian:(Ljava/math/BigInteger;)[B
invokestatic com.google.crypto.tink.subtle.Field25519.expand:([B)[J
putstatic com.google.crypto.tink.subtle.Ed25519Constants.SQRTM1:[J
13: aload 0
astore 1
start local 1 14: bipush 32
bipush 8
multianewarray [[Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT; 2
putstatic com.google.crypto.tink.subtle.Ed25519Constants.B_TABLE:[[Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
15: iconst_0
istore 2
start local 2 16: goto 30
17: StackMap locals: com.google.crypto.tink.subtle.Ed25519Constants$Point com.google.crypto.tink.subtle.Ed25519Constants$Point int
StackMap stack:
aload 1
astore 3
start local 3 18: iconst_0
istore 4
start local 4 19: goto 23
20: StackMap locals: com.google.crypto.tink.subtle.Ed25519Constants$Point int
StackMap stack:
getstatic com.google.crypto.tink.subtle.Ed25519Constants.B_TABLE:[[Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
iload 2
aaload
iload 4
aload 3
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.getCachedXYT:(Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;)Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
aastore
21: aload 3
aload 1
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.edwards:(Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;)Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
astore 3
22: iinc 4 1
StackMap locals:
StackMap stack:
23: iload 4
bipush 8
if_icmplt 20
end local 4 24: iconst_0
istore 4
start local 4 25: goto 28
26: StackMap locals:
StackMap stack:
aload 1
aload 1
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.edwards:(Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;)Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
astore 1
27: iinc 4 1
StackMap locals:
StackMap stack:
28: iload 4
bipush 8
if_icmplt 26
end local 4 end local 3 29: iinc 2 1
StackMap locals:
StackMap stack:
30: iload 2
bipush 32
if_icmplt 17
end local 2 31: aload 0
astore 1
32: aload 0
aload 0
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.edwards:(Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;)Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
astore 2
start local 2 33: bipush 8
anewarray com.google.crypto.tink.subtle.Ed25519$CachedXYT
putstatic com.google.crypto.tink.subtle.Ed25519Constants.B2:[Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
34: iconst_0
istore 3
start local 3 35: goto 39
36: StackMap locals: com.google.crypto.tink.subtle.Ed25519Constants$Point com.google.crypto.tink.subtle.Ed25519Constants$Point com.google.crypto.tink.subtle.Ed25519Constants$Point int
StackMap stack:
getstatic com.google.crypto.tink.subtle.Ed25519Constants.B2:[Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
iload 3
aload 1
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.getCachedXYT:(Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;)Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
aastore
37: aload 1
aload 2
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.edwards:(Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;)Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
astore 1
38: iinc 3 1
StackMap locals:
StackMap stack:
39: iload 3
bipush 8
if_icmplt 36
end local 3 end local 2 end local 1 end local 0 40: return
LocalVariableTable:
Start End Slot Name Signature
8 40 0 b Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
14 40 1 bi Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
16 31 2 i I
18 29 3 bij Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
19 24 4 j I
25 29 4 j I
33 40 2 b2 Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
35 40 3 i I
void <init>();
descriptor: ()V
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/google/crypto/tink/subtle/Ed25519Constants;
private static java.math.BigInteger recoverX(java.math.BigInteger);
descriptor: (Ljava/math/BigInteger;)Ljava/math/BigInteger;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=3, args_size=1
start local 0 0: aload 0
iconst_2
invokevirtual java.math.BigInteger.pow:(I)Ljava/math/BigInteger;
1: getstatic java.math.BigInteger.ONE:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
2: getstatic com.google.crypto.tink.subtle.Ed25519Constants.D_BI:Ljava/math/BigInteger;
aload 0
iconst_2
invokevirtual java.math.BigInteger.pow:(I)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic java.math.BigInteger.ONE:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.modInverse:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
3: astore 1
start local 1 4: aload 1
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
ldc 3
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
ldc 8
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.divide:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.modPow:(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 2
start local 2 5: aload 2
iconst_2
invokevirtual java.math.BigInteger.pow:(I)Ljava/math/BigInteger;
aload 1
invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic java.math.BigInteger.ZERO:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.equals:(Ljava/lang/Object;)Z
ifne 7
6: aload 2
getstatic com.google.crypto.tink.subtle.Ed25519Constants.SQRTM1_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 2
7: StackMap locals: java.math.BigInteger java.math.BigInteger
StackMap stack:
aload 2
iconst_0
invokevirtual java.math.BigInteger.testBit:(I)Z
ifeq 9
8: getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
aload 2
invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 2
9: StackMap locals:
StackMap stack:
aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 y Ljava/math/BigInteger;
4 10 1 xx Ljava/math/BigInteger;
5 10 2 x Ljava/math/BigInteger;
MethodParameters:
Name Flags
y
private static com.google.crypto.tink.subtle.Ed25519Constants$Point edwards(com.google.crypto.tink.subtle.Ed25519Constants$Point, com.google.crypto.tink.subtle.Ed25519Constants$Point);
descriptor: (Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;)Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=4, args_size=2
start local 0 start local 1 0: new com.google.crypto.tink.subtle.Ed25519Constants$Point
dup
invokespecial com.google.crypto.tink.subtle.Ed25519Constants$Point.<init>:()V
astore 2
start local 2 1: getstatic com.google.crypto.tink.subtle.Ed25519Constants.D_BI:Ljava/math/BigInteger;
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
aload 1
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 1
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 3
start local 3 2: aload 2
3: aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
aload 1
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 1
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
4: getstatic java.math.BigInteger.ONE:Ljava/math/BigInteger;
aload 3
invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.modInverse:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
5: getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
6: putfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
7: aload 2
8: aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
aload 1
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
aload 1
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
9: getstatic java.math.BigInteger.ONE:Ljava/math/BigInteger;
aload 3
invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.modInverse:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
10: getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
11: putfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
12: aload 2
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 a Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
0 13 1 b Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
1 13 2 o Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
2 13 3 xxyy Ljava/math/BigInteger;
MethodParameters:
Name Flags
a
b
private static byte[] toLittleEndian(java.math.BigInteger);
descriptor: (Ljava/math/BigInteger;)[B
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=5, locals=5, args_size=1
start local 0 0: bipush 32
newarray 8
astore 1
start local 1 1: aload 0
invokevirtual java.math.BigInteger.toByteArray:()[B
astore 2
start local 2 2: aload 2
iconst_0
aload 1
bipush 32
aload 2
arraylength
isub
aload 2
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
3: iconst_0
istore 3
start local 3 4: goto 9
5: StackMap locals: byte[] byte[] int
StackMap stack:
aload 1
iload 3
baload
istore 4
start local 4 6: aload 1
iload 3
aload 1
aload 1
arraylength
iload 3
isub
iconst_1
isub
baload
bastore
7: aload 1
aload 1
arraylength
iload 3
isub
iconst_1
isub
iload 4
bastore
end local 4 8: iinc 3 1
StackMap locals:
StackMap stack:
9: iload 3
aload 1
arraylength
iconst_2
idiv
if_icmplt 5
end local 3 10: aload 1
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 n Ljava/math/BigInteger;
1 11 1 b [B
2 11 2 nBytes [B
4 10 3 i I
6 8 4 t B
MethodParameters:
Name Flags
n
private static com.google.crypto.tink.subtle.Ed25519$CachedXYT getCachedXYT(com.google.crypto.tink.subtle.Ed25519Constants$Point);
descriptor: (Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;)Lcom/google/crypto/tink/subtle/Ed25519$CachedXYT;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=6, locals=1, args_size=1
start local 0 0: new com.google.crypto.tink.subtle.Ed25519$CachedXYT
dup
1: aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.toLittleEndian:(Ljava/math/BigInteger;)[B
invokestatic com.google.crypto.tink.subtle.Field25519.expand:([B)[J
2: aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.toLittleEndian:(Ljava/math/BigInteger;)[B
invokestatic com.google.crypto.tink.subtle.Field25519.expand:([B)[J
3: getstatic com.google.crypto.tink.subtle.Ed25519Constants.D2_BI:Ljava/math/BigInteger;
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.x:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 0
getfield com.google.crypto.tink.subtle.Ed25519Constants$Point.y:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
getstatic com.google.crypto.tink.subtle.Ed25519Constants.P_BI:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokestatic com.google.crypto.tink.subtle.Ed25519Constants.toLittleEndian:(Ljava/math/BigInteger;)[B
invokestatic com.google.crypto.tink.subtle.Field25519.expand:([B)[J
4: invokespecial com.google.crypto.tink.subtle.Ed25519$CachedXYT.<init>:([J[J[J)V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 p Lcom/google/crypto/tink/subtle/Ed25519Constants$Point;
MethodParameters:
Name Flags
p
}
SourceFile: "Ed25519Constants.java"
NestMembers:
com.google.crypto.tink.subtle.Ed25519Constants$Point
InnerClasses:
CachedXYT = com.google.crypto.tink.subtle.Ed25519$CachedXYT of com.google.crypto.tink.subtle.Ed25519
private Point = com.google.crypto.tink.subtle.Ed25519Constants$Point of com.google.crypto.tink.subtle.Ed25519Constants