configure.txt 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386
  1. // -*- mode:doc; -*-
  2. // vim: set syntax=asciidoc:
  3. [[configure]]
  4. == Buildroot configuration
  5. All the configuration options in +make *config+ have a help text
  6. providing details about the option.
  7. The +make *config+ commands also offer a search tool. Read the help
  8. message in the different frontend menus to know how to use it:
  9. * in _menuconfig_, the search tool is called by pressing +/+;
  10. * in _xconfig_, the search tool is called by pressing +Ctrl+ + +f+.
  11. The result of the search shows the help message of the matching items.
  12. In _menuconfig_, numbers in the left column provide a shortcut to the
  13. corresponding entry. Just type this number to directly jump to the
  14. entry, or to the containing menu in case the entry is not selectable due
  15. to a missing dependency.
  16. Although the menu structure and the help text of the entries should be
  17. sufficiently self-explanatory, a number of topics require additional
  18. explanation that cannot easily be covered in the help text and are
  19. therefore covered in the following sections.
  20. === Cross-compilation toolchain
  21. A compilation toolchain is the set of tools that allows you to compile
  22. code for your system. It consists of a compiler (in our case, +gcc+),
  23. binary utils like assembler and linker (in our case, +binutils+) and a
  24. C standard library (for example
  25. http://www.gnu.org/software/libc/libc.html[GNU Libc],
  26. http://www.uclibc.org/[uClibc]).
  27. The system installed on your development station certainly already has
  28. a compilation toolchain that you can use to compile an application
  29. that runs on your system. If you're using a PC, your compilation
  30. toolchain runs on an x86 processor and generates code for an x86
  31. processor. Under most Linux systems, the compilation toolchain uses
  32. the GNU libc (glibc) as the C standard library. This compilation
  33. toolchain is called the "host compilation toolchain". The machine on
  34. which it is running, and on which you're working, is called the "host
  35. system" footnote:[This terminology differs from what is used by GNU
  36. configure, where the host is the machine on which the application will
  37. run (which is usually the same as target)].
  38. The compilation toolchain is provided by your distribution, and
  39. Buildroot has nothing to do with it (other than using it to build a
  40. cross-compilation toolchain and other tools that are run on the
  41. development host).
  42. As said above, the compilation toolchain that comes with your system
  43. runs on and generates code for the processor in your host system. As
  44. your embedded system has a different processor, you need a
  45. cross-compilation toolchain - a compilation toolchain that runs on
  46. your _host system_ but generates code for your _target system_ (and
  47. target processor). For example, if your host system uses x86 and your
  48. target system uses ARM, the regular compilation toolchain on your host
  49. runs on x86 and generates code for x86, while the cross-compilation
  50. toolchain runs on x86 and generates code for ARM.
  51. Buildroot provides two solutions for the cross-compilation toolchain:
  52. * The *internal toolchain backend*, called +Buildroot toolchain+ in
  53. the configuration interface.
  54. * The *external toolchain backend*, called +External toolchain+ in
  55. the configuration interface.
  56. The choice between these two solutions is done using the +Toolchain
  57. Type+ option in the +Toolchain+ menu. Once one solution has been
  58. chosen, a number of configuration options appear, they are detailed in
  59. the following sections.
  60. [[internal-toolchain-backend]]
  61. ==== Internal toolchain backend
  62. The _internal toolchain backend_ is the backend where Buildroot builds
  63. by itself a cross-compilation toolchain, before building the userspace
  64. applications and libraries for your target embedded system.
  65. This backend supports several C libraries:
  66. http://www.uclibc.org[uClibc], the
  67. http://www.gnu.org/software/libc/libc.html[glibc] and
  68. http://www.eglibc.org[eglibc].
  69. Once you have selected this backend, a number of options appear. The
  70. most important ones allow to:
  71. * Change the version of the Linux kernel headers used to build the
  72. toolchain. This item deserves a few explanations. In the process of
  73. building a cross-compilation toolchain, the C library is being
  74. built. This library provides the interface between userspace
  75. applications and the Linux kernel. In order to know how to "talk"
  76. to the Linux kernel, the C library needs to have access to the
  77. _Linux kernel headers_ (i.e. the +.h+ files from the kernel), which
  78. define the interface between userspace and the kernel (system
  79. calls, data structures, etc.). Since this interface is backward
  80. compatible, the version of the Linux kernel headers used to build
  81. your toolchain do not need to match _exactly_ the version of the
  82. Linux kernel you intend to run on your embedded system. They only
  83. need to have a version equal or older to the version of the Linux
  84. kernel you intend to run. If you use kernel headers that are more
  85. recent than the Linux kernel you run on your embedded system, then
  86. the C library might be using interfaces that are not provided by
  87. your Linux kernel.
  88. * Change the version of the GCC compiler, binutils and the C library.
  89. * Select a number of toolchain options (uClibc only): whether the
  90. toolchain should have largefile support (i.e. support for files
  91. larger than 2 GB on 32 bits systems), IPv6 support, RPC support
  92. (used mainly for NFS), wide-char support, locale support (for
  93. internationalization), C++ support or thread support. Depending on
  94. which options you choose, the number of userspace applications and
  95. libraries visible in Buildroot menus will change: many applications
  96. and libraries require certain toolchain options to be enabled. Most
  97. packages show a comment when a certain toolchain option is required
  98. to be able to enable those packages. If needed, you can further
  99. refine the uClibc configuration by running +make
  100. uclibc-menuconfig+. Note however that all packages in Buildroot are
  101. tested against the default uClibc configuration bundled in
  102. Buildroot: if you deviate from this configuration by removing
  103. features from uClibc, some packages may no longer build.
  104. It is worth noting that whenever one of those options is modified,
  105. then the entire toolchain and system must be rebuilt. See
  106. xref:full-rebuild[].
  107. Advantages of this backend:
  108. * Well integrated with Buildroot
  109. * Fast, only builds what's necessary
  110. Drawbacks of this backend:
  111. * Rebuilding the toolchain is needed when doing +make clean+, which
  112. takes time. If you're trying to reduce your build time, consider
  113. using the _External toolchain backend_.
  114. [[external-toolchain-backend]]
  115. ==== External toolchain backend
  116. The _external toolchain backend_ allows to use existing pre-built
  117. cross-compilation toolchains. Buildroot knows about a number of
  118. well-known cross-compilation toolchains (from
  119. http://www.linaro.org[Linaro] for ARM,
  120. http://www.mentor.com/embedded-software/sourcery-tools/sourcery-codebench/editions/lite-edition/[Sourcery
  121. CodeBench] for ARM, x86, x86-64, PowerPC, MIPS and SuperH,
  122. https://blackfin.uclinux.org/gf/project/toolchain[Blackfin toolchains
  123. from Analog Devices], etc.) and is capable of downloading them
  124. automatically, or it can be pointed to a custom toolchain, either
  125. available for download or installed locally.
  126. Then, you have three solutions to use an external toolchain:
  127. * Use a predefined external toolchain profile, and let Buildroot
  128. download, extract and install the toolchain. Buildroot already knows
  129. about a few CodeSourcery, Linaro, Blackfin and Xilinx toolchains.
  130. Just select the toolchain profile in +Toolchain+ from the
  131. available ones. This is definitely the easiest solution.
  132. * Use a predefined external toolchain profile, but instead of having
  133. Buildroot download and extract the toolchain, you can tell Buildroot
  134. where your toolchain is already installed on your system. Just
  135. select the toolchain profile in +Toolchain+ through the available
  136. ones, unselect +Download toolchain automatically+, and fill the
  137. +Toolchain path+ text entry with the path to your cross-compiling
  138. toolchain.
  139. * Use a completely custom external toolchain. This is particularly
  140. useful for toolchains generated using crosstool-NG or with Buildroot
  141. itself. To do this, select the +Custom toolchain+ solution in the
  142. +Toolchain+ list. You need to fill the +Toolchain path+, +Toolchain
  143. prefix+ and +External toolchain C library+ options. Then, you have
  144. to tell Buildroot what your external toolchain supports. If your
  145. external toolchain uses the 'glibc' library, you only have to tell
  146. whether your toolchain supports C\++ or not and whether it has
  147. built-in RPC support. If your external toolchain uses the 'uClibc'
  148. library, then you have to tell Buildroot if it supports largefile,
  149. IPv6, RPC, wide-char, locale, program invocation, threads and
  150. C++. At the beginning of the execution, Buildroot will tell you if
  151. the selected options do not match the toolchain configuration.
  152. Our external toolchain support has been tested with toolchains from
  153. CodeSourcery and Linaro, toolchains generated by
  154. http://crosstool-ng.org[crosstool-NG], and toolchains generated by
  155. Buildroot itself. In general, all toolchains that support the
  156. 'sysroot' feature should work. If not, do not hesitate to contact the
  157. developers.
  158. We do not support toolchains or SDK generated by OpenEmbedded or
  159. Yocto, because these toolchains are not pure toolchains (i.e. just the
  160. compiler, binutils, the C and C++ libraries). Instead these toolchains
  161. come with a very large set of pre-compiled libraries and
  162. programs. Therefore, Buildroot cannot import the 'sysroot' of the
  163. toolchain, as it would contain hundreds of megabytes of pre-compiled
  164. libraries that are normally built by Buildroot.
  165. We also do not support using the distribution toolchain (i.e. the
  166. gcc/binutils/C library installed by your distribution) as the
  167. toolchain to build software for the target. This is because your
  168. distribution toolchain is not a "pure" toolchain (i.e. only with the
  169. C/C++ library), so we cannot import it properly into the Buildroot
  170. build environment. So even if you are building a system for a x86 or
  171. x86_64 target, you have to generate a cross-compilation toolchain with
  172. Buildroot or crosstool-NG.
  173. If you want to generate a custom toolchain for your project, that can
  174. be used as an external toolchain in Buildroot, our recommendation is
  175. definitely to build it with http://crosstool-ng.org[crosstool-NG]. We
  176. recommend to build the toolchain separately from Buildroot, and then
  177. _import_ it in Buildroot using the external toolchain backend.
  178. Advantages of this backend:
  179. * Allows to use well-known and well-tested cross-compilation
  180. toolchains.
  181. * Avoids the build time of the cross-compilation toolchain, which is
  182. often very significant in the overall build time of an embedded
  183. Linux system.
  184. * Not limited to uClibc: glibc and eglibc toolchains are supported.
  185. Drawbacks of this backend:
  186. * If your pre-built external toolchain has a bug, may be hard to get a
  187. fix from the toolchain vendor, unless you build your external
  188. toolchain by yourself using Crosstool-NG.
  189. ===== External toolchain wrapper
  190. When using an external toolchain, Buildroot generates a wrapper program,
  191. that transparently passes the appropriate options (according to the
  192. configuration) to the external toolchain programs. In case you need to
  193. debug this wrapper to check exactly what arguments are passed, you can
  194. set the environment variable +BR2_DEBUG_WRAPPER+ to either one of:
  195. * +0+, empty or not set: no debug
  196. * +1+: trace all arguments on a single line
  197. * +2+: trace one argument per line
  198. === /dev management
  199. On a Linux system, the +/dev+ directory contains special files, called
  200. _device files_, that allow userspace applications to access the
  201. hardware devices managed by the Linux kernel. Without these _device
  202. files_, your userspace applications would not be able to use the
  203. hardware devices, even if they are properly recognized by the Linux
  204. kernel.
  205. Under +System configuration+, +/dev management+, Buildroot offers four
  206. different solutions to handle the +/dev+ directory :
  207. * The first solution is *Static using device table*. This is the old
  208. classical way of handling device files in Linux. With this method,
  209. the device files are persistently stored in the root filesystem
  210. (i.e. they persist across reboots), and there is nothing that will
  211. automatically create and remove those device files when hardware
  212. devices are added or removed from the system. Buildroot therefore
  213. creates a standard set of device files using a _device table_, the
  214. default one being stored in +system/device_table_dev.txt+ in the
  215. Buildroot source code. This file is processed when Buildroot
  216. generates the final root filesystem image, and the _device files_
  217. are therefore not visible in the +output/target+ directory. The
  218. +BR2_ROOTFS_STATIC_DEVICE_TABLE+ option allows to change the
  219. default device table used by Buildroot, or to add an additional
  220. device table, so that additional _device files_ are created by
  221. Buildroot during the build. So, if you use this method, and a
  222. _device file_ is missing in your system, you can for example create
  223. a +board/<yourcompany>/<yourproject>/device_table_dev.txt+ file
  224. that contains the description of your additional _device files_,
  225. and then you can set +BR2_ROOTFS_STATIC_DEVICE_TABLE+ to
  226. +system/device_table_dev.txt
  227. board/<yourcompany>/<yourproject>/device_table_dev.txt+. For more
  228. details about the format of the device table file, see
  229. xref:makedev-syntax[].
  230. * The second solution is *Dynamic using devtmpfs only*. _devtmpfs_ is
  231. a virtual filesystem inside the Linux kernel that has been
  232. introduced in kernel 2.6.32 (if you use an older kernel, it is not
  233. possible to use this option). When mounted in +/dev+, this virtual
  234. filesystem will automatically make _device files_ appear and
  235. disappear as hardware devices are added and removed from the
  236. system. This filesystem is not persistent across reboots: it is
  237. filled dynamically by the kernel. Using _devtmpfs_ requires the
  238. following kernel configuration options to be enabled:
  239. +CONFIG_DEVTMPFS+ and +CONFIG_DEVTMPFS_MOUNT+. When Buildroot is in
  240. charge of building the Linux kernel for your embedded device, it
  241. makes sure that those two options are enabled. However, if you
  242. build your Linux kernel outside of Buildroot, then it is your
  243. responsibility to enable those two options (if you fail to do so,
  244. your Buildroot system will not boot).
  245. * The third solution is *Dynamic using mdev*. This method also relies
  246. on the _devtmpfs_ virtual filesystem detailed above (so the
  247. requirement to have +CONFIG_DEVTMPFS+ and +CONFIG_DEVTMPFS_MOUNT+
  248. enabled in the kernel configuration still apply), but adds the
  249. +mdev+ userspace utility on top of it. +mdev+ is a program part of
  250. BusyBox that the kernel will call every time a device is added or
  251. removed. Thanks to the +/etc/mdev.conf+ configuration file, +mdev+
  252. can be configured to for example, set specific permissions or
  253. ownership on a device file, call a script or application whenever a
  254. device appears or disappear, etc. Basically, it allows _userspace_
  255. to react on device addition and removal events. +mdev+ can for
  256. example be used to automatically load kernel modules when devices
  257. appear on the system. +mdev+ is also important if you have devices
  258. that require a firmware, as it will be responsible for pushing the
  259. firmware contents to the kernel. +mdev+ is a lightweight
  260. implementation (with fewer features) of +udev+. For more details
  261. about +mdev+ and the syntax of its configuration file, see
  262. http://git.busybox.net/busybox/tree/docs/mdev.txt.
  263. * The fourth solution is *Dynamic using eudev*. This method also
  264. relies on the _devtmpfs_ virtual filesystem detailed above, but
  265. adds the +eudev+ userspace daemon on top of it. +eudev+ is a daemon
  266. that runs in the background, and gets called by the kernel when a
  267. device gets added or removed from the system. It is a more
  268. heavyweight solution than +mdev+, but provides higher flexibility.
  269. +eudev+ is a standalone version of +udev+, the original userspace
  270. daemon used in most desktop Linux distributions, which is now part
  271. of Systemd. For more details, see http://en.wikipedia.org/wiki/Udev.
  272. The Buildroot developers recommendation is to start with the *Dynamic
  273. using devtmpfs only* solution, until you have the need for userspace
  274. to be notified when devices are added/removed, or if firmwares are
  275. needed, in which case *Dynamic using mdev* is usually a good solution.
  276. Note that if +systemd+ is chosen as init system, /dev management will
  277. be performed by the +udev+ program provided by +systemd+.
  278. === init system
  279. The _init_ program is the first userspace program started by the
  280. kernel (it carries the PID number 1), and is responsible for starting
  281. the userspace services and programs (for example: web server,
  282. graphical applications, other network servers, etc.).
  283. Buildroot allows to use three different types of init systems, which
  284. can be chosen from +System configuration+, +Init system+:
  285. * The first solution is *BusyBox*. Amongst many programs, BusyBox has
  286. an implementation of a basic +init+ program, which is sufficient
  287. for most embedded systems. Enabling the +BR2_INIT_BUSYBOX+ will
  288. ensure BusyBox will build and install its +init+ program. This is
  289. the default solution in Buildroot. The BusyBox +init+ program will
  290. read the +/etc/inittab+ file at boot to know what to do. The syntax
  291. of this file can be found in
  292. http://git.busybox.net/busybox/tree/examples/inittab (note that
  293. BusyBox +inittab+ syntax is special: do not use a random +inittab+
  294. documentation from the Internet to learn about BusyBox
  295. +inittab+). The default +inittab+ in Buildroot is stored in
  296. +system/skeleton/etc/inittab+. Apart from mounting a few important
  297. filesystems, the main job the default inittab does is to start the
  298. +/etc/init.d/rcS+ shell script, and start a +getty+ program (which
  299. provides a login prompt).
  300. * The second solution is *systemV*. This solution uses the old
  301. traditional _sysvinit_ program, packed in Buildroot in
  302. +package/sysvinit+. This was the solution used in most desktop
  303. Linux distributions, until they switched to more recent
  304. alternatives such as Upstart or Systemd. +sysvinit+ also works with
  305. an +inittab+ file (which has a slightly different syntax than the
  306. one from BusyBox). The default +inittab+ installed with this init
  307. solution is located in +package/sysvinit/inittab+.
  308. * The third solution is *systemd*. +systemd+ is the new generation
  309. init system for Linux. It does far more than traditional _init_
  310. programs: aggressive parallelization capabilities, uses socket and
  311. D-Bus activation for starting services, offers on-demand starting
  312. of daemons, keeps track of processes using Linux control groups,
  313. supports snapshotting and restoring of the system state,
  314. etc. +systemd+ will be useful on relatively complex embedded
  315. systems, for example the ones requiring D-Bus and services
  316. communicating between each other. It is worth noting that +systemd+
  317. brings a fairly big number of large dependencies: +dbus+, +udev+
  318. and more. For more details about +systemd+, see
  319. http://www.freedesktop.org/wiki/Software/systemd.
  320. The solution recommended by Buildroot developers is to use the
  321. *BusyBox init* as it is sufficient for most embedded
  322. systems. *systemd* can be used for more complex situations.