Date: Mon, 31 Dec 2001 10:59:40 +0200 From: Peter Pentchev <roam@ringlet.net> To: Mike Barcroft <mike@freebsd.org> Cc: Mike Smith <msmith@freebsd.org>, hackers@freebsd.org Subject: Re: loadable aio Message-ID: <20011231105940.B3512@straylight.oblivion.bg> In-Reply-To: <20011231034807.D45114@espresso.q9media.com>; from mike@freebsd.org on Mon, Dec 31, 2001 at 03:48:07AM -0500 References: <20011230215630.B45114@espresso.q9media.com> <200112310508.fBV58MI03596@mass.dis.org> <20011231034807.D45114@espresso.q9media.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, Dec 31, 2001 at 03:48:07AM -0500, Mike Barcroft wrote: > Mike Smith <msmith@freebsd.org> writes: > > > Terry Lambert <tlambert2@mindspring.com> writes: > > > > There is so much "goo" around the module loading these days; there > > > > are incursions into "mount" and all sorts of other programs that > > > > should not know about module loading. > > > > > > The kldload(2) interface alone is enough to make me cringe. The way > > > in which it locates a module to load appears to be black magic. > > > > What part of searching a path for a matching file is "black magic"? > > > > Shells have been doing this for decades... > > %%% > /* > * Load /boot/kernel/procfs.ko > * XXX: why does this work? > */ > chdir("/"); > kldload("procfs"); > > /* > * Load /boot/kernel/procfs.ko > * XXX: why does this work? > */ > chdir("/"); > kldload("procfs.ko"); > > /* > * Load /boot/kernel/procfs.ko > */ > kldload("/boot/kernel/procfs.ko"); /* Proper interface */ > > /* > * Move procfs.ko from /boot/kernel to /tmp, then load the copy in /tmp. > */ > system("/bin/mv /boot/kernel/procfs.ko /tmp"); > chdir("/tmp"); > kldload("procfs.ko"); /* XXX: this doesn't work. */ > %%% > > If that's not black magic, I'd like to know what is. I'd like to > refer you to the kldload(2) manual, but unfortunately it doesn't > document how kldload(2) works. :( Okay, so it's not documented in the manual, but one look at the source should suffice :) As Mike said, there is a search path. However, the current directory is tried first. If a file by that name is not found in the current directory, the search path is, well, searched ;) The search path is available in the kern.module_path sysctl or in the output of 'kldconfig -r'. This is similar to what shells have been doing for decades, with the added feature of an implicit '.' at the start of the search path. G'luck, Peter -- Do you think anybody has ever had *precisely this thought* before? To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20011231105940.B3512>