GMac.smali
.class public Lorg/spongycastle/crypto/macs/GMac;
.super Ljava/lang/Object;
.source "GMac.java"
# interfaces
.implements Lorg/spongycastle/crypto/Mac;
# instance fields
.field private final cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
.field private final macSizeBits:I
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/modes/GCMBlockCipher;)V
.registers 3
.prologue
.line 33
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 35
iput-object p1, p0, Lorg/spongycastle/crypto/macs/GMac;->cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
.line 36
const/16 v0, 0x80
iput v0, p0, Lorg/spongycastle/crypto/macs/GMac;->macSizeBits:I
.line 37
return-void
.end method
.method public constructor <init>(Lorg/spongycastle/crypto/modes/GCMBlockCipher;I)V
.registers 3
.prologue
.line 49
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 50
iput-object p1, p0, Lorg/spongycastle/crypto/macs/GMac;->cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
.line 51
iput p2, p0, Lorg/spongycastle/crypto/macs/GMac;->macSizeBits:I
.line 52
return-void
.end method
# virtual methods
.method public doFinal([BI)I
.registers 5
.prologue
.line 102
:try_start_0
iget-object v0, p0, Lorg/spongycastle/crypto/macs/GMac;->cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
invoke-virtual {v0, p1, p2}, Lorg/spongycastle/crypto/modes/GCMBlockCipher;->doFinal([BI)I
:try_end_5
.catch Lorg/spongycastle/crypto/InvalidCipherTextException; {:try_start_0 .. :try_end_5} :catch_7
move-result v0
return v0
.line 104
:catch_7
move-exception v0
.line 107
new-instance v1, Ljava/lang/IllegalStateException;
invoke-virtual {v0}, Lorg/spongycastle/crypto/InvalidCipherTextException;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v1
.end method
.method public getAlgorithmName()Ljava/lang/String;
.registers 3
.prologue
.line 78
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v1, p0, Lorg/spongycastle/crypto/macs/GMac;->cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
invoke-virtual {v1}, Lorg/spongycastle/crypto/modes/GCMBlockCipher;->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, "-GMAC"
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 getMacSize()I
.registers 2
.prologue
.line 83
iget v0, p0, Lorg/spongycastle/crypto/macs/GMac;->macSizeBits:I
div-int/lit8 v0, v0, 0x8
return v0
.end method
.method public init(Lorg/spongycastle/crypto/CipherParameters;)V
.registers 8
.prologue
.line 60
instance-of v0, p1, Lorg/spongycastle/crypto/params/ParametersWithIV;
if-eqz v0, :cond_1e
.line 62
check-cast p1, Lorg/spongycastle/crypto/params/ParametersWithIV;
.line 64
invoke-virtual {p1}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getIV()[B
move-result-object v1
.line 65
invoke-virtual {p1}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v0
check-cast v0, Lorg/spongycastle/crypto/params/KeyParameter;
.line 68
iget-object v2, p0, Lorg/spongycastle/crypto/macs/GMac;->cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
const/4 v3, 0x1
new-instance v4, Lorg/spongycastle/crypto/params/AEADParameters;
iget v5, p0, Lorg/spongycastle/crypto/macs/GMac;->macSizeBits:I
invoke-direct {v4, v0, v5, v1}, Lorg/spongycastle/crypto/params/AEADParameters;-><init>(Lorg/spongycastle/crypto/params/KeyParameter;I[B)V
invoke-virtual {v2, v3, v4}, Lorg/spongycastle/crypto/modes/GCMBlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 69
return-void
.line 72
:cond_1e
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "GMAC requires ParametersWithIV"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public reset()V
.registers 2
.prologue
.line 113
iget-object v0, p0, Lorg/spongycastle/crypto/macs/GMac;->cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
invoke-virtual {v0}, Lorg/spongycastle/crypto/modes/GCMBlockCipher;->reset()V
.line 114
return-void
.end method
.method public update(B)V
.registers 3
.prologue
.line 88
iget-object v0, p0, Lorg/spongycastle/crypto/macs/GMac;->cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
invoke-virtual {v0, p1}, Lorg/spongycastle/crypto/modes/GCMBlockCipher;->processAADByte(B)V
.line 89
return-void
.end method
.method public update([BII)V
.registers 5
.prologue
.line 94
iget-object v0, p0, Lorg/spongycastle/crypto/macs/GMac;->cipher:Lorg/spongycastle/crypto/modes/GCMBlockCipher;
invoke-virtual {v0, p1, p2, p3}, Lorg/spongycastle/crypto/modes/GCMBlockCipher;->processAADBytes([BII)V
.line 95
return-void
.end method