NTRUEngine.smali
.class public Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;
.super Ljava/lang/Object;
.source "NTRUEngine.java"
# interfaces
.implements Lorg/spongycastle/crypto/AsymmetricBlockCipher;
# instance fields
.field private forEncryption:Z
.field private params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
.field private privKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;
.field private pubKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;
.field private random:Ljava/security/SecureRandom;
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 37
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 38
return-void
.end method
.method private MGF([BIIZ)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.registers 17
.prologue
.line 268
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget-object v7, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->hashAlg:Lorg/spongycastle/crypto/Digest;
.line 269
invoke-interface {v7}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v2
.line 270
mul-int v0, p3, v2
new-array v0, v0, [B
.line 271
if-eqz p4, :cond_12
invoke-direct {p0, v7, p1}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->calcHash(Lorg/spongycastle/crypto/Digest;[B)[B
move-result-object p1
.line 272
:cond_12
const/4 v1, 0x0
.line 273
:goto_13
if-ge v1, p3, :cond_2a
.line 275
const/4 v3, 0x0
array-length v4, p1
invoke-interface {v7, p1, v3, v4}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 276
invoke-direct {p0, v7, v1}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->putInt(Lorg/spongycastle/crypto/Digest;I)V
.line 278
invoke-direct {p0, v7}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->calcHash(Lorg/spongycastle/crypto/Digest;)[B
move-result-object v3
.line 279
const/4 v4, 0x0
mul-int v5, v1, v2
invoke-static {v3, v4, v0, v5, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 280
add-int/lit8 v1, v1, 0x1
.line 281
goto :goto_13
.line 283
:cond_2a
new-instance v4, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
invoke-direct {v4, p2}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;-><init>(I)V
.line 286
:goto_2f
const/4 v3, 0x0
.line 287
const/4 v2, 0x0
:goto_31
array-length v5, v0
if-eq v2, v5, :cond_67
.line 289
aget-byte v5, v0, v2
and-int/lit16 v6, v5, 0xff
.line 290
const/16 v5, 0xf3
if-ge v6, v5, :cond_64
.line 295
const/4 v5, 0x0
move v11, v5
move v5, v6
move v6, v3
move v3, v11
:goto_41
const/4 v8, 0x4
if-ge v3, v8, :cond_58
.line 297
rem-int/lit8 v8, v5, 0x3
.line 298
iget-object v9, v4, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->coeffs:[I
add-int/lit8 v10, v8, -0x1
aput v10, v9, v6
.line 299
add-int/lit8 v6, v6, 0x1
.line 300
if-ne v6, p2, :cond_52
move-object v0, v4
.line 317
:goto_51
return-object v0
.line 304
:cond_52
sub-int/2addr v5, v8
div-int/lit8 v5, v5, 0x3
.line 295
add-int/lit8 v3, v3, 0x1
goto :goto_41
.line 307
:cond_58
iget-object v3, v4, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->coeffs:[I
add-int/lit8 v5, v5, -0x1
aput v5, v3, v6
.line 308
add-int/lit8 v3, v6, 0x1
.line 309
if-ne v3, p2, :cond_64
move-object v0, v4
.line 311
goto :goto_51
.line 287
:cond_64
add-int/lit8 v2, v2, 0x1
goto :goto_31
.line 315
:cond_67
if-lt v3, p2, :cond_6b
move-object v0, v4
.line 317
goto :goto_51
.line 320
:cond_6b
const/4 v0, 0x0
array-length v2, p1
invoke-interface {v7, p1, v0, v2}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 321
invoke-direct {p0, v7, v1}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->putInt(Lorg/spongycastle/crypto/Digest;I)V
.line 323
invoke-direct {p0, v7}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->calcHash(Lorg/spongycastle/crypto/Digest;)[B
move-result-object v0
.line 327
add-int/lit8 v1, v1, 0x1
.line 328
goto :goto_2f
.end method
.method private buildSData([B[BI[B[B)[B
.registers 10
.prologue
const/4 v3, 0x0
.line 177
array-length v0, p1
add-int/2addr v0, p3
array-length v1, p4
add-int/2addr v0, v1
array-length v1, p5
add-int/2addr v0, v1
new-array v0, v0, [B
.line 179
array-length v1, p1
invoke-static {p1, v3, v0, v3, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 180
array-length v1, p1
array-length v2, p2
invoke-static {p2, v3, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 181
array-length v1, p1
array-length v2, p2
add-int/2addr v1, v2
array-length v2, p4
invoke-static {p4, v3, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 182
array-length v1, p1
array-length v2, p2
add-int/2addr v1, v2
array-length v2, p4
add-int/2addr v1, v2
array-length v2, p5
invoke-static {p5, v3, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 183
return-object v0
.end method
.method private calcHash(Lorg/spongycastle/crypto/Digest;)[B
.registers 4
.prologue
.line 341
invoke-interface {p1}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
new-array v0, v0, [B
.line 343
const/4 v1, 0x0
invoke-interface {p1, v0, v1}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 345
return-object v0
.end method
.method private calcHash(Lorg/spongycastle/crypto/Digest;[B)[B
.registers 6
.prologue
const/4 v2, 0x0
.line 350
invoke-interface {p1}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
new-array v0, v0, [B
.line 352
array-length v1, p2
invoke-interface {p1, p2, v2, v1}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 353
invoke-interface {p1, v0, v2}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 355
return-object v0
.end method
.method private copyOf([BI)[B
.registers 6
.prologue
const/4 v2, 0x0
.line 478
new-array v0, p2, [B
.line 480
array-length v1, p1
if-ge p2, v1, :cond_a
:goto_6
invoke-static {p1, v2, v0, v2, p2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 482
return-object v0
.line 480
:cond_a
array-length p2, p1
goto :goto_6
.end method
.method private decrypt([BLorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;)[B
.registers 16
.prologue
.line 369
iget-object v0, p2, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;->t:Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;
.line 370
iget-object v2, p2, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;->fp:Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.line 371
iget-object v7, p2, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;->h:Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.line 372
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v3, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->N:I
.line 373
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v8, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
.line 374
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v4, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->db:I
.line 375
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v5, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->maxMsgLenBytes:I
.line 376
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v6, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->dm0:I
.line 377
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v9, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->pkLen:I
.line 378
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v10, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->minCallsMask:I
.line 379
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget-boolean v11, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->hashSeed:Z
.line 380
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget-object v1, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->oid:[B
.line 382
const/16 v12, 0xff
if-le v5, v12, :cond_36
.line 384
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "maxMsgLenBytes values bigger than 255 are not supported"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 387
:cond_36
div-int/lit8 v12, v4, 0x8
.line 389
invoke-static {p1, v3, v8}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->fromBinary([BII)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v4
.line 390
invoke-virtual {p0, v4, v0, v2}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->decrypt(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v2
.line 392
const/4 v0, -0x1
invoke-virtual {v2, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->count(I)I
move-result v0
if-ge v0, v6, :cond_4f
.line 394
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "Less than dm0 coefficients equal -1"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 396
:cond_4f
const/4 v0, 0x0
invoke-virtual {v2, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->count(I)I
move-result v0
if-ge v0, v6, :cond_5e
.line 398
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "Less than dm0 coefficients equal 0"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 400
:cond_5e
const/4 v0, 0x1
invoke-virtual {v2, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->count(I)I
move-result v0
if-ge v0, v6, :cond_6d
.line 402
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "Less than dm0 coefficients equal 1"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 405
:cond_6d
invoke-virtual {v4}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->clone()Ljava/lang/Object;
move-result-object v0
move-object v6, v0
check-cast v6, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.line 406
invoke-virtual {v6, v2}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->sub(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)V
.line 407
invoke-virtual {v6, v8}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->modPositive(I)V
.line 408
invoke-virtual {v6}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->clone()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.line 409
const/4 v4, 0x4
invoke-virtual {v0, v4}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->modPositive(I)V
.line 410
const/4 v4, 0x4
invoke-virtual {v0, v4}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->toBinary(I)[B
move-result-object v0
.line 411
invoke-direct {p0, v0, v3, v10, v11}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->MGF([BIIZ)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v0
.line 413
invoke-virtual {v2, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->sub(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)V
.line 414
invoke-virtual {v2}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->mod3()V
.line 415
invoke-virtual {v2}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->toBinary3Sves()[B
move-result-object v0
.line 417
new-array v4, v12, [B
.line 418
const/4 v2, 0x0
const/4 v3, 0x0
invoke-static {v0, v2, v4, v3, v12}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 419
aget-byte v2, v0, v12
and-int/lit16 v3, v2, 0xff
.line 420
if-le v3, v5, :cond_c3
.line 422
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Message too long: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ">"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 424
:cond_c3
new-array v2, v3, [B
.line 425
add-int/lit8 v5, v12, 0x1
const/4 v10, 0x0
invoke-static {v0, v5, v2, v10, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 426
array-length v5, v0
add-int/lit8 v10, v12, 0x1
add-int/2addr v10, v3
sub-int/2addr v5, v10
new-array v5, v5, [B
.line 427
add-int/lit8 v10, v12, 0x1
add-int/2addr v10, v3
const/4 v11, 0x0
array-length v12, v5
invoke-static {v0, v10, v5, v11, v12}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 428
array-length v0, v5
new-array v0, v0, [B
invoke-static {v5, v0}, Lorg/spongycastle/util/Arrays;->constantTimeAreEqual([B[B)Z
move-result v0
if-nez v0, :cond_eb
.line 430
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "The message is not followed by zeroes"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 434
:cond_eb
invoke-virtual {v7, v8}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->toBinary(I)[B
move-result-object v0
.line 435
div-int/lit8 v5, v9, 0x8
invoke-direct {p0, v0, v5}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->copyOf([BI)[B
move-result-object v5
move-object v0, p0
.line 436
invoke-direct/range {v0 .. v5}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->buildSData([B[BI[B[B)[B
move-result-object v0
.line 438
invoke-direct {p0, v0, v2}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->generateBlindingPoly([B[B)Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;
move-result-object v0
.line 439
invoke-interface {v0, v7}, Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;->mult(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v0
.line 440
invoke-virtual {v0, v8}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->modPositive(I)V
.line 441
invoke-virtual {v0, v6}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_113
.line 443
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "Invalid message encoding"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 446
:cond_113
return-object v2
.end method
.method private encrypt([BLorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;)[B
.registers 24
.prologue
.line 104
move-object/from16 v0, p2
iget-object v9, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;->h:Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.line 105
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v10, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->N:I
.line 106
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v11, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
.line 108
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v12, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->maxMsgLenBytes:I
.line 109
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v13, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->db:I
.line 110
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v14, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->bufferLenBits:I
.line 111
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v15, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->dm0:I
.line 112
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v0, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->pkLen:I
move/from16 v16, v0
.line 113
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v0, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->minCallsMask:I
move/from16 v17, v0
.line 114
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget-boolean v0, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->hashSeed:Z
move/from16 v18, v0
.line 115
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget-object v4, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->oid:[B
.line 117
move-object/from16 v0, p1
array-length v6, v0
.line 118
const/16 v3, 0xff
if-le v12, v3, :cond_55
.line 120
new-instance v3, Ljava/lang/IllegalArgumentException;
const-string v4, "llen values bigger than 1 are not supported"
invoke-direct {v3, v4}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v3
.line 122
:cond_55
if-le v6, v12, :cond_76
.line 124
new-instance v3, Lorg/spongycastle/crypto/DataLengthException;
new-instance v4, Ljava/lang/StringBuilder;
const-string v5, "Message too long: "
invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v4
const-string v5, ">"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, v12}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-direct {v3, v4}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v3
.line 130
:cond_76
div-int/lit8 v3, v13, 0x8
new-array v7, v3, [B
.line 131
move-object/from16 v0, p0
iget-object v3, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->random:Ljava/security/SecureRandom;
invoke-virtual {v3, v7}, Ljava/security/SecureRandom;->nextBytes([B)V
.line 132
add-int/lit8 v3, v12, 0x1
sub-int/2addr v3, v6
new-array v3, v3, [B
.line 133
div-int/lit8 v5, v14, 0x8
new-array v0, v5, [B
move-object/from16 v19, v0
.line 135
const/4 v5, 0x0
const/4 v8, 0x0
array-length v0, v7
move/from16 v20, v0
move-object/from16 v0, v19
move/from16 v1, v20
invoke-static {v7, v5, v0, v8, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 136
array-length v5, v7
int-to-byte v8, v6
aput-byte v8, v19, v5
.line 137
const/4 v5, 0x0
array-length v8, v7
add-int/lit8 v8, v8, 0x1
move-object/from16 v0, p1
array-length v0, v0
move/from16 v20, v0
move-object/from16 v0, p1
move-object/from16 v1, v19
move/from16 v2, v20
invoke-static {v0, v5, v1, v8, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 138
const/4 v5, 0x0
array-length v8, v7
add-int/lit8 v8, v8, 0x1
move-object/from16 v0, p1
array-length v0, v0
move/from16 v20, v0
add-int v8, v8, v20
array-length v0, v3
move/from16 v20, v0
move-object/from16 v0, v19
move/from16 v1, v20
invoke-static {v3, v5, v0, v8, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 140
move-object/from16 v0, v19
invoke-static {v0, v10}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->fromBinary3Sves([BI)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v20
.line 143
invoke-virtual {v9, v11}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->toBinary(I)[B
move-result-object v3
.line 144
div-int/lit8 v5, v16, 0x8
move-object/from16 v0, p0
invoke-direct {v0, v3, v5}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->copyOf([BI)[B
move-result-object v8
move-object/from16 v3, p0
move-object/from16 v5, p1
.line 145
invoke-direct/range {v3 .. v8}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->buildSData([B[BI[B[B)[B
move-result-object v3
.line 147
move-object/from16 v0, p0
move-object/from16 v1, v19
invoke-direct {v0, v3, v1}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->generateBlindingPoly([B[B)Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;
move-result-object v3
.line 148
invoke-interface {v3, v9, v11}, Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;->mult(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;I)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v5
.line 149
invoke-virtual {v5}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->clone()Ljava/lang/Object;
move-result-object v3
check-cast v3, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.line 150
const/4 v7, 0x4
invoke-virtual {v3, v7}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->modPositive(I)V
.line 151
const/4 v7, 0x4
invoke-virtual {v3, v7}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->toBinary(I)[B
move-result-object v3
.line 152
move-object/from16 v0, p0
move/from16 v1, v17
move/from16 v2, v18
invoke-direct {v0, v3, v10, v1, v2}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->MGF([BIIZ)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v3
.line 153
move-object/from16 v0, v20
invoke-virtual {v0, v3}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->add(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)V
.line 154
invoke-virtual/range {v20 .. v20}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->mod3()V
.line 156
const/4 v3, -0x1
move-object/from16 v0, v20
invoke-virtual {v0, v3}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->count(I)I
move-result v3
if-lt v3, v15, :cond_76
.line 160
const/4 v3, 0x0
move-object/from16 v0, v20
invoke-virtual {v0, v3}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->count(I)I
move-result v3
if-lt v3, v15, :cond_76
.line 164
const/4 v3, 0x1
move-object/from16 v0, v20
invoke-virtual {v0, v3}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->count(I)I
move-result v3
if-lt v3, v15, :cond_76
.line 169
move-object/from16 v0, v20
invoke-virtual {v5, v0, v11}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->add(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;I)V
.line 170
invoke-virtual {v5, v11}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->ensurePositive(I)V
.line 171
invoke-virtual {v5, v11}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->toBinary(I)[B
move-result-object v3
return-object v3
.end method
.method private generateBlindingCoeffs(Lorg/spongycastle/pqc/crypto/ntru/IndexGenerator;I)[I
.registers 8
.prologue
.line 238
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v0, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->N:I
.line 240
new-array v2, v0, [I
.line 241
const/4 v0, -0x1
move v1, v0
:goto_8
const/4 v0, 0x1
if-gt v1, v0, :cond_1f
.line 243
const/4 v0, 0x0
.line 244
:cond_c
:goto_c
if-ge v0, p2, :cond_1b
.line 246
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/ntru/IndexGenerator;->nextIndex()I
move-result v3
.line 247
aget v4, v2, v3
if-nez v4, :cond_c
.line 249
aput v1, v2, v3
.line 250
add-int/lit8 v0, v0, 0x1
goto :goto_c
.line 241
:cond_1b
add-int/lit8 v0, v1, 0x2
move v1, v0
goto :goto_8
.line 255
:cond_1f
return-object v2
.end method
.method private generateBlindingPoly([B[B)Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;
.registers 8
.prologue
.line 203
new-instance v0, Lorg/spongycastle/pqc/crypto/ntru/IndexGenerator;
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
invoke-direct {v0, p1, v1}, Lorg/spongycastle/pqc/crypto/ntru/IndexGenerator;-><init>([BLorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;)V
.line 205
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v1, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->polyType:I
const/4 v2, 0x1
if-ne v1, v2, :cond_3b
.line 207
new-instance v1, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v2, v2, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->dr1:I
invoke-direct {p0, v0, v2}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->generateBlindingCoeffs(Lorg/spongycastle/pqc/crypto/ntru/IndexGenerator;I)[I
move-result-object v2
invoke-direct {v1, v2}, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;-><init>([I)V
.line 208
new-instance v2, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;
iget-object v3, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v3, v3, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->dr2:I
invoke-direct {p0, v0, v3}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->generateBlindingCoeffs(Lorg/spongycastle/pqc/crypto/ntru/IndexGenerator;I)[I
move-result-object v3
invoke-direct {v2, v3}, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;-><init>([I)V
.line 209
new-instance v3, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;
iget-object v4, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v4, v4, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->dr3:I
invoke-direct {p0, v0, v4}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->generateBlindingCoeffs(Lorg/spongycastle/pqc/crypto/ntru/IndexGenerator;I)[I
move-result-object v0
invoke-direct {v3, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;-><init>([I)V
.line 210
new-instance v0, Lorg/spongycastle/pqc/math/ntru/polynomial/ProductFormPolynomial;
invoke-direct {v0, v1, v2, v3}, Lorg/spongycastle/pqc/math/ntru/polynomial/ProductFormPolynomial;-><init>(Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;)V
.line 223
:goto_3a
return-object v0
.line 214
:cond_3b
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v1, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->dr:I
.line 215
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget-boolean v2, v2, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->sparse:Z
.line 216
invoke-direct {p0, v0, v1}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->generateBlindingCoeffs(Lorg/spongycastle/pqc/crypto/ntru/IndexGenerator;I)[I
move-result-object v1
.line 217
if-eqz v2, :cond_4f
.line 219
new-instance v0, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;
invoke-direct {v0, v1}, Lorg/spongycastle/pqc/math/ntru/polynomial/SparseTernaryPolynomial;-><init>([I)V
goto :goto_3a
.line 223
:cond_4f
new-instance v0, Lorg/spongycastle/pqc/math/ntru/polynomial/DenseTernaryPolynomial;
invoke-direct {v0, v1}, Lorg/spongycastle/pqc/math/ntru/polynomial/DenseTernaryPolynomial;-><init>([I)V
goto :goto_3a
.end method
.method private log2(I)I
.registers 4
.prologue
.line 487
const/16 v0, 0x800
if-ne p1, v0, :cond_7
.line 489
const/16 v0, 0xb
return v0
.line 492
:cond_7
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "log2 not fully implemented"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method private putInt(Lorg/spongycastle/crypto/Digest;I)V
.registers 4
.prologue
.line 333
shr-int/lit8 v0, p2, 0x18
invoke-interface {p1, v0}, Lorg/spongycastle/crypto/Digest;->update(B)V
.line 334
shr-int/lit8 v0, p2, 0x10
int-to-byte v0, v0
invoke-interface {p1, v0}, Lorg/spongycastle/crypto/Digest;->update(B)V
.line 335
shr-int/lit8 v0, p2, 0x8
int-to-byte v0, v0
invoke-interface {p1, v0}, Lorg/spongycastle/crypto/Digest;->update(B)V
.line 336
int-to-byte v0, p2
invoke-interface {p1, v0}, Lorg/spongycastle/crypto/Digest;->update(B)V
.line 337
return-void
.end method
# virtual methods
.method protected decrypt(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.registers 7
.prologue
const/4 v2, 0x3
.line 458
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget-boolean v0, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->fastFp:Z
if-eqz v0, :cond_29
.line 460
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v0, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
invoke-interface {p2, p1, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;->mult(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;I)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v0
.line 461
invoke-virtual {v0, v2}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->mult(I)V
.line 462
invoke-virtual {v0, p1}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->add(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)V
.line 468
:goto_15
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v1, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
invoke-virtual {v0, v1}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->center0(I)V
.line 469
invoke-virtual {v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->mod3()V
.line 471
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget-boolean v1, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->fastFp:Z
if-eqz v1, :cond_32
.line 472
:goto_25
invoke-virtual {v0, v2}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->center0(I)V
.line 473
return-object v0
.line 466
:cond_29
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v0, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
invoke-interface {p2, p1, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/Polynomial;->mult(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;I)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v0
goto :goto_15
.line 471
:cond_32
new-instance v1, Lorg/spongycastle/pqc/math/ntru/polynomial/DenseTernaryPolynomial;
invoke-direct {v1, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/DenseTernaryPolynomial;-><init>(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)V
invoke-virtual {v1, p3, v2}, Lorg/spongycastle/pqc/math/ntru/polynomial/DenseTernaryPolynomial;->mult(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;I)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v0
goto :goto_25
.end method
.method protected encrypt(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;Lorg/spongycastle/pqc/math/ntru/polynomial/TernaryPolynomial;Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
.registers 6
.prologue
.line 188
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v0, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
invoke-interface {p2, p3, v0}, Lorg/spongycastle/pqc/math/ntru/polynomial/TernaryPolynomial;->mult(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;I)Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;
move-result-object v0
.line 189
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v1, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
invoke-virtual {v0, p1, v1}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->add(Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;I)V
.line 190
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v1, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
invoke-virtual {v0, v1}, Lorg/spongycastle/pqc/math/ntru/polynomial/IntegerPolynomial;->ensurePositive(I)V
.line 191
return-object v0
.end method
.method public getInputBlockSize()I
.registers 2
.prologue
.line 69
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v0, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->maxMsgLenBytes:I
return v0
.end method
.method public getOutputBlockSize()I
.registers 3
.prologue
.line 74
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v0, v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->N:I
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
iget v1, v1, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;->q:I
invoke-direct {p0, v1}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->log2(I)I
move-result v1
mul-int/2addr v0, v1
add-int/lit8 v0, v0, 0x7
div-int/lit8 v0, v0, 0x8
return v0
.end method
.method public init(ZLorg/spongycastle/crypto/CipherParameters;)V
.registers 4
.prologue
.line 42
iput-boolean p1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->forEncryption:Z
.line 43
if-eqz p1, :cond_2d
.line 45
instance-of v0, p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
if-eqz v0, :cond_21
.line 47
check-cast p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
.line 49
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getRandom()Ljava/security/SecureRandom;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->random:Ljava/security/SecureRandom;
.line 50
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
check-cast v0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->pubKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;
.line 58
:goto_18
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->pubKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;->getParameters()Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
.line 65
:goto_20
return-void
.line 54
:cond_21
new-instance v0, Ljava/security/SecureRandom;
invoke-direct {v0}, Ljava/security/SecureRandom;-><init>()V
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->random:Ljava/security/SecureRandom;
.line 55
check-cast p2, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;
iput-object p2, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->pubKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;
goto :goto_18
.line 62
:cond_2d
check-cast p2, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;
iput-object p2, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->privKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;
.line 63
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->privKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;->getParameters()Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->params:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionParameters;
goto :goto_20
.end method
.method public processBlock([BII)[B
.registers 6
.prologue
.line 80
new-array v0, p3, [B
.line 82
const/4 v1, 0x0
invoke-static {p1, p2, v0, v1, p3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 84
iget-boolean v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->forEncryption:Z
if-eqz v1, :cond_11
.line 86
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->pubKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;
invoke-direct {p0, v0, v1}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->encrypt([BLorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPublicKeyParameters;)[B
move-result-object v0
.line 90
:goto_10
return-object v0
:cond_11
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->privKey:Lorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;
invoke-direct {p0, v0, v1}, Lorg/spongycastle/pqc/crypto/ntru/NTRUEngine;->decrypt([BLorg/spongycastle/pqc/crypto/ntru/NTRUEncryptionPrivateKeyParameters;)[B
move-result-object v0
goto :goto_10
.end method