KDFDoublePipelineIterationParameters.smali
.class public final Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;
.super Ljava/lang/Object;
.source "KDFDoublePipelineIterationParameters.java"
# interfaces
.implements Lorg/spongycastle/crypto/DerivationParameters;
# static fields
.field private static final UNUSED_R:I = 0x20
# instance fields
.field private final fixedInputData:[B
.field private final ki:[B
.field private final r:I
.field private final useCounter:Z
# direct methods
.method private constructor <init>([B[BIZ)V
.registers 7
.prologue
.line 24
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 25
if-nez p1, :cond_d
.line 27
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "A KDF requires Ki (a seed) as input"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 29
:cond_d
invoke-static {p1}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->ki:[B
.line 31
if-nez p2, :cond_32
.line 33
const/4 v0, 0x0
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->fixedInputData:[B
.line 40
:goto_1a
const/16 v0, 0x8
if-eq p3, v0, :cond_39
const/16 v0, 0x10
if-eq p3, v0, :cond_39
const/16 v0, 0x18
if-eq p3, v0, :cond_39
const/16 v0, 0x20
if-eq p3, v0, :cond_39
.line 42
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Length of counter should be 8, 16, 24 or 32"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 37
:cond_32
invoke-static {p2}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->fixedInputData:[B
goto :goto_1a
.line 44
:cond_39
iput p3, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->r:I
.line 46
iput-boolean p4, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->useCounter:Z
.line 47
return-void
.end method
.method public static createWithCounter([B[BI)Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;
.registers 5
.prologue
.line 52
new-instance v0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;
const/4 v1, 0x1
invoke-direct {v0, p0, p1, p2, v1}, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;-><init>([B[BIZ)V
return-object v0
.end method
.method public static createWithoutCounter([B[B)Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;
.registers 5
.prologue
.line 58
new-instance v0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;
const/16 v1, 0x20
const/4 v2, 0x0
invoke-direct {v0, p0, p1, v1, v2}, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;-><init>([B[BIZ)V
return-object v0
.end method
# virtual methods
.method public final getFixedInputData()[B
.registers 2
.prologue
.line 78
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->fixedInputData:[B
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
return-object v0
.end method
.method public final getKI()[B
.registers 2
.prologue
.line 63
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->ki:[B
return-object v0
.end method
.method public final getR()I
.registers 2
.prologue
.line 73
iget v0, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->r:I
return v0
.end method
.method public final useCounter()Z
.registers 2
.prologue
.line 68
iget-boolean v0, p0, Lorg/spongycastle/crypto/params/KDFDoublePipelineIterationParameters;->useCounter:Z
return v0
.end method