svn commit: r228969 - head/sys/netinet
Mikolaj Golub
trociny at FreeBSD.org
Thu Oct 17 19:35:52 UTC 2013
On Wed, Oct 16, 2013 at 05:09:04PM -0400, John Baldwin wrote:
...
> > >> #10 0x80b6f1fd in igmp_change_state (inm=0x8ae70480)
> > >> at /home/golub/freebsd/base/head/sys/netinet/igmp.c:2595
> > >> #11 0x80b76f68 in in_leavegroup_locked (inm=0x8ae70480, imf=0x8a655a00)
> > >> at /home/golub/freebsd/base/head/sys/netinet/in_mcast.c:1239
> > >> #12 0x80b76fbd in in_leavegroup (inm=0x8ae70480, imf=0x8a655a00)
> > >> at /home/golub/freebsd/base/head/sys/netinet/in_mcast.c:1184
> > >> #13 0x80b770b4 in inp_gcmoptions (context=0x0, pending=1)
> > >> at /home/golub/freebsd/base/head/sys/netinet/in_mcast.c:1554
> > >> #14 0x80a8ff2b in taskqueue_run_locked (queue=0x87594880)
> > >> at /home/golub/freebsd/base/head/sys/kern/subr_taskqueue.c:308
> > >> #15 0x80a90987 in taskqueue_thread_loop (arg=0x81186bcc)
> > >> at /home/golub/freebsd/base/head/sys/kern/subr_taskqueue.c:497
> > >> #16 0x80a1b2d8 in fork_exit (callout=0x80a90920
> > >> <taskqueue_thread_loop>, arg=0x81186bcc,
> > >> frame=0x872b2d28) at /home/golub/freebsd/base/head/sys/kern/kern_fork.c:992
...
> > >> VNET context is not set at that point.
...
>
> I think this was just fixed by glebius@ in r256587:
>
> Author: glebius
> Date: Wed Oct 16 05:02:01 2013
> New Revision: 256587
> URL: http://svnweb.freebsd.org/changeset/base/256587
>
> Log:
> For VIMAGE kernels store vnet in the struct task, and set vnet context
> during task processing.
>
> Reported & tested by: mm
I think that particular issue was fixed earlier by hrs in r252510:
Fix a panic when leaving MC group in a kernel with VIMAGE enabled.
in_leavegroup() is called from an asynchronous task, and
igmp_change_state() requires that curvnet is set by the caller.
Concerning this more general solution from Gleb, with storing the vnet
pointer in the task, I wander how it is safe when the vnet is being
removed?
In vnet_destroy() the vnet interfaces are moved back to their parent
vnets, so setting the vnet context from the interface looks safer.
--
Mikolaj Golub
More information about the svn-src-all
mailing list