AesFlushingCipher.smali
.class public final Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;
.super Ljava/lang/Object;
.source "AesFlushingCipher.java"
# instance fields
.field private final blockSize:I
.field private final cipher:Ljavax/crypto/Cipher;
.field private final flushedBlock:[B
.field private pendingXorBytes:I
.field private final zerosBlock:[B
# direct methods
.method public constructor <init>(I[BJJ)V
.registers 12
.line 44
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
:try_start_3
const-string v0, "AES/CTR/NoPadding"
.line 46
invoke-static {v0}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
move-result-object v0
iput-object v0, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->cipher:Ljavax/crypto/Cipher;
.line 47
invoke-virtual {v0}, Ljavax/crypto/Cipher;->getBlockSize()I
move-result v0
iput v0, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->blockSize:I
.line 48
new-array v1, v0, [B
iput-object v1, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->zerosBlock:[B
.line 49
new-array v1, v0, [B
iput-object v1, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->flushedBlock:[B
int-to-long v1, v0
.line 50
div-long v1, p5, v1
int-to-long v3, v0
.line 51
rem-long/2addr p5, v3
long-to-int p6, p5
.line 52
iget-object p5, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->cipher:Ljavax/crypto/Cipher;
new-instance v0, Ljavax/crypto/spec/SecretKeySpec;
iget-object v3, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->cipher:Ljavax/crypto/Cipher;
invoke-virtual {v3}, Ljavax/crypto/Cipher;->getAlgorithm()Ljava/lang/String;
move-result-object v3
const-string v4, "/"
invoke-virtual {v3, v4}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v3
const/4 v4, 0x0
aget-object v3, v3, v4
invoke-direct {v0, p2, v3}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
new-instance p2, Ljavax/crypto/spec/IvParameterSpec;
.line 53
invoke-direct {p0, p3, p4, v1, v2}, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->getInitializationVector(JJ)[B
move-result-object p3
invoke-direct {p2, p3}, Ljavax/crypto/spec/IvParameterSpec;-><init>([B)V
.line 52
invoke-virtual {p5, p1, v0, p2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
if-eqz p6, :cond_48
.line 55
new-array p1, p6, [B
invoke-virtual {p0, p1, v4, p6}, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->updateInPlace([BII)V
:try_end_48
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_3 .. :try_end_48} :catch_4f
.catch Ljavax/crypto/NoSuchPaddingException; {:try_start_3 .. :try_end_48} :catch_4d
.catch Ljava/security/InvalidKeyException; {:try_start_3 .. :try_end_48} :catch_4b
.catch Ljava/security/InvalidAlgorithmParameterException; {:try_start_3 .. :try_end_48} :catch_49
:cond_48
return-void
:catch_49
move-exception p1
goto :goto_50
:catch_4b
move-exception p1
goto :goto_50
:catch_4d
move-exception p1
goto :goto_50
:catch_4f
move-exception p1
.line 60
:goto_50
new-instance p2, Ljava/lang/RuntimeException;
invoke-direct {p2, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw p2
.end method
.method private getInitializationVector(JJ)[B
.registers 6
const/16 v0, 0x10
.line 117
invoke-static {v0}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v0
invoke-virtual {v0, p1, p2}, Ljava/nio/ByteBuffer;->putLong(J)Ljava/nio/ByteBuffer;
move-result-object p1
invoke-virtual {p1, p3, p4}, Ljava/nio/ByteBuffer;->putLong(J)Ljava/nio/ByteBuffer;
move-result-object p1
invoke-virtual {p1}, Ljava/nio/ByteBuffer;->array()[B
move-result-object p1
return-object p1
.end method
.method private nonFlushingUpdate([BII[BI)I
.registers 12
.line 109
:try_start_0
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->cipher:Ljavax/crypto/Cipher;
move-object v1, p1
move v2, p2
move v3, p3
move-object v4, p4
move v5, p5
invoke-virtual/range {v0 .. v5}, Ljavax/crypto/Cipher;->update([BII[BI)I
move-result p1
:try_end_b
.catch Ljavax/crypto/ShortBufferException; {:try_start_0 .. :try_end_b} :catch_c
return p1
:catch_c
move-exception p1
.line 112
new-instance p2, Ljava/lang/RuntimeException;
invoke-direct {p2, p1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw p2
.end method
# virtual methods
.method public update([BII[BI)V
.registers 14
move v2, p2
.line 72
:cond_1
iget p2, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->pendingXorBytes:I
if-lez p2, :cond_1f
.line 73
aget-byte v0, p1, v2
iget-object v1, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->flushedBlock:[B
iget v3, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->blockSize:I
sub-int/2addr v3, p2
aget-byte v1, v1, v3
xor-int/2addr v0, v1
int-to-byte v0, v0
aput-byte v0, p4, p5
add-int/lit8 p5, p5, 0x1
add-int/lit8 v2, v2, 0x1
add-int/lit8 p2, p2, -0x1
.line 76
iput p2, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->pendingXorBytes:I
add-int/lit8 p3, p3, -0x1
if-nez p3, :cond_1
return-void
:cond_1f
move-object v0, p0
move-object v1, p1
move v3, p3
move-object v4, p4
move v5, p5
.line 84
invoke-direct/range {v0 .. v5}, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->nonFlushingUpdate([BII[BI)I
move-result p1
if-ne p3, p1, :cond_2b
return-void
:cond_2b
sub-int/2addr p3, p1
.line 95
iget p2, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->blockSize:I
const/4 v0, 0x0
const/4 v1, 0x1
if-ge p3, p2, :cond_34
const/4 p2, 0x1
goto :goto_35
:cond_34
const/4 p2, 0x0
:goto_35
invoke-static {p2}, Lcom/google/android/exoplayer2/util/Assertions;->checkState(Z)V
add-int/2addr p5, p1
.line 97
iget p1, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->blockSize:I
sub-int v5, p1, p3
iput v5, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->pendingXorBytes:I
.line 98
iget-object v3, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->zerosBlock:[B
const/4 v4, 0x0
iget-object v6, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->flushedBlock:[B
const/4 v7, 0x0
move-object v2, p0
invoke-direct/range {v2 .. v7}, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->nonFlushingUpdate([BII[BI)I
move-result p1
.line 99
iget p2, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->blockSize:I
if-ne p1, p2, :cond_4f
goto :goto_50
:cond_4f
const/4 v1, 0x0
:goto_50
invoke-static {v1}, Lcom/google/android/exoplayer2/util/Assertions;->checkState(Z)V
:goto_53
if-ge v0, p3, :cond_61
add-int/lit8 p1, p5, 0x1
.line 103
iget-object p2, p0, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->flushedBlock:[B
aget-byte p2, p2, v0
aput-byte p2, p4, p5
add-int/lit8 v0, v0, 0x1
move p5, p1
goto :goto_53
:cond_61
return-void
.end method
.method public updateInPlace([BII)V
.registers 10
move-object v0, p0
move-object v1, p1
move v2, p2
move v3, p3
move-object v4, p1
move v5, p2
.line 65
invoke-virtual/range {v0 .. v5}, Lcom/google/android/exoplayer2/upstream/crypto/AesFlushingCipher;->update([BII[BI)V
return-void
.end method