Commit 52ee6ef3 authored by Doron Roberts-Kedes's avatar Doron Roberts-Kedes Committed by David S. Miller

tls: fix skb_to_sgvec returning unhandled error.

The current code does not inspect the return value of skb_to_sgvec. This
can cause a nullptr kernel panic when the malformed sgvec is passed into
the crypto request.

Checking the return value of skb_to_sgvec and skipping decryption if it
is negative fixes this problem.

Fixes: c46234eb ("tls: RX path for ktls")
Acked-by: default avatarDave Watson <davejwatson@fb.com>
Signed-off-by: default avatarDoron Roberts-Kedes <doronrk@fb.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent c643ecf3
...@@ -701,6 +701,10 @@ static int decrypt_skb(struct sock *sk, struct sk_buff *skb, ...@@ -701,6 +701,10 @@ static int decrypt_skb(struct sock *sk, struct sk_buff *skb,
nsg = skb_to_sgvec(skb, &sgin[1], nsg = skb_to_sgvec(skb, &sgin[1],
rxm->offset + tls_ctx->rx.prepend_size, rxm->offset + tls_ctx->rx.prepend_size,
rxm->full_len - tls_ctx->rx.prepend_size); rxm->full_len - tls_ctx->rx.prepend_size);
if (nsg < 0) {
ret = nsg;
goto out;
}
tls_make_aad(ctx->rx_aad_ciphertext, tls_make_aad(ctx->rx_aad_ciphertext,
rxm->full_len - tls_ctx->rx.overhead_size, rxm->full_len - tls_ctx->rx.overhead_size,
...@@ -712,6 +716,7 @@ static int decrypt_skb(struct sock *sk, struct sk_buff *skb, ...@@ -712,6 +716,7 @@ static int decrypt_skb(struct sock *sk, struct sk_buff *skb,
rxm->full_len - tls_ctx->rx.overhead_size, rxm->full_len - tls_ctx->rx.overhead_size,
skb, sk->sk_allocation); skb, sk->sk_allocation);
out:
if (sgin != &sgin_arr[0]) if (sgin != &sgin_arr[0])
kfree(sgin); kfree(sgin);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment