SkeinEngine$UBI.smali
.class Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;
.super Ljava/lang/Object;
.source "SkeinEngine.java"
# instance fields
.field private currentBlock:[B
.field private currentOffset:I
.field private message:[J
.field final synthetic this$0:Lorg/spongycastle/crypto/digests/SkeinEngine;
.field private final tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/digests/SkeinEngine;I)V
.registers 4
.prologue
.line 389
iput-object p1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->this$0:Lorg/spongycastle/crypto/digests/SkeinEngine;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 371
new-instance v0, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
invoke-direct {v0}, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;-><init>()V
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
.line 390
new-array v0, p2, [B
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
.line 391
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
array-length v0, v0
div-int/lit8 v0, v0, 0x8
new-array v0, v0, [J
iput-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->message:[J
.line 392
return-void
.end method
.method private processBlock([J)V
.registers 8
.prologue
const/4 v1, 0x0
.line 435
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->this$0:Lorg/spongycastle/crypto/digests/SkeinEngine;
iget-object v0, v0, Lorg/spongycastle/crypto/digests/SkeinEngine;->threefish:Lorg/spongycastle/crypto/engines/ThreefishEngine;
const/4 v2, 0x1
iget-object v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->this$0:Lorg/spongycastle/crypto/digests/SkeinEngine;
iget-object v3, v3, Lorg/spongycastle/crypto/digests/SkeinEngine;->chain:[J
iget-object v4, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
invoke-virtual {v4}, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;->getWords()[J
move-result-object v4
invoke-virtual {v0, v2, v3, v4}, Lorg/spongycastle/crypto/engines/ThreefishEngine;->init(Z[J[J)V
move v0, v1
.line 436
:goto_14
iget-object v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->message:[J
array-length v2, v2
if-ge v0, v2, :cond_28
.line 438
iget-object v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->message:[J
iget-object v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
shl-int/lit8 v4, v0, 0x3
invoke-static {v3, v4}, Lorg/spongycastle/crypto/engines/ThreefishEngine;->bytesToWord([BI)J
move-result-wide v4
aput-wide v4, v2, v0
.line 436
add-int/lit8 v0, v0, 0x1
goto :goto_14
.line 441
:cond_28
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->this$0:Lorg/spongycastle/crypto/digests/SkeinEngine;
iget-object v0, v0, Lorg/spongycastle/crypto/digests/SkeinEngine;->threefish:Lorg/spongycastle/crypto/engines/ThreefishEngine;
iget-object v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->message:[J
invoke-virtual {v0, v2, p1}, Lorg/spongycastle/crypto/engines/ThreefishEngine;->processBlock([J[J)I
.line 443
:goto_31
array-length v0, p1
if-ge v1, v0, :cond_40
.line 445
aget-wide v2, p1, v1
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->message:[J
aget-wide v4, v0, v1
xor-long/2addr v2, v4
aput-wide v2, p1, v1
.line 443
add-int/lit8 v1, v1, 0x1
goto :goto_31
.line 447
:cond_40
return-void
.end method
# virtual methods
.method public doFinal([J)V
.registers 5
.prologue
.line 452
iget v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
:goto_2
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
array-length v1, v1
if-ge v0, v1, :cond_f
.line 454
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
const/4 v2, 0x0
aput-byte v2, v1, v0
.line 452
add-int/lit8 v0, v0, 0x1
goto :goto_2
.line 457
:cond_f
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
const/4 v1, 0x1
invoke-virtual {v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;->setFinal(Z)V
.line 458
invoke-direct {p0, p1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->processBlock([J)V
.line 459
return-void
.end method
.method public reset(I)V
.registers 3
.prologue
.line 404
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
invoke-virtual {v0}, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;->reset()V
.line 405
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
invoke-virtual {v0, p1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;->setType(I)V
.line 406
const/4 v0, 0x0
iput v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
.line 407
return-void
.end method
.method public reset(Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;)V
.registers 4
.prologue
.line 396
iget-object v0, p1, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[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$UBI;->currentBlock:[B
.line 397
iget v0, p1, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
iput v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
.line 398
iget-object v0, p1, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->message:[J
iget-object v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->message:[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$UBI;->message:[J
.line 399
iget-object v0, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
iget-object v1, p1, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
invoke-virtual {v0, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;->reset(Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;)V
.line 400
return-void
.end method
.method public update([BII[J)V
.registers 11
.prologue
const/4 v1, 0x0
.line 415
move v0, v1
.line 416
:goto_2
if-le p3, v0, :cond_36
.line 418
iget v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
iget-object v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
array-length v3, v3
if-ne v2, v3, :cond_15
.line 420
invoke-direct {p0, p4}, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->processBlock([J)V
.line 421
iget-object v2, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
invoke-virtual {v2, v1}, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;->setFirst(Z)V
.line 422
iput v1, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
.line 425
:cond_15
sub-int v2, p3, v0
iget-object v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
array-length v3, v3
iget v4, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
sub-int/2addr v3, v4
invoke-static {v2, v3}, Ljava/lang/Math;->min(II)I
move-result v2
.line 426
add-int v3, p2, v0
iget-object v4, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentBlock:[B
iget v5, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
invoke-static {p1, v3, v4, v5, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 427
add-int/2addr v0, v2
.line 428
iget v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
add-int/2addr v3, v2
iput v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->currentOffset:I
.line 429
iget-object v3, p0, Lorg/spongycastle/crypto/digests/SkeinEngine$UBI;->tweak:Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;
invoke-virtual {v3, v2}, Lorg/spongycastle/crypto/digests/SkeinEngine$UbiTweak;->advancePosition(I)V
goto :goto_2
.line 431
:cond_36
return-void
.end method