From: "Björn Töpel" <bjorn.topel@intel.com>
To: Cristian Dumitrescu <cristian.dumitrescu@intel.com>,
intel-wired-lan@lists.osuosl.org
Cc: bpf@vger.kernel.org, netdev@vger.kernel.org,
magnus.karlsson@intel.com, maciej.fijalkowski@intel.com
Subject: Re: [PATCH net] i40e: fix potential NULL pointer dereferencing
Date: Mon, 11 Jan 2021 20:47:38 +0100 [thread overview]
Message-ID: <ac36b7b2-bf0e-c58c-754b-d9ab4dbb9cae@intel.com> (raw)
In-Reply-To: <20210111181138.49757-1-cristian.dumitrescu@intel.com>
On 2021-01-11 19:11, Cristian Dumitrescu wrote:
> Currently, the function i40e_construct_skb_zc only frees the input xdp
> buffer when the output skb is successfully built. On error, the
> function i40e_clean_rx_irq_zc does not commit anything for the current
> packet descriptor and simply exits the packet descriptor processing
> loop, with the plan to restart the processing of this descriptor on
> the next invocation. Therefore, on error the ring next-to-clean
> pointer should not advance, the xdp i.e. *bi buffer should not be
> freed and the current buffer info should not be invalidated by setting
> *bi to NULL. Therefore, the *bi should only be set to NULL when the
> function i40e_construct_skb_zc is successful, otherwise a NULL *bi
> will be dereferenced when the work for the current descriptor is
> eventually restarted.
>
> Fixes: 3b4f0b66c2b3 ("i40e, xsk: Migrate to new MEM_TYPE_XSK_BUFF_POOL")
> Signed-off-by: Cristian Dumitrescu <cristian.dumitrescu@intel.com>
Thanks for finding and fixing this, Cristian!
Acked-by: Björn Töpel <bjorn.topel@intel.com>
> ---
> drivers/net/ethernet/intel/i40e/i40e_xsk.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/net/ethernet/intel/i40e/i40e_xsk.c b/drivers/net/ethernet/intel/i40e/i40e_xsk.c
> index 47eb9c584a12..492ce213208d 100644
> --- a/drivers/net/ethernet/intel/i40e/i40e_xsk.c
> +++ b/drivers/net/ethernet/intel/i40e/i40e_xsk.c
> @@ -348,12 +348,12 @@ int i40e_clean_rx_irq_zc(struct i40e_ring *rx_ring, int budget)
> * SBP is *not* set in PRT_SBPVSI (default not set).
> */
> skb = i40e_construct_skb_zc(rx_ring, *bi);
> - *bi = NULL;
> if (!skb) {
> rx_ring->rx_stats.alloc_buff_failed++;
> break;
> }
>
> + *bi = NULL;
> cleaned_count++;
> i40e_inc_ntc(rx_ring);
>
>
WARNING: multiple messages have this Message-ID (diff)
From: =?unknown-8bit?q?Bj=C3=B6rn_T=C3=B6pel?= <bjorn.topel@intel.com>
To: intel-wired-lan@osuosl.org
Subject: [Intel-wired-lan] [PATCH net] i40e: fix potential NULL pointer dereferencing
Date: Mon, 11 Jan 2021 20:47:38 +0100 [thread overview]
Message-ID: <ac36b7b2-bf0e-c58c-754b-d9ab4dbb9cae@intel.com> (raw)
In-Reply-To: <20210111181138.49757-1-cristian.dumitrescu@intel.com>
On 2021-01-11 19:11, Cristian Dumitrescu wrote:
> Currently, the function i40e_construct_skb_zc only frees the input xdp
> buffer when the output skb is successfully built. On error, the
> function i40e_clean_rx_irq_zc does not commit anything for the current
> packet descriptor and simply exits the packet descriptor processing
> loop, with the plan to restart the processing of this descriptor on
> the next invocation. Therefore, on error the ring next-to-clean
> pointer should not advance, the xdp i.e. *bi buffer should not be
> freed and the current buffer info should not be invalidated by setting
> *bi to NULL. Therefore, the *bi should only be set to NULL when the
> function i40e_construct_skb_zc is successful, otherwise a NULL *bi
> will be dereferenced when the work for the current descriptor is
> eventually restarted.
>
> Fixes: 3b4f0b66c2b3 ("i40e, xsk: Migrate to new MEM_TYPE_XSK_BUFF_POOL")
> Signed-off-by: Cristian Dumitrescu <cristian.dumitrescu@intel.com>
Thanks for finding and fixing this, Cristian!
Acked-by: Bj?rn T?pel <bjorn.topel@intel.com>
> ---
> drivers/net/ethernet/intel/i40e/i40e_xsk.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/net/ethernet/intel/i40e/i40e_xsk.c b/drivers/net/ethernet/intel/i40e/i40e_xsk.c
> index 47eb9c584a12..492ce213208d 100644
> --- a/drivers/net/ethernet/intel/i40e/i40e_xsk.c
> +++ b/drivers/net/ethernet/intel/i40e/i40e_xsk.c
> @@ -348,12 +348,12 @@ int i40e_clean_rx_irq_zc(struct i40e_ring *rx_ring, int budget)
> * SBP is *not* set in PRT_SBPVSI (default not set).
> */
> skb = i40e_construct_skb_zc(rx_ring, *bi);
> - *bi = NULL;
> if (!skb) {
> rx_ring->rx_stats.alloc_buff_failed++;
> break;
> }
>
> + *bi = NULL;
> cleaned_count++;
> i40e_inc_ntc(rx_ring);
>
>
next prev parent reply other threads:[~2021-01-11 19:48 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-01-11 18:11 [PATCH net] i40e: fix potential NULL pointer dereferencing Cristian Dumitrescu
2021-01-11 18:11 ` [Intel-wired-lan] " Cristian Dumitrescu
2021-01-11 19:47 ` Björn Töpel [this message]
2021-01-11 19:47 ` =?unknown-8bit?q?Bj=C3=B6rn_T=C3=B6pel?=
2021-01-14 3:40 ` patchwork-bot+netdevbpf
2021-01-14 3:40 ` [Intel-wired-lan] " patchwork-bot+netdevbpf
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ac36b7b2-bf0e-c58c-754b-d9ab4dbb9cae@intel.com \
--to=bjorn.topel@intel.com \
--cc=bpf@vger.kernel.org \
--cc=cristian.dumitrescu@intel.com \
--cc=intel-wired-lan@lists.osuosl.org \
--cc=maciej.fijalkowski@intel.com \
--cc=magnus.karlsson@intel.com \
--cc=netdev@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.