From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-pj1-f42.google.com (mail-pj1-f42.google.com [209.85.216.42]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 674DF3E929C for ; Fri, 12 Jun 2026 11:40:59 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.216.42 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1781264460; cv=none; b=HU+mPPaqyv1bNed5irNgNxocY+ewLaOUEQd+NYauByLb5v/tAy6btlBSSCIrSimqaPrwHQi61qOojAEI9UXzFVGGYDgfc6jQLS/mykzNspSQQ0IAYClnLFMBf6RvsOOuhDg8uX3IXeY+TH2q8TOk/uZvfy67OwCJspg7p63cb5Q= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1781264460; c=relaxed/simple; bh=pJ/QyvoAyb5v+r2U61ucd8SlUzxeU1gohB/ziTC8eW8=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=GYk0hV0W1u6D1HivDEy3Y4e7SWe8ZVOkgVEVIyAsqE1ws51Z4un+odvdCwalU75gSgcepF5uE/CWnzmdiCBUyPnOd3Bogbhg3xdhuVqfA4K+qjP/3oKL32xgzGeMAiyczolAHFc4uW1d2JXNM9/dZR52BiRRfUSfZBUq9ImUde0= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=ZkQQ/xls; arc=none smtp.client-ip=209.85.216.42 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="ZkQQ/xls" Received: by mail-pj1-f42.google.com with SMTP id 98e67ed59e1d1-36ba706ab46so548202a91.1 for ; Fri, 12 Jun 2026 04:40:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1781264459; x=1781869259; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=vO5l5ehIJQy/8ncJAgfC2hVtehf0lOaUgVls6srL24o=; b=ZkQQ/xlsyAwV63tXS5gGgEoLPqFO2FFqpYWTrlvJbfQ3QDDldjuSOoIraAWjf3zc3g kiEqaOoXH2AlJcJUe7joYbPgE74K+zhAdZ5KDAuyjob0jHOtVJfjs+VGFOMBLbbLy00a PJrftoY7AxGuH8u49YdcaGiEyntBZt0oHYm9sjapdCudqkESCTueI53y4rch1VUSQ1jp jNmPln79sxzuSiNKUOhQiXxH5kl8BbyhW6xWLNiu1Wr9t6E/jF+s66lEE0MtQAQ6PAZH kvPDDRM3V/CZRuR/M+fAjlvDgfksh1/pCaA6pq39glLaalUTvHLqLh9grTd+fZ/sCal2 GzDQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1781264459; x=1781869259; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=vO5l5ehIJQy/8ncJAgfC2hVtehf0lOaUgVls6srL24o=; b=Cmf1IhvTodqtANj5NdzuEDQnzID/zXVLMSKJRxWYfzRo4FViw5gkjDYCUbd+Y64O7+ CsRDfLaWNYTzgDpny3zVlgq4LviSSNCGNASHlGwp78pQ6dLWS8+QQ2n9YdF5Q/L3fTYj nmGZqBjLb+Aprhd8SVtWVphmPixwYaCRKL8XnBnDVeNpW1eZpGE9ztDjC55hIi3d96IJ ksm0YEGRKOlsyrU2q3WUw7PuwJ5G6yZ6o+Bp3hJpAvlKTj8Buut1/WLrCc5gQR5Rk6py Fufpbfn8h6NTRIQDteCxlzwCvncWU2qaQQKF9XLZvFhHLaM0XIf1zRXPZvlFiZb5gRRI CpZg== X-Gm-Message-State: AOJu0Yxu/gGCZS0uLYweeDFQC5R4EBXskCmpkXstVBFTwIrCOA8Ll079 /HBWNysge1Vsv7p1qWVsajwWomdaC0IkLigl6UBCVvVETLYS8JxCe6a8 X-Gm-Gg: Acq92OETD0bLJf4JjO+My5KxZQAg/Jx736pNaJlnwbUqW7C/ceocbEvUjzxLb/I1whi S+n7yUauRonE1+8GO6OTtNu1N4pPabfxaVSf3Oo01MvrUbAH4hrJRGaRuD7DWxdjrVHER7r9TYQ M1W7iffeiIwqfF0yVFkzMFxd9qX22SeFXkxo/9Bj8QBjEWT0ibw4a2ohrVM0rt+n0B398cJ9pGU hdRiZMl/N/o2yTuxli6fjUtdL5bG3KVPEBnm2bZoEiL4u6onJ84ndHDd8+8NICIpKNniI7bHkjD jWvIYppuUihvjXteKCsfu+d8T8BPQeJQEyfuBJyw3VWtMweUiF0Ocw8sft3xVYFoOCbErgmxCns cvaEd2LM7FgZ83SOCFLGi/WI/d8G3mNBlb1pzFCgKo099XkJ0ajcQtGPqUUnfzkO5egs+QAIJvT KtaAjKighLGFfSswVA0ahPgjemQs58P2xHdZc7qME+Pr6wJsSzpia3l5ab/35/PbwXdFWYZXZq9 /CPkfldeHv9AcYSNsU7KmY= X-Received: by 2002:a17:902:ced2:b0:2bd:7684:34b0 with SMTP id d9443c01a7336-2c4105092a4mr33621575ad.15.1781264458780; Fri, 12 Jun 2026 04:40:58 -0700 (PDT) Received: from localhost.localdomain ([45.142.165.58]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-2c4327ac72asm20697455ad.38.2026.06.12.04.40.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 12 Jun 2026 04:40:58 -0700 (PDT) From: Sun Jian To: bpf@vger.kernel.org Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, ast@kernel.org, daniel@iogearbox.net, andrii@kernel.org, martin.lau@linux.dev, davem@davemloft.net, kuba@kernel.org, hawk@kernel.org, john.fastabend@gmail.com, sdf@fomichev.me, shuah@kernel.org, jiayuan.chen@linux.dev, toke@redhat.com, menglong.dong@linux.dev, emil@etsalapatis.com, Sun Jian Subject: [PATCH bpf v5 1/2] bpf: Run generic devmap egress prog on private skb Date: Fri, 12 Jun 2026 19:40:31 +0800 Message-ID: <20260612114032.244616-2-sun.jian.kdev@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260612114032.244616-1-sun.jian.kdev@gmail.com> References: <20260612114032.244616-1-sun.jian.kdev@gmail.com> Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Generic XDP devmap multi redirect uses skb_clone() for intermediate destinations and sends the last destination with the original skb. This can leave multiple destinations sharing the same packet data. This becomes visible after generic devmap egress-program support was added: a devmap egress program may mutate packet data, and another destination sharing the same data can observe that mutation. Native XDP broadcast redirect does not have this issue because xdpf_clone() copies the frame data for each destination. Generic XDP should provide the same per-destination isolation before running a devmap egress program. Fix this by making cloned skbs private before running the generic devmap egress program. Use skb_copy() instead of skb_unshare() so allocation failure does not consume the skb and the existing caller error paths keep their ownership semantics. Fixes: 2ea5eabaf04a ("bpf: devmap: Implement devmap prog execution for generic XDP") Suggested-by: Jiayuan Chen Suggested-by: Jakub Kicinski Reviewed-by: Toke Høiland-Jørgensen Signed-off-by: Sun Jian --- kernel/bpf/devmap.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/kernel/bpf/devmap.c b/kernel/bpf/devmap.c index cc0a43ebab6b..28bd44591ce4 100644 --- a/kernel/bpf/devmap.c +++ b/kernel/bpf/devmap.c @@ -706,6 +706,18 @@ int dev_map_generic_redirect(struct bpf_dtab_netdev *dst, struct sk_buff *skb, if (unlikely(err)) return err; + if (dst->xdp_prog && skb_cloned(skb)) { + struct sk_buff *nskb; + + nskb = skb_copy(skb, GFP_ATOMIC); + if (!nskb) + return -ENOMEM; + + nskb->mac_len = skb->mac_len; + consume_skb(skb); + skb = nskb; + } + /* Redirect has already succeeded semantically at this point, so we just * return 0 even if packet is dropped. Helper below takes care of * freeing skb. -- 2.43.0