GMSSSigner.smali
.class public Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;
.super Ljava/lang/Object;
.source "GMSSSigner.java"
# interfaces
.implements Lorg/spongycastle/pqc/crypto/MessageSigner;
# instance fields
.field private currentAuthPaths:[[[B
.field private digestProvider:Lorg/spongycastle/pqc/crypto/gmss/GMSSDigestProvider;
.field private gmssPS:Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
.field private gmssRandom:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;
.field private gmssUtil:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;
.field private index:[I
.field key:Lorg/spongycastle/pqc/crypto/gmss/GMSSKeyParameters;
.field private mdLength:I
.field private messDigestOTS:Lorg/spongycastle/crypto/Digest;
.field private messDigestTrees:Lorg/spongycastle/crypto/Digest;
.field private numLayer:I
.field private ots:Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSignature;
.field private pubKeyBytes:[B
.field private random:Ljava/security/SecureRandom;
.field private subtreeRootSig:[[B
# direct methods
.method public constructor <init>(Lorg/spongycastle/pqc/crypto/gmss/GMSSDigestProvider;)V
.registers 4
.prologue
.line 109
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 30
new-instance v0, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;
invoke-direct {v0}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;-><init>()V
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssUtil:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;
.line 110
iput-object p1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->digestProvider:Lorg/spongycastle/pqc/crypto/gmss/GMSSDigestProvider;
.line 111
invoke-interface {p1}, Lorg/spongycastle/pqc/crypto/gmss/GMSSDigestProvider;->get()Lorg/spongycastle/crypto/Digest;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
.line 112
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestOTS:Lorg/spongycastle/crypto/Digest;
.line 113
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
.line 114
new-instance v0, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
invoke-direct {v0, v1}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;-><init>(Lorg/spongycastle/crypto/Digest;)V
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssRandom:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;
.line 115
return-void
.end method
.method private initSign()V
.registers 9
.prologue
const/4 v3, 0x0
.line 156
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->reset()V
.line 159
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->key:Lorg/spongycastle/pqc/crypto/gmss/GMSSKeyParameters;
check-cast v0, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;
.line 161
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->isUsed()Z
move-result v1
if-eqz v1, :cond_18
.line 163
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Private key already used"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 167
:cond_18
invoke-virtual {v0, v3}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->getIndex(I)I
move-result v1
invoke-virtual {v0, v3}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->getNumLeafs(I)I
move-result v2
if-lt v1, v2, :cond_2a
.line 169
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "No more signatures can be generated"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 173
:cond_2a
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->getParameters()Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
move-result-object v1
iput-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssPS:Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
.line 175
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssPS:Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
invoke-virtual {v1}, Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;->getNumOfLayers()I
move-result v1
iput v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
.line 178
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->getCurrentSeeds()[[B
move-result-object v1
iget v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
add-int/lit8 v2, v2, -0x1
aget-object v1, v1, v2
.line 180
iget v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
new-array v2, v2, [B
.line 181
iget v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
invoke-static {v1, v3, v2, v3, v4}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 182
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssRandom:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;
invoke-virtual {v1, v2}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSRandom;->nextSeed([B)[B
move-result-object v1
.line 183
new-instance v2, Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSignature;
iget-object v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->digestProvider:Lorg/spongycastle/pqc/crypto/gmss/GMSSDigestProvider;
invoke-interface {v4}, Lorg/spongycastle/pqc/crypto/gmss/GMSSDigestProvider;->get()Lorg/spongycastle/crypto/Digest;
move-result-object v4
iget-object v5, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssPS:Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
invoke-virtual {v5}, Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;->getWinternitzParameter()[I
move-result-object v5
iget v6, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
add-int/lit8 v6, v6, -0x1
aget v5, v5, v6
invoke-direct {v2, v1, v4, v5}, Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSignature;-><init>([BLorg/spongycastle/crypto/Digest;I)V
iput-object v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->ots:Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSignature;
.line 185
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->getCurrentAuthPaths()[[[B
move-result-object v4
.line 186
iget v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
new-array v1, v1, [[[B
iput-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->currentAuthPaths:[[[B
move v2, v3
.line 189
:goto_75
iget v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
if-ge v2, v1, :cond_aa
.line 191
iget-object v5, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->currentAuthPaths:[[[B
aget-object v1, v4, v2
array-length v1, v1
iget v6, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
filled-new-array {v1, v6}, [I
move-result-object v1
sget-object v6, Ljava/lang/Byte;->TYPE:Ljava/lang/Class;
invoke-static {v6, v1}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object;
move-result-object v1
check-cast v1, [[B
aput-object v1, v5, v2
move v1, v3
.line 192
:goto_8f
aget-object v5, v4, v2
array-length v5, v5
if-ge v1, v5, :cond_a6
.line 194
aget-object v5, v4, v2
aget-object v5, v5, v1
iget-object v6, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->currentAuthPaths:[[[B
aget-object v6, v6, v2
aget-object v6, v6, v1
iget v7, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
invoke-static {v5, v3, v6, v3, v7}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 192
add-int/lit8 v1, v1, 0x1
goto :goto_8f
.line 189
:cond_a6
add-int/lit8 v1, v2, 0x1
move v2, v1
goto :goto_75
.line 199
:cond_aa
iget v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
new-array v1, v1, [I
iput-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->index:[I
.line 200
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->getIndex()[I
move-result-object v1
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->index:[I
iget v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
invoke-static {v1, v3, v2, v3, v4}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 204
iget v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
add-int/lit8 v1, v1, -0x1
new-array v1, v1, [[B
iput-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->subtreeRootSig:[[B
move v1, v3
.line 205
:goto_c4
iget v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
add-int/lit8 v2, v2, -0x1
if-ge v1, v2, :cond_e0
.line 207
invoke-virtual {v0, v1}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->getSubtreeRootSig(I)[B
move-result-object v2
.line 208
iget-object v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->subtreeRootSig:[[B
array-length v5, v2
new-array v5, v5, [B
aput-object v5, v4, v1
.line 209
iget-object v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->subtreeRootSig:[[B
aget-object v4, v4, v1
array-length v5, v2
invoke-static {v2, v3, v4, v3, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 205
add-int/lit8 v1, v1, 0x1
goto :goto_c4
.line 212
:cond_e0
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;->markUsed()V
.line 213
return-void
.end method
.method private initVerify()V
.registers 3
.prologue
.line 286
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->reset()V
.line 288
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->key:Lorg/spongycastle/pqc/crypto/gmss/GMSSKeyParameters;
check-cast v0, Lorg/spongycastle/pqc/crypto/gmss/GMSSPublicKeyParameters;
.line 289
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPublicKeyParameters;->getPublicKey()[B
move-result-object v1
iput-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->pubKeyBytes:[B
.line 290
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSPublicKeyParameters;->getParameters()Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssPS:Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
.line 292
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssPS:Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;->getNumOfLayers()I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
.line 295
return-void
.end method
# virtual methods
.method public generateSignature([B)[B
.registers 12
.prologue
const/4 v9, 0x0
.line 227
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->ots:Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSignature;
invoke-virtual {v0, p1}, Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSignature;->getSignature([B)[B
move-result-object v0
.line 230
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssUtil:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->currentAuthPaths:[[[B
iget v3, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
add-int/lit8 v3, v3, -0x1
aget-object v2, v2, v3
invoke-virtual {v1, v2}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;->concatenateArray([[B)[B
move-result-object v1
.line 233
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssUtil:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;
iget-object v3, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->index:[I
iget v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
add-int/lit8 v4, v4, -0x1
aget v3, v3, v4
invoke-virtual {v2, v3}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;->intToBytesLittleEndian(I)[B
move-result-object v2
.line 236
array-length v3, v2
array-length v4, v0
add-int/2addr v3, v4
array-length v4, v1
add-int/2addr v3, v4
new-array v3, v3, [B
.line 237
array-length v4, v2
invoke-static {v2, v9, v3, v9, v4}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 238
array-length v4, v2
array-length v5, v0
invoke-static {v0, v9, v3, v4, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 239
array-length v2, v2
array-length v0, v0
add-int/2addr v0, v2
array-length v2, v1
invoke-static {v1, v9, v3, v0, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 244
new-array v1, v9, [B
.line 246
iget v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
add-int/lit8 v0, v0, -0x1
add-int/lit8 v0, v0, -0x1
:goto_42
if-ltz v0, :cond_94
.line 250
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssUtil:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;
iget-object v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->currentAuthPaths:[[[B
aget-object v4, v4, v0
invoke-virtual {v2, v4}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;->concatenateArray([[B)[B
move-result-object v2
.line 253
iget-object v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssUtil:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;
iget-object v5, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->index:[I
aget v5, v5, v0
invoke-virtual {v4, v5}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;->intToBytesLittleEndian(I)[B
move-result-object v4
.line 258
array-length v5, v1
new-array v5, v5, [B
.line 259
array-length v6, v1
invoke-static {v1, v9, v5, v9, v6}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 261
array-length v1, v5
array-length v6, v4
add-int/2addr v1, v6
iget-object v6, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->subtreeRootSig:[[B
aget-object v6, v6, v0
array-length v6, v6
add-int/2addr v1, v6
array-length v6, v2
add-int/2addr v1, v6
new-array v1, v1, [B
.line 264
array-length v6, v5
invoke-static {v5, v9, v1, v9, v6}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 265
array-length v6, v5
array-length v7, v4
invoke-static {v4, v9, v1, v6, v7}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 266
iget-object v6, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->subtreeRootSig:[[B
aget-object v6, v6, v0
array-length v7, v5
array-length v8, v4
add-int/2addr v7, v8
iget-object v8, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->subtreeRootSig:[[B
aget-object v8, v8, v0
array-length v8, v8
invoke-static {v6, v9, v1, v7, v8}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 267
array-length v5, v5
array-length v4, v4
add-int/2addr v4, v5
iget-object v5, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->subtreeRootSig:[[B
aget-object v5, v5, v0
array-length v5, v5
add-int/2addr v4, v5
array-length v5, v2
invoke-static {v2, v9, v1, v4, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 246
add-int/lit8 v0, v0, -0x1
goto :goto_42
.line 273
:cond_94
array-length v0, v3
array-length v2, v1
add-int/2addr v0, v2
new-array v0, v0, [B
.line 274
array-length v2, v3
invoke-static {v3, v9, v0, v9, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 275
array-length v2, v3
array-length v3, v1
invoke-static {v1, v9, v0, v2, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 278
return-object v0
.end method
.method public init(ZLorg/spongycastle/crypto/CipherParameters;)V
.registers 4
.prologue
.line 121
if-eqz p1, :cond_29
.line 123
instance-of v0, p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
if-eqz v0, :cond_1a
.line 125
check-cast p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
.line 128
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getRandom()Ljava/security/SecureRandom;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->random:Ljava/security/SecureRandom;
.line 129
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
check-cast v0, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->key:Lorg/spongycastle/pqc/crypto/gmss/GMSSKeyParameters;
.line 130
invoke-direct {p0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->initSign()V
.line 148
:goto_19
return-void
.line 136
:cond_1a
new-instance v0, Ljava/security/SecureRandom;
invoke-direct {v0}, Ljava/security/SecureRandom;-><init>()V
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->random:Ljava/security/SecureRandom;
.line 137
check-cast p2, Lorg/spongycastle/pqc/crypto/gmss/GMSSPrivateKeyParameters;
iput-object p2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->key:Lorg/spongycastle/pqc/crypto/gmss/GMSSKeyParameters;
.line 138
invoke-direct {p0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->initSign()V
goto :goto_19
.line 143
:cond_29
check-cast p2, Lorg/spongycastle/pqc/crypto/gmss/GMSSPublicKeyParameters;
iput-object p2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->key:Lorg/spongycastle/pqc/crypto/gmss/GMSSKeyParameters;
.line 144
invoke-direct {p0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->initVerify()V
goto :goto_19
.end method
.method public verifySignature([B[B)Z
.registers 14
.prologue
const/4 v6, 0x1
const/4 v3, 0x0
.line 308
.line 310
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestOTS:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->reset()V
.line 326
iget v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->numLayer:I
add-int/lit8 v0, v0, -0x1
move v7, v0
move v1, v3
:goto_d
if-ltz v7, :cond_ba
.line 328
new-instance v0, Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSVerify;
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->digestProvider:Lorg/spongycastle/pqc/crypto/gmss/GMSSDigestProvider;
invoke-interface {v2}, Lorg/spongycastle/pqc/crypto/gmss/GMSSDigestProvider;->get()Lorg/spongycastle/crypto/Digest;
move-result-object v2
iget-object v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssPS:Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
invoke-virtual {v4}, Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;->getWinternitzParameter()[I
move-result-object v4
aget v4, v4, v7
invoke-direct {v0, v2, v4}, Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSVerify;-><init>(Lorg/spongycastle/crypto/Digest;I)V
.line 329
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSVerify;->getSignatureLength()I
move-result v2
.line 333
iget-object v4, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssUtil:Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;
invoke-virtual {v4, p2, v1}, Lorg/spongycastle/pqc/crypto/gmss/util/GMSSUtil;->bytesToIntLittleEndian([BI)I
move-result v5
.line 336
add-int/lit8 v1, v1, 0x4
.line 339
new-array v4, v2, [B
.line 340
invoke-static {p2, v1, v4, v3, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 341
add-int/2addr v1, v2
.line 344
invoke-virtual {v0, p1, v4}, Lorg/spongycastle/pqc/crypto/gmss/util/WinternitzOTSVerify;->Verify([B[B)[B
move-result-object v4
.line 347
if-nez v4, :cond_42
.line 349
sget-object v0, Ljava/lang/System;->err:Ljava/io/PrintStream;
const-string v1, "OTS Public Key is null in GMSSSignature.verify"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 399
:cond_41
:goto_41
return v3
.line 354
:cond_42
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->gmssPS:Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/gmss/GMSSParameters;->getHeightOfTrees()[I
move-result-object v0
aget v0, v0, v7
iget v2, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
filled-new-array {v0, v2}, [I
move-result-object v0
sget-object v2, Ljava/lang/Byte;->TYPE:Ljava/lang/Class;
invoke-static {v2, v0}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object;
move-result-object v0
check-cast v0, [[B
move v2, v3
.line 355
:goto_59
array-length v8, v0
if-ge v2, v8, :cond_69
.line 357
aget-object v8, v0, v2
iget v9, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
invoke-static {p2, v1, v8, v3, v9}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 358
iget v8, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
add-int/2addr v1, v8
.line 355
add-int/lit8 v2, v2, 0x1
goto :goto_59
.line 366
:cond_69
array-length v2, v0
shl-int v2, v6, v2
.line 367
add-int/2addr v2, v5
move-object v5, v4
move v4, v3
.line 369
:goto_6f
array-length v8, v0
if-ge v4, v8, :cond_b4
.line 371
iget v8, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
shl-int/lit8 v8, v8, 0x1
new-array v8, v8, [B
.line 373
rem-int/lit8 v9, v2, 0x2
if-nez v9, :cond_a2
.line 375
iget v9, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
invoke-static {v5, v3, v8, v3, v9}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 376
aget-object v5, v0, v4
iget v9, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
iget v10, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
invoke-static {v5, v3, v8, v9, v10}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 377
div-int/lit8 v2, v2, 0x2
.line 385
:goto_8c
iget-object v5, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
array-length v9, v8
invoke-interface {v5, v8, v3, v9}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 386
iget-object v5, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
invoke-interface {v5}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v5
new-array v5, v5, [B
.line 387
iget-object v8, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->messDigestTrees:Lorg/spongycastle/crypto/Digest;
invoke-interface {v8, v5, v3}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 369
add-int/lit8 v4, v4, 0x1
goto :goto_6f
.line 381
:cond_a2
aget-object v9, v0, v4
iget v10, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
invoke-static {v9, v3, v8, v3, v10}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 382
iget v9, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->mdLength:I
array-length v10, v5
invoke-static {v5, v3, v8, v9, v10}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 383
add-int/lit8 v2, v2, -0x1
div-int/lit8 v2, v2, 0x2
goto :goto_8c
.line 326
:cond_b4
add-int/lit8 v0, v7, -0x1
move v7, v0
move-object p1, v5
goto/16 :goto_d
.line 394
:cond_ba
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/gmss/GMSSSigner;->pubKeyBytes:[B
invoke-static {v0, p1}, Lorg/spongycastle/util/Arrays;->areEqual([B[B)Z
move-result v0
if-eqz v0, :cond_41
move v3, v6
.line 396
goto/16 :goto_41
.end method