KDFFeedbackParameters.smali
.class public final Lorg/spongycastle/crypto/params/KDFFeedbackParameters;
.super Ljava/lang/Object;
.source "KDFFeedbackParameters.java"
# interfaces
.implements Lorg/spongycastle/crypto/DerivationParameters;
# static fields
.field private static final UNUSED_R:I = -0x1
# instance fields
.field private final fixedInputData:[B
.field private final iv:[B
.field private final ki:[B
.field private final r:I
.field private final useCounter:Z
# direct methods
.method private constructor <init>([B[B[BIZ)V
.registers 8
.prologue
const/4 v1, 0x0
.line 25
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 26
if-nez p1, :cond_e
.line 28
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 30
:cond_e
invoke-static {p1}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->ki:[B
.line 32
if-nez p3, :cond_25
.line 34
new-array v0, v1, [B
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->fixedInputData:[B
.line 41
:goto_1a
iput p4, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->r:I
.line 43
if-nez p2, :cond_2c
.line 45
new-array v0, v1, [B
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->iv:[B
.line 52
:goto_22
iput-boolean p5, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->useCounter:Z
.line 53
return-void
.line 38
:cond_25
invoke-static {p3}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->fixedInputData:[B
goto :goto_1a
.line 49
:cond_2c
invoke-static {p2}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->iv:[B
goto :goto_22
.end method
.method public static createWithCounter([B[B[BI)Lorg/spongycastle/crypto/params/KDFFeedbackParameters;
.registers 10
.prologue
.line 58
const/16 v0, 0x8
if-eq p3, v0, :cond_18
const/16 v0, 0x10
if-eq p3, v0, :cond_18
const/16 v0, 0x18
if-eq p3, v0, :cond_18
const/16 v0, 0x20
if-eq p3, v0, :cond_18
.line 60
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 63
:cond_18
new-instance v0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;
const/4 v5, 0x1
move-object v1, p0
move-object v2, p1
move-object v3, p2
move v4, p3
invoke-direct/range {v0 .. v5}, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;-><init>([B[B[BIZ)V
return-object v0
.end method
.method public static createWithoutCounter([B[B[B)Lorg/spongycastle/crypto/params/KDFFeedbackParameters;
.registers 9
.prologue
.line 69
new-instance v0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;
const/4 v4, -0x1
const/4 v5, 0x0
move-object v1, p0
move-object v2, p1
move-object v3, p2
invoke-direct/range {v0 .. v5}, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;-><init>([B[B[BIZ)V
return-object v0
.end method
# virtual methods
.method public final getFixedInputData()[B
.registers 2
.prologue
.line 94
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->fixedInputData:[B
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([B)[B
move-result-object v0
return-object v0
.end method
.method public final getIV()[B
.registers 2
.prologue
.line 79
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->iv:[B
return-object v0
.end method
.method public final getKI()[B
.registers 2
.prologue
.line 74
iget-object v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->ki:[B
return-object v0
.end method
.method public final getR()I
.registers 2
.prologue
.line 89
iget v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->r:I
return v0
.end method
.method public final useCounter()Z
.registers 2
.prologue
.line 84
iget-boolean v0, p0, Lorg/spongycastle/crypto/params/KDFFeedbackParameters;->useCounter:Z
return v0
.end method