Date: Tue, 22 May 2007 09:23:09 +1200 From: Andrew Thompson <thompsa@FreeBSD.org> To: Fredrik Lindberg <fli@FreeBSD.org> Cc: yar@freebsd.org, freebsd-current@freebsd.org Subject: Re: Network interface modules keeps re-loading Message-ID: <20070521212309.GA4320@heff.fud.org.nz> In-Reply-To: <46462CB2.9050008@FreeBSD.org> References: <4645E8A2.1040408@FreeBSD.org> <20070512202004.GA71624@heff.fud.org.nz> <46462CB2.9050008@FreeBSD.org>
next in thread | previous in thread | raw e-mail | index | archive | help
--C7zPtVaVf+AK4Oqc Content-Type: text/plain; charset=us-ascii Content-Disposition: inline On Sat, May 12, 2007 at 11:08:02PM +0200, Fredrik Lindberg wrote: > Andrew Thompson wrote: > > > >A similar solution to this was committed in rev1.129 of ifconfig.c but > >then backed out later as the module loading proved to be feature used by > >quite a few people. I think an example was being able to load and > >initialise an interface by just trying 'ifconfig foo0'. > > > >I think a different way to solve this is to add a argument to ifconfig > >to suppress the module loading and then use it at the appropriate places > >in rc. > > > > Oh, I should have read the commit logs first, sorry about that. > Either way, I think something should be done about it. It certainly > annoyed me today before I could figure out what as going on. > When somebody issues a kldunload, they shouldn't get the module > re-loaded right away. > > Clearly people want the current behavior (although I question it > myself), what would be an appropriate way to suppress loading? > ifconfig -n foo0, as in no-probe/load? Here is a patch to do this, i'll commit it unless there are any objections. Andrew --C7zPtVaVf+AK4Oqc Content-Type: text/plain; charset=us-ascii Content-Disposition: attachment; filename="ifconfig-load.diff" Index: ifconfig.8 =================================================================== RCS file: /home/ncvs/src/sbin/ifconfig/ifconfig.8,v retrieving revision 1.137 diff -u -p -r1.137 ifconfig.8 --- ifconfig.8 17 Apr 2007 00:35:09 -0000 1.137 +++ ifconfig.8 21 May 2007 21:15:18 -0000 @@ -1579,6 +1579,11 @@ For example, the values of 802.11 WEP ke the current user. This information is not printed by default, as it may be considered sensitive. +.Pp +If the network interface driver is not present in the kernel then the module +will be loaded, the +.Fl n +flag suppresses this. .Pp Only the super-user may modify the configuration of a network interface. .Sh NOTES Index: ifconfig.c =================================================================== RCS file: /home/ncvs/src/sbin/ifconfig/ifconfig.c,v retrieving revision 1.130 diff -u -p -r1.130 ifconfig.c --- ifconfig.c 24 Mar 2007 20:26:54 -0000 1.130 +++ ifconfig.c 21 May 2007 21:16:12 -0000 @@ -139,7 +139,7 @@ usage(void) int main(int argc, char *argv[]) { - int c, all, namesonly, downonly, uponly; + int c, all, namesonly, downonly, uponly, noload; const struct afswtch *afp = NULL; int ifindex; struct ifaddrs *ifap, *ifa; @@ -150,10 +150,10 @@ main(int argc, char *argv[]) struct option *p; size_t iflen; - all = downonly = uponly = namesonly = verbose = 0; + all = downonly = uponly = namesonly = noload = verbose = 0; /* Parse leading line options */ - strlcpy(options, "adklmuv", sizeof(options)); + strlcpy(options, "adklmnuv", sizeof(options)); for (p = opts; p != NULL; p = p->next) strlcat(options, p->opt, sizeof(options)); while ((c = getopt(argc, argv, options)) != -1) { @@ -173,6 +173,9 @@ main(int argc, char *argv[]) case 'm': /* show media choices in status */ supmedia = 1; break; + case 'n': /* suppress module loading */ + noload++; + break; case 'u': /* restrict scan to "up" interfaces */ uponly++; break; @@ -898,6 +901,10 @@ ifmaybeload(const char *name) char ifkind[35], *dp; const char *cp; + /* loading suppressed by the user */ + if (noload) + return; + /* turn interface and unit into module name */ strcpy(ifkind, "if_"); for (cp = name, dp = ifkind + 3; --C7zPtVaVf+AK4Oqc--
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070521212309.GA4320>