Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp8105399imu; Tue, 4 Dec 2018 03:05:50 -0800 (PST) X-Google-Smtp-Source: AFSGD/XjfrweK4uvS5GnjqmvOUEvzG8pvo4SbB9tlwvoPrDo4jdQLEWnPrkIUrl2mHR2noOYdBsf X-Received: by 2002:a17:902:227:: with SMTP id 36mr19724801plc.140.1543921550483; Tue, 04 Dec 2018 03:05:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543921550; cv=none; d=google.com; s=arc-20160816; b=VvZsOBcN5Ja7fAiENqAQGtZJd8UhOYklGfmsvEVT7VnfPuVesfuUnr1WQIAL4aqe+y DUta4QojTawpBL8uU98L1XrGqCibI1VnSrJSuYKs+GDWuvVpXcjgmdLik+4DE/Se1oKN lldkihyLpxaRK9MAM2YurBOmQfst8mgWlcYXEQwF+VgdkINjFen/X4hGrzIPfS4qoO88 UM7BPWtaPdLUSqzHqm3ZBdCI1H8tshlDlnua8+PfZPLaD1Li0wLpNDW9diUCvGeJrC6X YFR6dmwql6z/8ZE7oRN1IdavvM0ITSVksqbWcJAXL39XJVh3Ec5uW1J3AHic/ZLJ7+E/ r+XA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=GwnUTdZeeILZ7Bbr5QHEtLtAPS6mtUjGbQ7tWfNu9uU=; b=Wece9tM+J6EOndGQ+agBkYdgPPb4m9DpfMI1Lpm7kJWfn01RltqTeCU7YWZTE0FcbM PKsPCJOnhzo1sw0Fz6cl3fTeB5G8+lurcBtyX1r53zsJ1t5qfj8cVYeCTmPlb3bY+Psx K+tj0PsyU91YpfvaP15RBvLGfssDdllCDfzzMbE5QF4qar8SyJVwjIutccSeLrsvFppL IkYStcbPQdA0LE2mv1MopxHnR9+pKN+sT2CKWO86Smku6WRPM6Pa4c0jkk2i/QXTVYnQ VVyyzMLE7MUbK3VoefQ9ZPLkERbxl/pN12VzCQVdGHj7DkGItE/6f+Yj/PLHtkSlp2IN lD7A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=FXJNRRnZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o184si15146387pgo.591.2018.12.04.03.05.33; Tue, 04 Dec 2018 03:05:50 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=FXJNRRnZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727992AbeLDLE2 (ORCPT + 99 others); Tue, 4 Dec 2018 06:04:28 -0500 Received: from mail.kernel.org ([198.145.29.99]:51428 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726888AbeLDLEZ (ORCPT ); Tue, 4 Dec 2018 06:04:25 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 4892521508; Tue, 4 Dec 2018 11:04:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1543921464; bh=XrvhqPbzedG8a8nhggLBTcSV16WAHiB6wVsc9n3hxfU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=FXJNRRnZ4p2VzWX4IzU3eUrG87poG4adxYtLW/ooD/KALzVaTqc5PzTUpg1mFY/Na B3zyJrvmVBoTpCysPyPeNkBDtbijAq9gw9jpSQ9C+NNWrzac5224JyfwDJBDHaSb9F QXQLsjrIP4mrFZE6pYOO6SILf0bwRRMTC409hrfQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Anand H. Krishnan" , Willem de Bruijn , "David S. Miller" Subject: [PATCH 4.14 064/146] packet: copy user buffers before orphan or clone Date: Tue, 4 Dec 2018 11:49:10 +0100 Message-Id: <20181204103729.416508828@linuxfoundation.org> X-Mailer: git-send-email 2.19.2 In-Reply-To: <20181204103726.750894136@linuxfoundation.org> References: <20181204103726.750894136@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Willem de Bruijn [ Upstream commit 5cd8d46ea1562be80063f53c7c6a5f40224de623 ] tpacket_snd sends packets with user pages linked into skb frags. It notifies that pages can be reused when the skb is released by setting skb->destructor to tpacket_destruct_skb. This can cause data corruption if the skb is orphaned (e.g., on transmit through veth) or cloned (e.g., on mirror to another psock). Create a kernel-private copy of data in these cases, same as tun/tap zerocopy transmission. Reuse that infrastructure: mark the skb as SKBTX_ZEROCOPY_FRAG, which will trigger copy in skb_orphan_frags(_rx). Unlike other zerocopy packets, do not set shinfo destructor_arg to struct ubuf_info. tpacket_destruct_skb already uses that ptr to notify when the original skb is released and a timestamp is recorded. Do not change this timestamp behavior. The ubuf_info->callback is not needed anyway, as no zerocopy notification is expected. Mark destructor_arg as not-a-uarg by setting the lower bit to 1. The resulting value is not a valid ubuf_info pointer, nor a valid tpacket_snd frame address. Add skb_zcopy_.._nouarg helpers for this. The fix relies on features introduced in commit 52267790ef52 ("sock: add MSG_ZEROCOPY"), so can be backported as is only to 4.14. Tested with from `./in_netns.sh ./txring_overwrite` from http://github.com/wdebruij/kerneltools/tests Fixes: 69e3c75f4d54 ("net: TX_RING and packet mmap") Reported-by: Anand H. Krishnan Signed-off-by: Willem de Bruijn Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- include/linux/skbuff.h | 18 +++++++++++++++++- net/packet/af_packet.c | 4 ++-- 2 files changed, 19 insertions(+), 3 deletions(-) --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h @@ -1288,6 +1288,22 @@ static inline void skb_zcopy_set(struct } } +static inline void skb_zcopy_set_nouarg(struct sk_buff *skb, void *val) +{ + skb_shinfo(skb)->destructor_arg = (void *)((uintptr_t) val | 0x1UL); + skb_shinfo(skb)->tx_flags |= SKBTX_ZEROCOPY_FRAG; +} + +static inline bool skb_zcopy_is_nouarg(struct sk_buff *skb) +{ + return (uintptr_t) skb_shinfo(skb)->destructor_arg & 0x1UL; +} + +static inline void *skb_zcopy_get_nouarg(struct sk_buff *skb) +{ + return (void *)((uintptr_t) skb_shinfo(skb)->destructor_arg & ~0x1UL); +} + /* Release a reference on a zerocopy structure */ static inline void skb_zcopy_clear(struct sk_buff *skb, bool zerocopy) { @@ -1297,7 +1313,7 @@ static inline void skb_zcopy_clear(struc if (uarg->callback == sock_zerocopy_callback) { uarg->zerocopy = uarg->zerocopy && zerocopy; sock_zerocopy_put(uarg); - } else { + } else if (!skb_zcopy_is_nouarg(skb)) { uarg->callback(uarg, zerocopy); } --- a/net/packet/af_packet.c +++ b/net/packet/af_packet.c @@ -2433,7 +2433,7 @@ static void tpacket_destruct_skb(struct void *ph; __u32 ts; - ph = skb_shinfo(skb)->destructor_arg; + ph = skb_zcopy_get_nouarg(skb); packet_dec_pending(&po->tx_ring); ts = __packet_set_timestamp(po, ph, skb); @@ -2499,7 +2499,7 @@ static int tpacket_fill_skb(struct packe skb->priority = po->sk.sk_priority; skb->mark = po->sk.sk_mark; sock_tx_timestamp(&po->sk, sockc->tsflags, &skb_shinfo(skb)->tx_flags); - skb_shinfo(skb)->destructor_arg = ph.raw; + skb_zcopy_set_nouarg(skb, ph.raw); skb_reserve(skb, hlen); skb_reset_network_header(skb);