*BSD News Article 4159


Return to BSD News archive

Newsgroups: comp.unix.bsd
Path: sserve!manuel!munnari.oz.au!uunet!cs.utexas.edu!sun-barr!ames!haven.umd.edu!darwin.sura.net!Sirius.dfn.de!math.fu-berlin.de!unidui!du9ds3!veit
From: veit@du9ds3.uni-duisburg.de (Holger Veit)
Subject: Re: WD Ethernet Card not found on warmboot
References: <1992Aug21.171828.14323@doug.cae.wisc.edu> <1992Aug24.085511.21092@autelca.ascom.ch> <veit.714671205@du9ds3> <1992Aug25.035924.29631@fcom.cc.utah.edu> <veit.714724604@du9ds3> <1992Aug25.165542.5689@gateway.novell.com>
Date: 26 Aug 92 14:50:09 GMT
Reply-To: veit@du9ds3.uni-duisburg.de
Organization: Uni-Duisburg FB9 Datenverarbeitung
Sender: @unidui.uni-duisburg.de
Message-ID: <veit.714840609@du9ds3>
Lines: 159

In <1992Aug25.165542.5689@gateway.novell.com> terry@thisbe.npd.Novell.COM (Terry Lambert) writes:

>In article <veit.714724604@du9ds3>, veit@du9ds3.uni-duisburg.de (Holger Veit) writes:
>|> In <1992Aug25.035924.29631@fcom.cc.utah.edu> terry@cs.weber.edu (A Wizard of Earth C) writes:
>|> >In article <veit.714671205@du9ds3> veit@du9ds3.uni-duisburg.de writes:
>|> >>DO YOU REALLY NEED THIS? 
[...]
>|> You seem to carry your OS around, don't you? During installation I can
>|> live with a large "GENERIC" kernel which has support for all possible devices.
>|> After it has been relocated to the disk (IDE,SCSI or whatever) you can
>|> eliminate the unnecessary devices, and get this "small" kernel.

>Yes, but the idea is to have a generic kernel that has a piece of each SCSI
>driver in it (the probe), and loads the rest based on the results of the probe.
>This lets me have an apparently large kernel which is actually a small kernel.
>Thus, like a stripped kernel, we can run in 640K, for instance.  This is important
>for systems like the Amiga, where I have a limited amount of "fast" vs. "chip"
>ram.  It would also allow me to load 100% into the cache on some systems if I
>could get the kernel small enough.  Then I could really haul.

The question is what a kernel really is. Even device drivers are IMHO "kernel",
loadable or not. It is quite uninteresting which size all the parts have in
a disk directory. A microkernel of 100K and 10 loaded "value-added" or 
"mandatory" drivers, 100K each, is 1.1MB and needs 1.1MB in memory unless 
you want to do swapping on parts of the kernel which I would regard with 
suspect. You may, however, allocate different parts of the kernel to faster
or slower memory and tune your system (although, I personally think the
Amiga is a hacked hardware with its chip and fast ram).

>The main advantage of loadable kernel modules is the ability to reconfigure
>without rebuilding the kernel.  Many people are having problems in that they
>can not install enough to, for instance, recompile the kernel to get a new
>ethernet driver in so thay can remote mount /usr so they can recompile the kernel
>to get a new ethernet driver [ ... reminds me of the anti-cocaine commercial ...].

The kernel source subtree is ~ 5 MB, and needs 2-3 MB more to generate. I
think that was an unlucky decision to bundle it into the 40MB src01 file set
which contains the complete source of all the utilities which some people even 
do not know of that they exist at all. In a less busy moment, I think I'll
unpack this part and repack it into the "kernel01" kit and make it available
on the next FTP server (10 meters distance).

>|> >Another use would be loadable file systems, also with an initially small
>|> >kernel.
>|> 
>|> Loadable filesystems is a good idea, if you frequently reconfigure your
>|> disk layout. You may certainly have a UFS system, NFS, MFS, CDFS, and 
>|> DOS/FAT FS (the last to be written yet). I would call these the basic 
>|> facilities of the kernel. If you have no network card, not much RAM, no CDROM, 
>|> and/or no DOS partitions, you can live with the UFS only. Do you want to load
>|> them whenever you need them, for instance if you want to run mtools the DOS FS
>|> driver (server?) is loaded on line? Sounds like microkernel stuff such as
>|> MACH.

>First off, I've got the DOS/FAT FS I wrote for 0.0 basically up.  8-). 8-).
>Give me 2-3 weeks to clean it up (I have a very specific rewrite of the VFS
>layer in mind, and I want it to be easily convertable to the new interface)
>before I release it.

