Config.in 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482
  1. menu "System configuration"
  2. config BR2_TARGET_GENERIC_HOSTNAME
  3. string "System hostname"
  4. default "buildroot"
  5. help
  6. Select system hostname to be stored in /etc/hostname.
  7. Leave empty to not create /etc/hostname, or to keep the
  8. one from a custom skeleton.
  9. config BR2_TARGET_GENERIC_ISSUE
  10. string "System banner"
  11. default "Welcome to Buildroot"
  12. help
  13. Select system banner (/etc/issue) to be displayed at login.
  14. Leave empty to not create /etc/issue, or to keep the
  15. one from a custom skeleton.
  16. choice
  17. bool "Passwords encoding"
  18. default BR2_TARGET_GENERIC_PASSWD_MD5
  19. help
  20. Choose the password encoding scheme to use when Buildroot
  21. needs to encode a password (eg. the root password, below).
  22. Note: this is used at build-time, and *not* at runtime.
  23. config BR2_TARGET_GENERIC_PASSWD_MD5
  24. bool "md5"
  25. help
  26. Use MD5 to encode passwords.
  27. The default. Wildly available, and pretty good.
  28. Although pretty strong, MD5 is now an old hash function, and
  29. suffers from some weaknesses, which makes it susceptible to
  30. brute-force attacks.
  31. config BR2_TARGET_GENERIC_PASSWD_SHA256
  32. bool "sha-256"
  33. help
  34. Use SHA256 to encode passwords.
  35. Very strong, but not ubiquitous, although available in glibc
  36. for some time now. Choose only if you are sure your C library
  37. understands SHA256 passwords.
  38. config BR2_TARGET_GENERIC_PASSWD_SHA512
  39. bool "sha-512"
  40. help
  41. Use SHA512 to encode passwords.
  42. Extremely strong, but not ubiquitous, although available in glibc
  43. for some time now. Choose only if you are sure your C library
  44. understands SHA512 passwords.
  45. endchoice # Passwd encoding
  46. config BR2_TARGET_GENERIC_PASSWD_METHOD
  47. string
  48. default "md5" if BR2_TARGET_GENERIC_PASSWD_MD5
  49. default "sha-256" if BR2_TARGET_GENERIC_PASSWD_SHA256
  50. default "sha-512" if BR2_TARGET_GENERIC_PASSWD_SHA512
  51. choice
  52. prompt "Init system"
  53. default BR2_INIT_BUSYBOX
  54. config BR2_INIT_BUSYBOX
  55. bool "BusyBox"
  56. select BR2_PACKAGE_BUSYBOX
  57. select BR2_PACKAGE_INITSCRIPTS
  58. config BR2_INIT_SYSV
  59. bool "systemV"
  60. select BR2_PACKAGE_BUSYBOX_SHOW_OTHERS # sysvinit
  61. select BR2_PACKAGE_INITSCRIPTS
  62. select BR2_PACKAGE_SYSVINIT
  63. # In Buildroot, we decided not to support a split-usr when systemd is
  64. # used as an init system. This is a design decision, not a systemd
  65. # issue. Thus the select is with BR2_INIT_SYSTEMD (below) rather than
  66. # with BR2_PACKAGE_SYSTEMD.
  67. config BR2_INIT_SYSTEMD
  68. bool "systemd"
  69. depends on BR2_PACKAGE_SYSTEMD_ARCH_SUPPORTS
  70. depends on BR2_TOOLCHAIN_USES_GLIBC
  71. depends on BR2_USE_WCHAR
  72. depends on BR2_TOOLCHAIN_HAS_THREADS
  73. depends on BR2_TOOLCHAIN_HAS_SSP
  74. depends on BR2_USE_MMU
  75. depends on !BR2_STATIC_LIBS
  76. depends on BR2_TOOLCHAIN_HEADERS_AT_LEAST_3_10
  77. select BR2_ROOTFS_MERGED_USR
  78. select BR2_PACKAGE_SYSTEMD
  79. comment "systemd needs (e)glibc toolchain, headers >= 3.10"
  80. depends on !(BR2_TOOLCHAIN_USES_GLIBC \
  81. && BR2_TOOLCHAIN_HEADERS_AT_LEAST_3_10)
  82. config BR2_INIT_NONE
  83. bool "None"
  84. endchoice
  85. choice
  86. prompt "/dev management" if !BR2_INIT_SYSTEMD
  87. default BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_DEVTMPFS
  88. config BR2_ROOTFS_DEVICE_CREATION_STATIC
  89. bool "Static using device table"
  90. config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_DEVTMPFS
  91. bool "Dynamic using devtmpfs only"
  92. config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_MDEV
  93. bool "Dynamic using devtmpfs + mdev"
  94. select BR2_PACKAGE_BUSYBOX
  95. config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_EUDEV
  96. bool "Dynamic using devtmpfs + eudev"
  97. depends on BR2_USE_WCHAR
  98. depends on !BR2_STATIC_LIBS
  99. depends on BR2_USE_MMU # eudev
  100. select BR2_PACKAGE_EUDEV
  101. comment "eudev needs a toolchain w/ wchar, dynamic library"
  102. depends on BR2_USE_MMU
  103. depends on !BR2_USE_WCHAR || BR2_STATIC_LIBS
  104. endchoice
  105. comment "/dev management using udev (from systemd)"
  106. depends on BR2_INIT_SYSTEMD
  107. config BR2_ROOTFS_DEVICE_TABLE
  108. string "Path to the permission tables"
  109. default "system/device_table.txt"
  110. help
  111. Specify a space-separated list of permission table locations,
  112. that will be passed to the makedevs utility to assign
  113. correct owners and permissions on various files in the
  114. target filesystem.
  115. See package/makedevs/README for details on the usage and
  116. syntax of these files.
  117. config BR2_ROOTFS_STATIC_DEVICE_TABLE
  118. string "Path to the device tables"
  119. default "system/device_table_dev.txt"
  120. depends on BR2_ROOTFS_DEVICE_CREATION_STATIC
  121. help
  122. Specify a space-separated list of device table locations,
  123. that will be passed to the makedevs utility to create all
  124. the special device files under /dev.
  125. See package/makedevs/README for details on the usage and
  126. syntax of these files.
  127. choice
  128. prompt "Root FS skeleton"
  129. config BR2_ROOTFS_SKELETON_DEFAULT
  130. bool "default target skeleton"
  131. help
  132. Use default target skeleton
  133. config BR2_ROOTFS_SKELETON_CUSTOM
  134. bool "custom target skeleton"
  135. help
  136. Use custom target skeleton.
  137. endchoice
  138. if BR2_ROOTFS_SKELETON_CUSTOM
  139. config BR2_ROOTFS_SKELETON_CUSTOM_PATH
  140. string "custom target skeleton path"
  141. default "system/skeleton"
  142. help
  143. Path to custom target skeleton.
  144. # dummy config so merged /usr workarounds can also be activated for
  145. # custom rootfs skeleton
  146. config BR2_ROOTFS_MERGED_USR
  147. endif
  148. if BR2_ROOTFS_SKELETON_DEFAULT
  149. config BR2_ROOTFS_MERGED_USR
  150. bool "Use symlinks to /usr for /bin, /sbin and /lib"
  151. help
  152. If you say 'n' here, then /bin, /sbin and /lib and their
  153. counterparts in /usr will be separate directories. This
  154. is the historical UNIX way. In this case, /usr can be a
  155. filesystem on a partition separate from / .
  156. If you say 'y' here, then /bin, /sbin and /lib will be symlinks
  157. to their counterparts in /usr. In this case, /usr can not be a
  158. separate filesystem.
  159. config BR2_TARGET_ENABLE_ROOT_LOGIN
  160. bool "Enable root login with password"
  161. default y
  162. help
  163. Allow root to log in with a password.
  164. If not enabled, root will not be able to log in with a password.
  165. However, if you have an ssh server and you add an ssh key, you
  166. can still allow root to log in. Alternatively, you can use sudo
  167. to become root.
  168. config BR2_TARGET_GENERIC_ROOT_PASSWD
  169. string "Root password"
  170. default ""
  171. depends on BR2_TARGET_ENABLE_ROOT_LOGIN
  172. help
  173. Set the initial root password.
  174. If set to empty (the default), then no root password will be set,
  175. and root will need no password to log in.
  176. If the password starts with any of $1$, $5$ or $6$, it is considered
  177. to be already crypt-encoded with respectively md5, sha256 or sha512.
  178. Any other value is taken to be a clear-text value, and is crypt-encoded
  179. as per the "Passwords encoding" scheme, above.
  180. Note: "$" signs in the hashed password must be doubled. For example,
  181. if the hashed password is "$1$longsalt$v35DIIeMo4yUfI23yditq0",
  182. then you must enter it as "$$1$$longsalt$$v35DIIeMo4yUfI23yditq0"
  183. (this is necessary otherwise make would attempt to interpret the $
  184. as a variable expansion).
  185. WARNING! WARNING!
  186. The password appears as-is in the .config file, and may appear
  187. in the build log! Avoid using a valuable password if either the
  188. .config file or the build log may be distributed, or at the
  189. very least use a strong cryptographic hash for your password!
  190. choice
  191. bool "/bin/sh"
  192. default BR2_SYSTEM_BIN_SH_DASH if !BR2_PACKAGE_BUSYBOX
  193. help
  194. Select which shell will provide /bin/sh.
  195. # busybox has shells that work on noMMU
  196. config BR2_SYSTEM_BIN_SH_BUSYBOX
  197. bool "busybox' default shell"
  198. depends on BR2_PACKAGE_BUSYBOX
  199. config BR2_SYSTEM_BIN_SH_BASH
  200. bool "bash"
  201. depends on BR2_USE_MMU # bash
  202. depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
  203. select BR2_PACKAGE_BASH
  204. config BR2_SYSTEM_BIN_SH_DASH
  205. bool "dash"
  206. depends on BR2_USE_MMU # dash
  207. depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
  208. select BR2_PACKAGE_DASH
  209. config BR2_SYSTEM_BIN_SH_ZSH
  210. bool "zsh"
  211. depends on BR2_USE_MMU # zsh
  212. depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
  213. select BR2_PACKAGE_ZSH
  214. comment "bash, dash, zsh need BR2_PACKAGE_BUSYBOX_SHOW_OTHERS"
  215. depends on !BR2_PACKAGE_BUSYBOX_SHOW_OTHERS && BR2_PACKAGE_BUSYBOX
  216. config BR2_SYSTEM_BIN_SH_NONE
  217. bool "none"
  218. endchoice # /bin/sh
  219. config BR2_SYSTEM_BIN_SH
  220. string
  221. default "busybox" if BR2_SYSTEM_BIN_SH_BUSYBOX
  222. default "bash" if BR2_SYSTEM_BIN_SH_BASH
  223. default "dash" if BR2_SYSTEM_BIN_SH_DASH
  224. default "zsh" if BR2_SYSTEM_BIN_SH_ZSH
  225. menuconfig BR2_TARGET_GENERIC_GETTY
  226. bool "Run a getty (login prompt) after boot"
  227. default y
  228. if BR2_TARGET_GENERIC_GETTY
  229. config BR2_TARGET_GENERIC_GETTY_PORT
  230. string "TTY port"
  231. default "console"
  232. help
  233. Specify a port to run a getty on.
  234. choice
  235. prompt "Baudrate"
  236. default BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
  237. help
  238. Select a baudrate to use.
  239. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
  240. bool "keep kernel default"
  241. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_9600
  242. bool "9600"
  243. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_19200
  244. bool "19200"
  245. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_38400
  246. bool "38400"
  247. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_57600
  248. bool "57600"
  249. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_115200
  250. bool "115200"
  251. endchoice
  252. config BR2_TARGET_GENERIC_GETTY_BAUDRATE
  253. string
  254. default "0" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
  255. default "9600" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_9600
  256. default "19200" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_19200
  257. default "38400" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_38400
  258. default "57600" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_57600
  259. default "115200" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_115200
  260. config BR2_TARGET_GENERIC_GETTY_TERM
  261. string "TERM environment variable"
  262. default "vt100"
  263. help
  264. Specify a TERM type.
  265. config BR2_TARGET_GENERIC_GETTY_OPTIONS
  266. string "other options to pass to getty"
  267. default ""
  268. help
  269. Any other flags you want to pass to getty,
  270. Refer to getty --help for details.
  271. endif
  272. config BR2_TARGET_GENERIC_REMOUNT_ROOTFS_RW
  273. bool "remount root filesystem read-write during boot"
  274. default y
  275. help
  276. The root filesystem is typically mounted read-only at boot.
  277. By default, buildroot remounts it in read-write mode early during the
  278. boot process.
  279. Say no here if you would rather like your root filesystem to remain
  280. read-only.
  281. If unsure, say Y.
  282. endif # BR2_ROOTFS_SKELETON_DEFAULT
  283. config BR2_SYSTEM_DHCP
  284. string "Network interface to configure through DHCP"
  285. default ""
  286. depends on !BR2_PACKAGE_SYSTEMD_NETWORKD && (BR2_PACKAGE_BUSYBOX || BR2_PACKAGE_IFUPDOWN)
  287. help
  288. Enter here the name of the network interface (E.G. eth0) to
  289. automatically configure through DHCP at bootup.
  290. If left empty, no automatic DHCP requests will take place.
  291. For more complicated network setups use an overlay to overwrite
  292. /etc/network/interfaces or add a networkd configuration file.
  293. comment "automatic network configuration via DHCP is not compatible with networkd"
  294. depends on BR2_PACKAGE_SYSTEMD_NETWORKD
  295. comment "automatic network configuration via DHCP needs ifupdown or busybox"
  296. depends on !(BR2_PACKAGE_BUSYBOX || BR2_PACKAGE_IFUPDOWN)
  297. config BR2_TARGET_TZ_INFO
  298. bool "Install timezone info"
  299. # No timezone for musl; only for uClibc or (e)glibc.
  300. depends on BR2_TOOLCHAIN_USES_GLIBC || BR2_TOOLCHAIN_USES_UCLIBC
  301. select BR2_PACKAGE_TZDATA if BR2_TOOLCHAIN_USES_GLIBC
  302. select BR2_PACKAGE_TZ if BR2_TOOLCHAIN_USES_UCLIBC
  303. help
  304. Say 'y' here to install timezone info.
  305. if BR2_TARGET_TZ_INFO
  306. config BR2_TARGET_TZ_ZONELIST
  307. string "timezone list"
  308. default "default"
  309. help
  310. Space-separated list of time zones to compile.
  311. The value "default" includes all commonly used time zones. Note
  312. that this set consumes around 5.5M for (e)glibc and 2.1M for uClibc.
  313. The full list is the list of files in the time zone database source,
  314. not including the build and .tab files.
  315. config BR2_TARGET_LOCALTIME
  316. string "default local time"
  317. default "Etc/UTC"
  318. help
  319. The time zone to install as the default local time, expressed as a
  320. tzdata location, such as:
  321. GMT
  322. Europe/Paris
  323. America/New_York
  324. Pacific/Wallis
  325. ...
  326. If empty, no local time will be set, and the dates will be
  327. expressed in UTC.
  328. endif # BR2_TARGET_TZ_INFO
  329. config BR2_ROOTFS_USERS_TABLES
  330. string "Path to the users tables"
  331. help
  332. Specify a space-separated list of users table locations,
  333. that will be passed to the mkusers utility to create
  334. users on the system, with home directory, password, etc.
  335. See manual for details on the usage and syntax of these files.
  336. config BR2_ROOTFS_OVERLAY
  337. string "Root filesystem overlay directories"
  338. default ""
  339. help
  340. Specify a list of directories that are copied over the target
  341. root filesystem after the build has finished and before it is
  342. packed into the selected filesystem images.
  343. They are copied as-is into the rootfs, excluding files ending with
  344. ~ and .git, .svn and .hg directories.
  345. config BR2_ROOTFS_POST_BUILD_SCRIPT
  346. string "Custom scripts to run before creating filesystem images"
  347. default ""
  348. help
  349. Specify a space-separated list of scripts to be run after the build
  350. has finished and before Buildroot starts packing the files into
  351. selected filesystem images.
  352. This gives users the opportunity to do board-specific cleanups,
  353. add-ons and the like, so the generated files can be used directly
  354. without further processing.
  355. These scripts are called with the target directory name as first
  356. argument. Make sure the exit code of those scripts are 0, otherwise
  357. make will stop after calling them.
  358. config BR2_ROOTFS_POST_IMAGE_SCRIPT
  359. string "Custom scripts to run after creating filesystem images"
  360. default ""
  361. help
  362. Specify a space-separated list of scripts to be run after
  363. the build has finished and after Buildroot has packed the
  364. files into selected filesystem images.
  365. This can for example be used to call a tool building a
  366. firmware image from different images generated by Buildroot,
  367. or automatically extract the tarball root filesystem image
  368. into some location exported by NFS, or any other custom
  369. action.
  370. These scripts are called with the images directory name as
  371. first argument. The script is executed from the main Buildroot
  372. source directory as the current directory.
  373. config BR2_ROOTFS_POST_SCRIPT_ARGS
  374. string "Extra post-{build,image} arguments"
  375. depends on BR2_ROOTFS_POST_BUILD_SCRIPT != "" || BR2_ROOTFS_POST_IMAGE_SCRIPT != ""
  376. help
  377. Pass these additional arguments to each post-build or post-image
  378. scripts.
  379. Note that all the post-build and post-image scripts will be passed
  380. the same set of arguments, you can not pass different arguments to
  381. each script.
  382. Note also, as stated in their respective help text, that the first
  383. argument to each post-build or post-image script is the target
  384. directory / images directory. The arguments in this option will be
  385. passed *after* those.
  386. endmenu