TraceOptimizer.smali
.class public Lorg/spongycastle/math/ec/tools/TraceOptimizer;
.super Ljava/lang/Object;
.source "TraceOptimizer.java"
# static fields
.field private static final ONE:Ljava/math/BigInteger;
.field private static final R:Ljava/security/SecureRandom;
# direct methods
.method static constructor <clinit>()V
.registers 2
.prologue
.line 21
const-wide/16 v0, 0x1
invoke-static {v0, v1}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v0
sput-object v0, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->ONE:Ljava/math/BigInteger;
.line 23
new-instance v0, Ljava/security/SecureRandom;
invoke-direct {v0}, Ljava/security/SecureRandom;-><init>()V
sput-object v0, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->R:Ljava/security/SecureRandom;
return-void
.end method
.method public constructor <init>()V
.registers 1
.prologue
.line 19
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private static calculateTrace(Lorg/spongycastle/math/ec/ECFieldElement;)I
.registers 5
.prologue
const/4 v1, 0x1
.line 114
invoke-virtual {p0}, Lorg/spongycastle/math/ec/ECFieldElement;->getFieldSize()I
move-result v3
move v0, v1
move-object v2, p0
.line 116
:goto_7
if-ge v0, v3, :cond_14
.line 118
invoke-virtual {v2}, Lorg/spongycastle/math/ec/ECFieldElement;->square()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v2
.line 119
invoke-virtual {p0, v2}, Lorg/spongycastle/math/ec/ECFieldElement;->add(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object p0
.line 116
add-int/lit8 v0, v0, 0x1
goto :goto_7
.line 121
:cond_14
invoke-virtual {p0}, Lorg/spongycastle/math/ec/ECFieldElement;->toBigInteger()Ljava/math/BigInteger;
move-result-object v0
.line 122
invoke-virtual {v0}, Ljava/math/BigInteger;->bitLength()I
move-result v2
if-le v2, v1, :cond_24
.line 124
new-instance v0, Ljava/lang/IllegalStateException;
invoke-direct {v0}, Ljava/lang/IllegalStateException;-><init>()V
throw v0
.line 126
:cond_24
invoke-virtual {v0}, Ljava/math/BigInteger;->intValue()I
move-result v0
return v0
.end method
.method private static enumToList(Ljava/util/Enumeration;)Ljava/util/ArrayList;
.registers 3
.prologue
.line 131
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 132
:goto_5
invoke-interface {p0}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v1
if-eqz v1, :cond_13
.line 134
invoke-interface {p0}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_5
.line 136
:cond_13
return-object v0
.end method
.method public static implPrintNonZeroTraceBits(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.registers 11
.prologue
const/4 v2, 0x0
.line 59
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v5
.line 60
invoke-virtual {v5}, Lorg/spongycastle/math/ec/ECCurve;->getFieldSize()I
move-result v6
.line 62
new-instance v7, Ljava/util/ArrayList;
invoke-direct {v7}, Ljava/util/ArrayList;-><init>()V
move v0, v2
.line 70
:goto_f
if-ge v0, v6, :cond_3f
.line 72
sget-object v1, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->ONE:Ljava/math/BigInteger;
invoke-virtual {v1, v0}, Ljava/math/BigInteger;->shiftLeft(I)Ljava/math/BigInteger;
move-result-object v1
.line 73
invoke-virtual {v5, v1}, Lorg/spongycastle/math/ec/ECCurve;->fromBigInteger(Ljava/math/BigInteger;)Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v1
.line 74
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->calculateTrace(Lorg/spongycastle/math/ec/ECFieldElement;)I
move-result v1
.line 75
if-eqz v1, :cond_3c
.line 77
invoke-static {v0}, Lorg/spongycastle/util/Integers;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
invoke-virtual {v7, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 78
sget-object v1, Ljava/lang/System;->out:Ljava/io/PrintStream;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, " "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v1, v3}, Ljava/io/PrintStream;->print(Ljava/lang/String;)V
.line 70
:cond_3c
add-int/lit8 v0, v0, 0x1
goto :goto_f
.line 81
:cond_3f
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
invoke-virtual {v0}, Ljava/io/PrintStream;->println()V
move v4, v2
.line 88
:goto_45
const/16 v0, 0x3e8
if-ge v4, v0, :cond_84
.line 90
new-instance v8, Ljava/math/BigInteger;
sget-object v0, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->R:Ljava/security/SecureRandom;
invoke-direct {v8, v6, v0}, Ljava/math/BigInteger;-><init>(ILjava/util/Random;)V
.line 91
invoke-virtual {v5, v8}, Lorg/spongycastle/math/ec/ECCurve;->fromBigInteger(Ljava/math/BigInteger;)Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v0
.line 92
invoke-static {v0}, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->calculateTrace(Lorg/spongycastle/math/ec/ECFieldElement;)I
move-result v9
move v1, v2
move v3, v2
.line 95
:goto_5a
invoke-virtual {v7}, Ljava/util/ArrayList;->size()I
move-result v0
if-ge v1, v0, :cond_76
.line 97
invoke-virtual {v7, v1}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Integer;
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v0
.line 98
invoke-virtual {v8, v0}, Ljava/math/BigInteger;->testBit(I)Z
move-result v0
if-eqz v0, :cond_72
.line 100
xor-int/lit8 v3, v3, 0x1
.line 95
:cond_72
add-int/lit8 v0, v1, 0x1
move v1, v0
goto :goto_5a
.line 104
:cond_76
if-eq v9, v3, :cond_80
.line 106
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Optimized-trace sanity check failed"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 88
:cond_80
add-int/lit8 v0, v4, 0x1
move v4, v0
goto :goto_45
.line 110
:cond_84
return-void
.end method
.method public static main([Ljava/lang/String;)V
.registers 6
.prologue
.line 27
new-instance v0, Ljava/util/TreeSet;
invoke-static {}, Lorg/spongycastle/asn1/x9/ECNamedCurveTable;->getNames()Ljava/util/Enumeration;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->enumToList(Ljava/util/Enumeration;)Ljava/util/ArrayList;
move-result-object v1
invoke-direct {v0, v1}, Ljava/util/TreeSet;-><init>(Ljava/util/Collection;)V
.line 28
invoke-static {}, Lorg/spongycastle/crypto/ec/CustomNamedCurves;->getNames()Ljava/util/Enumeration;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->enumToList(Ljava/util/Enumeration;)Ljava/util/ArrayList;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/SortedSet;->addAll(Ljava/util/Collection;)Z
.line 30
invoke-interface {v0}, Ljava/util/SortedSet;->iterator()Ljava/util/Iterator;
move-result-object v2
.line 31
:cond_1c
:goto_1c
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_5a
.line 33
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
.line 34
invoke-static {v0}, Lorg/spongycastle/crypto/ec/CustomNamedCurves;->getByName(Ljava/lang/String;)Lorg/spongycastle/asn1/x9/X9ECParameters;
move-result-object v1
.line 35
if-nez v1, :cond_32
.line 37
invoke-static {v0}, Lorg/spongycastle/asn1/x9/ECNamedCurveTable;->getByName(Ljava/lang/String;)Lorg/spongycastle/asn1/x9/X9ECParameters;
move-result-object v1
.line 39
:cond_32
if-eqz v1, :cond_1c
invoke-virtual {v1}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v3
invoke-static {v3}, Lorg/spongycastle/math/ec/ECAlgorithms;->isF2mCurve(Lorg/spongycastle/math/ec/ECCurve;)Z
move-result v3
if-eqz v3, :cond_1c
.line 41
sget-object v3, Ljava/lang/System;->out:Ljava/io/PrintStream;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v4, ":"
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/io/PrintStream;->print(Ljava/lang/String;)V
.line 42
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->implPrintNonZeroTraceBits(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
goto :goto_1c
.line 45
:cond_5a
return-void
.end method
.method public static printNonZeroTraceBits(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.registers 3
.prologue
.line 49
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/math/ec/ECAlgorithms;->isF2mCurve(Lorg/spongycastle/math/ec/ECCurve;)Z
move-result v0
if-nez v0, :cond_12
.line 51
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Trace only defined over characteristic-2 fields"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 54
:cond_12
invoke-static {p0}, Lorg/spongycastle/math/ec/tools/TraceOptimizer;->implPrintNonZeroTraceBits(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.line 55
return-void
.end method