TlsMac.smali
.class public Lorg/spongycastle/crypto/tls/TlsMac;
.super Ljava/lang/Object;
.source "TlsMac.java"
# instance fields
.field protected context:Lorg/spongycastle/crypto/tls/TlsContext;
.field protected digestBlockSize:I
.field protected digestOverhead:I
.field protected mac:Lorg/spongycastle/crypto/Mac;
.field protected macLength:I
.field protected secret:[B
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/tls/TlsContext;Lorg/spongycastle/crypto/Digest;[BII)V
.registers 9
.prologue
.line 32
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 33
iput-object p1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->context:Lorg/spongycastle/crypto/tls/TlsContext;
.line 35
new-instance v0, Lorg/spongycastle/crypto/params/KeyParameter;
invoke-direct {v0, p3, p4, p5}, Lorg/spongycastle/crypto/params/KeyParameter;-><init>([BII)V
.line 37
invoke-virtual {v0}, Lorg/spongycastle/crypto/params/KeyParameter;->getKey()[B
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v1
iput-object v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->secret:[B
.line 40
instance-of v1, p2, Lorg/spongycastle/crypto/digests/LongDigest;
if-eqz v1, :cond_58
.line 42
const/16 v1, 0x80
iput v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->digestBlockSize:I
.line 43
const/16 v1, 0x10
iput v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->digestOverhead:I
.line 51
:goto_20
invoke-static {p1}, Lorg/spongycastle/crypto/tls/TlsUtils;->isSSL(Lorg/spongycastle/crypto/tls/TlsContext;)Z
move-result v1
if-eqz v1, :cond_61
.line 53
new-instance v1, Lorg/spongycastle/crypto/tls/SSL3Mac;
invoke-direct {v1, p2}, Lorg/spongycastle/crypto/tls/SSL3Mac;-><init>(Lorg/spongycastle/crypto/Digest;)V
iput-object v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
.line 56
invoke-interface {p2}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v1
const/16 v2, 0x14
if-ne v1, v2, :cond_38
.line 62
const/4 v1, 0x4
iput v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->digestOverhead:I
.line 72
:cond_38
:goto_38
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v1, v0}, Lorg/spongycastle/crypto/Mac;->init(Lorg/spongycastle/crypto/CipherParameters;)V
.line 74
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0}, Lorg/spongycastle/crypto/Mac;->getMacSize()I
move-result v0
iput v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->macLength:I
.line 75
invoke-interface {p1}, Lorg/spongycastle/crypto/tls/TlsContext;->getSecurityParameters()Lorg/spongycastle/crypto/tls/SecurityParameters;
move-result-object v0
iget-boolean v0, v0, Lorg/spongycastle/crypto/tls/SecurityParameters;->truncatedHMac:Z
if-eqz v0, :cond_57
.line 77
iget v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->macLength:I
const/16 v1, 0xa
invoke-static {v0, v1}, Ljava/lang/Math;->min(II)I
move-result v0
iput v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->macLength:I
.line 79
:cond_57
return-void
.line 47
:cond_58
const/16 v1, 0x40
iput v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->digestBlockSize:I
.line 48
const/16 v1, 0x8
iput v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->digestOverhead:I
goto :goto_20
.line 67
:cond_61
new-instance v1, Lorg/spongycastle/crypto/macs/HMac;
invoke-direct {v1, p2}, Lorg/spongycastle/crypto/macs/HMac;-><init>(Lorg/spongycastle/crypto/Digest;)V
iput-object v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
goto :goto_38
.end method
# virtual methods
.method public calculateMac(JS[BII)[B
.registers 12
.prologue
const/4 v4, 0x0
.line 108
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->context:Lorg/spongycastle/crypto/tls/TlsContext;
invoke-interface {v0}, Lorg/spongycastle/crypto/tls/TlsContext;->getServerVersion()Lorg/spongycastle/crypto/tls/ProtocolVersion;
move-result-object v1
.line 109
invoke-virtual {v1}, Lorg/spongycastle/crypto/tls/ProtocolVersion;->isSSL()Z
move-result v2
.line 111
if-eqz v2, :cond_43
const/16 v0, 0xb
:goto_f
new-array v0, v0, [B
.line 112
invoke-static {p1, p2, v0, v4}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint64(J[BI)V
.line 113
const/16 v3, 0x8
invoke-static {p3, v0, v3}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint8(S[BI)V
.line 114
if-nez v2, :cond_20
.line 116
const/16 v2, 0x9
invoke-static {v1, v0, v2}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeVersion(Lorg/spongycastle/crypto/tls/ProtocolVersion;[BI)V
.line 118
:cond_20
array-length v1, v0
add-int/lit8 v1, v1, -0x2
invoke-static {p6, v0, v1}, Lorg/spongycastle/crypto/tls/TlsUtils;->writeUint16(I[BI)V
.line 120
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
array-length v2, v0
invoke-interface {v1, v0, v4, v2}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 121
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0, p4, p5, p6}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 123
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0}, Lorg/spongycastle/crypto/Mac;->getMacSize()I
move-result v0
new-array v0, v0, [B
.line 124
iget-object v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v1, v0, v4}, Lorg/spongycastle/crypto/Mac;->doFinal([BI)I
.line 125
invoke-virtual {p0, v0}, Lorg/spongycastle/crypto/tls/TlsMac;->truncate([B)[B
move-result-object v0
return-object v0
.line 111
:cond_43
const/16 v0, 0xd
goto :goto_f
.end method
.method public calculateMacConstantTime(JS[BIII[B)[B
.registers 14
.prologue
const/4 v4, 0x0
.line 134
invoke-virtual/range {p0 .. p6}, Lorg/spongycastle/crypto/tls/TlsMac;->calculateMac(JS[BII)[B
move-result-object v1
.line 140
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->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_28
const/16 v0, 0xb
.line 143
:goto_f
add-int v2, v0, p7
invoke-virtual {p0, v2}, Lorg/spongycastle/crypto/tls/TlsMac;->getDigestBlockCount(I)I
move-result v2
add-int/2addr v0, p6
invoke-virtual {p0, v0}, Lorg/spongycastle/crypto/tls/TlsMac;->getDigestBlockCount(I)I
move-result v0
sub-int v0, v2, v0
.line 145
:goto_1c
add-int/lit8 v0, v0, -0x1
if-ltz v0, :cond_2b
.line 147
iget-object v2, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
iget v3, p0, Lorg/spongycastle/crypto/tls/TlsMac;->digestBlockSize:I
invoke-interface {v2, p8, v4, v3}, Lorg/spongycastle/crypto/Mac;->update([BII)V
goto :goto_1c
.line 140
:cond_28
const/16 v0, 0xd
goto :goto_f
.line 151
:cond_2b
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
aget-byte v2, p8, v4
invoke-interface {v0, v2}, Lorg/spongycastle/crypto/Mac;->update(B)V
.line 152
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0}, Lorg/spongycastle/crypto/Mac;->reset()V
.line 154
return-object v1
.end method
.method protected getDigestBlockCount(I)I
.registers 4
.prologue
.line 160
iget v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->digestOverhead:I
add-int/2addr v0, p1
iget v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->digestBlockSize:I
div-int/2addr v0, v1
return v0
.end method
.method public getMACSecret()[B
.registers 2
.prologue
.line 86
iget-object v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->secret:[B
return-object v0
.end method
.method public getSize()I
.registers 2
.prologue
.line 94
iget v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->macLength:I
return v0
.end method
.method protected truncate([B)[B
.registers 4
.prologue
.line 165
array-length v0, p1
iget v1, p0, Lorg/spongycastle/crypto/tls/TlsMac;->macLength:I
if-gt v0, v1, :cond_6
.line 170
:goto_5
return-object p1
:cond_6
iget v0, p0, Lorg/spongycastle/crypto/tls/TlsMac;->macLength:I
invoke-static {p1, v0}, Lorg/spongycastle/util/Arrays;->copyOf([BI)[B
move-result-object p1
goto :goto_5
.end method