public abstract class org.bouncycastle.math.ec.ECPoint$AbstractF2m extends org.bouncycastle.math.ec.ECPoint
minor version: 0
major version: 59
flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
this_class: org.bouncycastle.math.ec.ECPoint$AbstractF2m
super_class: org.bouncycastle.math.ec.ECPoint
{
protected void <init>(org.bouncycastle.math.ec.ECCurve, org.bouncycastle.math.ec.ECFieldElement, org.bouncycastle.math.ec.ECFieldElement);
descriptor: (Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
aload 1
aload 2
aload 3
invokespecial org.bouncycastle.math.ec.ECPoint.<init>:(Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;)V
1: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
0 2 1 curve Lorg/bouncycastle/math/ec/ECCurve;
0 2 2 x Lorg/bouncycastle/math/ec/ECFieldElement;
0 2 3 y Lorg/bouncycastle/math/ec/ECFieldElement;
MethodParameters:
Name Flags
curve
x
y
protected void <init>(org.bouncycastle.math.ec.ECCurve, org.bouncycastle.math.ec.ECFieldElement, org.bouncycastle.math.ec.ECFieldElement, org.bouncycastle.math.ec.ECFieldElement[]);
descriptor: (Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;[Lorg/bouncycastle/math/ec/ECFieldElement;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, 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
aload 2
aload 3
aload 4
invokespecial org.bouncycastle.math.ec.ECPoint.<init>:(Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;[Lorg/bouncycastle/math/ec/ECFieldElement;)V
1: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
0 2 1 curve Lorg/bouncycastle/math/ec/ECCurve;
0 2 2 x Lorg/bouncycastle/math/ec/ECFieldElement;
0 2 3 y Lorg/bouncycastle/math/ec/ECFieldElement;
0 2 4 zs [Lorg/bouncycastle/math/ec/ECFieldElement;
MethodParameters:
Name Flags
curve
x
y
zs
protected boolean satisfiesCurveEquation();
descriptor: ()Z
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=14, args_size=1
start local 0 0: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
astore 1
start local 1 1: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.x:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 2
start local 2 2: aload 1
invokevirtual org.bouncycastle.math.ec.ECCurve.getA:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 3
start local 3 3: aload 1
invokevirtual org.bouncycastle.math.ec.ECCurve.getB:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 4: aload 1
invokevirtual org.bouncycastle.math.ec.ECCurve.getCoordinateSystem:()I
istore 5
start local 5 5: iload 5
bipush 6
if_icmpne 27
6: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.zs:[Lorg/bouncycastle/math/ec/ECFieldElement;
iconst_0
aaload
astore 6
start local 6 7: aload 6
invokevirtual org.bouncycastle.math.ec.ECFieldElement.isOne:()Z
istore 7
start local 7 8: aload 2
invokevirtual org.bouncycastle.math.ec.ECFieldElement.isZero:()Z
ifeq 15
9: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.y:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 8
start local 8 10: aload 8
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 9
start local 9 11: aload 4
astore 10
start local 10 12: iload 7
ifne 14
13: aload 10
aload 6
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 10
14: StackMap locals: org.bouncycastle.math.ec.ECPoint$AbstractF2m org.bouncycastle.math.ec.ECCurve org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement int org.bouncycastle.math.ec.ECFieldElement int org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
aload 9
aload 10
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ireturn
end local 10 end local 9 end local 8 15: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.y:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 8
start local 8 16: aload 2
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 9
start local 9 17: iload 7
ifeq 21
18: aload 8
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
aload 8
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 10
start local 10 19: aload 9
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
aload 4
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 11
start local 11 20: goto 25
end local 11 end local 10 21: StackMap locals: org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
aload 6
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 12
start local 12 22: aload 12
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 13
start local 13 23: aload 8
aload 6
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 8
aload 3
aload 12
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiplyPlusProduct:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 10
start local 10 24: aload 9
aload 4
aload 13
invokevirtual org.bouncycastle.math.ec.ECFieldElement.squarePlusProduct:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 11
end local 13 end local 12 start local 11 25: StackMap locals: org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
aload 10
aload 9
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 10
26: aload 10
aload 11
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ireturn
end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 27: StackMap locals: org.bouncycastle.math.ec.ECPoint$AbstractF2m org.bouncycastle.math.ec.ECCurve org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement int
StackMap stack:
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.y:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 6
start local 6 28: aload 6
aload 2
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 6
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 7
start local 7 29: iload 5
tableswitch { // 0 - 1
0: 30
1: 31
default: 39
}
30: StackMap locals: org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
goto 40
31: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.zs:[Lorg/bouncycastle/math/ec/ECFieldElement;
iconst_0
aaload
astore 8
start local 8 32: aload 8
invokevirtual org.bouncycastle.math.ec.ECFieldElement.isOne:()Z
ifne 40
33: aload 8
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 9
start local 9 34: aload 8
aload 9
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 10
start local 10 35: aload 7
aload 8
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 7
36: aload 3
aload 8
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 3
37: aload 4
aload 10
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
end local 10 end local 9 38: goto 40
end local 8 39: StackMap locals:
StackMap stack:
new java.lang.IllegalStateException
dup
ldc "unsupported coordinate system"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
40: StackMap locals:
StackMap stack:
aload 2
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 2
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 4
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 8
start local 8 41: aload 7
aload 8
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ireturn
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 42 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
1 42 1 curve Lorg/bouncycastle/math/ec/ECCurve;
2 42 2 X Lorg/bouncycastle/math/ec/ECFieldElement;
3 42 3 A Lorg/bouncycastle/math/ec/ECFieldElement;
4 42 4 B Lorg/bouncycastle/math/ec/ECFieldElement;
5 42 5 coord I
7 27 6 Z Lorg/bouncycastle/math/ec/ECFieldElement;
8 27 7 ZIsOne Z
10 15 8 Y Lorg/bouncycastle/math/ec/ECFieldElement;
11 15 9 lhs Lorg/bouncycastle/math/ec/ECFieldElement;
12 15 10 rhs Lorg/bouncycastle/math/ec/ECFieldElement;
16 27 8 L Lorg/bouncycastle/math/ec/ECFieldElement;
17 27 9 X2 Lorg/bouncycastle/math/ec/ECFieldElement;
19 21 10 lhs Lorg/bouncycastle/math/ec/ECFieldElement;
24 27 10 lhs Lorg/bouncycastle/math/ec/ECFieldElement;
20 21 11 rhs Lorg/bouncycastle/math/ec/ECFieldElement;
25 27 11 rhs Lorg/bouncycastle/math/ec/ECFieldElement;
22 25 12 Z2 Lorg/bouncycastle/math/ec/ECFieldElement;
23 25 13 Z4 Lorg/bouncycastle/math/ec/ECFieldElement;
28 42 6 Y Lorg/bouncycastle/math/ec/ECFieldElement;
29 42 7 lhs Lorg/bouncycastle/math/ec/ECFieldElement;
32 39 8 Z Lorg/bouncycastle/math/ec/ECFieldElement;
34 38 9 Z2 Lorg/bouncycastle/math/ec/ECFieldElement;
35 38 10 Z3 Lorg/bouncycastle/math/ec/ECFieldElement;
41 42 8 rhs Lorg/bouncycastle/math/ec/ECFieldElement;
protected boolean satisfiesOrder();
descriptor: ()Z
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=7, args_size=1
start local 0 0: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.curve:Lorg/bouncycastle/math/ec/ECCurve;
invokevirtual org.bouncycastle.math.ec.ECCurve.getCofactor:()Ljava/math/BigInteger;
astore 1
start local 1 1: getstatic org.bouncycastle.math.ec.ECConstants.TWO:Ljava/math/BigInteger;
aload 1
invokevirtual java.math.BigInteger.equals:(Ljava/lang/Object;)Z
ifeq 7
2: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.normalize:()Lorg/bouncycastle/math/ec/ECPoint;
astore 2
start local 2 3: aload 2
invokevirtual org.bouncycastle.math.ec.ECPoint.getAffineXCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 3
start local 3 4: aload 3
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.curve:Lorg/bouncycastle/math/ec/ECCurve;
invokevirtual org.bouncycastle.math.ec.ECCurve.getA:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 5: aload 4
checkcast org.bouncycastle.math.ec.ECFieldElement$AbstractF2m
invokevirtual org.bouncycastle.math.ec.ECFieldElement$AbstractF2m.trace:()I
ifne 6
iconst_1
ireturn
StackMap locals: org.bouncycastle.math.ec.ECPoint$AbstractF2m java.math.BigInteger org.bouncycastle.math.ec.ECPoint org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
6: iconst_0
ireturn
end local 4 end local 3 end local 2 7: StackMap locals:
StackMap stack:
getstatic org.bouncycastle.math.ec.ECConstants.FOUR:Ljava/math/BigInteger;
aload 1
invokevirtual java.math.BigInteger.equals:(Ljava/lang/Object;)Z
ifeq 19
8: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.normalize:()Lorg/bouncycastle/math/ec/ECPoint;
astore 2
start local 2 9: aload 2
invokevirtual org.bouncycastle.math.ec.ECPoint.getAffineXCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 3
start local 3 10: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.curve:Lorg/bouncycastle/math/ec/ECCurve;
checkcast org.bouncycastle.math.ec.ECCurve$AbstractF2m
aload 3
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.curve:Lorg/bouncycastle/math/ec/ECCurve;
invokevirtual org.bouncycastle.math.ec.ECCurve.getA:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECCurve$AbstractF2m.solveQuadraticEquation:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 11: aload 4
ifnonnull 13
12: iconst_0
ireturn
13: StackMap locals: org.bouncycastle.math.ec.ECPoint org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
aload 3
aload 4
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 2
invokevirtual org.bouncycastle.math.ec.ECPoint.getAffineYCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 5
start local 5 14: aload 5
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.curve:Lorg/bouncycastle/math/ec/ECCurve;
invokevirtual org.bouncycastle.math.ec.ECCurve.getA:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 6
start local 6 15: aload 6
checkcast org.bouncycastle.math.ec.ECFieldElement$AbstractF2m
invokevirtual org.bouncycastle.math.ec.ECFieldElement$AbstractF2m.trace:()I
ifeq 18
16: aload 6
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
checkcast org.bouncycastle.math.ec.ECFieldElement$AbstractF2m
invokevirtual org.bouncycastle.math.ec.ECFieldElement$AbstractF2m.trace:()I
ifeq 18
17: iconst_0
ireturn
StackMap locals: org.bouncycastle.math.ec.ECFieldElement org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
18: iconst_1
ireturn
end local 6 end local 5 end local 4 end local 3 end local 2 19: StackMap locals: org.bouncycastle.math.ec.ECPoint$AbstractF2m java.math.BigInteger
StackMap stack:
aload 0
invokespecial org.bouncycastle.math.ec.ECPoint.satisfiesOrder:()Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 20 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
1 20 1 cofactor Ljava/math/BigInteger;
3 7 2 N Lorg/bouncycastle/math/ec/ECPoint;
4 7 3 X Lorg/bouncycastle/math/ec/ECFieldElement;
5 7 4 rhs Lorg/bouncycastle/math/ec/ECFieldElement;
9 19 2 N Lorg/bouncycastle/math/ec/ECPoint;
10 19 3 X Lorg/bouncycastle/math/ec/ECFieldElement;
11 19 4 lambda Lorg/bouncycastle/math/ec/ECFieldElement;
14 19 5 w Lorg/bouncycastle/math/ec/ECFieldElement;
15 19 6 t Lorg/bouncycastle/math/ec/ECFieldElement;
public org.bouncycastle.math.ec.ECPoint scaleX(org.bouncycastle.math.ec.ECFieldElement);
descriptor: (Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECPoint;
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=9, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.isInfinity:()Z
ifeq 2
1: aload 0
areturn
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getCurveCoordinateSystem:()I
istore 2
start local 2 3: iload 2
tableswitch { // 5 - 6
5: 4
6: 9
default: 16
}
4: StackMap locals: int
StackMap stack:
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawXCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 3
start local 3 5: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawYCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 6: aload 3
aload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 5
start local 5 7: aload 4
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.divide:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 5
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 6
start local 6 8: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
aload 3
aload 6
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawZCoords:()[Lorg/bouncycastle/math/ec/ECFieldElement;
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.withCompression:Z
invokevirtual org.bouncycastle.math.ec.ECCurve.createRawPoint:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;[Lorg/bouncycastle/math/ec/ECFieldElement;Z)Lorg/bouncycastle/math/ec/ECPoint;
areturn
end local 6 end local 5 end local 4 end local 3 9: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawXCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 3
start local 3 10: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawYCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 11: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawZCoords:()[Lorg/bouncycastle/math/ec/ECFieldElement;
iconst_0
aaload
astore 5
start local 5 12: aload 3
aload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 6
start local 6 13: aload 4
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 6
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 7
start local 7 14: aload 5
aload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 8
start local 8 15: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
aload 6
aload 7
iconst_1
anewarray org.bouncycastle.math.ec.ECFieldElement
dup
iconst_0
aload 8
aastore
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.withCompression:Z
invokevirtual org.bouncycastle.math.ec.ECCurve.createRawPoint:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;[Lorg/bouncycastle/math/ec/ECFieldElement;Z)Lorg/bouncycastle/math/ec/ECPoint;
areturn
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 16: StackMap locals:
StackMap stack:
aload 0
aload 1
invokespecial org.bouncycastle.math.ec.ECPoint.scaleX:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECPoint;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
0 17 1 scale Lorg/bouncycastle/math/ec/ECFieldElement;
3 17 2 coord I
5 9 3 X Lorg/bouncycastle/math/ec/ECFieldElement;
6 9 4 L Lorg/bouncycastle/math/ec/ECFieldElement;
7 9 5 X2 Lorg/bouncycastle/math/ec/ECFieldElement;
8 9 6 L2 Lorg/bouncycastle/math/ec/ECFieldElement;
10 16 3 X Lorg/bouncycastle/math/ec/ECFieldElement;
11 16 4 L Lorg/bouncycastle/math/ec/ECFieldElement;
12 16 5 Z Lorg/bouncycastle/math/ec/ECFieldElement;
13 16 6 X2 Lorg/bouncycastle/math/ec/ECFieldElement;
14 16 7 L2 Lorg/bouncycastle/math/ec/ECFieldElement;
15 16 8 Z2 Lorg/bouncycastle/math/ec/ECFieldElement;
MethodParameters:
Name Flags
scale
public org.bouncycastle.math.ec.ECPoint scaleY(org.bouncycastle.math.ec.ECFieldElement);
descriptor: (Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECPoint;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=6, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.isInfinity:()Z
ifeq 2
1: aload 0
areturn
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getCurveCoordinateSystem:()I
istore 2
start local 2 3: iload 2
tableswitch { // 5 - 6
5: 4
6: 4
default: 8
}
4: StackMap locals: int
StackMap stack:
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawXCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 3
start local 3 5: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawYCoord:()Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 6: aload 4
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.multiply:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.add:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECFieldElement;
astore 5
start local 5 7: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
aload 3
aload 5
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getRawZCoords:()[Lorg/bouncycastle/math/ec/ECFieldElement;
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.withCompression:Z
invokevirtual org.bouncycastle.math.ec.ECCurve.createRawPoint:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;[Lorg/bouncycastle/math/ec/ECFieldElement;Z)Lorg/bouncycastle/math/ec/ECPoint;
areturn
end local 5 end local 4 end local 3 8: StackMap locals:
StackMap stack:
aload 0
aload 1
invokespecial org.bouncycastle.math.ec.ECPoint.scaleY:(Lorg/bouncycastle/math/ec/ECFieldElement;)Lorg/bouncycastle/math/ec/ECPoint;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
0 9 1 scale Lorg/bouncycastle/math/ec/ECFieldElement;
3 9 2 coord I
5 8 3 X Lorg/bouncycastle/math/ec/ECFieldElement;
6 8 4 L Lorg/bouncycastle/math/ec/ECFieldElement;
7 8 5 L2 Lorg/bouncycastle/math/ec/ECFieldElement;
MethodParameters:
Name Flags
scale
public org.bouncycastle.math.ec.ECPoint subtract(org.bouncycastle.math.ec.ECPoint);
descriptor: (Lorg/bouncycastle/math/ec/ECPoint;)Lorg/bouncycastle/math/ec/ECPoint;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual org.bouncycastle.math.ec.ECPoint.isInfinity:()Z
ifeq 2
1: aload 0
areturn
2: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual org.bouncycastle.math.ec.ECPoint.negate:()Lorg/bouncycastle/math/ec/ECPoint;
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.add:(Lorg/bouncycastle/math/ec/ECPoint;)Lorg/bouncycastle/math/ec/ECPoint;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
0 3 1 b Lorg/bouncycastle/math/ec/ECPoint;
MethodParameters:
Name Flags
b
public org.bouncycastle.math.ec.ECPoint$AbstractF2m tau();
descriptor: ()Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=6, args_size=1
start local 0 0: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.isInfinity:()Z
ifeq 2
1: aload 0
areturn
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
astore 1
start local 1 3: aload 1
invokevirtual org.bouncycastle.math.ec.ECCurve.getCoordinateSystem:()I
istore 2
start local 2 4: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.x:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 3
start local 3 5: iload 2
tableswitch { // 0 - 6
0: 6
1: 8
2: 13
3: 13
4: 13
5: 6
6: 8
default: 13
}
6: StackMap locals: org.bouncycastle.math.ec.ECCurve int org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.y:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 7: aload 1
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
aload 4
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.withCompression:Z
invokevirtual org.bouncycastle.math.ec.ECCurve.createRawPoint:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;Z)Lorg/bouncycastle/math/ec/ECPoint;
checkcast org.bouncycastle.math.ec.ECPoint$AbstractF2m
areturn
end local 4 8: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.y:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 9: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.zs:[Lorg/bouncycastle/math/ec/ECFieldElement;
iconst_0
aaload
astore 5
start local 5 10: aload 1
aload 3
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
aload 4
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
11: iconst_1
anewarray org.bouncycastle.math.ec.ECFieldElement
dup
iconst_0
aload 5
invokevirtual org.bouncycastle.math.ec.ECFieldElement.square:()Lorg/bouncycastle/math/ec/ECFieldElement;
aastore
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.withCompression:Z
12: invokevirtual org.bouncycastle.math.ec.ECCurve.createRawPoint:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;[Lorg/bouncycastle/math/ec/ECFieldElement;Z)Lorg/bouncycastle/math/ec/ECPoint;
checkcast org.bouncycastle.math.ec.ECPoint$AbstractF2m
areturn
end local 5 end local 4 13: StackMap locals:
StackMap stack:
new java.lang.IllegalStateException
dup
ldc "unsupported coordinate system"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
3 14 1 curve Lorg/bouncycastle/math/ec/ECCurve;
4 14 2 coord I
5 14 3 X1 Lorg/bouncycastle/math/ec/ECFieldElement;
7 8 4 Y1 Lorg/bouncycastle/math/ec/ECFieldElement;
9 13 4 Y1 Lorg/bouncycastle/math/ec/ECFieldElement;
10 13 5 Z1 Lorg/bouncycastle/math/ec/ECFieldElement;
public org.bouncycastle.math.ec.ECPoint$AbstractF2m tauPow(int);
descriptor: (I)Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=7, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.isInfinity:()Z
ifeq 2
1: aload 0
areturn
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.bouncycastle.math.ec.ECPoint$AbstractF2m.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
astore 2
start local 2 3: aload 2
invokevirtual org.bouncycastle.math.ec.ECCurve.getCoordinateSystem:()I
istore 3
start local 3 4: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.x:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 4
start local 4 5: iload 3
tableswitch { // 0 - 6
0: 6
1: 8
2: 13
3: 13
4: 13
5: 6
6: 8
default: 13
}
6: StackMap locals: org.bouncycastle.math.ec.ECCurve int org.bouncycastle.math.ec.ECFieldElement
StackMap stack:
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.y:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 5
start local 5 7: aload 2
aload 4
iload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.squarePow:(I)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 5
iload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.squarePow:(I)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.withCompression:Z
invokevirtual org.bouncycastle.math.ec.ECCurve.createRawPoint:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;Z)Lorg/bouncycastle/math/ec/ECPoint;
checkcast org.bouncycastle.math.ec.ECPoint$AbstractF2m
areturn
end local 5 8: StackMap locals:
StackMap stack:
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.y:Lorg/bouncycastle/math/ec/ECFieldElement;
astore 5
start local 5 9: aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.zs:[Lorg/bouncycastle/math/ec/ECFieldElement;
iconst_0
aaload
astore 6
start local 6 10: aload 2
aload 4
iload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.squarePow:(I)Lorg/bouncycastle/math/ec/ECFieldElement;
aload 5
iload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.squarePow:(I)Lorg/bouncycastle/math/ec/ECFieldElement;
11: iconst_1
anewarray org.bouncycastle.math.ec.ECFieldElement
dup
iconst_0
aload 6
iload 1
invokevirtual org.bouncycastle.math.ec.ECFieldElement.squarePow:(I)Lorg/bouncycastle/math/ec/ECFieldElement;
aastore
aload 0
getfield org.bouncycastle.math.ec.ECPoint$AbstractF2m.withCompression:Z
12: invokevirtual org.bouncycastle.math.ec.ECCurve.createRawPoint:(Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;[Lorg/bouncycastle/math/ec/ECFieldElement;Z)Lorg/bouncycastle/math/ec/ECPoint;
checkcast org.bouncycastle.math.ec.ECPoint$AbstractF2m
areturn
end local 6 end local 5 13: StackMap locals:
StackMap stack:
new java.lang.IllegalStateException
dup
ldc "unsupported coordinate system"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lorg/bouncycastle/math/ec/ECPoint$AbstractF2m;
0 14 1 pow I
3 14 2 curve Lorg/bouncycastle/math/ec/ECCurve;
4 14 3 coord I
5 14 4 X1 Lorg/bouncycastle/math/ec/ECFieldElement;
7 8 5 Y1 Lorg/bouncycastle/math/ec/ECFieldElement;
9 13 5 Y1 Lorg/bouncycastle/math/ec/ECFieldElement;
10 13 6 Z1 Lorg/bouncycastle/math/ec/ECFieldElement;
MethodParameters:
Name Flags
pow
}
SourceFile: "ECPoint.java"
NestHost: org.bouncycastle.math.ec.ECPoint
InnerClasses:
public abstract AbstractF2m = org.bouncycastle.math.ec.ECCurve$AbstractF2m of org.bouncycastle.math.ec.ECCurve
public abstract AbstractF2m = org.bouncycastle.math.ec.ECFieldElement$AbstractF2m of org.bouncycastle.math.ec.ECFieldElement
public abstract AbstractF2m = org.bouncycastle.math.ec.ECPoint$AbstractF2m of org.bouncycastle.math.ec.ECPoint