OpenSSLEvpCipher.smali
.class public abstract Lorg/conscrypt/OpenSSLEvpCipher;
.super Lorg/conscrypt/OpenSSLCipher;
.source ""
# instance fields
.field private calledUpdate:Z
.field private final cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
.field private modeBlockSize:I
# direct methods
.method public constructor <init>(Lorg/conscrypt/OpenSSLCipher$Mode;Lorg/conscrypt/OpenSSLCipher$Padding;)V
.registers 5
invoke-direct {p0, p1, p2}, Lorg/conscrypt/OpenSSLCipher;-><init>(Lorg/conscrypt/OpenSSLCipher$Mode;Lorg/conscrypt/OpenSSLCipher$Padding;)V
new-instance p1, Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
invoke-static {}, Lorg/conscrypt/NativeCrypto;->EVP_CIPHER_CTX_new()J
move-result-wide v0
invoke-direct {p1, v0, v1}, Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;-><init>(J)V
iput-object p1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
return-void
.end method
.method private reset()V
.registers 7
iget-object v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
iget-object v3, p0, Lorg/conscrypt/OpenSSLCipher;->encodedKey:[B
iget-object v4, p0, Lorg/conscrypt/OpenSSLCipher;->iv:[B
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLCipher;->isEncrypting()Z
move-result v5
const-wide/16 v1, 0x0
invoke-static/range {v0 .. v5}, Lorg/conscrypt/NativeCrypto;->EVP_CipherInit_ex(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;J[B[BZ)V
const/4 v0, 0x0
iput-boolean v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->calledUpdate:Z
return-void
.end method
# virtual methods
.method doFinalInternal([BII)I
.registers 7
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLCipher;->isEncrypting()Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_c
iget-boolean v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->calledUpdate:Z
if-nez v0, :cond_c
return v1
:cond_c
array-length v0, p1
sub-int/2addr v0, p2
if-lt v0, p3, :cond_17
iget-object p3, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
invoke-static {p3, p1, p2}, Lorg/conscrypt/NativeCrypto;->EVP_CipherFinal_ex(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;[BI)I
move-result p1
goto :goto_27
:cond_17
new-array p3, p3, [B
iget-object v2, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
invoke-static {v2, p3, v1}, Lorg/conscrypt/NativeCrypto;->EVP_CipherFinal_ex(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;[BI)I
move-result v2
if-gt v2, v0, :cond_2d
if-lez v2, :cond_26
invoke-static {p3, v1, p1, p2, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
:cond_26
move p1, v2
:goto_27
add-int/2addr p1, p2
invoke-direct {p0}, Lorg/conscrypt/OpenSSLEvpCipher;->reset()V
sub-int/2addr p1, p2
return p1
:cond_2d
new-instance p1, Lorg/conscrypt/ShortBufferWithoutStackTraceException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p3, "buffer is too short: "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p3, " > "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Lorg/conscrypt/ShortBufferWithoutStackTraceException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method engineInitInternal([BLjava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
.registers 11
instance-of v0, p2, Ljavax/crypto/spec/IvParameterSpec;
if-eqz v0, :cond_b
check-cast p2, Ljavax/crypto/spec/IvParameterSpec;
invoke-virtual {p2}, Ljavax/crypto/spec/IvParameterSpec;->getIV()[B
move-result-object p2
goto :goto_c
:cond_b
const/4 p2, 0x0
:goto_c
array-length v0, p1
iget-object v1, p0, Lorg/conscrypt/OpenSSLCipher;->mode:Lorg/conscrypt/OpenSSLCipher$Mode;
invoke-virtual {p0, v0, v1}, Lorg/conscrypt/OpenSSLEvpCipher;->getCipherName(ILorg/conscrypt/OpenSSLCipher$Mode;)Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lorg/conscrypt/NativeCrypto;->EVP_get_cipherbyname(Ljava/lang/String;)J
move-result-wide v2
const-wide/16 v0, 0x0
cmp-long v4, v2, v0
if-eqz v4, :cond_e0
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLCipher;->isEncrypting()Z
move-result v6
invoke-static {v2, v3}, Lorg/conscrypt/NativeCrypto;->EVP_CIPHER_iv_length(J)I
move-result v0
const-string v1, " mode"
if-nez p2, :cond_55
if-eqz v0, :cond_55
if-eqz v6, :cond_39
new-array p2, v0, [B
if-eqz p3, :cond_35
invoke-virtual {p3, p2}, Ljava/security/SecureRandom;->nextBytes([B)V
goto :goto_9c
:cond_35
invoke-static {p2}, Lorg/conscrypt/NativeCrypto;->RAND_bytes([B)V
goto :goto_9c
:cond_39
new-instance p1, Ljava/security/InvalidAlgorithmParameterException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p3, "IV must be specified in "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p3, p0, Lorg/conscrypt/OpenSSLCipher;->mode:Lorg/conscrypt/OpenSSLCipher$Mode;
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw p1
:cond_55
if-nez v0, :cond_76
if-nez p2, :cond_5a
goto :goto_76
:cond_5a
new-instance p1, Ljava/security/InvalidAlgorithmParameterException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p3, "IV not used in "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p3, p0, Lorg/conscrypt/OpenSSLCipher;->mode:Lorg/conscrypt/OpenSSLCipher$Mode;
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw p1
:cond_76
:goto_76
if-eqz p2, :cond_9c
array-length p3, p2
if-ne p3, v0, :cond_7c
goto :goto_9c
:cond_7c
new-instance p1, Ljava/security/InvalidAlgorithmParameterException;
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "expected IV length of "
invoke-virtual {p3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v0, " but was "
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
array-length p2, p2
invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw p1
:cond_9c
:goto_9c
iput-object p2, p0, Lorg/conscrypt/OpenSSLCipher;->iv:[B
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLCipher;->supportsVariableSizeKey()Z
move-result p3
iget-object v1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
if-eqz p3, :cond_bf
const/4 v4, 0x0
const/4 v5, 0x0
invoke-static/range {v1 .. v6}, Lorg/conscrypt/NativeCrypto;->EVP_CipherInit_ex(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;J[B[BZ)V
iget-object p3, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
array-length v0, p1
invoke-static {p3, v0}, Lorg/conscrypt/NativeCrypto;->EVP_CIPHER_CTX_set_key_length(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;I)V
iget-object v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
const-wide/16 v1, 0x0
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLCipher;->isEncrypting()Z
move-result v5
move-object v3, p1
move-object v4, p2
invoke-static/range {v0 .. v5}, Lorg/conscrypt/NativeCrypto;->EVP_CipherInit_ex(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;J[B[BZ)V
goto :goto_c4
:cond_bf
move-object v4, p1
move-object v5, p2
invoke-static/range {v1 .. v6}, Lorg/conscrypt/NativeCrypto;->EVP_CipherInit_ex(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;J[B[BZ)V
:goto_c4
iget-object p1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLCipher;->getPadding()Lorg/conscrypt/OpenSSLCipher$Padding;
move-result-object p2
sget-object p3, Lorg/conscrypt/OpenSSLCipher$Padding;->PKCS5PADDING:Lorg/conscrypt/OpenSSLCipher$Padding;
const/4 v0, 0x0
if-ne p2, p3, :cond_d1
const/4 p2, 0x1
goto :goto_d2
:cond_d1
const/4 p2, 0x0
:goto_d2
invoke-static {p1, p2}, Lorg/conscrypt/NativeCrypto;->EVP_CIPHER_CTX_set_padding(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;Z)V
iget-object p1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
invoke-static {p1}, Lorg/conscrypt/NativeCrypto;->EVP_CIPHER_CTX_block_size(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;)I
move-result p1
iput p1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->modeBlockSize:I
iput-boolean v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->calledUpdate:Z
return-void
:cond_e0
new-instance p2, Ljava/security/InvalidAlgorithmParameterException;
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Cannot find name for key length = "
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
array-length p1, p1
mul-int/lit8 p1, p1, 0x8
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p1, " and mode = "
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p1, p0, Lorg/conscrypt/OpenSSLCipher;->mode:Lorg/conscrypt/OpenSSLCipher$Mode;
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/security/InvalidAlgorithmParameterException;-><init>(Ljava/lang/String;)V
throw p2
.end method
.method abstract getCipherName(ILorg/conscrypt/OpenSSLCipher$Mode;)Ljava/lang/String;
.end method
.method getOutputSizeForFinal(I)I
.registers 5
iget v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->modeBlockSize:I
const/4 v1, 0x1
if-ne v0, v1, :cond_6
return p1
:cond_6
iget-object v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
invoke-static {v0}, Lorg/conscrypt/NativeCrypto;->get_EVP_CIPHER_CTX_buf_len(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;)I
move-result v0
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLCipher;->getPadding()Lorg/conscrypt/OpenSSLCipher$Padding;
move-result-object v1
sget-object v2, Lorg/conscrypt/OpenSSLCipher$Padding;->NOPADDING:Lorg/conscrypt/OpenSSLCipher$Padding;
if-ne v1, v2, :cond_16
add-int/2addr v0, p1
return v0
:cond_16
iget-object v1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
invoke-static {v1}, Lorg/conscrypt/NativeCrypto;->get_EVP_CIPHER_CTX_final_used(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;)Z
move-result v1
add-int/2addr p1, v0
const/4 v0, 0x0
if-eqz v1, :cond_23
iget v1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->modeBlockSize:I
goto :goto_24
:cond_23
const/4 v1, 0x0
:goto_24
add-int/2addr p1, v1
iget v1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->modeBlockSize:I
rem-int v1, p1, v1
if-nez v1, :cond_31
invoke-virtual {p0}, Lorg/conscrypt/OpenSSLCipher;->isEncrypting()Z
move-result v1
if-eqz v1, :cond_33
:cond_31
iget v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->modeBlockSize:I
:cond_33
add-int/2addr p1, v0
iget v0, p0, Lorg/conscrypt/OpenSSLEvpCipher;->modeBlockSize:I
rem-int v0, p1, v0
sub-int/2addr p1, v0
return p1
.end method
.method getOutputSizeForUpdate(I)I
.registers 2
invoke-virtual {p0, p1}, Lorg/conscrypt/OpenSSLEvpCipher;->getOutputSizeForFinal(I)I
move-result p1
return p1
.end method
.method updateInternal([BII[BII)I
.registers 14
array-length v0, p4
sub-int/2addr v0, p5
if-lt v0, p6, :cond_15
iget-object v1, p0, Lorg/conscrypt/OpenSSLEvpCipher;->cipherCtx:Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;
move-object v2, p4
move v3, p5
move-object v4, p1
move v5, p2
move v6, p3
invoke-static/range {v1 .. v6}, Lorg/conscrypt/NativeCrypto;->EVP_CipherUpdate(Lorg/conscrypt/NativeRef$EVP_CIPHER_CTX;[BI[BII)I
move-result p1
add-int/2addr p1, p5
const/4 p2, 0x1
iput-boolean p2, p0, Lorg/conscrypt/OpenSSLEvpCipher;->calledUpdate:Z
sub-int/2addr p1, p5
return p1
:cond_15
new-instance p1, Lorg/conscrypt/ShortBufferWithoutStackTraceException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p3, "output buffer too small during update: "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p3, " < "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, p6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Lorg/conscrypt/ShortBufferWithoutStackTraceException;-><init>(Ljava/lang/String;)V
throw p1
.end method