OSDN Git Service

tcp: add TCP_MINTTL drop reason
authorEric Dumazet <edumazet@google.com>
Wed, 1 Feb 2023 17:43:45 +0000 (17:43 +0000)
committerJakub Kicinski <kuba@kernel.org>
Fri, 3 Feb 2023 05:14:50 +0000 (21:14 -0800)
In the unlikely case incoming packets are dropped because
of IP_MINTTL / IPV6_MINHOPCOUNT constraints...

Signed-off-by: Eric Dumazet <edumazet@google.com>
Link: https://lore.kernel.org/r/20230201174345.2708943-1-edumazet@google.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
include/net/dropreason.h
net/ipv4/tcp_ipv4.c
net/ipv6/tcp_ipv6.c

index 7053928..94bc3d5 100644 (file)
@@ -71,6 +71,7 @@
        FN(DUP_FRAG)                    \
        FN(FRAG_REASM_TIMEOUT)          \
        FN(FRAG_TOO_FAR)                \
+       FN(TCP_MINTTL)                  \
        FNe(MAX)
 
 /**
@@ -313,6 +314,11 @@ enum skb_drop_reason {
         */
        SKB_DROP_REASON_FRAG_TOO_FAR,
        /**
+        * @SKB_DROP_REASON_TCP_MINTTL: ipv4 ttl or ipv6 hoplimit below
+        * the threshold (IP_MINTTL or IPV6_MINHOPCOUNT).
+        */
+       SKB_DROP_REASON_TCP_MINTTL,
+       /**
         * @SKB_DROP_REASON_MAX: the maximum of drop reason, which shouldn't be
         * used as a real 'reason'
         */
index 8320d0e..ea370af 100644 (file)
@@ -2102,6 +2102,7 @@ process:
                /* min_ttl can be changed concurrently from do_ip_setsockopt() */
                if (unlikely(iph->ttl < READ_ONCE(inet_sk(sk)->min_ttl))) {
                        __NET_INC_STATS(net, LINUX_MIB_TCPMINTTLDROP);
+                       drop_reason = SKB_DROP_REASON_TCP_MINTTL;
                        goto discard_and_relse;
                }
        }
index 11b736a..543ee21 100644 (file)
@@ -1708,8 +1708,9 @@ process:
 
        if (static_branch_unlikely(&ip6_min_hopcount)) {
                /* min_hopcount can be changed concurrently from do_ipv6_setsockopt() */
-               if (hdr->hop_limit < READ_ONCE(tcp_inet6_sk(sk)->min_hopcount)) {
+               if (unlikely(hdr->hop_limit < READ_ONCE(tcp_inet6_sk(sk)->min_hopcount))) {
                        __NET_INC_STATS(net, LINUX_MIB_TCPMINTTLDROP);
+                       drop_reason = SKB_DROP_REASON_TCP_MINTTL;
                        goto discard_and_relse;
                }
        }