class org.bouncycastle.math.ec.WTauNafMultiplier implements org.bouncycastle.math.ec.ECMultiplier
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: org.bouncycastle.math.ec.WTauNafMultiplier
super_class: java.lang.Object
{
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 Lorg/bouncycastle/math/ec/WTauNafMultiplier;
public org.bouncycastle.math.ec.ECPoint multiply(org.bouncycastle.math.ec.ECPoint, java.math.BigInteger, org.bouncycastle.math.ec.PreCompInfo);
descriptor: (Lorg/bouncycastle/math/ec/ECPoint;Ljava/math/BigInteger;Lorg/bouncycastle/math/ec/PreCompInfo;)Lorg/bouncycastle/math/ec/ECPoint;
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=11, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 1
instanceof org.bouncycastle.math.ec.ECPoint$F2m
ifne 2
1: new java.lang.IllegalArgumentException
dup
ldc "Only ECPoint.F2m can be used in WTauNafMultiplier"
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 1
checkcast org.bouncycastle.math.ec.ECPoint$F2m
astore 4
start local 4 3: aload 4
invokevirtual org.bouncycastle.math.ec.ECPoint$F2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
checkcast org.bouncycastle.math.ec.ECCurve$F2m
astore 5
start local 5 4: aload 5
invokevirtual org.bouncycastle.math.ec.ECCurve$F2m.getM:()I
istore 6
start local 6 5: aload 5
invokevirtual org.bouncycastle.math.ec.ECCurve$F2m.getA:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.byteValue:()B
istore 7
start local 7 6: aload 5
invokevirtual org.bouncycastle.math.ec.ECCurve$F2m.getMu:()B
istore 8
start local 8 7: aload 5
invokevirtual org.bouncycastle.math.ec.ECCurve$F2m.getSi:()[Ljava/math/BigInteger;
astore 9
start local 9 8: aload 2
iload 6
iload 7
aload 9
iload 8
bipush 10
invokestatic org.bouncycastle.math.ec.Tnaf.partModReduction:(Ljava/math/BigInteger;IB[Ljava/math/BigInteger;BB)Lorg/bouncycastle/math/ec/ZTauElement;
astore 10
start local 10 9: aload 0
aload 4
aload 10
aload 3
iload 7
iload 8
invokevirtual org.bouncycastle.math.ec.WTauNafMultiplier.multiplyWTnaf:(Lorg/bouncycastle/math/ec/ECPoint$F2m;Lorg/bouncycastle/math/ec/ZTauElement;Lorg/bouncycastle/math/ec/PreCompInfo;BB)Lorg/bouncycastle/math/ec/ECPoint$F2m;
areturn
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 10 0 this Lorg/bouncycastle/math/ec/WTauNafMultiplier;
0 10 1 point Lorg/bouncycastle/math/ec/ECPoint;
0 10 2 k Ljava/math/BigInteger;
0 10 3 preCompInfo Lorg/bouncycastle/math/ec/PreCompInfo;
3 10 4 p Lorg/bouncycastle/math/ec/ECPoint$F2m;
4 10 5 curve Lorg/bouncycastle/math/ec/ECCurve$F2m;
5 10 6 m I
6 10 7 a B
7 10 8 mu B
8 10 9 s [Ljava/math/BigInteger;
9 10 10 rho Lorg/bouncycastle/math/ec/ZTauElement;
MethodParameters:
Name Flags
point
k
preCompInfo
private org.bouncycastle.math.ec.ECPoint$F2m multiplyWTnaf(org.bouncycastle.math.ec.ECPoint$F2m, org.bouncycastle.math.ec.ZTauElement, org.bouncycastle.math.ec.PreCompInfo, byte, byte);
descriptor: (Lorg/bouncycastle/math/ec/ECPoint$F2m;Lorg/bouncycastle/math/ec/ZTauElement;Lorg/bouncycastle/math/ec/PreCompInfo;BB)Lorg/bouncycastle/math/ec/ECPoint$F2m;
flags: (0x0002) ACC_PRIVATE
Code:
stack=6, locals=9, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: iload 4
ifne 3
1: getstatic org.bouncycastle.math.ec.Tnaf.alpha0:[Lorg/bouncycastle/math/ec/ZTauElement;
astore 6
start local 6 2: goto 4
end local 6 3: StackMap locals:
StackMap stack:
getstatic org.bouncycastle.math.ec.Tnaf.alpha1:[Lorg/bouncycastle/math/ec/ZTauElement;
astore 6
start local 6 4: StackMap locals: org.bouncycastle.math.ec.ZTauElement[]
StackMap stack:
iload 5
iconst_4
invokestatic org.bouncycastle.math.ec.Tnaf.getTw:(BI)Ljava/math/BigInteger;
astore 7
start local 7 5: iload 5
aload 2
iconst_4
6: ldc 16
invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
aload 7
aload 6
7: invokestatic org.bouncycastle.math.ec.Tnaf.tauAdicWNaf:(BLorg/bouncycastle/math/ec/ZTauElement;BLjava/math/BigInteger;Ljava/math/BigInteger;[Lorg/bouncycastle/math/ec/ZTauElement;)[B
astore 8
start local 8 8: aload 1
aload 8
aload 3
invokestatic org.bouncycastle.math.ec.WTauNafMultiplier.multiplyFromWTnaf:(Lorg/bouncycastle/math/ec/ECPoint$F2m;[BLorg/bouncycastle/math/ec/PreCompInfo;)Lorg/bouncycastle/math/ec/ECPoint$F2m;
areturn
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 9 0 this Lorg/bouncycastle/math/ec/WTauNafMultiplier;
0 9 1 p Lorg/bouncycastle/math/ec/ECPoint$F2m;
0 9 2 lambda Lorg/bouncycastle/math/ec/ZTauElement;
0 9 3 preCompInfo Lorg/bouncycastle/math/ec/PreCompInfo;
0 9 4 a B
0 9 5 mu B
2 3 6 alpha [Lorg/bouncycastle/math/ec/ZTauElement;
4 9 6 alpha [Lorg/bouncycastle/math/ec/ZTauElement;
5 9 7 tw Ljava/math/BigInteger;
8 9 8 u [B
MethodParameters:
Name Flags
p
lambda
preCompInfo
a
mu
private static org.bouncycastle.math.ec.ECPoint$F2m multiplyFromWTnaf(org.bouncycastle.math.ec.ECPoint$F2m, byte[], org.bouncycastle.math.ec.PreCompInfo);
descriptor: (Lorg/bouncycastle/math/ec/ECPoint$F2m;[BLorg/bouncycastle/math/ec/PreCompInfo;)Lorg/bouncycastle/math/ec/ECPoint$F2m;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=8, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$F2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
checkcast org.bouncycastle.math.ec.ECCurve$F2m
astore 3
start local 3 1: aload 3
invokevirtual org.bouncycastle.math.ec.ECCurve$F2m.getA:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.byteValue:()B
istore 4
start local 4 2: aload 2
ifnull 3
aload 2
instanceof org.bouncycastle.math.ec.WTauNafPreCompInfo
ifne 6
3: StackMap locals: org.bouncycastle.math.ec.ECCurve$F2m int
StackMap stack:
aload 0
iload 4
invokestatic org.bouncycastle.math.ec.Tnaf.getPreComp:(Lorg/bouncycastle/math/ec/ECPoint$F2m;B)[Lorg/bouncycastle/math/ec/ECPoint$F2m;
astore 5
start local 5 4: aload 0
new org.bouncycastle.math.ec.WTauNafPreCompInfo
dup
aload 5
invokespecial org.bouncycastle.math.ec.WTauNafPreCompInfo.<init>:([Lorg/bouncycastle/math/ec/ECPoint$F2m;)V
invokevirtual org.bouncycastle.math.ec.ECPoint$F2m.setPreCompInfo:(Lorg/bouncycastle/math/ec/PreCompInfo;)V
5: goto 7
end local 5 6: StackMap locals:
StackMap stack:
aload 2
checkcast org.bouncycastle.math.ec.WTauNafPreCompInfo
invokevirtual org.bouncycastle.math.ec.WTauNafPreCompInfo.getPreComp:()[Lorg/bouncycastle/math/ec/ECPoint$F2m;
astore 5
start local 5 7: StackMap locals: org.bouncycastle.math.ec.ECPoint$F2m[]
StackMap stack:
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$F2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
invokevirtual org.bouncycastle.math.ec.ECCurve.getInfinity:()Lorg/bouncycastle/math/ec/ECPoint;
checkcast org.bouncycastle.math.ec.ECPoint$F2m
astore 6
start local 6 8: aload 1
arraylength
iconst_1
isub
istore 7
start local 7 9: goto 17
10: StackMap locals: org.bouncycastle.math.ec.ECPoint$F2m int
StackMap stack:
aload 6
invokestatic org.bouncycastle.math.ec.Tnaf.tau:(Lorg/bouncycastle/math/ec/ECPoint$F2m;)Lorg/bouncycastle/math/ec/ECPoint$F2m;
astore 6
11: aload 1
iload 7
baload
ifeq 16
12: aload 1
iload 7
baload
ifle 15
13: aload 6
aload 5
aload 1
iload 7
baload
aaload
invokevirtual org.bouncycastle.math.ec.ECPoint$F2m.addSimple:(Lorg/bouncycastle/math/ec/ECPoint$F2m;)Lorg/bouncycastle/math/ec/ECPoint$F2m;
astore 6
14: goto 16
15: StackMap locals:
StackMap stack:
aload 6
aload 5
aload 1
iload 7
baload
ineg
aaload
invokevirtual org.bouncycastle.math.ec.ECPoint$F2m.subtractSimple:(Lorg/bouncycastle/math/ec/ECPoint$F2m;)Lorg/bouncycastle/math/ec/ECPoint$F2m;
astore 6
16: StackMap locals:
StackMap stack:
iinc 7 -1
StackMap locals:
StackMap stack:
17: iload 7
ifge 10
end local 7 18: aload 6
areturn
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 19 0 p Lorg/bouncycastle/math/ec/ECPoint$F2m;
0 19 1 u [B
0 19 2 preCompInfo Lorg/bouncycastle/math/ec/PreCompInfo;
1 19 3 curve Lorg/bouncycastle/math/ec/ECCurve$F2m;
2 19 4 a B
4 6 5 pu [Lorg/bouncycastle/math/ec/ECPoint$F2m;
7 19 5 pu [Lorg/bouncycastle/math/ec/ECPoint$F2m;
8 19 6 q Lorg/bouncycastle/math/ec/ECPoint$F2m;
9 18 7 i I
MethodParameters:
Name Flags
p
u
preCompInfo
}
SourceFile: "WTauNafMultiplier.java"
InnerClasses:
public F2m = org.bouncycastle.math.ec.ECCurve$F2m of org.bouncycastle.math.ec.ECCurve
public F2m = org.bouncycastle.math.ec.ECPoint$F2m of org.bouncycastle.math.ec.ECPoint