Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 30 Aug 2001 19:58:00 +0400
From:      Yar Tikhiy <yar@FreeBSD.ORG>
To:        Archie Cobbs <archie@dellroad.org>
Cc:        Mike Tancsa <mike@sentex.net>, stable@FreeBSD.ORG, net@FreeBSD.ORG
Subject:   Re: kernel panic when bringing up a VLAN interface (netgraph?)
Message-ID:  <20010830195759.A21176@comp.chem.msu.su>
In-Reply-To: <200108292247.f7TMl6i40209@arch20m.dellroad.org>; from archie@dellroad.org on Wed, Aug 29, 2001 at 03:47:06PM -0700
References:  <20010829214910.A204@comp.chem.msu.su> <200108292247.f7TMl6i40209@arch20m.dellroad.org>

next in thread | previous in thread | raw e-mail | index | archive | help
[adding -net to the Cc: list]

On Wed, Aug 29, 2001 at 03:47:06PM -0700, Archie Cobbs wrote:
> Yar Tikhiy writes:
> > Why does gdb report the values of "ifp" and "mp" inconsistently?
> > The kernel crashed at the first line of ng_ether_output(), so
> > the arguments couldn't be modified... I'm confused.
> 
> Optimization.. it's probably reusing the same variable/register for
> both 'ifp' and 'node'. So 'node' is NULL, which indicates that
> ether_ifattach() was probably never called on this interface.

Yes it was.  As I've just traced, it's ng_ether_mod_event() that
is responsible for the panic.  When ng_ether is being loaded as a
module, or just initialized as a part of a kernel, it attaches all
existing ethernet interfaces to netgraph using ng_ether_attach().
However, the vlan interface has a different type, IFT_L2VLAN, so
it won't get attached to netgraph properly. On the other hand, vlan
can't attach to netgraph by itself because its init function is
usually called earlier that that of ng_ether.

Peter Block on -net reported that he had avoided the panic by fiddling
with initialization order.  However, that was a hack, not a solution.

I'd suggest the following fix.  Not sure if it should be pushed
into the upcoming 4.4-RELEASE...

Index: ng_ether.c
===================================================================
RCS file: /home/ncvs/src/sys/netgraph/ng_ether.c,v
retrieving revision 1.18
diff -u -r1.18 ng_ether.c
--- ng_ether.c	2001/01/30 20:51:52	1.18
+++ ng_ether.c	2001/08/30 15:33:24
@@ -798,7 +798,8 @@
 
 		/* Create nodes for any already-existing Ethernet interfaces */
 		TAILQ_FOREACH(ifp, &ifnet, if_link) {
-			if (ifp->if_type == IFT_ETHER)
+			if (ifp->if_type == IFT_ETHER ||
+			    ifp->if_type == IFT_L2VLAN)
 				ng_ether_attach(ifp);
 		}
 		break;

-- 
Yar

To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-net" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20010830195759.A21176>