Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp5042851pxb; Mon, 15 Feb 2021 08:05:06 -0800 (PST) X-Google-Smtp-Source: ABdhPJxg6rpIB3o2eqPqN6+Ka/Yp3fjwTalWWrlwvIjPt1PDGxgOJ29OsCbLVhzOkXsInL+l0jBc X-Received: by 2002:a17:906:43d7:: with SMTP id j23mr16143791ejn.519.1613405105975; Mon, 15 Feb 2021 08:05:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613405105; cv=none; d=google.com; s=arc-20160816; b=0WmxuouMN8Ko9Ec/BTqbngZPzmrn0PNa7FVfuQTahz22s0ygRuCaNAMMF2wNi4dtg4 z8xzLIdTNlmGgeSnEuMXkqjMgjURFRBHC5nNUpfCt1atlbskptYF9XV3ymAG2VCqUlCV 97PsHPecHNE1ErPqZfkOPh09UWtiCTTV9AK8OkaIXfq4jPq8Mrb/oc3pZEDtMh9Ye/2V T7nCDoA0WulU9zDlX2d+k7fXL6qSA97ugn485liyuyJyoPmMHV9mwGTo/6FO0dDYuTuv B6YGOxPsuGh4HkW+e67YTjYu7v30+iFrfQ2ugnnJfg4xwPZICzZH2fY51UdMcD3N7rKR dz2w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=1vjb4t+z4NoIBCBHXkSDl9dBkNLJOgtAIdx0SvjILwo=; b=mLTGfI1obMoy3pMqibZvenu+0wpVub3YueIMaaVvDUv5ZmAFpqqRZnp2jsYbRgZnVf SoFQX9qYIxWGPYSWSWoi+cgoghyfPvj5nWR/S0I67PEPGw6VPiKbJSECVH/Ze87805Zu e3IwRvDMmcbrefk0rKnUbM036NGbJ2BcWwWhKsx9Ws98e6HT5MBaWXxEGEZEM+7nDrlP qPFErBQglo265dWCb7LRHsZn2p0wLsxJGkRMCqNTWieLzdjjo3VznIfEbZ2BTXUHlGL4 YBO+1FWV/owOtxq6pHcdXMd5hTJZdifLGMzDdn6nJUr+K5gDWv4z4+XG2/88TcXKwKar xJqg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=XM7iGTVe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a12si12880589edn.568.2021.02.15.08.04.41; Mon, 15 Feb 2021 08:05:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=XM7iGTVe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232713AbhBOQCu (ORCPT + 99 others); Mon, 15 Feb 2021 11:02:50 -0500 Received: from mail.kernel.org ([198.145.29.99]:46846 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230438AbhBOPdE (ORCPT ); Mon, 15 Feb 2021 10:33:04 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id A054764EAF; Mon, 15 Feb 2021 15:30:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1613403020; bh=xYSyYs1Q1r9aVnYKzKuFGV7yvk31Rvzr/CGCdDIT7RE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XM7iGTVeW71jFBbhPF6wJbQzmDY8cd6ZkRVqysTPqxFdDjg53YH78BXVfA/PJlt7b bFHK9Hm/VCIYm9sndsh9TwImuiJsYRjbnAFA4kCmyI3Is2dGGz/XcJELlXz1aRqnDP LHk+4ICcYjdIDZZXn96XvoN7FSs4u/++7AUfp41Y= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Oliver Graute , Willem de Bruijn , Alexander Duyck , Eric Dumazet , Jakub Kicinski Subject: [PATCH 5.4 50/60] udp: fix skb_copy_and_csum_datagram with odd segment sizes Date: Mon, 15 Feb 2021 16:27:38 +0100 Message-Id: <20210215152716.980123815@linuxfoundation.org> X-Mailer: git-send-email 2.30.1 In-Reply-To: <20210215152715.401453874@linuxfoundation.org> References: <20210215152715.401453874@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Willem de Bruijn commit 52cbd23a119c6ebf40a527e53f3402d2ea38eccb upstream. When iteratively computing a checksum with csum_block_add, track the offset "pos" to correctly rotate in csum_block_add when offset is odd. The open coded implementation of skb_copy_and_csum_datagram did this. With the switch to __skb_datagram_iter calling csum_and_copy_to_iter, pos was reinitialized to 0 on each call. Bring back the pos by passing it along with the csum to the callback. Changes v1->v2 - pass csum value, instead of csump pointer (Alexander Duyck) Link: https://lore.kernel.org/netdev/20210128152353.GB27281@optiplex/ Fixes: 950fcaecd5cc ("datagram: consolidate datagram copy to iter helpers") Reported-by: Oliver Graute Signed-off-by: Willem de Bruijn Reviewed-by: Alexander Duyck Reviewed-by: Eric Dumazet Link: https://lore.kernel.org/r/20210203192952.1849843-1-willemdebruijn.kernel@gmail.com Signed-off-by: Jakub Kicinski Signed-off-by: Greg Kroah-Hartman --- include/linux/uio.h | 8 +++++++- lib/iov_iter.c | 24 ++++++++++++++---------- net/core/datagram.c | 12 ++++++++++-- 3 files changed, 31 insertions(+), 13 deletions(-) --- a/include/linux/uio.h +++ b/include/linux/uio.h @@ -261,7 +261,13 @@ static inline void iov_iter_reexpand(str { i->count = count; } -size_t csum_and_copy_to_iter(const void *addr, size_t bytes, void *csump, struct iov_iter *i); + +struct csum_state { + __wsum csum; + size_t off; +}; + +size_t csum_and_copy_to_iter(const void *addr, size_t bytes, void *csstate, struct iov_iter *i); size_t csum_and_copy_from_iter(void *addr, size_t bytes, __wsum *csum, struct iov_iter *i); bool csum_and_copy_from_iter_full(void *addr, size_t bytes, __wsum *csum, struct iov_iter *i); size_t hash_and_copy_to_iter(const void *addr, size_t bytes, void *hashp, --- a/lib/iov_iter.c +++ b/lib/iov_iter.c @@ -570,12 +570,13 @@ static __wsum csum_and_memcpy(void *to, } static size_t csum_and_copy_to_pipe_iter(const void *addr, size_t bytes, - __wsum *csum, struct iov_iter *i) + struct csum_state *csstate, + struct iov_iter *i) { struct pipe_inode_info *pipe = i->pipe; + __wsum sum = csstate->csum; + size_t off = csstate->off; size_t n, r; - size_t off = 0; - __wsum sum = *csum; int idx; if (!sanity(i)) @@ -596,7 +597,8 @@ static size_t csum_and_copy_to_pipe_iter addr += chunk; } i->count -= bytes; - *csum = sum; + csstate->csum = sum; + csstate->off = off; return bytes; } @@ -1484,18 +1486,19 @@ bool csum_and_copy_from_iter_full(void * } EXPORT_SYMBOL(csum_and_copy_from_iter_full); -size_t csum_and_copy_to_iter(const void *addr, size_t bytes, void *csump, +size_t csum_and_copy_to_iter(const void *addr, size_t bytes, void *_csstate, struct iov_iter *i) { + struct csum_state *csstate = _csstate; const char *from = addr; - __wsum *csum = csump; __wsum sum, next; - size_t off = 0; + size_t off; if (unlikely(iov_iter_is_pipe(i))) - return csum_and_copy_to_pipe_iter(addr, bytes, csum, i); + return csum_and_copy_to_pipe_iter(addr, bytes, _csstate, i); - sum = *csum; + sum = csstate->csum; + off = csstate->off; if (unlikely(iov_iter_is_discard(i))) { WARN_ON(1); /* for now */ return 0; @@ -1524,7 +1527,8 @@ size_t csum_and_copy_to_iter(const void off += v.iov_len; }) ) - *csum = sum; + csstate->csum = sum; + csstate->off = off; return bytes; } EXPORT_SYMBOL(csum_and_copy_to_iter); --- a/net/core/datagram.c +++ b/net/core/datagram.c @@ -700,8 +700,16 @@ static int skb_copy_and_csum_datagram(co struct iov_iter *to, int len, __wsum *csump) { - return __skb_datagram_iter(skb, offset, to, len, true, - csum_and_copy_to_iter, csump); + struct csum_state csdata = { .csum = *csump }; + int ret; + + ret = __skb_datagram_iter(skb, offset, to, len, true, + csum_and_copy_to_iter, &csdata); + if (ret) + return ret; + + *csump = csdata.csum; + return 0; } /**