Date: Thu, 9 Jun 2005 10:25:30 +0200 From: Maxim Sobolev <sobomax@portaone.com> To: Brooks Davis <brooks@one-eyed-alien.net> Cc: current@FreeBSD.ORG, net@FreeBSD.ORG Subject: Re: HEADSUP: internal network interface changes Message-ID: <20050609082530.GA44274@www.portaone.com> In-Reply-To: <20050609064452.GC1595@odin.ac.hmc.edu> References: <20050609064452.GC1595@odin.ac.hmc.edu>
next in thread | previous in thread | raw e-mail | index | archive | help
Hi, I've noticed that in some cases you have removed bcopy() into arpcom.ac_enaddr completely, while in some others have modified it to use IFP2AC(). I wonder if it's a mistake or if there is some logic behind that. Also, it looks like in cdce(4) driver you are referencing if_softc before it's been assigned by if_alloc(): @@ -282,9 +283,13 @@ } } - bcopy(eaddr, (char *)&sc->arpcom.ac_enaddr, ETHER_ADDR_LEN); + bcopy(eaddr, (char *)&GET_ARPCOM(sc)->ac_enaddr, ETHER_ADDR_LEN); - ifp = GET_IFP(sc); + ifp = GET_IFP(sc) = if_alloc(IFT_ETHER); + if (ifp == NULL) { + printf("%s: can not if_alloc()\n", USBDEVNAME(sc->cdce_dev)); + USB_ATTACH_ERROR_RETURN; + } ifp->if_softc = sc; if_initname(ifp, "cdce", sc->cdce_unit); ifp->if_mtu = ETHERMTU; @@ -323,6 +328,7 @@ GET_ARPCOM(sc) basically dereferences sc->cdce_ifp, which isn't initialized before if_alloc() on the next line. -Maxim On Wed, Jun 08, 2005 at 11:44:52PM -0700, Brooks Davis wrote: > I plan to commit a major rework of network interface related storage > Friday morning PDT. This is a massive change touching every network > driver in the system. This change was discussed at the BSDCan dev > summit and derives from discussions at EuroBSDCon on dealing with > dynamic network devices. You can view the diff at: > > http://people.freebsd.org/~brooks/patches/ifnet.diff > > I'm not posting the diff to the list as it is nearly 700K. Below, you > will find the diff to ifnet(9) for a more technical view of the API > change. > > In short, the change removes the embedded struct ifnet and layer 2 common > structures (struct arpcom, struct ifatm, struct sppp, etc) from driver > softcs and replaces them with a struct ifnet pointer which is allocated > with a new function, if_alloc which takes an interface type. For > certain types, if_alloc also fills in the new struct ifnet member, > if_l2com with an initialized layer 2 common structure. > > The benefits of this change are: > - The size of struct ifnet and the layer 2 common structures is no > longer part of the network interface ABI. This means we add > features to the generic interface code so long as they do not require > action on the part of the driver without breaking the ABI. > - Since storage is no longer tied to the softc, we will able to > reference count struct ifnet more easily which is a prerequisite for > fixing the panics on removing an interface which is configured with > dummynet. > - This patch eliminates many ugly casts and the historically weakly > documented requirement that softc's be castable to ifnet's and > arpcom's. > > Things to note about this change: > - External drivers including those in ports will panic if loaded until > they are converted to the new API. > > Things to note about this patch: > - There are nearly 100 drivers in the tree and I only use a small set > of them so there are likely to be some small bugs in this patch. The > changes were mostly mechanical, but varying naming conventions, plus > the occasional driver written entirely from scratch introduce the > possibility of errors. Use care when updating, particularly with > remote systems. > - In most cases, this patch does not address the issue of keeping > source compatible with previous releases or other systems. I will > supply patches to do so in any case where there is a need, but I > intend to wait until after committing to do so. I hope the set of > drivers requiring these changes will be small. > > -- Brooks > > P.S. the posted patch contains a bug in the udav driver. It will be > fixed before commit. > > --- freebsd/share/man/man9/ifnet.9 Sun Jun 5 13:33:05 2005 > +++ ifnet/share/man/man9/ifnet.9 Sun Jun 5 20:20:03 2005 > @@ -46,9 +46,17 @@ > .In net/if_types.h > .\" > .Ss "Interface Manipulation Functions" > +.Ft "struct ifnet *" > +.Fn if_alloc "u_char type" > .Ft void > .Fn if_attach "struct ifnet *ifp" > .Ft void > +.Fn if_detach "struct ifnet *ifp" > +.Ft void > +.Fn if_free "struct ifnet *ifp" > +.Ft void > +.Fn if_free_type "struct ifnet *ifp" "u_char type" > +.Ft void > .Fn if_down "struct ifnet *ifp" > .Ft int > .Fn ifioctl "struct socket *so" "u_long cmd" "caddr_t data" "struct thread *td" > @@ -219,6 +227,11 @@ > .Pq Vt "void *" > A pointer to the driver's private state block. > (Initialized by driver.) > +.It Va if_l2com > +.Pq Vt "void *" > +A pointer to the common data for the interface's layer 2 protocol. > +(Initialized by > +.Fn if_alloc .) > .It Va if_link > .Pq Fn TAILQ_ENTRY ifnet > .Xr queue 3 > @@ -270,6 +283,8 @@ > to refer to a particular interface by index > (see > .Xr link_addr 3 ) . > +(Initialized by > +.Fn if_alloc .) > .It Va if_timer > .Pq Vt short > Number of seconds until the watchdog timer > @@ -988,6 +1003,14 @@ > .El > .Ss Interface Manipulation Functions > .Bl -ohang -offset indent > +.It Fn if_alloc > +Allocate and initalize an > +.Fa ifp . > +Initalization includes the allocation of an interface index and may > +include the allocation of a > +.Fa type > +specific structure in > +.Va if_l2com . > .It Fn if_attach > Link the specified interface > .Fa ifp > @@ -999,6 +1022,29 @@ > (A pointer to > this address structure is saved in the global array > .Va ifnet_addrs . ) > +The > +.Fa ifp > +must have been allocted by > +.Fn if_alloc . > +.It Fn if_detach > +Shutdown and unlink the specified > +.Fa ifp > +from the interface list. > +.It Fn if_free > +Free the given > +.Fa ifp > +back to the system. > +The interface must have been previously detached if it was ever attached. > +.It Fn if_free_type > +Identical to > +.Fn if_free > +except that the given > +.Fa type > + is used to free > + .Va if_l2com > + instead of the type in > + .Va if_type . > + This is intended for use with drivers that change their interface type. > .It Fn if_down > Mark the interface > .Fa ifp > > -- > Any statement of the form "X is the one, true Y" is FALSE. > PGP fingerprint 655D 519C 26A7 82E7 2529 9BF0 5D8E 8BE9 F238 1AD4
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20050609082530.GA44274>