Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp2336772imm; Thu, 11 Oct 2018 08:43:14 -0700 (PDT) X-Google-Smtp-Source: ACcGV63Qwe3HPHQJW+wWxN+WckMHDX/WILa4xpa+jQ3T69AYj9K+DJZK6JgKh9i6u3q94b/M/kTl X-Received: by 2002:a62:1f9d:: with SMTP id l29-v6mr2032049pfj.121.1539272594403; Thu, 11 Oct 2018 08:43:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539272594; cv=none; d=google.com; s=arc-20160816; b=mJKGW9jXk7wFtWotQWUfs4f1MN1JNxpMsixu7nPo8Aii4uY0wVUdp6yRFseIb3orSA MgDmdWtqgiFmNkrHup1GBU8rwFZdWcHSk1WQCCEVnCKcBOxMVQavQSjeLwRLAaFdVETn LqYeVlw6w17Ggn9nb/1SOzFFv3fRExE9uiNIgsYNNFOsKKy55gKUL4qJhuFcAyAxo8Rz xcJMhAnKVTnuh432HnWpOnWjTMFYwvcpy1EW19PuexNWAJzZJO4lYhrh/IYrL8eu6ZII maaH7eex5th96HrGAIcdwiloYxSPC1wYewRlJzPKPRH8yq80mWb+geDll3ZOC4MnJ3z1 TWmg== 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=hYLjOkuGThzyDqosTJY+t/rS7IGtm6ApICkJdG5yFOA=; b=JciLsyv6Icyq/tPTnXmIObO39XAlkdAjMyUTqdwT2+Xp8aRBRecDcBMIDLp9fXZuON jvKQ/t9bttMJGi3dyZPasX1YMzAz0mhUisrWwi9R9blJ/p8PrxRGJXZ7cm1fl/SM2QTJ kjTRSw3/g5SyTDRiP901rrMgVmjpfrXyrYdr4QrWO7EQOZe9VtUY4JCqFaXD+3UCB0sw uQp6jHat4pZgLbSmO1C1gh7A5JeO1PFOQHF3+r32VOQ8FYosiKUT8ZUvO5pYfrYlXJLJ KISsLUsh8oK78l84OFJtC1KoxAvoekU7RF/KLc4A0pUdLdKf18r3EZxrPZpzH7FR9Ssn br2g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=1hGC4H5K; 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 o5-v6si20395183plh.96.2018.10.11.08.42.59; Thu, 11 Oct 2018 08:43:14 -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=1hGC4H5K; 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 S1730620AbeJKXJw (ORCPT + 99 others); Thu, 11 Oct 2018 19:09:52 -0400 Received: from mail.kernel.org ([198.145.29.99]:40900 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726700AbeJKXJv (ORCPT ); Thu, 11 Oct 2018 19:09:51 -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 EDE1720652; Thu, 11 Oct 2018 15:42:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1539272527; bh=i+1pd3Ox7uanChlZLc2EMiDmD/rQz8DrgrlT6SbwlZ0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=1hGC4H5KiFO6gWbpW5ddl08ylSpwD5E5G1rt9yyPi2du/zM4xQ3i+m2Y8lyJr3Rph h8sXXy0kex6ZnbkBYEpShzdPYAur3e/j5D6bXqrKEKeH/HtvjjFeaHzWiZ7GX/pBA6 K2r0pMI6zmiiFJbbQ2HqKsaVgO/EKwnXf0vgUo7A= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Eric Dumazet , "David S. Miller" , Mao Wenan Subject: [PATCH 4.4 20/27] tcp: increment sk_drops for dropped rx packets Date: Thu, 11 Oct 2018 17:35:07 +0200 Message-Id: <20181011152534.998726678@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 532182cd610782db8c18230c2747626562032205 ] Now ss can report sk_drops, we can instruct TCP to increment this per socket counter when it drops an incoming frame, to refine monitoring and debugging. Following patch takes care of listeners drops. Signed-off-by: Eric Dumazet Signed-off-by: David S. Miller Signed-off-by: Mao Wenan Signed-off-by: Greg Kroah-Hartman --- include/net/sock.h | 7 +++++++ net/ipv4/tcp_input.c | 33 ++++++++++++++++++++------------- net/ipv4/tcp_ipv4.c | 1 + net/ipv6/tcp_ipv6.c | 1 + 4 files changed, 29 insertions(+), 13 deletions(-) --- a/include/net/sock.h +++ b/include/net/sock.h @@ -2139,6 +2139,13 @@ sock_skb_set_dropcount(const struct sock SOCK_SKB_CB(skb)->dropcount = atomic_read(&sk->sk_drops); } +static inline void sk_drops_add(struct sock *sk, const struct sk_buff *skb) +{ + int segs = max_t(u16, 1, skb_shinfo(skb)->gso_segs); + + atomic_add(segs, &sk->sk_drops); +} + void __sock_recv_timestamp(struct msghdr *msg, struct sock *sk, struct sk_buff *skb); void __sock_recv_wifi_status(struct msghdr *msg, struct sock *sk, --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c @@ -4296,6 +4296,12 @@ static bool tcp_try_coalesce(struct sock return true; } +static void tcp_drop(struct sock *sk, struct sk_buff *skb) +{ + sk_drops_add(sk, skb); + __kfree_skb(skb); +} + /* This one checks to see if we can put data from the * out_of_order queue into the receive_queue. */ @@ -4320,7 +4326,7 @@ static void tcp_ofo_queue(struct sock *s __skb_unlink(skb, &tp->out_of_order_queue); if (!after(TCP_SKB_CB(skb)->end_seq, tp->rcv_nxt)) { SOCK_DEBUG(sk, "ofo packet was already received\n"); - __kfree_skb(skb); + tcp_drop(sk, skb); continue; } SOCK_DEBUG(sk, "ofo requeuing : rcv_next %X seq %X - %X\n", @@ -4372,7 +4378,7 @@ static void tcp_data_queue_ofo(struct so if (unlikely(tcp_try_rmem_schedule(sk, skb, skb->truesize))) { NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPOFODROP); - __kfree_skb(skb); + tcp_drop(sk, skb); return; } @@ -4436,7 +4442,7 @@ static void tcp_data_queue_ofo(struct so if (!after(end_seq, TCP_SKB_CB(skb1)->end_seq)) { /* All the bits are present. Drop. */ NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPOFOMERGE); - __kfree_skb(skb); + tcp_drop(sk, skb); skb = NULL; tcp_dsack_set(sk, seq, end_seq); goto add_sack; @@ -4475,7 +4481,7 @@ static void tcp_data_queue_ofo(struct so tcp_dsack_extend(sk, TCP_SKB_CB(skb1)->seq, TCP_SKB_CB(skb1)->end_seq); NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPOFOMERGE); - __kfree_skb(skb1); + tcp_drop(sk, skb1); } add_sack: @@ -4558,12 +4564,13 @@ err: static void tcp_data_queue(struct sock *sk, struct sk_buff *skb) { struct tcp_sock *tp = tcp_sk(sk); - int eaten = -1; bool fragstolen = false; + int eaten = -1; - if (TCP_SKB_CB(skb)->seq == TCP_SKB_CB(skb)->end_seq) - goto drop; - + if (TCP_SKB_CB(skb)->seq == TCP_SKB_CB(skb)->end_seq) { + __kfree_skb(skb); + return; + } skb_dst_drop(skb); __skb_pull(skb, tcp_hdr(skb)->doff * 4); @@ -4645,7 +4652,7 @@ out_of_window: tcp_enter_quickack_mode(sk, TCP_MAX_QUICKACKS); inet_csk_schedule_ack(sk); drop: - __kfree_skb(skb); + tcp_drop(sk, skb); return; } @@ -5236,7 +5243,7 @@ syn_challenge: return true; discard: - __kfree_skb(skb); + tcp_drop(sk, skb); return false; } @@ -5454,7 +5461,7 @@ csum_error: TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_INERRS); discard: - __kfree_skb(skb); + tcp_drop(sk, skb); } EXPORT_SYMBOL(tcp_rcv_established); @@ -5684,7 +5691,7 @@ static int tcp_rcv_synsent_state_process TCP_DELACK_MAX, TCP_RTO_MAX); discard: - __kfree_skb(skb); + tcp_drop(sk, skb); return 0; } else { tcp_send_ack(sk); @@ -6041,7 +6048,7 @@ int tcp_rcv_state_process(struct sock *s if (!queued) { discard: - __kfree_skb(skb); + tcp_drop(sk, skb); } return 0; } --- a/net/ipv4/tcp_ipv4.c +++ b/net/ipv4/tcp_ipv4.c @@ -1716,6 +1716,7 @@ discard_it: return 0; discard_and_relse: + sk_drops_add(sk, skb); sock_put(sk); goto discard_it; --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c @@ -1505,6 +1505,7 @@ discard_it: return 0; discard_and_relse: + sk_drops_add(sk, skb); sock_put(sk); goto discard_it;