EAXBlockCipher.smali
.class public Lorg/spongycastle/crypto/modes/EAXBlockCipher;
.super Ljava/lang/Object;
.source "EAXBlockCipher.java"
# interfaces
.implements Lorg/spongycastle/crypto/modes/AEADBlockCipher;
# static fields
.field private static final cTAG:B = 0x2t
.field private static final hTAG:B = 0x1t
.field private static final nTAG:B
# instance fields
.field private associatedTextMac:[B
.field private blockSize:I
.field private bufBlock:[B
.field private bufOff:I
.field private cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
.field private cipherInitialized:Z
.field private forEncryption:Z
.field private initialAssociatedText:[B
.field private mac:Lorg/spongycastle/crypto/Mac;
.field private macBlock:[B
.field private macSize:I
.field private nonceMac:[B
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/BlockCipher;)V
.registers 3
.prologue
.line 61
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 62
invoke-interface {p1}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v0
iput v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
.line 63
new-instance v0, Lorg/spongycastle/crypto/macs/CMac;
invoke-direct {v0, p1}, Lorg/spongycastle/crypto/macs/CMac;-><init>(Lorg/spongycastle/crypto/BlockCipher;)V
iput-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
.line 64
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macBlock:[B
.line 65
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0}, Lorg/spongycastle/crypto/Mac;->getMacSize()I
move-result v0
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->associatedTextMac:[B
.line 66
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0}, Lorg/spongycastle/crypto/Mac;->getMacSize()I
move-result v0
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->nonceMac:[B
.line 67
new-instance v0, Lorg/spongycastle/crypto/modes/SICBlockCipher;
invoke-direct {v0, p1}, Lorg/spongycastle/crypto/modes/SICBlockCipher;-><init>(Lorg/spongycastle/crypto/BlockCipher;)V
iput-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
.line 68
return-void
.end method
.method private calculateMac()V
.registers 6
.prologue
const/4 v0, 0x0
.line 152
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
new-array v1, v1, [B
.line 153
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v2, v1, v0}, Lorg/spongycastle/crypto/Mac;->doFinal([BI)I
.line 155
:goto_a
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macBlock:[B
array-length v2, v2
if-ge v0, v2, :cond_23
.line 157
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macBlock:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->nonceMac:[B
aget-byte v3, v3, v0
iget-object v4, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->associatedTextMac:[B
aget-byte v4, v4, v0
xor-int/2addr v3, v4
aget-byte v4, v1, v0
xor-int/2addr v3, v4
int-to-byte v3, v3
aput-byte v3, v2, v0
.line 155
add-int/lit8 v0, v0, 0x1
goto :goto_a
.line 159
:cond_23
return-void
.end method
.method private initCipher()V
.registers 5
.prologue
const/4 v3, 0x0
.line 136
iget-boolean v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipherInitialized:Z
if-eqz v0, :cond_6
.line 148
:goto_5
return-void
.line 141
:cond_6
const/4 v0, 0x1
iput-boolean v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipherInitialized:Z
.line 143
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->associatedTextMac:[B
invoke-interface {v0, v1, v3}, Lorg/spongycastle/crypto/Mac;->doFinal([BI)I
.line 145
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
new-array v0, v0, [B
.line 146
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
add-int/lit8 v1, v1, -0x1
const/4 v2, 0x2
aput-byte v2, v0, v1
.line 147
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
invoke-interface {v1, v0, v3, v2}, Lorg/spongycastle/crypto/Mac;->update([BII)V
goto :goto_5
.end method
.method private process(B[BI)I
.registers 10
.prologue
const/4 v1, 0x0
.line 337
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
add-int/lit8 v3, v2, 0x1
iput v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
aput-byte p1, v0, v2
.line 339
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
array-length v2, v2
if-ne v0, v2, :cond_5b
.line 341
array-length v0, p2
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
add-int/2addr v2, p3
if-ge v0, v2, :cond_20
.line 343
new-instance v0, Lorg/spongycastle/crypto/OutputLengthException;
const-string v1, "Output buffer is too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/OutputLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 350
:cond_20
iget-boolean v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->forEncryption:Z
if-eqz v0, :cond_49
.line 352
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
invoke-virtual {v0, v2, v1, p2, p3}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->processBlock([BI[BI)I
move-result v0
.line 354
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
iget v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
invoke-interface {v2, p2, p3, v3}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 363
:goto_33
iput v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
.line 364
iget-boolean v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->forEncryption:Z
if-nez v2, :cond_48
.line 366
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
iget-object v4, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
iget v5, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
invoke-static {v2, v3, v4, v1, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 367
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
iput v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
.line 373
:cond_48
:goto_48
return v0
.line 358
:cond_49
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
invoke-interface {v0, v2, v1, v3}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 360
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
invoke-virtual {v0, v2, v1, p2, p3}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->processBlock([BI[BI)I
move-result v0
goto :goto_33
:cond_5b
move v0, v1
.line 373
goto :goto_48
.end method
.method private reset(Z)V
.registers 6
.prologue
const/4 v3, 0x0
.line 169
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
invoke-virtual {v0}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->reset()V
.line 170
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0}, Lorg/spongycastle/crypto/Mac;->reset()V
.line 172
iput v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
.line 173
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
invoke-static {v0, v3}, Lorg/spongycastle/util/Arrays;->fill([BB)V
.line 175
if-eqz p1, :cond_19
.line 177
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macBlock:[B
invoke-static {v0, v3}, Lorg/spongycastle/util/Arrays;->fill([BB)V
.line 180
:cond_19
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
new-array v0, v0, [B
.line 181
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
add-int/lit8 v1, v1, -0x1
const/4 v2, 0x1
aput-byte v2, v0, v1
.line 182
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
invoke-interface {v1, v0, v3, v2}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 184
iput-boolean v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipherInitialized:Z
.line 186
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->initialAssociatedText:[B
if-eqz v0, :cond_39
.line 188
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->initialAssociatedText:[B
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->initialAssociatedText:[B
array-length v1, v1
invoke-virtual {p0, v0, v3, v1}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->processAADBytes([BII)V
.line 190
:cond_39
return-void
.end method
.method private verifyMac([BI)Z
.registers 8
.prologue
const/4 v1, 0x0
.line 378
move v0, v1
move v2, v1
.line 380
:goto_3
iget v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
if-ge v0, v3, :cond_14
.line 382
iget-object v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macBlock:[B
aget-byte v3, v3, v0
add-int v4, p2, v0
aget-byte v4, p1, v4
xor-int/2addr v3, v4
or-int/2addr v2, v3
.line 380
add-int/lit8 v0, v0, 0x1
goto :goto_3
.line 385
:cond_14
if-nez v2, :cond_17
const/4 v1, 0x1
:cond_17
return v1
.end method
# virtual methods
.method public doFinal([BI)I
.registers 9
.prologue
const/4 v5, 0x0
.line 241
invoke-direct {p0}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->initCipher()V
.line 243
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
.line 244
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
array-length v1, v1
new-array v1, v1, [B
.line 246
iput v5, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
.line 248
iget-boolean v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->forEncryption:Z
if-eqz v2, :cond_43
.line 250
array-length v2, p1
add-int v3, p2, v0
iget v4, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
add-int/2addr v3, v4
if-ge v2, v3, :cond_21
.line 252
new-instance v0, Lorg/spongycastle/crypto/OutputLengthException;
const-string v1, "Output buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/OutputLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 254
:cond_21
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
iget-object v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
invoke-virtual {v2, v3, v5, v1, v5}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->processBlock([BI[BI)I
.line 256
invoke-static {v1, v5, p1, p2, v0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 258
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v2, v1, v5, v0}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 260
invoke-direct {p0}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->calculateMac()V
.line 262
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macBlock:[B
add-int v2, p2, v0
iget v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
invoke-static {v1, v5, p1, v2, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 264
invoke-direct {p0, v5}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->reset(Z)V
.line 266
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
add-int/2addr v0, v1
.line 296
:goto_42
return v0
.line 270
:cond_43
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
if-ge v0, v2, :cond_4f
.line 272
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "data too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 274
:cond_4f
array-length v2, p1
add-int v3, p2, v0
iget v4, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
sub-int/2addr v3, v4
if-ge v2, v3, :cond_5f
.line 276
new-instance v0, Lorg/spongycastle/crypto/OutputLengthException;
const-string v1, "Output buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/OutputLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 278
:cond_5f
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
if-le v0, v2, :cond_7c
.line 280
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
iget-object v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
iget v4, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
sub-int v4, v0, v4
invoke-interface {v2, v3, v5, v4}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 282
iget-object v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
iget-object v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
invoke-virtual {v2, v3, v5, v1, v5}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->processBlock([BI[BI)I
.line 284
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
sub-int v2, v0, v2
invoke-static {v1, v5, p1, p2, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 287
:cond_7c
invoke-direct {p0}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->calculateMac()V
.line 289
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
sub-int v2, v0, v2
invoke-direct {p0, v1, v2}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->verifyMac([BI)Z
move-result v1
if-nez v1, :cond_93
.line 291
new-instance v0, Lorg/spongycastle/crypto/InvalidCipherTextException;
const-string v1, "mac check in EAX failed"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/InvalidCipherTextException;-><init>(Ljava/lang/String;)V
throw v0
.line 294
:cond_93
invoke-direct {p0, v5}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->reset(Z)V
.line 296
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
sub-int/2addr v0, v1
goto :goto_42
.end method
.method public getAlgorithmName()Ljava/lang/String;
.registers 3
.prologue
.line 72
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
invoke-virtual {v1}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->getUnderlyingCipher()Lorg/spongycastle/crypto/BlockCipher;
move-result-object v1
invoke-interface {v1}, Lorg/spongycastle/crypto/BlockCipher;->getAlgorithmName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "/EAX"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getBlockSize()I
.registers 2
.prologue
.line 82
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
invoke-virtual {v0}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->getBlockSize()I
move-result v0
return v0
.end method
.method public getMac()[B
.registers 5
.prologue
const/4 v3, 0x0
.line 302
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
new-array v0, v0, [B
.line 304
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macBlock:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
invoke-static {v1, v3, v0, v3, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 306
return-object v0
.end method
.method public getOutputSize(I)I
.registers 4
.prologue
.line 325
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
add-int/2addr v0, p1
.line 327
iget-boolean v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->forEncryption:Z
if-eqz v1, :cond_b
.line 329
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
add-int/2addr v0, v1
.line 332
:goto_a
return v0
:cond_b
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
if-ge v0, v1, :cond_11
const/4 v0, 0x0
goto :goto_a
:cond_11
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
sub-int/2addr v0, v1
goto :goto_a
.end method
.method public getUnderlyingCipher()Lorg/spongycastle/crypto/BlockCipher;
.registers 2
.prologue
.line 77
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
invoke-virtual {v0}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->getUnderlyingCipher()Lorg/spongycastle/crypto/BlockCipher;
move-result-object v0
return-object v0
.end method
.method public getUpdateOutputSize(I)I
.registers 4
.prologue
.line 311
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufOff:I
add-int/2addr v0, p1
.line 312
iget-boolean v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->forEncryption:Z
if-nez v1, :cond_10
.line 314
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
if-ge v0, v1, :cond_d
.line 316
const/4 v0, 0x0
.line 320
:goto_c
return v0
.line 318
:cond_d
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
sub-int/2addr v0, v1
.line 320
:cond_10
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
rem-int v1, v0, v1
sub-int/2addr v0, v1
goto :goto_c
.end method
.method public init(ZLorg/spongycastle/crypto/CipherParameters;)V
.registers 9
.prologue
const/4 v5, 0x0
const/4 v4, 0x0
.line 88
iput-boolean p1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->forEncryption:Z
.line 93
instance-of v0, p2, Lorg/spongycastle/crypto/params/AEADParameters;
if-eqz v0, :cond_5e
.line 95
check-cast p2, Lorg/spongycastle/crypto/params/AEADParameters;
.line 97
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/AEADParameters;->getNonce()[B
move-result-object v1
.line 98
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/AEADParameters;->getAssociatedText()[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->initialAssociatedText:[B
.line 99
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/AEADParameters;->getMacSize()I
move-result v0
div-int/lit8 v0, v0, 0x8
iput v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
.line 100
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/AEADParameters;->getKey()Lorg/spongycastle/crypto/params/KeyParameter;
move-result-object v0
move-object v2, v1
move-object v1, v0
.line 116
:goto_22
if-eqz p1, :cond_83
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
:goto_26
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->bufBlock:[B
.line 118
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
new-array v0, v0, [B
.line 121
iget-object v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v3, v1}, Lorg/spongycastle/crypto/Mac;->init(Lorg/spongycastle/crypto/CipherParameters;)V
.line 123
iget v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
add-int/lit8 v1, v1, -0x1
aput-byte v4, v0, v1
.line 124
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
iget v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
invoke-interface {v1, v0, v4, v3}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 125
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
array-length v1, v2
invoke-interface {v0, v2, v4, v1}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 126
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
iget-object v1, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->nonceMac:[B
invoke-interface {v0, v1, v4}, Lorg/spongycastle/crypto/Mac;->doFinal([BI)I
.line 129
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipher:Lorg/spongycastle/crypto/modes/SICBlockCipher;
const/4 v1, 0x1
new-instance v2, Lorg/spongycastle/crypto/params/ParametersWithIV;
iget-object v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->nonceMac:[B
invoke-direct {v2, v5, v3}, Lorg/spongycastle/crypto/params/ParametersWithIV;-><init>(Lorg/spongycastle/crypto/CipherParameters;[B)V
invoke-virtual {v0, v1, v2}, Lorg/spongycastle/crypto/modes/SICBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 131
invoke-virtual {p0}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->reset()V
.line 132
return-void
.line 102
:cond_5e
instance-of v0, p2, Lorg/spongycastle/crypto/params/ParametersWithIV;
if-eqz v0, :cond_7b
.line 104
check-cast p2, Lorg/spongycastle/crypto/params/ParametersWithIV;
.line 106
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getIV()[B
move-result-object v1
.line 107
iput-object v5, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->initialAssociatedText:[B
.line 108
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0}, Lorg/spongycastle/crypto/Mac;->getMacSize()I
move-result v0
div-int/lit8 v0, v0, 0x2
iput v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
.line 109
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
move-object v2, v1
move-object v1, v0
.line 110
goto :goto_22
.line 113
:cond_7b
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "invalid parameters passed to EAX"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 116
:cond_83
iget v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->blockSize:I
iget v3, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->macSize:I
add-int/2addr v0, v3
goto :goto_26
.end method
.method public processAADByte(B)V
.registers 4
.prologue
.line 194
iget-boolean v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipherInitialized:Z
if-eqz v0, :cond_c
.line 196
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "AAD data cannot be added after encryption/decryption processing has begun."
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 198
:cond_c
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0, p1}, Lorg/spongycastle/crypto/Mac;->update(B)V
.line 199
return-void
.end method
.method public processAADBytes([BII)V
.registers 6
.prologue
.line 203
iget-boolean v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->cipherInitialized:Z
if-eqz v0, :cond_c
.line 205
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "AAD data cannot be added after encryption/decryption processing has begun."
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 207
:cond_c
iget-object v0, p0, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->mac:Lorg/spongycastle/crypto/Mac;
invoke-interface {v0, p1, p2, p3}, Lorg/spongycastle/crypto/Mac;->update([BII)V
.line 208
return-void
.end method
.method public processByte(B[BI)I
.registers 5
.prologue
.line 213
invoke-direct {p0}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->initCipher()V
.line 215
invoke-direct {p0, p1, p2, p3}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->process(B[BI)I
move-result v0
return v0
.end method
.method public processBytes([BII[BI)I
.registers 10
.prologue
const/4 v0, 0x0
.line 221
invoke-direct {p0}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->initCipher()V
.line 223
array-length v1, p1
add-int v2, p2, p3
if-ge v1, v2, :cond_11
.line 225
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "Input buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
:cond_11
move v1, v0
.line 230
:goto_12
if-eq v0, p3, :cond_22
.line 232
add-int v2, p2, v0
aget-byte v2, p1, v2
add-int v3, p5, v1
invoke-direct {p0, v2, p4, v3}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->process(B[BI)I
move-result v2
add-int/2addr v1, v2
.line 230
add-int/lit8 v0, v0, 0x1
goto :goto_12
.line 235
:cond_22
return v1
.end method
.method public reset()V
.registers 2
.prologue
.line 163
const/4 v0, 0x1
invoke-direct {p0, v0}, Lorg/spongycastle/crypto/modes/EAXBlockCipher;->reset(Z)V
.line 164
return-void
.end method