Config.in 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642
  1. menu "System configuration"
  2. # Note on package/skeleton: usually, it is not safe to 'select' a
  3. # provider of a virtual package. But below we have an exception: each
  4. # init system may select one of the virtual skeleton-init-* packages.
  5. # As only one init system may be enabled, only one skeleton-init-* may
  6. # be selected. So this is a safe situation.
  7. choice
  8. prompt "Root FS skeleton"
  9. config BR2_ROOTFS_SKELETON_DEFAULT
  10. bool "default target skeleton"
  11. help
  12. Use default target skeleton for selected init system.
  13. config BR2_ROOTFS_SKELETON_CUSTOM
  14. bool "custom target skeleton"
  15. select BR2_PACKAGE_SKELETON_CUSTOM
  16. help
  17. Use custom target skeleton.
  18. # skeleton from br2-external trees, if any
  19. source "$BR2_BASE_DIR/.br2-external.in.skeleton"
  20. endchoice
  21. if BR2_ROOTFS_SKELETON_CUSTOM
  22. config BR2_ROOTFS_SKELETON_CUSTOM_PATH
  23. string "custom target skeleton path"
  24. help
  25. Path to custom target skeleton.
  26. endif
  27. if BR2_ROOTFS_SKELETON_DEFAULT
  28. config BR2_TARGET_GENERIC_HOSTNAME
  29. string "System hostname"
  30. default "buildroot"
  31. help
  32. Select system hostname to be stored in /etc/hostname.
  33. Leave empty to not create /etc/hostname, or to keep the
  34. one from a custom skeleton.
  35. config BR2_TARGET_GENERIC_ISSUE
  36. string "System banner"
  37. default "Welcome to Buildroot"
  38. help
  39. Select system banner (/etc/issue) to be displayed at login.
  40. Leave empty to not create /etc/issue, or to keep the
  41. one from a custom skeleton.
  42. endif
  43. choice
  44. bool "Passwords encoding"
  45. default BR2_TARGET_GENERIC_PASSWD_SHA256
  46. help
  47. Choose the password encoding scheme to use when Buildroot
  48. needs to encode a password (eg. the root password, below).
  49. Note: this is used at build-time, and *not* at runtime.
  50. config BR2_TARGET_GENERIC_PASSWD_SHA256
  51. bool "sha-256"
  52. help
  53. Use SHA256 to encode passwords which is stronger than MD5.
  54. config BR2_TARGET_GENERIC_PASSWD_SHA512
  55. bool "sha-512"
  56. help
  57. Use SHA512 to encode passwords which is stronger than SHA256
  58. endchoice # Passwd encoding
  59. config BR2_TARGET_GENERIC_PASSWD_METHOD
  60. string
  61. default "md5" if BR2_TARGET_GENERIC_PASSWD_MD5
  62. default "sha-256" if BR2_TARGET_GENERIC_PASSWD_SHA256
  63. default "sha-512" if BR2_TARGET_GENERIC_PASSWD_SHA512
  64. # See comment at the top of the file, about selecting individual
  65. # skeletons, which are providers of the virtual skeleton package.
  66. choice
  67. prompt "Init system"
  68. default BR2_INIT_BUSYBOX
  69. config BR2_INIT_BUSYBOX
  70. bool "BusyBox"
  71. select BR2_PACKAGE_BUSYBOX
  72. select BR2_PACKAGE_INITSCRIPTS
  73. select BR2_PACKAGE_SKELETON_INIT_SYSV if BR2_ROOTFS_SKELETON_DEFAULT
  74. config BR2_INIT_SYSV
  75. bool "systemV"
  76. depends on BR2_USE_MMU # sysvinit
  77. select BR2_PACKAGE_BUSYBOX_SHOW_OTHERS # sysvinit
  78. select BR2_PACKAGE_INITSCRIPTS
  79. select BR2_PACKAGE_SYSVINIT
  80. select BR2_PACKAGE_SKELETON_INIT_SYSV if BR2_ROOTFS_SKELETON_DEFAULT
  81. config BR2_INIT_OPENRC
  82. bool "OpenRC"
  83. depends on BR2_USE_MMU
  84. depends on !BR2_STATIC_LIBS
  85. select BR2_PACKAGE_OPENRC
  86. select BR2_PACKAGE_SKELETON_INIT_OPENRC if BR2_ROOTFS_SKELETON_DEFAULT
  87. comment "openrc needs a toolchain w/ dynamic library"
  88. depends on BR2_USE_MMU
  89. depends on BR2_STATIC_LIBS
  90. # In Buildroot, we decided not to support a split-usr when systemd is
  91. # used as an init system. This is a design decision, not a systemd
  92. # issue. Thus the select is with BR2_INIT_SYSTEMD (below) rather than
  93. # with BR2_PACKAGE_SYSTEMD.
  94. config BR2_INIT_SYSTEMD
  95. bool "systemd"
  96. depends on BR2_PACKAGE_SYSTEMD_ARCH_SUPPORTS
  97. depends on BR2_USE_MMU
  98. depends on !BR2_STATIC_LIBS
  99. depends on BR2_TOOLCHAIN_USES_GLIBC
  100. depends on BR2_TOOLCHAIN_HAS_SSP
  101. depends on BR2_TOOLCHAIN_HAS_THREADS
  102. depends on BR2_TOOLCHAIN_HEADERS_AT_LEAST_3_13
  103. depends on BR2_TOOLCHAIN_GCC_AT_LEAST_5
  104. depends on BR2_HOST_GCC_AT_LEAST_5
  105. select BR2_ROOTFS_MERGED_USR
  106. select BR2_PACKAGE_SYSTEMD
  107. select BR2_PACKAGE_SKELETON_INIT_SYSTEMD if BR2_ROOTFS_SKELETON_DEFAULT
  108. comment "systemd needs a glibc toolchain w/ SSP, headers >= 3.10, host and target gcc >= 5"
  109. depends on BR2_PACKAGE_SYSTEMD_ARCH_SUPPORTS
  110. depends on BR2_USE_MMU
  111. depends on !BR2_TOOLCHAIN_USES_GLIBC || \
  112. !BR2_TOOLCHAIN_HAS_SSP || \
  113. !BR2_TOOLCHAIN_HEADERS_AT_LEAST_3_10 || \
  114. !BR2_TOOLCHAIN_GCC_AT_LEAST_5 || \
  115. !BR2_HOST_GCC_AT_LEAST_5
  116. config BR2_INIT_NONE
  117. bool "None"
  118. select BR2_PACKAGE_SKELETON_INIT_NONE if BR2_ROOTFS_SKELETON_DEFAULT
  119. help
  120. Buildroot will not install any init system. You will
  121. have to provide your own, either with a new package
  122. or with a rootfs-overlay.
  123. # Init systems from br2-external trees, if any
  124. source "$BR2_BASE_DIR/.br2-external.in.init"
  125. endchoice
  126. config BR2_PACKAGE_SYSTEMD_DEFAULT_TARGET
  127. string "The default unit systemd starts at bootup"
  128. default "multi-user.target"
  129. depends on BR2_INIT_SYSTEMD
  130. help
  131. Specify the name of the unit configuration file to be started
  132. at bootup by systemd. Should end in ".target".
  133. ex: multi-user.target
  134. https://www.freedesktop.org/software/systemd/man/systemd.special.html#default.target
  135. choice
  136. prompt "/dev management" if !BR2_INIT_SYSTEMD
  137. default BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_DEVTMPFS
  138. config BR2_ROOTFS_DEVICE_CREATION_STATIC
  139. bool "Static using device table"
  140. config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_DEVTMPFS
  141. bool "Dynamic using devtmpfs only"
  142. config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_MDEV
  143. bool "Dynamic using devtmpfs + mdev"
  144. select BR2_PACKAGE_BUSYBOX
  145. config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_EUDEV
  146. bool "Dynamic using devtmpfs + eudev"
  147. depends on BR2_USE_WCHAR # eudev
  148. depends on !BR2_STATIC_LIBS
  149. depends on BR2_USE_MMU # eudev
  150. select BR2_PACKAGE_EUDEV
  151. comment "eudev needs a toolchain w/ wchar, dynamic library"
  152. depends on BR2_USE_MMU
  153. depends on !BR2_USE_WCHAR || BR2_STATIC_LIBS
  154. endchoice
  155. comment "/dev management using udev (from systemd)"
  156. depends on BR2_INIT_SYSTEMD
  157. config BR2_ROOTFS_DEVICE_TABLE
  158. string "Path to the permission tables"
  159. default "system/device_table.txt"
  160. help
  161. Specify a space-separated list of permission table locations,
  162. that will be passed to the makedevs utility to assign
  163. correct owners and permissions on various files in the
  164. target filesystem.
  165. See package/makedevs/README for details on the usage and
  166. syntax of these files.
  167. config BR2_ROOTFS_STATIC_DEVICE_TABLE
  168. string "Path to the device tables"
  169. default "system/device_table_dev.txt"
  170. depends on BR2_ROOTFS_DEVICE_CREATION_STATIC
  171. help
  172. Specify a space-separated list of device table locations,
  173. that will be passed to the makedevs utility to create all
  174. the special device files under /dev.
  175. See package/makedevs/README for details on the usage and
  176. syntax of these files.
  177. config BR2_ROOTFS_DEVICE_TABLE_SUPPORTS_EXTENDED_ATTRIBUTES
  178. bool "support extended attributes in device tables"
  179. help
  180. Support extended attributes handling in device tables
  181. config BR2_ROOTFS_MERGED_USR
  182. bool "Use symlinks to /usr for /bin, /sbin and /lib"
  183. help
  184. If you say 'n' here, then /bin, /sbin and /lib and their
  185. counterparts in /usr will be separate directories. This
  186. is the historical UNIX way. In this case, /usr can be a
  187. filesystem on a partition separate from / .
  188. If you say 'y' here, then /bin, /sbin and /lib will be
  189. symlinks to their counterparts in /usr. In this case, /usr can
  190. not be a separate filesystem.
  191. if BR2_ROOTFS_SKELETON_DEFAULT
  192. config BR2_TARGET_ENABLE_ROOT_LOGIN
  193. bool "Enable root login with password"
  194. default y
  195. select BR2_PACKAGE_HOST_MKPASSWD if BR2_TARGET_GENERIC_ROOT_PASSWD != ""
  196. help
  197. Allow root to log in with a password.
  198. If not enabled, root will not be able to log in with a
  199. password. However, if you have an ssh server and you add an
  200. ssh key, you can still allow root to log in. Alternatively,
  201. you can use sudo to become root.
  202. config BR2_TARGET_GENERIC_ROOT_PASSWD
  203. string "Root password"
  204. default ""
  205. depends on BR2_TARGET_ENABLE_ROOT_LOGIN
  206. help
  207. Set the initial root password.
  208. If set to empty (the default), then no root password will be
  209. set, and root will need no password to log in.
  210. If the password starts with any of $1$, $5$ or $6$, it is
  211. considered to be already crypt-encoded with respectively md5,
  212. sha256 or sha512. Any other value is taken to be a clear-text
  213. value, and is crypt-encoded as per the "Passwords encoding"
  214. scheme, above.
  215. Note: "$" signs in the hashed password must be doubled. For
  216. example, if the hashed password is
  217. "$1$longsalt$v35DIIeMo4yUfI23yditq0", then you must enter it
  218. as "$$1$$longsalt$$v35DIIeMo4yUfI23yditq0" (this is necessary
  219. otherwise make would attempt to interpret the $ as a variable
  220. expansion).
  221. WARNING! WARNING!
  222. The password appears as-is in the .config file, and may appear
  223. in the build log! Avoid using a valuable password if either
  224. the .config file or the build log may be distributed, or at
  225. the very least use a strong cryptographic hash for your
  226. password!
  227. choice
  228. bool "/bin/sh"
  229. default BR2_SYSTEM_BIN_SH_DASH if !BR2_PACKAGE_BUSYBOX
  230. help
  231. Select which shell will provide /bin/sh.
  232. # busybox has shells that work on noMMU
  233. config BR2_SYSTEM_BIN_SH_BUSYBOX
  234. bool "busybox' default shell"
  235. depends on BR2_PACKAGE_BUSYBOX
  236. config BR2_SYSTEM_BIN_SH_BASH
  237. bool "bash"
  238. depends on BR2_USE_MMU # bash
  239. depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
  240. select BR2_PACKAGE_BASH
  241. config BR2_SYSTEM_BIN_SH_DASH
  242. bool "dash"
  243. depends on BR2_USE_MMU # dash
  244. depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
  245. select BR2_PACKAGE_DASH
  246. config BR2_SYSTEM_BIN_SH_MKSH
  247. bool "mksh"
  248. depends on BR2_USE_MMU # mksh
  249. depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
  250. select BR2_PACKAGE_MKSH
  251. config BR2_SYSTEM_BIN_SH_ZSH
  252. bool "zsh"
  253. depends on BR2_USE_MMU # zsh
  254. depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
  255. select BR2_PACKAGE_ZSH
  256. comment "bash, dash, mksh, zsh need BR2_PACKAGE_BUSYBOX_SHOW_OTHERS"
  257. depends on !BR2_PACKAGE_BUSYBOX_SHOW_OTHERS && BR2_PACKAGE_BUSYBOX
  258. config BR2_SYSTEM_BIN_SH_NONE
  259. bool "none"
  260. endchoice # /bin/sh
  261. config BR2_SYSTEM_BIN_SH
  262. string
  263. default "bash" if BR2_SYSTEM_BIN_SH_BASH
  264. default "dash" if BR2_SYSTEM_BIN_SH_DASH
  265. default "mksh" if BR2_SYSTEM_BIN_SH_MKSH
  266. default "zsh" if BR2_SYSTEM_BIN_SH_ZSH
  267. menuconfig BR2_TARGET_GENERIC_GETTY
  268. bool "Run a getty (login prompt) after boot"
  269. default y
  270. if BR2_TARGET_GENERIC_GETTY
  271. config BR2_TARGET_GENERIC_GETTY_PORT
  272. string "TTY port"
  273. default "console"
  274. help
  275. Specify a port to run a getty on.
  276. choice
  277. prompt "Baudrate"
  278. default BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
  279. help
  280. Select a baudrate to use.
  281. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
  282. bool "keep kernel default"
  283. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_9600
  284. bool "9600"
  285. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_19200
  286. bool "19200"
  287. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_38400
  288. bool "38400"
  289. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_57600
  290. bool "57600"
  291. config BR2_TARGET_GENERIC_GETTY_BAUDRATE_115200
  292. bool "115200"
  293. endchoice
  294. config BR2_TARGET_GENERIC_GETTY_BAUDRATE
  295. string
  296. default "0" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
  297. default "9600" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_9600
  298. default "19200" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_19200
  299. default "38400" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_38400
  300. default "57600" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_57600
  301. default "115200" if BR2_TARGET_GENERIC_GETTY_BAUDRATE_115200
  302. config BR2_TARGET_GENERIC_GETTY_TERM
  303. string "TERM environment variable"
  304. default "vt100"
  305. # currently observed by all but systemd
  306. depends on !BR2_INIT_SYSTEMD
  307. help
  308. Specify a TERM type.
  309. config BR2_TARGET_GENERIC_GETTY_OPTIONS
  310. string "other options to pass to getty"
  311. default ""
  312. # currently observed by all but systemd
  313. depends on !BR2_INIT_SYSTEMD
  314. help
  315. Any other flags you want to pass to getty,
  316. Refer to getty --help for details.
  317. endif
  318. config BR2_TARGET_GENERIC_REMOUNT_ROOTFS_RW
  319. bool "remount root filesystem read-write during boot"
  320. default y
  321. help
  322. The root filesystem is typically mounted read-only at boot.
  323. By default, buildroot remounts it in read-write mode early
  324. during the boot process.
  325. Say no here if you would rather like your root filesystem to
  326. remain read-only.
  327. If unsure, say Y.
  328. config BR2_SYSTEM_DHCP
  329. string "Network interface to configure through DHCP"
  330. default ""
  331. depends on BR2_PACKAGE_BUSYBOX || BR2_PACKAGE_IFUPDOWN || \
  332. BR2_PACKAGE_SYSTEMD_NETWORKD || BR2_PACKAGE_NETIFRC
  333. help
  334. Enter here the name of the network interface (E.G. eth0) to
  335. automatically configure through DHCP at bootup.
  336. If left empty, no automatic DHCP requests will take place.
  337. For more complicated network setups use an overlay to
  338. overwrite /etc/network/interfaces or add a networkd
  339. configuration file.
  340. comment "automatic network configuration via DHCP needs ifupdown or busybox or networkd or netifrc"
  341. depends on !(BR2_PACKAGE_BUSYBOX || BR2_PACKAGE_IFUPDOWN || \
  342. BR2_PACKAGE_SYSTEMD_NETWORKD || BR2_PACKAGE_NETIFRC)
  343. endif # BR2_ROOTFS_SKELETON_DEFAULT
  344. config BR2_SYSTEM_DEFAULT_PATH
  345. string "Set the system's default PATH"
  346. default "/usr/bin:/usr/sbin" if BR2_ROOTFS_MERGED_USR
  347. default "/bin:/sbin:/usr/bin:/usr/sbin" if !BR2_ROOTFS_MERGED_USR
  348. help
  349. Sets the system's default PATH. It is being used in
  350. /etc/profile in the skeleton-init-common package and by some
  351. daemons.
  352. The default should work in most cases.
  353. config BR2_ENABLE_LOCALE_PURGE
  354. bool "Purge unwanted locales"
  355. default y
  356. help
  357. Explicitly specify what locales to install on target. If N
  358. then all locales supported by packages are installed.
  359. config BR2_ENABLE_LOCALE_WHITELIST
  360. string "Locales to keep"
  361. default "C en_US"
  362. depends on BR2_ENABLE_LOCALE_PURGE
  363. help
  364. Whitespace seperated list of locales to allow on target.
  365. Locales not listed here will be removed from the target.
  366. See 'locale -a' on your host for a list of locales available
  367. on your build host, or have a look in /usr/share/locale in
  368. the target file system for available locales.
  369. Notice that listing a locale here doesn't guarantee that it
  370. will be available on the target - That purely depends on the
  371. support for that locale in the selected packages.
  372. config BR2_GENERATE_LOCALE
  373. string "Generate locale data"
  374. default ""
  375. depends on \
  376. (BR2_TOOLCHAIN_BUILDROOT_UCLIBC && BR2_ENABLE_LOCALE) || \
  377. BR2_TOOLCHAIN_USES_GLIBC
  378. help
  379. Generate support for a list of locales. Locales can be
  380. specified with or without encoding, when no encoding is
  381. specified, UTF-8 is assumed. Examples of locales: en_US,
  382. fr_FR.UTF-8.
  383. config BR2_SYSTEM_ENABLE_NLS
  384. bool "Enable Native Language Support (NLS)"
  385. depends on BR2_USE_WCHAR
  386. # - glibc has built-in NLS support, but anyway doesn't
  387. # support static linking
  388. # - musl and uclibc support static linking, but they don't
  389. # have built-in NLS support, which is provided by the
  390. # libintl library from gettext. The fact that it is a
  391. # separate library causes too many problems for static
  392. # linking.
  393. depends on !BR2_STATIC_LIBS
  394. select BR2_PACKAGE_GETTEXT if !BR2_TOOLCHAIN_HAS_FULL_GETTEXT
  395. help
  396. This option will enable Native Language Support, which will
  397. allow software packages to support translations.
  398. comment "NLS support needs a toolchain w/ wchar, dynamic library"
  399. depends on !BR2_USE_WCHAR || BR2_STATIC_LIBS
  400. config BR2_TARGET_TZ_INFO
  401. bool "Install timezone info"
  402. select BR2_PACKAGE_TZDATA if BR2_TOOLCHAIN_USES_GLIBC
  403. select BR2_PACKAGE_TZDATA if BR2_TOOLCHAIN_USES_MUSL
  404. select BR2_PACKAGE_TZ if BR2_TOOLCHAIN_USES_UCLIBC
  405. help
  406. Say 'y' here to install timezone info.
  407. if BR2_TARGET_TZ_INFO
  408. config BR2_TARGET_TZ_ZONELIST
  409. string "timezone list"
  410. default "default"
  411. help
  412. Space-separated list of time zones to compile.
  413. The value "default" includes all commonly used time zones.
  414. Note that this set consumes around 5.5M for glibc and 2.1M for
  415. uClibc.
  416. The full list is the list of files in the time zone database
  417. source, not including the build and .tab files.
  418. config BR2_TARGET_LOCALTIME
  419. string "default local time"
  420. default "Etc/UTC"
  421. help
  422. The time zone to install as the default local time, expressed
  423. as a tzdata location, such as:
  424. Etc/UTC (the default)
  425. GMT
  426. Europe/Paris
  427. America/New_York
  428. Pacific/Wallis
  429. ...
  430. Set to empty to not install a default time zone.
  431. endif # BR2_TARGET_TZ_INFO
  432. config BR2_ROOTFS_USERS_TABLES
  433. string "Path to the users tables"
  434. help
  435. Specify a space-separated list of users table locations,
  436. that will be passed to the mkusers utility to create
  437. users on the system, with home directory, password, etc.
  438. See manual for details on the usage and syntax of these files.
  439. config BR2_ROOTFS_OVERLAY
  440. string "Root filesystem overlay directories"
  441. default ""
  442. help
  443. Specify a list of directories that are copied over the target
  444. root filesystem after the build has finished and before it is
  445. packed into the selected filesystem images.
  446. They are copied as-is into the rootfs, excluding files ending
  447. with ~ and .git, .svn and .hg directories.
  448. config BR2_ROOTFS_PRE_BUILD_SCRIPT
  449. string "Custom scripts to run before commencing the build"
  450. default ""
  451. help
  452. Specify a space-separated list of scripts to be run before the
  453. build commences.
  454. This gives users the opportunity to do board-specific
  455. preparations before starting the build.
  456. config BR2_ROOTFS_POST_BUILD_SCRIPT
  457. string "Custom scripts to run before creating filesystem images"
  458. default ""
  459. help
  460. Specify a space-separated list of scripts to be run after the
  461. build has finished and before Buildroot starts packing the
  462. files into selected filesystem images.
  463. This gives users the opportunity to do board-specific
  464. cleanups, add-ons and the like, so the generated files can be
  465. used directly without further processing.
  466. These scripts are called with the target directory name as
  467. first argument. Make sure the exit code of those scripts are
  468. 0, otherwise make will stop after calling them.
  469. config BR2_ROOTFS_POST_FAKEROOT_SCRIPT
  470. string "Custom scripts to run inside the fakeroot environment"
  471. default ""
  472. help
  473. Specify a space-separated list of scripts to be run at the end
  474. of the fakeroot script right before the image(s) are actually
  475. generated.
  476. This gives users the opportunity to do customisations of the
  477. content of the rootfs, which would otherwise require root
  478. rights.
  479. These scripts are called with the target directory name as
  480. first argument. The build will fail on the first scripts that
  481. exits with a non-zero exit code.
  482. Note that Buildroot already provides mechanisms to customise
  483. the content of the rootfs:
  484. - BR2_ROOTFS_STATIC_DEVICE_TABLE
  485. to create arbitrary entries statically in /dev
  486. - BR2_ROOTFS_DEVICE_TABLE
  487. to set arbitrary permissions as well as extended
  488. attributes (such as capabilities) on files and
  489. directories,
  490. - BR2_ROOTFS_USERS_TABLES:
  491. to create arbitrary users and their home directories
  492. It is highly recommended to use those mechanisms if possible,
  493. rather than using custom fakeroot scripts.
  494. config BR2_ROOTFS_POST_IMAGE_SCRIPT
  495. string "Custom scripts to run after creating filesystem images"
  496. default ""
  497. help
  498. Specify a space-separated list of scripts to be run after
  499. the build has finished and after Buildroot has packed the
  500. files into selected filesystem images.
  501. This can for example be used to call a tool building a
  502. firmware image from different images generated by Buildroot,
  503. or automatically extract the tarball root filesystem image
  504. into some location exported by NFS, or any other custom
  505. action.
  506. These scripts are called with the images directory name as
  507. first argument. The script is executed from the main Buildroot
  508. source directory as the current directory.
  509. config BR2_ROOTFS_POST_SCRIPT_ARGS
  510. string "Extra arguments passed to custom scripts"
  511. depends on BR2_ROOTFS_POST_BUILD_SCRIPT != "" \
  512. || BR2_ROOTFS_POST_FAKEROOT_SCRIPT != "" \
  513. || BR2_ROOTFS_POST_IMAGE_SCRIPT != ""
  514. help
  515. Pass these additional arguments to each post-build or
  516. post-image scripts.
  517. Note that all the post-build and post-image scripts will be
  518. passed the same set of arguments, you can not pass different
  519. arguments to each script.
  520. Note also, as stated in their respective help text, that the
  521. first argument to each post-build or post-image script is the
  522. target directory / images directory. The arguments in this
  523. option will be passed *after* those.
  524. endmenu