[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20130110.141847.265135906896223944.davem@davemloft.net>
Date: Thu, 10 Jan 2013 14:18:47 -0800 (PST)
From: David Miller <davem@...emloft.net>
To: roland@...nel.org
Cc: netdev@...r.kernel.org, roland@...estorage.com
Subject: Re: [PATCH/RFC] ipv6: fib: Drop cached routes with dead neighbours
on fib GC
From: Roland Dreier <roland@...nel.org>
Date: Wed, 9 Jan 2013 09:44:19 -0800
> When a bonding interface changes slaves (or goes from no active slaves
> to having a slave with link), the bonding driver generates a
> NETDEV_CHANGEADDR notification. In this case, the ipv6 neighbour
> discovery code calls neigh_changeaddr(), which basically just calls
> neigh_flush_dev().
>
> Now, neigh_flush_dev() just goes through the neighbour hash table and
> tries to free every neighbour from the device being flushed. However,
> if someone else has an additional reference on the neighbour, we hit
...
> which leaves the final freeing of the "stray" neighbour until the last
> reference is dropped; in the meantime the output function is set to
> neigh_blackhole, which does nothing but free the skb and return ENETDOWN.
Another reason we must make ipv6 like ipv4, which looks up neighbours
on demand at packet output time rather than caching them in the route
entries.
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists