]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
xsk: tighten UMEM headroom validation to account for tailroom and min frame
authorMaciej Fijalkowski <maciej.fijalkowski@intel.com>
Thu, 2 Apr 2026 15:49:51 +0000 (17:49 +0200)
committerJakub Kicinski <kuba@kernel.org>
Tue, 7 Apr 2026 01:43:51 +0000 (18:43 -0700)
The current headroom validation in xdp_umem_reg() could leave us with
insufficient space dedicated to even receive minimum-sized ethernet
frame. Furthermore if multi-buffer would come to play then
skb_shared_info stored at the end of XSK frame would be corrupted.

HW typically works with 128-aligned sizes so let us provide this value
as bare minimum.

Multi-buffer setting is known later in the configuration process so
besides accounting for 128 bytes, let us also take care of tailroom space
upfront.

Reviewed-by: Björn Töpel <bjorn@kernel.org>
Acked-by: Stanislav Fomichev <sdf@fomichev.me>
Fixes: 99e3a236dd43 ("xsk: Add missing check on user supplied headroom size")
Signed-off-by: Maciej Fijalkowski <maciej.fijalkowski@intel.com>
Link: https://patch.msgid.link/20260402154958.562179-2-maciej.fijalkowski@intel.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/xdp/xdp_umem.c

index 066ce07c506d51938c88c4c511f550c187e837e5..58da2f4f4397aafbeea8a93e03849dd8416ac112 100644 (file)
@@ -203,7 +203,8 @@ static int xdp_umem_reg(struct xdp_umem *umem, struct xdp_umem_reg *mr)
        if (!unaligned_chunks && chunks_rem)
                return -EINVAL;
 
-       if (headroom >= chunk_size - XDP_PACKET_HEADROOM)
+       if (headroom > chunk_size - XDP_PACKET_HEADROOM -
+                      SKB_DATA_ALIGN(sizeof(struct skb_shared_info)) - 128)
                return -EINVAL;
 
        if (mr->flags & XDP_UMEM_TX_METADATA_LEN) {