That's good news.

[...]
>No, generally, with the exception of ISOFS and possibly DOSFS, I *don't* want to
>"load as needed".  But I do want the ability to run a bunch of machines off the
>same base kernel, with only the applicable device drivers for that hardware
>loaded.

This is what I meant with "carrying the OS around." I see a little bit more
convenience for sysops here, but but not very much else. It means you can
throw a number of strange files on a system and let it find the best solution.
I hate this kind of "user friendlyness", not for job security of the sysops, 
but because in the long terms the knowledge necessary not to lose track of
the system will disappear. With the OS/2 I installed on my system just to
see what it does I have already lost the insight almost because everything is
hidden under a "user friendly" surface and every kind of trouble shooting
(for which there is no need: there are no bugs and there are exactly (int)NULL
questions in comp.os.os2.* groups ;-) ;-) ;-) ;-) becomes a tricky or dirty 
hack of the knowing wizards. 

>Yes, this sounds like microkernel, but I draw one important distinction:  In most
>cases, the kernel will actually *be* small as opposed to just providing a subset
>of kernel services.  This is much more to my liking, given the meaning of "micro"
>I was taught in my Latin classes.

Yes, MIT uses a different dictionary for looking up "micro".

>|> >The ability to load system calls buys you, again, a standard kernel with,
>|> >as an example, a kernel implementation of variable granularity locks (with
>|> >intention modes).
>|> 
>|> >There are lots of things which it would be nice to be able to put in the
>|> >kernel, use, and remove.
>|> 
>|> Which system calls do you want to make "loadable"? It is an interesting idea
>|> to add features but it makes the software that rely on it unportable.

>The only thing that is "unportable" about it are any device drivers you load.
>Given a uniform underlying interface, everything else would have no problem
>running.  My major peeve with VFS is that it doesn't have a uniform underlying
>interface; only the top side is well defined.

>As to system call candidates for being "loadable":

>o	Auditing (auditsys)
>o	Quotas (oldquota, quotactl)
>o	Accounting (sysacct)
>o	Async I/O for a threads library (aioread, aiowrite, aiowait, aiocancel)
>o	Real time scheduling (rtschedule)
>o	SysV compatable semaphores (semsys)
>o	SysV compatable message queues (msgsys)
>o	SysV compatable shared memory (shmsys)
>o	386 debug register access (???)
>o	Backward compatability calls (otime, ostime, oalarm, outime, opause,
>	onice, oftime, osetpgrp, otimes, ossig, ovlimit, ovtimes, osetuid,
>	osetgid, ostat, ofstat)
>o	SysV compatable calls (omount, oumount)
>o	Tracing (vtrace)
>o	Grandfathering of wait3
>o	Debugging (debug)
>o	NFS client (async_daemon)
>o	NFS server (nfs_svc, nfs_getfh, exportfs)
>o	RFS (rfssys)
>o	VPIX or a clone thereof (vpixsys)
>o	Vax Unibus (resuba)

And why then loadable instead of configurable (by kernel generation)? Some of
them are already excludable by #ifdef's and appear as an option in kernel
config, others will possibly follow in future releases. 

Perhaps I was not accurate enough (you unfortunately removed my sarcastic
remark on the "QEMM for UNIX"): The interface you can use for inclusion or 
loading of the above optional features is good for "value-adding" as well.
Anyone has a much easier job to add his own "feature" to the system and
uses this for his own applications, for instance some special 
block read system call which returns a disk block in reversed order
(I know this is a stupid example but there ARE such ill brains) and allocates
a SYScall number for it (lets say 0x12345678 to use unique long numbers in
this interface). Another one uses the same number for the famous "Apple-II
emulator trap" and immediately, we have a conflict. Things like that on
other levels are the daily pain under "free" systems like MSDOS. The simple
example could be solved by a RPC like numbering system, but the more
interesting problems that deal with resource scheduling ("The tape drive is 
mine! No, I was faster!") remain or could come up again from the abyss.

Holger


>					Terry Lambert
>					terry_lambert@gateway.novell.com
>					terry@icarus.weber.edu

>---
>Disclaimer:  Any opinions in this posting are my own and not those of
>my present or previous employers.
-- 
|  |   / Holger Veit             | INTERNET: veit@du9ds3.uni-duisburg.de
|__|  /  University of Duisburg  | BITNET: veit%du9ds3.uni-duisburg.de@UNIDO
|  | /   Dept. of Electr. Eng.   | "No, my programs are not BUGGY, these are
|  |/    Inst. f. Dataprocessing |          just unexpected FEATURES"