net: af_unix should update its inuse counter
authorEric Dumazet <dada1@cosmosbay.com>
Mon, 17 Nov 2008 10:38:49 +0000 (02:38 -0800)
committerDavid S. Miller <davem@davemloft.net>
Mon, 17 Nov 2008 10:38:49 +0000 (02:38 -0800)
This patch is a preparation to namespace conversion of /proc/net/protocols

In order to have relevant information for UNIX protocol, we should use
sock_prot_inuse_add() to update a (percpu and pernamespace) counter of
inuse sockets.

Signed-off-by: Eric Dumazet <dada1@cosmosbay.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/unix/af_unix.c

index a1eb5969712c93805b6aa3cc2245635eff576b60..f2cf3f583f626df8bba6cb2bf5df417530eb9ca3 100644 (file)
@@ -361,6 +361,7 @@ static void unix_sock_destructor(struct sock *sk)
                unix_release_addr(u->addr);
 
        atomic_dec(&unix_nr_socks);
+       sock_prot_inuse_add(sock_net(sk), sk->sk_prot, -1);
 #ifdef UNIX_REFCNT_DEBUG
        printk(KERN_DEBUG "UNIX %p is destroyed, %d are still alive.\n", sk,
                atomic_read(&unix_nr_socks));
@@ -612,6 +613,9 @@ static struct sock *unix_create1(struct net *net, struct socket *sock)
 out:
        if (sk == NULL)
                atomic_dec(&unix_nr_socks);
+       else
+               sock_prot_inuse_add(sock_net(sk), sk->sk_prot, 1);
+
        return sk;
 }