ffdca37ecc51439af77608245e461dd83ed35446
[oweals/busybox.git] / Changelog
1 0.43
2         * Wrote basename.
3         * tar wouldn't create directory entries that don't end in '/',
4             now it does (thanks to Avery Pennarun <apenwarr@worldvisions.ca>)
5         * Several fixes from Pavel Roskin <pavel_roskin@geocities.com>:
6             -  When `tail' fails to open a file it now exits.
7             - When `syslogd' is given the `-n' option it should still use 
8                 fork() for running klogd.
9         * nslookup types are now changed to u_int32_t (instead of uint32_t)
10             changed per a patch from Pascal Bellard <pascal.bellard@ascend.com>
11         * Fixed "du" so it gives the same answers as GNU "du" (busybox du used 
12             to count hard-linked files more then once).  Many thanks to 
13             Friedrich Vedder <fwv@myrtle.lahn.de> for the fix.
14
15         -Erik Andersen
16
17
18 0.42
19
20         * Fairly massive restructuring of umount.c to deal with remounting 
21           busy devices read-only. Adds a -r option to control that; it is 
22           optionally compiled in with BB_FEATURE_REMOUNT
23         * Added a bunch of functions to mtab.c to interact with the
24           {get,set,end}mntent interface; as it turns out, those functions do
25           not appear to be re-entrant, and that causes a lot of problems with
26           the way umount was originally written.
27         * Makes init send TERM and KILL (instead of HUP and KILL) on reboot
28           to be more consistent with sysvinit
29         * Changes to init.c to use the new -r option to umount. Also increased
30           the sleep time between the time the TERM and KILL signals are sent
31
32         - Randolph Chung
33
34
35         * cp.c, mv.c: removed, replaced by cp_mv.c which has been
36             extensively rewritten from the original cp.c.
37         * Fixed cp and mv so if the source and destination are a the
38             same directory it will print an error and continue.
39         * Also added a warning message to the `mv' usage string saying that
40             this is not GNU mv, and it will break hard links. cp also breaks
41             hard links.
42         * ln.c: implemented `-n' switch, no-deref symlinks.
43         * include<sys/param.h>: and use PATH_MAX everywhere.  busybox: File
44         * name buffer overrun guards to prevent future crashes.
45             - Always check exit status.
46             - Purge all use of `creat()', replace with `open()'.
47         * utility.c 
48             - recursiveAction was overriding the value of followLinks thus
49               ignoring it.
50             - isDirectory now takes a followLinks boolean, updated all callers
51             - copyFile had the followLinks logic reversed.
52         * messages.c: New file. Put common error message strings all in
53             one place in an attempt to shrink the binary a little.
54
55         -Karl M. Hegbloom
56
57
58         * changed fsck_minix.c to reduce its .bss size significantly
59           -beppu -piptigger
60         * Made tar creation support in busybox tar optional.  You no longer
61         * _have_ to put a "-" in front of tar options.  Tar could inadvertently
62         * change permissions and ownership on
63             certain directories pointed to by symlinks.
64         * Made grep and grep -h do the right thing wrt printing
65             the file name (it failed to print files names in many cases).
66         * Fix a namespace aliasing problem wereby if du was built in, the 
67             symlink for both du and dutmp would be installed, or then rm was
68             built in, the symlinks for both rm and rmmod would be installed.
69         * Added a closelog() to init.c after loging -- fix thanks to 
70             Taketoshi Sano <kgh12351@nifty.ne.jp>
71         * Rewrote and simplified logger.  Added the "-t" option, and made it
72             behave itself a bit better.
73         * Optional support contributed by Ben Collins <bcollins@debian.org> 
74             for the kernel init chroot patch by Werner Almesberger, which
75             allows init to chroot to a new device, and umount the old one.
76         * Fixed bug that wouldn't let one chown a symlink -- it would
77             always dereference before.  -beppu
78         * Fixed a bug where init could have reference already freed memory.
79             Found and fixed by Taketoshi Sano <kgh12351@nifty.ne.jp>
80         * Several contributions from Friedrich Vedder <fwv@myrtle.lahn.de>
81         * Added (and documented) "-n" option for head
82         * Cleanup for a number of usage messages -- also 
83             contributed Friedrich Vedder <fwv@myrtle.lahn.de>
84         * Cosmetic fix to busybox.c (Don't print a comma at the
85             end of line if there are no more application names).
86         * Fixed a stupid bug in "head" option handling ("head -n" 
87             would segfault).
88         * Moved commonly used functions "xmalloc()" and "exit()"
89             to utility.c (with proper #ifdef's).
90         * Created a tiny tail implementation, removing -c, -q, -v, and making
91             tail -f work only with a single file.  This reduced tail from 6k to
92             2.4k.  The bigger/more featured tail can still be had by disabling
93             BB_FEATURE_SIMPLE_TAIL in busybox.defs.h
94         * Ping now falls back to doing the right thing if /etc/protocols
95             turns up missing.
96         * Fixed mount and umount.  Previously they could leak loop device 
97             allocations, causing the system to quickly run out.  Fix for umount
98             by Ben Collins <bcollins@debian.org>, and mount was fixed by me.
99         * ls formatting on eight charactor user names fixed by 
100             Randolph Chung <tausq@debian.org>.
101         * cp could, when copying symlinks, change permissions of the
102             files pointed to by the symlinks.
103         * Several fixes from Pavel Roskin <pavel_roskin@geocities.com>:
104             - `chown' with 1 argument displayed the error incorrectly
105             - `fdflush', `length' and `printf' crashed if run without arguments
106             - `fdflush' tried to flush itself using *argv
107             - added "skip" and "seek" to dd.
108             - ls no longer messus up output when combining files and
109               directories on the command line 
110         * swapoff -a was not working.  Now it is.  
111         * init did not cleanly unmount filesystems on reboot.  Now it does.  
112         * "sed -ne s/foo/bar/" worked but "sed -n -e s/foo/bar/" didn't.
113             Now both work.
114         * Some architectures (PowerPc) assume chars are unsigned, so they could
115             not distinguish between EOF and '\0xFF' in sed.  Sed now uses ints.
116         * Began converting error handling to use some common routines
117             in utility.c
118         * syslogd now has better message handling and ignores SIGHUP.
119         * install.sh had a bug preventing installation to the specified
120             target directory.  Fix from Gilbert Coville <gilbert@mvista.com>
121         * You can now spefify alternative strip commands -- change 
122             also from Gilbert Coville.
123
124
125         -Erik Andersen
126
127 0.41
128         * New Apps: wc, hostid, logname, tty, whoami, yes -- all contributed 
129             by Edward Betts <edward@debian.org>
130         * Fixed a bug in both cp and mv preventing 'cp foo/README bar'
131             type commands (file in a directory to another directory) from
132             working.
133         * Fixed a logger bug that caused garbage to be written to the syslog 
134             (unless you used busybox syslog, which hid the bug).  Thanks to
135             Alex Holden <alex@linuxhacker.org> for the fix.
136         * /bin/true and /bin/false were echoing a blank line when run.  
137             Now fixed.
138         * mkdir -p would print an error when asked to mkdir an existing dir
139             with no interveining subdirectories.
140         * Fixed "syslogd -O" so that it works.  Added -o loop option for mount,
141         * and support in umount for loop
142           devices. Support is toggled by MOUNT_LOOP feature -- Ben Collins
143           <bcollins@debian.org>
144         * Several fixes from Marco Pantaleoni <panta@prosa.it> compile in
145         * fullWrite() not only if BB_TAR is defined, but also
146                 if BB_CP or BB_MV are (fullWrite() is referenced by copyFile())
147             * add some compiler optimizations to further reduce executable size
148                 (as a side note, on my machines the largest code is generated
149                 by gcc 2.95.2 with -Os ! The smallest by plain gcc 2.7.2.3 with
150                 -O2 -m386 ...)
151             * Compile now won't fail if busybox.def.h defines 
152                 BB_FEATURE_LINUXRC but not BB_INIT.  (init_main used to be
153                 referenced, but not compiled)
154         * Fixed a bug in setting TERM for serial console support.  TERM now
155             defaults to "ansi" for serial consoles.
156         * Fixed a bug in handling the CONSOLE env. variable for serial
157         * consoles.
158
159         -Erik Andersen, Jan 15, 2000
160
161 0.40
162         * New Apps: sort, uniq. -beppu New Apps: lsmod, rmmod -erik New Apps:
163         * fbset contributed by Randolph Chung <tausq@debian.org>.  New App::
164         * loadacm contributed by Peter Novodvorsky <petya@logic.ru>
165             for loading application character maps for Unicode fonts.
166         * Major init re-work.  init now supports inittab (slightly different
167             but similar to sysvinit), allowing me to get all the policy out of
168             init and into the conf file.  It works just fine without inittab
169             being present, but if you dont like the defautl behavior you can
170             now do something about it.  Init is much cleaner as a result.
171         * Fixed an bug in syslogd causing it to stop after 20 minutes. -erik
172         * Fixed an embarrasing segfault in head -beppu Fixed the embarrasing
173         * failure of 'logger -p'. -erik Added the -s option to du -beppu
174         * Re-worked the source tree a bit so it will compile under glibc 2.0.7 
175             with the 2.0.x Linux kernel.
176         * Added 'grep -q' thanks to a patch from "Konstantin Boldyshev" 
177             <konst@voshod.com>.
178         * Grep -i previously failed on UPPER CASE patterns due to a silly 
179             regexp implementation bug that is now fixed.
180         * Fixed a bug where tar would set, and then clear SGID and SUID bits.
181         * Fixed a bug where tar would not set the user and group on device
182             special files.
183         * Fixed a bug where tar would not restore the time to files.  Fixed a
184         * major security problem with tar -- it changed ownership 
185             of any file pointed to by a symlink to 777 (like say libc....)
186             Ouch!!!
187         * cp and mv were very broken when moving directories.  I have rewritten 
188             them so they should now work as expected. 
189         * sed now supports addresses (numeric or regexp, with negation) and 
190             has an append command, thanks to Marco Pantaleoni <panta@prosa.it>
191         * Fixed dmesg.  It wasn't parsing its options (-n or -s) properly.
192         * Some cosmetic fixes to ls output formatting to make it behave more
193             like GNU ls.
194         * Fixed a stupid segfault in kill.  Several fixes from Friedrich Vedder
195         * <fwv@myrtle.lahn.de>:
196             - Added gunzip -t, removed gunzip.c dead code,
197             - fixed several typos
198             - Glibc 2.0.7 and libc5 compile fixes
199         * Fixed a bug where 'mknod --help' would segfault.
200             
201
202         -Erik Andersen, Jan 07, 2000
203
204 0.39 
205         * New Apps: ping, hostname, and mkfifo contributed by Randolph Chung
206             <tausq@debian.org>.  3 items off the TODO list!
207         * I wrote free (just calls "cat /proc/meminfo").  Added tail, based on
208         * tail from GNU textutils-1.19, but adjusted
209             to suit my evil purposes.  Costs 6k.  I'll make it smaller
210             sometime.
211         * on reboot, init called 'umount -a -n', which caused errors
212             when BB_MTAB was not enabled.  Changed to 'umount -a', which does
213             the right thing.
214         * init will now try to run /sbin/getty if it is present (for easy
215             integration with the about-to-be-released tinylogin.)
216         * kill now behaves itself properly, added 'kill -l' to list signals 'ls
217         * -l' was failing on long directories, since my_getid was leaking 
218             one file descriptor per file.  Oops.
219         * Fixed rebooting from init.  I'd accidently left some debugging code
220         * in
221             which blocked reboots.
222         * Fixed reboot, halt (and added poweroff) such that they handle it when
223             init is not at PID 1 (like when running in an initrd).
224         * Added a prelinary du implementation.  Some parameter parsing
225             stuff still needs to be added. -beppu (John Beppu
226             <beppu@lineo.com>)
227         * Implemented tee.  -beppu Implemented head. -beppu
228
229         -Erik Andersen, Dec 10, 1999
230
231 0.38
232         * Fixed a segfault in 'umount -a' when a badly formed /etc/fstab
233             file existed.
234         * df will not exit on error, but will stat all mounted filesystems.
235         * Fixed tar so uid/gid/permissions on extracted tarballs will be 
236             correct.
237         * Fixed find -name so it properly uses shell wildcard patterns 
238             (i.e. `*', `?', and `[]') instead of regular expressions, which
239             was causing some confusing and unexpected behavior.
240         * Added klogd to syslogd, so now the log will contain both system and
241             kernel messages.
242         * syslogd now creates the /dev/log socket to make sure it is there, and
243             is actually a socket with the right permissions.
244         * I've taken a first step to making busybox not need the /proc 
245             filesystem.  Most apps don't need it.  Those that _require_ it, 
246             will complain if you enable them when you disable 
247             BB_FEATURE_USE_PROCFS.
248            
249         -Erik Andersen, Dec 5, 1999
250
251 0.37
252         * Wrote a micro syslogd, and a logger util (to log things to the syslog
253             from the command line or scripts)  With both compiled in, costs 4k.
254         * Fixed 'make install' so symlinks are installed in their proper
255         * locations.  Changed the build system slightly so that features can
256         * now be enabled
257             or disabled from the busybox.defs.h header file, without trying to
258             compile in a source file named after that featue (unless that file
259             exists).
260         * Several options are now moved into busybox.defs.h Now 'rm -R' and 'rm
261         * -r' both work.  dd now properly handles input beyond 1 block from
262         * stdin.  Fixed a bug where tar unpacked everything a directories.
263         * Moved some code 
264             from createPath into mkdir where it belonged, thereby making tar
265             work properly.
266         * Fixed an off-by-one bug in cat.  Given a list of file it wouldn't cat
267         * out the
268             last file in the list.
269         * Fixed 'ls -ln' so numeric group/uid are presented properly, and fixed
270         * 'ls -l' 
271             so when uid/gid is not in /etc/{passwd,group} the numeric group/uid
272             are presented properly.  
273         * Also added a TODO.
274
275
276         -Erik Andersen, Nov 25, 1999
277
278 0.36
279         * fixed dd so it properly defaults to stdin and stdout when no 
280             if= and of= are set (fix thanks to Eric Delaunay).
281         * Don't try to close the file descriptor of a pipein tar. (fix also
282         * from
283             Eric Delaunay).
284         * Made createPath be quiet (again thanks to Eric Delaunay).  If
285         * BB_CONSOLE_CMD_IF_RC_SCRIPT_EXITS is defined, then whatever
286             command you define it as will be run if the init script exits.
287         * Updated install.sh to make it more robust (thanks to Adam Di Carlo)
288         * NFS support added to mount by Eric Delaunay.  It costs 10k when
289         * compiled
290             in, but that is still a big win for those that use NFS.
291         * Made 'rm -f' be silent for non-existant files (thanks to Eric
292         * Delaunay).  changed zcat.c to gunzip.c.  It now obeys the principle
293         * of least surprise 
294             and acts as god intended gunzip and zcat to act.  They answer
295             --help and obey the '-c' flag.
296         * Fixed a bug in mv which caused it to not move files when the
297         * destination
298             was a directory.
299         * Fixed a decimal-instead-of-octal bug causing mkdir to make
300         * directories
301             with very wrong permissions.
302         * chmod would overwrite file permissions instead of modifying them.
303             Now it properly modifies permissions.
304         * Init now sends warnings destined for the console to /dev/console to
305         * ensure
306             they show up on whatever the active console it.  Otherwise
307             important messages (for example that the system is rebooting) were
308             not seen when switched to a different VT.
309
310         -Erik Andersen, Nov 17, 1999
311         
312 0.35
313         * gzip now obeys the principle of least surprise and acts like god
314         * intended 
315             (i.e. it accepts a file name, answers --help, and obeys the '-c'
316             flag and only then outputs to stdout).
317         * Fixed more.c to compile autowidth on sparc and set initial winsize 
318             to 0,0 in case the TIOCGWINSZ ioctl fails.  Fix thanks to Eric
319             Delaunay.
320         * Fixed tar so it now works as expected (it had TRUE/FALSE backwards)
321         * tar now accepts --help chmod, chown, and chgrp usage now works
322         * General usage (i.e. --help) cleanups for most apps umount now parses
323         * options correctly tar can now unpack tarballs containing device
324         * special files, 
325             sockets, and fifos (though it can't pack them up) thanks to Matt
326             Porter.  Creating archives containing these is still left to the
327             interested student.
328         * fixed up the license in more.c to properly point to Bruce Perens.
329
330         -Erik Andersen, Nov  11, 1999
331
332 0.34
333         * ls -l now displays link names outside the current directory,
334             Patch thanks to Eric Delaunay
335         * init now properly handles sparc serial consoles and does a
336             better job of finding the real console device rather than using
337             /dev/console which doesn't support job control. Patch also thanks
338             to Eric Delaunay.
339         * more started to read from stdin after the last file was finished, and 
340             options were not parsed correctly (fix thanks to Eric Delaunay).
341         * more will now use the terminal size if BB_FEATURE_AUTOWIDTH is on.
342         * rm wouldn't remove a symlink unless the symlink was valid.  This was
343             a side effect of the busybox 0.32 recursiveAction() fix.  Things
344             should now work correctly.
345         * grep wouldn't grep stdin.  Now it does.  sed wouldn't sed stdin.  Now
346         * it does.  sed was appending a \n to the end of lines with
347         * replacements.
348             Now it doesn't do that.
349         * ls -l now bypasses libc6 nss when displaying user/group names.
350             Now uses my_getpwuid and my_getgrgid.
351
352          -Erik Andersen, Nov  8, 1999
353
354 0.33
355         * Fixed a bug where init could hang instead of rebooting.
356         * Removed some debugging noise from init.c
357         * Fixed ln so it works now (it was very broken).
358         * Fixed df so it won't segfault when there is no /etc/fstab,
359         * If BB_MTAB is not defined, df and mount will whine if /etc/fstab
360             is not installed (since they cannot fixup "/dev/root" to 
361             state the real root device name)
362         * merged some redundant code from mtab.c/df.c into utility.c
363
364          -Erik Andersen, Nov  5, 1999
365
366 0.32
367         * More changes -- many thanks to Lineo for paying me to work on
368             busybox.  If you have any problems please let me know ASAP at
369             andersen@lineo.com or andersee@debian.org
370         * usage() now prints the BusyBox version.  This will help folks
371             realize that they are not in Kansas anymore.
372         * Fixed mkdir -m option so that it works.  kill segfaulted w/o any
373         * arguments.  Now it doesn't do that.  kill wasn't properly accepting
374         * signal names.  It does now.  Added new apps chvt and deallocvt (I
375         * should probably add open) Major rewrite of init.c.  Code is now
376         * readable by mere mortals IMHO.  Wrote sed -- weighs only 1.8k (5.8k
377         * with full regular expressions!).  Fixed a stupid seg-fault in sync
378         * Fixed mount -- mount -a failed to parse and apply mount options Fixed
379         * umount -n (patch thanks to Matthew Grant <grantma@anathoth.gen.nz>)
380         * umount -a no longer umounts /proc Added BB_MTAB, allowing (at the
381         * cost of ~1.5k and the need for a rw /etc)
382             folks to use a real /etc/mtab file instead of a symlink to
383             /proc/mounts.  mount, and umount will add/remove entries and df
384             will now use /etc/mtab if BB_MTAB is defined. 
385         * Fixed a nice bug in recursiveAction() which caused it to infinitely
386             hunt through /proc/../fd/* creating new file descriptors if it
387             followed the /dev/fd link over to /proc.  recursiveAction() now
388             lstat's the file when followLinks==FALSE so it won't follow links
389             as the name suggests.  Fix thanks to Matt Porter
390             <porter@debian.org>.
391
392
393          -Erik Andersen, Nov  4, 1999
394
395 0.31
396         * I added a changelog for version 0.30.  adjusted find internals to
397         * make it smaller, and removed 
398             some redundancy.
399         * Fixed a segfault in ps when /etc/passwd or /etc/group 
400             are absent.  Now will warn you and carry on.
401         * Added in optional _real_ regular expression support (to be
402             the basis for a future sed utility).  When compiled in it adds
403             3.9k, but makes grep much more capable.
404         * Checked out using nftw(3) for recursive stuff, but unfortunatly
405             it wasn't supported before GNU libc 2.1, and some folks use glibc
406             2.0.7 since it is much smaller than that latest and greatest.
407
408          -Erik Andersen, Oct 21, 1999
409
410 0.30
411         Major changes -- lots of stuff rewritten. Many thanks to Lineo for
412         paying me to make these updates. If you have any problems with busybox, 
413         or notice any bugs -- please let me know so I can fix it.  These 
414         changes include:
415
416         Core Changes:
417             * busybox can now invoke apps in two ways: via symlinks to the
418                 busybox binary, and as 'busybox [function] [arguments]...'
419             * When invoked as busybox, the list of currently compiled in 
420                 functions is printed out (no this is not bloat -- the list has
421                 to be there anyway to map invocation name to function).
422             * busybox no longer parses command lines for apps or displays their
423                 usage info.  Each app gets to handle (or not handle) this for
424                 itself.
425             * Eliminated monadic, dyadic, descend, block_device, and 
426                 postprocess.  It was cumbersome to have so many programs
427                 cobbled together in this way.  Without them, the app is much
428                 more granular.
429             * All shared code now lives in utility.c, and is properly
430                 ifdef'ed to be only included for those apps requiring it.
431             * Eliminated struct FileInfo (the basis of monadic, dyadic, etc)
432                 so now each app has the function prototype of (da-dum): extern
433                 int foo_main(int argc, char** argv); which speeds integration
434                 of new apps.
435             * Adjusted the Makefile to make it easier to 
436                 {en|dis}able debugging.
437             * Changed default compiler optimization to -Os 
438                 (optimize for smaller binaries).
439
440         App Changes:
441             * To cope with the new app function prototype and the removal of
442                 monadic, dyadic, etc, the following apps were re-written:
443                     * cat - Works same as always.  chgrp, chmod, chown -
444                     * rewrite.  Combined into a single 
445                         source file.  Absorbed patches from Enrique Zanardi
446                         <ezanard@debian.org> that removes the dependency on
447                         libc6 libnss* libraries.
448                     * cp - Can now do 'cp -a' can can copy devices,
449                         pipes, symlinks, as well as recursive or non-recursive
450                         dir copies.
451                     * fdflush - adjusted to remove dependancy on struct
452                     * FileInfo.  find - Now includes some basic regexp matching 
453                         which will be the basic of a future mini-sed.
454                     * ln - Same functionality.  mkdir - Added -p flag to
455                     * feature set.  mv - rewrite.  rm - Added -f flag to
456                     * feature set.  rmdir - Same functionality.  swapon,
457                     * swapoff - Combined into a single binary. No longer
458                         uses /etc/swaps.  swap{on|off} -a uses /etc/fstab
459                         instead.
460                     * touch - Same functionality.  date - adjusted with a patch
461                     * from Matthew Grant <grantma@anathoth.gen.nz>
462                 to accomodate glibc timezone support.  I then ripped out GNU
463                 getopt.
464             * mkswap -- new version merged from util-linux.  Can now make
465             * >128Meg swaps.  Replaced the old and star, unstar, and tarcat
466             * with the tar 
467                 implementation from sash.   Now tar behaves as god intended it
468                 to (i.e. tar -xvf <file> and tar -cf <file> <dir> work).
469             * dd -- rewritten.  Can with with files, stdin, stdout.  Added the
470             * following new apps: loadfont -- added from debian boot floppies
471             * chroot -- added based on a patch from Paolo Molaro
472             * <lupus@lettere.unipd.it> grep -- I just wrote it.  Only matches
473             * simple strings ps -- I just wrote it.  Has _no_ options at all,
474             * but works.  fsck_minix, mkfs_minix -- added from util-linux, but
475             * I ripped out
476                         internationalization and such to make them smaller.
477                     * sfdisk -- Added from util-linux (minus
478                     * internationalization and such).  Probably some other
479                     * changes that I forgot to document...
480
481          -Erik Andersen, Oct 20, 1999
482
483 0.29    
484         This version was a messy pre-alpha.  stay away or it will bite you.
485          -Erik Andersen, Sep 24, 1999
486         
487 0.28    
488         mini-netcat (mnc) rewritten.
489         
490 0.27
491         Mount now supports -a, and -t auto.
492         Mount now updates mtab correctly for 'ro'.
493         More checks screen rows size, outputs bytes percentage.
494         Printf added as module.
495 0.26
496         Touch now creates files. -c option for no create.
497