Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 1 | # |
| 2 | # For a description of the syntax of this configuration file, |
Kartik Agaram | 43b17b1 | 2018-05-31 22:15:55 -0700 | [diff] [blame] | 3 | # see docs/Kconfig-language.txt. |
Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 4 | # |
| 5 | |
Mike Frysinger | 9ac178a | 2005-09-24 05:49:36 +0000 | [diff] [blame] | 6 | menu "Shells" |
Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 7 | |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 8 | |
| 9 | choice |
| 10 | prompt "Choose which shell is aliased to 'sh' name" |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 11 | default SH_IS_ASH |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 12 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 13 | Choose which shell you want to be executed by 'sh' alias. |
| 14 | The ash shell is the most bash compatible and full featured one. |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 15 | |
Denys Vlasenko | 121fb95 | 2010-06-07 13:34:34 +0200 | [diff] [blame] | 16 | # note: cannot use "select ASH" here, it breaks "make allnoconfig" |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 17 | config SH_IS_ASH |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 18 | depends on !NOMMU |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 19 | bool "ash" |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 20 | select SHELL_ASH |
Kang-Che Sung | 9529115 | 2017-01-04 12:29:04 +0100 | [diff] [blame] | 21 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 22 | Choose ash to be the shell executed by 'sh' name. |
| 23 | The ash code will be built into busybox. If you don't select |
| 24 | "ash" choice (CONFIG_ASH), this shell may only be invoked by |
| 25 | the name 'sh' (and not 'ash'). |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 26 | |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 27 | config SH_IS_HUSH |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 28 | bool "hush" |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 29 | select SHELL_HUSH |
Kang-Che Sung | 9529115 | 2017-01-04 12:29:04 +0100 | [diff] [blame] | 30 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 31 | Choose hush to be the shell executed by 'sh' name. |
| 32 | The hush code will be built into busybox. If you don't select |
| 33 | "hush" choice (CONFIG_HUSH), this shell may only be invoked by |
| 34 | the name 'sh' (and not 'hush'). |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 35 | |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 36 | config SH_IS_NONE |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 37 | bool "none" |
| 38 | |
| 39 | endchoice |
| 40 | |
| 41 | choice |
| 42 | prompt "Choose which shell is aliased to 'bash' name" |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 43 | default BASH_IS_NONE |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 44 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 45 | Choose which shell you want to be executed by 'bash' alias. |
| 46 | The ash shell is the most bash compatible and full featured one, |
| 47 | although compatibility is far from being complete. |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 48 | |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 49 | Note that selecting this option does not switch on any bash |
| 50 | compatibility code. It merely makes it possible to install |
| 51 | /bin/bash (sym)link and run scripts which start with |
| 52 | #!/bin/bash line. |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 53 | |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 54 | Many systems use it in scripts which use bash-specific features, |
| 55 | even simple ones like $RANDOM. Without this option, busybox |
| 56 | can't be used for running them because it won't recongnize |
| 57 | "bash" as a supported applet name. |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 58 | |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 59 | config BASH_IS_ASH |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 60 | depends on !NOMMU |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 61 | bool "ash" |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 62 | select SHELL_ASH |
Kang-Che Sung | 9529115 | 2017-01-04 12:29:04 +0100 | [diff] [blame] | 63 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 64 | Choose ash to be the shell executed by 'bash' name. |
| 65 | The ash code will be built into busybox. If you don't select |
| 66 | "ash" choice (CONFIG_ASH), this shell may only be invoked by |
| 67 | the name 'bash' (and not 'ash'). |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 68 | |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 69 | config BASH_IS_HUSH |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 70 | bool "hush" |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 71 | select SHELL_HUSH |
Kang-Che Sung | 9529115 | 2017-01-04 12:29:04 +0100 | [diff] [blame] | 72 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 73 | Choose hush to be the shell executed by 'bash' name. |
| 74 | The hush code will be built into busybox. If you don't select |
| 75 | "hush" choice (CONFIG_HUSH), this shell may only be invoked by |
| 76 | the name 'bash' (and not 'hush'). |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 77 | |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 78 | config BASH_IS_NONE |
Denys Vlasenko | c8aae0b | 2010-06-06 22:14:58 +0200 | [diff] [blame] | 79 | bool "none" |
| 80 | |
| 81 | endchoice |
| 82 | |
| 83 | |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 84 | INSERT |
| 85 | |
| 86 | |
Kang-Che Sung | 6cd0294 | 2017-01-06 17:02:03 +0100 | [diff] [blame] | 87 | comment "Options common to all shells" |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 88 | if SHELL_ASH || SHELL_HUSH |
Kang-Che Sung | 6cd0294 | 2017-01-06 17:02:03 +0100 | [diff] [blame] | 89 | |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 90 | config FEATURE_SH_MATH |
Mike Frysinger | 98c5264 | 2009-04-02 10:02:37 +0000 | [diff] [blame] | 91 | bool "POSIX math support" |
| 92 | default y |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 93 | depends on SHELL_ASH || SHELL_HUSH |
Mike Frysinger | 98c5264 | 2009-04-02 10:02:37 +0000 | [diff] [blame] | 94 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 95 | Enable math support in the shell via $((...)) syntax. |
Mike Frysinger | 98c5264 | 2009-04-02 10:02:37 +0000 | [diff] [blame] | 96 | |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 97 | config FEATURE_SH_MATH_64 |
Mike Frysinger | 98c5264 | 2009-04-02 10:02:37 +0000 | [diff] [blame] | 98 | bool "Extend POSIX math support to 64 bit" |
Denys Vlasenko | 2f32bf8 | 2010-06-06 04:14:28 +0200 | [diff] [blame] | 99 | default y |
Denys Vlasenko | 0b88358 | 2016-12-23 16:49:07 +0100 | [diff] [blame] | 100 | depends on FEATURE_SH_MATH |
Mike Frysinger | 98c5264 | 2009-04-02 10:02:37 +0000 | [diff] [blame] | 101 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 102 | Enable 64-bit math support in the shell. This will make the shell |
| 103 | slightly larger, but will allow computation with very large numbers. |
| 104 | This is not in POSIX, so do not rely on this in portable code. |
Mike Frysinger | 98c5264 | 2009-04-02 10:02:37 +0000 | [diff] [blame] | 105 | |
Denys Vlasenko | 9edd268 | 2019-05-19 17:23:31 +0200 | [diff] [blame] | 106 | config FEATURE_SH_MATH_BASE |
| 107 | bool "Support BASE#nnnn literals" |
| 108 | default y |
| 109 | depends on FEATURE_SH_MATH |
| 110 | |
Denis Vlasenko | 7d219aa | 2006-10-05 10:17:08 +0000 | [diff] [blame] | 111 | config FEATURE_SH_EXTRA_QUIET |
Glenn L McGrath | 3b25185 | 2004-01-03 12:07:32 +0000 | [diff] [blame] | 112 | bool "Hide message on interactive shell startup" |
Denys Vlasenko | 2f32bf8 | 2010-06-06 04:14:28 +0200 | [diff] [blame] | 113 | default y |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 114 | depends on SHELL_ASH || SHELL_HUSH |
Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 115 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 116 | Remove the busybox introduction when starting a shell. |
Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 117 | |
Denis Vlasenko | 80d14be | 2007-04-10 23:03:30 +0000 | [diff] [blame] | 118 | config FEATURE_SH_STANDALONE |
Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 119 | bool "Standalone shell" |
| 120 | default n |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 121 | depends on SHELL_ASH || SHELL_HUSH |
Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 122 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 123 | This option causes busybox shells to use busybox applets |
| 124 | in preference to executables in the PATH whenever possible. For |
| 125 | example, entering the command 'ifconfig' into the shell would cause |
| 126 | busybox to use the ifconfig busybox applet. Specifying the fully |
| 127 | qualified executable name, such as '/sbin/ifconfig' will still |
| 128 | execute the /sbin/ifconfig executable on the filesystem. This option |
| 129 | is generally used when creating a statically linked version of busybox |
| 130 | for use as a rescue shell, in the event that you screw up your system. |
Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 131 | |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 132 | This is implemented by re-execing /proc/self/exe (typically) |
| 133 | with right parameters. |
Paul Fox | 6ab0378 | 2006-06-08 21:37:26 +0000 | [diff] [blame] | 134 | |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 135 | However, there are drawbacks: it is problematic in chroot jails |
| 136 | without mounted /proc, and ps/top may show command name as 'exe' |
| 137 | for applets started this way. |
Eric Andersen | 6f8542b | 2004-09-24 01:25:39 +0000 | [diff] [blame] | 138 | |
Denis Vlasenko | 9bc80d7 | 2008-04-12 20:07:53 +0000 | [diff] [blame] | 139 | config FEATURE_SH_NOFORK |
| 140 | bool "Run 'nofork' applets directly" |
| 141 | default n |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 142 | depends on SHELL_ASH || SHELL_HUSH |
Denis Vlasenko | 9bc80d7 | 2008-04-12 20:07:53 +0000 | [diff] [blame] | 143 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 144 | This option causes busybox shells to not execute typical |
| 145 | fork/exec/wait sequence, but call <applet>_main directly, |
| 146 | if possible. (Sometimes it is not possible: for example, |
| 147 | this is not possible in pipes). |
Denis Vlasenko | 9bc80d7 | 2008-04-12 20:07:53 +0000 | [diff] [blame] | 148 | |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 149 | This will be done only for some applets (those which are marked |
| 150 | NOFORK in include/applets.h). |
Denis Vlasenko | 9bc80d7 | 2008-04-12 20:07:53 +0000 | [diff] [blame] | 151 | |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 152 | This may significantly speed up some shell scripts. |
Denis Vlasenko | 9bc80d7 | 2008-04-12 20:07:53 +0000 | [diff] [blame] | 153 | |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 154 | This feature is relatively new. Use with care. Report bugs |
| 155 | to project mailing list. |
Denis Vlasenko | 9bc80d7 | 2008-04-12 20:07:53 +0000 | [diff] [blame] | 156 | |
Denys Vlasenko | eae1268 | 2017-07-20 16:09:31 +0200 | [diff] [blame] | 157 | config FEATURE_SH_READ_FRAC |
| 158 | bool "read -t N.NNN support (+110 bytes)" |
| 159 | default y |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 160 | depends on SHELL_ASH || SHELL_HUSH |
Denys Vlasenko | eae1268 | 2017-07-20 16:09:31 +0200 | [diff] [blame] | 161 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 162 | Enable support for fractional second timeout in read builtin. |
Denys Vlasenko | eae1268 | 2017-07-20 16:09:31 +0200 | [diff] [blame] | 163 | |
Denys Vlasenko | 2c4de5b | 2011-03-31 13:16:52 +0200 | [diff] [blame] | 164 | config FEATURE_SH_HISTFILESIZE |
| 165 | bool "Use $HISTFILESIZE" |
| 166 | default y |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 167 | depends on SHELL_ASH || SHELL_HUSH |
Denys Vlasenko | 2c4de5b | 2011-03-31 13:16:52 +0200 | [diff] [blame] | 168 | help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 169 | This option makes busybox shells to use $HISTFILESIZE variable |
| 170 | to set shell history size. Note that its max value is capped |
| 171 | by "History size" setting in library tuning section. |
Denys Vlasenko | 2c4de5b | 2011-03-31 13:16:52 +0200 | [diff] [blame] | 172 | |
Ron Yorston | 71df2d3 | 2018-11-27 14:34:25 +0000 | [diff] [blame] | 173 | config FEATURE_SH_EMBEDDED_SCRIPTS |
| 174 | bool "Embed scripts in the binary" |
| 175 | default y |
Denys Vlasenko | 67e1529 | 2020-06-24 13:39:13 +0200 | [diff] [blame] | 176 | depends on SHELL_ASH || SHELL_HUSH |
Ron Yorston | 71df2d3 | 2018-11-27 14:34:25 +0000 | [diff] [blame] | 177 | help |
| 178 | Allow scripts to be compressed and embedded in the busybox |
| 179 | binary. The scripts should be placed in the 'embed' directory |
| 180 | at build time. Like applets, scripts can be run as |
| 181 | 'busybox SCRIPT ...' or by linking their name to the binary. |
| 182 | |
| 183 | This also allows applets to be implemented as scripts: place |
| 184 | the script in 'applets_sh' and a stub C file containing |
| 185 | configuration in the appropriate subsystem directory. |
| 186 | |
Kang-Che Sung | 6cd0294 | 2017-01-06 17:02:03 +0100 | [diff] [blame] | 187 | endif # Options common to all shells |
Denys Vlasenko | 2c4de5b | 2011-03-31 13:16:52 +0200 | [diff] [blame] | 188 | |
Eric Andersen | c9f20d9 | 2002-12-05 08:41:41 +0000 | [diff] [blame] | 189 | endmenu |