Why we didn't take a watchdog.c suggestion this time 'round, in case anybody
comes up with a fix...
diff --git a/TODO b/TODO
index 92fd403..a765627 100644
--- a/TODO
+++ b/TODO
@@ -1,6 +1,6 @@
Busybox TODO
-Stuff that needs to be done
+Stuff that needs to be done. All of this is fair game for 1.2.
find
doesn't understand (), lots of susv3 stuff.
@@ -13,11 +13,20 @@
way of adding the minimal set of bash features a given script uses is a big
job, but it would be a big improvement.
- Note: Rob Landley (rob@landley.net) is working on this one, but very slowly...
+ Note: Rob Landley (rob@landley.net) is working on a new unified shell called
+ bbsh, but it's a low priority...
---
diff
We should have a diff -u command. We have patch, we should have diff
(we only need to support unified diffs though).
+
+ Also, make sure we handle empty files properly:
+ From the patch man page:
+
+ you can remove a file by sending out a context diff that compares
+ the file to be deleted with an empty file dated the Epoch. The
+ file will be removed unless patch is conforming to POSIX and the
+ -E or --remove-empty-files option is not given.
---
patch
Should have simple fuzz factor support to apply patches at an offset which
@@ -31,12 +40,20 @@
anything, just one that can handle preformatted ascii man pages, possibly
compressed. This could probably be a script in the extras directory that
calls cat/zcat/bzcat | less
+
+ (How doclifter might work into this is anybody's guess.)
---
bzip2
Compression-side support.
---
init
General cleanup.
+---
+ar
+ Write support?
+---
+mdev
+ Micro-udev.
Architectural issues:
@@ -44,9 +61,11 @@
We should have a bb_close() in place of normal close, with a CONFIG_ option
to not just check the return value of close() for an error, but fsync().
Close can't reliably report anything useful because if write() accepted the
- data then it either went out or it's in cache or a pipe buffer. Either way,
- there's no guarantee it'll make it to its final destination before close()
- gets called, so there's no guarantee that any error will be reported.
+ data then it either went out to the network or it's in cache or a pipe
+ buffer. Either way, there's no guarantee it'll make it to its final
+ destination before close() gets called, so there's no guarantee that any
+ error will be reported.
+
You need to call fsync() if you care about errors that occur after write(),
but that can have a big performance impact. So make it a config option.
---
@@ -89,8 +108,8 @@
"add this directory", "add this symlink" and so on.
This could clean up tar and zip, and make it cheaper to add cpio and ar
- write support, and possibly even cheaply add things like mkisofs someday,
- if it becomes relevant.
+ write support, and possibly even cheaply add things like mkisofs or
+ mksquashfs someday, if they become relevant.
---
Text buffer support.
Several existing applets (sort, vi, less...) read
@@ -126,6 +145,10 @@
One example of an existing system that does this already is Firmware Linux:
http://www.landley.net/code/firmware
---
+initramfs
+ Busybox should have a sample initramfs build script. This depends on
+ involves bbsh, mdev, and switch_root.
+---
Memory Allocation
We have a CONFIG_BUFFER mechanism that lets us select whether to do memory
allocation on the stack or the heap. Unfortunately, we're not using it much.
@@ -202,3 +225,11 @@
render the existing FEATURE_CLEAN_UP code redundant.
For right now, exit() handles it just fine.
+
+
+
+Minor stuff:
+ watchdog.c could autodetect the timer duration via:
+ if(!ioctl (fd, WDIOC_GETTIMEOUT, &tmo)) timer_duration = 1 + (tmo / 2);
+ Unfortunately, that needs linux/watchdog.h and that contains unfiltered
+ kernel types on some distros, which breaks the build.