blob: f70f6229875aab287e3350252b72a1739b89a7ad [file] [log] [blame]
Eric Andersenb186d981999-12-03 09:19:54 +00001TODO list for busybox in no particular order. Just because something
2is listed here doesn't mean that it is going to be added to busybox,
3or that doing so is even a good idea. It just means that I _might_ get
4around to it some time. If you have any good ideas, please let me know.
Eric Andersen394f7641999-11-23 21:38:12 +00005
Erik Andersen1c5b2581999-12-16 20:59:36 +00006* login/sulogin/passwd/getty/etc are part of tinylogin, and so are not
Erik Andersen94f5e0b2000-05-01 19:10:52 +00007 needed or wanted in busybox (or else I'd have to link to libcrypt).
Erik Andersen1c5b2581999-12-16 20:59:36 +00008
Erik Andersen31638212000-01-15 22:28:50 +00009* Networking apps are probably going to be split out some time soon into a
Erik Andersen330fd2b2000-05-19 05:35:19 +000010 separate package (named perhaps netkit-tiny?). This would remove the
11 following items from BusyBox: hostid, hostname, nc, nslookup, telnet,
12 and ping. nfs mounting and syslogd (when it supports network logging)
13 will remain in BusyBox.
Erik Andersen31638212000-01-15 22:28:50 +000014
Eric Andersenb186d981999-12-03 09:19:54 +000015 -Erik
16
17-----------
Eric Andersenbefda6e1999-11-25 08:06:22 +000018
Eric Andersen926e0e32000-06-05 05:33:00 +000019Bugs that need fixing before the 0.44 release goes out the door:
Mark Whitley0a027e62000-05-08 23:25:59 +000020
Eric Andersenf0c30b72000-06-03 00:27:00 +000021 - mkfs.minix rev 1.7 completely broke the parser. Fix it.
Mark Whitley0a027e62000-05-08 23:25:59 +000022 - 'grep foo$ file' doesn't work
23 - 'grep *foo file' segfaults
24 - ps dirent race bug (need to stat the file before attempting chdir)
Eric Andersenb5966362000-05-31 20:04:38 +000025 - The following commands segfault:
26 chmod -R
27 chown -R
28 chgrp -R
Eric Andersenb5966362000-05-31 20:04:38 +000029 - I believe that swaponoff may also be also broken (check it).
30 - It used to be that BusyBox tar would happily overwrite existing files on
Eric Andersenb6c6d872000-06-02 03:21:32 +000031 an extraction. However, as of 0.42, BusyBox tar simply dies as soon as an
32 existing file is found.
33 - Make 'mount -a' work even when /proc isn't mounted (ugly bug).
34 - Make 'ln -s /tmp/file .' work the way GNU ln does (i.e. makes a link to
35 /tmp/file in the current directory, rather then trying and failing to create
36 a symlink named "." in the current working directory).
37 - implement 'ls -R'.
Eric Andersen926e0e32000-06-05 05:33:00 +000038 - "math" should also take input from stdin
39 - "more" doesn't accept " " to scroll by one page when BB_FEATURE_USE_TERMIOS
40 is not on.
Mark Whitley0a027e62000-05-08 23:25:59 +000041
Erik Andersen8ea7d8c2000-05-20 00:40:08 +000042
Mark Whitley0a027e62000-05-08 23:25:59 +000043-----------
44
Erik Andersen10c341a1999-12-17 18:52:06 +000045* Make insmod actually work
Eric Andersen485b9551999-12-07 23:14:59 +000046* dnsdomainname
Erik Andersen9ffdaa62000-02-11 21:55:04 +000047* traceroute/netstat
Eric Andersenb186d981999-12-03 09:19:54 +000048* rdate
49* hwclock
Eric Andersenb186d981999-12-03 09:19:54 +000050* stty
Erik Andersen0817d132000-04-09 15:17:40 +000051* expr
Erik Andersen95c1c1e2000-04-14 21:45:29 +000052* wget (or whatever I call it)
53* tftp
54* ftp
Mark Whitley0a027e62000-05-08 23:25:59 +000055* group/commonize strings, remove dups (for i18n, l10n)
Mark Whitley517cab72000-06-06 18:05:47 +000056* consider making a unified option parser (if it can be done modular, small, etc.)
Erik Andersenfac10d72000-02-07 05:29:42 +000057
Erik Andersene2729152000-02-18 21:34:17 +000058-----------------------
59
Erik Andersenf378fce2000-05-01 19:27:17 +000060Running the following:
61
Erik Andersen12d1b372000-05-01 19:50:37 +000062 rm -f busybox && make LDFLAGS+=-nostdlib 2>&1 | \
63 sed -ne 's/.*undefined reference to `\(.*\)..*/\1/gp' | sort | uniq
Erik Andersenf378fce2000-05-01 19:27:17 +000064
65reveals the list of all external (i.e. libc) things that BusyBox depends on.
66It would be a very nice thing to reduce this list to an absolute minimum, and
67then create a microLibc to provide these functions. There is no good reason
68for GNU libc to be so big. I'm sure it can be a lot better.
69
Erik Andersen9b7d9642000-05-01 19:49:20 +000070(BTW, this is more informative if BB_FEATURE_NFSMOUNT is turned off...)
71
Erik Andersen5afc8642000-05-02 00:07:56 +000072Most wanted list:
73
74 [andersen@slag busybox]$ grep -l getgroups *.[ch]
75 test.c
76
77Policy violation. getgroups uses libc nss, which is unlikely
78to be present in an embedded system.
79
Erik Andersen969f9b02000-05-13 19:08:58 +000080To be replaced with a busybox local glob routine:
Erik Andersen5afc8642000-05-02 00:07:56 +000081
82 [andersen@slag busybox]$ grep -l glob *.[ch]
83 gunzip.c
84 gzip.c
85 sh.c
86 tar.c
87 telnet.c
88
89Can check_wildcard_match() from utility.c do this job?
90
Erik Andersenf378fce2000-05-01 19:27:17 +000091
92-----------------------
93
Erik Andersen7c4b2f32000-02-29 21:49:22 +000094Compile with debugging on, run 'nm --size-sort ./busybox'
95and then start with the biggest things and make them smaller...
96
Erik Andersen7c4b2f32000-02-29 21:49:22 +000097-----------------------
98
Erik Andersene2729152000-02-18 21:34:17 +000099busybox.defs.h is too big and hard to follow.
100
Erik Andersen5661fe02000-04-05 01:00:52 +0000101Perhaps I need to add a better build system (like the Linux kernel?)
Erik Andersene2729152000-02-18 21:34:17 +0000102
103-----------------------
104
Erik Andersen27fdd082000-02-19 18:16:49 +0000105Feature request:
106
107/bin/busybox --install -s which makes all links to commands that it
108 can support (an optionnal -s should be used for symbolic links instead
109 of hard links).
110
Erik Andersen3b9522f2000-02-22 17:12:00 +0000111-----------------------
112
113
114> Have you ever thought of doig network logging in busybox syslogd ? It
115> would quite make sense on embedded systems... :)
116
117So far I had not considered it. Basically, you wish to have
118messages from the embedded box logged to a remote network
119syslog box, right? I can see that this would be useful.
120I'll add this to the TODO list,
121
Erik Andersen029011b2000-03-04 21:19:32 +0000122
123-----------------------
124
125
Erik Andersen029011b2000-03-04 21:19:32 +0000126 I think that the add_inode &c in utility.c needs to also stow the
127 st_dev field, and that du.c should NOT call `reset_inode_list'
128 because there can be hard links from inside one argv/ to inside
129 another argv/. du.c probably ought to have an -x switch like GNU du
130 does also...
131
132
Erik Andersen298854f2000-03-23 01:09:18 +0000133------------------------------------------------------------------
134
Eric Andersen926e0e32000-06-05 05:33:00 +0000135An interesting email listing some apps that use /proc. BusyBox
136tries to avoid /proc as mush as is possible, so this stuff is
137interesting (to me at least):
138
Erik Andersen298854f2000-03-23 01:09:18 +0000139
140Date: Fri, 25 Feb 2000 08:23:12 +0000 (GMT)
141From: Riley Williams <rhw@MemAlpha.CX>
142X-Sender: rhw@moo.cus.org.uk
143To: almesber@lrc.di.epfl.ch
144Cc: "Albert D. Cahalan" <acahalan@cs.uml.edu>,
145 Linux Kernel <linux-kernel@vger.rutgers.edu>
146Subject: Re: What /proc should contain [was: /proc/driver/microcode]
147In-Reply-To: <20000224165245.A29790@lrc.di.epfl.ch>
148Message-ID: <Pine.LNX.4.21.0002250806220.8741-100000@moo.cus.org.uk>
149Sender: owner-linux-kernel@vger.rutgers.edu
150Precedence: bulk
151
152Hi there.
153
154 >> Nope, most /proc access is does via programs written in C.
155
156 > That varies a lot from file to file. E.g. I haven't seen any
157 > programs that are specificly designed to read /proc/atm/* yet,
158 > and I know of only one (fuser) that reads /proc/mounts,
159 > extracting only partial information (just to pick two examples
160 > that I'm quite familiar with).
161
162As a point of reference, here's a slightly tweaked analysis of the
163programs on the system I'm reading your mail on. Basically, I ran the
164following script...
165
166 Q> #!/bin/bash
167 Q> function use() {
168 Q> for Z in $* ; do
169 Q> strings $Z | grep /proc | sed "s=^=$Z ="
170 Q> done
171 Q> }
172 Q> use /{,s}bin/* /usr/{,s}bin/* | sort -u | tee proc-usage
173
174...and then went through it removing comments and print format
175strings. Replace /proc with /dev and you'd soon have an equivalent
176list for that - although I can report that such is MUCH larger...
177
178There are three programs therein that refer to /proc/mounts ...
179
180 /bin/mount
181 /bin/umount
182 /usr/bin/eject
183
184...and, as you stated, none that refer to /proc/atm on this system.
185However, as this is a RedHat Linux 5.0 based system, that's not
186necessarily an up to date reference thereto...
187
188Here's the list anyway...
189
190/bin/kill /proc/%d/cmdline
191/bin/kill /proc/%d/stat
192
193/bin/mount /proc/devices
194/bin/mount /proc/filesystems
195/bin/mount /proc/mounts
196
197/bin/netstat /proc/net
198/bin/netstat /proc/net/appletalk
199/bin/netstat /proc/net/ax25
200/bin/netstat /proc/net/ax25_route
201/bin/netstat /proc/net/dev
202/bin/netstat /proc/net/ip_masquerade
203/bin/netstat /proc/net/ipx
204/bin/netstat /proc/net/ipx_route
205/bin/netstat /proc/net/netstat
206/bin/netstat /proc/net/nr
207/bin/netstat /proc/net/nr_neigh
208/bin/netstat /proc/net/nr_nodes
209/bin/netstat /proc/net/raw
210/bin/netstat /proc/net/route
211/bin/netstat /proc/net/rt_cache
212/bin/netstat /proc/net/snmp
213/bin/netstat /proc/net/tcp
214/bin/netstat /proc/net/udp
215/bin/netstat /proc/net/unix
216
217/bin/umount /proc/devices
218/bin/umount /proc/mounts
219
220/sbin/arp /proc/net/appletalk
221/sbin/arp /proc/net/arp
222/sbin/arp /proc/net/ax25
223/sbin/arp /proc/net/ipx
224/sbin/arp /proc/net/nr
225/sbin/arp /proc/net/unix
226
227/sbin/cardctl /proc/devices
228
229/sbin/cardmgr /proc/devices
230
231/sbin/fdisk /proc/ide/%s/media
232/sbin/fdisk /proc/scsi/scsi
233
234/sbin/getty /proc/version
235
236/sbin/ifconfig /proc/net
237/sbin/ifconfig /proc/net/appletalk
238/sbin/ifconfig /proc/net/ax25
239/sbin/ifconfig /proc/net/dev
240/sbin/ifconfig /proc/net/ipx
241/sbin/ifconfig /proc/net/nr
242/sbin/ifconfig /proc/net/unix
243
244/sbin/ifup /proc/sys/kernel/modprobe
245
246/sbin/ipchains /proc/net/ip_fwchains
247/sbin/ipchains /proc/net/ip_fwnames
248/sbin/ipchains /proc/net/ip_masquerade
249/sbin/ipchains /proc/sys/net/ipv4/ip_forward
250
251/sbin/ipmaddr /proc/net/dev_mcast
252/sbin/ipmaddr /proc/net/igmp
253/sbin/ipmaddr /proc/net/igmp6
254
255/sbin/iptunnel /proc/net/dev
256
257/sbin/killall5 /proc/%s/cmdline
258/sbin/killall5 /proc/%s/exe
259/sbin/killall5 /proc/%s/stat
260/sbin/killall5 /proc/version
261
262/sbin/klogd /proc/kmsg
263
264/sbin/lsmod /proc/modules
265
266/sbin/modprobe /proc/modules
267
268/sbin/pidof /proc/%s/cmdline
269/sbin/pidof /proc/%s/exe
270/sbin/pidof /proc/%s/stat
271/sbin/pidof /proc/version
272
273/sbin/probe /proc/pci
274
275/sbin/rarp /proc/net/ax25
276/sbin/rarp /proc/net/nr
277/sbin/rarp /proc/net/rarp
278
279/sbin/rmmod /proc/modules
280
281/sbin/rmmod.static /proc/modules
282
283/sbin/route /proc/net/appletalk
284/sbin/route /proc/net/ax25
285/sbin/route /proc/net/ax25_route
286/sbin/route /proc/net/ipx
287/sbin/route /proc/net/ipx_route
288/sbin/route /proc/net/nr
289/sbin/route /proc/net/nr_neigh
290/sbin/route /proc/net/nr_nodes
291/sbin/route /proc/net/route
292/sbin/route /proc/net/rt_cache
293/sbin/route /proc/net/unix
294
295/sbin/scsi_info /proc/scsi
296/sbin/scsi_info /proc/scsi/%s
297/sbin/scsi_info /proc/scsi/scsi
298
299/sbin/slattach /proc/net/ax25
300/sbin/slattach /proc/net/nr
301
302/sbin/swapoff /proc/swaps
303
304/sbin/swapon /proc/swaps
305
306/sbin/uugetty /proc/version
307
308/usr/bin/dig /proc/
309/usr/bin/dig /proc/interrupts
310/usr/bin/dig /proc/meminfo
311/usr/bin/dig /proc/rtc
312/usr/bin/dig /proc/self/status
313/usr/bin/dig /proc/stat
314
315/usr/bin/dnsquery /proc/
316/usr/bin/dnsquery /proc/interrupts
317/usr/bin/dnsquery /proc/meminfo
318/usr/bin/dnsquery /proc/rtc
319/usr/bin/dnsquery /proc/self/status
320/usr/bin/dnsquery /proc/stat
321
322/usr/bin/eject /proc/mounts
323
324/usr/bin/emacs /proc/loadavg
325
326/usr/bin/fetchmail /proc/net/dev
327
328/usr/bin/free /proc/meminfo
329
330/usr/bin/gmake /proc/loadavg
331
332/usr/bin/gpm-root /proc/loadavg
333/usr/bin/gpm-root /proc/meminfo
334
335/usr/bin/host /proc/
336/usr/bin/host /proc/interrupts
337/usr/bin/host /proc/meminfo
338/usr/bin/host /proc/rtc
339/usr/bin/host /proc/self/status
340/usr/bin/host /proc/stat
341
342/usr/bin/hoststat /proc/loadavg
343
344/usr/bin/hwdiag /proc/cpuinfo
345/usr/bin/hwdiag /proc/pci
346/usr/bin/hwdiag /proc/scsi/scsi
347/usr/bin/hwdiag /proc/version
348
349/usr/bin/lsdev /proc/dma
350/usr/bin/lsdev /proc/interrupts
351/usr/bin/lsdev /proc/ioports
352
353/usr/bin/mailq /proc/loadavg
354
355/usr/bin/make /proc/loadavg
356
357/usr/bin/mcookie /proc/loadavg
358/usr/bin/mcookie /proc/stat
359
360/usr/bin/newaliases /proc/loadavg
361
362/usr/bin/nslookup /proc/
363/usr/bin/nslookup /proc/interrupts
364/usr/bin/nslookup /proc/meminfo
365/usr/bin/nslookup /proc/rtc
366/usr/bin/nslookup /proc/self/status
367/usr/bin/nslookup /proc/stat
368
369/usr/bin/nsupdate /proc/
370/usr/bin/nsupdate /proc/interrupts
371/usr/bin/nsupdate /proc/meminfo
372/usr/bin/nsupdate /proc/rtc
373/usr/bin/nsupdate /proc/self/status
374/usr/bin/nsupdate /proc/stat
375
376/usr/bin/pgp /proc/version
377/usr/bin/pgpe /proc/version
378/usr/bin/pgpk /proc/version
379/usr/bin/pgps /proc/version
380/usr/bin/pgpv /proc/version
381
382/usr/bin/procinfo /proc/cmdline
383/usr/bin/procinfo /proc/devices
384/usr/bin/procinfo /proc/dma
385/usr/bin/procinfo /proc/filesystems
386/usr/bin/procinfo /proc/interrupts
387/usr/bin/procinfo /proc/loadavg
388/usr/bin/procinfo /proc/meminfo
389/usr/bin/procinfo /proc/modules
390/usr/bin/procinfo /proc/stat
391/usr/bin/procinfo /proc/uptime
392/usr/bin/procinfo /proc/version
393
394/usr/bin/purgestat /proc/loadavg
395
396/usr/bin/screen /proc/loadavg
397
398/usr/bin/strace /proc/%d/stat
399
400/usr/bin/top /proc/cpuinfo
401/usr/bin/top /proc/meminfo
402/usr/bin/top /proc/stat
403
404/usr/bin/vmstat /proc/%s/stat
405/usr/bin/vmstat /proc/meminfo
406/usr/bin/vmstat /proc/stat
407
408/usr/sbin/atd /proc/loadavg
409
410/usr/sbin/dnskeygen /proc/
411/usr/sbin/dnskeygen /proc/interrupts
412/usr/sbin/dnskeygen /proc/meminfo
413/usr/sbin/dnskeygen /proc/rtc
414/usr/sbin/dnskeygen /proc/self/status
415/usr/sbin/dnskeygen /proc/stat
416
417/usr/sbin/fuser /proc/%d/stat
418/usr/sbin/fuser /proc/net/%s
419/usr/sbin/fuser /proc/net/unix
420
421/usr/sbin/in.identd /proc/net/tcp
422
423/usr/sbin/irpd /proc/
424/usr/sbin/irpd /proc/interrupts
425/usr/sbin/irpd /proc/meminfo
426/usr/sbin/irpd /proc/rtc
427/usr/sbin/irpd /proc/self/status
428/usr/sbin/irpd /proc/stat
429
430/usr/sbin/named /proc/
431/usr/sbin/named /proc/interrupts
432/usr/sbin/named /proc/meminfo
433/usr/sbin/named /proc/rtc
434/usr/sbin/named /proc/self/status
435/usr/sbin/named /proc/stat
436
437/usr/sbin/named-xfer /proc/
438/usr/sbin/named-xfer /proc/interrupts
439/usr/sbin/named-xfer /proc/meminfo
440/usr/sbin/named-xfer /proc/rtc
441/usr/sbin/named-xfer /proc/self/status
442/usr/sbin/named-xfer /proc/stat
443
444/usr/sbin/readprofile /proc/profile
445
446/usr/sbin/rwhod /proc/loadavg
447/usr/sbin/rwhod /proc/uptime
448
449/usr/sbin/sendmail /proc/loadavg
450
451/usr/sbin/setconsole /proc/openprom/options
452/usr/sbin/setconsole /proc/openprom/options/${console}-mode
453/usr/sbin/setconsole /proc/openprom/options/input-device
454/usr/sbin/setconsole /proc/openprom/options/output-device
455
456Best wishes from Riley.
457
458 * Copyright (C) 1999, Memory Alpha Systems.
459 * All rights and wrongs reserved.
460
461+----------------------------------------------------------------------+
462| There is something frustrating about the quality and speed of Linux |
463| development, ie., the quality is too high and the speed is too high, |
464| in other words, I can implement this XXXX feature, but I bet someone |
465| else has already done so and is just about to release their patch. |
466+----------------------------------------------------------------------+
467 * http://www.memalpha.cx/Linux/Kernel/
468
469
470-
471To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
472the body of a message to majordomo@vger.rutgers.edu
473Please read the FAQ at http://www.tux.org/lkml/
474