Nat.smali
.class public abstract Lorg/spongycastle/math/raw/Nat;
.super Ljava/lang/Object;
.source "Nat.java"
# static fields
.field private static final M:J = 0xffffffffL
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 7
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static add(I[I[I[I)I
.registers 14
.prologue
const-wide v8, 0xffffffffL
.line 13
const-wide/16 v2, 0x0
.line 14
const/4 v0, 0x0
:goto_8
if-ge v0, p0, :cond_1d
.line 16
aget v1, p1, v0
int-to-long v4, v1
and-long/2addr v4, v8
aget v1, p2, v0
int-to-long v6, v1
and-long/2addr v6, v8
add-long/2addr v4, v6
add-long/2addr v2, v4
.line 17
long-to-int v1, v2
aput v1, p3, v0
.line 18
const/16 v1, 0x20
ushr-long/2addr v2, v1
.line 14
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 20
:cond_1d
long-to-int v0, v2
return v0
.end method
.method public static add33At(II[II)I
.registers 11
.prologue
const/16 v6, 0x20
const-wide v4, 0xffffffffL
.line 26
aget v0, p2, p3
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
add-long/2addr v0, v2
.line 27
long-to-int v2, v0
aput v2, p2, p3
.line 28
ushr-long/2addr v0, v6
.line 29
add-int/lit8 v2, p3, 0x1
aget v2, p2, v2
int-to-long v2, v2
and-long/2addr v2, v4
const-wide/16 v4, 0x1
add-long/2addr v2, v4
add-long/2addr v0, v2
.line 30
add-int/lit8 v2, p3, 0x1
long-to-int v3, v0
aput v3, p2, v2
.line 31
ushr-long/2addr v0, v6
.line 32
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_2a
const/4 v0, 0x0
:goto_29
return v0
:cond_2a
add-int/lit8 v0, p3, 0x2
invoke-static {p0, p2, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[II)I
move-result v0
goto :goto_29
.end method
.method public static add33At(II[III)I
.registers 12
.prologue
const/16 v6, 0x20
const-wide v4, 0xffffffffL
.line 38
add-int v0, p3, p4
aget v0, p2, v0
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
add-long/2addr v0, v2
.line 39
add-int v2, p3, p4
long-to-int v3, v0
aput v3, p2, v2
.line 40
ushr-long/2addr v0, v6
.line 41
add-int v2, p3, p4
add-int/lit8 v2, v2, 0x1
aget v2, p2, v2
int-to-long v2, v2
and-long/2addr v2, v4
const-wide/16 v4, 0x1
add-long/2addr v2, v4
add-long/2addr v0, v2
.line 42
add-int v2, p3, p4
add-int/lit8 v2, v2, 0x1
long-to-int v3, v0
aput v3, p2, v2
.line 43
ushr-long/2addr v0, v6
.line 44
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_32
const/4 v0, 0x0
:goto_31
return v0
:cond_32
add-int/lit8 v0, p4, 0x2
invoke-static {p0, p2, p3, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[III)I
move-result v0
goto :goto_31
.end method
.method public static add33To(II[I)I
.registers 13
.prologue
const/16 v9, 0x20
const/4 v8, 0x1
const-wide v6, 0xffffffffL
const/4 v0, 0x0
.line 49
aget v1, p2, v0
int-to-long v2, v1
and-long/2addr v2, v6
int-to-long v4, p1
and-long/2addr v4, v6
add-long/2addr v2, v4
.line 50
long-to-int v1, v2
aput v1, p2, v0
.line 51
ushr-long/2addr v2, v9
.line 52
aget v1, p2, v8
int-to-long v4, v1
and-long/2addr v4, v6
const-wide/16 v6, 0x1
add-long/2addr v4, v6
add-long/2addr v2, v4
.line 53
long-to-int v1, v2
aput v1, p2, v8
.line 54
ushr-long/2addr v2, v9
.line 55
const-wide/16 v4, 0x0
cmp-long v1, v2, v4
if-nez v1, :cond_27
:goto_26
return v0
:cond_27
const/4 v0, 0x2
invoke-static {p0, p2, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[II)I
move-result v0
goto :goto_26
.end method
.method public static add33To(II[II)I
.registers 11
.prologue
const/16 v6, 0x20
const-wide v4, 0xffffffffL
.line 60
aget v0, p2, p3
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
add-long/2addr v0, v2
.line 61
long-to-int v2, v0
aput v2, p2, p3
.line 62
ushr-long/2addr v0, v6
.line 63
add-int/lit8 v2, p3, 0x1
aget v2, p2, v2
int-to-long v2, v2
and-long/2addr v2, v4
const-wide/16 v4, 0x1
add-long/2addr v2, v4
add-long/2addr v0, v2
.line 64
add-int/lit8 v2, p3, 0x1
long-to-int v3, v0
aput v3, p2, v2
.line 65
ushr-long/2addr v0, v6
.line 66
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_2a
const/4 v0, 0x0
:goto_29
return v0
:cond_2a
const/4 v0, 0x2
invoke-static {p0, p2, p3, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[III)I
move-result v0
goto :goto_29
.end method
.method public static addBothTo(I[II[II[II)I
.registers 17
.prologue
.line 83
const-wide/16 v2, 0x0
.line 84
const/4 v0, 0x0
:goto_3
if-ge v0, p0, :cond_34
.line 86
add-int v1, p2, v0
aget v1, p1, v1
int-to-long v4, v1
const-wide v6, 0xffffffffL
and-long/2addr v4, v6
add-int v1, p4, v0
aget v1, p3, v1
int-to-long v6, v1
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
add-long/2addr v4, v6
add-int v1, p6, v0
aget v1, p5, v1
int-to-long v6, v1
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
add-long/2addr v4, v6
add-long/2addr v2, v4
.line 87
add-int v1, p6, v0
long-to-int v4, v2
aput v4, p5, v1
.line 88
const/16 v1, 0x20
ushr-long/2addr v2, v1
.line 84
add-int/lit8 v0, v0, 0x1
goto :goto_3
.line 90
:cond_34
long-to-int v0, v2
return v0
.end method
.method public static addBothTo(I[I[I[I)I
.registers 14
.prologue
const-wide v8, 0xffffffffL
.line 71
const-wide/16 v2, 0x0
.line 72
const/4 v0, 0x0
:goto_8
if-ge v0, p0, :cond_22
.line 74
aget v1, p1, v0
int-to-long v4, v1
and-long/2addr v4, v8
aget v1, p2, v0
int-to-long v6, v1
and-long/2addr v6, v8
add-long/2addr v4, v6
aget v1, p3, v0
int-to-long v6, v1
and-long/2addr v6, v8
add-long/2addr v4, v6
add-long/2addr v2, v4
.line 75
long-to-int v1, v2
aput v1, p3, v0
.line 76
const/16 v1, 0x20
ushr-long/2addr v2, v1
.line 72
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 78
:cond_22
long-to-int v0, v2
return v0
.end method
.method public static addDWordAt(IJ[II)I
.registers 12
.prologue
const-wide v4, 0xffffffffL
const/16 v6, 0x20
.line 96
aget v0, p3, p4
int-to-long v0, v0
and-long/2addr v0, v4
and-long v2, p1, v4
add-long/2addr v0, v2
.line 97
long-to-int v2, v0
aput v2, p3, p4
.line 98
ushr-long/2addr v0, v6
.line 99
add-int/lit8 v2, p4, 0x1
aget v2, p3, v2
int-to-long v2, v2
and-long/2addr v2, v4
ushr-long v4, p1, v6
add-long/2addr v2, v4
add-long/2addr v0, v2
.line 100
add-int/lit8 v2, p4, 0x1
long-to-int v3, v0
aput v3, p3, v2
.line 101
ushr-long/2addr v0, v6
.line 102
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_2a
const/4 v0, 0x0
:goto_29
return v0
:cond_2a
add-int/lit8 v0, p4, 0x2
invoke-static {p0, p3, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[II)I
move-result v0
goto :goto_29
.end method
.method public static addDWordAt(IJ[III)I
.registers 13
.prologue
const-wide v4, 0xffffffffL
const/16 v6, 0x20
.line 108
add-int v0, p4, p5
aget v0, p3, v0
int-to-long v0, v0
and-long/2addr v0, v4
and-long v2, p1, v4
add-long/2addr v0, v2
.line 109
add-int v2, p4, p5
long-to-int v3, v0
aput v3, p3, v2
.line 110
ushr-long/2addr v0, v6
.line 111
add-int v2, p4, p5
add-int/lit8 v2, v2, 0x1
aget v2, p3, v2
int-to-long v2, v2
and-long/2addr v2, v4
ushr-long v4, p1, v6
add-long/2addr v2, v4
add-long/2addr v0, v2
.line 112
add-int v2, p4, p5
add-int/lit8 v2, v2, 0x1
long-to-int v3, v0
aput v3, p3, v2
.line 113
ushr-long/2addr v0, v6
.line 114
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_32
const/4 v0, 0x0
:goto_31
return v0
:cond_32
add-int/lit8 v0, p5, 0x2
invoke-static {p0, p3, p4, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[III)I
move-result v0
goto :goto_31
.end method
.method public static addDWordTo(IJ[I)I
.registers 15
.prologue
const/4 v9, 0x1
const-wide v6, 0xffffffffL
const/16 v8, 0x20
const/4 v0, 0x0
.line 119
aget v1, p3, v0
int-to-long v2, v1
and-long/2addr v2, v6
and-long v4, p1, v6
add-long/2addr v2, v4
.line 120
long-to-int v1, v2
aput v1, p3, v0
.line 121
ushr-long/2addr v2, v8
.line 122
aget v1, p3, v9
int-to-long v4, v1
and-long/2addr v4, v6
ushr-long v6, p1, v8
add-long/2addr v4, v6
add-long/2addr v2, v4
.line 123
long-to-int v1, v2
aput v1, p3, v9
.line 124
ushr-long/2addr v2, v8
.line 125
const-wide/16 v4, 0x0
cmp-long v1, v2, v4
if-nez v1, :cond_27
:goto_26
return v0
:cond_27
const/4 v0, 0x2
invoke-static {p0, p3, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[II)I
move-result v0
goto :goto_26
.end method
.method public static addDWordTo(IJ[II)I
.registers 12
.prologue
const-wide v4, 0xffffffffL
const/16 v6, 0x20
.line 130
aget v0, p3, p4
int-to-long v0, v0
and-long/2addr v0, v4
and-long v2, p1, v4
add-long/2addr v0, v2
.line 131
long-to-int v2, v0
aput v2, p3, p4
.line 132
ushr-long/2addr v0, v6
.line 133
add-int/lit8 v2, p4, 0x1
aget v2, p3, v2
int-to-long v2, v2
and-long/2addr v2, v4
ushr-long v4, p1, v6
add-long/2addr v2, v4
add-long/2addr v0, v2
.line 134
add-int/lit8 v2, p4, 0x1
long-to-int v3, v0
aput v3, p3, v2
.line 135
ushr-long/2addr v0, v6
.line 136
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_2a
const/4 v0, 0x0
:goto_29
return v0
:cond_2a
const/4 v0, 0x2
invoke-static {p0, p3, p4, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[III)I
move-result v0
goto :goto_29
.end method
.method public static addTo(I[II[II)I
.registers 15
.prologue
const-wide v8, 0xffffffffL
.line 153
const-wide/16 v2, 0x0
.line 154
const/4 v0, 0x0
:goto_8
if-ge v0, p0, :cond_23
.line 156
add-int v1, p2, v0
aget v1, p1, v1
int-to-long v4, v1
and-long/2addr v4, v8
add-int v1, p4, v0
aget v1, p3, v1
int-to-long v6, v1
and-long/2addr v6, v8
add-long/2addr v4, v6
add-long/2addr v2, v4
.line 157
add-int v1, p4, v0
long-to-int v4, v2
aput v4, p3, v1
.line 158
const/16 v1, 0x20
ushr-long/2addr v2, v1
.line 154
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 160
:cond_23
long-to-int v0, v2
return v0
.end method
.method public static addTo(I[I[I)I
.registers 13
.prologue
const-wide v8, 0xffffffffL
.line 141
const-wide/16 v2, 0x0
.line 142
const/4 v0, 0x0
:goto_8
if-ge v0, p0, :cond_1d
.line 144
aget v1, p1, v0
int-to-long v4, v1
and-long/2addr v4, v8
aget v1, p2, v0
int-to-long v6, v1
and-long/2addr v6, v8
add-long/2addr v4, v6
add-long/2addr v2, v4
.line 145
long-to-int v1, v2
aput v1, p2, v0
.line 146
const/16 v1, 0x20
ushr-long/2addr v2, v1
.line 142
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 148
:cond_1d
long-to-int v0, v2
return v0
.end method
.method public static addWordAt(II[II)I
.registers 10
.prologue
const-wide v4, 0xffffffffL
.line 166
int-to-long v0, p1
and-long/2addr v0, v4
aget v2, p2, p3
int-to-long v2, v2
and-long/2addr v2, v4
add-long/2addr v0, v2
.line 167
long-to-int v2, v0
aput v2, p2, p3
.line 168
const/16 v2, 0x20
ushr-long/2addr v0, v2
.line 169
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_1a
const/4 v0, 0x0
:goto_19
return v0
:cond_1a
add-int/lit8 v0, p3, 0x1
invoke-static {p0, p2, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[II)I
move-result v0
goto :goto_19
.end method
.method public static addWordAt(II[III)I
.registers 11
.prologue
const-wide v4, 0xffffffffL
.line 175
int-to-long v0, p1
and-long/2addr v0, v4
add-int v2, p3, p4
aget v2, p2, v2
int-to-long v2, v2
and-long/2addr v2, v4
add-long/2addr v0, v2
.line 176
add-int v2, p3, p4
long-to-int v3, v0
aput v3, p2, v2
.line 177
const/16 v2, 0x20
ushr-long/2addr v0, v2
.line 178
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_1e
const/4 v0, 0x0
:goto_1d
return v0
:cond_1e
add-int/lit8 v0, p4, 0x1
invoke-static {p0, p2, p3, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[III)I
move-result v0
goto :goto_1d
.end method
.method public static addWordTo(II[I)I
.registers 11
.prologue
const-wide v6, 0xffffffffL
const/4 v0, 0x0
.line 183
int-to-long v2, p1
and-long/2addr v2, v6
aget v1, p2, v0
int-to-long v4, v1
and-long/2addr v4, v6
add-long/2addr v2, v4
.line 184
long-to-int v1, v2
aput v1, p2, v0
.line 185
const/16 v1, 0x20
ushr-long/2addr v2, v1
.line 186
const-wide/16 v4, 0x0
cmp-long v1, v2, v4
if-nez v1, :cond_1a
:goto_19
return v0
:cond_1a
const/4 v0, 0x1
invoke-static {p0, p2, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[II)I
move-result v0
goto :goto_19
.end method
.method public static addWordTo(II[II)I
.registers 10
.prologue
const-wide v4, 0xffffffffL
.line 191
int-to-long v0, p1
and-long/2addr v0, v4
aget v2, p2, p3
int-to-long v2, v2
and-long/2addr v2, v4
add-long/2addr v0, v2
.line 192
long-to-int v2, v0
aput v2, p2, p3
.line 193
const/16 v2, 0x20
ushr-long/2addr v0, v2
.line 194
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_1a
const/4 v0, 0x0
:goto_19
return v0
:cond_1a
const/4 v0, 0x1
invoke-static {p0, p2, p3, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[III)I
move-result v0
goto :goto_19
.end method
.method public static copy(I[I[I)V
.registers 4
.prologue
const/4 v0, 0x0
.line 206
invoke-static {p1, v0, p2, v0, p0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 207
return-void
.end method
.method public static copy(I[I)[I
.registers 4
.prologue
const/4 v1, 0x0
.line 199
new-array v0, p0, [I
.line 200
invoke-static {p1, v1, v0, v1, p0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 201
return-object v0
.end method
.method public static create(I)[I
.registers 2
.prologue
.line 211
new-array v0, p0, [I
return-object v0
.end method
.method public static create64(I)[J
.registers 2
.prologue
.line 216
new-array v0, p0, [J
return-object v0
.end method
.method public static dec(I[I)I
.registers 6
.prologue
const/4 v0, 0x0
const/4 v1, -0x1
.line 221
move v2, v0
:goto_3
if-ge v2, p0, :cond_11
.line 223
aget v3, p1, v2
add-int/lit8 v3, v3, -0x1
aput v3, p1, v2
if-eq v3, v1, :cond_e
.line 228
:goto_d
return v0
.line 221
:cond_e
add-int/lit8 v2, v2, 0x1
goto :goto_3
:cond_11
move v0, v1
.line 228
goto :goto_d
.end method
.method public static dec(I[I[I)I
.registers 7
.prologue
const/4 v0, 0x0
const/4 v1, -0x1
.line 233
move v2, v0
.line 234
:cond_3
if-ge v2, p0, :cond_19
.line 236
aget v3, p1, v2
add-int/lit8 v3, v3, -0x1
.line 237
aput v3, p2, v2
.line 238
add-int/lit8 v2, v2, 0x1
.line 239
if-eq v3, v1, :cond_3
move v1, v2
.line 241
:goto_10
if-ge v1, p0, :cond_1a
.line 243
aget v2, p1, v1
aput v2, p2, v1
.line 244
add-int/lit8 v1, v1, 0x1
goto :goto_10
:cond_19
move v0, v1
.line 249
:cond_1a
return v0
.end method
.method public static decAt(I[II)I
.registers 5
.prologue
const/4 v0, -0x1
.line 255
:goto_1
if-ge p2, p0, :cond_c
.line 257
aget v1, p1, p2
add-int/lit8 v1, v1, -0x1
aput v1, p1, p2
if-eq v1, v0, :cond_d
.line 259
const/4 v0, 0x0
.line 262
:cond_c
return v0
.line 255
:cond_d
add-int/lit8 p2, p2, 0x1
goto :goto_1
.end method
.method public static decAt(I[III)I
.registers 7
.prologue
const/4 v0, -0x1
.line 268
:goto_1
if-ge p3, p0, :cond_e
.line 270
add-int v1, p2, p3
aget v2, p1, v1
add-int/lit8 v2, v2, -0x1
aput v2, p1, v1
if-eq v2, v0, :cond_f
.line 272
const/4 v0, 0x0
.line 275
:cond_e
return v0
.line 268
:cond_f
add-int/lit8 p3, p3, 0x1
goto :goto_1
.end method
.method public static eq(I[I[I)Z
.registers 6
.prologue
.line 280
add-int/lit8 v0, p0, -0x1
:goto_2
if-ltz v0, :cond_f
.line 282
aget v1, p1, v0
aget v2, p2, v0
if-eq v1, v2, :cond_c
.line 284
const/4 v0, 0x0
.line 287
:goto_b
return v0
.line 280
:cond_c
add-int/lit8 v0, v0, -0x1
goto :goto_2
.line 287
:cond_f
const/4 v0, 0x1
goto :goto_b
.end method
.method public static fromBigInteger(ILjava/math/BigInteger;)[I
.registers 6
.prologue
.line 292
invoke-virtual {p1}, Ljava/math/BigInteger;->signum()I
move-result v0
if-ltz v0, :cond_c
invoke-virtual {p1}, Ljava/math/BigInteger;->bitLength()I
move-result v0
if-le v0, p0, :cond_12
.line 294
:cond_c
new-instance v0, Ljava/lang/IllegalArgumentException;
invoke-direct {v0}, Ljava/lang/IllegalArgumentException;-><init>()V
throw v0
.line 297
:cond_12
add-int/lit8 v0, p0, 0x1f
shr-int/lit8 v0, v0, 0x5
.line 298
invoke-static {v0}, Lorg/spongycastle/math/raw/Nat;->create(I)[I
move-result-object v2
.line 299
const/4 v0, 0x0
.line 300
:goto_1b
invoke-virtual {p1}, Ljava/math/BigInteger;->signum()I
move-result v1
if-eqz v1, :cond_31
.line 302
add-int/lit8 v1, v0, 0x1
invoke-virtual {p1}, Ljava/math/BigInteger;->intValue()I
move-result v3
aput v3, v2, v0
.line 303
const/16 v0, 0x20
invoke-virtual {p1, v0}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object p1
move v0, v1
goto :goto_1b
.line 305
:cond_31
return-object v2
.end method
.method public static getBit([II)I
.registers 5
.prologue
const/4 v0, 0x0
.line 310
if-nez p1, :cond_8
.line 312
aget v0, p0, v0
and-int/lit8 v0, v0, 0x1
.line 320
:cond_7
:goto_7
return v0
.line 314
:cond_8
shr-int/lit8 v1, p1, 0x5
.line 315
if-ltz v1, :cond_7
array-length v2, p0
if-ge v1, v2, :cond_7
.line 319
and-int/lit8 v0, p1, 0x1f
.line 320
aget v1, p0, v1
ushr-int v0, v1, v0
and-int/lit8 v0, v0, 0x1
goto :goto_7
.end method
.method public static gte(I[I[I)Z
.registers 8
.prologue
const/4 v0, 0x1
const/high16 v4, -0x80000000
.line 325
add-int/lit8 v1, p0, -0x1
:goto_5
if-ltz v1, :cond_10
.line 327
aget v2, p1, v1
xor-int/2addr v2, v4
.line 328
aget v3, p2, v1
xor-int/2addr v3, v4
.line 329
if-ge v2, v3, :cond_11
.line 330
const/4 v0, 0x0
.line 334
:cond_10
return v0
.line 331
:cond_11
if-gt v2, v3, :cond_10
.line 325
add-int/lit8 v1, v1, -0x1
goto :goto_5
.end method
.method public static inc(I[I)I
.registers 5
.prologue
const/4 v0, 0x0
.line 339
move v1, v0
:goto_2
if-ge v1, p0, :cond_10
.line 341
aget v2, p1, v1
add-int/lit8 v2, v2, 0x1
aput v2, p1, v1
if-eqz v2, :cond_d
.line 346
:goto_c
return v0
.line 339
:cond_d
add-int/lit8 v1, v1, 0x1
goto :goto_2
.line 346
:cond_10
const/4 v0, 0x1
goto :goto_c
.end method
.method public static inc(I[I[I)I
.registers 6
.prologue
const/4 v0, 0x0
.line 351
move v1, v0
.line 352
:cond_2
if-ge v1, p0, :cond_17
.line 354
aget v2, p1, v1
add-int/lit8 v2, v2, 0x1
.line 355
aput v2, p2, v1
.line 356
add-int/lit8 v1, v1, 0x1
.line 357
if-eqz v2, :cond_2
.line 359
:goto_e
if-ge v1, p0, :cond_18
.line 361
aget v2, p1, v1
aput v2, p2, v1
.line 362
add-int/lit8 v1, v1, 0x1
goto :goto_e
.line 367
:cond_17
const/4 v0, 0x1
:cond_18
return v0
.end method
.method public static incAt(I[II)I
.registers 4
.prologue
.line 373
:goto_0
if-ge p2, p0, :cond_f
.line 375
aget v0, p1, p2
add-int/lit8 v0, v0, 0x1
aput v0, p1, p2
if-eqz v0, :cond_c
.line 377
const/4 v0, 0x0
.line 380
:goto_b
return v0
.line 373
:cond_c
add-int/lit8 p2, p2, 0x1
goto :goto_0
.line 380
:cond_f
const/4 v0, 0x1
goto :goto_b
.end method
.method public static incAt(I[III)I
.registers 6
.prologue
.line 386
:goto_0
if-ge p3, p0, :cond_11
.line 388
add-int v0, p2, p3
aget v1, p1, v0
add-int/lit8 v1, v1, 0x1
aput v1, p1, v0
if-eqz v1, :cond_e
.line 390
const/4 v0, 0x0
.line 393
:goto_d
return v0
.line 386
:cond_e
add-int/lit8 p3, p3, 0x1
goto :goto_0
.line 393
:cond_11
const/4 v0, 0x1
goto :goto_d
.end method
.method public static isOne(I[I)Z
.registers 6
.prologue
const/4 v1, 0x1
const/4 v0, 0x0
.line 398
aget v2, p1, v0
if-eq v2, v1, :cond_7
.line 409
:cond_6
:goto_6
return v0
:cond_7
move v2, v1
.line 402
:goto_8
if-ge v2, p0, :cond_11
.line 404
aget v3, p1, v2
if-nez v3, :cond_6
.line 402
add-int/lit8 v2, v2, 0x1
goto :goto_8
:cond_11
move v0, v1
.line 409
goto :goto_6
.end method
.method public static isZero(I[I)Z
.registers 5
.prologue
const/4 v0, 0x0
.line 414
move v1, v0
:goto_2
if-ge v1, p0, :cond_c
.line 416
aget v2, p1, v1
if-eqz v2, :cond_9
.line 421
:goto_8
return v0
.line 414
:cond_9
add-int/lit8 v1, v1, 0x1
goto :goto_2
.line 421
:cond_c
const/4 v0, 0x1
goto :goto_8
.end method
.method public static mul(I[II[II[II)V
.registers 15
.prologue
.line 436
add-int v6, p6, p0
aget v1, p1, p2
move v0, p0
move-object v2, p3
move v3, p4
move-object v4, p5
move v5, p6
invoke-static/range {v0 .. v5}, Lorg/spongycastle/math/raw/Nat;->mulWord(II[II[II)I
move-result v0
aput v0, p5, v6
.line 438
const/4 v0, 0x1
move v6, v0
:goto_11
if-ge v6, p0, :cond_2b
.line 440
add-int v0, p6, v6
add-int v7, v0, p0
add-int v0, p2, v6
aget v1, p1, v0
add-int v5, p6, v6
move v0, p0
move-object v2, p3
move v3, p4
move-object v4, p5
invoke-static/range {v0 .. v5}, Lorg/spongycastle/math/raw/Nat;->mulWordAddTo(II[II[II)I
move-result v0
aput v0, p5, v7
.line 438
add-int/lit8 v0, v6, 0x1
move v6, v0
goto :goto_11
.line 442
:cond_2b
return-void
.end method
.method public static mul(I[I[I[I)V
.registers 11
.prologue
const/4 v3, 0x0
.line 426
aget v0, p1, v3
invoke-static {p0, v0, p2, p3}, Lorg/spongycastle/math/raw/Nat;->mulWord(II[I[I)I
move-result v0
aput v0, p3, p0
.line 428
const/4 v5, 0x1
:goto_a
if-ge v5, p0, :cond_1c
.line 430
add-int v6, v5, p0
aget v1, p1, v5
move v0, p0
move-object v2, p2
move-object v4, p3
invoke-static/range {v0 .. v5}, Lorg/spongycastle/math/raw/Nat;->mulWordAddTo(II[II[II)I
move-result v0
aput v0, p3, v6
.line 428
add-int/lit8 v5, v5, 0x1
goto :goto_a
.line 432
:cond_1c
return-void
.end method
.method public static mul31BothAdd(II[II[I[II)I
.registers 23
.prologue
.line 473
const-wide/16 v2, 0x0
move/from16 v0, p1
int-to-long v4, v0
const-wide v6, 0xffffffffL
and-long/2addr v6, v4
move/from16 v0, p3
int-to-long v4, v0
const-wide v8, 0xffffffffL
and-long/2addr v8, v4
.line 474
const/4 v4, 0x0
.line 477
:cond_15
aget v5, p2, v4
int-to-long v10, v5
const-wide v12, 0xffffffffL
and-long/2addr v10, v12
mul-long/2addr v10, v6
aget v5, p4, v4
int-to-long v12, v5
const-wide v14, 0xffffffffL
and-long/2addr v12, v14
mul-long/2addr v12, v8
add-long/2addr v10, v12
add-int v5, p6, v4
aget v5, p5, v5
int-to-long v12, v5
const-wide v14, 0xffffffffL
and-long/2addr v12, v14
add-long/2addr v10, v12
add-long/2addr v2, v10
.line 478
add-int v5, p6, v4
long-to-int v10, v2
aput v10, p5, v5
.line 479
const/16 v5, 0x20
ushr-long/2addr v2, v5
.line 481
add-int/lit8 v4, v4, 0x1
move/from16 v0, p0
if-lt v4, v0, :cond_15
.line 482
long-to-int v2, v2
return v2
.end method
.method public static mulAddTo(I[II[II[II)I
.registers 19
.prologue
.line 459
const-wide/16 v2, 0x0
.line 460
const/4 v0, 0x0
move v6, v0
move-wide v8, v2
move/from16 v5, p6
:goto_7
if-ge v6, p0, :cond_3b
.line 462
add-int v0, p2, v6
aget v1, p1, v0
move v0, p0
move-object v2, p3
move/from16 v3, p4
move-object/from16 v4, p5
invoke-static/range {v0 .. v5}, Lorg/spongycastle/math/raw/Nat;->mulWordAddTo(II[II[II)I
move-result v0
int-to-long v0, v0
const-wide v2, 0xffffffffL
and-long/2addr v0, v2
.line 463
add-int v2, v5, p0
aget v2, p5, v2
int-to-long v2, v2
const-wide v10, 0xffffffffL
and-long/2addr v2, v10
add-long/2addr v2, v8
add-long/2addr v0, v2
.line 464
add-int v2, v5, p0
long-to-int v3, v0
aput v3, p5, v2
.line 465
const/16 v2, 0x20
ushr-long v2, v0, v2
.line 466
add-int/lit8 v5, v5, 0x1
.line 460
add-int/lit8 v0, v6, 0x1
move v6, v0
move-wide v8, v2
goto :goto_7
.line 468
:cond_3b
long-to-int v0, v8
return v0
.end method
.method public static mulAddTo(I[I[I[I)I
.registers 16
.prologue
const-wide v10, 0xffffffffL
const/4 v3, 0x0
.line 446
const-wide/16 v0, 0x0
move v5, v3
move-wide v6, v0
.line 447
:goto_a
if-ge v5, p0, :cond_2b
.line 449
aget v1, p1, v5
move v0, p0
move-object v2, p2
move-object v4, p3
invoke-static/range {v0 .. v5}, Lorg/spongycastle/math/raw/Nat;->mulWordAddTo(II[II[II)I
move-result v0
int-to-long v0, v0
and-long/2addr v0, v10
.line 450
add-int v2, v5, p0
aget v2, p3, v2
int-to-long v8, v2
and-long/2addr v8, v10
add-long/2addr v6, v8
add-long/2addr v0, v6
.line 451
add-int v2, v5, p0
long-to-int v4, v0
aput v4, p3, v2
.line 452
const/16 v2, 0x20
ushr-long/2addr v0, v2
.line 447
add-int/lit8 v5, v5, 0x1
move-wide v6, v0
goto :goto_a
.line 454
:cond_2b
long-to-int v0, v6
return v0
.end method
.method public static mulWord(II[II[II)I
.registers 16
.prologue
const-wide v8, 0xffffffffL
.line 501
const-wide/16 v0, 0x0
int-to-long v2, p1
and-long v4, v2, v8
.line 502
const/4 v2, 0x0
.line 505
:cond_b
add-int v3, p3, v2
aget v3, p2, v3
int-to-long v6, v3
and-long/2addr v6, v8
mul-long/2addr v6, v4
add-long/2addr v0, v6
.line 506
add-int v3, p5, v2
long-to-int v6, v0
aput v6, p4, v3
.line 507
const/16 v3, 0x20
ushr-long/2addr v0, v3
.line 509
add-int/lit8 v2, v2, 0x1
if-lt v2, p0, :cond_b
.line 510
long-to-int v0, v0
return v0
.end method
.method public static mulWord(II[I[I)I
.registers 14
.prologue
const-wide v8, 0xffffffffL
.line 487
const-wide/16 v0, 0x0
int-to-long v2, p1
and-long v4, v2, v8
.line 488
const/4 v2, 0x0
.line 491
:cond_b
aget v3, p2, v2
int-to-long v6, v3
and-long/2addr v6, v8
mul-long/2addr v6, v4
add-long/2addr v0, v6
.line 492
long-to-int v3, v0
aput v3, p3, v2
.line 493
const/16 v3, 0x20
ushr-long/2addr v0, v3
.line 495
add-int/lit8 v2, v2, 0x1
if-lt v2, p0, :cond_b
.line 496
long-to-int v0, v0
return v0
.end method
.method public static mulWordAddTo(II[II[II)I
.registers 18
.prologue
.line 515
const-wide/16 v0, 0x0
int-to-long v2, p1
const-wide v4, 0xffffffffL
and-long/2addr v4, v2
.line 516
const/4 v2, 0x0
.line 519
:cond_a
add-int v3, p3, v2
aget v3, p2, v3
int-to-long v6, v3
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
mul-long/2addr v6, v4
add-int v3, p5, v2
aget v3, p4, v3
int-to-long v8, v3
const-wide v10, 0xffffffffL
and-long/2addr v8, v10
add-long/2addr v6, v8
add-long/2addr v0, v6
.line 520
add-int v3, p5, v2
long-to-int v6, v0
aput v6, p4, v3
.line 521
const/16 v3, 0x20
ushr-long/2addr v0, v3
.line 523
add-int/lit8 v2, v2, 0x1
if-lt v2, p0, :cond_a
.line 524
long-to-int v0, v0
return v0
.end method
.method public static mulWordDwordAddAt(IIJ[II)I
.registers 16
.prologue
.line 530
int-to-long v0, p1
const-wide v2, 0xffffffffL
and-long/2addr v0, v2
.line 531
const-wide/16 v2, 0x0
const-wide v4, 0xffffffffL
and-long/2addr v4, p2
mul-long/2addr v4, v0
aget v6, p4, p5
int-to-long v6, v6
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
add-long/2addr v4, v6
add-long/2addr v2, v4
.line 532
long-to-int v4, v2
aput v4, p4, p5
.line 533
const/16 v4, 0x20
ushr-long/2addr v2, v4
.line 534
const/16 v4, 0x20
ushr-long v4, p2, v4
mul-long/2addr v0, v4
add-int/lit8 v4, p5, 0x1
aget v4, p4, v4
int-to-long v4, v4
const-wide v6, 0xffffffffL
and-long/2addr v4, v6
add-long/2addr v0, v4
add-long/2addr v0, v2
.line 535
add-int/lit8 v2, p5, 0x1
long-to-int v3, v0
aput v3, p4, v2
.line 536
const/16 v2, 0x20
ushr-long/2addr v0, v2
.line 537
add-int/lit8 v2, p5, 0x2
aget v2, p4, v2
int-to-long v2, v2
const-wide v4, 0xffffffffL
and-long/2addr v2, v4
add-long/2addr v0, v2
.line 538
add-int/lit8 v2, p5, 0x2
long-to-int v3, v0
aput v3, p4, v2
.line 539
const/16 v2, 0x20
ushr-long/2addr v0, v2
.line 540
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_57
const/4 v0, 0x0
:goto_56
return v0
:cond_57
add-int/lit8 v0, p5, 0x3
invoke-static {p0, p4, v0}, Lorg/spongycastle/math/raw/Nat;->incAt(I[II)I
move-result v0
goto :goto_56
.end method
.method public static shiftDownBit(I[II)I
.registers 6
.prologue
.line 546
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_f
.line 548
aget v0, p1, p0
.line 549
ushr-int/lit8 v1, v0, 0x1
shl-int/lit8 v2, p2, 0x1f
or-int/2addr v1, v2
aput v1, p1, p0
move p2, v0
.line 551
goto :goto_0
.line 552
:cond_f
shl-int/lit8 v0, p2, 0x1f
return v0
.end method
.method public static shiftDownBit(I[III)I
.registers 8
.prologue
.line 558
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_13
.line 560
add-int v0, p2, p0
aget v0, p1, v0
.line 561
add-int v1, p2, p0
ushr-int/lit8 v2, v0, 0x1
shl-int/lit8 v3, p3, 0x1f
or-int/2addr v2, v3
aput v2, p1, v1
move p3, v0
.line 563
goto :goto_0
.line 564
:cond_13
shl-int/lit8 v0, p3, 0x1f
return v0
.end method
.method public static shiftDownBit(I[III[II)I
.registers 10
.prologue
.line 582
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_13
.line 584
add-int v0, p2, p0
aget v0, p1, v0
.line 585
add-int v1, p5, p0
ushr-int/lit8 v2, v0, 0x1
shl-int/lit8 v3, p3, 0x1f
or-int/2addr v2, v3
aput v2, p4, v1
move p3, v0
.line 587
goto :goto_0
.line 588
:cond_13
shl-int/lit8 v0, p3, 0x1f
return v0
.end method
.method public static shiftDownBit(I[II[I)I
.registers 7
.prologue
.line 570
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_f
.line 572
aget v0, p1, p0
.line 573
ushr-int/lit8 v1, v0, 0x1
shl-int/lit8 v2, p2, 0x1f
or-int/2addr v1, v2
aput v1, p3, p0
move p2, v0
.line 575
goto :goto_0
.line 576
:cond_f
shl-int/lit8 v0, p2, 0x1f
return v0
.end method
.method public static shiftDownBits(I[III)I
.registers 7
.prologue
.line 595
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_10
.line 597
aget v0, p1, p0
.line 598
ushr-int v1, v0, p2
neg-int v2, p2
shl-int v2, p3, v2
or-int/2addr v1, v2
aput v1, p1, p0
move p3, v0
.line 600
goto :goto_0
.line 601
:cond_10
neg-int v0, p2
shl-int v0, p3, v0
return v0
.end method
.method public static shiftDownBits(I[IIII)I
.registers 9
.prologue
.line 608
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_14
.line 610
add-int v0, p2, p0
aget v0, p1, v0
.line 611
add-int v1, p2, p0
ushr-int v2, v0, p3
neg-int v3, p3
shl-int v3, p4, v3
or-int/2addr v2, v3
aput v2, p1, v1
move p4, v0
.line 613
goto :goto_0
.line 614
:cond_14
neg-int v0, p3
shl-int v0, p4, v0
return v0
.end method
.method public static shiftDownBits(I[IIII[II)I
.registers 11
.prologue
.line 634
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_14
.line 636
add-int v0, p2, p0
aget v0, p1, v0
.line 637
add-int v1, p6, p0
ushr-int v2, v0, p3
neg-int v3, p3
shl-int v3, p4, v3
or-int/2addr v2, v3
aput v2, p5, v1
move p4, v0
.line 639
goto :goto_0
.line 640
:cond_14
neg-int v0, p3
shl-int v0, p4, v0
return v0
.end method
.method public static shiftDownBits(I[III[I)I
.registers 8
.prologue
.line 621
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_10
.line 623
aget v0, p1, p0
.line 624
ushr-int v1, v0, p2
neg-int v2, p2
shl-int v2, p3, v2
or-int/2addr v1, v2
aput v1, p4, p0
move p3, v0
.line 626
goto :goto_0
.line 627
:cond_10
neg-int v0, p2
shl-int v0, p3, v0
return v0
.end method
.method public static shiftDownWord(I[II)I
.registers 4
.prologue
.line 646
:goto_0
add-int/lit8 p0, p0, -0x1
if-ltz p0, :cond_a
.line 648
aget v0, p1, p0
.line 649
aput p2, p1, p0
move p2, v0
.line 651
goto :goto_0
.line 652
:cond_a
return p2
.end method
.method public static shiftUpBit(I[II)I
.registers 7
.prologue
.line 657
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_10
.line 659
aget v1, p1, v0
.line 660
shl-int/lit8 v2, v1, 0x1
ushr-int/lit8 v3, p2, 0x1f
or-int/2addr v2, v3
aput v2, p1, v0
.line 657
add-int/lit8 v0, v0, 0x1
move p2, v1
goto :goto_1
.line 663
:cond_10
ushr-int/lit8 v0, p2, 0x1f
return v0
.end method
.method public static shiftUpBit(I[III)I
.registers 9
.prologue
.line 668
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_14
.line 670
add-int v1, p2, v0
aget v1, p1, v1
.line 671
add-int v2, p2, v0
shl-int/lit8 v3, v1, 0x1
ushr-int/lit8 v4, p3, 0x1f
or-int/2addr v3, v4
aput v3, p1, v2
.line 668
add-int/lit8 v0, v0, 0x1
move p3, v1
goto :goto_1
.line 674
:cond_14
ushr-int/lit8 v0, p3, 0x1f
return v0
.end method
.method public static shiftUpBit(I[III[II)I
.registers 11
.prologue
.line 690
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_14
.line 692
add-int v1, p2, v0
aget v1, p1, v1
.line 693
add-int v2, p5, v0
shl-int/lit8 v3, v1, 0x1
ushr-int/lit8 v4, p3, 0x1f
or-int/2addr v3, v4
aput v3, p4, v2
.line 690
add-int/lit8 v0, v0, 0x1
move p3, v1
goto :goto_1
.line 696
:cond_14
ushr-int/lit8 v0, p3, 0x1f
return v0
.end method
.method public static shiftUpBit(I[II[I)I
.registers 8
.prologue
.line 679
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_10
.line 681
aget v1, p1, v0
.line 682
shl-int/lit8 v2, v1, 0x1
ushr-int/lit8 v3, p2, 0x1f
or-int/2addr v2, v3
aput v2, p3, v0
.line 679
add-int/lit8 v0, v0, 0x1
move p2, v1
goto :goto_1
.line 685
:cond_10
ushr-int/lit8 v0, p2, 0x1f
return v0
.end method
.method public static shiftUpBit64(I[JIJ[JI)J
.registers 16
.prologue
const/16 v8, 0x3f
.line 701
const/4 v0, 0x0
:goto_3
if-ge v0, p0, :cond_17
.line 703
add-int v1, p2, v0
aget-wide v2, p1, v1
.line 704
add-int v1, p6, v0
const/4 v4, 0x1
shl-long v4, v2, v4
ushr-long v6, p3, v8
or-long/2addr v4, v6
aput-wide v4, p5, v1
.line 701
add-int/lit8 v0, v0, 0x1
move-wide p3, v2
goto :goto_3
.line 707
:cond_17
ushr-long v0, p3, v8
return-wide v0
.end method
.method public static shiftUpBits(I[III)I
.registers 8
.prologue
.line 713
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_11
.line 715
aget v1, p1, v0
.line 716
shl-int v2, v1, p2
neg-int v3, p2
ushr-int v3, p3, v3
or-int/2addr v2, v3
aput v2, p1, v0
.line 713
add-int/lit8 v0, v0, 0x1
move p3, v1
goto :goto_1
.line 719
:cond_11
neg-int v0, p2
ushr-int v0, p3, v0
return v0
.end method
.method public static shiftUpBits(I[IIII)I
.registers 10
.prologue
.line 725
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_15
.line 727
add-int v1, p2, v0
aget v1, p1, v1
.line 728
add-int v2, p2, v0
shl-int v3, v1, p3
neg-int v4, p3
ushr-int v4, p4, v4
or-int/2addr v3, v4
aput v3, p1, v2
.line 725
add-int/lit8 v0, v0, 0x1
move p4, v1
goto :goto_1
.line 731
:cond_15
neg-int v0, p3
ushr-int v0, p4, v0
return v0
.end method
.method public static shiftUpBits(I[IIII[II)I
.registers 12
.prologue
.line 761
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_15
.line 763
add-int v1, p2, v0
aget v1, p1, v1
.line 764
add-int v2, p6, v0
shl-int v3, v1, p3
neg-int v4, p3
ushr-int v4, p4, v4
or-int/2addr v3, v4
aput v3, p5, v2
.line 761
add-int/lit8 v0, v0, 0x1
move p4, v1
goto :goto_1
.line 767
:cond_15
neg-int v0, p3
ushr-int v0, p4, v0
return v0
.end method
.method public static shiftUpBits(I[III[I)I
.registers 9
.prologue
.line 749
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_11
.line 751
aget v1, p1, v0
.line 752
shl-int v2, v1, p2
neg-int v3, p2
ushr-int v3, p3, v3
or-int/2addr v2, v3
aput v2, p4, v0
.line 749
add-int/lit8 v0, v0, 0x1
move p3, v1
goto :goto_1
.line 755
:cond_11
neg-int v0, p2
ushr-int v0, p3, v0
return v0
.end method
.method public static shiftUpBits64(I[JIIJ)J
.registers 14
.prologue
.line 737
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_15
.line 739
add-int v1, p2, v0
aget-wide v2, p1, v1
.line 740
add-int v1, p2, v0
shl-long v4, v2, p3
neg-int v6, p3
ushr-long v6, p4, v6
or-long/2addr v4, v6
aput-wide v4, p1, v1
.line 737
add-int/lit8 v0, v0, 0x1
move-wide p4, v2
goto :goto_1
.line 743
:cond_15
neg-int v0, p3
ushr-long v0, p4, v0
return-wide v0
.end method
.method public static shiftUpBits64(I[JIIJ[JI)J
.registers 16
.prologue
.line 773
const/4 v0, 0x0
:goto_1
if-ge v0, p0, :cond_15
.line 775
add-int v1, p2, v0
aget-wide v2, p1, v1
.line 776
add-int v1, p7, v0
shl-long v4, v2, p3
neg-int v6, p3
ushr-long v6, p4, v6
or-long/2addr v4, v6
aput-wide v4, p6, v1
.line 773
add-int/lit8 v0, v0, 0x1
move-wide p4, v2
goto :goto_1
.line 779
:cond_15
neg-int v0, p3
ushr-long v0, p4, v0
return-wide v0
.end method
.method public static square(I[II[II)V
.registers 15
.prologue
const/4 v4, 0x1
.line 808
shl-int/lit8 v1, p0, 0x1
.line 809
const/4 v0, 0x0
move v2, p0
move v3, v0
move v0, v1
.line 813
:cond_7
add-int/lit8 v2, v2, -0x1
add-int v5, p2, v2
aget v5, p1, v5
int-to-long v6, v5
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
.line 814
mul-long/2addr v6, v6
.line 815
add-int/lit8 v0, v0, -0x1
add-int v5, p4, v0
shl-int/lit8 v3, v3, 0x1f
const/16 v8, 0x21
ushr-long v8, v6, v8
long-to-int v8, v8
or-int/2addr v3, v8
aput v3, p3, v5
.line 816
add-int/lit8 v0, v0, -0x1
add-int v3, p4, v0
ushr-long v8, v6, v4
long-to-int v5, v8
aput v5, p3, v3
.line 817
long-to-int v3, v6
.line 819
if-gtz v2, :cond_7
move v0, v4
.line 821
:goto_30
if-ge v0, p0, :cond_3e
.line 823
invoke-static {p1, p2, v0, p3, p4}, Lorg/spongycastle/math/raw/Nat;->squareWordAdd([III[II)I
move-result v2
.line 824
shl-int/lit8 v3, v0, 0x1
invoke-static {v1, v2, p3, p4, v3}, Lorg/spongycastle/math/raw/Nat;->addWordAt(II[III)I
.line 821
add-int/lit8 v0, v0, 0x1
goto :goto_30
.line 827
:cond_3e
aget v0, p1, p2
shl-int/lit8 v0, v0, 0x1f
invoke-static {v1, p3, p4, v0}, Lorg/spongycastle/math/raw/Nat;->shiftUpBit(I[III)I
.line 828
return-void
.end method
.method public static square(I[I[I)V
.registers 13
.prologue
const/4 v5, 0x1
const/4 v4, 0x0
.line 784
shl-int/lit8 v1, p0, 0x1
move v0, v1
move v2, p0
move v3, v4
.line 789
:cond_7
add-int/lit8 v2, v2, -0x1
aget v6, p1, v2
int-to-long v6, v6
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
.line 790
mul-long/2addr v6, v6
.line 791
add-int/lit8 v0, v0, -0x1
shl-int/lit8 v3, v3, 0x1f
const/16 v8, 0x21
ushr-long v8, v6, v8
long-to-int v8, v8
or-int/2addr v3, v8
aput v3, p2, v0
.line 792
add-int/lit8 v0, v0, -0x1
ushr-long v8, v6, v5
long-to-int v3, v8
aput v3, p2, v0
.line 793
long-to-int v3, v6
.line 795
if-gtz v2, :cond_7
move v0, v5
.line 797
:goto_2a
if-ge v0, p0, :cond_38
.line 799
invoke-static {p1, v0, p2}, Lorg/spongycastle/math/raw/Nat;->squareWordAdd([II[I)I
move-result v2
.line 800
shl-int/lit8 v3, v0, 0x1
invoke-static {v1, v2, p2, v3}, Lorg/spongycastle/math/raw/Nat;->addWordAt(II[II)I
.line 797
add-int/lit8 v0, v0, 0x1
goto :goto_2a
.line 803
:cond_38
aget v0, p1, v4
shl-int/lit8 v0, v0, 0x1f
invoke-static {v1, p2, v0}, Lorg/spongycastle/math/raw/Nat;->shiftUpBit(I[II)I
.line 804
return-void
.end method
.method public static squareWordAdd([III[II)I
.registers 17
.prologue
.line 846
const-wide/16 v2, 0x0
add-int v0, p1, p2
aget v0, p0, v0
int-to-long v0, v0
const-wide v4, 0xffffffffL
and-long/2addr v4, v0
.line 847
const/4 v0, 0x0
.line 850
:cond_e
add-int v1, p1, v0
aget v1, p0, v1
int-to-long v6, v1
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
mul-long/2addr v6, v4
add-int v1, p2, p4
aget v1, p3, v1
int-to-long v8, v1
const-wide v10, 0xffffffffL
and-long/2addr v8, v10
add-long/2addr v6, v8
add-long/2addr v2, v6
.line 851
add-int v1, p2, p4
long-to-int v6, v2
aput v6, p3, v1
.line 852
const/16 v1, 0x20
ushr-long/2addr v2, v1
.line 853
add-int/lit8 p4, p4, 0x1
.line 855
add-int/lit8 v0, v0, 0x1
if-lt v0, p2, :cond_e
.line 856
long-to-int v0, v2
return v0
.end method
.method public static squareWordAdd([II[I)I
.registers 15
.prologue
const-wide v10, 0xffffffffL
.line 832
const-wide/16 v2, 0x0
aget v0, p0, p1
int-to-long v0, v0
and-long v4, v0, v10
.line 833
const/4 v0, 0x0
.line 836
:cond_d
aget v1, p0, v0
int-to-long v6, v1
and-long/2addr v6, v10
mul-long/2addr v6, v4
add-int v1, p1, v0
aget v1, p2, v1
int-to-long v8, v1
and-long/2addr v8, v10
add-long/2addr v6, v8
add-long/2addr v2, v6
.line 837
add-int v1, p1, v0
long-to-int v6, v2
aput v6, p2, v1
.line 838
const/16 v1, 0x20
ushr-long/2addr v2, v1
.line 840
add-int/lit8 v0, v0, 0x1
if-lt v0, p1, :cond_d
.line 841
long-to-int v0, v2
return v0
.end method
.method public static sub(I[II[II[II)I
.registers 17
.prologue
.line 873
const-wide/16 v2, 0x0
.line 874
const/4 v0, 0x0
:goto_3
if-ge v0, p0, :cond_28
.line 876
add-int v1, p2, v0
aget v1, p1, v1
int-to-long v4, v1
const-wide v6, 0xffffffffL
and-long/2addr v4, v6
add-int v1, p4, v0
aget v1, p3, v1
int-to-long v6, v1
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
sub-long/2addr v4, v6
add-long/2addr v2, v4
.line 877
add-int v1, p6, v0
long-to-int v4, v2
aput v4, p5, v1
.line 878
const/16 v1, 0x20
shr-long/2addr v2, v1
.line 874
add-int/lit8 v0, v0, 0x1
goto :goto_3
.line 880
:cond_28
long-to-int v0, v2
return v0
.end method
.method public static sub(I[I[I[I)I
.registers 14
.prologue
const-wide v8, 0xffffffffL
.line 861
const-wide/16 v2, 0x0
.line 862
const/4 v0, 0x0
:goto_8
if-ge v0, p0, :cond_1d
.line 864
aget v1, p1, v0
int-to-long v4, v1
and-long/2addr v4, v8
aget v1, p2, v0
int-to-long v6, v1
and-long/2addr v6, v8
sub-long/2addr v4, v6
add-long/2addr v2, v4
.line 865
long-to-int v1, v2
aput v1, p3, v0
.line 866
const/16 v1, 0x20
shr-long/2addr v2, v1
.line 862
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 868
:cond_1d
long-to-int v0, v2
return v0
.end method
.method public static sub33At(II[II)I
.registers 11
.prologue
const/16 v6, 0x20
const-wide v4, 0xffffffffL
.line 886
aget v0, p2, p3
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
sub-long/2addr v0, v2
.line 887
long-to-int v2, v0
aput v2, p2, p3
.line 888
shr-long/2addr v0, v6
.line 889
add-int/lit8 v2, p3, 0x1
aget v2, p2, v2
int-to-long v2, v2
and-long/2addr v2, v4
const-wide/16 v4, 0x1
sub-long/2addr v2, v4
add-long/2addr v0, v2
.line 890
add-int/lit8 v2, p3, 0x1
long-to-int v3, v0
aput v3, p2, v2
.line 891
shr-long/2addr v0, v6
.line 892
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_2a
const/4 v0, 0x0
:goto_29
return v0
:cond_2a
add-int/lit8 v0, p3, 0x2
invoke-static {p0, p2, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[II)I
move-result v0
goto :goto_29
.end method
.method public static sub33At(II[III)I
.registers 12
.prologue
const/16 v6, 0x20
const-wide v4, 0xffffffffL
.line 898
add-int v0, p3, p4
aget v0, p2, v0
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
sub-long/2addr v0, v2
.line 899
add-int v2, p3, p4
long-to-int v3, v0
aput v3, p2, v2
.line 900
shr-long/2addr v0, v6
.line 901
add-int v2, p3, p4
add-int/lit8 v2, v2, 0x1
aget v2, p2, v2
int-to-long v2, v2
and-long/2addr v2, v4
const-wide/16 v4, 0x1
sub-long/2addr v2, v4
add-long/2addr v0, v2
.line 902
add-int v2, p3, p4
add-int/lit8 v2, v2, 0x1
long-to-int v3, v0
aput v3, p2, v2
.line 903
shr-long/2addr v0, v6
.line 904
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_32
const/4 v0, 0x0
:goto_31
return v0
:cond_32
add-int/lit8 v0, p4, 0x2
invoke-static {p0, p2, p3, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[III)I
move-result v0
goto :goto_31
.end method
.method public static sub33From(II[I)I
.registers 13
.prologue
const/16 v9, 0x20
const/4 v8, 0x1
const-wide v6, 0xffffffffL
const/4 v0, 0x0
.line 909
aget v1, p2, v0
int-to-long v2, v1
and-long/2addr v2, v6
int-to-long v4, p1
and-long/2addr v4, v6
sub-long/2addr v2, v4
.line 910
long-to-int v1, v2
aput v1, p2, v0
.line 911
shr-long/2addr v2, v9
.line 912
aget v1, p2, v8
int-to-long v4, v1
and-long/2addr v4, v6
const-wide/16 v6, 0x1
sub-long/2addr v4, v6
add-long/2addr v2, v4
.line 913
long-to-int v1, v2
aput v1, p2, v8
.line 914
shr-long/2addr v2, v9
.line 915
const-wide/16 v4, 0x0
cmp-long v1, v2, v4
if-nez v1, :cond_27
:goto_26
return v0
:cond_27
const/4 v0, 0x2
invoke-static {p0, p2, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[II)I
move-result v0
goto :goto_26
.end method
.method public static sub33From(II[II)I
.registers 11
.prologue
const/16 v6, 0x20
const-wide v4, 0xffffffffL
.line 920
aget v0, p2, p3
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
sub-long/2addr v0, v2
.line 921
long-to-int v2, v0
aput v2, p2, p3
.line 922
shr-long/2addr v0, v6
.line 923
add-int/lit8 v2, p3, 0x1
aget v2, p2, v2
int-to-long v2, v2
and-long/2addr v2, v4
const-wide/16 v4, 0x1
sub-long/2addr v2, v4
add-long/2addr v0, v2
.line 924
add-int/lit8 v2, p3, 0x1
long-to-int v3, v0
aput v3, p2, v2
.line 925
shr-long/2addr v0, v6
.line 926
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_2a
const/4 v0, 0x0
:goto_29
return v0
:cond_2a
const/4 v0, 0x2
invoke-static {p0, p2, p3, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[III)I
move-result v0
goto :goto_29
.end method
.method public static subBothFrom(I[II[II[II)I
.registers 17
.prologue
.line 943
const-wide/16 v2, 0x0
.line 944
const/4 v0, 0x0
:goto_3
if-ge v0, p0, :cond_34
.line 946
add-int v1, p6, v0
aget v1, p5, v1
int-to-long v4, v1
const-wide v6, 0xffffffffL
and-long/2addr v4, v6
add-int v1, p2, v0
aget v1, p1, v1
int-to-long v6, v1
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
sub-long/2addr v4, v6
add-int v1, p4, v0
aget v1, p3, v1
int-to-long v6, v1
const-wide v8, 0xffffffffL
and-long/2addr v6, v8
sub-long/2addr v4, v6
add-long/2addr v2, v4
.line 947
add-int v1, p6, v0
long-to-int v4, v2
aput v4, p5, v1
.line 948
const/16 v1, 0x20
shr-long/2addr v2, v1
.line 944
add-int/lit8 v0, v0, 0x1
goto :goto_3
.line 950
:cond_34
long-to-int v0, v2
return v0
.end method
.method public static subBothFrom(I[I[I[I)I
.registers 14
.prologue
const-wide v8, 0xffffffffL
.line 931
const-wide/16 v2, 0x0
.line 932
const/4 v0, 0x0
:goto_8
if-ge v0, p0, :cond_22
.line 934
aget v1, p3, v0
int-to-long v4, v1
and-long/2addr v4, v8
aget v1, p1, v0
int-to-long v6, v1
and-long/2addr v6, v8
sub-long/2addr v4, v6
aget v1, p2, v0
int-to-long v6, v1
and-long/2addr v6, v8
sub-long/2addr v4, v6
add-long/2addr v2, v4
.line 935
long-to-int v1, v2
aput v1, p3, v0
.line 936
const/16 v1, 0x20
shr-long/2addr v2, v1
.line 932
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 938
:cond_22
long-to-int v0, v2
return v0
.end method
.method public static subDWordAt(IJ[II)I
.registers 12
.prologue
const-wide v4, 0xffffffffL
const/16 v6, 0x20
.line 956
aget v0, p3, p4
int-to-long v0, v0
and-long/2addr v0, v4
and-long v2, p1, v4
sub-long/2addr v0, v2
.line 957
long-to-int v2, v0
aput v2, p3, p4
.line 958
shr-long/2addr v0, v6
.line 959
add-int/lit8 v2, p4, 0x1
aget v2, p3, v2
int-to-long v2, v2
and-long/2addr v2, v4
ushr-long v4, p1, v6
sub-long/2addr v2, v4
add-long/2addr v0, v2
.line 960
add-int/lit8 v2, p4, 0x1
long-to-int v3, v0
aput v3, p3, v2
.line 961
shr-long/2addr v0, v6
.line 962
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_2a
const/4 v0, 0x0
:goto_29
return v0
:cond_2a
add-int/lit8 v0, p4, 0x2
invoke-static {p0, p3, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[II)I
move-result v0
goto :goto_29
.end method
.method public static subDWordAt(IJ[III)I
.registers 13
.prologue
const-wide v4, 0xffffffffL
const/16 v6, 0x20
.line 968
add-int v0, p4, p5
aget v0, p3, v0
int-to-long v0, v0
and-long/2addr v0, v4
and-long v2, p1, v4
sub-long/2addr v0, v2
.line 969
add-int v2, p4, p5
long-to-int v3, v0
aput v3, p3, v2
.line 970
shr-long/2addr v0, v6
.line 971
add-int v2, p4, p5
add-int/lit8 v2, v2, 0x1
aget v2, p3, v2
int-to-long v2, v2
and-long/2addr v2, v4
ushr-long v4, p1, v6
sub-long/2addr v2, v4
add-long/2addr v0, v2
.line 972
add-int v2, p4, p5
add-int/lit8 v2, v2, 0x1
long-to-int v3, v0
aput v3, p3, v2
.line 973
shr-long/2addr v0, v6
.line 974
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_32
const/4 v0, 0x0
:goto_31
return v0
:cond_32
add-int/lit8 v0, p5, 0x2
invoke-static {p0, p3, p4, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[III)I
move-result v0
goto :goto_31
.end method
.method public static subDWordFrom(IJ[I)I
.registers 15
.prologue
const/4 v9, 0x1
const-wide v6, 0xffffffffL
const/16 v8, 0x20
const/4 v0, 0x0
.line 979
aget v1, p3, v0
int-to-long v2, v1
and-long/2addr v2, v6
and-long v4, p1, v6
sub-long/2addr v2, v4
.line 980
long-to-int v1, v2
aput v1, p3, v0
.line 981
shr-long/2addr v2, v8
.line 982
aget v1, p3, v9
int-to-long v4, v1
and-long/2addr v4, v6
ushr-long v6, p1, v8
sub-long/2addr v4, v6
add-long/2addr v2, v4
.line 983
long-to-int v1, v2
aput v1, p3, v9
.line 984
shr-long/2addr v2, v8
.line 985
const-wide/16 v4, 0x0
cmp-long v1, v2, v4
if-nez v1, :cond_27
:goto_26
return v0
:cond_27
const/4 v0, 0x2
invoke-static {p0, p3, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[II)I
move-result v0
goto :goto_26
.end method
.method public static subDWordFrom(IJ[II)I
.registers 12
.prologue
const-wide v4, 0xffffffffL
const/16 v6, 0x20
.line 990
aget v0, p3, p4
int-to-long v0, v0
and-long/2addr v0, v4
and-long v2, p1, v4
sub-long/2addr v0, v2
.line 991
long-to-int v2, v0
aput v2, p3, p4
.line 992
shr-long/2addr v0, v6
.line 993
add-int/lit8 v2, p4, 0x1
aget v2, p3, v2
int-to-long v2, v2
and-long/2addr v2, v4
ushr-long v4, p1, v6
sub-long/2addr v2, v4
add-long/2addr v0, v2
.line 994
add-int/lit8 v2, p4, 0x1
long-to-int v3, v0
aput v3, p3, v2
.line 995
shr-long/2addr v0, v6
.line 996
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_2a
const/4 v0, 0x0
:goto_29
return v0
:cond_2a
const/4 v0, 0x2
invoke-static {p0, p3, p4, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[III)I
move-result v0
goto :goto_29
.end method
.method public static subFrom(I[II[II)I
.registers 15
.prologue
const-wide v8, 0xffffffffL
.line 1013
const-wide/16 v2, 0x0
.line 1014
const/4 v0, 0x0
:goto_8
if-ge v0, p0, :cond_23
.line 1016
add-int v1, p4, v0
aget v1, p3, v1
int-to-long v4, v1
and-long/2addr v4, v8
add-int v1, p2, v0
aget v1, p1, v1
int-to-long v6, v1
and-long/2addr v6, v8
sub-long/2addr v4, v6
add-long/2addr v2, v4
.line 1017
add-int v1, p4, v0
long-to-int v4, v2
aput v4, p3, v1
.line 1018
const/16 v1, 0x20
shr-long/2addr v2, v1
.line 1014
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 1020
:cond_23
long-to-int v0, v2
return v0
.end method
.method public static subFrom(I[I[I)I
.registers 13
.prologue
const-wide v8, 0xffffffffL
.line 1001
const-wide/16 v2, 0x0
.line 1002
const/4 v0, 0x0
:goto_8
if-ge v0, p0, :cond_1d
.line 1004
aget v1, p2, v0
int-to-long v4, v1
and-long/2addr v4, v8
aget v1, p1, v0
int-to-long v6, v1
and-long/2addr v6, v8
sub-long/2addr v4, v6
add-long/2addr v2, v4
.line 1005
long-to-int v1, v2
aput v1, p2, v0
.line 1006
const/16 v1, 0x20
shr-long/2addr v2, v1
.line 1002
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 1008
:cond_1d
long-to-int v0, v2
return v0
.end method
.method public static subWordAt(II[II)I
.registers 10
.prologue
const-wide v4, 0xffffffffL
.line 1026
aget v0, p2, p3
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
sub-long/2addr v0, v2
.line 1027
long-to-int v2, v0
aput v2, p2, p3
.line 1028
const/16 v2, 0x20
shr-long/2addr v0, v2
.line 1029
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_1a
const/4 v0, 0x0
:goto_19
return v0
:cond_1a
add-int/lit8 v0, p3, 0x1
invoke-static {p0, p2, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[II)I
move-result v0
goto :goto_19
.end method
.method public static subWordAt(II[III)I
.registers 11
.prologue
const-wide v4, 0xffffffffL
.line 1035
add-int v0, p3, p4
aget v0, p2, v0
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
sub-long/2addr v0, v2
.line 1036
add-int v2, p3, p4
long-to-int v3, v0
aput v3, p2, v2
.line 1037
const/16 v2, 0x20
shr-long/2addr v0, v2
.line 1038
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_1e
const/4 v0, 0x0
:goto_1d
return v0
:cond_1e
add-int/lit8 v0, p4, 0x1
invoke-static {p0, p2, p3, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[III)I
move-result v0
goto :goto_1d
.end method
.method public static subWordFrom(II[I)I
.registers 11
.prologue
const-wide v6, 0xffffffffL
const/4 v0, 0x0
.line 1043
aget v1, p2, v0
int-to-long v2, v1
and-long/2addr v2, v6
int-to-long v4, p1
and-long/2addr v4, v6
sub-long/2addr v2, v4
.line 1044
long-to-int v1, v2
aput v1, p2, v0
.line 1045
const/16 v1, 0x20
shr-long/2addr v2, v1
.line 1046
const-wide/16 v4, 0x0
cmp-long v1, v2, v4
if-nez v1, :cond_1a
:goto_19
return v0
:cond_1a
const/4 v0, 0x1
invoke-static {p0, p2, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[II)I
move-result v0
goto :goto_19
.end method
.method public static subWordFrom(II[II)I
.registers 10
.prologue
const-wide v4, 0xffffffffL
.line 1051
aget v0, p2, p3
int-to-long v0, v0
and-long/2addr v0, v4
int-to-long v2, p1
and-long/2addr v2, v4
sub-long/2addr v0, v2
.line 1052
long-to-int v2, v0
aput v2, p2, p3
.line 1053
const/16 v2, 0x20
shr-long/2addr v0, v2
.line 1054
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_1a
const/4 v0, 0x0
:goto_19
return v0
:cond_1a
const/4 v0, 0x1
invoke-static {p0, p2, p3, v0}, Lorg/spongycastle/math/raw/Nat;->decAt(I[III)I
move-result v0
goto :goto_19
.end method
.method public static toBigInteger(I[I)Ljava/math/BigInteger;
.registers 6
.prologue
.line 1059
shl-int/lit8 v0, p0, 0x2
new-array v1, v0, [B
.line 1060
const/4 v0, 0x0
:goto_5
if-ge v0, p0, :cond_16
.line 1062
aget v2, p1, v0
.line 1063
if-eqz v2, :cond_13
.line 1065
add-int/lit8 v3, p0, -0x1
sub-int/2addr v3, v0
shl-int/lit8 v3, v3, 0x2
invoke-static {v2, v1, v3}, Lorg/spongycastle/util/Pack;->intToBigEndian(I[BI)V
.line 1060
:cond_13
add-int/lit8 v0, v0, 0x1
goto :goto_5
.line 1068
:cond_16
new-instance v0, Ljava/math/BigInteger;
const/4 v2, 0x1
invoke-direct {v0, v2, v1}, Ljava/math/BigInteger;-><init>(I[B)V
return-object v0
.end method
.method public static zero(I[I)V
.registers 4
.prologue
const/4 v1, 0x0
.line 1073
move v0, v1
:goto_2
if-ge v0, p0, :cond_9
.line 1075
aput v1, p1, v0
.line 1073
add-int/lit8 v0, v0, 0x1
goto :goto_2
.line 1077
:cond_9
return-void
.end method