SkeinEngine.smali
.class public Lorg/spongycastle/crypto/digests/SkeinEngine;
.super Ljava/lang/Object;
.source "SkeinEngine.java"
# interfaces
.implements Lorg/spongycastle/util/Memoable;
# static fields
.field private static final INITIAL_STATES:Ljava/util/Hashtable;
.field private static final PARAM_TYPE_CONFIG:I = 0x4
.field private static final PARAM_TYPE_KEY:I = 0x0
.field private static final PARAM_TYPE_MESSAGE:I = 0x30
.field private static final PARAM_TYPE_OUTPUT:I = 0x3f
.field public static final SKEIN_1024:I = 0x400
.field public static final SKEIN_256:I = 0x100
.field public static final SKEIN_512:I = 0x200
# instance fields
.field chain:[J
.field private initialState:[J
.field private key:[B
.field private final outputSizeBytes:I
.field private postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.field private preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.field private final singleByte:[B
.field final threefish:Lorg/spongycastle/crypto/engines/ThreefishEngine;
.field private final ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
# direct methods
.method static constructor <clinit>()V
.registers 7
.prologue
const/16 v6, 0x80
const/4 v5, 0x4
const/16 v4, 0x100
const/16 v3, 0x8
const/16 v2, 0x200
.line 137
new-instance v0, Ljava/util/Hashtable;
invoke-direct {v0}, Ljava/util/Hashtable;-><init>()V
sput-object v0, Lorg/spongycastle/crypto/digests/SkeinEngine;->INITIAL_STATES:Ljava/util/Hashtable;
.line 142
new-array v0, v5, [J
fill-array-data v0, :array_64
invoke-static {v4, v6, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 148
const/16 v0, 0xa0
new-array v1, v5, [J
fill-array-data v1, :array_78
invoke-static {v4, v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 154
const/16 v0, 0xe0
new-array v1, v5, [J
fill-array-data v1, :array_8c
invoke-static {v4, v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 160
new-array v0, v5, [J
fill-array-data v0, :array_a0
invoke-static {v4, v4, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 166
new-array v0, v3, [J
fill-array-data v0, :array_b4
invoke-static {v2, v6, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 176
const/16 v0, 0xa0
new-array v1, v3, [J
fill-array-data v1, :array_d8
invoke-static {v2, v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 186
const/16 v0, 0xe0
new-array v1, v3, [J
fill-array-data v1, :array_fc
invoke-static {v2, v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 196
const/16 v0, 0x180
new-array v1, v3, [J
fill-array-data v1, :array_120
invoke-static {v2, v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 206
new-array v0, v3, [J
fill-array-data v0, :array_144
invoke-static {v2, v2, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState(II[J)V
.line 215
return-void
.line 142
nop
:array_64
.array-data 8
-0x1eeee6f969b28da0L # -3.755924499506369E159
-0x77c2555883727ee4L
0x10080df491960f7aL # 1.936733715973684E-231
-0x3308221a4ba43e3eL # -6.136391494407059E62
.end array-data
.line 148
:array_78
.array-data 8
0x1420231472825e98L # 9.586866583092151E-212
0x2ac4e9a25a77e590L
-0x2b85a7a977c729c2L # -9.003636605138722E98
0x2dd2e4968586ab7dL # 5.935815605536115E-88
.end array-data
.line 154
:array_8c
.array-data 8
-0x39f67573651a15f5L # -2.5294787191403843E29
-0x7892a979f73ae6e4L # -6.778977455371991E-273
-0x66347728280ac77cL # -2.02502573808248E-184
0x384bddb1aeddb5deL # 1.6378158369262575E-37
.end array-data
.line 160
:array_a0
.array-data 8
-0x362579f2fb74bb7L
0x2fca66479fa7d833L # 1.781178079886423E-78
-0x4cc43c7699a97bf1L # -6.749009640937583E-62
0x6a54e920fde8da69L # 1.6390221063977923E204
.end array-data
.line 166
:array_b4
.array-data 8
-0x5743840c904060aeL
0x1e9872cebd1af0aaL
0x309b1790b32190d3L # 1.4974177594959565E-74
-0x430447abc06b7fa4L # -6.155084337311389E-15
0xda61bcd6e31b11bL
0x1a18ebead46a32e3L # 5.86513116755826E-183
-0x5d33a4e7317b557eL # -4.650660861511907E-141
0x6982ab289d46982dL # 1.7862350882471686E200
.end array-data
.line 176
:array_d8
.array-data 8
0x28b81a2ae013bd91L
-0x3d0ee9974a420871L # -3.0060709910104894E14
0x1760d8f3f6a56f12L # 4.507623037519005E-196
0x4fb747588239904fL # 1.0529252523548142E76
0x21ede07f7eaf5056L # 2.990806367775679E-145
-0x26f76dd19c128f48L # -7.93106429127717E120
-0x471389001334ad06L # -1.7131653979910983E-34
0x1a47bb8a3f27a6eL # 9.55815287055376E-301
.end array-data
.line 186
:array_fc
.array-data 8
-0x332f9e9db7988ddcL # -1.0528918985767222E62
-0x3459a30c56dcc611L # -2.741707220167551E56
-0x73329629ad00b49cL
0x398aed7b3ab890b4L # 1.6595452726835055E-31
0xf59d1b1457d2bd0L
0x6776fe6575d4eb3dL # 2.5612195686199393E190
-0x660438f1668bec17L
-0x61d303301e3be109L # -2.516887647587867E-163
.end array-data
.line 196
:array_120
.array-data 8
-0x5c093940c58a10a1L
-0x4f010633027b055cL # -1.0957295332530228E-72
-0x62882299c288f302L
-0x2867340c4b970226L # -9.541398731956652E113
0x1bc4a6668a0e4465L # 6.522778463246742E-175
0x7ed7d434e5807407L # 1.02131623536852E303
0x548fc1acd4ec44d6L # 2.170610083874673E99
0x266e17546aa18ff8L # 1.422493577730732E-123
.end array-data
.line 206
:array_144
.array-data 8
0x4903adff749c51ceL # 5.485893890549328E43
0xd95de399746df03L
-0x702e6cbed8386432L
-0x65daa9d600cad34fL
0x5db62599df6ca7b0L # 2.7006635905297533E143
-0x1541c6b3562a3c0cL # -1.5161650890352393E206
-0x66eeed38e58a4addL # -6.13114337881356E-188
-0x51e75bf499f033cdL # -1.238671206473047E-86
.end array-data
.end method
.method public constructor <init>(II)V
.registers 6
.prologue
.line 517
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 506
const/4 v0, 0x1
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->singleByte:[B
.line 518
rem-int/lit8 v0, p2, 0x8
if-eqz v0, :cond_21
.line 520
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Output size must be a multiple of 8 bits. :"
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 523
:cond_21
div-int/lit8 v0, p2, 0x8
iput v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
.line 525
new-instance v0, Lorg/spongycastle/crypto/engines/ThreefishEngine;
invoke-direct {v0, p1}, Lorg/spongycastle/crypto/engines/ThreefishEngine;-><init>(I)V
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->threefish:Lorg/spongycastle/crypto/engines/ThreefishEngine;
.line 526
new-instance v0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->threefish:Lorg/spongycastle/crypto/engines/ThreefishEngine;
invoke-virtual {v1}, Lorg/spongycastle/crypto/engines/ThreefishEngine;->getBlockSize()I
move-result v1
invoke-direct {v0, p0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;-><init>(Lorg/spongycastle/crypto/digests/SkeinEngine;I)V
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
.line 527
return-void
.end method
.method public constructor <init>(Lorg/spongycastle/crypto/digests/SkeinEngine;)V
.registers 4
.prologue
.line 534
invoke-virtual {p1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->getBlockSize()I
move-result v0
shl-int/lit8 v0, v0, 0x3
invoke-virtual {p1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->getOutputSize()I
move-result v1
shl-int/lit8 v1, v1, 0x3
invoke-direct {p0, v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;-><init>(II)V
.line 535
invoke-direct {p0, p1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->copyIn(Lorg/spongycastle/crypto/digests/SkeinEngine;)V
.line 536
return-void
.end method
.method private checkInitialised()V
.registers 3
.prologue
.line 736
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
if-nez v0, :cond_c
.line 738
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Skein engine is not initialised."
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 740
:cond_c
return-void
.end method
.method private static clone([Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;)[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.registers 5
.prologue
const/4 v2, 0x0
.line 550
if-nez p0, :cond_5
.line 552
const/4 p1, 0x0
.line 559
:goto_4
return-object p1
.line 554
:cond_5
if-eqz p1, :cond_b
array-length v0, p1
array-length v1, p0
if-eq v0, v1, :cond_e
.line 556
:cond_b
array-length v0, p0
new-array p1, v0, [Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.line 558
:cond_e
array-length v0, p1
invoke-static {p0, v2, p1, v2, v0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
goto :goto_4
.end method
.method private copyIn(Lorg/spongycastle/crypto/digests/SkeinEngine;)V
.registers 4
.prologue
.line 540
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
iget-object v1, p1, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
invoke-virtual {v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->reset(Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;)V
.line 541
iget-object v0, p1, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
invoke-static {v0, v1}, Lorg/spongycastle/util/Arrays;->clone([J[J)[J
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
.line 542
iget-object v0, p1, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState:[J
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState:[J
invoke-static {v0, v1}, Lorg/spongycastle/util/Arrays;->clone([J[J)[J
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState:[J
.line 543
iget-object v0, p1, Lorg/spongycastle/crypto/digests/SkeinEngine;->key:[B
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->key:[B
invoke-static {v0, v1}, Lorg/spongycastle/util/Arrays;->clone([B[B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->key:[B
.line 544
iget-object v0, p1, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
invoke-static {v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->clone([Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;)[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.line 545
iget-object v0, p1, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
invoke-static {v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->clone([Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;)[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.line 546
return-void
.end method
.method private createInitialState()V
.registers 7
.prologue
const/4 v1, 0x0
.line 673
sget-object v0, Lorg/spongycastle/crypto/digests/SkeinEngine;->INITIAL_STATES:Ljava/util/Hashtable;
invoke-virtual {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->getBlockSize()I
move-result v2
invoke-virtual {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->getOutputSize()I
move-result v3
invoke-static {v2, v3}, Lorg/spongycastle/crypto/digests/SkeinEngine;->variantIdentifier(II)Ljava/lang/Integer;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/util/Hashtable;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, [J
.line 674
iget-object v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->key:[B
if-nez v2, :cond_3d
if-eqz v0, :cond_3d
.line 677
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([J)[J
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
.line 695
:goto_21
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
if-eqz v0, :cond_63
move v0, v1
.line 697
:goto_26
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
array-length v1, v1
if-ge v0, v1, :cond_63
.line 699
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
aget-object v1, v1, v0
.line 700
invoke-virtual {v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;->getType()I
move-result v2
invoke-virtual {v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;->getValue()[B
move-result-object v1
invoke-direct {p0, v2, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiComplete(I[B)V
.line 697
add-int/lit8 v0, v0, 0x1
goto :goto_26
.line 682
:cond_3d
invoke-virtual {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->getBlockSize()I
move-result v0
div-int/lit8 v0, v0, 0x8
new-array v0, v0, [J
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
.line 685
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->key:[B
if-eqz v0, :cond_50
.line 687
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->key:[B
invoke-direct {p0, v1, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiComplete(I[B)V
.line 691
:cond_50
const/4 v0, 0x4
new-instance v2, Lorg/spongycastle/crypto/digests/SkeinEngine$Configuration;
iget v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
shl-int/lit8 v3, v3, 0x3
int-to-long v4, v3
invoke-direct {v2, v4, v5}, Lorg/spongycastle/crypto/digests/SkeinEngine$Configuration;-><init>(J)V
invoke-virtual {v2}, Lorg/spongycastle/crypto/digests/SkeinEngine$Configuration;->getBytes()[B
move-result-object v2
invoke-direct {p0, v0, v2}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiComplete(I[B)V
goto :goto_21
.line 703
:cond_63
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([J)[J
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState:[J
.line 704
return-void
.end method
.method private initParams(Ljava/util/Hashtable;)V
.registers 9
.prologue
.line 617
invoke-virtual {p1}, Ljava/util/Hashtable;->keys()Ljava/util/Enumeration;
move-result-object v2
.line 618
new-instance v3, Ljava/util/Vector;
invoke-direct {v3}, Ljava/util/Vector;-><init>()V
.line 619
new-instance v4, Ljava/util/Vector;
invoke-direct {v4}, Ljava/util/Vector;-><init>()V
.line 621
:goto_e
invoke-interface {v2}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v0
if-eqz v0, :cond_4b
.line 623
invoke-interface {v2}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Integer;
.line 624
invoke-virtual {p1, v0}, Ljava/util/Hashtable;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, [B
.line 626
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v5
if-nez v5, :cond_29
.line 628
iput-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->key:[B
goto :goto_e
.line 630
:cond_29
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v5
const/16 v6, 0x30
if-ge v5, v6, :cond_3e
.line 632
new-instance v5, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v0
invoke-direct {v5, v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;-><init>(I[B)V
invoke-virtual {v3, v5}, Ljava/util/Vector;->addElement(Ljava/lang/Object;)V
goto :goto_e
.line 636
:cond_3e
new-instance v5, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v0
invoke-direct {v5, v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;-><init>(I[B)V
invoke-virtual {v4, v5}, Ljava/util/Vector;->addElement(Ljava/lang/Object;)V
goto :goto_e
.line 639
:cond_4b
invoke-virtual {v3}, Ljava/util/Vector;->size()I
move-result v0
new-array v0, v0, [Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.line 640
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
invoke-virtual {v3, v0}, Ljava/util/Vector;->copyInto([Ljava/lang/Object;)V
.line 641
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
invoke-static {v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->sort([Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;)V
.line 643
invoke-virtual {v4}, Ljava/util/Vector;->size()I
move-result v0
new-array v0, v0, [Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.line 644
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
invoke-virtual {v4, v0}, Ljava/util/Vector;->copyInto([Ljava/lang/Object;)V
.line 645
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
invoke-static {v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->sort([Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;)V
.line 646
return-void
.end method
.method private static initialState(II[J)V
.registers 6
.prologue
.line 219
sget-object v0, Lorg/spongycastle/crypto/digests/SkeinEngine;->INITIAL_STATES:Ljava/util/Hashtable;
div-int/lit8 v1, p0, 0x8
div-int/lit8 v2, p1, 0x8
invoke-static {v1, v2}, Lorg/spongycastle/crypto/digests/SkeinEngine;->variantIdentifier(II)Ljava/lang/Integer;
move-result-object v1
invoke-virtual {v0, v1, p2}, Ljava/util/Hashtable;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 220
return-void
.end method
.method private output(J[BII)V
.registers 15
.prologue
const/16 v8, 0x8
const/4 v1, 0x0
.line 791
new-array v2, v8, [B
.line 792
invoke-static {p1, p2, v2, v1}, Lorg/spongycastle/crypto/engines/ThreefishEngine;->wordToBytes(J[BI)V
.line 796
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
array-length v0, v0
new-array v3, v0, [J
.line 797
const/16 v0, 0x3f
invoke-direct {p0, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiInit(I)V
.line 798
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
invoke-virtual {v0, v2, v1, v8, v3}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->update([BII[J)V
.line 799
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
invoke-virtual {v0, v3}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->doFinal([J)V
.line 801
add-int/lit8 v0, p5, 0x8
add-int/lit8 v0, v0, -0x1
div-int/lit8 v4, v0, 0x8
move v0, v1
.line 802
:goto_23
if-ge v0, v4, :cond_46
.line 804
shl-int/lit8 v5, v0, 0x3
sub-int v5, p5, v5
invoke-static {v8, v5}, Ljava/lang/Math;->min(II)I
move-result v5
.line 805
if-ne v5, v8, :cond_3a
.line 807
aget-wide v6, v3, v0
shl-int/lit8 v5, v0, 0x3
add-int/2addr v5, p4
invoke-static {v6, v7, p3, v5}, Lorg/spongycastle/crypto/engines/ThreefishEngine;->wordToBytes(J[BI)V
.line 802
:goto_37
add-int/lit8 v0, v0, 0x1
goto :goto_23
.line 811
:cond_3a
aget-wide v6, v3, v0
invoke-static {v6, v7, v2, v1}, Lorg/spongycastle/crypto/engines/ThreefishEngine;->wordToBytes(J[BI)V
.line 812
shl-int/lit8 v6, v0, 0x3
add-int/2addr v6, p4
invoke-static {v2, v1, p3, v6, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
goto :goto_37
.line 815
:cond_46
return-void
.end method
.method private static sort([Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;)V
.registers 6
.prologue
.line 650
if-nez p0, :cond_3
.line 666
:cond_2
return-void
.line 655
:cond_3
const/4 v0, 0x1
:goto_4
array-length v1, p0
if-ge v0, v1, :cond_2
.line 657
aget-object v2, p0, v0
move v1, v0
.line 659
:goto_a
if-lez v1, :cond_23
invoke-virtual {v2}, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;->getType()I
move-result v3
add-int/lit8 v4, v1, -0x1
aget-object v4, p0, v4
invoke-virtual {v4}, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;->getType()I
move-result v4
if-ge v3, v4, :cond_23
.line 661
add-int/lit8 v3, v1, -0x1
aget-object v3, p0, v3
aput-object v3, p0, v1
.line 662
add-int/lit8 v1, v1, -0x1
goto :goto_a
.line 664
:cond_23
aput-object v2, p0, v1
.line 655
add-int/lit8 v0, v0, 0x1
goto :goto_4
.end method
.method private ubiComplete(I[B)V
.registers 7
.prologue
.line 719
invoke-direct {p0, p1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiInit(I)V
.line 720
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
const/4 v1, 0x0
array-length v2, p2
iget-object v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
invoke-virtual {v0, p2, v1, v2, v3}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->update([BII[J)V
.line 721
invoke-direct {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiFinal()V
.line 722
return-void
.end method
.method private ubiFinal()V
.registers 3
.prologue
.line 731
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
invoke-virtual {v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->doFinal([J)V
.line 732
return-void
.end method
.method private ubiInit(I)V
.registers 3
.prologue
.line 726
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
invoke-virtual {v0, p1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->reset(I)V
.line 727
return-void
.end method
.method private static variantIdentifier(II)Ljava/lang/Integer;
.registers 4
.prologue
.line 224
new-instance v0, Ljava/lang/Integer;
shl-int/lit8 v1, p1, 0x10
or-int/2addr v1, p0
invoke-direct {v0, v1}, Ljava/lang/Integer;-><init>(I)V
return-object v0
.end method
# virtual methods
.method public copy()Lorg/spongycastle/util/Memoable;
.registers 2
.prologue
.line 564
new-instance v0, Lorg/spongycastle/crypto/digests/SkeinEngine;
invoke-direct {v0, p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;-><init>(Lorg/spongycastle/crypto/digests/SkeinEngine;)V
return-object v0
.end method
.method public doFinal([BI)I
.registers 12
.prologue
const/4 v1, 0x0
.line 756
invoke-direct {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->checkInitialised()V
.line 757
array-length v0, p1
iget v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
add-int/2addr v2, p2
if-ge v0, v2, :cond_12
.line 759
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "Output buffer is too short to hold output"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 763
:cond_12
invoke-direct {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiFinal()V
.line 766
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
if-eqz v0, :cond_31
move v0, v1
.line 768
:goto_1a
iget-object v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
array-length v2, v2
if-ge v0, v2, :cond_31
.line 770
iget-object v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
aget-object v2, v2, v0
.line 771
invoke-virtual {v2}, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;->getType()I
move-result v3
invoke-virtual {v2}, Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;->getValue()[B
move-result-object v2
invoke-direct {p0, v3, v2}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiComplete(I[B)V
.line 768
add-int/lit8 v0, v0, 0x1
goto :goto_1a
.line 776
:cond_31
invoke-virtual {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->getBlockSize()I
move-result v7
.line 777
iget v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
add-int/2addr v0, v7
add-int/lit8 v0, v0, -0x1
div-int v8, v0, v7
move v0, v1
.line 778
:goto_3d
if-ge v0, v8, :cond_56
.line 780
iget v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
mul-int v2, v0, v7
sub-int/2addr v1, v2
invoke-static {v7, v1}, Ljava/lang/Math;->min(II)I
move-result v6
.line 781
int-to-long v2, v0
mul-int v1, v0, v7
add-int v5, p2, v1
move-object v1, p0
move-object v4, p1
invoke-direct/range {v1 .. v6}, Lorg/spongycastle/crypto/digests/SkeinEngine;->output(J[BII)V
.line 778
add-int/lit8 v1, v0, 0x1
move v0, v1
goto :goto_3d
.line 784
:cond_56
invoke-virtual {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->reset()V
.line 786
iget v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
return v0
.end method
.method public getBlockSize()I
.registers 2
.prologue
.line 584
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->threefish:Lorg/spongycastle/crypto/engines/ThreefishEngine;
invoke-virtual {v0}, Lorg/spongycastle/crypto/engines/ThreefishEngine;->getBlockSize()I
move-result v0
return v0
.end method
.method public getOutputSize()I
.registers 2
.prologue
.line 579
iget v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
return v0
.end method
.method public init(Lorg/spongycastle/crypto/params/SkeinParameters;)V
.registers 4
.prologue
const/4 v0, 0x0
.line 595
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
.line 596
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->key:[B
.line 597
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->preMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.line 598
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->postMessageParameters:[Lorg/spongycastle/crypto/digests/SkeinEngine$Parameter;
.line 600
if-eqz p1, :cond_23
.line 602
invoke-virtual {p1}, Lorg/spongycastle/crypto/params/SkeinParameters;->getKey()[B
move-result-object v0
.line 603
array-length v0, v0
const/16 v1, 0x10
if-ge v0, v1, :cond_1c
.line 605
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Skein key must be at least 128 bits."
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 607
:cond_1c
invoke-virtual {p1}, Lorg/spongycastle/crypto/params/SkeinParameters;->getParameters()Ljava/util/Hashtable;
move-result-object v0
invoke-direct {p0, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->initParams(Ljava/util/Hashtable;)V
.line 609
:cond_23
invoke-direct {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->createInitialState()V
.line 612
const/16 v0, 0x30
invoke-direct {p0, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiInit(I)V
.line 613
return-void
.end method
.method public reset()V
.registers 5
.prologue
const/4 v3, 0x0
.line 712
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->initialState:[J
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
iget-object v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
array-length v2, v2
invoke-static {v0, v3, v1, v3, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 714
const/16 v0, 0x30
invoke-direct {p0, v0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubiInit(I)V
.line 715
return-void
.end method
.method public reset(Lorg/spongycastle/util/Memoable;)V
.registers 4
.prologue
.line 569
check-cast p1, Lorg/spongycastle/crypto/digests/SkeinEngine;
.line 570
invoke-virtual {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->getBlockSize()I
move-result v0
invoke-virtual {p1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->getBlockSize()I
move-result v1
if-ne v0, v1, :cond_12
iget v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
iget v1, p1, Lorg/spongycastle/crypto/digests/SkeinEngine;->outputSizeBytes:I
if-eq v0, v1, :cond_1a
.line 572
:cond_12
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Incompatible parameters in provided SkeinEngine."
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 574
:cond_1a
invoke-direct {p0, p1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->copyIn(Lorg/spongycastle/crypto/digests/SkeinEngine;)V
.line 575
return-void
.end method
.method public update(B)V
.registers 5
.prologue
const/4 v2, 0x0
.line 744
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->singleByte:[B
aput-byte p1, v0, v2
.line 745
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->singleByte:[B
const/4 v1, 0x1
invoke-virtual {p0, v0, v2, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine;->update([BII)V
.line 746
return-void
.end method
.method public update([BII)V
.registers 6
.prologue
.line 750
invoke-direct {p0}, Lorg/spongycastle/crypto/digests/SkeinEngine;->checkInitialised()V
.line 751
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->ubi:Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
invoke-virtual {v0, p1, p2, p3, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->update([BII[J)V
.line 752
return-void
.end method