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