GMSSRandom.smali
.class public Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;
.super Ljava/lang/Object;
.source "GMSSRandom.java"
# instance fields
.field private messDigestTree:Lorg/spongycastle/crypto/Digest;
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/Digest;)V
.registers 2
.prologue
.line 21
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 23
iput-object p1, p0, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;->messDigestTree:Lorg/spongycastle/crypto/Digest;
.line 24
return-void
.end method
.method private addByteArrays([B[B)V
.registers 7
.prologue
const/4 v0, 0x0
.line 54
move v1, v0
.line 57
:goto_2
array-length v2, p1
if-ge v0, v2, :cond_18
.line 59
aget-byte v2, p1, v0
and-int/lit16 v2, v2, 0xff
aget-byte v3, p2, v0
and-int/lit16 v3, v3, 0xff
add-int/2addr v2, v3
add-int/2addr v1, v2
.line 60
int-to-byte v2, v1
aput-byte v2, p1, v0
.line 61
shr-int/lit8 v1, v1, 0x8
int-to-byte v1, v1
.line 57
add-int/lit8 v0, v0, 0x1
goto :goto_2
.line 63
:cond_18
return-void
.end method
.method private addOne([B)V
.registers 5
.prologue
.line 68
const/4 v1, 0x1
.line 71
const/4 v0, 0x0
:goto_2
array-length v2, p1
if-ge v0, v2, :cond_13
.line 73
aget-byte v2, p1, v0
and-int/lit16 v2, v2, 0xff
add-int/2addr v1, v2
.line 74
int-to-byte v2, v1
aput-byte v2, p1, v0
.line 75
shr-int/lit8 v1, v1, 0x8
int-to-byte v1, v1
.line 71
add-int/lit8 v0, v0, 0x1
goto :goto_2
.line 77
:cond_13
return-void
.end method
# virtual methods
.method public nextSeed([B)[B
.registers 5
.prologue
const/4 v2, 0x0
.line 38
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;->messDigestTree:Lorg/spongycastle/crypto/Digest;
array-length v1, p1
invoke-interface {v0, p1, v2, v1}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 39
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;->messDigestTree:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
new-array v0, v0, [B
.line 40
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;->messDigestTree:Lorg/spongycastle/crypto/Digest;
invoke-interface {v1, v0, v2}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 43
invoke-direct {p0, p1, v0}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;->addByteArrays([B[B)V
.line 44
invoke-direct {p0, p1}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;->addOne([B)V
.line 48
return-object v0
.end method