]> git.hungrycats.org Git - linux/commitdiff
tls: rx: move counting TlsDecryptErrors for sync
authorJakub Kicinski <kuba@kernel.org>
Mon, 11 Apr 2022 19:19:10 +0000 (12:19 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 6 Mar 2024 14:38:47 +0000 (14:38 +0000)
[ Upstream commit 284b4d93daee56dff3e10029ddf2e03227f50dbf ]

Move counting TlsDecryptErrors to tls_do_decryption()
where differences between sync and async crypto are
reconciled.

No functional changes, this code just always gave
me a pause.

Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Stable-dep-of: f7fa16d49837 ("tls: decrement decrypt_pending if no async completion will be called")
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/tls/tls_sw.c

index d3bbae9af9f4180f420c4078dd8c71d7efda3577..85fa49170b4e54b84e41556d3e7b3737ba5b0045 100644 (file)
@@ -274,6 +274,8 @@ static int tls_do_decryption(struct sock *sk,
 
                ret = crypto_wait_req(ret, &ctx->async_wait);
        }
+       if (ret == -EBADMSG)
+               TLS_INC_STATS(sock_net(sk), LINUX_MIB_TLSDECRYPTERROR);
 
        if (async)
                atomic_dec(&ctx->decrypt_pending);
@@ -1583,8 +1585,6 @@ static int decrypt_skb_update(struct sock *sk, struct sk_buff *skb,
        if (err < 0) {
                if (err == -EINPROGRESS)
                        tls_advance_record_sn(sk, prot, &tls_ctx->rx);
-               else if (err == -EBADMSG)
-                       TLS_INC_STATS(sock_net(sk), LINUX_MIB_TLSDECRYPTERROR);
                return err;
        }