d35f1a4bfa165195fabaae25f52cb90dd0ad18f4
[oweals/busybox.git] / Config.h
1 /* vi: set sw=4 ts=4: */
2 // This file defines the feature set to be compiled into busybox.
3 // When you turn things off here, they won't be compiled in at all.
4 //
5 //// This file is parsed by sed. You MUST use single line comments.
6 //   i.e.  //#define BB_BLAH
7 //
8 //
9 // BusyBox Applications
10 //#define BB_ADJTIMEX
11 //#define BB_AR
12 #define BB_BASENAME
13 #define BB_CAT
14 #define BB_CHGRP
15 #define BB_CHMOD
16 #define BB_CHOWN
17 #define BB_CHROOT
18 #define BB_CHVT
19 #define BB_CLEAR
20 //#define BB_CMP
21 #define BB_CP
22 #define BB_CUT
23 #define BB_DATE
24 //#define BB_DC
25 #define BB_DD
26 //#define BB_DEALLOCVT
27 #define BB_DF
28 #define BB_DIRNAME
29 #define BB_DMESG
30 //#define BB_DOS2UNIX
31 //#define BB_DPKG
32 //#define BB_DPKG_DEB
33 //#define BB_DUTMP
34 #define BB_DU
35 //#define BB_DUMPKMAP
36 #define BB_ECHO
37 #define BB_ENV
38 //#define BB_EXPR
39 //#define BB_FBSET
40 //#define BB_FDFLUSH
41 #define BB_FIND
42 #define BB_FREE
43 //#define BB_FREERAMDISK
44 //#define BB_FSCK_MINIX
45 //#define BB_GETOPT
46 #define BB_GREP
47 #define BB_GUNZIP
48 #define BB_GZIP
49 #define BB_HALT
50 #define BB_HEAD
51 //#define BB_HOSTID
52 //#define BB_HOSTNAME
53 #define BB_ID
54 //#define BB_IFCONFIG
55 #define BB_INIT
56 //#define BB_INSMOD
57 #define BB_KILL
58 #define BB_KILLALL
59 #define BB_KLOGD
60 //#define BB_LASH
61 //#define BB_LENGTH
62 #define BB_LN
63 //#define BB_LOADACM
64 //#define BB_LOADFONT
65 //#define BB_LOADKMAP
66 #define BB_LOGGER
67 //#define BB_LOGNAME
68 #define BB_LS
69 #define BB_LSMOD
70 //#define BB_MAKEDEVS
71 //#define BB_MD5SUM
72 #define BB_MKDIR
73 //#define BB_MKFIFO
74 //#define BB_MKFS_MINIX
75 #define BB_MKNOD
76 #define BB_MKSWAP
77 //#define BB_MKTEMP
78 //#define BB_NC
79 #define BB_MORE
80 #define BB_MOUNT
81 //#define BB_MT
82 #define BB_MV
83 //#define BB_NSLOOKUP
84 //#define BB_PING
85 //#define BB_PIVOT_ROOT
86 #define BB_POWEROFF
87 //#define BB_PRINTF
88 #define BB_PS
89 #define BB_PWD
90 //#define BB_RDATE
91 //#define BB_READLINK
92 #define BB_REBOOT
93 //#define BB_RENICE
94 #define BB_RESET
95 #define BB_RM
96 #define BB_RMDIR
97 //#define BB_RMMOD
98 //#define BB_ROUTE
99 //#define BB_RPMUNPACK
100 #define BB_SED
101 //#define BB_SETKEYCODES
102 #define BB_SH
103 #define BB_SLEEP
104 #define BB_SORT
105 //#define BB_STTY
106 #define BB_SWAPONOFF
107 #define BB_SYNC
108 #define BB_SYSLOGD
109 #define BB_TAIL
110 #define BB_TAR
111 //#define BB_TEE
112 //#define BB_TEST
113 //#define BB_TELNET
114 //#define BB_TFTP
115 #define BB_TOUCH
116 //#define BB_TR
117 #define BB_TRUE_FALSE
118 #define BB_TTY
119 //#define BB_UNIX2DOS
120 //#define BB_UUENCODE
121 //#define BB_UUDECODE
122 #define BB_UMOUNT
123 #define BB_UNIQ
124 #define BB_UNAME
125 //#define BB_UPDATE
126 #define BB_UPTIME
127 //#define BB_USLEEP
128 //#define BB_VI
129 //#define BB_WATCHDOG
130 #define BB_WC
131 //#define BB_WGET
132 #define BB_WHICH
133 #define BB_WHOAMI
134 #define BB_XARGS
135 #define BB_YES
136 // End of Applications List
137 //
138 //
139 //
140 // ---------------------------------------------------------
141 // This is where feature definitions go.  Generally speaking,
142 // turning this stuff off makes things a bit smaller (and less 
143 // pretty/useful).
144 //
145 //
146 // BusyBox will, by default, malloc space for its buffers.  This costs code
147 // size for the call to xmalloc.  You can use the following feature to have
148 // them put on the stack.  For some very small machines with limited stack
149 // space, this can be deadly.  For most folks, this works just fine...
150 //#define BB_FEATURE_BUFFERS_GO_ON_STACK
151 // The third alternative for buffer allocation is to use BSS.  This works
152 // beautifully for computers with a real MMU (and OS support), but wastes
153 // runtime RAM for uCLinux.  This behavior was the only one available for
154 // BusyBox versions 0.48 and earlier.
155 //#define BB_FEATURE_BUFFERS_GO_IN_BSS
156 //
157 // Turn this on to use Erik's very cool devps, and devmtab kernel drivers,
158 // thereby eliminating the need for the /proc filesystem and thereby saving
159 // lots and lots memory for more important things.  NOTE:  If you enable this
160 // feature, you _must_ have patched the kernel to include the devps patch that
161 // is included in the busybox/kernel-patches directory.  You will also need to
162 // create some device special files in /dev on your embedded system:
163 //        mknod /dev/mtab c 10 22
164 //        mknod /dev/ps c 10 21
165 // I emailed Linus and this patch will not be going into the stock kernel.
166 //#define BB_FEATURE_USE_DEVPS_PATCH
167 //
168 // show verbose usage messages
169 //#define BB_FEATURE_VERBOSE_USAGE
170 //
171 // Use termios to manipulate the screen ('more' is prettier with this on)
172 //#define BB_FEATURE_USE_TERMIOS
173 //
174 // calculate terminal & column widths (for more and ls)
175 #define BB_FEATURE_AUTOWIDTH
176 //
177 // show username/groupnames for ls
178 #define BB_FEATURE_LS_USERNAME
179 //
180 // show file timestamps in ls
181 #define BB_FEATURE_LS_TIMESTAMPS
182 //
183 // enable ls -p and -F
184 #define BB_FEATURE_LS_FILETYPES
185 //
186 // sort the file names
187 #define BB_FEATURE_LS_SORTFILES
188 //
189 // enable ls -R
190 #define BB_FEATURE_LS_RECURSIVE
191 //
192 // enable ls -L
193 #define BB_FEATURE_LS_FOLLOWLINKS
194 //
195 // Disable for a smaller (but less functional) ping
196 #define BB_FEATURE_FANCY_PING
197 //
198 // Make init use a simplified /etc/inittab file (recommended).
199 #define BB_FEATURE_USE_INITTAB
200 //
201 //Enable init being called as /linuxrc
202 #define BB_FEATURE_LINUXRC
203 //
204 //Have init enable core dumping for child processes (for debugging only) 
205 //#define BB_FEATURE_INIT_COREDUMPS
206 //
207 //Make sure nothing is printed to the console on boot
208 //#define BB_FEATURE_EXTRA_QUIET
209 //
210 // enable syslogd -R remotehost
211 #define BB_FEATURE_REMOTE_LOG
212 //
213 // enable syslogd -C
214 //#define BB_FEATURE_IPC_SYSLOG
215 //
216 //Disable for a simple tail implementation (2.34k vs 3k for the full one).
217 //Both provide 'tail -f', but this cuts out -c, -q, -s, and -v. 
218 #define BB_FEATURE_FANCY_TAIL
219 //
220 // Enable support for loop devices in mount
221 #define BB_FEATURE_MOUNT_LOOP
222 //
223 // Enable support for a real /etc/mtab file instead of /proc/mounts
224 //#define BB_FEATURE_MTAB_SUPPORT
225 //
226 // Enable support for mounting remote NFS volumes. 
227 // You may need to mount with "-o nolock" if you are
228 // not running a local portmapper daemon...
229 #define BB_FEATURE_NFSMOUNT
230 //
231 // Enable support forced filesystem unmounting 
232 // (i.e. in case of an unreachable NFS system).
233 #define BB_FEATURE_MOUNT_FORCE
234 //
235 // Enable support for creation of tar files.
236 #define BB_FEATURE_TAR_CREATE
237 //
238 // Enable support for "--exclude" and "-X" for excluding files
239 #define BB_FEATURE_TAR_EXCLUDE
240 //
241 // Enable support for tar -z option (currently only works for inflating)
242 #define BB_FEATURE_TAR_GZIP 
243 //
244 // Enable reverse sort
245 #define BB_FEATURE_SORT_REVERSE
246 //
247 // Enable uniqe sort
248 #define BB_FEATURE_SORT_UNIQUE
249 //
250 // Enable command line editing in the shell.  
251 // Only relevant if BB_SH is enabled. On by default.
252 #define BB_FEATURE_COMMAND_EDITING
253 //
254 // Enable tab completion in the shell.  This is now working quite nicely.
255 // This feature adds a bit over 4k. Only relevant if BB_SH is enabled.
256 #define BB_FEATURE_COMMAND_TAB_COMPLETION
257 //
258 // Attempts to match usernames in a ~-prefixed path
259 //#define BB_FEATURE_COMMAND_USERNAME_COMPLETION
260 //
261 //Allow the shell to invoke all the compiled in BusyBox applets as if they
262 //were shell builtins.  Nice for staticly linking an emergency rescue shell,
263 //among other things. Off by default.
264 // Only relevant if BB_SH is enabled.
265 //#define BB_FEATURE_SH_STANDALONE_SHELL
266 //
267 //When this is enabled, busybox shell applets can be called using full path
268 //names.  This causes applets (i.e., most busybox commands) to override
269 //real commands on the filesystem.  For example, if you run run /bin/cat, it
270 //will use BusyBox cat even if /bin/cat exists on the filesystem and is _not_
271 //busybox.  Some systems want this, others do not.  Choose wisely.  :-) This
272 //only has meaning when BB_FEATURE_SH_STANDALONE_SHELL is enabled.
273 // Only relevant if BB_SH is enabled. Off by default.
274 //#define BB_FEATURE_SH_APPLETS_ALWAYS_WIN
275 //
276 // Uncomment this option for a fancy shell prompt that includes the
277 // current username and hostname.  On systems that don't have usernames
278 // or hostnames, this can look hideous.
279 // Only relevant if BB_SH is enabled.
280 //#define BB_FEATURE_SH_FANCY_PROMPT
281 //
282 //Turn on extra fbset options
283 //#define BB_FEATURE_FBSET_FANCY
284 //
285 //Turn on fbset readmode support
286 //#define BB_FEATURE_FBSET_READMODE
287 //
288 // Support insmod/lsmod/rmmod for post 2.1 kernels
289 //#define BB_FEATURE_NEW_MODULE_INTERFACE
290 //
291 // Support insmod/lsmod/rmmod for pre 2.1 kernels
292 //#define BB_FEATURE_OLD_MODULE_INTERFACE
293 //
294 // Support module version checking
295 //#define BB_FEATURE_INSMOD_VERSION_CHECKING
296 //
297 // Support for uClinux memory usage optimization, which will load the image
298 // directly into the kernel memory.  This divides memory requrements by three.
299 // If you are not running uClinux (i.e. your CPU has an MMU) leave this
300 // disabled...
301 //#define BB_FEATURE_INSMOD_LOADINKMEM
302 //
303 // Support for Minix filesystem, version 2
304 //#define BB_FEATURE_MINIX2
305 //
306 // Enable ifconfig status reporting output -- this feature adds 12k.
307 //#define BB_FEATURE_IFCONFIG_STATUS
308 //
309 // Enable ifconfig slip-specific options "keepalive" and "outfill"
310 //#define BB_FEATURE_IFCONFIG_SLIP
311 //
312 // Enable ifconfig options "mem_start", "io_addr", and "irq".
313 //#define BB_FEATURE_IFCONFIG_MEMSTART_IOADDR_IRQ
314 //
315 // Enable ifconfig option "hw".  Currently works for only with "ether".
316 //#define BB_FEATURE_IFCONFIG_HW
317 //
318 // Enable busybox --install [-s]
319 // to create links (or symlinks) for all the commands that are 
320 // compiled into the binary.  (needs /proc filesystem)
321 // #define BB_FEATURE_INSTALLER
322 //
323 // Enable a nifty progress meter in wget (adds just under 2k)
324 #define BB_FEATURE_WGET_STATUSBAR
325 //
326 // Enable HTTP authentication in wget
327 #define BB_FEATURE_WGET_AUTHENTICATION
328 //
329 // Clean up all memory before exiting -- usually not needed
330 // as the OS can clean up...  Don't enable this unless you
331 // have a really good reason for cleaning things up manually.
332 //#define BB_FEATURE_CLEAN_UP
333 //
334 // Support for human readable output by ls, du, etc.(example 13k, 23M, 235G)
335 #define BB_FEATURE_HUMAN_READABLE
336 //
337 // Support for the find -type option.
338 #define BB_FEATURE_FIND_TYPE
339 //
340 // Support for the find -perm option.
341 #define BB_FEATURE_FIND_PERM
342 //
343 // Support for the find -mtine option.
344 #define BB_FEATURE_FIND_MTIME
345 //
346 // Support for the -A -B and -C context flags in grep
347 //#define BB_FEATURE_GREP_CONTEXT
348 //
349 // Support for the EGREP applet (alias to the grep applet)
350 //#define BB_FEATURE_GREP_EGREP_ALIAS
351 //
352 // Tell tftp what commands that should be supported.
353 #define BB_FEATURE_TFTP_PUT
354 #define BB_FEATURE_TFTP_GET
355 //
356 // features for vi
357 #define BB_FEATURE_VI_COLON             // ":" colon commands, no "ex" mode
358 #define BB_FEATURE_VI_YANKMARK          // Yank/Put commands and Mark cmds
359 #define BB_FEATURE_VI_SEARCH            // search and replace cmds
360 #define BB_FEATURE_VI_USE_SIGNALS       // catch signals
361 #define BB_FEATURE_VI_DOT_CMD           // remember previous cmd and "." cmd
362 #define BB_FEATURE_VI_READONLY          // vi -R and "view" mode
363 #define BB_FEATURE_VI_SETOPTS           // set-able options,  ai ic showmatch
364 #define BB_FEATURE_VI_SET               // :set
365 #define BB_FEATURE_VI_WIN_RESIZE        // handle window resize
366 //
367 // Enable a if you system have setuped locale
368 //#define BB_LOCALE_SUPPORT
369 //
370 // Support for TELNET to pass TERM type to remote host.  Adds 384 bytes.
371 #define BB_FEATURE_TELNET_TTYPE
372 //
373 // End of Features List
374 //
375 //
376 //
377 //
378 //
379 //
380 //---------------------------------------------------
381 // Nothing beyond this point should ever be touched by 
382 // mere mortals so leave this stuff alone.
383 //
384 #if defined BB_SH
385         #if defined BB_FEATURE_COMMAND_EDITING 
386                 #define BB_CMDEDIT
387         #else
388                 #undef BB_FEATURE_COMMAND_EDITING
389                 #undef BB_FEATURE_COMMAND_TAB_COMPLETION
390                 #undef BB_FEATURE_COMMAND_USERNAME_COMPLETION
391                 #undef BB_FEATURE_SH_FANCY_PROMPT
392         #endif
393 #else
394         #undef BB_FEATURE_SH_APPLETS_ALWAYS_WIN
395         #undef BB_FEATURE_SH_STANDALONE_SHELL
396         #undef BB_FEATURE_SH_FANCY_PROMPT
397 #endif
398 //
399 #ifdef BB_KILLALL
400         #ifndef BB_KILL
401                 #define BB_KILL
402         #endif
403 #endif
404 //
405 #ifndef BB_INIT
406         #undef BB_FEATURE_LINUXRC
407 #endif
408 //
409 #if defined BB_MOUNT && defined BB_FEATURE_NFSMOUNT
410         #define BB_NFSMOUNT
411 #endif
412 //
413 #if defined BB_FEATURE_AUTOWIDTH
414         #ifndef BB_FEATURE_USE_TERMIOS
415                 #define BB_FEATURE_USE_TERMIOS
416         #endif
417 #endif
418 //
419 #if defined BB_INSMOD || defined BB_LSMOD
420         #if ! defined BB_FEATURE_NEW_MODULE_INTERFACE && ! defined BB_FEATURE_OLD_MODULE_INTERFACE
421                 #define BB_FEATURE_NEW_MODULE_INTERFACE
422         #endif
423 #endif
424 //
425 #ifdef BB_SYSLOGD
426         #if defined BB_FEATURE_IPC_SYSLOG
427                 #define BB_LOGREAD
428         #endif
429 #endif