Util.smali
.class public Lorg/spongycastle/pqc/math/ntru/util/Util;
.super Ljava/lang/Object;
.source "Util.java"
# static fields
.field private static volatile IS_64_BITNESS_KNOWN:Z
.field private static volatile IS_64_BIT_JVM:Z
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 16
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static generateRandomTernary(IIIZLjava/security/SecureRandom;)Lorg/spongycastle/pqc/math/ntru/polynomial/TernaryPolynomial;
.registers 6
.prologue
.line 72
if-eqz p3, :cond_7
.line 74
invoke-static {p0, p1, p2, p4}, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;->generateRandom(IIILjava/security/SecureRandom;)Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;
move-result-object v0
.line 78
:goto_6
return-object v0
:cond_7
invoke-static {p0, p1, p2, p4}, Lorg/spongycastle/pqc/math/ntru/polynomial/DenseTernaryPolynomial;->generateRandom(IIILjava/security/SecureRandom;)Lorg/spongycastle/pqc/math/ntru/polynomial/DenseTernaryPolynomial;
move-result-object v0
goto :goto_6
.end method
.method public static generateRandomTernary(IIILjava/security/SecureRandom;)[I
.registers 10
.prologue
const/4 v0, 0x0
.line 93
const/4 v1, 0x1
invoke-static {v1}, Lorg/spongycastle/util/Integers;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
.line 94
const/4 v1, -0x1
invoke-static {v1}, Lorg/spongycastle/util/Integers;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
.line 95
invoke-static {v0}, Lorg/spongycastle/util/Integers;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
.line 97
new-instance v5, Ljava/util/ArrayList;
invoke-direct {v5}, Ljava/util/ArrayList;-><init>()V
move v1, v0
.line 98
:goto_15
if-ge v1, p1, :cond_1d
.line 100
invoke-interface {v5, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 98
add-int/lit8 v1, v1, 0x1
goto :goto_15
:cond_1d
move v1, v0
.line 102
:goto_1e
if-ge v1, p2, :cond_26
.line 104
invoke-interface {v5, v3}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 102
add-int/lit8 v1, v1, 0x1
goto :goto_1e
.line 106
:cond_26
:goto_26
invoke-interface {v5}, Ljava/util/List;->size()I
move-result v1
if-ge v1, p0, :cond_30
.line 108
invoke-interface {v5, v4}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_26
.line 111
:cond_30
invoke-static {v5, p3}, Ljava/util/Collections;->shuffle(Ljava/util/List;Ljava/util/Random;)V
.line 113
new-array v2, p0, [I
move v1, v0
.line 114
:goto_36
if-ge v1, p0, :cond_48
.line 116
invoke-interface {v5, v1}, Ljava/util/List;->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
aput v0, v2, v1
.line 114
add-int/lit8 v0, v1, 0x1
move v1, v0
goto :goto_36
.line 118
:cond_48
return-object v2
.end method
.method public static invert(II)I
.registers 3
.prologue
.line 26
rem-int v0, p0, p1
.line 27
if-gez v0, :cond_5
.line 29
add-int/2addr v0, p1
.line 31
:cond_5
invoke-static {v0, p1}, Lorg/spongycastle/pqc/math/ntru/euclid/IntEuclidean;->calculate(II)Lorg/spongycastle/pqc/math/ntru/euclid/IntEuclidean;
move-result-object v0
iget v0, v0, Lorg/spongycastle/pqc/math/ntru/euclid/IntEuclidean;->x:I
return v0
.end method
.method public static is64BitJVM()Z
.registers 4
.prologue
const/4 v1, 0x1
.line 128
sget-boolean v0, Lorg/spongycastle/pqc/math/ntru/util/Util;->IS_64_BITNESS_KNOWN:Z
if-nez v0, :cond_36
.line 130
const-string v0, "os.arch"
invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 131
const-string v2, "sun.arch.data.model"
invoke-static {v2}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v2
.line 132
const-string v3, "amd64"
invoke-virtual {v3, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v3
if-nez v3, :cond_31
const-string v3, "x86_64"
invoke-virtual {v3, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v3
if-nez v3, :cond_31
const-string v3, "ppc64"
invoke-virtual {v3, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_31
const-string v0, "64"
invoke-virtual {v0, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_39
:cond_31
move v0, v1
:goto_32
sput-boolean v0, Lorg/spongycastle/pqc/math/ntru/util/Util;->IS_64_BIT_JVM:Z
.line 133
sput-boolean v1, Lorg/spongycastle/pqc/math/ntru/util/Util;->IS_64_BITNESS_KNOWN:Z
.line 135
:cond_36
sget-boolean v0, Lorg/spongycastle/pqc/math/ntru/util/Util;->IS_64_BIT_JVM:Z
return v0
.line 132
:cond_39
const/4 v0, 0x0
goto :goto_32
.end method
.method public static pow(III)I
.registers 5
.prologue
.line 39
const/4 v1, 0x1
.line 40
const/4 v0, 0x0
:goto_2
if-ge v0, p1, :cond_9
.line 42
mul-int/2addr v1, p0
rem-int/2addr v1, p2
.line 40
add-int/lit8 v0, v0, 0x1
goto :goto_2
.line 44
:cond_9
return v1
.end method
.method public static pow(JIJ)J
.registers 9
.prologue
.line 52
const-wide/16 v2, 0x1
.line 53
const/4 v0, 0x0
:goto_3
if-ge v0, p2, :cond_a
.line 55
mul-long/2addr v2, p0
rem-long/2addr v2, p3
.line 53
add-int/lit8 v0, v0, 0x1
goto :goto_3
.line 57
:cond_a
return-wide v2
.end method
.method public static readFullLength(Ljava/io/InputStream;I)[B
.registers 4
.prologue
.line 151
new-array v0, p1, [B
.line 152
invoke-virtual {p0, v0}, Ljava/io/InputStream;->read([B)I
move-result v1
if-eq v1, p1, :cond_10
.line 154
new-instance v0, Ljava/io/IOException;
const-string v1, "Not enough bytes to read."
invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
.line 156
:cond_10
return-object v0
.end method