[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <1421311071.1962.2.camel@sipsolutions.net>
Date: Thu, 15 Jan 2015 09:37:51 +0100
From: Johannes Berg <johannes@...solutions.net>
To: Jeff Layton <jeff.layton@...marydata.com>
Cc: netdev@...r.kernel.org
Subject: Re: [ 2375.793397] WARNING: CPU: 0 PID: 1149 at
net/netlink/genetlink.c:1037 genl_unbind+0xc0/0xd0()
On Wed, 2015-01-14 at 21:20 -0500, Jeff Layton wrote:
> > Ok - after long deliberation I found a way to trigger it. It requires
> > that you leave a multicast group (likely by destroying a socket) at the
> > same time as the kernel unregisters the generic netlink group. I have no
> > idea what generic netlink group you might be using here, but I could
> > reproduce it with a strategically placed delay in the netlink code and
> > the nl80211 genl group by opening a socket, closing the socket, and
> > removing the cfg80211 module (to unregister the nl80211 genl group)
> > while the socket was still being closed.
> >
> > I'll think about a fix tomorrow - it doesn't seem trivial due to
> > possible locking concerns.
> FWIW, it popped around a dozen times or so?
Yeah it would pop up for every multicast group that any socket you owned
while closing the program (which of course closes the sockets) would
have opened on that genl family.
The thing that confuses me is how you managed to unregister a genl
family at literally the same time, but I cannot find - from code review
- a way to trigger it without that. If the family goes away cleanly
before then the groups of all open sockets are cleared so it can't
happen, and if the family is still alive when the socket is closed then
of course it also can't happen.
> Unfortunately, I didn't save the logs from the run. I'll try to
> reproduce it again tomorrow (and save the logs this time), but I don't
> see it every time.
If you do manage to do that it would be great to confirm that it is
indeed the scenario I found (and reproduced).
Thanks,
johannes
--
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