FN(DUP_FRAG)                    \
        FN(FRAG_REASM_TIMEOUT)          \
        FN(FRAG_TOO_FAR)                \
+       FN(TCP_MINTTL)                  \
        FNe(MAX)
 
 /**
         * (/proc/sys/net/ipv4/ipfrag_max_dist)
         */
        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'
 
                /* 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;
                }
        }
 
 
        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;
                }
        }