SecP224K1FieldElement.smali
.class public Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
.super Lorg/spongycastle/math/ec/ECFieldElement;
.source "SecP224K1FieldElement.java"
# static fields
.field private static final PRECOMP_POW2:[I
.field public static final Q:Ljava/math/BigInteger;
# instance fields
.field protected x:[I
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 12
sget-object v0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Curve;->q:Ljava/math/BigInteger;
sput-object v0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->Q:Ljava/math/BigInteger;
.line 15
const/4 v0, 0x7
new-array v0, v0, [I
fill-array-data v0, :array_e
sput-object v0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->PRECOMP_POW2:[I
return-void
nop
:array_e
.array-data 4
0x33bfd202
-0x23052ecd
0x2287624a
-0x3c7ee458
-0x57aaa704
0x1eaef5d7
-0x7120eab4
.end array-data
.end method
.method public constructor <init>()V
.registers 2
.prologue
.line 31
invoke-direct {p0}, Lorg/spongycastle/math/ec/ECFieldElement;-><init>()V
.line 32
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
.line 33
return-void
.end method
.method public constructor <init>(Ljava/math/BigInteger;)V
.registers 4
.prologue
.line 21
invoke-direct {p0}, Lorg/spongycastle/math/ec/ECFieldElement;-><init>()V
.line 22
if-eqz p1, :cond_13
invoke-virtual {p1}, Ljava/math/BigInteger;->signum()I
move-result v0
if-ltz v0, :cond_13
sget-object v0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->Q:Ljava/math/BigInteger;
invoke-virtual {p1, v0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-ltz v0, :cond_1b
.line 24
:cond_13
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "x value invalid for SecP224K1FieldElement"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 27
:cond_1b
invoke-static {p1}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->fromBigInteger(Ljava/math/BigInteger;)[I
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
.line 28
return-void
.end method
.method protected constructor <init>([I)V
.registers 2
.prologue
.line 36
invoke-direct {p0}, Lorg/spongycastle/math/ec/ECFieldElement;-><init>()V
.line 37
iput-object p1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
.line 38
return-void
.end method
# virtual methods
.method public add(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
.registers 5
.prologue
.line 72
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
.line 73
iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
iget-object v2, p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v1, v2, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->add([I[I[I)V
.line 74
new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
return-object v1
.end method
.method public addOne()Lorg/spongycastle/math/ec/ECFieldElement;
.registers 3
.prologue
.line 79
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
.line 80
iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->addOne([I[I)V
.line 81
new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
return-object v1
.end method
.method public divide(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
.registers 5
.prologue
.line 101
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
.line 102
sget-object v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->P:[I
check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
iget-object v2, p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v1, v2, v0}, Lorg/spongycastle/math/raw/Mod;->invert([I[I[I)V
.line 103
iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v0, v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 104
new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
return-object v1
.end method
.method public equals(Ljava/lang/Object;)Z
.registers 4
.prologue
.line 225
if-ne p1, p0, :cond_4
.line 227
const/4 v0, 0x1
.line 236
:goto_3
return v0
.line 230
:cond_4
instance-of v0, p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
if-nez v0, :cond_a
.line 232
const/4 v0, 0x0
goto :goto_3
.line 235
:cond_a
check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
.line 236
iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
iget-object v1, p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v0, v1}, Lorg/spongycastle/math/raw/Nat224;->eq([I[I)Z
move-result v0
goto :goto_3
.end method
.method public getFieldName()Ljava/lang/String;
.registers 2
.prologue
.line 62
const-string v0, "SecP224K1Field"
return-object v0
.end method
.method public getFieldSize()I
.registers 2
.prologue
.line 67
sget-object v0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->Q:Ljava/math/BigInteger;
invoke-virtual {v0}, Ljava/math/BigInteger;->bitLength()I
move-result v0
return v0
.end method
.method public hashCode()I
.registers 5
.prologue
.line 241
sget-object v0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->Q:Ljava/math/BigInteger;
invoke-virtual {v0}, Ljava/math/BigInteger;->hashCode()I
move-result v0
iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
const/4 v2, 0x0
const/4 v3, 0x7
invoke-static {v1, v2, v3}, Lorg/spongycastle/util/Arrays;->hashCode([III)I
move-result v1
xor-int/2addr v0, v1
return v0
.end method
.method public invert()Lorg/spongycastle/math/ec/ECFieldElement;
.registers 4
.prologue
.line 124
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
.line 125
sget-object v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->P:[I
iget-object v2, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v1, v2, v0}, Lorg/spongycastle/math/raw/Mod;->invert([I[I[I)V
.line 126
new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
return-object v1
.end method
.method public isOne()Z
.registers 2
.prologue
.line 47
iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v0}, Lorg/spongycastle/math/raw/Nat224;->isOne([I)Z
move-result v0
return v0
.end method
.method public isZero()Z
.registers 2
.prologue
.line 42
iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v0}, Lorg/spongycastle/math/raw/Nat224;->isZero([I)Z
move-result v0
return v0
.end method
.method public multiply(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
.registers 5
.prologue
.line 93
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
.line 94
iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
iget-object v2, p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v1, v2, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 95
new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
return-object v1
.end method
.method public negate()Lorg/spongycastle/math/ec/ECFieldElement;
.registers 3
.prologue
.line 109
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
.line 110
iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->negate([I[I)V
.line 111
new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
return-object v1
.end method
.method public sqrt()Lorg/spongycastle/math/ec/ECFieldElement;
.registers 10
.prologue
const/4 v8, 0x3
const/4 v7, 0x4
.line 148
iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
.line 149
invoke-static {v0}, Lorg/spongycastle/math/raw/Nat224;->isZero([I)Z
move-result v1
if-nez v1, :cond_10
invoke-static {v0}, Lorg/spongycastle/math/raw/Nat224;->isOne([I)Z
move-result v1
if-eqz v1, :cond_11
.line 220
:cond_10
:goto_10
return-object p0
.line 154
:cond_11
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v1
.line 155
invoke-static {v0, v1}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->square([I[I)V
.line 156
invoke-static {v1, v0, v1}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 158
invoke-static {v1, v1}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->square([I[I)V
.line 159
invoke-static {v1, v0, v1}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 160
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v2
.line 161
invoke-static {v1, v2}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->square([I[I)V
.line 162
invoke-static {v2, v0, v2}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 163
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v3
.line 164
invoke-static {v2, v7, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 165
invoke-static {v3, v2, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 166
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v4
.line 167
invoke-static {v3, v8, v4}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 168
invoke-static {v4, v1, v4}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 170
const/16 v5, 0x8
invoke-static {v4, v5, v4}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 171
invoke-static {v4, v3, v4}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 173
invoke-static {v4, v7, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 174
invoke-static {v3, v2, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 176
const/16 v5, 0x13
invoke-static {v3, v5, v2}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 177
invoke-static {v2, v4, v2}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 178
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v5
.line 179
const/16 v6, 0x2a
invoke-static {v2, v6, v5}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 180
invoke-static {v5, v2, v5}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 182
const/16 v6, 0x17
invoke-static {v5, v6, v2}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 183
invoke-static {v2, v3, v2}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 185
const/16 v6, 0x54
invoke-static {v2, v6, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 186
invoke-static {v3, v5, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 189
const/16 v2, 0x14
invoke-static {v3, v2, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 190
invoke-static {v3, v4, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 191
invoke-static {v3, v8, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 192
invoke-static {v3, v0, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 193
const/4 v2, 0x2
invoke-static {v3, v2, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 194
invoke-static {v3, v0, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 195
invoke-static {v3, v7, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->squareN([II[I)V
.line 196
invoke-static {v3, v1, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 197
invoke-static {v3, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->square([I[I)V
.line 200
invoke-static {v3, v5}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->square([I[I)V
.line 202
invoke-static {v0, v5}, Lorg/spongycastle/math/raw/Nat224;->eq([I[I)Z
move-result v1
if-eqz v1, :cond_9f
.line 204
new-instance p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {p0, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
goto/16 :goto_10
.line 211
:cond_9f
sget-object v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->PRECOMP_POW2:[I
invoke-static {v3, v1, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->multiply([I[I[I)V
.line 213
invoke-static {v3, v5}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->square([I[I)V
.line 215
invoke-static {v0, v5}, Lorg/spongycastle/math/raw/Nat224;->eq([I[I)Z
move-result v0
if-eqz v0, :cond_b4
.line 217
new-instance p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {p0, v3}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
goto/16 :goto_10
.line 220
:cond_b4
const/4 p0, 0x0
goto/16 :goto_10
.end method
.method public square()Lorg/spongycastle/math/ec/ECFieldElement;
.registers 3
.prologue
.line 116
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
.line 117
iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->square([I[I)V
.line 118
new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
return-object v1
.end method
.method public subtract(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
.registers 5
.prologue
.line 86
invoke-static {}, Lorg/spongycastle/math/raw/Nat224;->create()[I
move-result-object v0
.line 87
iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
iget-object v2, p1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v1, v2, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1Field;->subtract([I[I[I)V
.line 88
new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;
invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;-><init>([I)V
return-object v1
.end method
.method public testBitZero()Z
.registers 4
.prologue
const/4 v0, 0x1
const/4 v1, 0x0
.line 52
iget-object v2, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v2, v1}, Lorg/spongycastle/math/raw/Nat224;->getBit([II)I
move-result v2
if-ne v2, v0, :cond_b
:goto_a
return v0
:cond_b
move v0, v1
goto :goto_a
.end method
.method public toBigInteger()Ljava/math/BigInteger;
.registers 2
.prologue
.line 57
iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecP224K1FieldElement;->x:[I
invoke-static {v0}, Lorg/spongycastle/math/raw/Nat224;->toBigInteger([I)Ljava/math/BigInteger;
move-result-object v0
return-object v0
.end method