net: Fix module refcount leak in kernel_accept()
authorWei Yongjun <yjwei@cn.fujitsu.com>
Fri, 19 Dec 2008 03:35:10 +0000 (19:35 -0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 19 Dec 2008 03:35:10 +0000 (19:35 -0800)
commit1b08534e562dae7b084326f8aa8cc12a4c1b6593
tree9fcc3093d7002015d334a28b0b0e21527ed5dcf7
parent3298a7388c00227e736d1037328788073c80c7b4
net: Fix module refcount leak in kernel_accept()

The kernel_accept() does not hold the module refcount of newsock->ops->owner,
so we need __module_get(newsock->ops->owner) code after call kernel_accept()
by hand.
In sunrpc, the module refcount is missing to hold. So this cause kernel panic.

Used following script to reproduct:

while [ 1 ];
do
    mount -t nfs4 192.168.0.19:/ /mnt
    touch /mnt/file
    umount /mnt
    lsmod | grep ipv6
done

This patch fixed the problem by add __module_get(newsock->ops->owner) to
kernel_accept(). So we do not need to used __module_get(newsock->ops->owner)
in every place when used kernel_accept().

Signed-off-by: Wei Yongjun <yjwei@cn.fujitsu.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/bluetooth/rfcomm/core.c
net/socket.c