PGPCFBBlockCipher.smali
.class public Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;
.super Ljava/lang/Object;
.source "PGPCFBBlockCipher.java"
# interfaces
.implements Lorg/spongycastle/crypto/BlockCipher;
# instance fields
.field private FR:[B
.field private FRE:[B
.field private IV:[B
.field private blockSize:I
.field private cipher:Lorg/spongycastle/crypto/BlockCipher;
.field private count:I
.field private forEncryption:Z
.field private inlineIv:Z
.field private tmp:[B
# direct methods
.method public constructor <init>(Lorg/spongycastle/crypto/BlockCipher;Z)V
.registers 4
.prologue
.line 37
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 38
iput-object p1, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
.line 39
iput-boolean p2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->inlineIv:Z
.line 41
invoke-interface {p1}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v0
iput v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
.line 42
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
.line 43
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
.line 44
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
.line 45
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
new-array v0, v0, [B
iput-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
.line 46
return-void
.end method
.method private decryptBlock([BI[BI)I
.registers 9
.prologue
const/4 v1, 0x0
.line 431
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p2
array-length v2, p1
if-le v0, v2, :cond_f
.line 433
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "input buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 436
:cond_f
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p4
array-length v2, p3
if-le v0, v2, :cond_1d
.line 438
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "output buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 441
:cond_1d
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
move v0, v1
.line 442
:goto_27
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ge v0, v2, :cond_3a
.line 444
add-int v2, p4, v0
add-int v3, p2, v0
aget-byte v3, p1, v3
invoke-direct {p0, v3, v0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v3
aput-byte v3, p3, v2
.line 442
add-int/lit8 v0, v0, 0x1
goto :goto_27
.line 447
:cond_3a
:goto_3a
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ge v1, v0, :cond_49
.line 449
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
add-int v2, p2, v1
aget-byte v2, p1, v2
aput-byte v2, v0, v1
.line 447
add-int/lit8 v1, v1, 0x1
goto :goto_3a
.line 452
:cond_49
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
return v0
.end method
.method private decryptBlockWithIV([BI[BI)I
.registers 11
.prologue
const/4 v4, 0x1
const/4 v5, 0x2
const/4 v1, 0x0
.line 298
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p2
array-length v2, p1
if-le v0, v2, :cond_11
.line 300
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "input buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 303
:cond_11
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p4
array-length v2, p3
if-le v0, v2, :cond_1f
.line 305
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "output buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 308
:cond_1f
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
if-nez v0, :cond_44
move v0, v1
.line 310
:goto_24
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ge v0, v2, :cond_33
.line 312
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
add-int v3, p2, v0
aget-byte v3, p1, v3
aput-byte v3, v2, v0
.line 310
add-int/lit8 v0, v0, 0x1
goto :goto_24
.line 315
:cond_33
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
.line 317
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, v2
iput v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
.line 365
:goto_43
return v1
.line 321
:cond_44
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ne v0, v2, :cond_ab
.line 324
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
invoke-static {p1, p2, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 326
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v3, v3, -0x2
invoke-static {v0, v5, v2, v1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 328
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v2, v2, -0x2
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
aget-byte v3, v3, v1
aput-byte v3, v0, v2
.line 329
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v2, v2, -0x1
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
aget-byte v3, v3, v4
aput-byte v3, v0, v2
.line 331
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
move v0, v1
.line 333
:goto_7e
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v2, v2, -0x2
if-ge v0, v2, :cond_95
.line 335
add-int v2, p4, v0
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
add-int/lit8 v4, v0, 0x2
aget-byte v3, v3, v4
invoke-direct {p0, v3, v0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v3
aput-byte v3, p3, v2
.line 333
add-int/lit8 v0, v0, 0x1
goto :goto_7e
.line 338
:cond_95
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v3, v3, -0x2
invoke-static {v0, v5, v2, v1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 340
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
add-int/lit8 v0, v0, 0x2
iput v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
.line 342
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v1, v0, -0x2
goto :goto_43
.line 344
:cond_ab
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v2, v2, 0x2
if-lt v0, v2, :cond_111
.line 347
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
invoke-static {p1, p2, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 349
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
aget-byte v0, v0, v1
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v2, v2, -0x2
invoke-direct {p0, v0, v2}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v0
aput-byte v0, p3, p4
.line 350
add-int/lit8 v0, p4, 0x1
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
aget-byte v2, v2, v4
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v3, v3, -0x1
invoke-direct {p0, v2, v3}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v2
aput-byte v2, p3, v0
.line 352
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v3, v3, -0x2
invoke-static {v0, v1, v2, v3, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 354
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
move v0, v1
.line 356
:goto_ed
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v2, v2, -0x2
if-ge v0, v2, :cond_106
.line 358
add-int v2, p4, v0
add-int/lit8 v2, v2, 0x2
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
add-int/lit8 v4, v0, 0x2
aget-byte v3, v3, v4
invoke-direct {p0, v3, v0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v3
aput-byte v3, p3, v2
.line 356
add-int/lit8 v0, v0, 0x1
goto :goto_ed
.line 361
:cond_106
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->tmp:[B
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v3, v3, -0x2
invoke-static {v0, v5, v2, v1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 365
:cond_111
iget v1, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
goto/16 :goto_43
.end method
.method private encryptBlock([BI[BI)I
.registers 9
.prologue
const/4 v1, 0x0
.line 387
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p2
array-length v2, p1
if-le v0, v2, :cond_f
.line 389
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "input buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 392
:cond_f
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p4
array-length v2, p3
if-le v0, v2, :cond_1d
.line 394
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "output buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 397
:cond_1d
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
move v0, v1
.line 398
:goto_27
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ge v0, v2, :cond_3a
.line 400
add-int v2, p4, v0
add-int v3, p2, v0
aget-byte v3, p1, v3
invoke-direct {p0, v3, v0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v3
aput-byte v3, p3, v2
.line 398
add-int/lit8 v0, v0, 0x1
goto :goto_27
.line 403
:cond_3a
:goto_3a
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ge v1, v0, :cond_49
.line 405
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
add-int v2, p4, v1
aget-byte v2, p3, v2
aput-byte v2, v0, v1
.line 403
add-int/lit8 v1, v1, 0x1
goto :goto_3a
.line 408
:cond_49
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
return v0
.end method
.method private encryptBlockWithIV([BI[BI)I
.registers 9
.prologue
const/4 v1, 0x0
.line 218
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p2
array-length v2, p1
if-le v0, v2, :cond_f
.line 220
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "input buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 223
:cond_f
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
if-nez v0, :cond_bf
.line 225
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
mul-int/lit8 v0, v0, 0x2
add-int/2addr v0, p4
add-int/lit8 v0, v0, 0x2
array-length v2, p3
if-le v0, v2, :cond_25
.line 227
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "output buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 230
:cond_25
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
move v0, v1
.line 232
:goto_2f
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ge v0, v2, :cond_42
.line 234
add-int v2, p4, v0
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
aget-byte v3, v3, v0
invoke-direct {p0, v3, v0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v3
aput-byte v3, p3, v2
.line 232
add-int/lit8 v0, v0, 0x1
goto :goto_2f
.line 237
:cond_42
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
invoke-static {p3, p4, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 239
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
.line 241
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p4
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v3, v3, -0x2
aget-byte v2, v2, v3
invoke-direct {p0, v2, v1}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v2
aput-byte v2, p3, v0
.line 242
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p4
add-int/lit8 v0, v0, 0x1
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v3, v3, -0x1
aget-byte v2, v2, v3
const/4 v3, 0x1
invoke-direct {p0, v2, v3}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v2
aput-byte v2, p3, v0
.line 244
add-int/lit8 v0, p4, 0x2
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
invoke-static {p3, v0, v2, v1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 246
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
move v0, v1
.line 248
:goto_8a
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ge v0, v2, :cond_a1
.line 250
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v2, p4
add-int/lit8 v2, v2, 0x2
add-int/2addr v2, v0
add-int v3, p2, v0
aget-byte v3, p1, v3
invoke-direct {p0, v3, v0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v3
aput-byte v3, p3, v2
.line 248
add-int/lit8 v0, v0, 0x1
goto :goto_8a
.line 253
:cond_a1
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p4
add-int/lit8 v0, v0, 0x2
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
invoke-static {p3, v0, v2, v1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 255
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
iget v1, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
mul-int/lit8 v1, v1, 0x2
add-int/lit8 v1, v1, 0x2
add-int/2addr v0, v1
iput v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
.line 257
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
mul-int/lit8 v0, v0, 0x2
add-int/lit8 v0, v0, 0x2
.line 276
:goto_be
return v0
.line 259
:cond_bf
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/lit8 v2, v2, 0x2
if-lt v0, v2, :cond_f9
.line 261
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
add-int/2addr v0, p4
array-length v2, p3
if-le v0, v2, :cond_d5
.line 263
new-instance v0, Lorg/spongycastle/crypto/DataLengthException;
const-string v1, "output buffer too short"
invoke-direct {v0, v1}, Lorg/spongycastle/crypto/DataLengthException;-><init>(Ljava/lang/String;)V
throw v0
.line 266
:cond_d5
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
invoke-interface {v0, v2, v1, v3, v1}, Lorg/spongycastle/crypto/BlockCipher;->processBlock([BI[BI)I
move v0, v1
.line 268
:goto_df
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
if-ge v0, v2, :cond_f2
.line 270
add-int v2, p4, v0
add-int v3, p2, v0
aget-byte v3, p1, v3
invoke-direct {p0, v3, v0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptByte(BI)B
move-result v3
aput-byte v3, p3, v2
.line 268
add-int/lit8 v0, v0, 0x1
goto :goto_df
.line 273
:cond_f2
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
invoke-static {p3, p4, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 276
:cond_f9
iget v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->blockSize:I
goto :goto_be
.end method
.method private encryptByte(BI)B
.registers 4
.prologue
.line 196
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FRE:[B
aget-byte v0, v0, p2
xor-int/2addr v0, p1
int-to-byte v0, v0
return v0
.end method
# virtual methods
.method public getAlgorithmName()Ljava/lang/String;
.registers 3
.prologue
.line 66
iget-boolean v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->inlineIv:Z
if-eqz v0, :cond_1e
.line 68
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v1, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v1}, Lorg/spongycastle/crypto/BlockCipher;->getAlgorithmName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "/PGPCFBwithIV"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 72
:goto_1d
return-object v0
:cond_1e
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v1, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v1}, Lorg/spongycastle/crypto/BlockCipher;->getAlgorithmName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "/PGPCFB"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
goto :goto_1d
.end method
.method public getBlockSize()I
.registers 2
.prologue
.line 83
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v0}, Lorg/spongycastle/crypto/BlockCipher;->getBlockSize()I
move-result v0
return v0
.end method
.method public getUnderlyingCipher()Lorg/spongycastle/crypto/BlockCipher;
.registers 2
.prologue
.line 55
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
return-object v0
.end method
.method public init(ZLorg/spongycastle/crypto/CipherParameters;)V
.registers 9
.prologue
const/4 v5, 0x1
const/4 v1, 0x0
.line 155
iput-boolean p1, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->forEncryption:Z
.line 157
instance-of v0, p2, Lorg/spongycastle/crypto/params/ParametersWithIV;
if-eqz v0, :cond_43
.line 159
check-cast p2, Lorg/spongycastle/crypto/params/ParametersWithIV;
.line 160
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getIV()[B
move-result-object v2
.line 162
array-length v0, v2
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
array-length v3, v3
if-ge v0, v3, :cond_2e
.line 165
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
array-length v3, v3
array-length v4, v2
sub-int/2addr v3, v4
array-length v4, v2
invoke-static {v2, v1, v0, v3, v4}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
move v0, v1
.line 166
:goto_20
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
array-length v3, v3
array-length v4, v2
sub-int/2addr v3, v4
if-ge v0, v3, :cond_36
.line 168
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
aput-byte v1, v3, v0
.line 166
add-int/lit8 v0, v0, 0x1
goto :goto_20
.line 173
:cond_2e
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
array-length v3, v3
invoke-static {v2, v1, v0, v1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 176
:cond_36
invoke-virtual {p0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->reset()V
.line 178
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-virtual {p2}, Lorg/spongycastle/crypto/params/ParametersWithIV;->getParameters()Lorg/spongycastle/crypto/CipherParameters;
move-result-object v1
invoke-interface {v0, v5, v1}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
.line 186
:goto_42
return-void
.line 182
:cond_43
invoke-virtual {p0}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->reset()V
.line 184
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v0, v5, p2}, Lorg/spongycastle/crypto/BlockCipher;->init(ZLorg/spongycastle/crypto/CipherParameters;)V
goto :goto_42
.end method
.method public processBlock([BI[BI)I
.registers 6
.prologue
.line 106
iget-boolean v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->inlineIv:Z
if-eqz v0, :cond_12
.line 108
iget-boolean v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->forEncryption:Z
if-eqz v0, :cond_d
invoke-direct {p0, p1, p2, p3, p4}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptBlockWithIV([BI[BI)I
move-result v0
.line 112
:goto_c
return v0
.line 108
:cond_d
invoke-direct {p0, p1, p2, p3, p4}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->decryptBlockWithIV([BI[BI)I
move-result v0
goto :goto_c
.line 112
:cond_12
iget-boolean v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->forEncryption:Z
if-eqz v0, :cond_1b
invoke-direct {p0, p1, p2, p3, p4}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->encryptBlock([BI[BI)I
move-result v0
goto :goto_c
:cond_1b
invoke-direct {p0, p1, p2, p3, p4}, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->decryptBlock([BI[BI)I
move-result v0
goto :goto_c
.end method
.method public reset()V
.registers 5
.prologue
const/4 v1, 0x0
.line 122
iput v1, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->count:I
move v0, v1
.line 124
:goto_4
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
array-length v2, v2
if-eq v0, v2, :cond_1d
.line 126
iget-boolean v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->inlineIv:Z
if-eqz v2, :cond_14
.line 128
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
aput-byte v1, v2, v0
.line 124
:goto_11
add-int/lit8 v0, v0, 0x1
goto :goto_4
.line 132
:cond_14
iget-object v2, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->FR:[B
iget-object v3, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->IV:[B
aget-byte v3, v3, v0
aput-byte v3, v2, v0
goto :goto_11
.line 136
:cond_1d
iget-object v0, p0, Lorg/spongycastle/crypto/modes/PGPCFBBlockCipher;->cipher:Lorg/spongycastle/crypto/BlockCipher;
invoke-interface {v0}, Lorg/spongycastle/crypto/BlockCipher;->reset()V
.line 137
return-void
.end method