TlsBlockCipher.smali
.class public Lorg/spongycastle/crypto/tls/TlsBlockCipher;
.super Ljava/lang/Object;
.source "TlsBlockCipher.java"
# interfaces
.implements Lorg/spongycastle/crypto/tls/TlsCipher;
# instance fields
.field protected context:Lorg/spongycastle/crypto/tls/TlsContext;
.field protected decryptCipher:Lorg/spongycastle/crypto/BlockCipher;
.field protected encryptCipher:Lorg/spongycastle/crypto/BlockCipher;
.field protected encryptThenMAC:Z
.field protected randomData:[B
.field protected readMac:Lorg/spongycastle/crypto/tls/TlsMac;
.field protected useExplicitIV:Z
.field protected writeMac:Lorg/spongycastle/crypto/tls/TlsMac;
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/tls/TlsContext;Lorg/spongycastle/crypto/BlockCipher;Lorg/spongycastle/crypto/BlockCipher;Lorg/spongycastle/crypto/Digest;Lorg/spongycastle/crypto/Digest;I)V
.registers 20
.prologue
.line 42
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 43
iput-object p1, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->context:Lorg/spongycastle/crypto/tls/TlsContext;
.line 45
const/16 v1, 0x100
new-array v1, v1, [B
iput-object v1, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->randomData:[B
.line 46
invoke-interface {p1}, Lorg/spongycastle/crypto/tls/TlsContext;->getNonceRandomGenerator()Lorg/spongycastle/crypto/prng/RandomGenerator;
move-result-object v1
iget-object v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->randomData:[B
invoke-interface {v1, v2}, Lorg/spongycastle/crypto/prng/RandomGenerator;->nextBytes([B)V
.line 48
invoke-static {p1}, Lorg/spongycastle/crypto/tls/TlsUtils;->isTLSv11(Lorg/spongycastle/crypto/tls/TlsContext;)Z
move-result v1
iput-boolean v1, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->useExplicitIV:Z
.line 49
invoke-interface {p1}, Lorg/spongycastle/crypto/tls/TlsContext;->getSecurityParameters()Lorg/spongycastle/crypto/tls/SecurityParameters;
move-result-object v1
iget-boolean v1, v1, Lorg/spongycastle/crypto/tls/SecurityParameters;->encryptThenMAC:Z
iput-boolean v1, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
.line 51
mul-int/lit8 v1, p6, 0x2
invoke-interface/range {p4 .. p4}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v2
add-int/2addr v1, v2
.line 52
invoke-interface/range {p5 .. p5}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v2
add-int/2addr v1, v2
.line 55
iget-boolean v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->useExplicitIV:Z
if-nez v2, :cond_f2
.line 57
invoke-interface {p2}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v2
invoke-interface/range {p3 .. p3}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v3
add-int/2addr v2, v3
add-int/2addr v1, v2
move v11, v1
.line 60
:goto_3d
invoke-static {p1, v11}, Lorg/spongycastle/crypto/tls/TlsUtils;->calculateKeyBlock(Lorg/spongycastle/crypto/tls/TlsContext;I)[B
move-result-object v4
.line 64
new-instance v1, Lorg/spongycastle/crypto/tls/TlsMac;
const/4 v5, 0x0
.line 65
invoke-interface/range {p4 .. p4}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v6
move-object v2, p1
move-object/from16 v3, p4
invoke-direct/range {v1 .. v6}, Lorg/spongycastle/crypto/tls/TlsMac;-><init>(Lorg/spongycastle/crypto/tls/TlsContext;Lorg/spongycastle/crypto/Digest;[BII)V
.line 66
invoke-interface/range {p4 .. p4}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v2
add-int/lit8 v9, v2, 0x0
.line 67
new-instance v5, Lorg/spongycastle/crypto/tls/TlsMac;
.line 68
invoke-interface/range {p5 .. p5}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v10
move-object v6, p1
move-object/from16 v7, p5
move-object v8, v4
invoke-direct/range {v5 .. v10}, Lorg/spongycastle/crypto/tls/TlsMac;-><init>(Lorg/spongycastle/crypto/tls/TlsContext;Lorg/spongycastle/crypto/Digest;[BII)V
.line 69
invoke-interface/range {p5 .. p5}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v2
add-int/2addr v2, v9
.line 71
new-instance v7, Lorg/spongycastle/crypto/params/KeyParameter;
move/from16 v0, p6
invoke-direct {v7, v4, v2, v0}, Lorg/spongycastle/crypto/params/KeyParameter;-><init>([BII)V
.line 72
add-int v2, v2, p6
.line 73
new-instance v8, Lorg/spongycastle/crypto/params/KeyParameter;
move/from16 v0, p6
invoke-direct {v8, v4, v2, v0}, Lorg/spongycastle/crypto/params/KeyParameter;-><init>([BII)V
.line 74
add-int v6, v2, p6
.line 77
iget-boolean v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->useExplicitIV:Z
if-eqz v2, :cond_95
.line 79
invoke-interface {p2}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v2
new-array v3, v2, [B
.line 80
invoke-interface/range {p3 .. p3}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v2
new-array v2, v2, [B
move-object v4, v3
move-object v3, v2
move v2, v6
.line 90
:goto_8b
if-eq v2, v11, :cond_b6
.line 92
new-instance v1, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v2, 0x50
invoke-direct {v1, v2}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v1
.line 84
:cond_95
invoke-interface {p2}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v2
add-int/2addr v2, v6
invoke-static {v4, v6, v2}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v3
.line 85
invoke-interface {p2}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v2
add-int/2addr v6, v2
.line 86
invoke-interface/range {p3 .. p3}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v2
add-int/2addr v2, v6
invoke-static {v4, v6, v2}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v2
.line 87
invoke-interface/range {p3 .. p3}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v4
add-int/2addr v4, v6
move-object v12, v2
move v2, v4
move-object v4, v3
move-object v3, v12
goto :goto_8b
.line 96
:cond_b6
invoke-interface {p1}, Lorg/spongycastle/crypto/tls/TlsContext;->isServer()Z
move-result v2
if-eqz v2, :cond_dd
.line 98
iput-object v5, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->writeMac:Lorg/spongycastle/crypto/tls/TlsMac;
.line 99
iput-object v1, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->readMac:Lorg/spongycastle/crypto/tls/TlsMac;
.line 100
move-object/from16 v0, p3
iput-object v0, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptCipher:Lorg/spongycastle/crypto/BlockCipher;
.line 101
iput-object p2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->decryptCipher:Lorg/spongycastle/crypto/BlockCipher;
.line 102
new-instance v2, Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-direct {v2, v8, v3}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
.line 103
new-instance v1, Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-direct {v1, v7, v4}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
.line 115
:goto_d0
iget-object v3, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptCipher:Lorg/spongycastle/crypto/BlockCipher;
const/4 v4, 0x1
invoke-interface {v3, v4, v2}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 116
iget-object v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->decryptCipher:Lorg/spongycastle/crypto/BlockCipher;
const/4 v3, 0x0
invoke-interface {v2, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 117
return-void
.line 107
:cond_dd
iput-object v1, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->writeMac:Lorg/spongycastle/crypto/tls/TlsMac;
.line 108
iput-object v5, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->readMac:Lorg/spongycastle/crypto/tls/TlsMac;
.line 109
iput-object p2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptCipher:Lorg/spongycastle/crypto/BlockCipher;
.line 110
move-object/from16 v0, p3
iput-object v0, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->decryptCipher:Lorg/spongycastle/crypto/BlockCipher;
.line 111
new-instance v2, Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-direct {v2, v7, v4}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
.line 112
new-instance v1, Lorg/spongycastle/crypto/params/ParametersWithIV;
invoke-direct {v1, v8, v3}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
goto :goto_d0
:cond_f2
move v11, v1
goto/16 :goto_3d
.end method
# virtual methods
.method protected checkPaddingConstantTime([BIIII)I
.registers 13
.prologue
const/4 v1, 0x0
.line 327
add-int v5, p2, p3
.line 328
add-int/lit8 v0, v5, -0x1
aget-byte v6, p1, v0
.line 329
and-int/lit16 v0, v6, 0xff
.line 330
add-int/lit8 v4, v0, 0x1
.line 335
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->context:Lorg/spongycastle/crypto/tls/TlsContext;
invoke-static {v0}, Lorg/spongycastle/crypto/tls/TlsUtils;->isSSL(Lorg/spongycastle/crypto/tls/TlsContext;)Z
move-result v0
if-eqz v0, :cond_15
if-gt v4, p4, :cond_19
:cond_15
add-int v0, p5, v4
if-le v0, p3, :cond_2b
:cond_19
move v0, v1
move v2, v1
move v4, v1
.line 358
:goto_1c
iget-object v5, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->randomData:[B
.line 359
:goto_1e
const/16 v3, 0x100
if-ge v2, v3, :cond_3d
.line 361
add-int/lit8 v3, v2, 0x1
aget-byte v2, v5, v2
xor-int/2addr v2, v6
or-int/2addr v0, v2
int-to-byte v0, v0
move v2, v3
goto :goto_1e
.line 341
:cond_2b
sub-int v0, v5, v4
move v2, v0
move v0, v1
.line 344
:goto_2f
add-int/lit8 v3, v2, 0x1
aget-byte v2, p1, v2
xor-int/2addr v2, v6
or-int/2addr v0, v2
int-to-byte v0, v0
.line 346
if-lt v3, v5, :cond_46
.line 350
if-eqz v0, :cond_44
move v2, v4
move v4, v1
.line 352
goto :goto_1c
.line 364
:cond_3d
aget-byte v2, v5, v1
xor-int/2addr v0, v2
int-to-byte v0, v0
aput-byte v0, v5, v1
.line 367
return v4
:cond_44
move v2, v4
goto :goto_1c
:cond_46
move v2, v3
goto :goto_2f
.end method
.method protected chooseExtraPadBlocks(Ljava/security/SecureRandom;I)I
.registers 4
.prologue
.line 374
invoke-virtual {p1}, Ljava/security/SecureRandom;->nextInt()I
move-result v0
.line 375
invoke-virtual {p0, v0}, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->lowestBitSet(I)I
move-result v0
.line 376
invoke-static {v0, p2}, Ljava/lang/Math;->min(II)I
move-result v0
return v0
.end method
.method public decodeCiphertext(JS[BII)[B
.registers 22
.prologue
.line 231
iget-object v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->decryptCipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v2}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v11
.line 232
iget-object v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->readMac:Lorg/spongycastle/crypto/tls/TlsMac;
invoke-virtual {v2}, Lorg/spongycastle/crypto/tls/TlsMac;->getSize()I
move-result v10
.line 235
iget-boolean v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-eqz v2, :cond_23
.line 237
add-int v2, v11, v10
.line 244
:goto_12
iget-boolean v3, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->useExplicitIV:Z
if-eqz v3, :cond_17
.line 246
add-int/2addr v2, v11
.line 249
:cond_17
move/from16 v0, p6
if-ge v0, v2, :cond_2a
.line 251
new-instance v2, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v3, 0x32
invoke-direct {v2, v3}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v2
.line 241
:cond_23
add-int/lit8 v2, v10, 0x1
invoke-static {v11, v2}, Ljava/lang/Math;->max(II)I
move-result v2
goto :goto_12
.line 255
:cond_2a
iget-boolean v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-eqz v2, :cond_ef
.line 257
sub-int v2, p6, v10
.line 260
:goto_30
rem-int v3, v2, v11
if-eqz v3, :cond_3c
.line 262
new-instance v2, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v3, 0x15
invoke-direct {v2, v3}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v2
.line 265
:cond_3c
iget-boolean v3, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-eqz v3, :cond_6d
.line 267
add-int v3, p5, p6
.line 268
sub-int v4, v3, v10
move-object/from16 v0, p4
invoke-static {v0, v4, v3}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v12
.line 269
iget-object v3, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->readMac:Lorg/spongycastle/crypto/tls/TlsMac;
sub-int v9, p6, v10
move-wide/from16 v4, p1
move/from16 v6, p3
move-object/from16 v7, p4
move/from16 v8, p5
invoke-virtual/range {v3 .. v9}, Lorg/spongycastle/crypto/tls/TlsMac;->calculateMac(JS[BII)[B
move-result-object v3
.line 271
invoke-static {v3, v12}, Lorg/spongycastle/util/Arrays;->constantTimeAreEqual([B[B)Z
move-result v3
if-nez v3, :cond_6b
const/4 v3, 0x1
.line 272
:goto_61
if-eqz v3, :cond_6d
.line 282
new-instance v2, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v3, 0x14
invoke-direct {v2, v3}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v2
.line 271
:cond_6b
const/4 v3, 0x0
goto :goto_61
.line 286
:cond_6d
iget-boolean v3, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->useExplicitIV:Z
if-eqz v3, :cond_eb
.line 288
iget-object v3, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->decryptCipher:Lorg/spongycastle/crypto/BlockCipher;
const/4 v4, 0x0
new-instance v5, Lorg/spongycastle/crypto/params/ParametersWithIV;
const/4 v6, 0x0
move-object/from16 v0, p4
move/from16 v1, p5
invoke-direct {v5, v6, v0, v1, v11}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[BII)V
invoke-interface {v3, v4, v5}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 290
add-int v4, p5, v11
.line 291
sub-int v5, v2, v11
.line 294
:goto_85
const/4 v2, 0x0
:goto_86
if-ge v2, v5, :cond_97
.line 296
iget-object v3, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->decryptCipher:Lorg/spongycastle/crypto/BlockCipher;
add-int v6, v4, v2
add-int v7, v4, v2
move-object/from16 v0, p4
move-object/from16 v1, p4
invoke-interface {v3, v0, v6, v1, v7}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
.line 294
add-int/2addr v2, v11
goto :goto_86
.line 300
:cond_97
iget-boolean v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-eqz v2, :cond_dc
const/4 v7, 0x0
:goto_9c
move-object v2, p0
move-object/from16 v3, p4
move v6, v11
invoke-virtual/range {v2 .. v7}, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->checkPaddingConstantTime([BIIII)I
move-result v3
.line 301
if-nez v3, :cond_de
const/4 v2, 0x1
.line 303
:goto_a7
sub-int v11, v5, v3
.line 305
iget-boolean v3, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-nez v3, :cond_d2
.line 307
sub-int/2addr v11, v10
.line 309
add-int v3, v4, v11
.line 310
add-int v6, v3, v10
move-object/from16 v0, p4
invoke-static {v0, v3, v6}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v3
.line 311
iget-object v6, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->readMac:Lorg/spongycastle/crypto/tls/TlsMac;
sub-int v12, v5, v10
iget-object v13, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->randomData:[B
move-object v5, v6
move-wide/from16 v6, p1
move/from16 v8, p3
move-object/from16 v9, p4
move v10, v4
invoke-virtual/range {v5 .. v13}, Lorg/spongycastle/crypto/tls/TlsMac;->calculateMacConstantTime(JS[BIII[B)[B
move-result-object v5
.line 314
invoke-static {v5, v3}, Lorg/spongycastle/util/Arrays;->constantTimeAreEqual([B[B)Z
move-result v3
if-nez v3, :cond_e0
const/4 v3, 0x1
:goto_d1
or-int/2addr v2, v3
.line 317
:cond_d2
if-eqz v2, :cond_e2
.line 319
new-instance v2, Lorg/spongycastle/crypto/tls/TlsFatalAlert;
const/16 v3, 0x14
invoke-direct {v2, v3}, Lorg/spongycastle/crypto/tls/TlsFatalAlert;-><init>(S)V
throw v2
:cond_dc
move v7, v10
.line 300
goto :goto_9c
.line 301
:cond_de
const/4 v2, 0x0
goto :goto_a7
.line 314
:cond_e0
const/4 v3, 0x0
goto :goto_d1
.line 322
:cond_e2
add-int v2, v4, v11
move-object/from16 v0, p4
invoke-static {v0, v4, v2}, Lorg/spongycastle/util/Arrays;->copyOfRange([BII)[B
move-result-object v2
return-object v2
:cond_eb
move v5, v2
move/from16 v4, p5
goto :goto_85
:cond_ef
move/from16 v2, p6
goto/16 :goto_30
.end method
.method public encodePlaintext(JS[BII)[B
.registers 24
.prologue
.line 152
move-object/from16 v0, p0
iget-object v4, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptCipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v4}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v13
.line 153
move-object/from16 v0, p0
iget-object v4, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->writeMac:Lorg/spongycastle/crypto/tls/TlsMac;
invoke-virtual {v4}, Lorg/spongycastle/crypto/tls/TlsMac;->getSize()I
move-result v5
.line 155
move-object/from16 v0, p0
iget-object v4, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->context:Lorg/spongycastle/crypto/tls/TlsContext;
invoke-interface {v4}, Lorg/spongycastle/crypto/tls/TlsContext;->getServerVersion()Lorg/spongycastle/crypto/tls/ProtocolVersion;
move-result-object v6
.line 158
move-object/from16 v0, p0
iget-boolean v4, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-nez v4, :cond_da
.line 160
add-int v4, p6, v5
.line 163
:goto_20
add-int/lit8 v7, v13, -0x1
rem-int/2addr v4, v13
sub-int v4, v7, v4
.line 166
invoke-virtual {v6}, Lorg/spongycastle/crypto/tls/ProtocolVersion;->isDTLS()Z
move-result v7
if-nez v7, :cond_44
invoke-virtual {v6}, Lorg/spongycastle/crypto/tls/ProtocolVersion;->isSSL()Z
move-result v6
if-nez v6, :cond_44
.line 169
rsub-int v6, v4, 0xff
div-int/2addr v6, v13
.line 170
move-object/from16 v0, p0
iget-object v7, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->context:Lorg/spongycastle/crypto/tls/TlsContext;
invoke-interface {v7}, Lorg/spongycastle/crypto/tls/TlsContext;->getSecureRandom()Ljava/security/SecureRandom;
move-result-object v7
move-object/from16 v0, p0
invoke-virtual {v0, v7, v6}, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->chooseExtraPadBlocks(Ljava/security/SecureRandom;I)I
move-result v6
.line 171
mul-int/2addr v6, v13
add-int/2addr v4, v6
.line 174
:cond_44
add-int v5, v5, p6
add-int/2addr v5, v4
add-int/lit8 v5, v5, 0x1
.line 175
move-object/from16 v0, p0
iget-boolean v6, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->useExplicitIV:Z
if-eqz v6, :cond_50
.line 177
add-int/2addr v5, v13
.line 180
:cond_50
new-array v15, v5, [B
.line 181
const/4 v5, 0x0
.line 183
move-object/from16 v0, p0
iget-boolean v6, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->useExplicitIV:Z
if-eqz v6, :cond_d8
.line 185
new-array v5, v13, [B
.line 186
move-object/from16 v0, p0
iget-object v6, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->context:Lorg/spongycastle/crypto/tls/TlsContext;
invoke-interface {v6}, Lorg/spongycastle/crypto/tls/TlsContext;->getNonceRandomGenerator()Lorg/spongycastle/crypto/prng/RandomGenerator;
move-result-object v6
invoke-interface {v6, v5}, Lorg/spongycastle/crypto/prng/RandomGenerator;->nextBytes([B)V
.line 188
move-object/from16 v0, p0
iget-object v6, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptCipher:Lorg/spongycastle/crypto/BlockCipher;
const/4 v7, 0x1
new-instance v8, Lorg/spongycastle/crypto/params/ParametersWithIV;
const/4 v9, 0x0
invoke-direct {v8, v9, v5}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
invoke-interface {v6, v7, v8}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 190
const/4 v6, 0x0
const/4 v7, 0x0
invoke-static {v5, v6, v15, v7, v13}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
move v12, v13
.line 196
:goto_7a
move-object/from16 v0, p4
move/from16 v1, p5
move/from16 v2, p6
invoke-static {v0, v1, v15, v12, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 197
add-int v14, v12, p6
.line 199
move-object/from16 v0, p0
iget-boolean v5, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-nez v5, :cond_d6
.line 201
move-object/from16 v0, p0
iget-object v5, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->writeMac:Lorg/spongycastle/crypto/tls/TlsMac;
move-wide/from16 v6, p1
move/from16 v8, p3
move-object/from16 v9, p4
move/from16 v10, p5
move/from16 v11, p6
invoke-virtual/range {v5 .. v11}, Lorg/spongycastle/crypto/tls/TlsMac;->calculateMac(JS[BII)[B
move-result-object v5
.line 202
const/4 v6, 0x0
array-length v7, v5
invoke-static {v5, v6, v15, v14, v7}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 203
array-length v5, v5
add-int/2addr v5, v14
.line 206
:goto_a4
const/4 v6, 0x0
move v11, v5
:goto_a6
if-gt v6, v4, :cond_b1
.line 208
add-int/lit8 v5, v11, 0x1
int-to-byte v7, v4
aput-byte v7, v15, v11
.line 206
add-int/lit8 v6, v6, 0x1
move v11, v5
goto :goto_a6
.line 211
:cond_b1
:goto_b1
if-ge v12, v11, :cond_bc
.line 213
move-object/from16 v0, p0
iget-object v4, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptCipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v4, v15, v12, v15, v12}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
.line 211
add-int/2addr v12, v13
goto :goto_b1
.line 216
:cond_bc
move-object/from16 v0, p0
iget-boolean v4, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-eqz v4, :cond_d5
.line 218
move-object/from16 v0, p0
iget-object v5, v0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->writeMac:Lorg/spongycastle/crypto/tls/TlsMac;
const/4 v10, 0x0
move-wide/from16 v6, p1
move/from16 v8, p3
move-object v9, v15
invoke-virtual/range {v5 .. v11}, Lorg/spongycastle/crypto/tls/TlsMac;->calculateMac(JS[BII)[B
move-result-object v4
.line 219
const/4 v5, 0x0
array-length v6, v4
invoke-static {v4, v5, v15, v11, v6}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 225
:cond_d5
return-object v15
:cond_d6
move v5, v14
goto :goto_a4
:cond_d8
move v12, v5
goto :goto_7a
:cond_da
move/from16 v4, p6
goto/16 :goto_20
.end method
.method public getPlaintextLimit(I)I
.registers 5
.prologue
.line 121
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptCipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v0}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v0
.line 122
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->writeMac:Lorg/spongycastle/crypto/tls/TlsMac;
invoke-virtual {v1}, Lorg/spongycastle/crypto/tls/TlsMac;->getSize()I
move-result v1
.line 127
iget-boolean v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->useExplicitIV:Z
if-eqz v2, :cond_11
.line 129
sub-int/2addr p1, v0
.line 133
:cond_11
iget-boolean v2, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->encryptThenMAC:Z
if-eqz v2, :cond_1e
.line 135
sub-int v1, p1, v1
.line 136
rem-int v0, v1, v0
sub-int v0, v1, v0
.line 145
:goto_1b
add-int/lit8 v0, v0, -0x1
.line 147
return v0
.line 140
:cond_1e
rem-int v0, p1, v0
sub-int v0, p1, v0
.line 141
sub-int/2addr v0, v1
goto :goto_1b
.end method
.method public getReadMac()Lorg/spongycastle/crypto/tls/TlsMac;
.registers 2
.prologue
.line 37
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->readMac:Lorg/spongycastle/crypto/tls/TlsMac;
return-object v0
.end method
.method public getWriteMac()Lorg/spongycastle/crypto/tls/TlsMac;
.registers 2
.prologue
.line 32
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsBlockCipher;->writeMac:Lorg/spongycastle/crypto/tls/TlsMac;
return-object v0
.end method
.method protected lowestBitSet(I)I
.registers 4
.prologue
.line 381
if-nez p1, :cond_5
.line 383
const/16 v0, 0x20
.line 392
:cond_4
return v0
.line 386
:cond_5
const/4 v0, 0x0
.line 387
:goto_6
and-int/lit8 v1, p1, 0x1
if-nez v1, :cond_4
.line 389
add-int/lit8 v0, v0, 0x1
.line 390
shr-int/lit8 p1, p1, 0x1
goto :goto_6
.end method