Subject: Re: execing gzipped files (was Re: Netpliance Iopener booted with
To: der Mouse <mouse@Rodents.Montreal.QC.CA>
From: Greywolf <greywolf@starwolf.com>
List: port-i386
Date: 03/23/2000 13:19:46
On Thu, 23 Mar 2000, der Mouse wrote:
# >>> % gzip -9 hello
# >>> % ./hello.gz
# >>> Hello world
#
# > [W]hile there's no reason that *all* architectures shouldn't benefit
# > from this neat hack, it does require putting gzip in the kernel.
#
# That was my first thought too.
#
# Now I'm not so sure. Couldn't ld.so or ld.elf_so or whatever it's
# called these days handle forking gunzip? Or Am I Missing Something
# (tm)?
:-)
The problem lies in that most of the executables compiled for the miniroot
are *static*.
And even if ld.so or whatever did that, that's still kind of a lose:
What if gunzip is gzipped? :-)
I think the guts of gunzip need to be built into the exec module, callable
from the exec module or built in to ld.so*.
# > it probably kills demand paging though. :)
#
# I daresay. :) And machines so cramped for disk space that they have to
# resort to this trick are likely to be the ones shortest on swap. :(
The demand-paging algorithm would have to be modified a fair bit if
it's hitting gzipped executables; it'd probably have to do compressed-
to-normal page/offset mappings on the first hit on the executable, freeing
that table once the executable's last reference is closed.
It'd kill demand paging-over-NFS, though, given its stateless nature...
#
# der Mouse
#
# mouse@rodents.montreal.qc.ca
# 7D C8 61 52 5D E7 2D 39 4E F1 31 3E E8 B3 27 4B
#
--*greywolf;
--
BSD: unshackling hardware designers and users from the bondage of WinTel.