ipv6: clean up anycast when an interface is destroyed
authorSabrina Dubroca <sd@queasysnail.net>
Wed, 10 Sep 2014 21:23:02 +0000 (23:23 +0200)
committerDavid S. Miller <davem@davemloft.net>
Fri, 12 Sep 2014 21:33:06 +0000 (17:33 -0400)
commit381f4dca48d23e155b936b86ccd3ff12f073cf0f
treeb6f2de835f42420ad2d374c8ec91da74de2ba988
parentdcbc0054d783d53cf0479c391334e9a478daa25f
ipv6: clean up anycast when an interface is destroyed

If we try to rmmod the driver for an interface while sockets with
setsockopt(JOIN_ANYCAST) are alive, some refcounts aren't cleaned up
and we get stuck on:

  unregister_netdevice: waiting for ens3 to become free. Usage count = 1

If we LEAVE_ANYCAST/close everything before rmmod'ing, there is no
problem.

We need to perform a cleanup similar to the one for multicast in
addrconf_ifdown(how == 1).

Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
Acked-by: Hannes Frederic Sowa <hannes@stressinduktion.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/addrconf.h
net/ipv6/addrconf.c
net/ipv6/anycast.c