blob: 35631b84ef47321ec7a3a5d6b6e79224adab3353 [file] [log] [blame]
John Beppu5bca0af2001-04-05 19:41:23 +00001# vi: set sw=4 ts=4:
2
3=head1 NAME
4
5BusyBox - The Swiss Army Knife of Embedded Linux
6
7=head1 SYNTAX
8
9 BusyBox <function> [arguments...] # or
10
11 <function> [arguments...] # if symlinked
12
13=head1 DESCRIPTION
14
15BusyBox combines tiny versions of many common UNIX utilities into a single
16small executable. It provides minimalist replacements for most of the utilities
Eric Andersenfbcf06d2004-03-27 09:40:15 +000017you usually find in GNU coreutils, util-linux, etc. The utilities in BusyBox
18generally have fewer options than their full-featured GNU cousins; however, the
19options that are included provide the expected functionality and behave very
Eric Andersen69bd0d12004-04-06 15:39:20 +000020much like their GNU counterparts.
John Beppu5bca0af2001-04-05 19:41:23 +000021
22BusyBox has been written with size-optimization and limited resources in mind.
23It is also extremely modular so you can easily include or exclude commands (or
Eric Andersenfbcf06d2004-03-27 09:40:15 +000024features) at compile time. This makes it easy to customize your embedded
25systems. To create a working system, just add /dev, /etc, and a Linux kernel.
Eric Andersen69bd0d12004-04-06 15:39:20 +000026BusyBox provides a fairly complete POSIX environment for any small or embedded
27system.
Eric Andersenfbcf06d2004-03-27 09:40:15 +000028
29BusyBox is extremely configurable. This allows you to include only the
30components you need, thereby reducing binary size. Run 'make config' or 'make
Eric Andersen69bd0d12004-04-06 15:39:20 +000031menuconfig' to select the functionality that you wish to enable. The run
Eric Andersenfbcf06d2004-03-27 09:40:15 +000032'make' to compile BusyBox using your configuration.
33
34After the compile has finished, you should use 'make install' to install
35BusyBox. This will install the '/bin/busybox' binary, and will also create
36symlinks pointing to the '/bin/busybox' binary for each utility that you
37compile into BusyBox. By default, 'make install' will place these symlinks
38into the './_install' directory, unless you have defined 'PREFIX', thereby
39specifying some alternative location (i.e., 'make PREFIX=/tmp/foo install').
40If you wish to install using hardlinks, rather than the default of using
41symlinks, you can use 'make PREFIX=/tmp/foo install-hardlinks' instead.
John Beppu5bca0af2001-04-05 19:41:23 +000042
43=head1 USAGE
44
Eric Andersenfbcf06d2004-03-27 09:40:15 +000045BusyBox is a multi-call binary. A multi-call binary is an executable program
46that performs the same job as more than one utility program. That means there
47is just a single BusyBox binary, but that single binary acts like a large
48number of utilities. This allows BusyBox to be smaller since all the built-in
49utility programs (we call them applets) can share code for many common operations.
John Beppu5bca0af2001-04-05 19:41:23 +000050
Eric Andersen69bd0d12004-04-06 15:39:20 +000051You can also invoke BusyBox by issuing a command as an argument on the
John Beppu5bca0af2001-04-05 19:41:23 +000052command line. For example, entering
53
Eric Andersenfbcf06d2004-03-27 09:40:15 +000054 /bin/busybox ls
John Beppu5bca0af2001-04-05 19:41:23 +000055
Eric Andersenc7bda1c2004-03-15 08:29:22 +000056will also cause BusyBox to behave as 'ls'.
John Beppu5bca0af2001-04-05 19:41:23 +000057
Eric Andersenfbcf06d2004-03-27 09:40:15 +000058Of course, adding '/bin/busybox' into every command would be painful. So most
59people will invoke BusyBox using links to the BusyBox binary.
60
61For example, entering
62
63 ln -s /bin/busybox ls
64 ./ls
65
66will cause BusyBox to behave as 'ls' (if the 'ls' command has been compiled
67into BusyBox). Generally speaking, you should never need to make all these
68links yourself, as the BusyBox build system will do this for you when you run
69the 'make install' command.
70
71If you invoke BusyBox with no arguments, it will provide you with a list of the
72applets that have been compiled into your BusyBox binary.
73
John Beppu5bca0af2001-04-05 19:41:23 +000074=head1 COMMON OPTIONS
75
Eric Andersenfbcf06d2004-03-27 09:40:15 +000076Most BusyBox commands support the B<--help> argument to provide a terse runtime
77description of their behavior. If the CONFIG_FEATURE_VERBOSE_USAGE option has
78been enabled, more detailed usage information will also be available.
John Beppu5bca0af2001-04-05 19:41:23 +000079
80=head1 COMMANDS
81
82Currently defined functions include:
83
Eric Andersenb868f552003-12-20 07:16:22 +000084 addgroup, adduser, adjtimex, ar, arping, ash, awk, basename, bunzip2,
Eric Andersen69bd0d12004-04-06 15:39:20 +000085 busybox, bzcat, cal, cat, chgrp, chmod, chown, chroot, chvt, clear, cmp,
86 cp, cpio, crond, crontab, cut, date, dc, dd, deallocvt, delgroup, deluser,
87 devfsd, df, dirname, dmesg, dos2unix, dpkg, dpkg-deb, du, dumpkmap,
88 dumpleases, echo, egrep, env, expr, false, fbset, fdflush, fdformat, fdisk,
89 fgrep, find, fold, free, freeramdisk, fsck.minix, ftpget, ftpput, getopt,
90 getty, grep, gunzip, gzip, halt, hdparm, head, hexdump, hostid, hostname,
91 httpd, hush, hwclock, id, ifconfig, ifdown, ifup, inetd, init, insmod,
Eric Andersenb36900c2004-08-16 10:29:29 +000092 install, ip, ipaddr, ipcalc, iplink, iproute, iptunnel, kill, killall,
93 klogd, lash, last, length, linuxrc, ln, loadfont, loadkmap, logger, login,
94 logname, logread, losetup, ls, lsmod, makedevs, md5sum, mesg, mkdir,
95 mkfifo, mkfs.minix, mknod, mkswap, mktemp, modprobe, more, mount, msh, mt,
96 mv, nameif, nc, netstat, nslookup, od, openvt, passwd, patch, pidof, ping,
Eric Andersen69bd0d12004-04-06 15:39:20 +000097 ping6, pipe_progress, pivot_root, poweroff, printf, ps, pwd, rdate,
98 readlink, realpath, reboot, renice, reset, rm, rmdir, rmmod, route, rpm,
99 rpm2cpio, run-parts, rx, sed, seq, setkeycodes, sha1sum, sleep, sort,
100 start-stop-daemon, strings, stty, su, sulogin, swapoff, swapon, sync,
101 sysctl, syslogd, tail, tar, tee, telnet, telnetd, test, tftp, time, top,
102 touch, tr, traceroute, true, tty, udhcpc, udhcpd, umount, uname,
103 uncompress, uniq, unix2dos, unzip, uptime, usleep, uudecode, uuencode,
104 vconfig, vi, vlock, watch, watchdog, wc, wget, which, who, whoami, xargs,
105 yes, zcat
John Beppu5bca0af2001-04-05 19:41:23 +0000106
Eric Andersen3ddff212004-04-13 16:31:41 +0000107=head1 COMMAND DESCRIPTIONS
Matt Kraai91631012001-08-27 18:55:10 +0000108
Eric Andersen38748fd2004-03-27 11:35:46 +0000109=over 4
110
111