Tables8kGCMMultiplier.smali
.class public Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;
.super Ljava/lang/Object;
.source "Tables8kGCMMultiplier.java"
# interfaces
.implements Lorg/spongycastle/crypto/modes/gcm/GCMMultiplier;
# instance fields
.field private H:[B
.field private M:[[[I
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 6
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public init([B)V
.registers 12
.prologue
const/16 v9, 0x10
const/16 v2, 0x8
const/4 v4, 0x4
const/4 v1, 0x0
const/4 v3, 0x1
.line 13
iget-object v0, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
if-nez v0, :cond_41
.line 15
const/16 v0, 0x20
filled-new-array {v0, v9, v4}, [I
move-result-object v0
sget-object v5, Ljava/lang/Integer;->TYPE:Ljava/lang/Class;
invoke-static {v5, v0}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object;
move-result-object v0
check-cast v0, [[[I
iput-object v0, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
.line 22
:cond_1b
invoke-static {p1}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->H:[B
.line 26
iget-object v0, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v0, v0, v3
aget-object v0, v0, v2
invoke-static {p1, v0}, Lorg/spongycastle/crypto/modes/gcm/GCMUtil;->asInts([B[I)V
move v0, v4
.line 28
:goto_2b
if-lez v0, :cond_4a
.line 30
iget-object v5, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v5, v5, v3
add-int v6, v0, v0
aget-object v5, v5, v6
iget-object v6, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v6, v6, v3
aget-object v6, v6, v0
invoke-static {v5, v6}, Lorg/spongycastle/crypto/modes/gcm/GCMUtil;->multiplyP([I[I)V
.line 28
shr-int/lit8 v0, v0, 0x1
goto :goto_2b
.line 17
:cond_41
iget-object v0, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->H:[B
invoke-static {v0, p1}, Lorg/spongycastle/util/Arrays;->areEqual([B[B)Z
move-result v0
if-eqz v0, :cond_1b
.line 53
:cond_49
return-void
.line 33
:cond_4a
iget-object v0, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v0, v0, v3
aget-object v0, v0, v3
iget-object v5, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v5, v5, v1
aget-object v5, v5, v2
invoke-static {v0, v5}, Lorg/spongycastle/crypto/modes/gcm/GCMUtil;->multiplyP([I[I)V
move v0, v4
.line 35
:goto_5a
if-lez v0, :cond_70
.line 37
iget-object v4, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v4, v4, v1
add-int v5, v0, v0
aget-object v4, v4, v5
iget-object v5, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v5, v5, v1
aget-object v5, v5, v0
invoke-static {v4, v5}, Lorg/spongycastle/crypto/modes/gcm/GCMUtil;->multiplyP([I[I)V
.line 35
shr-int/lit8 v0, v0, 0x1
goto :goto_5a
:cond_70
move v0, v1
.line 43
:cond_71
const/4 v1, 0x2
move v4, v1
:goto_73
if-ge v4, v9, :cond_96
move v1, v3
.line 45
:goto_76
if-ge v1, v4, :cond_92
.line 47
iget-object v5, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v5, v5, v0
aget-object v5, v5, v4
iget-object v6, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v6, v6, v0
aget-object v6, v6, v1
iget-object v7, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v7, v7, v0
add-int v8, v4, v1
aget-object v7, v7, v8
invoke-static {v5, v6, v7}, Lorg/spongycastle/crypto/modes/gcm/GCMUtil;->xor([I[I[I)V
.line 45
add-int/lit8 v1, v1, 0x1
goto :goto_76
.line 43
:cond_92
add-int v1, v4, v4
move v4, v1
goto :goto_73
.line 51
:cond_96
add-int/lit8 v0, v0, 0x1
const/16 v1, 0x20
if-eq v0, v1, :cond_49
.line 56
if-le v0, v3, :cond_71
move v1, v2
.line 59
:goto_9f
if-lez v1, :cond_71
.line 61
iget-object v4, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
add-int/lit8 v5, v0, -0x2
aget-object v4, v4, v5
aget-object v4, v4, v1
iget-object v5, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
aget-object v5, v5, v0
aget-object v5, v5, v1
invoke-static {v4, v5}, Lorg/spongycastle/crypto/modes/gcm/GCMUtil;->multiplyP8([I[I)V
.line 59
shr-int/lit8 v1, v1, 0x1
goto :goto_9f
.end method
.method public multiplyH([B)V
.registers 11
.prologue
const/4 v8, 0x3
const/4 v7, 0x2
const/4 v6, 0x1
const/4 v5, 0x0
.line 71
const/4 v0, 0x4
new-array v1, v0, [I
.line 72
const/16 v0, 0xf
:goto_9
if-ltz v0, :cond_62
.line 75
iget-object v2, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
add-int v3, v0, v0
aget-object v2, v2, v3
aget-byte v3, p1, v0
and-int/lit8 v3, v3, 0xf
aget-object v2, v2, v3
.line 76
aget v3, v1, v5
aget v4, v2, v5
xor-int/2addr v3, v4
aput v3, v1, v5
.line 77
aget v3, v1, v6
aget v4, v2, v6
xor-int/2addr v3, v4
aput v3, v1, v6
.line 78
aget v3, v1, v7
aget v4, v2, v7
xor-int/2addr v3, v4
aput v3, v1, v7
.line 79
aget v3, v1, v8
aget v2, v2, v8
xor-int/2addr v2, v3
aput v2, v1, v8
.line 81
iget-object v2, p0, Lorg/spongycastle/crypto/modes/gcm/Tables8kGCMMultiplier;->M:[[[I
add-int v3, v0, v0
add-int/lit8 v3, v3, 0x1
aget-object v2, v2, v3
aget-byte v3, p1, v0
and-int/lit16 v3, v3, 0xf0
ushr-int/lit8 v3, v3, 0x4
aget-object v2, v2, v3
.line 82
aget v3, v1, v5
aget v4, v2, v5
xor-int/2addr v3, v4
aput v3, v1, v5
.line 83
aget v3, v1, v6
aget v4, v2, v6
xor-int/2addr v3, v4
aput v3, v1, v6
.line 84
aget v3, v1, v7
aget v4, v2, v7
xor-int/2addr v3, v4
aput v3, v1, v7
.line 85
aget v3, v1, v8
aget v2, v2, v8
xor-int/2addr v2, v3
aput v2, v1, v8
.line 72
add-int/lit8 v0, v0, -0x1
goto :goto_9
.line 88
:cond_62
invoke-static {v1, p1, v5}, Lorg/spongycastle/util/Pack;->intToBigEndian([I[BI)V
.line 89
return-void
.end method