Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp2338373imm; Thu, 11 Oct 2018 08:44:45 -0700 (PDT) X-Google-Smtp-Source: ACcGV61KaS0DcWfTboovCoC6Op75VVfjvSIjZJaP3n6XtKYO2BjL6y0lm8lThKdMlnl9OD3bNVD3 X-Received: by 2002:a17:902:b403:: with SMTP id x3-v6mr2082081plr.237.1539272685536; Thu, 11 Oct 2018 08:44:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539272685; cv=none; d=google.com; s=arc-20160816; b=mDjutxT7z127VeHmfTKiricbk+/ndazHfznfgrDxZGxFiHi1oKsE98nGjxydanxqVs ivUnjJXDbPuelaNCjLpy589umQcOB6Nvx7z6JcNVElNGga6C9kRj/qgRySjk69sgWNkc zqI4s25p7pRmhVCCplg/d3IaC1nafLHt3RXzDAVhypTJ4J8Z39Aochqym73wZJ5wSI5C iXlL52BuD3/f7QaWC09MYilyPZvNOtNrZ6VgEZwTwrQA9EvLy6aEe6WJbUQjlGd4qzDb r2y/RCyYnrhWtsOTbDcuDkarlINUlVOTQO2OjvGRTdfnVByNuBJTkZcV03Q9Ki1l44KI UjWw== 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=g0fE2HCDWQ/JycsLWm/zRhZkEjeamRhLruoDRq81KUI=; b=LZvGnGOaChmDmYGPSfn+o7DYpRCYnl3t00NzI/przWH/L7YYYtZysaAyTcq9gZ7cpV +9VAViAOkGPmMt1JW9bFs5z/eIkBqKbUrobbjUrNg94pEB2DH39Wq9GylNzZTbe4Ighl JLiLox1/lOBE3WGXKBKdGMbspZM+ZRPhnYV7DuCROJd7ckKhpR7H40PxkIoXbSDxHN7S LWRmTvi5+NkJGswfKDasms+fh8dXMc8XH3MoH1xQR06hXDNq7r5X5cdqdk3rgJoxjsr4 g/8eUqwT4VA7hi+IhLwykzRHECDpHfYTx5AIQmEO8oXVo9HvN3DmZSo214U8bNQF3emY dSAw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=UHhKEFrf; 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 t10-v6si30122401pfk.252.2018.10.11.08.44.31; Thu, 11 Oct 2018 08:44:45 -0700 (PDT) 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=UHhKEFrf; 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 S1730682AbeJKXKG (ORCPT + 99 others); Thu, 11 Oct 2018 19:10:06 -0400 Received: from mail.kernel.org ([198.145.29.99]:41234 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726700AbeJKXKF (ORCPT ); Thu, 11 Oct 2018 19:10:05 -0400 Received: from localhost (ip-213-127-77-176.ip.prioritytelecom.net [213.127.77.176]) (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 DEF6D213A2; Thu, 11 Oct 2018 15:42:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1539272541; bh=seJyfT3S1vRBoUxBARbPjinUttrwwoH/BQZgH3Y6PK0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=UHhKEFrfd9oyacLRnfyu8s2zz3AWuQOEa/bAf8HuI8bP2SbJBbXYyZ06fEUNlZOny AhgMrSXMtoulUnkrI7U1fJ7uaITxEdKfdxOVnIAXoxRYB/rxNqOD/6lYGnK/QxT4Uw 0UlNyfq8aNc+z/ZbZbVnaQimTFCIHkSnCD4EWJ7A= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Eric Dumazet , Soheil Hassas Yeganeh , Yuchung Cheng , "David S. Miller" , Mao Wenan Subject: [PATCH 4.4 25/27] tcp: add tcp_ooo_try_coalesce() helper Date: Thu, 11 Oct 2018 17:35:12 +0200 Message-Id: <20181011152535.243990354@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181011152534.014964888@linuxfoundation.org> References: <20181011152534.014964888@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review 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.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Eric Dumazet [ Upstream commit 58152ecbbcc6a0ce7fddd5bf5f6ee535834ece0c ] In case skb in out_or_order_queue is the result of multiple skbs coalescing, we would like to get a proper gso_segs counter tracking, so that future tcp_drop() can report an accurate number. I chose to not implement this tracking for skbs in receive queue, since they are not dropped, unless socket is disconnected. Signed-off-by: Eric Dumazet Acked-by: Soheil Hassas Yeganeh Acked-by: Yuchung Cheng Signed-off-by: David S. Miller Signed-off-by: Mao Wenan Signed-off-by: Greg Kroah-Hartman --- net/ipv4/tcp_input.c | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c @@ -4296,6 +4296,23 @@ static bool tcp_try_coalesce(struct sock return true; } +static bool tcp_ooo_try_coalesce(struct sock *sk, + struct sk_buff *to, + struct sk_buff *from, + bool *fragstolen) +{ + bool res = tcp_try_coalesce(sk, to, from, fragstolen); + + /* In case tcp_drop() is called later, update to->gso_segs */ + if (res) { + u32 gso_segs = max_t(u16, 1, skb_shinfo(to)->gso_segs) + + max_t(u16, 1, skb_shinfo(from)->gso_segs); + + skb_shinfo(to)->gso_segs = min_t(u32, gso_segs, 0xFFFF); + } + return res; +} + static void tcp_drop(struct sock *sk, struct sk_buff *skb) { sk_drops_add(sk, skb); @@ -4422,7 +4439,8 @@ static void tcp_data_queue_ofo(struct so /* In the typical case, we are adding an skb to the end of the list. * Use of ooo_last_skb avoids the O(Log(N)) rbtree lookup. */ - if (tcp_try_coalesce(sk, tp->ooo_last_skb, skb, &fragstolen)) { + if (tcp_ooo_try_coalesce(sk, tp->ooo_last_skb, + skb, &fragstolen)) { coalesce_done: tcp_grow_window(sk, skb); kfree_skb_partial(skb, fragstolen); @@ -4467,7 +4485,8 @@ coalesce_done: tcp_drop(sk, skb1); goto merge_right; } - } else if (tcp_try_coalesce(sk, skb1, skb, &fragstolen)) { + } else if (tcp_ooo_try_coalesce(sk, skb1, + skb, &fragstolen)) { goto coalesce_done; } p = &parent->rb_right;