From owner-freebsd-hackers Tue Jan 19 02:42:28 1999 Return-Path: Received: (from majordom@localhost) by hub.freebsd.org (8.8.8/8.8.8) id CAA18378 for freebsd-hackers-outgoing; Tue, 19 Jan 1999 02:42:28 -0800 (PST) (envelope-from owner-freebsd-hackers@FreeBSD.ORG) Received: from nlsystems.com (nlsys.demon.co.uk [158.152.125.33]) by hub.freebsd.org (8.8.8/8.8.8) with ESMTP id CAA18342 for ; Tue, 19 Jan 1999 02:42:23 -0800 (PST) (envelope-from dfr@nlsystems.com) Received: from localhost (dfr@localhost) by nlsystems.com (8.9.1/8.8.5) with SMTP id JAA46023; Tue, 19 Jan 1999 09:21:19 GMT Date: Tue, 19 Jan 1999 09:21:18 +0000 (GMT) From: Doug Rabson To: Archie Cobbs cc: freebsd-hackers@FreeBSD.ORG, Julian Elischer Subject: Re: Loading KLD from the kernel In-Reply-To: <199901190451.UAA07575@bubba.whistle.com> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG On Mon, 18 Jan 1999, Archie Cobbs wrote: > Doug Rabson writes: > > > What's the correct way to request loading of a KLD module from within > > > the kernel (but not from an interrupt handler). I see the kldload() > > > syscall function.. should I just call it directly? > > > > > > Same question for unloading a KLD module... > > > > The right thing to do is to call linker_load_file() like this: > > > > linker_file_t lf; > > int error = linker_load_file(filename, &lf); > > if (error) > > ...; > > Thanks!! That works great. > > Now I have another much more minor question.. when kldload() loads > a module, it increments "lf->userrefs" .. I assume this field is > for the "client" code to use (eg, kld syscalls or other kernel > entity). > > If this field is zero, you can't unload the module from root shell: > > linkerunload: attempt to unload file which was not loaded by user > > I'm trying to understand the exact semantics of userrefs, and how > we can allow root to unload a KLD from the shell that was loaded > from the kernel (after checking that it's safe, of course)? > > I tried simply incrementing lf->userrefs after loading the module > from the kernel, but somehow it went back to zero (?) This field is a count of how many times a user has loaded the file using kldload(2). It is there to prevent a user from unloading a file which was loaded explicitly by the kernel (e.g. as a dependancy). Incrementing userrefs should have worked though - can you watch what happens in the debugger and find out why it is being reset? The extra error checks added recently to kldload(2) seem to have broken the user refcount anyway. The intention is that if the file is already present, kldload(2) will simply increment the refcounts. That way two unrelated user programs can kldload/kldunload the same file without stepping on each other's toes. I think instead of returning EEXIST, it should increment the refcounts and return the file id. -- Doug Rabson Mail: dfr@nlsystems.com Nonlinear Systems Ltd. Phone: +44 181 442 9037 To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message