net: add LINUX_MIB_PFMEMALLOCDROP counter
authorEric Dumazet <edumazet@google.com>
Thu, 2 Feb 2017 04:47:59 +0000 (20:47 -0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 3 Feb 2017 04:34:19 +0000 (23:34 -0500)
Debugging issues caused by pfmemalloc is often tedious.

Add a new SNMP counter to more easily diagnose these problems.

Signed-off-by: Eric Dumazet <edumazet@google.com>
Cc: Josef Bacik <jbacik@fb.com>
Acked-by: Josef Bacik <jbacik@fb.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/uapi/linux/snmp.h
net/core/filter.c
net/ipv4/proc.c

index e7a31f8..3b2bed7 100644 (file)
@@ -240,6 +240,7 @@ enum
        LINUX_MIB_SACKMERGED,
        LINUX_MIB_SACKSHIFTFALLBACK,
        LINUX_MIB_TCPBACKLOGDROP,
+       LINUX_MIB_PFMEMALLOCDROP,
        LINUX_MIB_TCPMINTTLDROP, /* RFC 5082 */
        LINUX_MIB_TCPDEFERACCEPTDROP,
        LINUX_MIB_IPRPFILTER, /* IP Reverse Path Filter (rp_filter) */
index 1e00737..0b753cb 100644 (file)
@@ -76,9 +76,10 @@ int sk_filter_trim_cap(struct sock *sk, struct sk_buff *skb, unsigned int cap)
         * allow SOCK_MEMALLOC sockets to use it as this socket is
         * helping free memory
         */
-       if (skb_pfmemalloc(skb) && !sock_flag(sk, SOCK_MEMALLOC))
+       if (skb_pfmemalloc(skb) && !sock_flag(sk, SOCK_MEMALLOC)) {
+               NET_INC_STATS(sock_net(sk), LINUX_MIB_PFMEMALLOCDROP);
                return -ENOMEM;
-
+       }
        err = BPF_CGROUP_RUN_PROG_INET_INGRESS(sk, skb);
        if (err)
                return err;
index a9deeb9..69cf49e 100644 (file)
@@ -262,6 +262,7 @@ static const struct snmp_mib snmp4_net_list[] = {
        SNMP_MIB_ITEM("TCPSackMerged", LINUX_MIB_SACKMERGED),
        SNMP_MIB_ITEM("TCPSackShiftFallback", LINUX_MIB_SACKSHIFTFALLBACK),
        SNMP_MIB_ITEM("TCPBacklogDrop", LINUX_MIB_TCPBACKLOGDROP),
+       SNMP_MIB_ITEM("PFMemallocDrop", LINUX_MIB_PFMEMALLOCDROP),
        SNMP_MIB_ITEM("TCPMinTTLDrop", LINUX_MIB_TCPMINTTLDROP),
        SNMP_MIB_ITEM("TCPDeferAcceptDrop", LINUX_MIB_TCPDEFERACCEPTDROP),
        SNMP_MIB_ITEM("IPReversePathFilter", LINUX_MIB_IPRPFILTER),