From owner-freebsd-stable@FreeBSD.ORG Fri Feb 1 14:43:31 2008 Return-Path: Delivered-To: freebsd-stable@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 382EE16A46E for ; Fri, 1 Feb 2008 14:43:31 +0000 (UTC) (envelope-from danny@ricin.com) Received: from smtpq2.groni1.gr.home.nl (smtpq2.groni1.gr.home.nl [213.51.130.201]) by mx1.freebsd.org (Postfix) with ESMTP id C193613C4DD for ; Fri, 1 Feb 2008 14:43:30 +0000 (UTC) (envelope-from danny@ricin.com) Received: from [213.51.130.190] (port=48017 helo=smtp1.groni1.gr.home.nl) by smtpq2.groni1.gr.home.nl with esmtp (Exim 4.60) (envelope-from ) id 1JKwr5-0002wk-5g for freebsd-stable@freebsd.org; Fri, 01 Feb 2008 15:26:59 +0100 Received: from cp1228410-a.dbsch1.nb.home.nl ([84.27.217.164]:63321 helo=desktop.homenet) by smtp1.groni1.gr.home.nl with smtp (Exim 4.60) (envelope-from ) id 1JKwr3-00087Y-Hr for freebsd-stable@freebsd.org; Fri, 01 Feb 2008 15:26:58 +0100 Received: by desktop.homenet (sSMTP sendmail emulation); Fri, 1 Feb 2008 15:26:23 +0100 From: "Danny Pansters" To: freebsd-stable@freebsd.org Date: Fri, 1 Feb 2008 15:26:22 +0100 User-Agent: KMail/1.9.7 References: <47A0B642.9060000@icyb.net.ua> <47A1C198.6090802@icyb.net.ua> <47A1E3D5.6040301@icyb.net.ua> In-Reply-To: <47A1E3D5.6040301@icyb.net.ua> X-Face: (Zs+'ncTcchkOX|~t6{?Iii=O!G#WEK!+OD0|-F=i%1pvP5V_Sz4PaJC8o)=?utf-8?q?MiSnH/JMJFy=0A=09oBN-My?=, v":S7, (=?utf-8?q?mmkPm=27U=7BMgT+eM=2EBd=5Cp/P!dr=5DhOTXqpse21O!=25Ct=60SE=2EOodq?= =?utf-8?q?=5Dry=5E=23kU=5E=0A=09-?=GT.[8D}i$6P>=" =?utf-8?q?=23=0A=09*J+4d=7E?= MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Content-Disposition: inline Message-Id: <200802011526.23000.danny@ricin.com> X-Spam-Score: 0.0 (/) Subject: Re: kld regression X-BeenThere: freebsd-stable@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Production branch of FreeBSD source code List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 01 Feb 2008 14:43:31 -0000 On Thursday 31 January 2008 16:05:57 Andriy Gapon wrote: > on 31/01/2008 14:39 Andriy Gapon said the following: > > on 31/01/2008 13:07 John Baldwin said the following: > >> On Wednesday 30 January 2008 12:39:14 pm Andriy Gapon wrote: > >>> The problem is as follows: > >>> 1. put udf_load="YES" in loader.conf > >>> 2. you can mount and unmount udf filesystems > >>> 3. you can kldunload udf if no udf filesystems are mounted > >>> 4. now mount udf fs while udf.ko is unloaded > >>> 5. udf is auto loaded and fs is mounted > >>> 6. unmount fs > >>> 7. try to kldunload udf > >>> kldunload: can't unload file: Device busy > >>> kernel message: kldunload: attempt to unload file that was loaded by > >>> the kernel > >>> > >>> Yeah, it was loaded by kernel indeed, but WTF - what is the difference > >>> from manual/loader.conf loading and why I can not manage my modules as > >>> I wish? > >> > >> Hmm, the relevant code (vfs_init.c) hasn't changed in 6.x since 6.0. > >> There were some changes in 7.0, but this should work in both branches. > >> What is the previous release that this worked on? > > > > Maybe I was wrong when I called this regression, but this was very > > surprising behavior for me. And in 5.X I did a lot of udf > > debugging/experimenting and never encountered such a problem. Maybe I > > always did kldload before mount, I can't tell now. > > Anyway, this seems like an annoyance at the very least, pinning a kernel > > module without any important reasons. > > Hmm, I found one difference with previous setups: in step 1 I also have > udf_iconv_load="YES" and udf_iconv.ko module is what seems to prevent > udf.ko from unloading in step 7. I can actually unload udf_iconv and > then I am able again to unload udf. > > Still don't understand what is a big difference here. > > And if I had UDF_ICONV built into kernel then I wouldn't have this > work-around. The way I understand it, there are two different things: 1. kldload will load "child" modules on demand, but kldunload does not attempt to unload any other modules than the one you ask for. I don't think it's material whether the kldload was done via the loader (before the kernel kmod gets loaded, kernel is also a kmod), or after. It's also possible to have modules who need to access the filesystem (other than /boot partition) when kldloaded, and such modules can obviously not be loaded via the loader at all. 2. There may be modules (such as bktr) that allocate memory in kernel space. These can not be unloaded, because that memory may not be deallocated while the kernel is up and running (the latter is my assumption). Anyhow, unless you're very tight on RAM, it hardly matters if you have some kmods loaded but left unused. Kmods are small, typically 10-100 kB. If all your kmods are built into the kernel, you have the footprint of all of them and you can't disable any at runtime. Feel free to correct me, anyone, if you think the above is not correct or complete. Dan