DiscoverEndomorphisms.smali
.class public Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;
.super Ljava/lang/Object;
.source "DiscoverEndomorphisms.java"
# static fields
.field private static final radix:I = 0x10
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 15
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private static areRelativelyPrime(Ljava/math/BigInteger;Ljava/math/BigInteger;)Z
.registers 4
.prologue
.line 223
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->gcd(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
sget-object v1, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v0
return v0
.end method
.method private static calculateRange(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
.registers 5
.prologue
.line 228
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0, p2}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
.line 229
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v1, p2}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 230
invoke-static {v0, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->order(Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v0
return-object v0
.end method
.method private static chooseShortest([Ljava/math/BigInteger;[Ljava/math/BigInteger;)[Ljava/math/BigInteger;
.registers 3
.prologue
.line 307
invoke-static {p0, p1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->isShorter([Ljava/math/BigInteger;[Ljava/math/BigInteger;)Z
move-result v0
if-eqz v0, :cond_7
:goto_6
return-object p0
:cond_7
move-object p0, p1
goto :goto_6
.end method
.method private static discoverEndomorphisms(Ljava/lang/String;)V
.registers 5
.prologue
.line 55
invoke-static {p0}, Lorg/spongycastle/asn1/x9/ECNamedCurveTable;->getByName(Ljava/lang/String;)Lorg/spongycastle/asn1/x9/X9ECParameters;
move-result-object v0
.line 56
if-nez v0, :cond_1b
.line 58
sget-object v0, Ljava/lang/System;->err:Ljava/io/PrintStream;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Unknown curve: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 73
:cond_1a
:goto_1a
return-void
.line 62
:cond_1b
invoke-virtual {v0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v1
.line 63
invoke-static {v1}, Lorg/spongycastle/math/ec/ECAlgorithms;->isFpCurve(Lorg/spongycastle/math/ec/ECCurve;)Z
move-result v2
if-eqz v2, :cond_1a
.line 65
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECCurve;->getField()Lorg/spongycastle/math/field/FiniteField;
move-result-object v2
invoke-interface {v2}, Lorg/spongycastle/math/field/FiniteField;->getCharacteristic()Ljava/math/BigInteger;
move-result-object v2
.line 67
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECCurve;->getA()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v1
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECFieldElement;->isZero()Z
move-result v1
if-eqz v1, :cond_1a
sget-object v1, Lorg/spongycastle/math/ec/ECConstants;->THREE:Ljava/math/BigInteger;
invoke-virtual {v2, v1}, Ljava/math/BigInteger;->mod(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
sget-object v2, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_1a
.line 69
sget-object v1, Ljava/lang/System;->out:Ljava/io/PrintStream;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Curve \'"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, "\' has a \'GLV Type B\' endomorphism with these parameters:"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 70
invoke-static {v0}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printGLVTypeBParameters(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
goto :goto_1a
.end method
.method public static discoverEndomorphisms(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.registers 3
.prologue
.line 35
if-nez p0, :cond_a
.line 37
new-instance v0, Ljava/lang/NullPointerException;
const-string v1, "x9"
invoke-direct {v0, v1}, Ljava/lang/NullPointerException;-><init>(Ljava/lang/String;)V
throw v0
.line 40
:cond_a
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v0
.line 41
invoke-static {v0}, Lorg/spongycastle/math/ec/ECAlgorithms;->isFpCurve(Lorg/spongycastle/math/ec/ECCurve;)Z
move-result v1
if-eqz v1, :cond_3e
.line 43
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECCurve;->getField()Lorg/spongycastle/math/field/FiniteField;
move-result-object v1
invoke-interface {v1}, Lorg/spongycastle/math/field/FiniteField;->getCharacteristic()Ljava/math/BigInteger;
move-result-object v1
.line 45
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECCurve;->getA()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECFieldElement;->isZero()Z
move-result v0
if-eqz v0, :cond_3e
sget-object v0, Lorg/spongycastle/math/ec/ECConstants;->THREE:Ljava/math/BigInteger;
invoke-virtual {v1, v0}, Ljava/math/BigInteger;->mod(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
sget-object v1, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_3e
.line 47
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, "Curve has a \'GLV Type B\' endomorphism with these parameters:"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 48
invoke-static {p0}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printGLVTypeBParameters(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.line 51
:cond_3e
return-void
.end method
.method private static extEuclidBezout([Ljava/math/BigInteger;)[Ljava/math/BigInteger;
.registers 15
.prologue
const/4 v7, 0x1
const/4 v8, 0x0
.line 235
aget-object v0, p0, v8
aget-object v1, p0, v7
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-gez v0, :cond_48
move v6, v7
.line 236
:goto_d
if-eqz v6, :cond_12
.line 238
invoke-static {p0}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->swap([Ljava/math/BigInteger;)V
.line 241
:cond_12
aget-object v4, p0, v8
aget-object v5, p0, v7
.line 242
sget-object v3, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
sget-object v2, Lorg/spongycastle/math/ec/ECConstants;->ZERO:Ljava/math/BigInteger;
.line 243
sget-object v1, Lorg/spongycastle/math/ec/ECConstants;->ZERO:Ljava/math/BigInteger;
sget-object v0, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
.line 245
:goto_1e
sget-object v9, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v5, v9}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v9
if-lez v9, :cond_4a
.line 247
invoke-virtual {v4, v5}, Ljava/math/BigInteger;->divideAndRemainder(Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v4
.line 248
aget-object v9, v4, v8
aget-object v4, v4, v7
.line 250
invoke-virtual {v9, v2}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v10
invoke-virtual {v3, v10}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v3
.line 251
invoke-virtual {v9, v0}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v9
invoke-virtual {v1, v9}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
move-object v11, v1
move-object v1, v0
move-object v0, v11
move-object v12, v3
move-object v3, v2
move-object v2, v12
move-object v13, v5
move-object v5, v4
move-object v4, v13
.line 259
goto :goto_1e
:cond_48
move v6, v8
.line 235
goto :goto_d
.line 261
:cond_4a
invoke-virtual {v5}, Ljava/math/BigInteger;->signum()I
move-result v1
if-gtz v1, :cond_52
.line 266
const/4 v0, 0x0
.line 274
:goto_51
return-object v0
.line 269
:cond_52
const/4 v1, 0x2
new-array v1, v1, [Ljava/math/BigInteger;
aput-object v2, v1, v8
aput-object v0, v1, v7
.line 270
if-eqz v6, :cond_5e
.line 272
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->swap([Ljava/math/BigInteger;)V
:cond_5e
move-object v0, v1
.line 274
goto :goto_51
.end method
.method private static extEuclidGLV(Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
.registers 10
.prologue
const/4 v7, 0x1
const/4 v6, 0x0
.line 279
.line 281
sget-object v1, Lorg/spongycastle/math/ec/ECConstants;->ZERO:Ljava/math/BigInteger;
sget-object v0, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
move-object v2, v1
move-object v3, p0
move-object v4, p1
.line 285
:goto_9
invoke-virtual {v3, v4}, Ljava/math/BigInteger;->divideAndRemainder(Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v1
.line 286
aget-object v5, v1, v6
aget-object p1, v1, v7
.line 289
invoke-virtual {v5, v0}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 291
invoke-static {v4, p0}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->isLessThanSqrt(Ljava/math/BigInteger;Ljava/math/BigInteger;)Z
move-result v5
if-eqz v5, :cond_33
.line 293
const/4 v5, 0x6
new-array v5, v5, [Ljava/math/BigInteger;
aput-object v3, v5, v6
aput-object v2, v5, v7
const/4 v2, 0x2
aput-object v4, v5, v2
const/4 v2, 0x3
aput-object v0, v5, v2
const/4 v0, 0x4
aput-object p1, v5, v0
const/4 v0, 0x5
aput-object v1, v5, v0
return-object v5
:cond_33
move-object v2, v0
move-object v3, v4
move-object v0, v1
move-object v4, p1
.line 302
goto :goto_9
.end method
.method private static findBetaValues(Lorg/spongycastle/math/ec/ECCurve;)[Lorg/spongycastle/math/ec/ECFieldElement;
.registers 6
.prologue
.line 395
invoke-virtual {p0}, Lorg/spongycastle/math/ec/ECCurve;->getField()Lorg/spongycastle/math/field/FiniteField;
move-result-object v0
invoke-interface {v0}, Lorg/spongycastle/math/field/FiniteField;->getCharacteristic()Ljava/math/BigInteger;
move-result-object v0
.line 396
sget-object v1, Lorg/spongycastle/math/ec/ECConstants;->THREE:Ljava/math/BigInteger;
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 399
new-instance v2, Ljava/security/SecureRandom;
invoke-direct {v2}, Ljava/security/SecureRandom;-><init>()V
.line 403
:cond_13
sget-object v3, Lorg/spongycastle/math/ec/ECConstants;->TWO:Ljava/math/BigInteger;
sget-object v4, Lorg/spongycastle/math/ec/ECConstants;->TWO:Ljava/math/BigInteger;
invoke-virtual {v0, v4}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
invoke-static {v3, v4, v2}, Lorg/spongycastle/util/BigIntegers;->createRandomInRange(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/security/SecureRandom;)Ljava/math/BigInteger;
move-result-object v3
.line 404
invoke-virtual {v3, v1, v0}, Ljava/math/BigInteger;->modPow(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v3
.line 406
sget-object v4, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v3, v4}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v4
if-nez v4, :cond_13
.line 408
invoke-virtual {p0, v3}, Lorg/spongycastle/math/ec/ECCurve;->fromBigInteger(Ljava/math/BigInteger;)Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v0
.line 410
const/4 v1, 0x2
new-array v1, v1, [Lorg/spongycastle/math/ec/ECFieldElement;
const/4 v2, 0x0
aput-object v0, v1, v2
const/4 v2, 0x1
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECFieldElement;->square()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v0
aput-object v0, v1, v2
return-object v1
.end method
.method private static intersect([Ljava/math/BigInteger;[Ljava/math/BigInteger;)[Ljava/math/BigInteger;
.registers 7
.prologue
const/4 v4, 0x1
const/4 v3, 0x0
.line 312
aget-object v0, p0, v3
aget-object v1, p1, v3
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->max(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 313
aget-object v0, p0, v4
aget-object v2, p1, v4
invoke-virtual {v0, v2}, Ljava/math/BigInteger;->min(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
.line 314
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-lez v0, :cond_1a
.line 316
const/4 v0, 0x0
.line 318
:goto_19
return-object v0
:cond_1a
const/4 v0, 0x2
new-array v0, v0, [Ljava/math/BigInteger;
aput-object v1, v0, v3
aput-object v2, v0, v4
goto :goto_19
.end method
.method private static isLessThanSqrt(Ljava/math/BigInteger;Ljava/math/BigInteger;)Z
.registers 7
.prologue
.line 323
invoke-virtual {p0}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v0
.line 324
invoke-virtual {p1}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v1
.line 325
invoke-virtual {v1}, Ljava/math/BigInteger;->bitLength()I
move-result v2
invoke-virtual {v0}, Ljava/math/BigInteger;->bitLength()I
move-result v3
shl-int/lit8 v3, v3, 0x1
add-int/lit8 v4, v3, -0x1
.line 326
if-gt v4, v2, :cond_24
if-lt v3, v2, :cond_22
invoke-virtual {v0, v0}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-gez v0, :cond_24
:cond_22
const/4 v0, 0x1
:goto_23
return v0
:cond_24
const/4 v0, 0x0
goto :goto_23
.end method
.method private static isShorter([Ljava/math/BigInteger;[Ljava/math/BigInteger;)Z
.registers 10
.prologue
const/4 v1, 0x1
const/4 v2, 0x0
.line 331
aget-object v0, p0, v2
invoke-virtual {v0}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v4
aget-object v0, p0, v1
invoke-virtual {v0}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v5
aget-object v0, p1, v2
invoke-virtual {v0}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v6
aget-object v0, p1, v1
invoke-virtual {v0}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v7
.line 336
invoke-virtual {v4, v6}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-gez v0, :cond_2b
move v0, v1
:goto_21
invoke-virtual {v5, v7}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v3
if-gez v3, :cond_2d
move v3, v1
.line 337
:goto_28
if-ne v0, v3, :cond_2f
.line 345
:goto_2a
return v0
:cond_2b
move v0, v2
.line 336
goto :goto_21
:cond_2d
move v3, v2
goto :goto_28
.line 342
:cond_2f
invoke-virtual {v4, v4}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v5, v5}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
.line 343
invoke-virtual {v6, v6}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v3
invoke-virtual {v7, v7}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v3
.line 345
invoke-virtual {v0, v3}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-gez v0, :cond_4f
move v0, v1
goto :goto_2a
:cond_4f
move v0, v2
goto :goto_2a
.end method
.method private static isVectorBoundedBySqrt([Ljava/math/BigInteger;Ljava/math/BigInteger;)Z
.registers 4
.prologue
.line 350
const/4 v0, 0x0
aget-object v0, p0, v0
invoke-virtual {v0}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v0
const/4 v1, 0x1
aget-object v1, p0, v1
invoke-virtual {v1}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->max(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
.line 351
invoke-static {v0, p1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->isLessThanSqrt(Ljava/math/BigInteger;Ljava/math/BigInteger;)Z
move-result v0
return v0
.end method
.method private static isqrt(Ljava/math/BigInteger;)Ljava/math/BigInteger;
.registers 4
.prologue
.line 415
invoke-virtual {p0}, Ljava/math/BigInteger;->bitLength()I
move-result v0
div-int/lit8 v0, v0, 0x2
invoke-virtual {p0, v0}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object v0
.line 418
:goto_a
invoke-virtual {p0, v0}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
const/4 v2, 0x1
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object v1
.line 419
invoke-virtual {v1, v0}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1e
.line 421
return-object v1
:cond_1e
move-object v0, v1
.line 424
goto :goto_a
.end method
.method public static main([Ljava/lang/String;)V
.registers 3
.prologue
.line 21
array-length v0, p0
if-gtz v0, :cond_b
.line 23
sget-object v0, Ljava/lang/System;->err:Ljava/io/PrintStream;
const-string v1, "Expected a list of curve names as arguments"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 31
:cond_a
return-void
.line 27
:cond_b
const/4 v0, 0x0
:goto_c
array-length v1, p0
if-ge v0, v1, :cond_a
.line 29
aget-object v1, p0, v0
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->discoverEndomorphisms(Ljava/lang/String;)V
.line 27
add-int/lit8 v0, v0, 0x1
goto :goto_c
.end method
.method private static order(Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
.registers 6
.prologue
const/4 v3, 0x2
const/4 v2, 0x1
const/4 v1, 0x0
.line 356
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-gtz v0, :cond_10
.line 358
new-array v0, v3, [Ljava/math/BigInteger;
aput-object p0, v0, v1
aput-object p1, v0, v2
.line 360
:goto_f
return-object v0
:cond_10
new-array v0, v3, [Ljava/math/BigInteger;
aput-object p1, v0, v1
aput-object p0, v0, v2
goto :goto_f
.end method
.method private static printGLVTypeBParameters(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.registers 5
.prologue
.line 78
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getN()Ljava/math/BigInteger;
move-result-object v0
sget-object v1, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
sget-object v2, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-static {v0, v1, v2}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->solveQuadraticEquation(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v0
.line 84
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->findBetaValues(Lorg/spongycastle/math/ec/ECCurve;)[Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v1
.line 86
const/4 v2, 0x0
aget-object v2, v0, v2
invoke-static {p0, v2, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printGLVTypeBParameters(Lorg/spongycastle/asn1/x9/X9ECParameters;Ljava/math/BigInteger;[Lorg/spongycastle/math/ec/ECFieldElement;)V
.line 87
sget-object v2, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v3, "OR"
invoke-virtual {v2, v3}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 88
const/4 v2, 0x1
aget-object v0, v0, v2
invoke-static {p0, v0, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printGLVTypeBParameters(Lorg/spongycastle/asn1/x9/X9ECParameters;Ljava/math/BigInteger;[Lorg/spongycastle/math/ec/ECFieldElement;)V
.line 89
return-void
.end method
.method private static printGLVTypeBParameters(Lorg/spongycastle/asn1/x9/X9ECParameters;Ljava/math/BigInteger;[Lorg/spongycastle/math/ec/ECFieldElement;)V
.registers 16
.prologue
.line 96
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getG()Lorg/spongycastle/math/ec/ECPoint;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECPoint;->normalize()Lorg/spongycastle/math/ec/ECPoint;
move-result-object v1
.line 97
invoke-virtual {v1, p1}, Lorg/spongycastle/math/ec/ECPoint;->multiply(Ljava/math/BigInteger;)Lorg/spongycastle/math/ec/ECPoint;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECPoint;->normalize()Lorg/spongycastle/math/ec/ECPoint;
move-result-object v2
.line 98
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECPoint;->getYCoord()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v0
invoke-virtual {v2}, Lorg/spongycastle/math/ec/ECPoint;->getYCoord()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_26
.line 100
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Derivation of GLV Type B parameters failed unexpectedly"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 107
:cond_26
const/4 v0, 0x0
aget-object v0, p2, v0
.line 108
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECPoint;->getXCoord()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v3
invoke-virtual {v3, v0}, Lorg/spongycastle/math/ec/ECFieldElement;->multiply(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v3
invoke-virtual {v2}, Lorg/spongycastle/math/ec/ECPoint;->getXCoord()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v3
if-nez v3, :cond_58
.line 110
const/4 v0, 0x1
aget-object v0, p2, v0
.line 111
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECPoint;->getXCoord()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v1
invoke-virtual {v1, v0}, Lorg/spongycastle/math/ec/ECFieldElement;->multiply(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v1
invoke-virtual {v2}, Lorg/spongycastle/math/ec/ECPoint;->getXCoord()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_58
.line 113
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Derivation of GLV Type B parameters failed unexpectedly"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 120
:cond_58
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getN()Ljava/math/BigInteger;
move-result-object v5
.line 124
invoke-static {v5, p1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->extEuclidGLV(Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v1
.line 125
const/4 v2, 0x2
new-array v6, v2, [Ljava/math/BigInteger;
const/4 v2, 0x0
const/4 v3, 0x2
aget-object v3, v1, v3
aput-object v3, v6, v2
const/4 v2, 0x1
const/4 v3, 0x3
aget-object v3, v1, v3
invoke-virtual {v3}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v3
aput-object v3, v6, v2
.line 126
const/4 v2, 0x2
new-array v2, v2, [Ljava/math/BigInteger;
const/4 v3, 0x0
const/4 v4, 0x0
aget-object v4, v1, v4
aput-object v4, v2, v3
const/4 v3, 0x1
const/4 v4, 0x1
aget-object v4, v1, v4
invoke-virtual {v4}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v4
aput-object v4, v2, v3
const/4 v3, 0x2
new-array v3, v3, [Ljava/math/BigInteger;
const/4 v4, 0x0
const/4 v7, 0x4
aget-object v7, v1, v7
aput-object v7, v3, v4
const/4 v4, 0x1
const/4 v7, 0x5
aget-object v1, v1, v7
invoke-virtual {v1}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v1
aput-object v1, v3, v4
invoke-static {v2, v3}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->chooseShortest([Ljava/math/BigInteger;[Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v3
.line 134
invoke-static {v3, v5}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->isVectorBoundedBySqrt([Ljava/math/BigInteger;Ljava/math/BigInteger;)Z
move-result v1
if-nez v1, :cond_173
const/4 v1, 0x0
aget-object v1, v6, v1
const/4 v2, 0x1
aget-object v2, v6, v2
invoke-static {v1, v2}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->areRelativelyPrime(Ljava/math/BigInteger;Ljava/math/BigInteger;)Z
move-result v1
if-eqz v1, :cond_173
.line 136
const/4 v1, 0x0
aget-object v7, v6, v1
const/4 v1, 0x1
aget-object v8, v6, v1
invoke-virtual {v8, p1}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v7, v1}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v1, v5}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
.line 138
const/4 v1, 0x2
new-array v1, v1, [Ljava/math/BigInteger;
const/4 v2, 0x0
invoke-virtual {v4}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v9
aput-object v9, v1, v2
const/4 v2, 0x1
invoke-virtual {v8}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v9
aput-object v9, v1, v2
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->extEuclidBezout([Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v2
.line 139
if-eqz v2, :cond_173
.line 141
const/4 v1, 0x0
aget-object v1, v2, v1
const/4 v9, 0x1
aget-object v2, v2, v9
.line 143
invoke-virtual {v4}, Ljava/math/BigInteger;->signum()I
move-result v9
if-gez v9, :cond_e8
.line 145
invoke-virtual {v1}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v1
.line 147
:cond_e8
invoke-virtual {v8}, Ljava/math/BigInteger;->signum()I
move-result v9
if-lez v9, :cond_f2
.line 149
invoke-virtual {v2}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v2
.line 152
:cond_f2
invoke-virtual {v4, v1}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
invoke-virtual {v8, v2}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v9
invoke-virtual {v4, v9}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
.line 153
sget-object v9, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v4, v9}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v4
if-nez v4, :cond_10c
.line 155
new-instance v0, Ljava/lang/IllegalStateException;
invoke-direct {v0}, Ljava/lang/IllegalStateException;-><init>()V
throw v0
.line 158
:cond_10c
invoke-virtual {v2, v5}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
invoke-virtual {v1, p1}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
invoke-virtual {v2, v4}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v9
.line 160
invoke-virtual {v1}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v2
.line 161
invoke-virtual {v9}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v4
.line 167
sget-object v10, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v5, v10}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v10
invoke-static {v10}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->isqrt(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v10
sget-object v11, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v10, v11}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v10
.line 169
invoke-static {v2, v10, v8}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->calculateRange(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v2
.line 170
invoke-static {v4, v10, v7}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->calculateRange(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v4
.line 172
invoke-static {v2, v4}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->intersect([Ljava/math/BigInteger;[Ljava/math/BigInteger;)[Ljava/math/BigInteger;
move-result-object v10
.line 173
if-eqz v10, :cond_173
.line 175
const/4 v2, 0x0
aget-object v2, v10, v2
move-object v4, v2
:goto_142
const/4 v2, 0x1
aget-object v2, v10, v2
invoke-virtual {v4, v2}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v2
if-gtz v2, :cond_173
.line 177
const/4 v2, 0x2
new-array v2, v2, [Ljava/math/BigInteger;
const/4 v11, 0x0
invoke-virtual {v4, v7}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v12
invoke-virtual {v9, v12}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v12
aput-object v12, v2, v11
const/4 v11, 0x1
invoke-virtual {v4, v8}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v12
invoke-virtual {v1, v12}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v12
aput-object v12, v2, v11
.line 178
invoke-static {v2, v3}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->isShorter([Ljava/math/BigInteger;[Ljava/math/BigInteger;)Z
move-result v11
if-eqz v11, :cond_263
.line 175
:goto_16a
sget-object v3, Lorg/spongycastle/math/ec/ECConstants;->ONE:Ljava/math/BigInteger;
invoke-virtual {v4, v3}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v3
move-object v4, v3
move-object v3, v2
goto :goto_142
.line 187
:cond_173
const/4 v1, 0x0
aget-object v1, v6, v1
const/4 v2, 0x1
aget-object v2, v3, v2
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
const/4 v2, 0x1
aget-object v2, v6, v2
const/4 v4, 0x0
aget-object v4, v3, v4
invoke-virtual {v2, v4}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 194
invoke-virtual {v5}, Ljava/math/BigInteger;->bitLength()I
move-result v2
add-int/lit8 v2, v2, 0x10
invoke-virtual {v5}, Ljava/math/BigInteger;->bitLength()I
move-result v4
and-int/lit8 v4, v4, 0x7
sub-int/2addr v2, v4
.line 195
const/4 v4, 0x1
aget-object v4, v3, v4
invoke-virtual {v4, v2}, Ljava/math/BigInteger;->shiftLeft(I)Ljava/math/BigInteger;
move-result-object v4
invoke-static {v4, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->roundQuotient(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v4
.line 196
const/4 v5, 0x1
aget-object v5, v6, v5
invoke-virtual {v5, v2}, Ljava/math/BigInteger;->shiftLeft(I)Ljava/math/BigInteger;
move-result-object v5
invoke-static {v5, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->roundQuotient(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v5
invoke-virtual {v5}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v5
.line 198
const-string v7, "Beta"
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECFieldElement;->toBigInteger()Ljava/math/BigInteger;
move-result-object v0
const/16 v8, 0x10
invoke-virtual {v0, v8}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v0
invoke-static {v7, v0}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.line 199
const-string v0, "Lambda"
const/16 v7, 0x10
invoke-virtual {p1, v7}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v7
invoke-static {v0, v7}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.line 200
const-string v0, "v1"
new-instance v7, Ljava/lang/StringBuilder;
const-string v8, "{ "
invoke-direct {v7, v8}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
const/4 v8, 0x0
aget-object v8, v6, v8
const/16 v9, 0x10
invoke-virtual {v8, v9}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v8
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
const-string v8, ", "
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
const/4 v8, 0x1
aget-object v6, v6, v8
const/16 v8, 0x10
invoke-virtual {v6, v8}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v6
invoke-virtual {v7, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const-string v7, " }"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-static {v0, v6}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.line 201
const-string v0, "v2"
new-instance v6, Ljava/lang/StringBuilder;
const-string v7, "{ "
invoke-direct {v6, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
const/4 v7, 0x0
aget-object v7, v3, v7
const/16 v8, 0x10
invoke-virtual {v7, v8}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v7
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const-string v7, ", "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const/4 v7, 0x1
aget-object v3, v3, v7
const/16 v7, 0x10
invoke-virtual {v3, v7}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v3
invoke-virtual {v6, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const-string v6, " }"
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v0, v3}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.line 202
const-string v0, "d"
const/16 v3, 0x10
invoke-virtual {v1, v3}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.line 203
const-string v0, "(OPT) g1"
const/16 v1, 0x10
invoke-virtual {v4, v1}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.line 204
const-string v0, "(OPT) g2"
const/16 v1, 0x10
invoke-virtual {v5, v1}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.line 205
const-string v0, "(OPT) bits"
invoke-static {v2}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lorg/spongycastle/math/ec/tools/DiscoverEndomorphisms;->printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.line 206
return-void
:cond_263
move-object v2, v3
goto/16 :goto_16a
.end method
.method private static printProperty(Ljava/lang/String;Ljava/lang/Object;)V
.registers 5
.prologue
.line 210
new-instance v0, Ljava/lang/StringBuffer;
const-string v1, " "
invoke-direct {v0, v1}, Ljava/lang/StringBuffer;-><init>(Ljava/lang/String;)V
.line 211
invoke-virtual {v0, p0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
.line 212
:goto_a
invoke-virtual {v0}, Ljava/lang/StringBuffer;->length()I
move-result v1
const/16 v2, 0x14
if-ge v1, v2, :cond_18
.line 214
const/16 v1, 0x20
invoke-virtual {v0, v1}, Ljava/lang/StringBuffer;->append(C)Ljava/lang/StringBuffer;
goto :goto_a
.line 216
:cond_18
const-string v1, "= "
invoke-virtual {v0, v1}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
.line 217
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
.line 218
sget-object v1, Ljava/lang/System;->out:Ljava/io/PrintStream;
invoke-virtual {v0}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 219
return-void
.end method
.method private static roundQuotient(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
.registers 6
.prologue
const/4 v1, 0x1
.line 365
invoke-virtual {p0}, Ljava/math/BigInteger;->signum()I
move-result v0
invoke-virtual {p1}, Ljava/math/BigInteger;->signum()I
move-result v2
if-eq v0, v2, :cond_27
move v0, v1
.line 366
:goto_c
invoke-virtual {p0}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v2
.line 367
invoke-virtual {p1}, Ljava/math/BigInteger;->abs()Ljava/math/BigInteger;
move-result-object v3
.line 368
invoke-virtual {v3, v1}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v1, v3}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 369
if-eqz v0, :cond_29
invoke-virtual {v1}, Ljava/math/BigInteger;->negate()Ljava/math/BigInteger;
move-result-object v0
:goto_26
return-object v0
.line 365
:cond_27
const/4 v0, 0x0
goto :goto_c
:cond_29
move-object v0, v1
.line 369
goto :goto_26
.end method
.method private static solveQuadraticEquation(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)[Ljava/math/BigInteger;
.registers 9
.prologue
const/4 v5, 0x2
const/4 v4, 0x0
const/4 v3, 0x1
.line 374
invoke-virtual {p1, p1}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {p2, v5}, Ljava/math/BigInteger;->shiftLeft(I)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0, p0}, Ljava/math/BigInteger;->mod(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
.line 376
new-instance v1, Lorg/spongycastle/math/ec/ECFieldElement$Fp;
invoke-direct {v1, p0, v0}, Lorg/spongycastle/math/ec/ECFieldElement$Fp;-><init>(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECFieldElement$Fp;->sqrt()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECFieldElement;->toBigInteger()Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {p0, v1}, Ljava/math/BigInteger;->subtract(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
.line 377
invoke-virtual {v1, v4}, Ljava/math/BigInteger;->testBit(I)Z
move-result v2
if-eqz v2, :cond_3d
.line 379
invoke-virtual {v0, p0}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
.line 390
:goto_2e
new-array v2, v5, [Ljava/math/BigInteger;
invoke-virtual {v1, v3}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object v1
aput-object v1, v2, v4
invoke-virtual {v0, v3}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object v0
aput-object v0, v2, v3
return-object v2
.line 383
:cond_3d
invoke-virtual {v1, p0}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
goto :goto_2e
.end method
.method private static swap([Ljava/math/BigInteger;)V
.registers 5
.prologue
const/4 v3, 0x1
const/4 v2, 0x0
.line 429
aget-object v0, p0, v2
.line 430
aget-object v1, p0, v3
aput-object v1, p0, v2
.line 431
aput-object v0, p0, v3
.line 432
return-void
.end method