McElieceKobaraImaiCipher.smali
.class public Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;
.super Ljava/lang/Object;
.source "McElieceKobaraImaiCipher.java"
# interfaces
.implements Lorg/spongycastle/pqc/crypto/MessageEncryptor;
# static fields
.field private static final DEFAULT_PRNG_NAME:Ljava/lang/String; = "SHA1PRNG"
.field public static final OID:Ljava/lang/String; = "1.3.6.1.4.1.8301.3.1.3.4.2.3"
.field public static final PUBLIC_CONSTANT:[B
# instance fields
.field private k:I
.field key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
.field private messDigest:Lorg/spongycastle/crypto/Digest;
.field private n:I
.field private sr:Ljava/security/SecureRandom;
.field private t:I
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 35
const-string v0, "a predetermined public constant"
.line 36
invoke-virtual {v0}, Ljava/lang/String;->getBytes()[B
move-result-object v0
sput-object v0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->PUBLIC_CONSTANT:[B
.line 35
return-void
.end method
.method public constructor <init>()V
.registers 1
.prologue
.line 21
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private initCipherEncrypt(Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;)V
.registers 3
.prologue
.line 103
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;->getParameters()Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2Parameters;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2Parameters;->getDigest()Lorg/spongycastle/crypto/Digest;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
.line 104
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;->getN()I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->n:I
.line 105
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;->getK()I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->k:I
.line 106
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;->getT()I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->t:I
.line 108
return-void
.end method
# virtual methods
.method public getKeySize(Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;)I
.registers 4
.prologue
.line 89
instance-of v0, p1, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;
if-eqz v0, :cond_b
.line 91
check-cast p1, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;->getN()I
move-result v0
.line 96
:goto_a
return v0
.line 94
:cond_b
instance-of v0, p1, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;
if-eqz v0, :cond_16
.line 96
check-cast p1, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;->getN()I
move-result v0
goto :goto_a
.line 98
:cond_16
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "unsupported type"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public init(ZLorg/spongycastle/crypto/CipherParameters;)V
.registers 4
.prologue
.line 55
if-eqz p1, :cond_31
.line 57
instance-of v0, p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
if-eqz v0, :cond_1e
.line 59
check-cast p2, Lorg/spongycastle/crypto/params/ParametersWithRandom;
.line 61
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getRandom()Ljava/security/SecureRandom;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->sr:Ljava/security/SecureRandom;
.line 62
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithRandom;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
check-cast v0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
.line 63
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
check-cast v0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;
invoke-direct {p0, v0}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->initCipherEncrypt(Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;)V
.line 79
:goto_1d
return-void
.line 68
:cond_1e
new-instance v0, Ljava/security/SecureRandom;
invoke-direct {v0}, Ljava/security/SecureRandom;-><init>()V
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->sr:Ljava/security/SecureRandom;
.line 69
check-cast p2, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;
iput-object p2, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
.line 70
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
check-cast v0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;
invoke-direct {p0, v0}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->initCipherEncrypt(Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;)V
goto :goto_1d
.line 75
:cond_31
check-cast p2, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;
iput-object p2, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
.line 76
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
check-cast v0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;
invoke-virtual {p0, v0}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->initCipherDecrypt(Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;)V
goto :goto_1d
.end method
.method public initCipherDecrypt(Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;)V
.registers 3
.prologue
.line 112
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;->getParameters()Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2Parameters;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2Parameters;->getDigest()Lorg/spongycastle/crypto/Digest;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
.line 113
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;->getN()I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->n:I
.line 114
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;->getK()I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->k:I
.line 115
invoke-virtual {p1}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;->getT()I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->t:I
.line 116
return-void
.end method
.method public messageDecrypt([B)[B
.registers 11
.prologue
const/4 v8, 0x1
const/4 v7, 0x0
.line 218
iget v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->n:I
shr-int/lit8 v0, v0, 0x3
.line 220
array-length v1, p1
if-ge v1, v0, :cond_11
.line 222
new-instance v0, Ljava/lang/Exception;
const-string v1, "Bad Padding: Ciphertext too short."
invoke-direct {v0, v1}, Ljava/lang/Exception;-><init>(Ljava/lang/String;)V
throw v0
.line 225
:cond_11
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v1}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v2
.line 226
iget v1, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->k:I
shr-int/lit8 v3, v1, 0x3
.line 227
array-length v1, p1
sub-int v0, v1, v0
.line 231
if-lez v0, :cond_82
.line 233
invoke-static {p1, v0}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->split([BI)[[B
move-result-object v1
.line 234
aget-object v0, v1, v7
.line 235
aget-object p1, v1, v8
move-object v1, v0
.line 244
:goto_29
iget v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->n:I
invoke-static {v0, p1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;->OS2VP(I[B)Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;
move-result-object v4
.line 247
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
check-cast v0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;
invoke-static {v0, v4}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2Primitives;->decryptionPrimitive(Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PrivateKeyParameters;Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;)[Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;
move-result-object v4
.line 249
aget-object v0, v4, v7
invoke-virtual {v0}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;->getEncoded()[B
move-result-object v0
.line 250
aget-object v4, v4, v8
.line 253
array-length v5, v0
if-le v5, v3, :cond_46
.line 256
invoke-static {v0, v7, v3}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->subArray([BII)[B
move-result-object v0
.line 260
:cond_46
iget v3, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->n:I
iget v5, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->t:I
invoke-static {v3, v5, v4}, Lorg/spongycastle/pqc/crypto/mceliece/Conversions;->decode(IILorg/spongycastle/pqc/math/linearalgebra/GF2Vector;)[B
move-result-object v3
.line 263
invoke-static {v1, v3}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->concatenate([B[B)[B
move-result-object v1
.line 264
invoke-static {v1, v0}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->concatenate([B[B)[B
move-result-object v0
.line 268
array-length v1, v0
sub-int/2addr v1, v2
.line 269
invoke-static {v0, v2}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->split([BI)[[B
move-result-object v0
.line 270
aget-object v3, v0, v7
.line 271
aget-object v4, v0, v8
.line 274
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
new-array v5, v0, [B
.line 275
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
array-length v6, v4
invoke-interface {v0, v4, v7, v6}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 276
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0, v5, v7}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 279
add-int/lit8 v0, v2, -0x1
:goto_75
if-ltz v0, :cond_86
.line 281
aget-byte v2, v5, v0
aget-byte v6, v3, v0
xor-int/2addr v2, v6
int-to-byte v2, v2
aput-byte v2, v5, v0
.line 279
add-int/lit8 v0, v0, -0x1
goto :goto_75
.line 239
:cond_82
new-array v0, v7, [B
move-object v1, v0
goto :goto_29
.line 285
:cond_86
new-instance v0, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;
new-instance v2, Lorg/spongycastle/crypto/digests/SHA1Digest;
invoke-direct {v2}, Lorg/spongycastle/crypto/digests/SHA1Digest;-><init>()V
invoke-direct {v0, v2}, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;-><init>(Lorg/spongycastle/crypto/Digest;)V
.line 288
invoke-virtual {v0, v5}, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;->addSeedMaterial([B)V
.line 291
new-array v2, v1, [B
.line 292
invoke-virtual {v0, v2}, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;->nextBytes([B)V
.line 295
add-int/lit8 v0, v1, -0x1
:goto_9a
if-ltz v0, :cond_a7
.line 297
aget-byte v3, v2, v0
aget-byte v5, v4, v0
xor-int/2addr v3, v5
int-to-byte v3, v3
aput-byte v3, v2, v0
.line 295
add-int/lit8 v0, v0, -0x1
goto :goto_9a
.line 300
:cond_a7
array-length v0, v2
if-ge v0, v1, :cond_b2
.line 302
new-instance v0, Ljava/lang/Exception;
const-string v1, "Bad Padding: invalid ciphertext"
invoke-direct {v0, v1}, Ljava/lang/Exception;-><init>(Ljava/lang/String;)V
throw v0
.line 305
:cond_b2
sget-object v0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->PUBLIC_CONSTANT:[B
array-length v0, v0
sub-int v0, v1, v0
invoke-static {v2, v0}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->split([BI)[[B
move-result-object v0
.line 307
aget-object v1, v0, v7
.line 308
aget-object v0, v0, v8
.line 310
sget-object v2, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->PUBLIC_CONSTANT:[B
invoke-static {v0, v2}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->equals([B[B)Z
move-result v0
if-nez v0, :cond_cf
.line 312
new-instance v0, Ljava/lang/Exception;
const-string v1, "Bad Padding: invalid ciphertext"
invoke-direct {v0, v1}, Ljava/lang/Exception;-><init>(Ljava/lang/String;)V
throw v0
.line 315
:cond_cf
return-object v1
.end method
.method public messageEncrypt([B)[B
.registers 13
.prologue
const/4 v10, 0x0
.line 122
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v1
.line 123
iget v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->k:I
shr-int/lit8 v2, v0, 0x3
.line 124
iget v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->n:I
iget v3, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->t:I
invoke-static {v0, v3}, Lorg/spongycastle/pqc/math/linearalgebra/IntegerFunctions;->binomial(II)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0}, Ljava/math/BigInteger;->bitLength()I
move-result v0
add-int/lit8 v0, v0, -0x1
shr-int/lit8 v3, v0, 0x3
.line 127
add-int v0, v2, v3
sub-int/2addr v0, v1
sget-object v4, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->PUBLIC_CONSTANT:[B
array-length v4, v4
sub-int/2addr v0, v4
.line 128
array-length v4, p1
if-le v4, v0, :cond_26
.line 130
array-length v0, p1
.line 133
:cond_26
sget-object v4, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->PUBLIC_CONSTANT:[B
array-length v4, v4
add-int/2addr v4, v0
.line 134
add-int v5, v4, v1
sub-int/2addr v5, v2
sub-int/2addr v5, v3
.line 137
new-array v6, v4, [B
.line 138
array-length v7, p1
invoke-static {p1, v10, v6, v10, v7}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 139
sget-object v7, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->PUBLIC_CONSTANT:[B
sget-object v8, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->PUBLIC_CONSTANT:[B
array-length v8, v8
invoke-static {v7, v10, v6, v0, v8}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 143
new-array v7, v1, [B
.line 144
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->sr:Ljava/security/SecureRandom;
invoke-virtual {v0, v7}, Ljava/security/SecureRandom;->nextBytes([B)V
.line 148
new-instance v0, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;
new-instance v8, Lorg/spongycastle/crypto/digests/SHA1Digest;
invoke-direct {v8}, Lorg/spongycastle/crypto/digests/SHA1Digest;-><init>()V
invoke-direct {v0, v8}, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;-><init>(Lorg/spongycastle/crypto/Digest;)V
.line 151
invoke-virtual {v0, v7}, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;->addSeedMaterial([B)V
.line 154
new-array v8, v4, [B
.line 155
invoke-virtual {v0, v8}, Lorg/spongycastle/crypto/prng/DigestRandomGenerator;->nextBytes([B)V
.line 158
add-int/lit8 v0, v4, -0x1
:goto_57
if-ltz v0, :cond_64
.line 160
aget-byte v4, v8, v0
aget-byte v9, v6, v0
xor-int/2addr v4, v9
int-to-byte v4, v4
aput-byte v4, v8, v0
.line 158
add-int/lit8 v0, v0, -0x1
goto :goto_57
.line 164
:cond_64
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v0
new-array v4, v0, [B
.line 165
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
array-length v6, v8
invoke-interface {v0, v8, v10, v6}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 166
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->messDigest:Lorg/spongycastle/crypto/Digest;
invoke-interface {v0, v4, v10}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 169
add-int/lit8 v0, v1, -0x1
:goto_79
if-ltz v0, :cond_86
.line 171
aget-byte v1, v4, v0
aget-byte v6, v7, v0
xor-int/2addr v1, v6
int-to-byte v1, v1
aput-byte v1, v4, v0
.line 169
add-int/lit8 v0, v0, -0x1
goto :goto_79
.line 175
:cond_86
invoke-static {v4, v8}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->concatenate([B[B)[B
move-result-object v4
.line 180
new-array v0, v10, [B
.line 181
if-lez v5, :cond_93
.line 183
new-array v0, v5, [B
.line 184
invoke-static {v4, v10, v0, v10, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
:cond_93
move-object v1, v0
.line 187
new-array v0, v3, [B
.line 188
invoke-static {v4, v5, v0, v10, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 190
new-array v6, v2, [B
.line 191
add-int/2addr v3, v5
invoke-static {v4, v3, v6, v10, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 194
iget v2, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->k:I
invoke-static {v2, v6}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;->OS2VP(I[B)Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;
move-result-object v2
.line 197
iget v3, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->n:I
iget v4, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->t:I
invoke-static {v3, v4, v0}, Lorg/spongycastle/pqc/crypto/mceliece/Conversions;->encode(II[B)Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;
move-result-object v3
.line 200
iget-object v0, p0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceKobaraImaiCipher;->key:Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2KeyParameters;
check-cast v0, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;
invoke-static {v0, v2, v3}, Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2Primitives;->encryptionPrimitive(Lorg/spongycastle/pqc/crypto/mceliece/McElieceCCA2PublicKeyParameters;Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;)Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;
move-result-object v0
.line 201
invoke-virtual {v0}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Vector;->getEncoded()[B
move-result-object v0
.line 204
if-lez v5, :cond_bf
.line 207
invoke-static {v1, v0}, Lorg/spongycastle/pqc/math/linearalgebra/ByteUtils;->concatenate([B[B)[B
move-result-object v0
.line 210
:cond_bf
return-object v0
.end method