Re: Driverfs updates

David D. Hagood (wowbagger@sktc.net)
Tue, 09 Jul 2002 07:20:40 -0500


I've been following this thread for some time, and one aspect of it
disturbs me - the principle of symmetry.

I've found that generally, in design thing should be symmetric - if you
can turn a thing on, you could be able to turn it off, if you can heat a
thing, you should be able to cool it, and if you can load a thing, you
should be able to unload it.

In the old days, a computer was "complete" when it booted - all things
that ever would be in the machine during that run were present at boot,
and the only way something could be added would be to turn the machine
off. In such an environment, a monolithic kernel loaded at boot made sense.

Now, we have things like Firewire, USB, Bluetooth, PCMCIA, Hot-Plug PCI
and TCP/IP attached devices, all of which can come and go as they
please. Loadable modules made supporting such things easy - witness the
trouble WinNT had dealing with PCMCIA vs. Linux.

However, if you cannot unload modules, then the kernel grows without
bound - the mere fact that a Bluetooth camera came into range causes the
kernel to grow as the driver gets loaded. True, you could go in as root
and clean up, but it seems to me that requiring root to do that sort of
periodic maintainance prevents Linux from being able to be the Energizer
Bunny OS - "it keeps going and going...." without much diddling.

It seems to me the problem is in designing modules to unload, and saying
"Then don't unload them" is not even a band-aid - it is willful
ignorance. If there is a potential race condition unloading a module,
then the module is BROKEN.

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/