From e9be64e3ab0fc9bdc604151046b6c9d701239c96 Mon Sep 17 00:00:00 2001 From: PartialVolume Date: Sun, 20 Feb 2022 14:52:42 +0000 Subject: [PATCH] Add DRM drivers for AMDGPU, Radeon, Nouveau, I915, GMA500, UDL for improved functioning of suspend and re-wake from RAM required to unfreeze drives ready for upcoming secure erase implementation in nwipe. Added LCD devices L4F00242T03, LMS283GF05. Added Backlight KTD253, GPIO. Added boot logo support. Removed buildroot manual packages. --- board/shredos/kernel-5.13-defconfig.config | 17 +- board/shredos/version.txt | 2 +- configs/shredos_defconfig | 1 + docs/images | 1 - docs/manual/adding-board-support.txt | 48 - docs/manual/adding-packages-autotools.txt | 175 - docs/manual/adding-packages-cargo.txt | 109 - docs/manual/adding-packages-cmake.txt | 157 - docs/manual/adding-packages-conclusion.txt | 13 - docs/manual/adding-packages-directory.txt | 556 -- docs/manual/adding-packages-generic.txt | 659 -- docs/manual/adding-packages-gettext.txt | 62 - docs/manual/adding-packages-golang.txt | 122 - docs/manual/adding-packages-hooks.txt | 87 - docs/manual/adding-packages-kconfig.txt | 96 - docs/manual/adding-packages-kernel-module.txt | 143 - ...dding-packages-linux-kernel-spec-infra.txt | 152 - docs/manual/adding-packages-luarocks.txt | 109 - docs/manual/adding-packages-meson.txt | 133 - docs/manual/adding-packages-perl.txt | 129 - docs/manual/adding-packages-python.txt | 260 - docs/manual/adding-packages-qmake.txt | 85 - docs/manual/adding-packages-rebar.txt | 108 - docs/manual/adding-packages-tips.txt | 242 - docs/manual/adding-packages-virtual.txt | 144 - docs/manual/adding-packages-waf.txt | 91 - docs/manual/adding-packages.txt | 58 - docs/manual/advanced.txt | 16 - docs/manual/appendix.txt | 6 - docs/manual/beyond-buildroot.txt | 66 - docs/manual/ccache-support.txt | 55 - docs/manual/common-usage.txt | 422 - docs/manual/configure-other-components.txt | 60 - docs/manual/configure.txt | 431 +- docs/manual/contribute.txt | 712 -- docs/manual/customize-configuration.txt | 64 - .../customize-device-permission-tables.txt | 30 - docs/manual/customize-directory-structure.txt | 111 - docs/manual/customize-outside-br.txt | 446 - docs/manual/customize-packages.txt | 56 - docs/manual/customize-patches.txt | 59 - docs/manual/customize-post-image.txt | 38 - docs/manual/customize-quick-guide.txt | 66 - docs/manual/customize-rootfs.txt | 156 - docs/manual/customize-users-tables.txt | 18 - docs/manual/customize.txt | 60 - docs/manual/debugging-buildroot.txt | 43 - docs/manual/developers.txt | 49 - docs/manual/docbook-xsl.css | 329 - docs/manual/download-infra.txt | 8 - docs/manual/download-location.txt | 27 - docs/manual/eclipse-integration.txt | 30 - docs/manual/faq-troubleshooting.txt | 244 - docs/manual/getting.txt | 2 +- docs/manual/github_hash_mongrel2.png | Bin 19029 -> 0 bytes docs/manual/how-buildroot-works.txt | 69 - docs/manual/introduction.txt | 27 +- docs/manual/known-issues.txt | 15 - docs/manual/legal-notice.txt | 122 - docs/manual/logo.png | Bin 117499 -> 0 bytes docs/manual/make-tips.txt | 133 - docs/manual/makedev-syntax.txt | 103 - docs/manual/makeusers-syntax.txt | 89 - docs/manual/manual.html | 5898 ------------ docs/manual/manual.mk | 2 +- docs/manual/manual.pdf | Bin 587127 -> 0 bytes docs/manual/manual.text | 8468 ----------------- docs/manual/manual.txt | 75 +- docs/manual/migrating.txt | 88 - docs/manual/package-make-target.txt | 96 - docs/manual/patch-policy.txt | 162 - docs/manual/prerequisite.txt | 97 +- docs/manual/quickstart.txt | 125 - docs/manual/rebuilding-packages.txt | 136 - docs/manual/release-engineering.txt | 34 - docs/manual/resources.txt | 71 - docs/manual/selinux-support.txt | 74 - docs/manual/using-buildroot-debugger.txt | 53 - docs/manual/using-buildroot-development.txt | 121 - docs/manual/using-buildroot-toolchain.txt | 48 - docs/manual/writing-rules.txt | 151 - docs/website/.htaccess | 62 - docs/website/association.html | 122 - docs/website/contribute.html | 44 - docs/website/copyright.txt | 30 - docs/website/css/main.css | 260 - docs/website/css/timeline.css | 184 - docs/website/docs.html | 130 - docs/website/download.html | 217 - docs/website/favicon.ico | Bin 2238 -> 0 bytes docs/website/favicon.png | Bin 1801 -> 0 bytes .../fonts/glyphicons-halflings-regular.woff | Bin 23292 -> 0 bytes docs/website/footer.html | 7 - docs/website/header.html | 54 - .../website/images/amarula-solutions-logo.png | Bin 16768 -> 0 bytes docs/website/images/bootlin-logo.png | Bin 6171 -> 0 bytes docs/website/images/boundary-devices-logo.png | Bin 13305 -> 0 bytes docs/website/images/browser.png | Bin 18175 -> 0 bytes docs/website/images/bug-buddy.png | Bin 5946 -> 0 bytes docs/website/images/buildroot-slides.png | Bin 32837 -> 0 bytes docs/website/images/calao-logo.png | Bin 15386 -> 0 bytes docs/website/images/circuitco-logo.png | Bin 10750 -> 0 bytes docs/website/images/clippy.svg | 3 - docs/website/images/email.png | Bin 4101 -> 0 bytes docs/website/images/fluendo-logo.png | Bin 9098 -> 0 bytes docs/website/images/free-electrons-logo.png | Bin 9174 -> 0 bytes docs/website/images/gift.png | Bin 15906 -> 0 bytes docs/website/images/github_hash_mongrel2.png | Bin 19029 -> 0 bytes docs/website/images/google-logo.png | Bin 12005 -> 0 bytes docs/website/images/hammer.png | Bin 18353 -> 0 bytes docs/website/images/imgtec-logo.png | Bin 5276 -> 0 bytes docs/website/images/irc.png | Bin 7696 -> 0 bytes docs/website/images/logilin-logo.png | Bin 34112 -> 0 bytes docs/website/images/logo.png | Bin 117499 -> 0 bytes docs/website/images/logo.xcf | Bin 356067 -> 0 bytes docs/website/images/logo_small.png | Bin 3624 -> 0 bytes docs/website/images/menuconfig.png | Bin 181491 -> 0 bytes docs/website/images/mind-logo.png | Bin 10214 -> 0 bytes docs/website/images/nconfig.png | Bin 88055 -> 0 bytes docs/website/images/package.png | Bin 7746 -> 0 bytes docs/website/images/pdf-icon.png | Bin 10324 -> 0 bytes docs/website/images/rockwell-collins-logo.png | Bin 6124 -> 0 bytes docs/website/images/scaleway-logo.png | Bin 12331 -> 0 bytes docs/website/images/smile-logo.png | Bin 28422 -> 0 bytes docs/website/images/synopsys-logo.png | Bin 52426 -> 0 bytes docs/website/images/tap2open-logo.png | Bin 9064 -> 0 bytes docs/website/images/text.png | Bin 6437 -> 0 bytes docs/website/images/tkos-logo.png | Bin 10101 -> 0 bytes docs/website/images/tux-flat.png | Bin 20106 -> 0 bytes docs/website/images/xconfig.png | Bin 224081 -> 0 bytes docs/website/images/zillabit-logo.png | Bin 5394 -> 0 bytes docs/website/images/zip.png | Bin 8208 -> 0 bytes docs/website/index.html | 151 - docs/website/js/buildroot.js | 93 - docs/website/news.html | 6515 ------------- docs/website/robots.txt | 2 - docs/website/sponsors.html | 350 - docs/website/support.html | 124 - package/Config.in | 1 + package/nwipe/nwipe.hash | 3 +- package/nwipe/nwipe.mk | 2 +- 141 files changed, 53 insertions(+), 31921 deletions(-) delete mode 120000 docs/images delete mode 100644 docs/manual/adding-board-support.txt delete mode 100644 docs/manual/adding-packages-autotools.txt delete mode 100644 docs/manual/adding-packages-cargo.txt delete mode 100644 docs/manual/adding-packages-cmake.txt delete mode 100644 docs/manual/adding-packages-conclusion.txt delete mode 100644 docs/manual/adding-packages-directory.txt delete mode 100644 docs/manual/adding-packages-generic.txt delete mode 100644 docs/manual/adding-packages-gettext.txt delete mode 100644 docs/manual/adding-packages-golang.txt delete mode 100644 docs/manual/adding-packages-hooks.txt delete mode 100644 docs/manual/adding-packages-kconfig.txt delete mode 100644 docs/manual/adding-packages-kernel-module.txt delete mode 100644 docs/manual/adding-packages-linux-kernel-spec-infra.txt delete mode 100644 docs/manual/adding-packages-luarocks.txt delete mode 100644 docs/manual/adding-packages-meson.txt delete mode 100644 docs/manual/adding-packages-perl.txt delete mode 100644 docs/manual/adding-packages-python.txt delete mode 100644 docs/manual/adding-packages-qmake.txt delete mode 100644 docs/manual/adding-packages-rebar.txt delete mode 100644 docs/manual/adding-packages-tips.txt delete mode 100644 docs/manual/adding-packages-virtual.txt delete mode 100644 docs/manual/adding-packages-waf.txt delete mode 100644 docs/manual/adding-packages.txt delete mode 100644 docs/manual/advanced.txt delete mode 100644 docs/manual/appendix.txt delete mode 100644 docs/manual/beyond-buildroot.txt delete mode 100644 docs/manual/ccache-support.txt delete mode 100644 docs/manual/common-usage.txt delete mode 100644 docs/manual/configure-other-components.txt delete mode 100644 docs/manual/contribute.txt delete mode 100644 docs/manual/customize-configuration.txt delete mode 100644 docs/manual/customize-device-permission-tables.txt delete mode 100644 docs/manual/customize-directory-structure.txt delete mode 100644 docs/manual/customize-outside-br.txt delete mode 100644 docs/manual/customize-packages.txt delete mode 100644 docs/manual/customize-patches.txt delete mode 100644 docs/manual/customize-post-image.txt delete mode 100644 docs/manual/customize-quick-guide.txt delete mode 100644 docs/manual/customize-rootfs.txt delete mode 100644 docs/manual/customize-users-tables.txt delete mode 100644 docs/manual/customize.txt delete mode 100644 docs/manual/debugging-buildroot.txt delete mode 100644 docs/manual/developers.txt delete mode 100644 docs/manual/docbook-xsl.css delete mode 100644 docs/manual/download-infra.txt delete mode 100644 docs/manual/download-location.txt delete mode 100644 docs/manual/eclipse-integration.txt delete mode 100644 docs/manual/faq-troubleshooting.txt delete mode 100644 docs/manual/github_hash_mongrel2.png delete mode 100644 docs/manual/how-buildroot-works.txt delete mode 100644 docs/manual/known-issues.txt delete mode 100644 docs/manual/legal-notice.txt delete mode 100644 docs/manual/logo.png delete mode 100644 docs/manual/make-tips.txt delete mode 100644 docs/manual/makedev-syntax.txt delete mode 100644 docs/manual/makeusers-syntax.txt delete mode 100644 docs/manual/manual.html delete mode 100644 docs/manual/manual.pdf delete mode 100644 docs/manual/manual.text delete mode 100644 docs/manual/migrating.txt delete mode 100644 docs/manual/package-make-target.txt delete mode 100644 docs/manual/patch-policy.txt delete mode 100644 docs/manual/quickstart.txt delete mode 100644 docs/manual/rebuilding-packages.txt delete mode 100644 docs/manual/release-engineering.txt delete mode 100644 docs/manual/resources.txt delete mode 100644 docs/manual/selinux-support.txt delete mode 100644 docs/manual/using-buildroot-debugger.txt delete mode 100644 docs/manual/using-buildroot-development.txt delete mode 100644 docs/manual/using-buildroot-toolchain.txt delete mode 100644 docs/manual/writing-rules.txt delete mode 100644 docs/website/.htaccess delete mode 100644 docs/website/association.html delete mode 100644 docs/website/contribute.html delete mode 100644 docs/website/copyright.txt delete mode 100644 docs/website/css/main.css delete mode 100644 docs/website/css/timeline.css delete mode 100644 docs/website/docs.html delete mode 100644 docs/website/download.html delete mode 100644 docs/website/favicon.ico delete mode 100644 docs/website/favicon.png delete mode 100644 docs/website/fonts/glyphicons-halflings-regular.woff delete mode 100644 docs/website/footer.html delete mode 100644 docs/website/header.html delete mode 100644 docs/website/images/amarula-solutions-logo.png delete mode 100644 docs/website/images/bootlin-logo.png delete mode 100644 docs/website/images/boundary-devices-logo.png delete mode 100644 docs/website/images/browser.png delete mode 100644 docs/website/images/bug-buddy.png delete mode 100644 docs/website/images/buildroot-slides.png delete mode 100644 docs/website/images/calao-logo.png delete mode 100644 docs/website/images/circuitco-logo.png delete mode 100644 docs/website/images/clippy.svg delete mode 100644 docs/website/images/email.png delete mode 100644 docs/website/images/fluendo-logo.png delete mode 100644 docs/website/images/free-electrons-logo.png delete mode 100644 docs/website/images/gift.png delete mode 100644 docs/website/images/github_hash_mongrel2.png delete mode 100644 docs/website/images/google-logo.png delete mode 100644 docs/website/images/hammer.png delete mode 100644 docs/website/images/imgtec-logo.png delete mode 100644 docs/website/images/irc.png delete mode 100644 docs/website/images/logilin-logo.png delete mode 100644 docs/website/images/logo.png delete mode 100644 docs/website/images/logo.xcf delete mode 100644 docs/website/images/logo_small.png delete mode 100644 docs/website/images/menuconfig.png delete mode 100644 docs/website/images/mind-logo.png delete mode 100644 docs/website/images/nconfig.png delete mode 100644 docs/website/images/package.png delete mode 100644 docs/website/images/pdf-icon.png delete mode 100644 docs/website/images/rockwell-collins-logo.png delete mode 100644 docs/website/images/scaleway-logo.png delete mode 100644 docs/website/images/smile-logo.png delete mode 100644 docs/website/images/synopsys-logo.png delete mode 100644 docs/website/images/tap2open-logo.png delete mode 100644 docs/website/images/text.png delete mode 100644 docs/website/images/tkos-logo.png delete mode 100644 docs/website/images/tux-flat.png delete mode 100644 docs/website/images/xconfig.png delete mode 100644 docs/website/images/zillabit-logo.png delete mode 100644 docs/website/images/zip.png delete mode 100644 docs/website/index.html delete mode 100644 docs/website/js/buildroot.js delete mode 100644 docs/website/news.html delete mode 100644 docs/website/robots.txt delete mode 100644 docs/website/sponsors.html delete mode 100644 docs/website/support.html diff --git a/board/shredos/kernel-5.13-defconfig.config b/board/shredos/kernel-5.13-defconfig.config index 2f000bebe9..d7ab7e7a14 100644 --- a/board/shredos/kernel-5.13-defconfig.config +++ b/board/shredos/kernel-5.13-defconfig.config @@ -33,13 +33,11 @@ CONFIG_EFI=y CONFIG_EFI_STUB=y CONFIG_EFI_MIXED=y CONFIG_PM_WAKELOCKS=y -CONFIG_ACPI_VIDEO=y CONFIG_CPU_IDLE_GOV_LADDER=y CONFIG_X86_SYSFB=y CONFIG_IA32_EMULATION=y CONFIG_X86_X32=y CONFIG_GOOGLE_FIRMWARE=y -# CONFIG_COMPAT_32BIT_TIME is not set # CONFIG_GCC_PLUGINS is not set CONFIG_MODULES=y CONFIG_MODULE_UNLOAD=y @@ -630,6 +628,14 @@ CONFIG_AGP_SIS=y CONFIG_AGP_VIA=y CONFIG_VGA_SWITCHEROO=y CONFIG_DRM=y +# CONFIG_DRM_I2C_CH7006 is not set +# CONFIG_DRM_I2C_SIL164 is not set +CONFIG_DRM_RADEON=y +CONFIG_DRM_AMDGPU=y +CONFIG_DRM_NOUVEAU=y +CONFIG_DRM_I915=y +CONFIG_DRM_GMA500=y +CONFIG_DRM_UDL=y CONFIG_DRM_ANALOGIX_ANX78XX=y CONFIG_FIRMWARE_EDID=y CONFIG_FB_TILEBLITTING=y @@ -638,6 +644,8 @@ CONFIG_FB_VESA=y CONFIG_FB_EFI=y CONFIG_FB_SIMPLE=y CONFIG_LCD_CLASS_DEVICE=y +CONFIG_LCD_L4F00242T03=y +CONFIG_LCD_LMS283GF05=y CONFIG_LCD_LTV350QV=y CONFIG_LCD_ILI922X=y CONFIG_LCD_TDO24M=y @@ -647,7 +655,7 @@ CONFIG_LCD_AMS369FG06=y CONFIG_LCD_LMS501KF03=y CONFIG_LCD_HX8357=y CONFIG_LCD_OTM3225A=y -CONFIG_BACKLIGHT_CLASS_DEVICE=y +CONFIG_BACKLIGHT_KTD253=y CONFIG_BACKLIGHT_LM3533=y CONFIG_BACKLIGHT_DA903X=y CONFIG_BACKLIGHT_DA9052=y @@ -665,11 +673,13 @@ CONFIG_BACKLIGHT_LM3639=y CONFIG_BACKLIGHT_PANDORA=y CONFIG_BACKLIGHT_SKY81452=y CONFIG_BACKLIGHT_AS3711=y +CONFIG_BACKLIGHT_GPIO=y CONFIG_BACKLIGHT_LV5207LP=y CONFIG_BACKLIGHT_BD6107=y CONFIG_BACKLIGHT_ARCXCNN=y CONFIG_FRAMEBUFFER_CONSOLE=y CONFIG_FRAMEBUFFER_CONSOLE_DEFERRED_TAKEOVER=y +CONFIG_LOGO=y CONFIG_HIDRAW=y CONFIG_UHID=y CONFIG_HID_A4TECH=y @@ -1110,7 +1120,6 @@ CONFIG_VFAT_FS=y CONFIG_EXFAT_FS=y CONFIG_NTFS_FS=y CONFIG_NTFS_RW=y -CONFIG_TMPFS=y CONFIG_ECRYPT_FS=y CONFIG_ECRYPT_FS_MESSAGING=y CONFIG_SQUASHFS=y diff --git a/board/shredos/version.txt b/board/shredos/version.txt index 84f7fea848..be590254f8 100644 --- a/board/shredos/version.txt +++ b/board/shredos/version.txt @@ -1 +1 @@ -2021.08.2_20_x86-64_0.32.014 +2021.08.2_22_x86-64_0.32.023 diff --git a/configs/shredos_defconfig b/configs/shredos_defconfig index d0b182d8e7..37eaeef9a0 100644 --- a/configs/shredos_defconfig +++ b/configs/shredos_defconfig @@ -65,6 +65,7 @@ BR2_PACKAGE_LIBHID=y BR2_PACKAGE_KERNEL_CMDLINE_EXTRACTOR=y BR2_PACKAGE_LIBCAP=y BR2_PACKAGE_NWIPE=y +BR2_PACKAGE_SHREDOS=y BR2_PACKAGE_COLLECTD=y BR2_PACKAGE_COLLECTD_NTPD=y BR2_PACKAGE_XUTIL_UTIL_MACROS=y diff --git a/docs/images b/docs/images deleted file mode 120000 index 7356350c8a..0000000000 --- a/docs/images +++ /dev/null @@ -1 +0,0 @@ -website/images \ No newline at end of file diff --git a/docs/manual/adding-board-support.txt b/docs/manual/adding-board-support.txt deleted file mode 100644 index 33ed709535..0000000000 --- a/docs/manual/adding-board-support.txt +++ /dev/null @@ -1,48 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[adding-board-support]] -== Adding support for a particular board - -Buildroot contains basic configurations for several publicly available -hardware boards, so that users of such a board can easily build a system -that is known to work. You are welcome to add support for other boards -to Buildroot too. - -To do so, you need to create a normal Buildroot configuration that -builds a basic system for the hardware: (internal) toolchain, kernel, -bootloader, filesystem and a simple BusyBox-only userspace. No specific -package should be selected: the configuration should be as minimal as -possible, and should only build a working basic BusyBox system for the -target platform. You can of course use more complicated configurations -for your internal projects, but the Buildroot project will only -integrate basic board configurations. This is because package -selections are highly application-specific. - -Once you have a known working configuration, run +make -savedefconfig+. This will generate a minimal +defconfig+ file at the -root of the Buildroot source tree. Move this file into the +configs/+ -directory, and rename it +_defconfig+. If the configuration -is a bit more complicated, it is nice to manually reformat it and -separate it into sections, with a comment before each section. Typical -sections are _Architecture_, _Toolchain options_ (typically just linux -headers version), _Firmware_, _Bootloader_, _Kernel_, and _Filesystem_. - -Always use fixed versions or commit hashes for the different -components, not the "latest" version. For example, set -+BR2_LINUX_KERNEL_CUSTOM_VERSION=y+ and -+BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE+ to the kernel version you tested -with. - -It is recommended to use as much as possible upstream versions of the -Linux kernel and bootloaders, and to use as much as possible default -kernel and bootloader configurations. If they are incorrect for your -board, or no default exists, we encourage you to send fixes to the -corresponding upstream projects. - -However, in the mean time, you may want to store kernel or bootloader -configuration or patches specific to your target platform. To do so, -create a directory +board/+ and a subdirectory -+board//+. You can then store your patches -and configurations in these directories, and reference them from the main -Buildroot configuration. Refer to xref:customize[] for more details. diff --git a/docs/manual/adding-packages-autotools.txt b/docs/manual/adding-packages-autotools.txt deleted file mode 100644 index a041d91eb6..0000000000 --- a/docs/manual/adding-packages-autotools.txt +++ /dev/null @@ -1,175 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for autotools-based packages - -[[autotools-package-tutorial]] - -==== +autotools-package+ tutorial - -First, let's see how to write a +.mk+ file for an autotools-based -package, with an example : - ------------------------- -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_INSTALL_STAGING = YES -11: LIBFOO_INSTALL_TARGET = NO -12: LIBFOO_CONF_OPTS = --disable-shared -13: LIBFOO_DEPENDENCIES = libglib2 host-pkgconf -14: -15: $(eval $(autotools-package)) ------------------------- - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball recommended) -and the location of the tarball on the Web. Buildroot will automatically -download the tarball from this location. - -On line 10, we tell Buildroot to install the package to the staging -directory. The staging directory, located in +output/staging/+ -is the directory where all the packages are installed, including their -development files, etc. By default, packages are not installed to the -staging directory, since usually, only libraries need to be installed in -the staging directory: their development files are needed to compile -other libraries or applications depending on them. Also by default, when -staging installation is enabled, packages are installed in this location -using the +make install+ command. - -On line 11, we tell Buildroot to not install the package to the -target directory. This directory contains what will become the root -filesystem running on the target. For purely static libraries, it is -not necessary to install them in the target directory because they will -not be used at runtime. By default, target installation is enabled; setting -this variable to NO is almost never needed. Also by default, packages are -installed in this location using the +make install+ command. - -On line 12, we tell Buildroot to pass a custom configure option, that -will be passed to the +./configure+ script before configuring -and building the package. - -On line 13, we declare our dependencies, so that they are built -before the build process of our package starts. - -Finally, on line line 15, we invoke the +autotools-package+ -macro that generates all the Makefile rules that actually allows the -package to be built. - -[[autotools-package-reference]] - -==== +autotools-package+ reference - -The main macro of the autotools package infrastructure is -+autotools-package+. It is similar to the +generic-package+ macro. The ability to -have target and host packages is also available, with the -+host-autotools-package+ macro. - -Just like the generic infrastructure, the autotools infrastructure -works by defining a number of variables before calling the -+autotools-package+ macro. - -First, all the package metadata information variables that exist in the -generic infrastructure also exist in the autotools infrastructure: -+LIBFOO_VERSION+, +LIBFOO_SOURCE+, -+LIBFOO_PATCH+, +LIBFOO_SITE+, -+LIBFOO_SUBDIR+, +LIBFOO_DEPENDENCIES+, -+LIBFOO_INSTALL_STAGING+, +LIBFOO_INSTALL_TARGET+. - -A few additional variables, specific to the autotools infrastructure, -can also be defined. Many of them are only useful in very specific -cases, typical packages will therefore only use a few of them. - -* +LIBFOO_SUBDIR+ may contain the name of a subdirectory - inside the package that contains the configure script. This is useful, - if for example, the main configure script is not at the root of the - tree extracted by the tarball. If +HOST_LIBFOO_SUBDIR+ is - not specified, it defaults to +LIBFOO_SUBDIR+. - -* +LIBFOO_CONF_ENV+, to specify additional environment - variables to pass to the configure script. By default, empty. - -* +LIBFOO_CONF_OPTS+, to specify additional configure - options to pass to the configure script. By default, empty. - -* +LIBFOO_MAKE+, to specify an alternate +make+ - command. This is typically useful when parallel make is enabled in - the configuration (using +BR2_JLEVEL+) but that this - feature should be disabled for the given package, for one reason or - another. By default, set to +$(MAKE)+. If parallel building - is not supported by the package, then it should be set to - +LIBFOO_MAKE=$(MAKE1)+. - -* +LIBFOO_MAKE_ENV+, to specify additional environment - variables to pass to make in the build step. These are passed before - the +make+ command. By default, empty. - -* +LIBFOO_MAKE_OPTS+, to specify additional variables to - pass to make in the build step. These are passed after the - +make+ command. By default, empty. - -* +LIBFOO_AUTORECONF+, tells whether the package should - be autoreconfigured or not (i.e. if the configure script and - Makefile.in files should be re-generated by re-running autoconf, - automake, libtool, etc.). Valid values are +YES+ and - +NO+. By default, the value is +NO+ - -* +LIBFOO_AUTORECONF_ENV+, to specify additional environment - variables to pass to the 'autoreconf' program if - +LIBFOO_AUTORECONF=YES+. These are passed in the environment of - the 'autoreconf' command. By default, empty. - -* +LIBFOO_AUTORECONF_OPTS+ to specify additional options - passed to the 'autoreconf' program if - +LIBFOO_AUTORECONF=YES+. By default, empty. - -* +LIBFOO_GETTEXTIZE+, tells whether the package should be - gettextized or not (i.e. if the package uses a different gettext - version than Buildroot provides, and it is needed to run - 'gettextize'.) Only valid when +LIBFOO_AUTORECONF=YES+. Valid - values are +YES+ and +NO+. The default is +NO+. - -* +LIBFOO_GETTEXTIZE_OPTS+, to specify additional options passed to - the 'gettextize' program, if +LIBFOO_GETTEXTIZE=YES+. You may - use that if, for example, the +.po+ files are not located in the - standard place (i.e. in +po/+ at the root of the package.) By - default, '-f'. - -* +LIBFOO_LIBTOOL_PATCH+ tells whether the Buildroot - patch to fix libtool cross-compilation issues should be applied or - not. Valid values are +YES+ and +NO+. By - default, the value is +YES+ - -* +LIBFOO_INSTALL_STAGING_OPTS+ contains the make options - used to install the package to the staging directory. By default, the - value is +DESTDIR=$(STAGING_DIR) install+, which is - correct for most autotools packages. It is still possible to override - it. - -* +LIBFOO_INSTALL_TARGET_OPTS+ contains the make options - used to install the package to the target directory. By default, the - value is +DESTDIR=$(TARGET_DIR) install+. The default - value is correct for most autotools packages, but it is still possible - to override it if needed. - -With the autotools infrastructure, all the steps required to build -and install the packages are already defined, and they generally work -well for most autotools-based packages. However, when required, it is -still possible to customize what is done in any particular step: - -* By adding a post-operation hook (after extract, patch, configure, - build or install). See xref:hooks[] for details. - -* By overriding one of the steps. For example, even if the autotools - infrastructure is used, if the package +.mk+ file defines its - own +LIBFOO_CONFIGURE_CMDS+ variable, it will be used - instead of the default autotools one. However, using this method - should be restricted to very specific cases. Do not use it in the - general case. diff --git a/docs/manual/adding-packages-cargo.txt b/docs/manual/adding-packages-cargo.txt deleted file mode 100644 index 8fcc80bcc6..0000000000 --- a/docs/manual/adding-packages-cargo.txt +++ /dev/null @@ -1,109 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Integration of Cargo-based packages - -Cargo is the package manager for the Rust programming language. It allows the -user to build programs or libraries written in Rust, but it also downloads and -manages their dependencies, to ensure repeatable builds. Cargo packages are -called "crates". - -[[cargo-package-tutorial]] - -==== Cargo-based package's +Config.in+ file - -The +Config.in+ file of Cargo-based package 'foo' should contain: - ---------------------------- -01: config BR2_PACKAGE_FOO -02: bool "foo" -03: depends on BR2_PACKAGE_HOST_RUSTC_TARGET_ARCH_SUPPORTS -04: select BR2_PACKAGE_HOST_RUSTC -05: help -06: This is a comment that explains what foo is. -07: -08: http://foosoftware.org/foo/ ---------------------------- - -==== Cargo-based package's +.mk+ file - -Buildroot does not (yet) provide a dedicated package infrastructure for -Cargo-based packages. So, we will explain how to write a +.mk+ file for such a -package. Let's start with an example: - ------------------------------- -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.0 -08: FOO_SOURCE = foo-$(FOO_VERSION).tar.gz -09: FOO_SITE = http://www.foosoftware.org/download -10: FOO_LICENSE = GPL-3.0+ -11: FOO_LICENSE_FILES = COPYING -12: -13: FOO_DEPENDENCIES = host-rustc -14: -15: FOO_CARGO_ENV = CARGO_HOME=$(HOST_DIR)/share/cargo -16: -17: FOO_BIN_DIR = target/$(RUSTC_TARGET_NAME)/$(FOO_CARGO_MODE) -18: -19: FOO_CARGO_OPTS = \ -20: $(if $(BR2_ENABLE_DEBUG),,--release) \ -21: --target=$(RUSTC_TARGET_NAME) \ -22: --manifest-path=$(@D)/Cargo.toml -23: -24: define FOO_BUILD_CMDS -25: $(TARGET_MAKE_ENV) $(FOO_CARGO_ENV) \ -26: cargo build $(FOO_CARGO_OPTS) -27: endef -28: -29: define FOO_INSTALL_TARGET_CMDS -30: $(INSTALL) -D -m 0755 $(@D)/$(FOO_BIN_DIR)/foo \ -31: $(TARGET_DIR)/usr/bin/foo -32: endef -33: -34: $(eval $(generic-package)) --------------------------------- - -The Makefile starts with the definition of the standard variables for package -declaration (lines 7 to 11). - -As seen in line 34, it is based on the -xref:generic-package-tutorial[+generic-package+ infrastructure]. So, it defines -the variables required by this particular infrastructure, where Cargo is -invoked: - -* +FOO_BUILD_CMDS+: Cargo is invoked to perform the build. The options required - to configure the cross-compilation of the package are passed via - +FOO_CONF_OPTS+. - -* +FOO_INSTALL_TARGET_CMDS+: The binary executable generated is installed on - the target. - -In order to have Cargo available for the build, +FOO_DEPENDENCIES+ needs to -contain +host-cargo+. - -To sum it up, to add a new Cargo-based package, the Makefile example can be -copied verbatim then edited to replace all occurences of +FOO+ with the -uppercase name of the new package and update the values of the standard -variables. - -==== About Dependencies Management - -A crate can depend on other libraries from crates.io or git repositories, listed -in its Cargo.toml file. Before starting a build, Cargo usually downloads -automatically them. This step can also be performed independently, via the -+cargo fetch+ command. - -Cargo maintains a local cache of the registry index and of git checkouts of the -crates, whose location is given by +$CARGO_HOME+. As seen in the package -Makefile example at line 15, this environment variable is set to -+$(HOST_DIR)/share/cargo+. - -This dependency download mechanism is not convenient when performing an offline -build, as Cargo will fail to fetch the dependencies. In that case, it is advised -to generate a tarball of the dependencies using the +cargo vendor+ and add it to -+FOO_EXTRA_DOWNLOADS+. diff --git a/docs/manual/adding-packages-cmake.txt b/docs/manual/adding-packages-cmake.txt deleted file mode 100644 index 541d7422cf..0000000000 --- a/docs/manual/adding-packages-cmake.txt +++ /dev/null @@ -1,157 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for CMake-based packages - -[[cmake-package-tutorial]] - -==== +cmake-package+ tutorial - -First, let's see how to write a +.mk+ file for a CMake-based package, -with an example : - ------------------------- -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_INSTALL_STAGING = YES -11: LIBFOO_INSTALL_TARGET = NO -12: LIBFOO_CONF_OPTS = -DBUILD_DEMOS=ON -13: LIBFOO_DEPENDENCIES = libglib2 host-pkgconf -14: -15: $(eval $(cmake-package)) ------------------------- - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball recommended) -and the location of the tarball on the Web. Buildroot will automatically -download the tarball from this location. - -On line 10, we tell Buildroot to install the package to the staging -directory. The staging directory, located in +output/staging/+ -is the directory where all the packages are installed, including their -development files, etc. By default, packages are not installed to the -staging directory, since usually, only libraries need to be installed in -the staging directory: their development files are needed to compile -other libraries or applications depending on them. Also by default, when -staging installation is enabled, packages are installed in this location -using the +make install+ command. - -On line 11, we tell Buildroot to not install the package to the -target directory. This directory contains what will become the root -filesystem running on the target. For purely static libraries, it is -not necessary to install them in the target directory because they will -not be used at runtime. By default, target installation is enabled; setting -this variable to NO is almost never needed. Also by default, packages are -installed in this location using the +make install+ command. - -On line 12, we tell Buildroot to pass custom options to CMake when it is -configuring the package. - -On line 13, we declare our dependencies, so that they are built -before the build process of our package starts. - -Finally, on line line 15, we invoke the +cmake-package+ -macro that generates all the Makefile rules that actually allows the -package to be built. - -[[cmake-package-reference]] - -==== +cmake-package+ reference - -The main macro of the CMake package infrastructure is -+cmake-package+. It is similar to the +generic-package+ macro. The ability to -have target and host packages is also available, with the -+host-cmake-package+ macro. - -Just like the generic infrastructure, the CMake infrastructure works -by defining a number of variables before calling the +cmake-package+ -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the CMake infrastructure: -+LIBFOO_VERSION+, +LIBFOO_SOURCE+, +LIBFOO_PATCH+, +LIBFOO_SITE+, -+LIBFOO_SUBDIR+, +LIBFOO_DEPENDENCIES+, +LIBFOO_INSTALL_STAGING+, -+LIBFOO_INSTALL_TARGET+. - -A few additional variables, specific to the CMake infrastructure, can -also be defined. Many of them are only useful in very specific cases, -typical packages will therefore only use a few of them. - -* +LIBFOO_SUBDIR+ may contain the name of a subdirectory inside the - package that contains the main CMakeLists.txt file. This is useful, - if for example, the main CMakeLists.txt file is not at the root of - the tree extracted by the tarball. If +HOST_LIBFOO_SUBDIR+ is not - specified, it defaults to +LIBFOO_SUBDIR+. - -* +LIBFOO_CONF_ENV+, to specify additional environment variables to - pass to CMake. By default, empty. - -* +LIBFOO_CONF_OPTS+, to specify additional configure options to pass - to CMake. By default, empty. A number of common CMake options are - set by the +cmake-package+ infrastructure; so it is normally not - necessary to set them in the package's +*.mk+ file unless you want - to override them: - -** +CMAKE_BUILD_TYPE+ is driven by +BR2_ENABLE_RUNTIME_DEBUG+; -** +CMAKE_INSTALL_PREFIX+; -** +BUILD_SHARED_LIBS+ is driven by +BR2_STATIC_LIBS+; -** +BUILD_DOC+, +BUILD_DOCS+ are disabled; -** +BUILD_EXAMPLE+, +BUILD_EXAMPLES+ are disabled; -** +BUILD_TEST+, +BUILD_TESTS+, +BUILD_TESTING+ are disabled. - -* +LIBFOO_SUPPORTS_IN_SOURCE_BUILD = NO+ should be set when the package - cannot be built inside the source tree but needs a separate build - directory. - -* +LIBFOO_MAKE+, to specify an alternate +make+ command. This is - typically useful when parallel make is enabled in the configuration - (using +BR2_JLEVEL+) but that this feature should be disabled for - the given package, for one reason or another. By default, set to - +$(MAKE)+. If parallel building is not supported by the package, - then it should be set to +LIBFOO_MAKE=$(MAKE1)+. - -* +LIBFOO_MAKE_ENV+, to specify additional environment variables to - pass to make in the build step. These are passed before the +make+ - command. By default, empty. - -* +LIBFOO_MAKE_OPTS+, to specify additional variables to pass to make - in the build step. These are passed after the +make+ command. By - default, empty. - -* +LIBFOO_INSTALL_OPTS+ contains the make options used to - install the package to the host directory. By default, the value - is +install+, which is correct for most CMake packages. It is still - possible to override it. - -* +LIBFOO_INSTALL_STAGING_OPTS+ contains the make options used to - install the package to the staging directory. By default, the value - is +DESTDIR=$(STAGING_DIR) install/fast+, which is correct for most - CMake packages. It is still possible to override it. - -* +LIBFOO_INSTALL_TARGET_OPTS+ contains the make options used to - install the package to the target directory. By default, the value - is +DESTDIR=$(TARGET_DIR) install/fast+. The default value is correct - for most CMake packages, but it is still possible to override it if - needed. - -With the CMake infrastructure, all the steps required to build and -install the packages are already defined, and they generally work well -for most CMake-based packages. However, when required, it is still -possible to customize what is done in any particular step: - -* By adding a post-operation hook (after extract, patch, configure, - build or install). See xref:hooks[] for details. - -* By overriding one of the steps. For example, even if the CMake - infrastructure is used, if the package +.mk+ file defines its own - +LIBFOO_CONFIGURE_CMDS+ variable, it will be used instead of the - default CMake one. However, using this method should be restricted - to very specific cases. Do not use it in the general case. diff --git a/docs/manual/adding-packages-conclusion.txt b/docs/manual/adding-packages-conclusion.txt deleted file mode 100644 index 93f90a419d..0000000000 --- a/docs/manual/adding-packages-conclusion.txt +++ /dev/null @@ -1,13 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Conclusion - -As you can see, adding a software package to Buildroot is simply a -matter of writing a Makefile using an existing example and modifying it -according to the compilation process required by the package. - -If you package software that might be useful for other people, don't -forget to send a patch to the Buildroot mailing list (see -xref:submitting-patches[])! - diff --git a/docs/manual/adding-packages-directory.txt b/docs/manual/adding-packages-directory.txt deleted file mode 100644 index 4ceb3fd772..0000000000 --- a/docs/manual/adding-packages-directory.txt +++ /dev/null @@ -1,556 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Package directory - -First of all, create a directory under the +package+ directory for -your software, for example +libfoo+. - -Some packages have been grouped by topic in a sub-directory: -+x11r7+, +qt5+ and +gstreamer+. If your package fits in -one of these categories, then create your package directory in these. -New subdirectories are discouraged, however. - -=== Config files - -For the package to be displayed in the configuration tool, you need to -create a Config file in your package directory. There are two types: -+Config.in+ and +Config.in.host+. - -==== +Config.in+ file - -For packages used on the target, create a file named +Config.in+. This -file will contain the option descriptions related to our +libfoo+ software -that will be used and displayed in the configuration tool. It should basically -contain: - ---------------------------- -config BR2_PACKAGE_LIBFOO - bool "libfoo" - help - This is a comment that explains what libfoo is. The help text - should be wrapped. - - http://foosoftware.org/libfoo/ ---------------------------- - -The +bool+ line, +help+ line and other metadata information about the -configuration option must be indented with one tab. The help text -itself should be indented with one tab and two spaces, lines should -be wrapped to fit 72 columns, where tab counts for 8, so 62 characters -in the text itself. The help text must mention the upstream URL of the -project after an empty line. - -As a convention specific to Buildroot, the ordering of the attributes -is as follows: - -1. The type of option: +bool+, +string+... with the prompt -2. If needed, the +default+ value(s) -3. Any dependencies on the target in +depends on+ form -4. Any dependencies on the toolchain in +depends on+ form -5. Any dependencies on other packages in +depends on+ form -6. Any dependency of the +select+ form -7. The help keyword and help text. - -You can add other sub-options into a +if BR2_PACKAGE_LIBFOO...endif+ -statement to configure particular things in your software. You can look at -examples in other packages. The syntax of the +Config.in+ file is the same -as the one for the kernel Kconfig file. The documentation for this syntax is -available at http://kernel.org/doc/Documentation/kbuild/kconfig-language.txt[] - -Finally you have to add your new +libfoo/Config.in+ to -+package/Config.in+ (or in a category subdirectory if you decided to -put your package in one of the existing categories). The files -included there are 'sorted alphabetically' per category and are 'NOT' -supposed to contain anything but the 'bare' name of the package. - --------------------------- -source "package/libfoo/Config.in" --------------------------- - - -==== +Config.in.host+ file - -Some packages also need to be built for the host system. There are two -options here: - -* The host package is only required to satisfy build-time - dependencies of one or more target packages. In this case, add - +host-foo+ to the target package's +BAR_DEPENDENCIES+ variable. No - +Config.in.host+ file should be created. - -* The host package should be explicitly selectable by the user from - the configuration menu. In this case, create a +Config.in.host+ file - for that host package: -+ ---------------------------- -config BR2_PACKAGE_HOST_FOO - bool "host foo" - help - This is a comment that explains what foo for the host is. - - http://foosoftware.org/foo/ ---------------------------- -+ -The same coding style and options as for the +Config.in+ file are valid. -+ -Finally you have to add your new +libfoo/Config.in.host+ to -+package/Config.in.host+. The files included there are 'sorted alphabetically' -and are 'NOT' supposed to contain anything but the 'bare' name of the package. -+ --------------------------- -source "package/foo/Config.in.host" --------------------------- -+ -The host package will then be available from the +Host utilities+ menu. - -[[depends-on-vs-select]] -==== Choosing +depends on+ or +select+ - -The +Config.in+ file of your package must also ensure that -dependencies are enabled. Typically, Buildroot uses the following -rules: - -* Use a +select+ type of dependency for dependencies on - libraries. These dependencies are generally not obvious and it - therefore make sense to have the kconfig system ensure that the - dependencies are selected. For example, the _libgtk2_ package uses - +select BR2_PACKAGE_LIBGLIB2+ to make sure this library is also - enabled. - The +select+ keyword expresses the dependency with a backward - semantic. - -* Use a +depends on+ type of dependency when the user really needs to - be aware of the dependency. Typically, Buildroot uses this type of - dependency for dependencies on target architecture, MMU support and - toolchain options (see xref:dependencies-target-toolchain-options[]), - or for dependencies on "big" things, such as the X.org system. - The +depends on+ keyword expresses the dependency with a forward - semantic. - -.Note -The current problem with the _kconfig_ language is that these two -dependency semantics are not internally linked. Therefore, it may be -possible to select a package, whom one of its dependencies/requirement -is not met. - -An example illustrates both the usage of +select+ and +depends on+. - --------------------------- -config BR2_PACKAGE_RRDTOOL - bool "rrdtool" - depends on BR2_USE_WCHAR - select BR2_PACKAGE_FREETYPE - select BR2_PACKAGE_LIBART - select BR2_PACKAGE_LIBPNG - select BR2_PACKAGE_ZLIB - help - RRDtool is the OpenSource industry standard, high performance - data logging and graphing system for time series data. - - http://oss.oetiker.ch/rrdtool/ - -comment "rrdtool needs a toolchain w/ wchar" - depends on !BR2_USE_WCHAR --------------------------- - - -Note that these two dependency types are only transitive with the -dependencies of the same kind. - -This means, in the following example: - --------------------------- -config BR2_PACKAGE_A - bool "Package A" - -config BR2_PACKAGE_B - bool "Package B" - depends on BR2_PACKAGE_A - -config BR2_PACKAGE_C - bool "Package C" - depends on BR2_PACKAGE_B - -config BR2_PACKAGE_D - bool "Package D" - select BR2_PACKAGE_B - -config BR2_PACKAGE_E - bool "Package E" - select BR2_PACKAGE_D --------------------------- - -* Selecting +Package C+ will be visible if +Package B+ has been - selected, which in turn is only visible if +Package A+ has been - selected. - -* Selecting +Package E+ will select +Package D+, which will select - +Package B+, it will not check for the dependencies of +Package B+, - so it will not select +Package A+. - -* Since +Package B+ is selected but +Package A+ is not, this violates - the dependency of +Package B+ on +Package A+. Therefore, in such a - situation, the transitive dependency has to be added explicitly: - --------------------------- -config BR2_PACKAGE_D - bool "Package D" - select BR2_PACKAGE_B - depends on BR2_PACKAGE_A - -config BR2_PACKAGE_E - bool "Package E" - select BR2_PACKAGE_D - depends on BR2_PACKAGE_A --------------------------- - -Overall, for package library dependencies, +select+ should be -preferred. - -Note that such dependencies will ensure that the dependency option -is also enabled, but not necessarily built before your package. To do -so, the dependency also needs to be expressed in the +.mk+ file of the -package. - -Further formatting details: see xref:writing-rules-config-in[the -coding style]. - -[[dependencies-target-toolchain-options]] -==== Dependencies on target and toolchain options - -Many packages depend on certain options of the toolchain: the choice of -C library, C++ support, thread support, RPC support, wchar support, -or dynamic library support. Some packages can only be built on certain -target architectures, or if an MMU is available in the processor. - -These dependencies have to be expressed with the appropriate 'depends -on' statements in the Config.in file. Additionally, for dependencies on -toolchain options, a +comment+ should be displayed when the option is -not enabled, so that the user knows why the package is not available. -Dependencies on target architecture or MMU support should not be -made visible in a comment: since it is unlikely that the user can -freely choose another target, it makes little sense to show these -dependencies explicitly. - -The +comment+ should only be visible if the +config+ option itself would -be visible when the toolchain option dependencies are met. This means -that all other dependencies of the package (including dependencies on -target architecture and MMU support) have to be repeated on the -+comment+ definition. To keep it clear, the +depends on+ statement for -these non-toolchain option should be kept separate from the +depends on+ -statement for the toolchain options. -If there is a dependency on a config option in that same file (typically -the main package) it is preferable to have a global +if ... endif+ -construct rather than repeating the +depends on+ statement on the -comment and other config options. - -The general format of a dependency +comment+ for package foo is: - --------------------------- -foo needs a toolchain w/ featA, featB, featC --------------------------- - -for example: - --------------------------- -mpd needs a toolchain w/ C++, threads, wchar --------------------------- - -or - --------------------------- -crda needs a toolchain w/ threads --------------------------- - -Note that this text is kept brief on purpose, so that it will fit on a -80-character terminal. - -The rest of this section enumerates the different target and toolchain -options, the corresponding config symbols to depend on, and the text to -use in the comment. - -* Target architecture -** Dependency symbol: +BR2_powerpc+, +BR2_mips+, ... (see +arch/Config.in+) -** Comment string: no comment to be added - -* MMU support -** Dependency symbol: +BR2_USE_MMU+ -** Comment string: no comment to be added - -* Gcc +__sync_*+ built-ins used for atomic operations. They are - available in variants operating on 1 byte, 2 bytes, 4 bytes and 8 - bytes. Since different architectures support atomic operations on - different sizes, one dependency symbol is available for each size: -** Dependency symbol: +BR2_TOOLCHAIN_HAS_SYNC_1+ for 1 byte, - +BR2_TOOLCHAIN_HAS_SYNC_2+ for 2 bytes, - +BR2_TOOLCHAIN_HAS_SYNC_4+ for 4 bytes, +BR2_TOOLCHAIN_HAS_SYNC_8+ - for 8 bytes. -** Comment string: no comment to be added - -* Gcc +__atomic_*+ built-ins used for atomic operations. -** Dependency symbol: +BR2_TOOLCHAIN_HAS_ATOMIC+. -** Comment string: no comment to be added - -* Kernel headers -** Dependency symbol: +BR2_TOOLCHAIN_HEADERS_AT_LEAST_X_Y+, (replace - +X_Y+ with the proper version, see +toolchain/Config.in+) -** Comment string: +headers >= X.Y+ and/or `headers <= X.Y` (replace - +X.Y+ with the proper version) - -* GCC version -** Dependency symbol: +BR2_TOOLCHAIN_GCC_AT_LEAST_X_Y+, (replace - +X_Y+ with the proper version, see +toolchain/Config.in+) -** Comment string: +gcc >= X.Y+ and/or `gcc <= X.Y` (replace - +X.Y+ with the proper version) - -* Host GCC version -** Dependency symbol: +BR2_HOST_GCC_AT_LEAST_X_Y+, (replace - +X_Y+ with the proper version, see +Config.in+) -** Comment string: no comment to be added -** Note that it is usually not the package itself that has a minimum - host GCC version, but rather a host-package on which it depends. - -* C library -** Dependency symbol: +BR2_TOOLCHAIN_USES_GLIBC+, - +BR2_TOOLCHAIN_USES_MUSL+, +BR2_TOOLCHAIN_USES_UCLIBC+ -** Comment string: for the C library, a slightly different comment text - is used: +foo needs a glibc toolchain+, or `foo needs a glibc - toolchain w/ C++` - -* C++ support -** Dependency symbol: +BR2_INSTALL_LIBSTDCPP+ -** Comment string: `C++` - -* D support -** Dependency symbol: +BR2_TOOLCHAIN_HAS_DLANG+ -** Comment string: `Dlang` - -* Fortran support -** Dependency symbol: +BR2_TOOLCHAIN_HAS_FORTRAN+ -** Comment string: `fortran` - -* thread support -** Dependency symbol: +BR2_TOOLCHAIN_HAS_THREADS+ -** Comment string: +threads+ (unless +BR2_TOOLCHAIN_HAS_THREADS_NPTL+ - is also needed, in which case, specifying only +NPTL+ is sufficient) - -* NPTL thread support -** Dependency symbol: +BR2_TOOLCHAIN_HAS_THREADS_NPTL+ -** Comment string: +NPTL+ - -* RPC support -** Dependency symbol: +BR2_TOOLCHAIN_HAS_NATIVE_RPC+ -** Comment string: +RPC+ - -* wchar support -** Dependency symbol: +BR2_USE_WCHAR+ -** Comment string: +wchar+ - -* dynamic library -** Dependency symbol: +!BR2_STATIC_LIBS+ -** Comment string: +dynamic library+ - -==== Dependencies on a Linux kernel built by buildroot - -Some packages need a Linux kernel to be built by buildroot. These are -typically kernel modules or firmware. A comment should be added in the -Config.in file to express this dependency, similar to dependencies on -toolchain options. The general format is: - --------------------------- -foo needs a Linux kernel to be built --------------------------- - -If there is a dependency on both toolchain options and the Linux -kernel, use this format: - --------------------------- -foo needs a toolchain w/ featA, featB, featC and a Linux kernel to be built --------------------------- - -==== Dependencies on udev /dev management - -If a package needs udev /dev management, it should depend on symbol -+BR2_PACKAGE_HAS_UDEV+, and the following comment should be added: - --------------------------- -foo needs udev /dev management --------------------------- - -If there is a dependency on both toolchain options and udev /dev -management, use this format: - --------------------------- -foo needs udev /dev management and a toolchain w/ featA, featB, featC --------------------------- - -==== Dependencies on features provided by virtual packages - -Some features can be provided by more than one package, such as the -openGL libraries. - -See xref:virtual-package-tutorial[] for more on the virtual packages. - -=== The +.mk+ file - -[[adding-packages-mk]] - -Finally, here's the hardest part. Create a file named +libfoo.mk+. It -describes how the package should be downloaded, configured, built, -installed, etc. - -Depending on the package type, the +.mk+ file must be written in a -different way, using different infrastructures: - -* *Makefiles for generic packages* (not using autotools or CMake): - These are based on an infrastructure similar to the one used for - autotools-based packages, but require a little more work from the - developer. They specify what should be done for the configuration, - compilation and installation of the package. This - infrastructure must be used for all packages that do not use the - autotools as their build system. In the future, other specialized - infrastructures might be written for other build systems. We cover - them through in a xref:generic-package-tutorial[tutorial] and a - xref:generic-package-reference[reference]. - -* *Makefiles for autotools-based software* (autoconf, automake, etc.): - We provide a dedicated infrastructure for such packages, since - autotools is a very common build system. This infrastructure 'must' - be used for new packages that rely on the autotools as their build - system. We cover them through a xref:autotools-package-tutorial[tutorial] - and xref:autotools-package-reference[reference]. - -* *Makefiles for cmake-based software*: We provide a dedicated - infrastructure for such packages, as CMake is a more and more - commonly used build system and has a standardized behaviour. This - infrastructure 'must' be used for new packages that rely on - CMake. We cover them through a xref:cmake-package-tutorial[tutorial] - and xref:cmake-package-reference[reference]. - -* *Makefiles for Python modules*: We have a dedicated infrastructure - for Python modules that use either the +distutils+ or the - +setuptools+ mechanism. We cover them through a - xref:python-package-tutorial[tutorial] and a - xref:python-package-reference[reference]. - -* *Makefiles for Lua modules*: We have a dedicated infrastructure for - Lua modules available through the LuaRocks web site. We cover them - through a xref:luarocks-package-tutorial[tutorial] and a - xref:luarocks-package-reference[reference]. - -Further formatting details: see xref:writing-rules-mk[the writing -rules]. - -[[adding-packages-hash]] -=== The +.hash+ file - -When possible, you must add a third file, named +libfoo.hash+, that -contains the hashes of the downloaded files for the +libfoo+ -package. The only reason for not adding a +.hash+ file is when hash -checking is not possible due to how the package is downloaded. - -When a package has a version selection choice, then the hash file may be -stored in a subdirectory named after the version, e.g. -+package/libfoo/1.2.3/libfoo.hash+. This is especially important if the -different versions have different licensing terms, but they are stored -in the same file. Otherwise, the hash file should stay in the package's -directory. - -The hashes stored in that file are used to validate the integrity of the -downloaded files and of the license files. - -The format of this file is one line for each file for which to check the -hash, each line with the following three fields separated by two spaces: - -* the type of hash, one of: -** +md5+, +sha1+, +sha224+, +sha256+, +sha384+, +sha512+, +none+ -* the hash of the file: -** for +none+, one or more non-space chars, usually just the string +xxx+ -** for +md5+, 32 hexadecimal characters -** for +sha1+, 40 hexadecimal characters -** for +sha224+, 56 hexadecimal characters -** for +sha256+, 64 hexadecimal characters -** for +sha384+, 96 hexadecimal characters -** for +sha512+, 128 hexadecimal characters -* the name of the file: -** for a source archive: the basename of the file, without any directory - component, -** for a license file: the path as it appears in +FOO_LICENSE_FILES+. - -Lines starting with a +#+ sign are considered comments, and ignored. Empty -lines are ignored. - -There can be more than one hash for a single file, each on its own line. In -this case, all hashes must match. - -.Note -Ideally, the hashes stored in this file should match the hashes published by -upstream, e.g. on their website, in the e-mail announcement... If upstream -provides more than one type of hash (e.g. +sha1+ and +sha512+), then it is -best to add all those hashes in the +.hash+ file. If upstream does not -provide any hash, or only provides an +md5+ hash, then compute at least one -strong hash yourself (preferably +sha256+, but not +md5+), and mention -this in a comment line above the hashes. - -.Note -The hashes for license files are used to detect a license change when a -package version is bumped. The hashes are checked during the make legal-info -target run. For a package with multiple versions (like Qt5), -create the hash file in a subdirectory ++ of that package -(see also xref:patch-apply-order[]). - -The +none+ hash type is reserved to those archives downloaded from a -repository, like a 'git clone', a 'subversion checkout'... - -The example below defines a +sha1+ and a +sha256+ published by upstream for -the main +libfoo-1.2.3.tar.bz2+ tarball, an +md5+ from upstream and a -locally-computed +sha256+ hashes for a binary blob, a +sha256+ for a -downloaded patch, and an archive with no hash: - ----- -# Hashes from: http://www.foosoftware.org/download/libfoo-1.2.3.tar.bz2.{sha1,sha256}: -sha1 486fb55c3efa71148fe07895fd713ea3a5ae343a libfoo-1.2.3.tar.bz2 -sha256 efc8103cc3bcb06bda6a781532d12701eb081ad83e8f90004b39ab81b65d4369 libfoo-1.2.3.tar.bz2 - -# md5 from: http://www.foosoftware.org/download/libfoo-1.2.3.tar.bz2.md5, sha256 locally computed: -md5 2d608f3c318c6b7557d551a5a09314f03452f1a1 libfoo-data.bin -sha256 01ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546b libfoo-data.bin - -# Locally computed: -sha256 ff52101fb90bbfc3fe9475e425688c660f46216d7e751c4bbdb1dc85cdccacb9 libfoo-fix-blabla.patch - -# No hash for 1234: -none xxx libfoo-1234.tar.gz - -# Hash for license files: -sha256 a45a845012742796534f7e91fe623262ccfb99460a2bd04015bd28d66fba95b8 COPYING -sha256 01b1f9f2c8ee648a7a596a1abe8aa4ed7899b1c9e5551bda06da6e422b04aa55 doc/COPYING.LGPL ----- - -If the +.hash+ file is present, and it contains one or more hashes for a -downloaded file, the hash(es) computed by Buildroot (after download) must -match the hash(es) stored in the +.hash+ file. If one or more hashes do -not match, Buildroot considers this an error, deletes the downloaded file, -and aborts. - -If the +.hash+ file is present, but it does not contain a hash for a -downloaded file, Buildroot considers this an error and aborts. However, -the downloaded file is left in the download directory since this -typically indicates that the +.hash+ file is wrong but the downloaded -file is probably OK. - -Hashes are currently checked for files fetched from http/ftp servers, -Git repositories, files copied using scp and local files. Hashes are -not checked for other version control systems (such as Subversion, -CVS, etc.) because Buildroot currently does not generate reproducible -tarballs when source code is fetched from such version control -systems. - -Hashes should only be added in +.hash+ files for files that are -guaranteed to be stable. For example, patches auto-generated by Github -are not guaranteed to be stable, and therefore their hashes can change -over time. Such patches should not be downloaded, and instead be added -locally to the package folder. - -If the +.hash+ file is missing, then no check is done at all. diff --git a/docs/manual/adding-packages-generic.txt b/docs/manual/adding-packages-generic.txt deleted file mode 100644 index 2201d4385e..0000000000 --- a/docs/manual/adding-packages-generic.txt +++ /dev/null @@ -1,659 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for packages with specific build systems - -By 'packages with specific build systems' we mean all the packages -whose build system is not one of the standard ones, such as -'autotools' or 'CMake'. This typically includes packages whose build -system is based on hand-written Makefiles or shell scripts. - -[[generic-package-tutorial]] - -==== +generic-package+ tutorial - ------------------------------- -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_LICENSE = GPL-3.0+ -11: LIBFOO_LICENSE_FILES = COPYING -12: LIBFOO_INSTALL_STAGING = YES -13: LIBFOO_CONFIG_SCRIPTS = libfoo-config -14: LIBFOO_DEPENDENCIES = host-libaaa libbbb -15: -16: define LIBFOO_BUILD_CMDS -17: $(MAKE) $(TARGET_CONFIGURE_OPTS) -C $(@D) all -18: endef -19: -20: define LIBFOO_INSTALL_STAGING_CMDS -21: $(INSTALL) -D -m 0755 $(@D)/libfoo.a $(STAGING_DIR)/usr/lib/libfoo.a -22: $(INSTALL) -D -m 0644 $(@D)/foo.h $(STAGING_DIR)/usr/include/foo.h -23: $(INSTALL) -D -m 0755 $(@D)/libfoo.so* $(STAGING_DIR)/usr/lib -24: endef -25: -26: define LIBFOO_INSTALL_TARGET_CMDS -27: $(INSTALL) -D -m 0755 $(@D)/libfoo.so* $(TARGET_DIR)/usr/lib -28: $(INSTALL) -d -m 0755 $(TARGET_DIR)/etc/foo.d -29: endef -30: -31: define LIBFOO_USERS -32: foo -1 libfoo -1 * - - - LibFoo daemon -33: endef -34: -35: define LIBFOO_DEVICES -36: /dev/foo c 666 0 0 42 0 - - - -37: endef -38: -39: define LIBFOO_PERMISSIONS -40: /bin/foo f 4755 foo libfoo - - - - - -41: endef -42: -43: $(eval $(generic-package)) --------------------------------- - -The Makefile begins on line 7 to 11 with metadata information: the -version of the package (+LIBFOO_VERSION+), the name of the -tarball containing the package (+LIBFOO_SOURCE+) (xz-ed tarball recommended) -the Internet location at which the tarball can be downloaded from -(+LIBFOO_SITE+), the license (+LIBFOO_LICENSE+) and file with the -license text (+LIBFOO_LICENSE_FILES+). All variables must start with -the same prefix, +LIBFOO_+ in this case. This prefix is always the -uppercased version of the package name (see below to understand where -the package name is defined). - -On line 12, we specify that this package wants to install something to -the staging space. This is often needed for libraries, since they must -install header files and other development files in the staging space. -This will ensure that the commands listed in the -+LIBFOO_INSTALL_STAGING_CMDS+ variable will be executed. - -On line 13, we specify that there is some fixing to be done to some -of the 'libfoo-config' files that were installed during -+LIBFOO_INSTALL_STAGING_CMDS+ phase. -These *-config files are executable shell script files that are -located in '$(STAGING_DIR)/usr/bin' directory and are executed -by other 3rd party packages to find out the location and the linking -flags of this particular package. - -The problem is that all these *-config files by default give wrong, -host system linking flags that are unsuitable for cross-compiling. - -For example: '-I/usr/include' instead of '-I$(STAGING_DIR)/usr/include' -or: '-L/usr/lib' instead of '-L$(STAGING_DIR)/usr/lib' - -So some sed magic is done to these scripts to make them give correct -flags. -The argument to be given to +LIBFOO_CONFIG_SCRIPTS+ is the file name(s) -of the shell script(s) needing fixing. All these names are relative to -'$(STAGING_DIR)/usr/bin' and if needed multiple names can be given. - -In addition, the scripts listed in +LIBFOO_CONFIG_SCRIPTS+ are removed -from +$(TARGET_DIR)/usr/bin+, since they are not needed on the target. - -.Config script: 'divine' package -================================ -Package divine installs shell script '$(STAGING_DIR)/usr/bin/divine-config'. - -So its fixup would be: - --------------------------------- -DIVINE_CONFIG_SCRIPTS = divine-config --------------------------------- -================================ - -.Config script: 'imagemagick' package: -================================ -Package imagemagick installs the following scripts: -'$(STAGING_DIR)/usr/bin/{Magick,Magick++,MagickCore,MagickWand,Wand}-config' - -So it's fixup would be: - --------------------------------- -IMAGEMAGICK_CONFIG_SCRIPTS = \ - Magick-config Magick++-config \ - MagickCore-config MagickWand-config Wand-config --------------------------------- -================================ - -On line 14, we specify the list of dependencies this package relies -on. These dependencies are listed in terms of lower-case package names, -which can be packages for the target (without the +host-+ -prefix) or packages for the host (with the +host-+) prefix). -Buildroot will ensure that all these packages are built and installed -'before' the current package starts its configuration. - -The rest of the Makefile, lines 16..29, defines what should be done -at the different steps of the package configuration, compilation and -installation. -+LIBFOO_BUILD_CMDS+ tells what steps should be performed to -build the package. +LIBFOO_INSTALL_STAGING_CMDS+ tells what -steps should be performed to install the package in the staging space. -+LIBFOO_INSTALL_TARGET_CMDS+ tells what steps should be -performed to install the package in the target space. - -All these steps rely on the +$(@D)+ variable, which -contains the directory where the source code of the package has been -extracted. - -On lines 31..33, we define a user that is used by this package (e.g. -to run a daemon as non-root) (+LIBFOO_USERS+). - -On line 35..37, we define a device-node file used by this package -(+LIBFOO_DEVICES+). - -On line 39..41, we define the permissions to set to specific files -installed by this package (+LIBFOO_PERMISSIONS+). - -Finally, on line 43, we call the +generic-package+ function, which -generates, according to the variables defined previously, all the -Makefile code necessary to make your package working. - -[[generic-package-reference]] - -==== +generic-package+ reference - -There are two variants of the generic target. The +generic-package+ macro is -used for packages to be cross-compiled for the target. The -+host-generic-package+ macro is used for host packages, natively compiled -for the host. It is possible to call both of them in a single +.mk+ -file: once to create the rules to generate a target -package and once to create the rules to generate a host package: - ----------------------- -$(eval $(generic-package)) -$(eval $(host-generic-package)) ----------------------- - -This might be useful if the compilation of the target package requires -some tools to be installed on the host. If the package name is -+libfoo+, then the name of the package for the target is also -+libfoo+, while the name of the package for the host is -+host-libfoo+. These names should be used in the DEPENDENCIES -variables of other packages, if they depend on +libfoo+ or -+host-libfoo+. - -The call to the +generic-package+ and/or +host-generic-package+ macro -*must* be at the end of the +.mk+ file, after all variable definitions. -The call to +host-generic-package+ *must* be after the call to -+generic-package+, if any. - -For the target package, the +generic-package+ uses the variables defined by -the .mk file and prefixed by the uppercased package name: -+LIBFOO_*+. +host-generic-package+ uses the +HOST_LIBFOO_*+ variables. For -'some' variables, if the +HOST_LIBFOO_+ prefixed variable doesn't -exist, the package infrastructure uses the corresponding variable -prefixed by +LIBFOO_+. This is done for variables that are likely to -have the same value for both the target and host packages. See below -for details. - -The list of variables that can be set in a +.mk+ file to give metadata -information is (assuming the package name is +libfoo+) : - -* +LIBFOO_VERSION+, mandatory, must contain the version of the - package. Note that if +HOST_LIBFOO_VERSION+ doesn't exist, it is - assumed to be the same as +LIBFOO_VERSION+. It can also be a - revision number or a tag for packages that are fetched directly - from their version control system. Examples: - ** a version for a release tarball: +LIBFOO_VERSION = 0.1.2+ - ** a sha1 for a git tree: +LIBFOO_VERSION = cb9d6aa9429e838f0e54faa3d455bcbab5eef057+ - ** a tag for a git tree +LIBFOO_VERSION = v0.1.2+ -+ -.Note: -Using a branch name as +FOO_VERSION+ is not supported, because it does -not and can not work as people would expect it should: -+ - 1. due to local caching, Buildroot will not re-fetch the repository, - so people who expect to be able to follow the remote repository - would be quite surprised and disappointed; - 2. because two builds can never be perfectly simultaneous, and because - the remote repository may get new commits on the branch anytime, - two users, using the same Buildroot tree and building the same - configuration, may get different source, thus rendering the build - non reproducible, and people would be quite surprised and - disappointed. - -* +LIBFOO_SOURCE+ may contain the name of the tarball of the package, - which Buildroot will use to download the tarball from - +LIBFOO_SITE+. If +HOST_LIBFOO_SOURCE+ is not specified, it defaults - to +LIBFOO_SOURCE+. If none are specified, then the value is assumed - to be +libfoo-$(LIBFOO_VERSION).tar.gz+. + - Example: +LIBFOO_SOURCE = foobar-$(LIBFOO_VERSION).tar.bz2+ - -* +LIBFOO_PATCH+ may contain a space-separated list of patch file - names, that Buildroot will download and apply to the package source - code. If an entry contains +://+, then Buildroot will assume it is a - full URL and download the patch from this location. Otherwise, - Buildroot will assume that the patch should be downloaded from - +LIBFOO_SITE+. If +HOST_LIBFOO_PATCH+ is not specified, it defaults - to +LIBFOO_PATCH+. Note that patches that are included in Buildroot - itself use a different mechanism: all files of the form - +*.patch+ present in the package directory inside - Buildroot will be applied to the package after extraction (see - xref:patch-policy[patching a package]). Finally, patches listed in - the +LIBFOO_PATCH+ variable are applied _before_ the patches stored - in the Buildroot package directory. - -* +LIBFOO_SITE+ provides the location of the package, which can be a - URL or a local filesystem path. HTTP, FTP and SCP are supported URL - types for retrieving package tarballs. In these cases don't include a - trailing slash: it will be added by Buildroot between the directory - and the filename as appropriate. Git, Subversion, Mercurial, - and Bazaar are supported URL types for retrieving packages directly - from source code management systems. There is a helper function to make - it easier to download source tarballs from GitHub (refer to - xref:github-download-url[] for details). A filesystem path may be used - to specify either a tarball or a directory containing the package - source code. See +LIBFOO_SITE_METHOD+ below for more details on how - retrieval works. + - Note that SCP URLs should be of the form - +scp://[user@]host:filepath+, and that filepath is relative to the - user's home directory, so you may want to prepend the path with a - slash for absolute paths: - +scp://[user@]host:/absolutepath+. + - If +HOST_LIBFOO_SITE+ is not specified, it defaults to - +LIBFOO_SITE+. - Examples: + - +LIBFOO_SITE=http://www.libfoosoftware.org/libfoo+ + - +LIBFOO_SITE=http://svn.xiph.org/trunk/Tremor+ + - +LIBFOO_SITE=/opt/software/libfoo.tar.gz+ + - +LIBFOO_SITE=$(TOPDIR)/../src/libfoo+ - -* +LIBFOO_DL_OPTS+ is a space-separated list of additional options to - pass to the downloader. Useful for retrieving documents with - server-side checking for user logins and passwords, or to use a proxy. - All download methods valid for +LIBFOO_SITE_METHOD+ are supported; - valid options depend on the download method (consult the man page - for the respective download utilities). - -* +LIBFOO_EXTRA_DOWNLOADS+ is a space-separated list of additional - files that Buildroot should download. If an entry contains +://+ - then Buildroot will assume it is a complete URL and will download - the file using this URL. Otherwise, Buildroot will assume the file - to be downloaded is located at +LIBFOO_SITE+. Buildroot will not do - anything with those additional files, except download them: it will - be up to the package recipe to use them from +$(LIBFOO_DL_DIR)+. - -* +LIBFOO_SITE_METHOD+ determines the method used to fetch or copy the - package source code. In many cases, Buildroot guesses the method - from the contents of +LIBFOO_SITE+ and setting +LIBFOO_SITE_METHOD+ - is unnecessary. When +HOST_LIBFOO_SITE_METHOD+ is not specified, it - defaults to the value of +LIBFOO_SITE_METHOD+. + - The possible values of +LIBFOO_SITE_METHOD+ are: - ** +wget+ for normal FTP/HTTP downloads of tarballs. Used by - default when +LIBFOO_SITE+ begins with +http://+, +https://+ or - +ftp://+. - ** +scp+ for downloads of tarballs over SSH with scp. Used by - default when +LIBFOO_SITE+ begins with +scp://+. - ** +svn+ for retrieving source code from a Subversion repository. - Used by default when +LIBFOO_SITE+ begins with +svn://+. When a - +http://+ Subversion repository URL is specified in - +LIBFOO_SITE+, one 'must' specify +LIBFOO_SITE_METHOD=svn+. - Buildroot performs a checkout which is preserved as a tarball in - the download cache; subsequent builds use the tarball instead of - performing another checkout. - ** +cvs+ for retrieving source code from a CVS repository. - Used by default when +LIBFOO_SITE+ begins with +cvs://+. - The downloaded source code is cached as with the +svn+ method. - Anonymous pserver mode is assumed otherwise explicitly defined - on +LIBFOO_SITE+. Both - +LIBFOO_SITE=cvs://libfoo.net:/cvsroot/libfoo+ and - +LIBFOO_SITE=cvs://:ext:libfoo.net:/cvsroot/libfoo+ - are accepted, on the former anonymous pserver access mode is - assumed. - +LIBFOO_SITE+ 'must' contain the source URL as well as the remote - repository directory. The module is the package name. - +LIBFOO_VERSION+ is 'mandatory' and 'must' be a tag, a branch, or - a date (e.g. "2014-10-20", "2014-10-20 13:45", "2014-10-20 - 13:45+01" see "man cvs" for further details). - ** +git+ for retrieving source code from a Git repository. Used by - default when +LIBFOO_SITE+ begins with +git://+. The downloaded - source code is cached as with the +svn+ - method. - ** +hg+ for retrieving source code from a Mercurial repository. One - 'must' specify +LIBFOO_SITE_METHOD=hg+ when +LIBFOO_SITE+ - contains a Mercurial repository URL. The downloaded source code - is cached as with the +svn+ method. - ** +bzr+ for retrieving source code from a Bazaar repository. Used - by default when +LIBFOO_SITE+ begins with +bzr://+. The - downloaded source code is cached as with the +svn+ method. - ** +file+ for a local tarball. One should use this when - +LIBFOO_SITE+ specifies a package tarball as a local filename. - Useful for software that isn't available publicly or in version - control. - ** +local+ for a local source code directory. One should use this - when +LIBFOO_SITE+ specifies a local directory path containing - the package source code. Buildroot copies the contents of the - source directory into the package's build directory. Note that - for +local+ packages, no patches are applied. If you need to - still patch the source code, use +LIBFOO_POST_RSYNC_HOOKS+, see - xref:hooks-rsync[]. - -* +LIBFOO_GIT_SUBMODULES+ can be set to +YES+ to create an archive - with the git submodules in the repository. This is only available - for packages downloaded with git (i.e. when - +LIBFOO_SITE_METHOD=git+). Note that we try not to use such git - submodules when they contain bundled libraries, in which case we - prefer to use those libraries from their own package. - -* +LIBFOO_STRIP_COMPONENTS+ is the number of leading components - (directories) that tar must strip from file names on extraction. - The tarball for most packages has one leading component named - "-", thus Buildroot passes - --strip-components=1 to tar to remove it. - For non-standard packages that don't have this component, or - that have more than one leading component to strip, set this - variable with the value to be passed to tar. Default: 1. - -* +LIBFOO_EXCLUDES+ is a space-separated list of patterns to exclude - when extracting the archive. Each item from that list is passed as - a tar's +--exclude+ option. By default, empty. - -* +LIBFOO_DEPENDENCIES+ lists the dependencies (in terms of package - name) that are required for the current target package to - compile. These dependencies are guaranteed to be compiled and - installed before the configuration of the current package starts. - However, modifications to configuration of these dependencies will - not force a rebuild of the current package. In a similar way, - +HOST_LIBFOO_DEPENDENCIES+ lists the dependencies for the current - host package. - -* +LIBFOO_EXTRACT_DEPENDENCIES+ lists the dependencies (in terms of - package name) that are required for the current target package to be - extracted. These dependencies are guaranteed to be compiled and - installed before the extract step of the current package - starts. This is only used internally by the package infrastructure, - and should typically not be used directly by packages. - -* +LIBFOO_PATCH_DEPENDENCIES+ lists the dependencies (in terms of - package name) that are required for the current package to be - patched. These dependencies are guaranteed to be extracted and - patched (but not necessarily built) before the current package is - patched. In a similar way, +HOST_LIBFOO_PATCH_DEPENDENCIES+ lists - the dependencies for the current host package. - This is seldom used; usually, +LIBFOO_DEPENDENCIES+ is what you - really want to use. - -* +LIBFOO_PROVIDES+ lists all the virtual packages +libfoo+ is an - implementation of. See xref:virtual-package-tutorial[]. - -* +LIBFOO_INSTALL_STAGING+ can be set to +YES+ or +NO+ (default). If - set to +YES+, then the commands in the +LIBFOO_INSTALL_STAGING_CMDS+ - variables are executed to install the package into the staging - directory. - -* +LIBFOO_INSTALL_TARGET+ can be set to +YES+ (default) or +NO+. If - set to +YES+, then the commands in the +LIBFOO_INSTALL_TARGET_CMDS+ - variables are executed to install the package into the target - directory. - -* +LIBFOO_INSTALL_IMAGES+ can be set to +YES+ or +NO+ (default). If - set to +YES+, then the commands in the +LIBFOO_INSTALL_IMAGES_CMDS+ - variable are executed to install the package into the images - directory. - -* +LIBFOO_CONFIG_SCRIPTS+ lists the names of the files in - '$(STAGING_DIR)/usr/bin' that need some special fixing to make them - cross-compiling friendly. Multiple file names separated by space can - be given and all are relative to '$(STAGING_DIR)/usr/bin'. The files - listed in +LIBFOO_CONFIG_SCRIPTS+ are also removed from - +$(TARGET_DIR)/usr/bin+ since they are not needed on the target. - -* +LIBFOO_DEVICES+ lists the device files to be created by Buildroot - when using the static device table. The syntax to use is the - makedevs one. You can find some documentation for this syntax in the - xref:makedev-syntax[]. This variable is optional. - -* +LIBFOO_PERMISSIONS+ lists the changes of permissions to be done at - the end of the build process. The syntax is once again the makedevs one. - You can find some documentation for this syntax in the xref:makedev-syntax[]. - This variable is optional. - -* +LIBFOO_USERS+ lists the users to create for this package, if it installs - a program you want to run as a specific user (e.g. as a daemon, or as a - cron-job). The syntax is similar in spirit to the makedevs one, and is - described in the xref:makeuser-syntax[]. This variable is optional. - -* +LIBFOO_LICENSE+ defines the license (or licenses) under which the package - is released. - This name will appear in the manifest file produced by +make legal-info+. - If the license appears in https://spdx.org/licenses/[the SPDX License List], - use the SPDX short identifier to make the manifest file uniform. - Otherwise, describe the license in a precise and concise way, avoiding - ambiguous names such as +BSD+ which actually name a family of licenses. - This variable is optional. If it is not defined, +unknown+ will appear in - the +license+ field of the manifest file for this package. + - The expected format for this variable must comply with the following rules: - ** If different parts of the package are released under different - licenses, then +comma+ separate licenses (e.g. +`LIBFOO_LICENSE = - GPL-2.0+, LGPL-2.1+`+). If there is clear distinction between which - component is licensed under what license, then annotate the license - with that component, between parenthesis (e.g. +`LIBFOO_LICENSE = - GPL-2.0+ (programs), LGPL-2.1+ (libraries)`+). - ** If some licenses are conditioned on a sub-option being enabled, append - the conditional licenses with a comma (e.g.: `FOO_LICENSE += , GPL-2.0+ - (programs)`); the infrastructure will internally remove the space before - the comma. - ** If the package is dual licensed, then separate licenses with the - +or+ keyword (e.g. +`LIBFOO_LICENSE = AFL-2.1 or GPL-2.0+`+). - -* +LIBFOO_LICENSE_FILES+ is a space-separated list of files in the package - tarball that contain the license(s) under which the package is released. - +make legal-info+ copies all of these files in the +legal-info+ directory. - See xref:legal-info[] for more information. - This variable is optional. If it is not defined, a warning will be produced - to let you know, and +not saved+ will appear in the +license files+ field - of the manifest file for this package. - -* +LIBFOO_ACTUAL_SOURCE_TARBALL+ only applies to packages whose - +LIBFOO_SITE+ / +LIBFOO_SOURCE+ pair points to an archive that does - not actually contain source code, but binary code. This a very - uncommon case, only known to apply to external toolchains which come - already compiled, although theoretically it might apply to other - packages. In such cases a separate tarball is usually available with - the actual source code. Set +LIBFOO_ACTUAL_SOURCE_TARBALL+ to the - name of the actual source code archive and Buildroot will download - it and use it when you run +make legal-info+ to collect - legally-relevant material. Note this file will not be downloaded - during regular builds nor by +make source+. - -* +LIBFOO_ACTUAL_SOURCE_SITE+ provides the location of the actual - source tarball. The default value is +LIBFOO_SITE+, so you don't - need to set this variable if the binary and source archives are - hosted on the same directory. If +LIBFOO_ACTUAL_SOURCE_TARBALL+ is - not set, it doesn't make sense to define - +LIBFOO_ACTUAL_SOURCE_SITE+. - -* +LIBFOO_REDISTRIBUTE+ can be set to +YES+ (default) or +NO+ to indicate if - the package source code is allowed to be redistributed. Set it to +NO+ for - non-opensource packages: Buildroot will not save the source code for this - package when collecting the +legal-info+. - -* +LIBFOO_FLAT_STACKSIZE+ defines the stack size of an application built into - the FLAT binary format. The application stack size on the NOMMU architecture - processors can't be enlarged at run time. The default stack size for the - FLAT binary format is only 4k bytes. If the application consumes more stack, - append the required number here. - -* +LIBFOO_BIN_ARCH_EXCLUDE+ is a space-separated list of paths (relative - to the target directory) to ignore when checking that the package - installs correctly cross-compiled binaries. You seldom need to set this - variable, unless the package installs binary blobs outside the default - locations, `/lib/firmware`, `/usr/lib/firmware`, `/lib/modules`, - `/usr/lib/modules`, and `/usr/share`, which are automatically excluded. - -* +LIBFOO_IGNORE_CVES+ is a space-separated list of CVEs that tells - Buildroot CVE tracking tools which CVEs should be ignored for this - package. This is typically used when the CVE is fixed by a patch in - the package, or when the CVE for some reason does not affect the - Buildroot package. A Makefile comment must always precede the - addition of a CVE to this variable. Example: - ----------------------- -# 0001-fix-cve-2020-12345.patch -LIBFOO_IGNORE_CVES += CVE-2020-12345 -# only when built with libbaz, which Buildroot doesn't support -LIBFOO_IGNORE_CVES += CVE-2020-54321 ----------------------- - -* +LIBFOO_CPE_ID_*+ variables is a set of variables that allows the - package to define its https://nvd.nist.gov/products/cpe[CPE - identifier]. The available variables are: -+ --- -** +LIBFOO_CPE_ID_PREFIX+, specifies the prefix of the CPE identifier, - i.e the first three fields. When not defined, the default value is - +cpe:2.3:a+. - -** +LIBFOO_CPE_ID_VENDOR+, specifies the vendor part of the CPE - identifier. When not defined, the default value is - +_project+. - -** +LIBFOO_CPE_ID_PRODUCT+, specifies the product part of the CPE - identifier. When not defined, the default value is ++. - -** +LIBFOO_CPE_ID_VERSION+, specifies the version part of the CPE - identifier. When not defined the default value is - +$(LIBFOO_VERSION)+. - -** +LIBFOO_CPE_ID_UPDATE+ specifies the _update_ part of the CPE - identifier. When not defined the default value is +*+. --- -+ -If any of those variables is defined, then the generic package -infrastructure assumes the package provides valid CPE information. In -this case, the generic package infrastructure will define -+LIBFOO_CPE_ID+. -+ -For a host package, if its +LIBFOO_CPE_ID_*+ variables are not -defined, it inherits the value of those variables from the -corresponding target package. - -The recommended way to define these variables is to use the following -syntax: - ----------------------- -LIBFOO_VERSION = 2.32 ----------------------- - -Now, the variables that define what should be performed at the -different steps of the build process. - -* +LIBFOO_EXTRACT_CMDS+ lists the actions to be performed to extract - the package. This is generally not needed as tarballs are - automatically handled by Buildroot. However, if the package uses a - non-standard archive format, such as a ZIP or RAR file, or has a - tarball with a non-standard organization, this variable allows to - override the package infrastructure default behavior. - -* +LIBFOO_CONFIGURE_CMDS+ lists the actions to be performed to - configure the package before its compilation. - -* +LIBFOO_BUILD_CMDS+ lists the actions to be performed to - compile the package. - -* +HOST_LIBFOO_INSTALL_CMDS+ lists the actions to be performed - to install the package, when the package is a host package. The - package must install its files to the directory given by - +$(HOST_DIR)+. All files, including development files such as - headers should be installed, since other packages might be compiled - on top of this package. - -* +LIBFOO_INSTALL_TARGET_CMDS+ lists the actions to be - performed to install the package to the target directory, when the - package is a target package. The package must install its files to - the directory given by +$(TARGET_DIR)+. Only the files required for - 'execution' of the package have to be - installed. Header files, static libraries and documentation will be - removed again when the target filesystem is finalized. - -* +LIBFOO_INSTALL_STAGING_CMDS+ lists the actions to be - performed to install the package to the staging directory, when the - package is a target package. The package must install its files to - the directory given by +$(STAGING_DIR)+. All development files - should be installed, since they might be needed to compile other - packages. - -* +LIBFOO_INSTALL_IMAGES_CMDS+ lists the actions to be performed to - install the package to the images directory, when the package is a - target package. The package must install its files to the directory - given by +$(BINARIES_DIR)+. Only files that are binary images (aka - images) that do not belong in the +TARGET_DIR+ but are necessary - for booting the board should be placed here. For example, a package - should utilize this step if it has binaries which would be similar - to the kernel image, bootloader or root filesystem images. - -* +LIBFOO_INSTALL_INIT_SYSV+, +LIBFOO_INSTALL_INIT_OPENRC+ and - +LIBFOO_INSTALL_INIT_SYSTEMD+ list the actions to install init - scripts either for the systemV-like init systems (busybox, - sysvinit, etc.), openrc or for the systemd units. These commands - will be run only when the relevant init system is installed (i.e. - if systemd is selected as the init system in the configuration, - only +LIBFOO_INSTALL_INIT_SYSTEMD+ will be run). The only exception - is when openrc is chosen as init system and +LIBFOO_INSTALL_INIT_OPENRC+ - has not been set, in such situation +LIBFOO_INSTALL_INIT_SYSV+ will - be called, since openrc supports sysv init scripts. - When systemd is used as the init system, buildroot will automatically enable - all services using the +systemctl preset-all+ command in the final phase of - image building. You can add preset files to prevent a particular unit from - being automatically enabled by buildroot. - -* +LIBFOO_HELP_CMDS+ lists the actions to print the package help, which - is included to the main +make help+ output. These commands can print - anything in any format. - This is seldom used, as packages rarely have custom rules. *Do not use - this variable*, unless you really know that you need to print help. - -* +LIBFOO_LINUX_CONFIG_FIXUPS+ lists the Linux kernel configuration - options that are needed to build and use this package, and without - which the package is fundamentally broken. This shall be a set of - calls to one of the kconfig tweaking option: `KCONFIG_ENABLE_OPT`, - `KCONFIG_DISABLE_OPT`, or `KCONFIG_SET_OPT`. - This is seldom used, as package usually have no strict requirements on - the kernel options. - -The preferred way to define these variables is: - ----------------------- -define LIBFOO_CONFIGURE_CMDS - action 1 - action 2 - action 3 -endef ----------------------- - -In the action definitions, you can use the following variables: - -* +$(LIBFOO_PKGDIR)+ contains the path to the directory containing the - +libfoo.mk+ and +Config.in+ files. This variable is useful when it is - necessary to install a file bundled in Buildroot, like a runtime - configuration file, a splashscreen image... - -* +$(@D)+, which contains the directory in which the package source - code has been uncompressed. - -* +$(LIBFOO_DL_DIR)+ contains the path to the directory where all the downloads - made by Buildroot for +libfoo+ are stored in. - -* +$(TARGET_CC)+, +$(TARGET_LD)+, etc. to get the target - cross-compilation utilities - -* +$(TARGET_CROSS)+ to get the cross-compilation toolchain prefix - -* Of course the +$(HOST_DIR)+, +$(STAGING_DIR)+ and +$(TARGET_DIR)+ - variables to install the packages properly. Those variables point to - the global _host_, _staging_ and _target_ directories, unless - _per-package directory_ support is used, in which case they point to - the current package _host_, _staging_ and _target_ directories. In - both cases, it doesn't make any difference from the package point of - view: it should simply use +HOST_DIR+, +STAGING_DIR+ and - +TARGET_DIR+. See xref:top-level-parallel-build[] for more details - about _per-package directory_ support. - -Finally, you can also use hooks. See xref:hooks[] for more information. diff --git a/docs/manual/adding-packages-gettext.txt b/docs/manual/adding-packages-gettext.txt deleted file mode 100644 index e9c6968e79..0000000000 --- a/docs/manual/adding-packages-gettext.txt +++ /dev/null @@ -1,62 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Gettext integration and interaction with packages - -Many packages that support internationalization use the gettext -library. Dependencies for this library are fairly complicated and -therefore, deserve some explanation. - -The 'glibc' C library integrates a full-blown implementation of -'gettext', supporting translation. Native Language Support is -therefore built-in in 'glibc'. - -On the other hand, the 'uClibc' and 'musl' C libraries only provide a -stub implementation of the gettext functionality, which allows to -compile libraries and programs using gettext functions, but without -providing the translation capabilities of a full-blown gettext -implementation. With such C libraries, if real Native Language Support -is necessary, it can be provided by the +libintl+ library of the -+gettext+ package. - -Due to this, and in order to make sure that Native Language Support is -properly handled, packages in Buildroot that can use NLS support -should: - -1. Ensure NLS support is enabled when +BR2_SYSTEM_ENABLE_NLS=y+. This - is done automatically for 'autotools' packages and therefore should - only be done for packages using other package infrastructures. - -1. Add +$(TARGET_NLS_DEPENDENCIES)+ to the package - +_DEPENDENCIES+ variable. This addition should be done - unconditionally: the value of this variable is automatically - adjusted by the core infrastructure to contain the relevant list of - packages. If NLS support is disabled, this variable is empty. If - NLS support is enabled, this variable contains +host-gettext+ so - that tools needed to compile translation files are available on the - host. In addition, if 'uClibc' or 'musl' are used, this variable - also contains +gettext+ in order to get the full-blown 'gettext' - implementation. - -1. If needed, add +$(TARGET_NLS_LIBS)+ to the linker flags, so that - the package gets linked with +libintl+. This is generally not - needed with 'autotools' packages as they usually detect - automatically that they should link with +libintl+. However, - packages using other build systems, or problematic autotools-based - packages may need this. +$(TARGET_NLS_LIBS)+ should be added - unconditionally to the linker flags, as the core automatically - makes it empty or defined to +-lintl+ depending on the - configuration. - -No changes should be made to the +Config.in+ file to support NLS. - -Finally, certain packages need some gettext utilities on the target, -such as the +gettext+ program itself, which allows to retrieve -translated strings, from the command line. In such a case, the package -should: - -* use +select BR2_PACKAGE_GETTEXT+ in their +Config.in+ file, - indicating in a comment above that it's a runtime dependency only. - -* not add any +gettext+ dependency in the +DEPENDENCIES+ variable of - their +.mk+ file. diff --git a/docs/manual/adding-packages-golang.txt b/docs/manual/adding-packages-golang.txt deleted file mode 100644 index 3b34579200..0000000000 --- a/docs/manual/adding-packages-golang.txt +++ /dev/null @@ -1,122 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for Go packages - -This infrastructure applies to Go packages that use the standard -build system and use bundled dependencies. - -[[golang-package-tutorial]] - -==== +golang-package+ tutorial - -First, let's see how to write a +.mk+ file for a go package, -with an example : - ------------------------- -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.0 -08: FOO_SITE = $(call github,bar,foo,$(FOO_VERSION)) -09: FOO_LICENSE = BSD-3-Clause -10: FOO_LICENSE_FILES = LICENSE -11: -12: $(eval $(golang-package)) ------------------------- - -On line 7, we declare the version of the package. - -On line 8, we declare the upstream location of the package, here -fetched from Github, since a large number of Go packages are hosted on -Github. - -On line 9 and 10, we give licensing details about the package. - -Finally, on line 12, we invoke the +golang-package+ macro that -generates all the Makefile rules that actually allow the package to be -built. - -[[golang-package-reference]] - -==== +golang-package+ reference - -In their +Config.in+ file, packages using the +golang-package+ -infrastructure should depend on +BR2_PACKAGE_HOST_GO_TARGET_ARCH_SUPPORTS+ -because Buildroot will automatically add a dependency on +host-go+ -to such packages. -If you need CGO support in your package, you must add a dependency on -+BR2_PACKAGE_HOST_GO_TARGET_CGO_LINKING_SUPPORTS+. - -The main macro of the Go package infrastructure is -+golang-package+. It is similar to the +generic-package+ macro. The -ability to build host packages is also available, with the -+host-golang-package+ macro. -Host packages built by +host-golang-package+ macro should depend on -BR2_PACKAGE_HOST_GO_HOST_ARCH_SUPPORTS. - -Just like the generic infrastructure, the Go infrastructure works -by defining a number of variables before calling the +golang-package+. - -All the package metadata information variables that exist in the -xref:generic-package-reference[generic package infrastructure] also -exist in the Go infrastructure: +FOO_VERSION+, +FOO_SOURCE+, -+FOO_PATCH+, +FOO_SITE+, +FOO_SUBDIR+, +FOO_DEPENDENCIES+, -+FOO_LICENSE+, +FOO_LICENSE_FILES+, +FOO_INSTALL_STAGING+, etc. - -Note that it is not necessary to add +host-go+ in the -+FOO_DEPENDENCIES+ variable of a package, since this basic dependency -is automatically added as needed by the Go package infrastructure. - -A few additional variables, specific to the Go infrastructure, can -optionally be defined, depending on the package's needs. Many of them -are only useful in very specific cases, typical packages will -therefore only use a few of them, or none. - -* The package must specify its Go module name in the +FOO_GOMOD+ - variable. If not specified, it defaults to - +URL-domain/1st-part-of-URL/2nd-part-of-URL+, e.g +FOO_GOMOD+ will - take the value +github.com/bar/foo+ for a package that specifies - +FOO_SITE = $(call github,bar,foo,$(FOO_VERSION))+. The Go package - infrastructure will automatically generate a minimal +go.mod+ file - in the package source tree if it doesn't exist. - -* +FOO_LDFLAGS+ and +FOO_TAGS+ can be used to pass respectively the - +LDFLAGS+ or the +TAGS+ to the +go+ build command. - -* +FOO_BUILD_TARGETS+ can be used to pass the list of targets that - should be built. If +FOO_BUILD_TARGETS+ is not specified, it - defaults to +.+. We then have two cases: - -** +FOO_BUILD_TARGETS+ is +.+. In this case, we assume only one binary - will be produced, and that by default we name it after the package - name. If that is not appropriate, the name of the produced binary - can be overridden using +FOO_BIN_NAME+. - -** +FOO_BUILD_TARGETS+ is not +.+. In this case, we iterate over the - values to build each target, and for each produced a binary that is - the non-directory component of the target. For example if - +FOO_BUILD_TARGETS = cmd/docker cmd/dockerd+ the binaries produced - are +docker+ and +dockerd+. - -* +FOO_INSTALL_BINS+ can be used to pass the list of binaries that - should be installed in +/usr/bin+ on the target. If - +FOO_INSTALL_BINS+ is not specified, it defaults to the lower-case - name of package. - -With the Go infrastructure, all the steps required to build and -install the packages are already defined, and they generally work well -for most Go-based packages. However, when required, it is still -possible to customize what is done in any particular step: - -* By adding a post-operation hook (after extract, patch, configure, - build or install). See xref:hooks[] for details. - -* By overriding one of the steps. For example, even if the Go - infrastructure is used, if the package +.mk+ file defines its own - +FOO_BUILD_CMDS+ variable, it will be used instead of the default Go - one. However, using this method should be restricted to very - specific cases. Do not use it in the general case. diff --git a/docs/manual/adding-packages-hooks.txt b/docs/manual/adding-packages-hooks.txt deleted file mode 100644 index 0ce79f8907..0000000000 --- a/docs/manual/adding-packages-hooks.txt +++ /dev/null @@ -1,87 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[hooks]] -=== Hooks available in the various build steps - -The generic infrastructure (and as a result also the derived autotools -and cmake infrastructures) allow packages to specify hooks. -These define further actions to perform after existing steps. -Most hooks aren't really useful for generic packages, since the +.mk+ -file already has full control over the actions performed in each step -of the package construction. - -The following hook points are available: - -* +LIBFOO_PRE_DOWNLOAD_HOOKS+ -* +LIBFOO_POST_DOWNLOAD_HOOKS+ - -* +LIBFOO_PRE_EXTRACT_HOOKS+ -* +LIBFOO_POST_EXTRACT_HOOKS+ - -* +LIBFOO_PRE_RSYNC_HOOKS+ -* +LIBFOO_POST_RSYNC_HOOKS+ - -* +LIBFOO_PRE_PATCH_HOOKS+ -* +LIBFOO_POST_PATCH_HOOKS+ - -* +LIBFOO_PRE_CONFIGURE_HOOKS+ -* +LIBFOO_POST_CONFIGURE_HOOKS+ - -* +LIBFOO_PRE_BUILD_HOOKS+ -* +LIBFOO_POST_BUILD_HOOKS+ - -* +LIBFOO_PRE_INSTALL_HOOKS+ (for host packages only) -* +LIBFOO_POST_INSTALL_HOOKS+ (for host packages only) - -* +LIBFOO_PRE_INSTALL_STAGING_HOOKS+ (for target packages only) -* +LIBFOO_POST_INSTALL_STAGING_HOOKS+ (for target packages only) - -* +LIBFOO_PRE_INSTALL_TARGET_HOOKS+ (for target packages only) -* +LIBFOO_POST_INSTALL_TARGET_HOOKS+ (for target packages only) - -* +LIBFOO_PRE_INSTALL_IMAGES_HOOKS+ -* +LIBFOO_POST_INSTALL_IMAGES_HOOKS+ - -* +LIBFOO_PRE_LEGAL_INFO_HOOKS+ -* +LIBFOO_POST_LEGAL_INFO_HOOKS+ - -These variables are 'lists' of variable names containing actions to be -performed at this hook point. This allows several hooks to be -registered at a given hook point. Here is an example: - ----------------------- -define LIBFOO_POST_PATCH_FIXUP - action1 - action2 -endef - -LIBFOO_POST_PATCH_HOOKS += LIBFOO_POST_PATCH_FIXUP ----------------------- - -[[hooks-rsync]] -==== Using the +POST_RSYNC+ hook -The +POST_RSYNC+ hook is run only for packages that use a local source, -either through the +local+ site method or the +OVERRIDE_SRCDIR+ -mechanism. In this case, package sources are copied using +rsync+ from -the local location into the buildroot build directory. The +rsync+ -command does not copy all files from the source directory, though. -Files belonging to a version control system, like the directories -+.git+, +.hg+, etc. are not copied. For most packages this is -sufficient, but a given package can perform additional actions using -the +POST_RSYNC+ hook. - -In principle, the hook can contain any command you want. One specific -use case, though, is the intentional copying of the version control -directory using +rsync+. The +rsync+ command you use in the hook can, among -others, use the following variables: - -* +$(SRCDIR)+: the path to the overridden source directory -* +$(@D)+: the path to the build directory - -==== Target-finalize hook - -Packages may also register hooks in +LIBFOO_TARGET_FINALIZE_HOOKS+. -These hooks are run after all packages are built, but before the -filesystem images are generated. They are seldom used, and your -package probably do not need them. diff --git a/docs/manual/adding-packages-kconfig.txt b/docs/manual/adding-packages-kconfig.txt deleted file mode 100644 index a35681775f..0000000000 --- a/docs/manual/adding-packages-kconfig.txt +++ /dev/null @@ -1,96 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for packages using kconfig for configuration files - -A popular way for a software package to handle user-specified -configuration is +kconfig+. Among others, it is used by the Linux -kernel, Busybox, and Buildroot itself. The presence of a .config file -and a +menuconfig+ target are two well-known symptoms of kconfig being -used. - -Buildroot features an infrastructure for packages that use kconfig for -their configuration. This infrastructure provides the necessary logic to -expose the package's +menuconfig+ target as +foo-menuconfig+ in -Buildroot, and to handle the copying back and forth of the configuration -file in a correct way. - -The +kconfig-package+ infrastructure is based on the +generic-package+ -infrastructure. All variables supported by +generic-package+ are -available in +kconfig-package+ as well. See -xref:generic-package-reference[] for more details. - -In order to use the +kconfig-package+ infrastructure for a Buildroot -package, the minimally required lines in the +.mk+ file, in addition to -the variables required by the +generic-package+ infrastructure, are: - ------------------------------- -FOO_KCONFIG_FILE = reference-to-source-configuration-file - -$(eval $(kconfig-package)) ------------------------------- - -This snippet creates the following make targets: - -* +foo-menuconfig+, which calls the package's +menuconfig+ target - -* +foo-update-config+, which copies the configuration back to the - source configuration file. It is not possible to use this target - when fragment files are set. - -* +foo-update-defconfig+, which copies the configuration back to the - source configuration file. The configuration file will only list the - options that differ from the default values. It is not possible to - use this target when fragment files are set. - -* +foo-diff-config+, which outputs the differences between the current - configuration and the one defined in the Buildroot configuration for - this kconfig package. The output is useful to identify the - configuration changes that may have to be propagated to - configuration fragments for example. - -and ensures that the source configuration file is copied to the build -directory at the right moment. - -There are two options to specify a configuration file to use, either -+FOO_KCONFIG_FILE+ (as in the example, above) or +FOO_KCONFIG_DEFCONFIG+. -It is mandatory to provide either, but not both: - -* +FOO_KCONFIG_FILE+ specifies the path to a defconfig or full-config file - to be used to configure the package. - -* +FOO_KCONFIG_DEFCONFIG+ specifies the defconfig 'make' rule to call to - configure the package. - -In addition to these minimally required lines, several optional variables can -be set to suit the needs of the package under consideration: - -* +FOO_KCONFIG_EDITORS+: a space-separated list of kconfig editors to - support, for example 'menuconfig xconfig'. By default, 'menuconfig'. - -* +FOO_KCONFIG_FRAGMENT_FILES+: a space-separated list of configuration - fragment files that are merged to the main configuration file. - Fragment files are typically used when there is a desire to stay in sync - with an upstream (def)config file, with some minor modifications. - -* +FOO_KCONFIG_OPTS+: extra options to pass when calling the kconfig - editors. This may need to include '$(FOO_MAKE_OPTS)', for example. By - default, empty. - -* +FOO_KCONFIG_FIXUP_CMDS+: a list of shell commands needed to fixup the - configuration file after copying it or running a kconfig editor. Such - commands may be needed to ensure a configuration consistent with other - configuration of Buildroot, for example. By default, empty. - -* +FOO_KCONFIG_DOTCONFIG+: path (with filename) of the +.config+ file, - relative to the package source tree. The default, +.config+, should - be well suited for all packages that use the standard kconfig - infrastructure as inherited from the Linux kernel; some packages use - a derivative of kconfig that use a different location. - -* +FOO_KCONFIG_DEPENDENCIES+: the list of packages (most probably, host - packages) that need to be built before this package's kconfig is - interpreted. Seldom used. By default, empty. - -* +FOO_KCONFIG_SUPPORTS_DEFCONFIG+: whether the package's kconfig system - supports using defconfig files; few packages do not. By default, 'YES'. diff --git a/docs/manual/adding-packages-kernel-module.txt b/docs/manual/adding-packages-kernel-module.txt deleted file mode 100644 index b609ecc90a..0000000000 --- a/docs/manual/adding-packages-kernel-module.txt +++ /dev/null @@ -1,143 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for packages building kernel modules - -Buildroot offers a helper infrastructure to make it easy to write packages that -build and install Linux kernel modules. Some packages only contain a kernel -module, other packages contain programs and libraries in addition to kernel -modules. Buildroot's helper infrastructure supports either case. - -[[kernel-module-tutorial]] -==== +kernel-module+ tutorial - -Let's start with an example on how to prepare a simple package that only -builds a kernel module, and no other component: - ----- -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.2.3 -08: FOO_SOURCE = foo-$(FOO_VERSION).tar.xz -09: FOO_SITE = http://www.foosoftware.org/download -10: FOO_LICENSE = GPL-2.0 -11: FOO_LICENSE_FILES = COPYING -12: -13: $(eval $(kernel-module)) -14: $(eval $(generic-package)) ----- - -Lines 7-11 define the usual meta-data to specify the version, archive name, -remote URI where to find the package source, licensing information. - -On line 13, we invoke the +kernel-module+ helper infrastructure, that -generates all the appropriate Makefile rules and variables to build -that kernel module. - -Finally, on line 14, we invoke the -xref:generic-package-tutorial[+generic-package+ infrastructure]. - -The dependency on +linux+ is automatically added, so it is not needed to -specify it in +FOO_DEPENDENCIES+. - -What you may have noticed is that, unlike other package infrastructures, -we explicitly invoke a second infrastructure. This allows a package to -build a kernel module, but also, if needed, use any one of other package -infrastructures to build normal userland components (libraries, -executables...). Using the +kernel-module+ infrastructure on its own is -not sufficient; another package infrastructure *must* be used. - -Let's look at a more complex example: - ----- -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.2.3 -08: FOO_SOURCE = foo-$(FOO_VERSION).tar.xz -09: FOO_SITE = http://www.foosoftware.org/download -10: FOO_LICENSE = GPL-2.0 -11: FOO_LICENSE_FILES = COPYING -12: -13: FOO_MODULE_SUBDIRS = driver/base -14: FOO_MODULE_MAKE_OPTS = KVERSION=$(LINUX_VERSION_PROBED) -15: -16: ifeq ($(BR2_PACKAGE_LIBBAR),y) -17: FOO_DEPENDENCIES = libbar -18: FOO_CONF_OPTS = --enable-bar -19: FOO_MODULE_SUBDIRS += driver/bar -20: else -21: FOO_CONF_OPTS = --disable-bar -22: endif -23: -24: $(eval $(kernel-module)) -26: $(eval $(autotools-package)) ----- - -Here, we see that we have an autotools-based package, that also builds -the kernel module located in sub-directory +driver/base+ and, if libbar -is enabled, the kernel module located in sub-directory +driver/bar+, and -defines the variable +KVERSION+ to be passed to the Linux buildsystem -when building the module(s). - - -[[kernel-module-reference]] -==== +kernel-module+ reference - -The main macro for the kernel module infrastructure is +kernel-module+. -Unlike other package infrastructures, it is not stand-alone, and requires -any of the other +*-package+ macros be called after it. - -The +kernel-module+ macro defines post-build and post-target-install -hooks to build the kernel modules. If the package's +.mk+ needs access -to the built kernel modules, it should do so in a post-build hook, -*registered after* the call to +kernel-module+. Similarly, if the -package's +.mk+ needs access to the kernel module after it has been -installed, it should do so in a post-install hook, *registered after* -the call to +kernel-module+. Here's an example: - ----- -$(eval $(kernel-module)) - -define FOO_DO_STUFF_WITH_KERNEL_MODULE - # Do something with it... -endef -FOO_POST_BUILD_HOOKS += FOO_DO_STUFF_WITH_KERNEL_MODULE - -$(eval $(generic-package)) ----- - -Finally, unlike the other package infrastructures, there is no -+host-kernel-module+ variant to build a host kernel module. - -The following additional variables can optionally be defined to further -configure the build of the kernel module: - -* +FOO_MODULE_SUBDIRS+ may be set to one or more sub-directories (relative - to the package source top-directory) where the kernel module sources are. - If empty or not set, the sources for the kernel module(s) are considered - to be located at the top of the package source tree. - -* +FOO_MODULE_MAKE_OPTS+ may be set to contain extra variable definitions - to pass to the Linux buildsystem. - -[[kernel-variables]] -You may also reference (but you may *not* set!) those variables: - - * +LINUX_DIR+ contains the path to where the Linux kernel has been - extracted and built. - - * +LINUX_VERSION+ contains the version string as configured by the user. - - * +LINUX_VERSION_PROBED+ contains the real version string of the kernel, - retrieved with running `make -C $(LINUX_DIR) kernelrelease` - - * +KERNEL_ARCH+ contains the name of the current architecture, like `arm`, - `mips`... diff --git a/docs/manual/adding-packages-linux-kernel-spec-infra.txt b/docs/manual/adding-packages-linux-kernel-spec-infra.txt deleted file mode 100644 index b948e208da..0000000000 --- a/docs/manual/adding-packages-linux-kernel-spec-infra.txt +++ /dev/null @@ -1,152 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[linux-kernel-specific-infra]] -=== Infrastructure specific to the Linux kernel package - -The Linux kernel package can use some specific infrastructures based on package -hooks for building Linux kernel tools or/and building Linux kernel extensions. - -[[linux-kernel-tools]] -==== linux-kernel-tools - -Buildroot offers a helper infrastructure to build some userspace tools -for the target available within the Linux kernel sources. Since their -source code is part of the kernel source code, a special package, -+linux-tools+, exists and re-uses the sources of the Linux kernel that -runs on the target. - -Let's look at an example of a Linux tool. For a new Linux tool named -+foo+, create a new menu entry in the existing -+package/linux-tools/Config.in+. This file will contain the option -descriptions related to each kernel tool that will be used and -displayed in the configuration tool. It would basically look like: - ------------------------------- -01: config BR2_PACKAGE_LINUX_TOOLS_FOO -02: bool "foo" -03: select BR2_PACKAGE_LINUX_TOOLS -04: help -05: This is a comment that explains what foo kernel tool is. -06: -07: http://foosoftware.org/foo/ ------------------------------- - -The name of the option starts with the prefix +BR2_PACKAGE_LINUX_TOOLS_+, -followed by the uppercase name of the tool (like is done for packages). - -.Note -Unlike other packages, the +linux-tools+ package options appear in the -+linux+ kernel menu, under the `Linux Kernel Tools` sub-menu, not under -the `Target packages` main menu. - -Then for each linux tool, add a new +.mk.in+ file named -+package/linux-tools/linux-tool-foo.mk.in+. It would basically look like: - ------------------------------- -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: LINUX_TOOLS += foo -08: -09: FOO_DEPENDENCIES = libbbb -10: -11: define FOO_BUILD_CMDS -12: $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools foo -13: endef -14: -15: define FOO_INSTALL_STAGING_CMDS -16: $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools \ -17: DESTDIR=$(STAGING_DIR) \ -18: foo_install -19: endef -20: -21: define FOO_INSTALL_TARGET_CMDS -22: $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools \ -23: DESTDIR=$(TARGET_DIR) \ -24: foo_install -25: endef --------------------------------- - -On line 7, we register the Linux tool +foo+ to the list of available -Linux tools. - -On line 9, we specify the list of dependencies this tool relies on. These -dependencies are added to the Linux package dependencies list only when the -+foo+ tool is selected. - -The rest of the Makefile, lines 11-25 defines what should be done at the -different steps of the Linux tool build process like for a -xref:generic-package-tutorial[+generic package+]. They will actually be -used only when the +foo+ tool is selected. The only supported commands are -+_BUILD_CMDS+, +_INSTALL_STAGING_CMDS+ and +_INSTALL_TARGET_CMDS+. - -.Note -One *must not* call +$(eval $(generic-package))+ or any other -package infrastructure! Linux tools are not packages by themselves, -they are part of the +linux-tools+ package. - -[[linux-kernel-ext]] -==== linux-kernel-extensions - -Some packages provide new features that require the Linux kernel tree -to be modified. This can be in the form of patches to be applied on -the kernel tree, or in the form of new files to be added to the -tree. The Buildroot's Linux kernel extensions infrastructure provides -a simple solution to automatically do this, just after the kernel -sources are extracted and before the kernel patches are -applied. Examples of extensions packaged using this mechanism are the -real-time extensions Xenomai and RTAI, as well as the set of -out-of-tree LCD screens drivers +fbtft+. - -Let's look at an example on how to add a new Linux extension +foo+. - -First, create the package +foo+ that provides the extension: this -package is a standard package; see the previous chapters on how to -create such a package. This package is in charge of downloading the -sources archive, checking the hash, defining the licence informations -and building user space tools if any. - -Then create the 'Linux extension' proper: create a new menu entry in -the existing +linux/Config.ext.in+. This file contains the option -descriptions related to each kernel extension that will be used and -displayed in the configuration tool. It would basically look like: - ------------------------------- -01: config BR2_LINUX_KERNEL_EXT_FOO -02: bool "foo" -03: help -04: This is a comment that explains what foo kernel extension is. -05: -06: http://foosoftware.org/foo/ ------------------------------- - -Then for each linux extension, add a new +.mk+ file named -+linux/linux-ext-foo.mk+. It should basically contain: - ------------------------------- -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: LINUX_EXTENSIONS += foo -08: -09: define FOO_PREPARE_KERNEL -10: $(FOO_DIR)/prepare-kernel-tree.sh --linux-dir=$(@D) -11: endef --------------------------------- - -On line 7, we add the Linux extension +foo+ to the list of available -Linux extensions. - -On line 9-11, we define what should be done by the extension to modify -the Linux kernel tree; this is specific to the linux extension and can -use the variables defined by the +foo+ package, like: +$(FOO_DIR)+ or -+$(FOO_VERSION)+... as well as all the Linux variables, like: -+$(LINUX_VERSION)+ or +$(LINUX_VERSION_PROBED)+, +$(KERNEL_ARCH)+... -See the xref:kernel-variables[definition of those kernel variables]. diff --git a/docs/manual/adding-packages-luarocks.txt b/docs/manual/adding-packages-luarocks.txt deleted file mode 100644 index 70f48fc02c..0000000000 --- a/docs/manual/adding-packages-luarocks.txt +++ /dev/null @@ -1,109 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for LuaRocks-based packages - -[[luarocks-package-tutorial]] - -==== +luarocks-package+ tutorial - -First, let's see how to write a +.mk+ file for a LuaRocks-based package, -with an example : - ------------------------- -01: ################################################################################ -02: # -03: # lua-foo -04: # -05: ################################################################################ -06: -07: LUA_FOO_VERSION = 1.0.2-1 -08: LUA_FOO_NAME_UPSTREAM = foo -09: LUA_FOO_DEPENDENCIES = bar -10: -11: LUA_FOO_BUILD_OPTS += BAR_INCDIR=$(STAGING_DIR)/usr/include -12: LUA_FOO_BUILD_OPTS += BAR_LIBDIR=$(STAGING_DIR)/usr/lib -13: LUA_FOO_LICENSE = luaFoo license -14: LUA_FOO_LICENSE_FILES = $(LUA_FOO_SUBDIR)/COPYING -15: -16: $(eval $(luarocks-package)) ------------------------- - -On line 7, we declare the version of the package (the same as in the rockspec, -which is the concatenation of the upstream version and the rockspec revision, -separated by a hyphen '-'). - -On line 8, we declare that the package is called "foo" on LuaRocks. In -Buildroot, we give Lua-related packages a name that starts with "lua", so the -Buildroot name is different from the upstream name. +LUA_FOO_NAME_UPSTREAM+ -makes the link between the two names. - -On line 9, we declare our dependencies against native libraries, so that they -are built before the build process of our package starts. - -On lines 11-12, we tell Buildroot to pass custom options to LuaRocks when it is -building the package. - -On lines 13-14, we specify the licensing terms for the package. - -Finally, on line 16, we invoke the +luarocks-package+ -macro that generates all the Makefile rules that actually allows the -package to be built. - -Most of these details can be retrieved from the +rock+ and +rockspec+. -So, this file and the Config.in file can be generated by running the -command +luarocks buildroot foo lua-foo+ in the Buildroot -directory. This command runs a specific Buildroot addon of +luarocks+ -that will automatically generate a Buildroot package. The result must -still be manually inspected and possibly modified. - -* The +package/Config.in+ file has to be updated manually to include the - generated Config.in files. - -[[luarocks-package-reference]] - -==== +luarocks-package+ reference - -LuaRocks is a deployment and management system for Lua modules, and supports -various +build.type+: +builtin+, +make+ and +cmake+. In the context of -Buildroot, the +luarocks-package+ infrastructure only supports the +builtin+ -mode. LuaRocks packages that use the +make+ or +cmake+ build mechanisms -should instead be packaged using the +generic-package+ and +cmake-package+ -infrastructures in Buildroot, respectively. - -The main macro of the LuaRocks package infrastructure is +luarocks-package+: -like +generic-package+ it works by defining a number of variables providing -metadata information about the package, and then calling +luarocks-package+. - -Just like the generic infrastructure, the LuaRocks infrastructure works -by defining a number of variables before calling the +luarocks-package+ -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the LuaRocks infrastructure: -+LUA_FOO_VERSION+, +LUA_FOO_SOURCE+, +LUA_FOO_SITE+, -+LUA_FOO_DEPENDENCIES+, +LUA_FOO_LICENSE+, +LUA_FOO_LICENSE_FILES+. - -Two of them are populated by the LuaRocks infrastructure (for the -+download+ step). If your package is not hosted on the LuaRocks mirror -+$(BR2_LUAROCKS_MIRROR)+, you can override them: - -* +LUA_FOO_SITE+, which defaults to +$(BR2_LUAROCKS_MIRROR)+ - -* +LUA_FOO_SOURCE+, which defaults to - +$(lowercase LUA_FOO_NAME_UPSTREAM)-$(LUA_FOO_VERSION).src.rock+ - -A few additional variables, specific to the LuaRocks infrastructure, are -also defined. They can be overridden in specific cases. - -* +LUA_FOO_NAME_UPSTREAM+, which defaults to +lua-foo+, i.e. the Buildroot - package name - -* +LUA_FOO_ROCKSPEC+, which defaults to - +$(lowercase LUA_FOO_NAME_UPSTREAM)-$(LUA_FOO_VERSION).rockspec+ - -* +LUA_FOO_SUBDIR+, which defaults to - +$(LUA_FOO_NAME_UPSTREAM)-$(LUA_FOO_VERSION_WITHOUT_ROCKSPEC_REVISION)+ - -* +LUA_FOO_BUILD_OPTS+ contains additional build options for the - +luarocks build+ call. diff --git a/docs/manual/adding-packages-meson.txt b/docs/manual/adding-packages-meson.txt deleted file mode 100644 index 029c8c2488..0000000000 --- a/docs/manual/adding-packages-meson.txt +++ /dev/null @@ -1,133 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for Meson-based packages - -[[meson-package-tutorial]] - -==== +meson-package+ tutorial - -http://mesonbuild.com[Meson] is an open source build system meant to be both -extremely fast, and, even more importantly, as user friendly as possible. It -uses https://ninja-build.org[Ninja] as a companion tool to perform the actual -build operations. - -Let's see how to write a +.mk+ file for a Meson-based package, with an example: - ------------------------------- -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.0 -08: FOO_SOURCE = foo-$(FOO_VERSION).tar.gz -09: FOO_SITE = http://www.foosoftware.org/download -10: FOO_LICENSE = GPL-3.0+ -11: FOO_LICENSE_FILES = COPYING -12: FOO_INSTALL_STAGING = YES -13: -14: FOO_DEPENDENCIES = host-pkgconf bar -15: -16: ifeq ($(BR2_PACKAGE_BAZ),y) -17: FOO_CONF_OPTS += -Dbaz=true -18: FOO_DEPENDENCIES += baz -19: else -20: FOO_CONF_OPTS += -Dbaz=false -21: endif -22: -23: $(eval $(meson-package)) --------------------------------- - -The Makefile starts with the definition of the standard variables for package -declaration (lines 7 to 11). - -On line line 23, we invoke the +meson-package+ macro that generates all the -Makefile rules that actually allows the package to be built. - -In the example, +host-pkgconf+ and +bar+ are declared as dependencies in -+FOO_DEPENDENCIES+ at line 14 because the Meson build file of +foo+ uses -`pkg-config` to determine the compilation flags and libraries of package +bar+. - -Note that it is not necessary to add +host-meson+ in the +FOO_DEPENDENCIES+ -variable of a package, since this basic dependency is automatically added as -needed by the Meson package infrastructure. - -If the "baz" package is selected, then support for the "baz" feature in "foo" is -activated by adding +-Dbaz=true+ to +FOO_CONF_OPTS+ at line 17, as specified in -the +meson_options.txt+ file in "foo" source tree. The "baz" package is also -added to +FOO_DEPENDENCIES+. Note that the support for +baz+ is explicitly -disabled at line 20, if the package is not selected. - -To sum it up, to add a new meson-based package, the Makefile example can be -copied verbatim then edited to replace all occurences of +FOO+ with the -uppercase name of the new package and update the values of the standard -variables. - -[[meson-package-reference]] - -==== +meson-package+ reference - -The main macro of the Meson package infrastructure is +meson-package+. It is -similar to the +generic-package+ macro. The ability to have target and host -packages is also available, with the +host-meson-package+ macro. - -Just like the generic infrastructure, the Meson infrastructure works by defining -a number of variables before calling the +meson-package+ macro. - -First, all the package metadata information variables that exist in the generic -infrastructure also exist in the Meson infrastructure: +FOO_VERSION+, -+FOO_SOURCE+, +FOO_PATCH+, +FOO_SITE+, +FOO_SUBDIR+, +FOO_DEPENDENCIES+, -+FOO_INSTALL_STAGING+, +FOO_INSTALL_TARGET+. - -A few additional variables, specific to the Meson infrastructure, can also be -defined. Many of them are only useful in very specific cases, typical packages -will therefore only use a few of them. - -* +FOO_SUBDIR+ may contain the name of a subdirectory inside the - package that contains the main meson.build file. This is useful, - if for example, the main meson.build file is not at the root of - the tree extracted by the tarball. If +HOST_FOO_SUBDIR+ is not - specified, it defaults to +FOO_SUBDIR+. - -* +FOO_CONF_ENV+, to specify additional environment variables to pass to - +meson+ for the configuration step. By default, empty. - -* +FOO_CONF_OPTS+, to specify additional options to pass to +meson+ for the - configuration step. By default, empty. - -* +FOO_CFLAGS+, to specify compiler arguments added to the package specific - +cross-compile.conf+ file +c_args+ property. By default, the value of - +TARGET_CFLAGS+. - -* +FOO_CXXFLAGS+, to specify compiler arguments added to the package specific - +cross-compile.conf+ file +cpp_args+ property. By default, the value of - +TARGET_CXXFLAGS+. - -* +FOO_LDFLAGS+, to specify compiler arguments added to the package specific - +cross-compile.conf+ file +c_link_args+ and +cpp_link_args+ properties. By - default, the value of +TARGET_LDFLAGS+. - -* +FOO_MESON_EXTRA_BINARIES+, to specify a space-separated list of programs - to add to the `[binaries]` section of the meson `cross-compilation.conf` - configuration file. The format is `program-name='/path/to/program'`, with - no space around the +=+ sign, and with the path of the program between - single quotes. By default, empty. Note that Buildroot already sets the - correct values for +c+, +cpp+, +ar+, +strip+, and +pkgconfig+. - -* +FOO_MESON_EXTRA_PROPERTIES+, to specify a space-separated list of - properties to add to the `[properties]` section of the meson - `cross-compilation.conf` configuration file. The format is - `property-name=` with no space around the +=+ sign, and with - single quotes around string values. By default, empty. Note that - Buildroot already sets values for +needs_exe_wrapper+, +c_args+, - +c_link_args+, +cpp_args+, +cpp_link_args+, +sys_root+, and - +pkg_config_libdir+. - -* +FOO_NINJA_ENV+, to specify additional environment variables to pass to - +ninja+, meson companion tool in charge of the build operations. By default, - empty. - -* +FOO_NINJA_OPTS+, to specify a space-separated list of targets to build. By - default, empty, to build the default target(s). diff --git a/docs/manual/adding-packages-perl.txt b/docs/manual/adding-packages-perl.txt deleted file mode 100644 index 6ce693fd6e..0000000000 --- a/docs/manual/adding-packages-perl.txt +++ /dev/null @@ -1,129 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for Perl/CPAN packages - -[[perl-package-tutorial]] - -==== +perl-package+ tutorial - -First, let's see how to write a +.mk+ file for a Perl/CPAN package, -with an example : - ------------------------- -01: ################################################################################ -02: # -03: # perl-foo-bar -04: # -05: ################################################################################ -06: -07: PERL_FOO_BAR_VERSION = 0.02 -08: PERL_FOO_BAR_SOURCE = Foo-Bar-$(PERL_FOO_BAR_VERSION).tar.gz -09: PERL_FOO_BAR_SITE = $(BR2_CPAN_MIRROR)/authors/id/M/MO/MONGER -10: PERL_FOO_BAR_DEPENDENCIES = perl-strictures -11: PERL_FOO_BAR_LICENSE = Artistic or GPL-1.0+ -12: PERL_FOO_BAR_LICENSE_FILES = LICENSE -13: PERL_FOO_BAR_DISTNAME = Foo-Bar -14: -15: $(eval $(perl-package)) ------------------------- - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball and the location -of the tarball on a CPAN server. Buildroot will automatically download -the tarball from this location. - -On line 10, we declare our dependencies, so that they are built -before the build process of our package starts. - -On line 11 and 12, we give licensing details about the package (its -license on line 11, and the file containing the license text on line -12). - -On line 13, the name of the distribution as needed by the script -+utils/scancpan+ (in order to regenerate/upgrade these package files). - -Finally, on line 15, we invoke the +perl-package+ macro that -generates all the Makefile rules that actually allow the package to be -built. - -Most of these data can be retrieved from https://metacpan.org/. -So, this file and the Config.in can be generated by running -the script +utils/scancpan Foo-Bar+ in the Buildroot directory -(or in a br2-external tree). -This script creates a Config.in file and foo-bar.mk file for the -requested package, and also recursively for all dependencies specified by -CPAN. You should still manually edit the result. In particular, the -following things should be checked. - -* If the perl module links with a shared library that is provided by - another (non-perl) package, this dependency is not added automatically. - It has to be added manually to +PERL_FOO_BAR_DEPENDENCIES+. -* The +package/Config.in+ file has to be updated manually to include the - generated Config.in files. As a hint, the +scancpan+ script prints out - the required +source "..."+ statements, sorted alphabetically. - -[[perl-package-reference]] - -==== +perl-package+ reference - -As a policy, packages that provide Perl/CPAN modules should all be -named +perl-+ in Buildroot. - -This infrastructure handles various Perl build systems : -+ExtUtils-MakeMaker+ (EUMM), +Module-Build+ (MB) and +Module-Build-Tiny+. -+Build.PL+ is preferred by default when a package provides a +Makefile.PL+ -and a +Build.PL+. - -The main macro of the Perl/CPAN package infrastructure is -+perl-package+. It is similar to the +generic-package+ macro. The ability to -have target and host packages is also available, with the -+host-perl-package+ macro. - -Just like the generic infrastructure, the Perl/CPAN infrastructure -works by defining a number of variables before calling the -+perl-package+ macro. - -First, all the package metadata information variables that exist in the -generic infrastructure also exist in the Perl/CPAN infrastructure: -+PERL_FOO_VERSION+, +PERL_FOO_SOURCE+, -+PERL_FOO_PATCH+, +PERL_FOO_SITE+, -+PERL_FOO_SUBDIR+, +PERL_FOO_DEPENDENCIES+, -+PERL_FOO_INSTALL_TARGET+. - -Note that setting +PERL_FOO_INSTALL_STAGING+ to +YES+ has no effect -unless a +PERL_FOO_INSTALL_STAGING_CMDS+ variable is defined. The perl -infrastructure doesn't define these commands since Perl modules generally -don't need to be installed to the +staging+ directory. - -A few additional variables, specific to the Perl/CPAN infrastructure, -can also be defined. Many of them are only useful in very specific -cases, typical packages will therefore only use a few of them. - -* +PERL_FOO_PREFER_INSTALLER+/+HOST_PERL_FOO_PREFER_INSTALLER+, - specifies the preferred installation method. Possible values are - +EUMM+ (for +Makefile.PL+ based installation using - +ExtUtils-MakeMaker+) and +MB+ (for +Build.PL+ based installation - using +Module-Build+). This variable is only used when the package - provides both installation methods. - -* +PERL_FOO_CONF_ENV+/+HOST_PERL_FOO_CONF_ENV+, to specify additional - environment variables to pass to the +perl Makefile.PL+ or +perl Build.PL+. - By default, empty. - -* +PERL_FOO_CONF_OPTS+/+HOST_PERL_FOO_CONF_OPTS+, to specify additional - configure options to pass to the +perl Makefile.PL+ or +perl Build.PL+. - By default, empty. - -* +PERL_FOO_BUILD_OPTS+/+HOST_PERL_FOO_BUILD_OPTS+, to specify additional - options to pass to +make pure_all+ or +perl Build build+ in the build step. - By default, empty. - -* +PERL_FOO_INSTALL_TARGET_OPTS+, to specify additional options to - pass to +make pure_install+ or +perl Build install+ in the install step. - By default, empty. - -* +HOST_PERL_FOO_INSTALL_OPTS+, to specify additional options to - pass to +make pure_install+ or +perl Build install+ in the install step. - By default, empty. diff --git a/docs/manual/adding-packages-python.txt b/docs/manual/adding-packages-python.txt deleted file mode 100644 index 0c100859be..0000000000 --- a/docs/manual/adding-packages-python.txt +++ /dev/null @@ -1,260 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for Python packages - -This infrastructure applies to Python packages that use the standard -Python setuptools mechanism as their build system, generally -recognizable by the usage of a +setup.py+ script. - -[[python-package-tutorial]] - -==== +python-package+ tutorial - -First, let's see how to write a +.mk+ file for a Python package, -with an example : - ------------------------- -01: ################################################################################ -02: # -03: # python-foo -04: # -05: ################################################################################ -06: -07: PYTHON_FOO_VERSION = 1.0 -08: PYTHON_FOO_SOURCE = python-foo-$(PYTHON_FOO_VERSION).tar.xz -09: PYTHON_FOO_SITE = http://www.foosoftware.org/download -10: PYTHON_FOO_LICENSE = BSD-3-Clause -11: PYTHON_FOO_LICENSE_FILES = LICENSE -12: PYTHON_FOO_ENV = SOME_VAR=1 -13: PYTHON_FOO_DEPENDENCIES = libmad -14: PYTHON_FOO_SETUP_TYPE = distutils -15: -16: $(eval $(python-package)) ------------------------- - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10 and 11, we give licensing details about the package (its -license on line 10, and the file containing the license text on line -11). - -On line 12, we tell Buildroot to pass custom options to the Python -+setup.py+ script when it is configuring the package. - -On line 13, we declare our dependencies, so that they are built -before the build process of our package starts. - -On line 14, we declare the specific Python build system being used. In -this case the +distutils+ Python build system is used. The two -supported ones are +distutils+ and +setuptools+. - -Finally, on line 16, we invoke the +python-package+ macro that -generates all the Makefile rules that actually allow the package to be -built. - -[[python-package-reference]] - -==== +python-package+ reference - -As a policy, packages that merely provide Python modules should all be -named +python-+ in Buildroot. Other packages that use the -Python build system, but are not Python modules, can freely choose -their name (existing examples in Buildroot are +scons+ and -+supervisor+). - -Packages that are only compatible with one version of Python (as in: -Python 2 or Python 3) should depend on that version explicitely in -their +Config.in+ file (+BR2_PACKAGE_PYTHON+ for Python 2, -+BR2_PACKAGE_PYTHON3+ for Python 3). Packages that are compatible -with both versions should not explicitely depend on them in their -+Config.in+ file, since that condition is already expressed for the -whole "External python modules" menu. - -The main macro of the Python package infrastructure is -+python-package+. It is similar to the +generic-package+ macro. It is -also possible to create Python host packages with the -+host-python-package+ macro. - -Just like the generic infrastructure, the Python infrastructure works -by defining a number of variables before calling the +python-package+ -or +host-python-package+ macros. - -All the package metadata information variables that exist in the -xref:generic-package-reference[generic package infrastructure] also -exist in the Python infrastructure: +PYTHON_FOO_VERSION+, -+PYTHON_FOO_SOURCE+, +PYTHON_FOO_PATCH+, +PYTHON_FOO_SITE+, -+PYTHON_FOO_SUBDIR+, +PYTHON_FOO_DEPENDENCIES+, +PYTHON_FOO_LICENSE+, -+PYTHON_FOO_LICENSE_FILES+, +PYTHON_FOO_INSTALL_STAGING+, etc. - -Note that: - - * It is not necessary to add +python+ or +host-python+ in the - +PYTHON_FOO_DEPENDENCIES+ variable of a package, since these basic - dependencies are automatically added as needed by the Python - package infrastructure. - - * Similarly, it is not needed to add +host-setuptools+ to - +PYTHON_FOO_DEPENDENCIES+ for setuptools-based packages, since it's - automatically added by the Python infrastructure as needed. - -One variable specific to the Python infrastructure is mandatory: - -* +PYTHON_FOO_SETUP_TYPE+, to define which Python build system is used - by the package. The two supported values are +distutils+ and - +setuptools+. If you don't know which one is used in your package, - look at the +setup.py+ file in your package source code, and see - whether it imports things from the +distutils+ module or the - +setuptools+ module. - -A few additional variables, specific to the Python infrastructure, can -optionally be defined, depending on the package's needs. Many of them -are only useful in very specific cases, typical packages will -therefore only use a few of them, or none. - -* +PYTHON_FOO_SUBDIR+ may contain the name of a subdirectory inside the - package that contains the main +setup.py+ file. This is useful, - if for example, the main +setup.py+ file is not at the root of - the tree extracted by the tarball. If +HOST_PYTHON_FOO_SUBDIR+ is not - specified, it defaults to +PYTHON_FOO_SUBDIR+. - -* +PYTHON_FOO_ENV+, to specify additional environment variables to - pass to the Python +setup.py+ script (for both the build and install - steps). Note that the infrastructure is automatically passing - several standard variables, defined in +PKG_PYTHON_DISTUTILS_ENV+ - (for distutils target packages), +HOST_PKG_PYTHON_DISTUTILS_ENV+ - (for distutils host packages), +PKG_PYTHON_SETUPTOOLS_ENV+ (for - setuptools target packages) and +HOST_PKG_PYTHON_SETUPTOOLS_ENV+ - (for setuptools host packages). - -* +PYTHON_FOO_BUILD_OPTS+, to specify additional options to pass to the - Python +setup.py+ script during the build step. For target distutils - packages, the +PKG_PYTHON_DISTUTILS_BUILD_OPTS+ options are already - passed automatically by the infrastructure. - -* +PYTHON_FOO_INSTALL_TARGET_OPTS+, +PYTHON_FOO_INSTALL_STAGING_OPTS+, - +HOST_PYTHON_FOO_INSTALL_OPTS+ to specify additional options to pass - to the Python +setup.py+ script during the target installation step, - the staging installation step or the host installation, - respectively. Note that the infrastructure is automatically passing - some options, defined in +PKG_PYTHON_DISTUTILS_INSTALL_TARGET_OPTS+ - or +PKG_PYTHON_DISTUTILS_INSTALL_STAGING_OPTS+ (for target distutils - packages), +HOST_PKG_PYTHON_DISTUTILS_INSTALL_OPTS+ (for host - distutils packages), +PKG_PYTHON_SETUPTOOLS_INSTALL_TARGET_OPTS+ or - +PKG_PYTHON_SETUPTOOLS_INSTALL_STAGING_OPTS+ (for target setuptools - packages) and +HOST_PKG_PYTHON_SETUPTOOLS_INSTALL_OPTS+ (for host - setuptools packages). - -* +HOST_PYTHON_FOO_NEEDS_HOST_PYTHON+, to define the host python - interpreter. The usage of this variable is limited to host - packages. The two supported value are +python2+ and +python3+. It - will ensure the right host python package is available and will - invoke it for the build. If some build steps are overloaded, the - right python interpreter must be explicitly called in the commands. - -With the Python infrastructure, all the steps required to build and -install the packages are already defined, and they generally work well -for most Python-based packages. However, when required, it is still -possible to customize what is done in any particular step: - -* By adding a post-operation hook (after extract, patch, configure, - build or install). See xref:hooks[] for details. - -* By overriding one of the steps. For example, even if the Python - infrastructure is used, if the package +.mk+ file defines its own - +PYTHON_FOO_BUILD_CMDS+ variable, it will be used instead of the - default Python one. However, using this method should be restricted - to very specific cases. Do not use it in the general case. - -[[scanpypi]] - -==== Generating a +python-package+ from a PyPI repository - -If the Python package for which you would like to create a Buildroot -package is available on PyPI, you may want to use the +scanpypi+ tool -located in +utils/+ to automate the process. - -You can find the list of existing PyPI packages -https://pypi.python.org[here]. - -+scanpypi+ requires Python's +setuptools+ package to be installed on -your host. - -When at the root of your buildroot directory just do : - ------------------------ -utils/scanpypi foo bar -o package ------------------------ - -This will generate packages +python-foo+ and +python-bar+ in the package -folder if they exist on https://pypi.python.org. - -Find the +external python modules+ menu and insert your package inside. -Keep in mind that the items inside a menu should be in alphabetical order. - -Please keep in mind that you'll most likely have to manually check the -package for any mistakes as there are things that cannot be guessed by -the generator (e.g. dependencies on any of the python core modules -such as BR2_PACKAGE_PYTHON_ZLIB). Also, please take note that the -license and license files are guessed and must be checked. You also -need to manually add the package to the +package/Config.in+ file. - -If your Buildroot package is not in the official Buildroot tree but in -a br2-external tree, use the -o flag as follows: - ------------------------ -utils/scanpypi foo bar -o other_package_dir ------------------------ - -This will generate packages +python-foo+ and +python-bar+ in the -+other_package_directory+ instead of +package+. - -Option +-h+ will list the available options: - ------------------------ -utils/scanpypi -h ------------------------ - -[[python-package-cffi-backend]] - -==== +python-package+ CFFI backend - -C Foreign Function Interface for Python (CFFI) provides a convenient -and reliable way to call compiled C code from Python using interface -declarations written in C. Python packages relying on this backend can -be identified by the appearance of a +cffi+ dependency in the -+install_requires+ field of their +setup.py+ file. - -Such a package should: - - * add +python-cffi+ as a runtime dependency in order to install the -compiled C library wrapper on the target. This is achieved by adding -+select BR2_PACKAGE_PYTHON_CFFI+ to the package +Config.in+. - ------------------------- -config BR2_PACKAGE_PYTHON_FOO - bool "python-foo" - select BR2_PACKAGE_PYTHON_CFFI # runtime ------------------------- - - * add +host-python-cffi+ as a build-time dependency in order to -cross-compile the C wrapper. This is achieved by adding -+host-python-cffi+ to the +PYTHON_FOO_DEPENDENCIES+ variable. - ------------------------- -################################################################################ -# -# python-foo -# -################################################################################ - -... - -PYTHON_FOO_DEPENDENCIES = host-python-cffi - -$(eval $(python-package)) ------------------------- diff --git a/docs/manual/adding-packages-qmake.txt b/docs/manual/adding-packages-qmake.txt deleted file mode 100644 index 699d082aa1..0000000000 --- a/docs/manual/adding-packages-qmake.txt +++ /dev/null @@ -1,85 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for QMake-based packages - -[[qmake-package-tutorial]] - -==== +qmake-package+ tutorial - -First, let's see how to write a +.mk+ file for a QMake-based package, with -an example : - ------------------------- -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_CONF_OPTS = QT_CONFIG+=bar QT_CONFIG-=baz -11: LIBFOO_DEPENDENCIES = bar -12: -13: $(eval $(qmake-package)) ------------------------- - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10, we tell Buildroot what options to enable for libfoo. - -On line 11, we tell Buildroot the dependencies of libfoo. - -Finally, on line line 13, we invoke the +qmake-package+ -macro that generates all the Makefile rules that actually allows the -package to be built. - -[[qmake-package-reference]] - -==== +qmake-package+ reference - -The main macro of the QMake package infrastructure is +qmake-package+. -It is similar to the +generic-package+ macro. - -Just like the generic infrastructure, the QMake infrastructure works -by defining a number of variables before calling the +qmake-package+ -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the QMake infrastructure: -+LIBFOO_VERSION+, +LIBFOO_SOURCE+, +LIBFOO_PATCH+, +LIBFOO_SITE+, -+LIBFOO_SUBDIR+, +LIBFOO_DEPENDENCIES+, +LIBFOO_INSTALL_STAGING+, -+LIBFOO_INSTALL_TARGET+. - -An additional variable, specific to the QMake infrastructure, can -also be defined. - -* +LIBFOO_CONF_ENV+, to specify additional environment variables to - pass to the +qmake+ script for the configuration step. By default, empty. - -* +LIBFOO_CONF_OPTS+, to specify additional options to pass to the - +qmake+ script for the configuration step. By default, empty. - -* +LIBFOO_MAKE_ENV+, to specify additional environment variables to the - +make+ command during the build and install steps. By default, empty. - -* +LIBFOO_MAKE_OPTS+, to specify additional targets to pass to the - +make+ command during the build step. By default, empty. - -* +LIBFOO_INSTALL_STAGING_OPTS+, to specify additional targets to pass - to the +make+ command during the staging installation step. By default, - +install+. - -* +LIBFOO_INSTALL_TARGET_OPTS+, to specify additional targets to pass - to the +make+ command during the target installation step. By default, - +install+. - -* +LIBFOO_SYNC_QT_HEADERS+, to run syncqt.pl before qmake. Some packages - need this to have a properly populated include directory before - running the build. diff --git a/docs/manual/adding-packages-rebar.txt b/docs/manual/adding-packages-rebar.txt deleted file mode 100644 index d78b3171d8..0000000000 --- a/docs/manual/adding-packages-rebar.txt +++ /dev/null @@ -1,108 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for rebar-based packages - -[[rebar-package-tutorial]] - -==== +rebar-package+ tutorial - -First, let's see how to write a +.mk+ file for a rebar-based package, -with an example : - ------------------------------- -01: ################################################################################ -02: # -03: # erlang-foobar -04: # -05: ################################################################################ -06: -07: ERLANG_FOOBAR_VERSION = 1.0 -08: ERLANG_FOOBAR_SOURCE = erlang-foobar-$(ERLANG_FOOBAR_VERSION).tar.xz -09: ERLANG_FOOBAR_SITE = http://www.foosoftware.org/download -10: ERLANG_FOOBAR_DEPENDENCIES = host-libaaa libbbb -11: -12: $(eval $(rebar-package)) --------------------------------- - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10, we declare our dependencies, so that they are built -before the build process of our package starts. - -Finally, on line 12, we invoke the +rebar-package+ macro that -generates all the Makefile rules that actually allows the package to -be built. - -[[rebar-package-reference]] - -==== +rebar-package+ reference - -The main macro of the +rebar+ package infrastructure is -+rebar-package+. It is similar to the +generic-package+ macro. The -ability to have host packages is also available, with the -+host-rebar-package+ macro. - -Just like the generic infrastructure, the +rebar+ infrastructure works -by defining a number of variables before calling the +rebar-package+ -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the +rebar+ infrastructure: -+ERLANG_FOOBAR_VERSION+, +ERLANG_FOOBAR_SOURCE+, -+ERLANG_FOOBAR_PATCH+, +ERLANG_FOOBAR_SITE+, -+ERLANG_FOOBAR_SUBDIR+, +ERLANG_FOOBAR_DEPENDENCIES+, -+ERLANG_FOOBAR_INSTALL_STAGING+, +ERLANG_FOOBAR_INSTALL_TARGET+, -+ERLANG_FOOBAR_LICENSE+ and +ERLANG_FOOBAR_LICENSE_FILES+. - -A few additional variables, specific to the +rebar+ infrastructure, -can also be defined. Many of them are only useful in very specific -cases, typical packages will therefore only use a few of them. - -* +ERLANG_FOOBAR_USE_AUTOCONF+, to specify that the package uses - _autoconf_ at the configuration step. When a package sets this - variable to +YES+, the +autotools+ infrastructure is used. -+ -.Note -You can also use some of the variables from the +autotools+ - infrastructure: +ERLANG_FOOBAR_CONF_ENV+, +ERLANG_FOOBAR_CONF_OPTS+, - +ERLANG_FOOBAR_AUTORECONF+, +ERLANG_FOOBAR_AUTORECONF_ENV+ and - +ERLANG_FOOBAR_AUTORECONF_OPTS+. - -* +ERLANG_FOOBAR_USE_BUNDLED_REBAR+, to specify that the package has - a bundled version of _rebar_ *and* that it shall be used. Valid - values are +YES+ or +NO+ (the default). -+ -.Note -If the package bundles a _rebar_ utility, but can use the generic - one that Buildroot provides, just say +NO+ (i.e., do not specify - this variable). Only set if it is mandatory to use the _rebar_ - utility bundled in this package. - -* +ERLANG_FOOBAR_REBAR_ENV+, to specify additional environment - variables to pass to the _rebar_ utility. - -* +ERLANG_FOOBAR_KEEP_DEPENDENCIES+, to keep the dependencies - described in the rebar.config file. Valid values are +YES+ or +NO+ - (the default). Unless this variable is set to +YES+, the _rebar_ - infrastructure removes such dependencies in a post-patch hook to - ensure rebar does not download nor compile them. - -With the rebar infrastructure, all the steps required to build -and install the packages are already defined, and they generally work -well for most rebar-based packages. However, when required, it is -still possible to customize what is done in any particular step: - -* By adding a post-operation hook (after extract, patch, configure, - build or install). See xref:hooks[] for details. - -* By overriding one of the steps. For example, even if the rebar - infrastructure is used, if the package +.mk+ file defines its - own +ERLANG_FOOBAR_BUILD_CMDS+ variable, it will be used instead - of the default rebar one. However, using this method should be - restricted to very specific cases. Do not use it in the general - case. diff --git a/docs/manual/adding-packages-tips.txt b/docs/manual/adding-packages-tips.txt deleted file mode 100644 index d8c2eceb10..0000000000 --- a/docs/manual/adding-packages-tips.txt +++ /dev/null @@ -1,242 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Tips and tricks - -[[package-name-variable-relation]] -==== Package name, config entry name and makefile variable relationship - -In Buildroot, there is some relationship between: - -* the _package name_, which is the package directory name (and the - name of the +*.mk+ file); - -* the config entry name that is declared in the +Config.in+ file; - -* the makefile variable prefix. - -It is mandatory to maintain consistency between these elements, -using the following rules: - -* the package directory and the +*.mk+ name are the _package name_ - itself (e.g.: +package/foo-bar_boo/foo-bar_boo.mk+); - -* the _make_ target name is the _package name_ itself (e.g.: - +foo-bar_boo+); - -* the config entry is the upper case _package name_ with `.` and `-` - characters substituted with `_`, prefixed with +BR2_PACKAGE_+ (e.g.: - +BR2_PACKAGE_FOO_BAR_BOO+); - -* the +*.mk+ file variable prefix is the upper case _package name_ - with `.` and `-` characters substituted with `_` (e.g.: - +FOO_BAR_BOO_VERSION+). - -[[check-package]] -==== How to check the coding style - -Buildroot provides a script in +utils/check-package+ that checks new or -changed files for coding style. It is not a complete language validator, -but it catches many common mistakes. It is meant to run in the actual -files you created or modified, before creating the patch for submission. - -This script can be used for packages, filesystem makefiles, Config.in -files, etc. It does not check the files defining the package -infrastructures and some other files containing similar common code. - -To use it, run the +check-package+ script, by telling which files you -created or changed: - ----- -$ ./utils/check-package package/new-package/* ----- - -If you have the +utils+ directory in your path you can also run: - ----- -$ cd package/new-package/ -$ check-package * ----- - -The tool can also be used for packages in a br2-external: - ----- -$ check-package -b /path/to/br2-ext-tree/package/my-package/* ----- - -[[testing-package]] -==== How to test your package - -Once you have added your new package, it is important that you test it -under various conditions: does it build for all architectures? Does it -build with the different C libraries? Does it need threads, NPTL? And -so on... - -Buildroot runs http://autobuild.buildroot.org/[autobuilders] which -continuously test random configurations. However, these only build the -`master` branch of the git tree, and your new fancy package is not yet -there. - -Buildroot provides a script in +utils/test-pkg+ that uses the same base -configurations as used by the autobuilders so you can test your package -in the same conditions. - -First, create a config snippet that contains all the necessary options -needed to enable your package, but without any architecture or toolchain -option. For example, let's create a config snippet that just enables -+libcurl+, without any TLS backend: - ----- -$ cat libcurl.config -BR2_PACKAGE_LIBCURL=y ----- - -If your package needs more configuration options, you can add them to the -config snippet. For example, here's how you would test +libcurl+ with -+openssl+ as a TLS backend and the +curl+ program: - ----- -$ cat libcurl.config -BR2_PACKAGE_LIBCURL=y -BR2_PACKAGE_LIBCURL_CURL=y -BR2_PACKAGE_OPENSSL=y ----- - -Then run the +test-pkg+ script, by telling it what config snippet to use -and what package to test: - ----- -$ ./utils/test-pkg -c libcurl.config -p libcurl ----- - -By default, +test-pkg+ will build your package against a subset of the -toolchains used by the autobuilders, which has been selected by the -Buildroot developers as being the most useful and representative -subset. If you want to test all toolchains, pass the +-a+ option. Note -that in any case, internal toolchains are excluded as they take too -long to build. - -The output lists all toolchains that are tested and the corresponding -result (excerpt, results are fake): - ----- -$ ./utils/test-pkg -c libcurl.config -p libcurl - armv5-ctng-linux-gnueabi [ 1/11]: OK - armv7-ctng-linux-gnueabihf [ 2/11]: OK - br-aarch64-glibc [ 3/11]: SKIPPED - br-arcle-hs38 [ 4/11]: SKIPPED - br-arm-basic [ 5/11]: FAILED - br-arm-cortex-a9-glibc [ 6/11]: OK - br-arm-cortex-a9-musl [ 7/11]: FAILED - br-arm-cortex-m4-full [ 8/11]: OK - br-arm-full [ 9/11]: OK - br-arm-full-nothread [10/11]: FAILED - br-arm-full-static [11/11]: OK -11 builds, 2 skipped, 2 build failed, 1 legal-info failed ----- - -The results mean: - -* `OK`: the build was successful. -* `SKIPPED`: one or more configuration options listed in the config - snippet were not present in the final configuration. This is due to - options having dependencies not satisfied by the toolchain, such as - for example a package that +depends on BR2_USE_MMU+ with a noMMU - toolchain. The missing options are reported in +missing.config+ in - the output build directory (+~/br-test-pkg/TOOLCHAIN_NAME/+ by - default). -* `FAILED`: the build failed. Inspect the +logfile+ file in the output - build directory to see what went wrong: -** the actual build failed, -** the legal-info failed, -** one of the preliminary steps (downloading the config file, applying - the configuration, running `dirclean` for the package) failed. - -When there are failures, you can just re-run the script with the same -options (after you fixed your package); the script will attempt to -re-build the package specified with +-p+ for all toolchains, without -the need to re-build all the dependencies of that package. - -The +test-pkg+ script accepts a few options, for which you can get some -help by running: - ----- -$ ./utils/test-pkg -h ----- - -[[github-download-url]] -==== How to add a package from GitHub - -Packages on GitHub often don't have a download area with release tarballs. -However, it is possible to download tarballs directly from the repository -on GitHub. As GitHub is known to have changed download mechanisms in the -past, the 'github' helper function should be used as shown below. - ------------------------- -# Use a tag or a full commit ID -FOO_VERSION = 1.0 -FOO_SITE = $(call github,,,v$(FOO_VERSION)) ------------------------- - -.Notes -- The FOO_VERSION can either be a tag or a commit ID. -- The tarball name generated by github matches the default one from - Buildroot (e.g.: +foo-f6fb6654af62045239caed5950bc6c7971965e60.tar.gz+), - so it is not necessary to specify it in the +.mk+ file. -- When using a commit ID as version, you should use the full 40 hex characters. -- When the tag contains a prefix such as +v+ in +v1.0+, then the - +VERSION+ variable should contain just +1.0+, and the +v+ should be - added directly in the +SITE+ variable, as illustrated above. This - ensures that the +VERSION+ variable value can be used to match - against http://www.release-monitoring.org/[release-monitoring.org] - results. - -If the package you wish to add does have a release section on GitHub, the -maintainer may have uploaded a release tarball, or the release may just point -to the automatically generated tarball from the git tag. If there is a -release tarball uploaded by the maintainer, we prefer to use that since it -may be slightly different (e.g. it contains a configure script so we don't -need to do AUTORECONF). - -You can see on the release page if it's an uploaded tarball or a git tag: - -image::github_hash_mongrel2.png[] - -- If it looks like the image above then it was uploaded by the - maintainer and you should use that link (in that example: - 'mongrel2-v1.9.2.tar.bz2') to specify +FOO_SITE+, and not use the - 'github' helper. - -- On the other hand, if there's is *only* the "Source code" link, then - it's an automatically generated tarball and you should use the - 'github' helper function. - -[[gitlab-download-url]] -==== How to add a package from Gitlab - -In a similar way to the +github+ macro described in -xref:github-download-url[], Buildroot also provides the +gitlab+ macro -to download from Gitlab repositories. It can be used to download -auto-generated tarballs produced by Gitlab, either for specific tags -or commits: - ------------------------- -# Use a tag or a full commit ID -FOO_VERSION = 1.0 -FOO_SITE = $(call gitlab,,,v$(FOO_VERSION)) ------------------------- - -By default, it will use a +.tar.gz+ tarball, but Gitlab also provides -+.tar.bz2+ tarballs, so by adding a +_SOURCE+ variable, this -+.tar.bz2+ tarball can be used: - ------------------------- -# Use a tag or a full commit ID -FOO_VERSION = 1.0 -FOO_SITE = $(call gitlab,,,v$(FOO_VERSION)) -FOO_SOURCE = foo-$(FOO_VERSION).tar.bz2 ------------------------- - -If there is a specific tarball uploaded by the upstream developers in -+https://gitlab.com//releases/+, do not use this macro, but -rather use directly the link to the tarball. diff --git a/docs/manual/adding-packages-virtual.txt b/docs/manual/adding-packages-virtual.txt deleted file mode 100644 index 6326bb5455..0000000000 --- a/docs/manual/adding-packages-virtual.txt +++ /dev/null @@ -1,144 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for virtual packages - -[[virtual-package-tutorial]] - -In Buildroot, a virtual package is a package whose functionalities are -provided by one or more packages, referred to as 'providers'. The virtual -package management is an extensible mechanism allowing the user to choose -the provider used in the rootfs. - -For example, 'OpenGL ES' is an API for 2D and 3D graphics on embedded systems. -The implementation of this API is different for the 'Allwinner Tech Sunxi' and -the 'Texas Instruments OMAP35xx' platforms. So +libgles+ will be a virtual -package and +sunxi-mali+ and +ti-gfx+ will be the providers. - -==== +virtual-package+ tutorial - -In the following example, we will explain how to add a new virtual package -('something-virtual') and a provider for it ('some-provider'). - -First, let's create the virtual package. - -==== Virtual package's +Config.in+ file - -The +Config.in+ file of virtual package 'something-virtual' should contain: - ---------------------------- -01: config BR2_PACKAGE_HAS_SOMETHING_VIRTUAL -02: bool -03: -04: config BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL -05: depends on BR2_PACKAGE_HAS_SOMETHING_VIRTUAL -06: string ---------------------------- - -In this file, we declare two options, +BR2_PACKAGE_HAS_SOMETHING_VIRTUAL+ and -+BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL+, whose values will be used by the -providers. - -==== Virtual package's +.mk+ file - -The +.mk+ for the virtual package should just evaluate the +virtual-package+ macro: - ---------------------------- -01: ################################################################################ -02: # -03: # something-virtual -04: # -05: ################################################################################ -06: -07: $(eval $(virtual-package)) ---------------------------- - -The ability to have target and host packages is also available, with the -+host-virtual-package+ macro. - -==== Provider's +Config.in+ file - -When adding a package as a provider, only the +Config.in+ file requires some -modifications. - -The +Config.in+ file of the package 'some-provider', which provides the -functionalities of 'something-virtual', should contain: - ---------------------------- -01: config BR2_PACKAGE_SOME_PROVIDER -02: bool "some-provider" -03: select BR2_PACKAGE_HAS_SOMETHING_VIRTUAL -04: help -05: This is a comment that explains what some-provider is. -06: -07: http://foosoftware.org/some-provider/ -08: -09: if BR2_PACKAGE_SOME_PROVIDER -10: config BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL -11: default "some-provider" -12: endif ---------------------------- - -On line 3, we select +BR2_PACKAGE_HAS_SOMETHING_VIRTUAL+, and on line 11, we -set the value of +BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL+ to the name of the -provider, but only if it is selected. - -==== Provider's +.mk+ file - -The +.mk+ file should also declare an additional variable -+SOME_PROVIDER_PROVIDES+ to contain the names of all the virtual -packages it is an implementation of: - ---------------------------- -01: SOME_PROVIDER_PROVIDES = something-virtual ---------------------------- - -Of course, do not forget to add the proper build and runtime dependencies for -this package! - -==== Notes on depending on a virtual package - -When adding a package that requires a certain +FEATURE+ provided by a virtual -package, you have to use +depends on BR2_PACKAGE_HAS_FEATURE+, like so: - ---------------------------- -config BR2_PACKAGE_HAS_FEATURE - bool - -config BR2_PACKAGE_FOO - bool "foo" - depends on BR2_PACKAGE_HAS_FEATURE ---------------------------- - -==== Notes on depending on a specific provider - -If your package really requires a specific provider, then you'll have to -make your package +depends on+ this provider; you can _not_ +select+ a -provider. - -Let's take an example with two providers for a +FEATURE+: - ---------------------------- -config BR2_PACKAGE_HAS_FEATURE - bool - -config BR2_PACKAGE_FOO - bool "foo" - select BR2_PACKAGE_HAS_FEATURE - -config BR2_PACKAGE_BAR - bool "bar" - select BR2_PACKAGE_HAS_FEATURE ---------------------------- - -And you are adding a package that needs +FEATURE+ as provided by +foo+, -but not as provided by +bar+. - -If you were to use +select BR2_PACKAGE_FOO+, then the user would still -be able to select +BR2_PACKAGE_BAR+ in the menuconfig. This would create -a configuration inconsistency, whereby two providers of the same +FEATURE+ -would be enabled at once, one explicitly set by the user, the other -implicitly by your +select+. - -Instead, you have to use +depends on BR2_PACKAGE_FOO+, which avoids any -implicit configuration inconsistency. diff --git a/docs/manual/adding-packages-waf.txt b/docs/manual/adding-packages-waf.txt deleted file mode 100644 index 101cddf1f1..0000000000 --- a/docs/manual/adding-packages-waf.txt +++ /dev/null @@ -1,91 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Infrastructure for Waf-based packages - -[[waf-package-tutorial]] - -==== +waf-package+ tutorial - -First, let's see how to write a +.mk+ file for a Waf-based package, with -an example : - ------------------------- -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_CONF_OPTS = --enable-bar --disable-baz -11: LIBFOO_DEPENDENCIES = bar -12: -13: $(eval $(waf-package)) ------------------------- - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10, we tell Buildroot what options to enable for libfoo. - -On line 11, we tell Buildroot the dependencies of libfoo. - -Finally, on line line 13, we invoke the +waf-package+ -macro that generates all the Makefile rules that actually allows the -package to be built. - -[[waf-package-reference]] - -==== +waf-package+ reference - -The main macro of the Waf package infrastructure is +waf-package+. -It is similar to the +generic-package+ macro. - -Just like the generic infrastructure, the Waf infrastructure works -by defining a number of variables before calling the +waf-package+ -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the Waf infrastructure: -+LIBFOO_VERSION+, +LIBFOO_SOURCE+, +LIBFOO_PATCH+, +LIBFOO_SITE+, -+LIBFOO_SUBDIR+, +LIBFOO_DEPENDENCIES+, +LIBFOO_INSTALL_STAGING+, -+LIBFOO_INSTALL_TARGET+. - -An additional variable, specific to the Waf infrastructure, can -also be defined. - -* +LIBFOO_SUBDIR+ may contain the name of a subdirectory inside the - package that contains the main wscript file. This is useful, - if for example, the main wscript file is not at the root of - the tree extracted by the tarball. If +HOST_LIBFOO_SUBDIR+ is not - specified, it defaults to +LIBFOO_SUBDIR+. - -* +LIBFOO_NEEDS_EXTERNAL_WAF+ can be set to +YES+ or +NO+ to tell - Buildroot to use the bundled +waf+ executable. If set to +NO+, the - default, then Buildroot will use the waf executable provided in the - package source tree; if set to +YES+, then Buildroot will download, - install waf as a host tool and use it to build the package. - -* +LIBFOO_WAF_OPTS+, to specify additional options to pass to the - +waf+ script at every step of the package build process: configure, - build and installation. By default, empty. - -* +LIBFOO_CONF_OPTS+, to specify additional options to pass to the - +waf+ script for the configuration step. By default, empty. - -* +LIBFOO_BUILD_OPTS+, to specify additional options to pass to the - +waf+ script during the build step. By default, empty. - -* +LIBFOO_INSTALL_STAGING_OPTS+, to specify additional options to pass - to the +waf+ script during the staging installation step. By default, - empty. - -* +LIBFOO_INSTALL_TARGET_OPTS+, to specify additional options to pass - to the +waf+ script during the target installation step. By default, - empty. diff --git a/docs/manual/adding-packages.txt b/docs/manual/adding-packages.txt deleted file mode 100644 index 814355cd76..0000000000 --- a/docs/manual/adding-packages.txt +++ /dev/null @@ -1,58 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[adding-packages]] -== Adding new packages to Buildroot - -This section covers how new packages (userspace libraries or -applications) can be integrated into Buildroot. It also shows how -existing packages are integrated, which is needed for fixing issues or -tuning their configuration. - -When you add a new package, be sure to test it in various conditions -(see xref:testing-package[]) and also check it for coding style (see -xref:check-package[]). - -include::adding-packages-directory.txt[] - -include::adding-packages-generic.txt[] - -include::adding-packages-autotools.txt[] - -include::adding-packages-cmake.txt[] - -include::adding-packages-python.txt[] - -include::adding-packages-luarocks.txt[] - -include::adding-packages-perl.txt[] - -include::adding-packages-virtual.txt[] - -include::adding-packages-kconfig.txt[] - -include::adding-packages-rebar.txt[] - -include::adding-packages-waf.txt[] - -include::adding-packages-meson.txt[] - -include::adding-packages-cargo.txt[] - -include::adding-packages-golang.txt[] - -include::adding-packages-qmake.txt[] - -include::adding-packages-kernel-module.txt[] - -include::adding-packages-asciidoc.txt[] - -include::adding-packages-linux-kernel-spec-infra.txt[] - -include::adding-packages-hooks.txt[] - -include::adding-packages-gettext.txt[] - -include::adding-packages-tips.txt[] - -include::adding-packages-conclusion.txt[] diff --git a/docs/manual/advanced.txt b/docs/manual/advanced.txt deleted file mode 100644 index b7bfc4923d..0000000000 --- a/docs/manual/advanced.txt +++ /dev/null @@ -1,16 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Advanced usage - -include::using-buildroot-toolchain.txt[] - -include::using-buildroot-debugger.txt[] - -include::ccache-support.txt[] - -include::download-location.txt[] - -include::package-make-target.txt[] - -include::using-buildroot-development.txt[] diff --git a/docs/manual/appendix.txt b/docs/manual/appendix.txt deleted file mode 100644 index 86afa4bdaa..0000000000 --- a/docs/manual/appendix.txt +++ /dev/null @@ -1,6 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -include::makedev-syntax.txt[] -include::makeusers-syntax.txt[] -include::migrating.txt[] diff --git a/docs/manual/beyond-buildroot.txt b/docs/manual/beyond-buildroot.txt deleted file mode 100644 index eefea1fecf..0000000000 --- a/docs/manual/beyond-buildroot.txt +++ /dev/null @@ -1,66 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== Beyond Buildroot - -=== Boot the generated images - -==== NFS boot - -To achieve NFS-boot, enable _tar root filesystem_ in the _Filesystem -images_ menu. - -After a complete build, just run the following commands to setup the -NFS-root directory: - -------------------- -sudo tar -xavf /path/to/output_dir/rootfs.tar -C /path/to/nfs_root_dir -------------------- - -Remember to add this path to +/etc/exports+. - -Then, you can execute a NFS-boot from your target. - -==== Live CD - -To build a live CD image, enable the _iso image_ option in the -_Filesystem images_ menu. Note that this option is only available on -the x86 and x86-64 architectures, and if you are building your kernel -with Buildroot. - -You can build a live CD image with either IsoLinux, Grub or Grub 2 as -a bootloader, but only Isolinux supports making this image usable both -as a live CD and live USB (through the _Build hybrid image_ option). - -You can test your live CD image using QEMU: - -------------------- -qemu-system-i386 -cdrom output/images/rootfs.iso9660 -------------------- - -Or use it as a hard-drive image if it is a hybrid ISO: - -------------------- -qemu-system-i386 -hda output/images/rootfs.iso9660 -------------------- - -It can be easily flashed to a USB drive with +dd+: - -------------------- -dd if=output/images/rootfs.iso9660 of=/dev/sdb -------------------- - -=== Chroot - -If you want to chroot in a generated image, then there are few thing -you should be aware of: - -* you should setup the new root from the _tar root filesystem_ image; - -* either the selected target architecture is compatible with your host - machine, or you should use some +qemu-*+ binary and correctly set it - within the +binfmt+ properties to be able to run the binaries built - for the target on your host machine; - -* Buildroot does not currently provide +host-qemu+ and +binfmt+ - correctly built and set for that kind of use. diff --git a/docs/manual/ccache-support.txt b/docs/manual/ccache-support.txt deleted file mode 100644 index f6746ad7d8..0000000000 --- a/docs/manual/ccache-support.txt +++ /dev/null @@ -1,55 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[ccache]] -==== Using +ccache+ in Buildroot - -http://ccache.samba.org[ccache] is a compiler cache. It stores the -object files resulting from each compilation process, and is able to -skip future compilation of the same source file (with same compiler -and same arguments) by using the pre-existing object files. When doing -almost identical builds from scratch a number of times, it can nicely -speed up the build process. - -+ccache+ support is integrated in Buildroot. You just have to enable -+Enable compiler cache+ in +Build options+. This will automatically -build +ccache+ and use it for every host and target compilation. - -The cache is located in +$HOME/.buildroot-ccache+. It is stored -outside of Buildroot output directory so that it can be shared by -separate Buildroot builds. If you want to get rid of the cache, simply -remove this directory. - -You can get statistics on the cache (its size, number of hits, -misses, etc.) by running +make ccache-stats+. - -The make target +ccache-options+ and the +CCACHE_OPTIONS+ variable -provide more generic access to the ccache. For example - ------------------ -# set cache limit size -make CCACHE_OPTIONS="--max-size=5G" ccache-options - -# zero statistics counters -make CCACHE_OPTIONS="--zero-stats" ccache-options ------------------ - -+ccache+ makes a hash of the source files and of the compiler options. -If a compiler option is different, the cached object file will not be -used. Many compiler options, however, contain an absolute path to the -staging directory. Because of this, building in a different output -directory would lead to many cache misses. - -To avoid this issue, buildroot has the +Use relative paths+ option -(+BR2_CCACHE_USE_BASEDIR+). This will rewrite all absolute paths that -point inside the output directory into relative paths. Thus, changing -the output directory no longer leads to cache misses. - -A disadvantage of the relative paths is that they also end up to be -relative paths in the object file. Therefore, for example, the debugger -will no longer find the file, unless you cd to the output directory -first. - -See https://ccache.samba.org/manual.html#_compiling_in_different_directories[the -ccache manual's section on "Compiling in different directories"] for -more details about this rewriting of absolute paths. diff --git a/docs/manual/common-usage.txt b/docs/manual/common-usage.txt deleted file mode 100644 index 9ba87a8339..0000000000 --- a/docs/manual/common-usage.txt +++ /dev/null @@ -1,422 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== General Buildroot usage - -include::make-tips.txt[] - -include::rebuilding-packages.txt[] - -=== Offline builds - -If you intend to do an offline build and just want to download -all sources that you previously selected in the configurator -('menuconfig', 'nconfig', 'xconfig' or 'gconfig'), then issue: - --------------------- - $ make source --------------------- - -You can now disconnect or copy the content of your +dl+ -directory to the build-host. - -=== Building out-of-tree - -As default, everything built by Buildroot is stored in the directory -+output+ in the Buildroot tree. - -Buildroot also supports building out of tree with a syntax similar to -the Linux kernel. To use it, add +O=+ to the make command -line: - --------------------- - $ make O=/tmp/build --------------------- - -Or: - --------------------- - $ cd /tmp/build; make O=$PWD -C path/to/buildroot --------------------- - -All the output files will be located under +/tmp/build+. If the +O+ -path does not exist, Buildroot will create it. - -*Note:* the +O+ path can be either an absolute or a relative path, but if it's -passed as a relative path, it is important to note that it is interpreted -relative to the main Buildroot source directory, *not* the current working -directory. - -When using out-of-tree builds, the Buildroot +.config+ and temporary -files are also stored in the output directory. This means that you can -safely run multiple builds in parallel using the same source tree as -long as they use unique output directories. - -For ease of use, Buildroot generates a Makefile wrapper in the output -directory - so after the first run, you no longer need to pass +O=<...>+ -and +-C <...>+, simply run (in the output directory): - --------------------- - $ make --------------------- - -[[env-vars]] - -=== Environment variables - -Buildroot also honors some environment variables, when they are passed -to +make+ or set in the environment: - -* +HOSTCXX+, the host C++ compiler to use -* +HOSTCC+, the host C compiler to use -* +UCLIBC_CONFIG_FILE=+, path to - the uClibc configuration file, used to compile uClibc, if an - internal toolchain is being built. - + - Note that the uClibc configuration file can also be set from the - configuration interface, so through the Buildroot +.config+ file; this - is the recommended way of setting it. - + -* +BUSYBOX_CONFIG_FILE=+, path to - the BusyBox configuration file. - + - Note that the BusyBox configuration file can also be set from the - configuration interface, so through the Buildroot +.config+ file; this - is the recommended way of setting it. - + -* +BR2_CCACHE_DIR+ to override the directory where - Buildroot stores the cached files when using ccache. - + -* +BR2_DL_DIR+ to override the directory in which - Buildroot stores/retrieves downloaded files. - + - Note that the Buildroot download directory can also be set from the - configuration interface, so through the Buildroot +.config+ file. See - xref:download-location[] for more details on how you can set the download - directory. -* +BR2_GRAPH_ALT+, if set and non-empty, to use an alternate color-scheme in - build-time graphs -* +BR2_GRAPH_OUT+ to set the filetype of generated graphs, either +pdf+ (the - default), or +png+. -* +BR2_GRAPH_DEPS_OPTS+ to pass extra options to the dependency graph; see - xref:graph-depends[] for the accepted options -* +BR2_GRAPH_DOT_OPTS+ is passed verbatim as options to the +dot+ utility to - draw the dependency graph. -* +BR2_GRAPH_SIZE_OPTS+ to pass extra options to the size graph; see - xref:graph-size[] for the acepted options - -An example that uses config files located in the toplevel directory and -in your $HOME: - --------------------- - $ make UCLIBC_CONFIG_FILE=uClibc.config BUSYBOX_CONFIG_FILE=$HOME/bb.config --------------------- - -If you want to use a compiler other than the default +gcc+ -or +g+++ for building helper-binaries on your host, then do - --------------------- - $ make HOSTCXX=g++-4.3-HEAD HOSTCC=gcc-4.3-HEAD --------------------- - -=== Dealing efficiently with filesystem images - -Filesystem images can get pretty big, depending on the filesystem you choose, -the number of packages, whether you provisioned free space... Yet, some -locations in the filesystems images may just be _empty_ (e.g. a long run of -'zeroes'); such a file is called a _sparse_ file. - -Most tools can handle sparse files efficiently, and will only store or write -those parts of a sparse file that are not empty. - -For example: - -* +tar+ accepts the +-S+ option to tell it to only store non-zero blocks - of sparse files: -** +tar cf archive.tar -S [files...]+ will efficiently store sparse files - in a tarball -** +tar xf archive.tar -S+ will efficiently store sparse files extracted - from a tarball - -* +cp+ accepts the +--sparse=WHEN+ option (+WHEN+ is one of +auto+, - +never+ or +always+): -** +cp --sparse=always source.file dest.file+ will make +dest.file+ a - sparse file if +source.file+ has long runs of zeroes - -Other tools may have similar options. Please consult their respective man -pages. - -You can use sparse files if you need to store the filesystem images (e.g. -to transfer from one machine to another), or if you need to send them (e.g. -to the Q&A team). - -Note however that flashing a filesystem image to a device while using the -sparse mode of +dd+ may result in a broken filesystem (e.g. the block bitmap -of an ext2 filesystem may be corrupted; or, if you have sparse files in -your filesystem, those parts may not be all-zeroes when read back). You -should only use sparse files when handling files on the build machine, not -when transferring them to an actual device that will be used on the target. - -=== Details about packages - -[[package-details]] - -Buildroot can produce a JSON blurb that describes the set of enabled -packages in the current configuration, together with their -dependencies, licenses and other metadata. This JSON blurb is produced -by using the +show-info+ make target: - ------------------------- -make show-info ------------------------- - -Buildroot can also produce details about packages as HTML and JSON -output using the +pkg-stats+ make target. Amongst other things, these -details include whether known CVEs (security vulnerabilities) affect -the packages in your current configuration. It also shows if there is -a newer upstream version for those packages. - ------------------------- -make pkg-stats ------------------------- - -=== Graphing the dependencies between packages - -[[graph-depends]] - -One of Buildroot's jobs is to know the dependencies between packages, -and make sure they are built in the right order. These dependencies -can sometimes be quite complicated, and for a given system, it is -often not easy to understand why such or such package was brought into -the build by Buildroot. - -In order to help understanding the dependencies, and therefore better -understand what is the role of the different components in your -embedded Linux system, Buildroot is capable of generating dependency -graphs. - -To generate a dependency graph of the full system you have compiled, -simply run: - ------------------------- -make graph-depends ------------------------- - -You will find the generated graph in -+output/graphs/graph-depends.pdf+. - -If your system is quite large, the dependency graph may be too complex -and difficult to read. It is therefore possible to generate the -dependency graph just for a given package: - ------------------------- -make -graph-depends ------------------------- - -You will find the generated graph in -+output/graph/-graph-depends.pdf+. - -Note that the dependency graphs are generated using the +dot+ tool -from the _Graphviz_ project, which you must have installed on your -system to use this feature. In most distributions, it is available as -the +graphviz+ package. - -By default, the dependency graphs are generated in the PDF -format. However, by passing the +BR2_GRAPH_OUT+ environment variable, you -can switch to other output formats, such as PNG, PostScript or -SVG. All formats supported by the +-T+ option of the +dot+ tool are -supported. - --------------------------------- -BR2_GRAPH_OUT=svg make graph-depends --------------------------------- - -The +graph-depends+ behaviour can be controlled by setting options in the -+BR2_GRAPH_DEPS_OPTS+ environment variable. The accepted options are: - -* +--depth N+, +-d N+, to limit the dependency depth to +N+ levels. The - default, +0+, means no limit. - -* +--stop-on PKG+, +-s PKG+, to stop the graph on the package +PKG+. - +PKG+ can be an actual package name, a glob, the keyword 'virtual' - (to stop on virtual packages), or the keyword 'host' (to stop on - host packages). The package is still present on the graph, but its - dependencies are not. - -* +--exclude PKG+, +-x PKG+, like +--stop-on+, but also omits +PKG+ from - the graph. - -* +--transitive+, +--no-transitive+, to draw (or not) the transitive - dependencies. The default is to not draw transitive dependencies. - -* +--colors R,T,H+, the comma-separated list of colors to draw the - root package (+R+), the target packages (+T+) and the host packages - (+H+). Defaults to: +lightblue,grey,gainsboro+ - --------------------------------- -BR2_GRAPH_DEPS_OPTS='-d 3 --no-transitive --colors=red,green,blue' make graph-depends --------------------------------- - -=== Graphing the build duration - -[[graph-duration]] - -When the build of a system takes a long time, it is sometimes useful -to be able to understand which packages are the longest to build, to -see if anything can be done to speed up the build. In order to help -such build time analysis, Buildroot collects the build time of each -step of each package, and allows to generate graphs from this data. - -To generate the build time graph after a build, run: - ----------------- -make graph-build ----------------- - -This will generate a set of files in +output/graphs+ : - -* +build.hist-build.pdf+, a histogram of the build time for each - package, ordered in the build order. - -* +build.hist-duration.pdf+, a histogram of the build time for each - package, ordered by duration (longest first) - -* +build.hist-name.pdf+, a histogram of the build time for each - package, order by package name. - -* +build.pie-packages.pdf+, a pie chart of the build time per package - -* +build.pie-steps.pdf+, a pie chart of the global time spent in each - step of the packages build process. - -This +graph-build+ target requires the Python Matplotlib and Numpy -libraries to be installed (+python-matplotlib+ and +python-numpy+ on -most distributions), and also the +argparse+ module if you're using a -Python version older than 2.7 (+python-argparse+ on most -distributions). - -By default, the output format for the graph is PDF, but a different -format can be selected using the +BR2_GRAPH_OUT+ environment variable. The -only other format supported is PNG: - ----------------- -BR2_GRAPH_OUT=png make graph-build ----------------- - -[[graph-size]] -=== Graphing the filesystem size contribution of packages - -When your target system grows, it is sometimes useful to understand -how much each Buildroot package is contributing to the overall root -filesystem size. To help with such an analysis, Buildroot collects -data about files installed by each package and using this data, -generates a graph and CSV files detailing the size contribution of -the different packages. - -To generate these data after a build, run: - ----------------- -make graph-size ----------------- - -This will generate: - -* +output/graphs/graph-size.pdf+, a pie chart of the contribution of - each package to the overall root filesystem size - -* +output/graphs/package-size-stats.csv+, a CSV file giving the size - contribution of each package to the overall root filesystem size - -* +output/graphs/file-size-stats.csv+, a CSV file giving the size - contribution of each installed file to the package it belongs, and - to the overall filesystem size. - -This +graph-size+ target requires the Python Matplotlib library to be -installed (+python-matplotlib+ on most distributions), and also the -+argparse+ module if you're using a Python version older than 2.7 -(+python-argparse+ on most distributions). - -Just like for the duration graph, a +BR2_GRAPH_OUT+ environment variable -is supported to adjust the output file format. See xref:graph-depends[] -for details about this environment variable. - -Additionally, one may set the environment variable +BR2_GRAPH_SIZE_OPTS+ -to further control the generated graph. Accepted options are: - -* `--size-limit X`, `-l X`, will group all packages which individual - contribution is below `X` percent, to a single entry labelled _Others_ - in the graph. By default, `X=0.01`, which means packages each - contributing less than 1% are grouped under _Others_. Accepted values - are in the range `[0.0..1.0]`. - -* `--iec`, `--binary`, `--si`, `--decimal`, to use IEC (binary, powers - of 1024) or SI (decimal, powers of 1000; the default) prefixes. - -* `--biggest-first`, to sort packages in decreasing size order, rather - than in increasing size order. - -.Note -The collected filesystem size data is only meaningful after a complete -clean rebuild. Be sure to run +make clean all+ before using +make -graph-size+. - -To compare the root filesystem size of two different Buildroot compilations, -for example after adjusting the configuration or when switching to another -Buildroot release, use the +size-stats-compare+ script. It takes two -+file-size-stats.csv+ files (produced by +make graph-size+) as input. -Refer to the help text of this script for more details: - ----------------- -utils/size-stats-compare -h ----------------- - -[[top-level-parallel-build]] -=== Top-level parallel build - -.Note -This section deals with a very experimental feature, which is known to -break even in some non-unusual situations. Use at your own risk. - -Buildroot has always been capable of using parallel build on a per -package basis: each package is built by Buildroot using +make -jN+ (or -the equivalent invocation for non-make-based build systems). The level -of parallelism is by default number of CPUs + 1, but it can be -adjusted using the +BR2_JLEVEL+ configuration option. - -Until 2020.02, Buildroot was however building packages in a serial -fashion: each package was built one after the other, without -parallelization of the build between packages. As of 2020.02, -Buildroot has experimental support for *top-level parallel build*, -which allows some signicant build time savings by building packages -that have no dependency relationship in parallel. This feature is -however marked as experimental and is known not to work in some cases. - -In order to use top-level parallel build, one must: - -. Enable the option +BR2_PER_PACKAGE_DIRECTORIES+ in the Buildroot -configuration - -. Use +make -jN+ when starting the Buildroot build - -Internally, the +BR2_PER_PACKAGE_DIRECTORIES+ will enable a mechanism -called *per-package directories*, which will have the following -effects: - -* Instead of a global _target_ directory and a global _host_ directory - common to all packages, per-package _target_ and _host_ directories - will be used, in +$(O)/per-package//target/+ and - +$(O)/per-package//host/+ respectively. Those folders will be - populated from the corresponding folders of the package dependencies - at the beginning of ++ build. The compiler and all other tools - will therefore only be able to see and access files installed by - dependencies explicitly listed by ++. - -* At the end of the build, the global _target_ and _host_ directories - will be populated, located in +$(O)/target+ and +$(O)/host+ - respectively. This means that during the build, those folders will - be empty and it's only at the very end of the build that they will - be populated. - -include::eclipse-integration.txt[] - -include::advanced.txt[] diff --git a/docs/manual/configure-other-components.txt b/docs/manual/configure-other-components.txt deleted file mode 100644 index 60a80f0a48..0000000000 --- a/docs/manual/configure-other-components.txt +++ /dev/null @@ -1,60 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== Configuration of other components - -Before attempting to modify any of the components below, make sure you -have already configured Buildroot itself, and have enabled the -corresponding package. - -BusyBox:: -+ -If you already have a BusyBox configuration file, you can directly -specify this file in the Buildroot configuration, using -+BR2_PACKAGE_BUSYBOX_CONFIG+. Otherwise, Buildroot will start from a -default BusyBox configuration file. -+ -To make subsequent changes to the configuration, use +make -busybox-menuconfig+ to open the BusyBox configuration editor. -+ -It is also possible to specify a BusyBox configuration file through an -environment variable, although this is not recommended. Refer to -xref:env-vars[] for more details. - -uClibc:: -+ -Configuration of uClibc is done in the same way as for BusyBox. The -configuration variable to specify an existing configuration file is -+BR2_UCLIBC_CONFIG+. The command to make subsequent changes is +make -uclibc-menuconfig+. - -Linux kernel:: -+ -If you already have a kernel configuration file, you can directly -specify this file in the Buildroot configuration, using -+BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG+. -+ -If you do not yet have a kernel configuration file, you can either start -by specifying a defconfig in the Buildroot configuration, using -+BR2_LINUX_KERNEL_USE_DEFCONFIG+, or start by creating an empty file and -specifying it as custom configuration file, using -+BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG+. -+ -To make subsequent changes to the configuration, use +make -linux-menuconfig+ to open the Linux configuration editor. - -Barebox:: -+ -Configuration of Barebox is done in the same way as for the Linux -kernel. The corresponding configuration variables are -+BR2_TARGET_BAREBOX_USE_CUSTOM_CONFIG+ and -+BR2_TARGET_BAREBOX_USE_DEFCONFIG+. To open the configuration editor, -use +make barebox-menuconfig+. - -U-Boot:: -+ -Configuration of U-Boot (version 2015.04 or newer) is done in the same -way as for the Linux kernel. The corresponding configuration variables -are +BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG+ and -+BR2_TARGET_UBOOT_USE_DEFCONFIG+. To open the configuration editor, -use +make uboot-menuconfig+. diff --git a/docs/manual/configure.txt b/docs/manual/configure.txt index c9eef567f4..8d1c8b69c3 100644 --- a/docs/manual/configure.txt +++ b/docs/manual/configure.txt @@ -1,430 +1 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[configure]] -== Buildroot configuration - -All the configuration options in +make *config+ have a help text -providing details about the option. - -The +make *config+ commands also offer a search tool. Read the help -message in the different frontend menus to know how to use it: - -* in _menuconfig_, the search tool is called by pressing +/+; -* in _xconfig_, the search tool is called by pressing +Ctrl+ + +f+. - -The result of the search shows the help message of the matching items. -In _menuconfig_, numbers in the left column provide a shortcut to the -corresponding entry. Just type this number to directly jump to the -entry, or to the containing menu in case the entry is not selectable due -to a missing dependency. - -Although the menu structure and the help text of the entries should be -sufficiently self-explanatory, a number of topics require additional -explanation that cannot easily be covered in the help text and are -therefore covered in the following sections. - -=== Cross-compilation toolchain - -A compilation toolchain is the set of tools that allows you to compile -code for your system. It consists of a compiler (in our case, +gcc+), -binary utils like assembler and linker (in our case, +binutils+) and a -C standard library (for example -http://www.gnu.org/software/libc/libc.html[GNU Libc], -http://www.uclibc-ng.org/[uClibc-ng]). - -The system installed on your development station certainly already has -a compilation toolchain that you can use to compile an application -that runs on your system. If you're using a PC, your compilation -toolchain runs on an x86 processor and generates code for an x86 -processor. Under most Linux systems, the compilation toolchain uses -the GNU libc (glibc) as the C standard library. This compilation -toolchain is called the "host compilation toolchain". The machine on -which it is running, and on which you're working, is called the "host -system" footnote:[This terminology differs from what is used by GNU -configure, where the host is the machine on which the application will -run (which is usually the same as target)]. - -The compilation toolchain is provided by your distribution, and -Buildroot has nothing to do with it (other than using it to build a -cross-compilation toolchain and other tools that are run on the -development host). - -As said above, the compilation toolchain that comes with your system -runs on and generates code for the processor in your host system. As -your embedded system has a different processor, you need a -cross-compilation toolchain - a compilation toolchain that runs on -your _host system_ but generates code for your _target system_ (and -target processor). For example, if your host system uses x86 and your -target system uses ARM, the regular compilation toolchain on your host -runs on x86 and generates code for x86, while the cross-compilation -toolchain runs on x86 and generates code for ARM. - -Buildroot provides two solutions for the cross-compilation toolchain: - - * The *internal toolchain backend*, called +Buildroot toolchain+ in - the configuration interface. - - * The *external toolchain backend*, called +External toolchain+ in - the configuration interface. - -The choice between these two solutions is done using the +Toolchain -Type+ option in the +Toolchain+ menu. Once one solution has been -chosen, a number of configuration options appear, they are detailed in -the following sections. - -[[internal-toolchain-backend]] -==== Internal toolchain backend - -The _internal toolchain backend_ is the backend where Buildroot builds -by itself a cross-compilation toolchain, before building the userspace -applications and libraries for your target embedded system. - -This backend supports several C libraries: -http://www.uclibc-ng.org[uClibc-ng], -http://www.gnu.org/software/libc/libc.html[glibc] and -http://www.musl-libc.org[musl]. - -Once you have selected this backend, a number of options appear. The -most important ones allow to: - - * Change the version of the Linux kernel headers used to build the - toolchain. This item deserves a few explanations. In the process of - building a cross-compilation toolchain, the C library is being - built. This library provides the interface between userspace - applications and the Linux kernel. In order to know how to "talk" - to the Linux kernel, the C library needs to have access to the - _Linux kernel headers_ (i.e. the +.h+ files from the kernel), which - define the interface between userspace and the kernel (system - calls, data structures, etc.). Since this interface is backward - compatible, the version of the Linux kernel headers used to build - your toolchain do not need to match _exactly_ the version of the - Linux kernel you intend to run on your embedded system. They only - need to have a version equal or older to the version of the Linux - kernel you intend to run. If you use kernel headers that are more - recent than the Linux kernel you run on your embedded system, then - the C library might be using interfaces that are not provided by - your Linux kernel. - - * Change the version of the GCC compiler, binutils and the C library. - - * Select a number of toolchain options (uClibc only): whether the - toolchain should have RPC support (used mainly for NFS), - wide-char support, locale support (for internationalization), - C++ support or thread support. Depending on which options you choose, - the number of userspace applications and libraries visible in - Buildroot menus will change: many applications and libraries require - certain toolchain options to be enabled. Most packages show a comment - when a certain toolchain option is required to be able to enable - those packages. If needed, you can further refine the uClibc - configuration by running +make uclibc-menuconfig+. Note however that - all packages in Buildroot are tested against the default uClibc - configuration bundled in Buildroot: if you deviate from this - configuration by removing features from uClibc, some packages may no - longer build. - -It is worth noting that whenever one of those options is modified, -then the entire toolchain and system must be rebuilt. See -xref:full-rebuild[]. - -Advantages of this backend: - -* Well integrated with Buildroot -* Fast, only builds what's necessary - -Drawbacks of this backend: - -* Rebuilding the toolchain is needed when doing +make clean+, which - takes time. If you're trying to reduce your build time, consider - using the _External toolchain backend_. - -[[external-toolchain-backend]] -==== External toolchain backend - -The _external toolchain backend_ allows to use existing pre-built -cross-compilation toolchains. Buildroot knows about a number of -well-known cross-compilation toolchains (from -http://www.linaro.org[Linaro] for ARM, -http://www.mentor.com/embedded-software/sourcery-tools/sourcery-codebench/editions/lite-edition/[Sourcery -CodeBench] for ARM, x86-64, PowerPC, and MIPS, and is capable of -downloading them automatically, or it can be pointed to a custom -toolchain, either available for download or installed locally. - -Then, you have three solutions to use an external toolchain: - -* Use a predefined external toolchain profile, and let Buildroot - download, extract and install the toolchain. Buildroot already knows - about a few CodeSourcery and Linaro toolchains. Just select the - toolchain profile in +Toolchain+ from the available ones. This is - definitely the easiest solution. - -* Use a predefined external toolchain profile, but instead of having - Buildroot download and extract the toolchain, you can tell Buildroot - where your toolchain is already installed on your system. Just - select the toolchain profile in +Toolchain+ through the available - ones, unselect +Download toolchain automatically+, and fill the - +Toolchain path+ text entry with the path to your cross-compiling - toolchain. - -* Use a completely custom external toolchain. This is particularly - useful for toolchains generated using crosstool-NG or with Buildroot - itself. To do this, select the +Custom toolchain+ solution in the - +Toolchain+ list. You need to fill the +Toolchain path+, +Toolchain - prefix+ and +External toolchain C library+ options. Then, you have - to tell Buildroot what your external toolchain supports. If your - external toolchain uses the 'glibc' library, you only have to tell - whether your toolchain supports C\++ or not and whether it has - built-in RPC support. If your external toolchain uses the 'uClibc' - library, then you have to tell Buildroot if it supports RPC, - wide-char, locale, program invocation, threads and C++. - At the beginning of the execution, Buildroot will tell you if - the selected options do not match the toolchain configuration. - -Our external toolchain support has been tested with toolchains from -CodeSourcery and Linaro, toolchains generated by -http://crosstool-ng.org[crosstool-NG], and toolchains generated by -Buildroot itself. In general, all toolchains that support the -'sysroot' feature should work. If not, do not hesitate to contact the -developers. - -We do not support toolchains or SDK generated by OpenEmbedded or -Yocto, because these toolchains are not pure toolchains (i.e. just the -compiler, binutils, the C and C++ libraries). Instead these toolchains -come with a very large set of pre-compiled libraries and -programs. Therefore, Buildroot cannot import the 'sysroot' of the -toolchain, as it would contain hundreds of megabytes of pre-compiled -libraries that are normally built by Buildroot. - -We also do not support using the distribution toolchain (i.e. the -gcc/binutils/C library installed by your distribution) as the -toolchain to build software for the target. This is because your -distribution toolchain is not a "pure" toolchain (i.e. only with the -C/C++ library), so we cannot import it properly into the Buildroot -build environment. So even if you are building a system for a x86 or -x86_64 target, you have to generate a cross-compilation toolchain with -Buildroot or crosstool-NG. - -If you want to generate a custom toolchain for your project, that can -be used as an external toolchain in Buildroot, our recommendation is -to build it either with Buildroot itself (see -xref:build-toolchain-with-buildroot[]) or with -http://crosstool-ng.org[crosstool-NG]. - -Advantages of this backend: - -* Allows to use well-known and well-tested cross-compilation - toolchains. - -* Avoids the build time of the cross-compilation toolchain, which is - often very significant in the overall build time of an embedded - Linux system. - -Drawbacks of this backend: - -* If your pre-built external toolchain has a bug, may be hard to get a - fix from the toolchain vendor, unless you build your external - toolchain by yourself using Buildroot or Crosstool-NG. - -[[build-toolchain-with-buildroot]] -==== Build an external toolchain with Buildroot - -The Buildroot internal toolchain option can be used to create an -external toolchain. Here are a series of steps to build an internal -toolchain and package it up for reuse by Buildroot itself (or other -projects). - -Create a new Buildroot configuration, with the following details: - -* Select the appropriate *Target options* for your target CPU - architecture - -* In the *Toolchain* menu, keep the default of *Buildroot toolchain* - for *Toolchain type*, and configure your toolchain as desired - -* In the *System configuration* menu, select *None* as the *Init - system* and *none* as */bin/sh* - -* In the *Target packages* menu, disable *BusyBox* - -* In the *Filesystem images* menu, disable *tar the root filesystem* - -Then, we can trigger the build, and also ask Buildroot to generate a -SDK. This will conveniently generate for us a tarball which contains -our toolchain: - ------ -make sdk ------ - -This produces the SDK tarball in +$(O)/images+, with a name similar to -+arm-buildroot-linux-uclibcgnueabi_sdk-buildroot.tar.gz+. Save this -tarball, as it is now the toolchain that you can re-use as an external -toolchain in other Buildroot projects. - -In those other Buildroot projects, in the *Toolchain* menu: - -* Set *Toolchain type* to *External toolchain* - -* Set *Toolchain* to *Custom toolchain* - -* Set *Toolchain origin* to *Toolchain to be downloaded and installed* - -* Set *Toolchain URL* to +file:///path/to/your/sdk/tarball.tar.gz+ - -===== External toolchain wrapper - -When using an external toolchain, Buildroot generates a wrapper program, -that transparently passes the appropriate options (according to the -configuration) to the external toolchain programs. In case you need to -debug this wrapper to check exactly what arguments are passed, you can -set the environment variable +BR2_DEBUG_WRAPPER+ to either one of: - -* +0+, empty or not set: no debug - -* +1+: trace all arguments on a single line - -* +2+: trace one argument per line - -=== /dev management - -On a Linux system, the +/dev+ directory contains special files, called -_device files_, that allow userspace applications to access the -hardware devices managed by the Linux kernel. Without these _device -files_, your userspace applications would not be able to use the -hardware devices, even if they are properly recognized by the Linux -kernel. - -Under +System configuration+, +/dev management+, Buildroot offers four -different solutions to handle the +/dev+ directory : - - * The first solution is *Static using device table*. This is the old - classical way of handling device files in Linux. With this method, - the device files are persistently stored in the root filesystem - (i.e. they persist across reboots), and there is nothing that will - automatically create and remove those device files when hardware - devices are added or removed from the system. Buildroot therefore - creates a standard set of device files using a _device table_, the - default one being stored in +system/device_table_dev.txt+ in the - Buildroot source code. This file is processed when Buildroot - generates the final root filesystem image, and the _device files_ - are therefore not visible in the +output/target+ directory. The - +BR2_ROOTFS_STATIC_DEVICE_TABLE+ option allows to change the - default device table used by Buildroot, or to add an additional - device table, so that additional _device files_ are created by - Buildroot during the build. So, if you use this method, and a - _device file_ is missing in your system, you can for example create - a +board///device_table_dev.txt+ file - that contains the description of your additional _device files_, - and then you can set +BR2_ROOTFS_STATIC_DEVICE_TABLE+ to - +system/device_table_dev.txt - board///device_table_dev.txt+. For more - details about the format of the device table file, see - xref:makedev-syntax[]. - - * The second solution is *Dynamic using devtmpfs only*. _devtmpfs_ is - a virtual filesystem inside the Linux kernel that has been - introduced in kernel 2.6.32 (if you use an older kernel, it is not - possible to use this option). When mounted in +/dev+, this virtual - filesystem will automatically make _device files_ appear and - disappear as hardware devices are added and removed from the - system. This filesystem is not persistent across reboots: it is - filled dynamically by the kernel. Using _devtmpfs_ requires the - following kernel configuration options to be enabled: - +CONFIG_DEVTMPFS+ and +CONFIG_DEVTMPFS_MOUNT+. When Buildroot is in - charge of building the Linux kernel for your embedded device, it - makes sure that those two options are enabled. However, if you - build your Linux kernel outside of Buildroot, then it is your - responsibility to enable those two options (if you fail to do so, - your Buildroot system will not boot). - - * The third solution is *Dynamic using devtmpfs + mdev*. This method - also relies on the _devtmpfs_ virtual filesystem detailed above (so - the requirement to have +CONFIG_DEVTMPFS+ and - +CONFIG_DEVTMPFS_MOUNT+ enabled in the kernel configuration still - apply), but adds the +mdev+ userspace utility on top of it. +mdev+ - is a program part of BusyBox that the kernel will call every time a - device is added or removed. Thanks to the +/etc/mdev.conf+ - configuration file, +mdev+ can be configured to for example, set - specific permissions or ownership on a device file, call a script - or application whenever a device appears or disappear, - etc. Basically, it allows _userspace_ to react on device addition - and removal events. +mdev+ can for example be used to automatically - load kernel modules when devices appear on the system. +mdev+ is - also important if you have devices that require a firmware, as it - will be responsible for pushing the firmware contents to the - kernel. +mdev+ is a lightweight implementation (with fewer - features) of +udev+. For more details about +mdev+ and the syntax - of its configuration file, see - http://git.busybox.net/busybox/tree/docs/mdev.txt. - - * The fourth solution is *Dynamic using devtmpfs + eudev*. This - method also relies on the _devtmpfs_ virtual filesystem detailed - above, but adds the +eudev+ userspace daemon on top of it. +eudev+ - is a daemon that runs in the background, and gets called by the - kernel when a device gets added or removed from the system. It is a - more heavyweight solution than +mdev+, but provides higher - flexibility. +eudev+ is a standalone version of +udev+, the - original userspace daemon used in most desktop Linux distributions, - which is now part of Systemd. For more details, see - http://en.wikipedia.org/wiki/Udev. - -The Buildroot developers recommendation is to start with the *Dynamic -using devtmpfs only* solution, until you have the need for userspace -to be notified when devices are added/removed, or if firmwares are -needed, in which case *Dynamic using devtmpfs + mdev* is usually a -good solution. - -Note that if +systemd+ is chosen as init system, /dev management will -be performed by the +udev+ program provided by +systemd+. - -=== init system - -The _init_ program is the first userspace program started by the -kernel (it carries the PID number 1), and is responsible for starting -the userspace services and programs (for example: web server, -graphical applications, other network servers, etc.). - -Buildroot allows to use three different types of init systems, which -can be chosen from +System configuration+, +Init system+: - - * The first solution is *BusyBox*. Amongst many programs, BusyBox has - an implementation of a basic +init+ program, which is sufficient - for most embedded systems. Enabling the +BR2_INIT_BUSYBOX+ will - ensure BusyBox will build and install its +init+ program. This is - the default solution in Buildroot. The BusyBox +init+ program will - read the +/etc/inittab+ file at boot to know what to do. The syntax - of this file can be found in - http://git.busybox.net/busybox/tree/examples/inittab (note that - BusyBox +inittab+ syntax is special: do not use a random +inittab+ - documentation from the Internet to learn about BusyBox - +inittab+). The default +inittab+ in Buildroot is stored in - +system/skeleton/etc/inittab+. Apart from mounting a few important - filesystems, the main job the default inittab does is to start the - +/etc/init.d/rcS+ shell script, and start a +getty+ program (which - provides a login prompt). - - * The second solution is *systemV*. This solution uses the old - traditional _sysvinit_ program, packed in Buildroot in - +package/sysvinit+. This was the solution used in most desktop - Linux distributions, until they switched to more recent - alternatives such as Upstart or Systemd. +sysvinit+ also works with - an +inittab+ file (which has a slightly different syntax than the - one from BusyBox). The default +inittab+ installed with this init - solution is located in +package/sysvinit/inittab+. - - * The third solution is *systemd*. +systemd+ is the new generation - init system for Linux. It does far more than traditional _init_ - programs: aggressive parallelization capabilities, uses socket and - D-Bus activation for starting services, offers on-demand starting - of daemons, keeps track of processes using Linux control groups, - supports snapshotting and restoring of the system state, - etc. +systemd+ will be useful on relatively complex embedded - systems, for example the ones requiring D-Bus and services - communicating between each other. It is worth noting that +systemd+ - brings a fairly big number of large dependencies: +dbus+, +udev+ - and more. For more details about +systemd+, see - http://www.freedesktop.org/wiki/Software/systemd. - -The solution recommended by Buildroot developers is to use the -*BusyBox init* as it is sufficient for most embedded -systems. *systemd* can be used for more complex situations. + diff --git a/docs/manual/contribute.txt b/docs/manual/contribute.txt deleted file mode 100644 index bf2aed6b51..0000000000 --- a/docs/manual/contribute.txt +++ /dev/null @@ -1,712 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== Contributing to Buildroot - -There are many ways in which you can contribute to Buildroot: analyzing -and fixing bugs, analyzing and fixing package build failures detected by -the autobuilders, testing and reviewing patches sent by other -developers, working on the items in our TODO list and sending your own -improvements to Buildroot or its manual. The following sections give a -little more detail on each of these items. - -If you are interested in contributing to Buildroot, the first thing you -should do is to subscribe to the Buildroot mailing list. This list is -the main way of interacting with other Buildroot developers and to send -contributions to. If you aren't subscribed yet, then refer to -xref:community-resources[] for the subscription link. - -If you are going to touch the code, it is highly recommended to use a -git repository of Buildroot, rather than starting from an extracted -source code tarball. Git is the easiest way to develop from and directly -send your patches to the mailing list. Refer to xref:getting-buildroot[] -for more information on obtaining a Buildroot git tree. - -=== Reproducing, analyzing and fixing bugs - -A first way of contributing is to have a look at the open bug reports in -the https://bugs.buildroot.org/buglist.cgi?product=buildroot[Buildroot bug -tracker]. As we strive to keep the bug count as small as possible, all -help in reproducing, analyzing and fixing reported bugs is more than -welcome. Don't hesitate to add a comment to bug reports reporting your -findings, even if you don't yet see the full picture. - -=== Analyzing and fixing autobuild failures - -The Buildroot autobuilders are a set of build machines that continuously -run Buildroot builds based on random configurations. This is done for -all architectures supported by Buildroot, with various toolchains, and -with a random selection of packages. With the large commit activity on -Buildroot, these autobuilders are a great help in detecting problems -very early after commit. - -All build results are available at http://autobuild.buildroot.org[], -statistics are at http://autobuild.buildroot.org/stats.php[]. Every day, -an overview of all failed packages is sent to the mailing list. - -Detecting problems is great, but obviously these problems have to be -fixed as well. Your contribution is very welcome here! There are -basically two things that can be done: - -- Analyzing the problems. The daily summary mails do not contain details - about the actual failures: in order to see what's going on you have to - open the build log and check the last output. Having someone doing - this for all packages in the mail is very useful for other developers, - as they can make a quick initial analysis based on this output alone. - -- Fixing a problem. When fixing autobuild failures, you should follow - these steps: - . Check if you can reproduce the problem by building with the same - configuration. You can do this manually, or use the - http://git.buildroot.org/buildroot-test/tree/utils/br-reproduce-build[br-reproduce-build] - script that will automatically clone a Buildroot git repository, - checkout the correct revision, download and set the right - configuration, and start the build. - . Analyze the problem and create a fix. - . Verify that the problem is really fixed by starting from a clean - Buildroot tree and only applying your fix. - . Send the fix to the Buildroot mailing list (see - xref:submitting-patches[]). In case you created a patch against the - package sources, you should also send the patch upstream so that the - problem will be fixed in a later release, and the patch in Buildroot - can be removed. - In the commit message of a patch fixing an autobuild failure, add a - reference to the build result directory, as follows: ---------------------- -Fixes: http://autobuild.buildroot.org/results/51000a9d4656afe9e0ea6f07b9f8ed374c2e4069 ---------------------- - -=== Reviewing and testing patches - -With the amount of patches sent to the mailing list each day, the -maintainer has a very hard job to judge which patches are ready to apply -and which ones aren't. Contributors can greatly help here by reviewing -and testing these patches. - -In the review process, do not hesitate to respond to patch submissions -for remarks, suggestions or anything that will help everyone to -understand the patches and make them better. Please use internet -style replies in plain text emails when responding to patch -submissions. - -To indicate approval of a patch, there are three formal tags that keep -track of this approval. To add your tag to a patch, reply to it with the -approval tag below the original author's Signed-off-by line. These tags -will be picked up automatically by patchwork (see -xref:apply-patches-patchwork[]) and will be part of the commit log when -the patch is accepted. - -Tested-by:: Indicates that the patch has been tested successfully. - You are encouraged to specify what kind of testing you performed - (compile-test on architecture X and Y, runtime test on target A, - ...). This additional information helps other testers and the - maintainer. - -Reviewed-by:: Indicates that you code-reviewed the patch and did your - best in spotting problems, but you are not sufficiently familiar with - the area touched to provide an Acked-by tag. This means that there - may be remaining problems in the patch that would be spotted by - someone with more experience in that area. Should such problems be - detected, your Reviewed-by tag remains appropriate and you cannot - be blamed. - -Acked-by:: Indicates that you code-reviewed the patch and you are - familiar enough with the area touched to feel that the patch can be - committed as-is (no additional changes required). In case it later - turns out that something is wrong with the patch, your Acked-by could - be considered inappropriate. The difference between Acked-by and - Reviewed-by is thus mainly that you are prepared to take the blame on - Acked patches, but not on Reviewed ones. - -If you reviewed a patch and have comments on it, you should simply reply -to the patch stating these comments, without providing a Reviewed-by or -Acked-by tag. These tags should only be provided if you judge the patch -to be good as it is. - -It is important to note that neither Reviewed-by nor Acked-by imply -that testing has been performed. To indicate that you both reviewed and -tested the patch, provide two separate tags (Reviewed/Acked-by and -Tested-by). - -Note also that _any developer_ can provide Tested/Reviewed/Acked-by -tags, without exception, and we encourage everyone to do this. Buildroot -does not have a defined group of _core_ developers, it just so happens -that some developers are more active than others. The maintainer will -value tags according to the track record of their submitter. Tags -provided by a regular contributor will naturally be trusted more than -tags provided by a newcomer. As you provide tags more regularly, your -'trustworthiness' (in the eyes of the maintainer) will go up, but _any_ -tag provided is valuable. - -Buildroot's Patchwork website can be used to pull in patches for testing -purposes. Please see xref:apply-patches-patchwork[] for more -information on using Buildroot's Patchwork website to apply patches. - -[[apply-patches-patchwork]] -==== Applying Patches from Patchwork - -The main use of Buildroot's Patchwork website for a developer is for -pulling in patches into their local git repository for testing -purposes. - -When browsing patches in the patchwork management interface, an +mbox+ -link is provided at the top of the page. Copy this link address and -run the following commands: - ---------------------- -$ git checkout -b -$ wget -O - | git am ---------------------- - -Another option for applying patches is to create a bundle. A bundle is -a set of patches that you can group together using the patchwork -interface. Once the bundle is created and the bundle is made public, -you can copy the +mbox+ link for the bundle and apply the bundle -using the above commands. - - -=== Work on items from the TODO list - -If you want to contribute to Buildroot but don't know where to start, -and you don't like any of the above topics, you can always work on items -from the http://elinux.org/Buildroot#Todo_list[Buildroot TODO list]. -Don't hesitate to discuss an item first on the mailing list or on IRC. -Do edit the wiki to indicate when you start working on an item, so we -avoid duplicate efforts. - -[[submitting-patches]] -=== Submitting patches - -[NOTE] -_Please, do not attach patches to bugs, send them to the mailing list -instead_. - -If you made some changes to Buildroot and you would like to contribute -them to the Buildroot project, proceed as follows. - -==== The formatting of a patch - -We expect patches to be formatted in a specific way. This is necessary -to make it easy to review patches, to be able to apply them easily to -the git repository, to make it easy to find back in the history how -and why things have changed, and to make it possible to use +git -bisect+ to locate the origin of a problem. - -First of all, it is essential that the patch has a good commit -message. The commit message should start with a separate line with a -brief summary of the change, prefixed by the area touched by the -patch. A few examples of good commit titles: - -* +package/linuxptp: bump version to 2.0+ - -* +configs/imx23evk: bump Linux version to 4.19+ - -* +package/pkg-generic: postpone evaluation of dependency conditions+ - -* +boot/uboot: needs host-{flex,bison}+ - -* +support/testing: add python-ubjson tests+ - -The description that follows the prefix should start with a lower case -letter (i.e "bump", "needs", "postpone", "add" in the above examples). - -Second, the body of the commit message should describe _why_ this -change is needed, and if necessary also give details about _how_ it -was done. When writing the commit message, think of how the reviewers -will read it, but also think about how you will read it when you look -at this change again a few years down the line. - -Third, the patch itself should do only one change, but do it -completely. Two unrelated or weakly related changes should usually be -done in two separate patches. This usually means that a patch affects -only a single package. If several changes are related, it is often -still possible to split them up in small patches and apply them in a -specific order. Small patches make it easier to review, and often -make it easier to understand afterwards why a change was done. -However, each patch must be complete. It is not allowed that the -build is broken when only the first but not the second patch is -applied. This is necessary to be able to use +git bisect+ afterwards. - -Of course, while you're doing your development, you're probably going -back and forth between packages, and certainly not committing things -immediately in a way that is clean enough for submission. So most -developers rewrite the history of commits to produce a clean set of -commits that is appropriate for submission. To do this, you need to -use _interactive rebasing_. You can learn about it -https://git-scm.com/book/en/v2/Git-Tools-Rewriting-History[in the Pro -Git book]. Sometimes, it is even easier to discard you history with -+git reset --soft origin/master+ and select individual changes with -+git add -i+ or +git add -p+. - -Finally, the patch should be signed off. This is done by adding -+Signed-off-by: Your Real Name + at the end of the -commit message. +git commit -s+ does that for you, if configured -properly. The +Signed-off-by+ tag means that you publish the patch -under the Buildroot license (i.e. GPL-2.0+, except for package patches, -which have the upstream license), and that you are allowed to do so. -See http://developercertificate.org/[the Developer Certificate of -Origin] for details. - -When adding new packages, you should submit every package in a -separate patch. This patch should have the update to -+package/Config.in+, the package +Config.in+ file, the +.mk+ file, the -+.hash+ file, any init script, and all package patches. If the package -has many sub-options, these are sometimes better added as separate -follow-up patches. The summary line should be something like -+: new package+. The body of the commit message can be -empty for simple packages, or it can contain the description of the -package (like the Config.in help text). If anything special has to be -done to build the package, this should also be explained explicitly in -the commit message body. - -When you bump a package to a new version, you should also submit a -separate patch for each package. Don't forget to update the +.hash+ -file, or add it if it doesn't exist yet. Also don't forget to check if -the +_LICENSE+ and +_LICENSE_FILES+ are still valid. The summary line -should be something like +: bump to version +. If the new version only contains security updates compared -to the existing one, the summary should be +: security -bump to version + and the commit message body should show -the CVE numbers that are fixed. If some package patches can be removed -in the new version, it should be explained explicitly why they can be -removed, preferably with the upstream commit ID. Also any other -required changes should be explained explicitly, like configure -options that no longer exist or are no longer needed. - -If you are interested in getting notified of build failures and of -further changes in the packages you added or modified, please add -yourself to the DEVELOPERS file. This should be done in the same patch -creating or modifying the package. See xref:DEVELOPERS[the DEVELOPERS file] -for more information. - -Buildroot provides a handy tool to check for common coding style -mistakes on files you created or modified, called +check-package+ (see -xref:check-package[] for more information). - -==== Preparing a patch series - -Starting from the changes committed in your local git view, _rebase_ -your development branch on top of the upstream tree before generating -a patch set. To do so, run: - ---------------------- -$ git fetch --all --tags -$ git rebase origin/master ---------------------- - -Now, you are ready to generate then submit your patch set. - -To generate it, run: - ---------------------- -$ git format-patch -M -n -s -o outgoing origin/master ---------------------- - -This will generate patch files in the +outgoing+ subdirectory, -automatically adding the +Signed-off-by+ line. - -Once patch files are generated, you can review/edit the commit message -before submitting them, using your favorite text editor. - -Buildroot provides a handy tool to know to whom your patches should be -sent, called +get-developers+ (see xref:DEVELOPERS[] for more -information). This tool reads your patches and outputs the appropriate -+git send-email+ command to use: - ---------------------- -$ ./utils/get-developers outgoing/* ---------------------- - -Use the output of +get-developers+ to send your patches: - ---------------------- -$ git send-email --to buildroot@buildroot.org --cc bob --cc alice outgoing/* ---------------------- - -Alternatively, +get-developers -e+ can be used directly with the -+--cc-cmd+ argument to +git send-email+ to automatically CC the -affected developers: - ---------------------- -$ git send-email --to buildroot@buildroot.org \ - --cc-cmd './utils/get-developers -e' origin/master ---------------------- - -+git+ can be configured to automatically do this out of the box with: - ---------------------- -$ git config sendemail.to buildroot@buildroot.org -$ git config sendemail.ccCmd "$(pwd)/utils/get-developers -e" ---------------------- - -And then just do: - ---------------------- -$ git send-email origin/master ---------------------- - -Note that +git+ should be configured to use your mail account. -To configure +git+, see +man git-send-email+ or google it. - -If you do not use +git send-email+, make sure posted *patches are not -line-wrapped*, otherwise they cannot easily be applied. In such a case, -fix your e-mail client, or better yet, learn to use +git send-email+. - -==== Cover letter - -If you want to present the whole patch set in a separate mail, add -+--cover-letter+ to the +git format-patch+ command (see +man -git-format-patch+ for further information). This will generate a -template for an introduction e-mail to your patch series. - -A 'cover letter' may be useful to introduce the changes you propose -in the following cases: - -* large number of commits in the series; - -* deep impact of the changes in the rest of the project; - -* RFC footnote:[RFC: (Request for comments) change proposal]; - -* whenever you feel it will help presenting your work, your choices, - the review process, etc. - -==== Patches for maintenance branches - -When fixing bugs on a maintenance branch, bugs should be fixed on the -master branch first. The commit log for such a patch may then contain a -post-commit note specifying what branches are affected: - ----- -package/foo: fix stuff - -Signed-off-by: Your Real Name ---- -Backport to: 2020.02.x, 2020.05.x -(2020.08.x not affected as the version was bumped) ----- - -Those changes will then be backported by a maintainer to the affected -branches. - -However, some bugs may apply only to a specific release, for example -because it is using an older version of a package. In that case, patches -should be based off the maintenance branch, and the patch subject prefix -must include the maintenance branch name (for example "[PATCH 2020.02.x]"). -This can be done with the +git format-patch+ flag +--subject-prefix+: - ---------------------- -$ git format-patch --subject-prefix "PATCH 2020.02.x" \ - -M -s -o outgoing origin/2020.02.x ---------------------- - -Then send the patches with +git send-email+, as described above. - -==== Patch revision changelog - -When improvements are requested, the new revision of each commit -should include a changelog of the modifications between each -submission. Note that when your patch series is introduced by a cover -letter, an overall changelog may be added to the cover letter in -addition to the changelog in the individual commits. -The best thing to rework a patch series is by interactive rebasing: -+git rebase -i origin/master+. Consult the git manual for more -information. - -When added to the individual commits, this changelog is added when -editing the commit message. Below the +Signed-off-by+ section, add -+---+ and your changelog. - -Although the changelog will be visible for the reviewers in the mail -thread, as well as in http://patchwork.buildroot.org[patchwork], +git+ -will automatically ignores lines below +---+ when the patch will be -merged. This is the intended behavior: the changelog is not meant to -be preserved forever in the +git+ history of the project. - -Hereafter the recommended layout: - ---------------- -Patch title: short explanation, max 72 chars - -A paragraph that explains the problem, and how it manifests itself. If -the problem is complex, it is OK to add more paragraphs. All paragraphs -should be wrapped at 72 characters. - -A paragraph that explains the root cause of the problem. Again, more -than one paragraph is OK. - -Finally, one or more paragraphs that explain how the problem is solved. -Don't hesitate to explain complex solutions in detail. - -Signed-off-by: John DOE - ---- -Changes v2 -> v3: - - foo bar (suggested by Jane) - - bar buz - -Changes v1 -> v2: - - alpha bravo (suggested by John) - - charly delta ---------------- - -Any patch revision should include the version number. The version number -is simply composed of the letter +v+ followed by an +integer+ greater or -equal to two (i.e. "PATCH v2", "PATCH v3" ...). - -This can be easily handled with +git format-patch+ by using the option -+--subject-prefix+: - ---------------------- -$ git format-patch --subject-prefix "PATCH v4" \ - -M -s -o outgoing origin/master ---------------------- - -Since git version 1.8.1, you can also use +-v + (where is the -version number): - ---------------------- -$ git format-patch -v4 -M -s -o outgoing origin/master ---------------------- - -When you provide a new version of a patch, please mark the old one as -superseded in http://patchwork.buildroot.org[patchwork]. You need to -create an account on http://patchwork.buildroot.org[patchwork] to be -able to modify the status of your patches. Note that you can only change -the status of patches you submitted yourself, which means the email -address you register in http://patchwork.buildroot.org[patchwork] should -match the one you use for sending patches to the mailing list. - -You can also add the +--in-reply-to + option when -submitting a patch to the mailing list. The id of the mail to reply to -can be found under the "Message Id" tag on -http://patchwork.buildroot.org[patchwork]. The advantage of -*in-reply-to* is that patchwork will automatically mark the previous -version of the patch as superseded. - -[[reporting-bugs]] -=== Reporting issues/bugs or getting help - -Before reporting any issue, please check in -xref:community-resources[the mailing list archive] whether someone has -already reported and/or fixed a similar problem. - -However you choose to report bugs or get help, either by -opening a bug in the xref:community-resources[bug tracker] or by -xref:community-resources[sending a mail to the mailing list], there are -a number of details to provide in order to help people reproduce and -find a solution to the issue. - -Try to think as if you were trying to help someone else; in -that case, what would you need? - -Here is a short list of details to provide in such case: - -* host machine (OS/release) -* version of Buildroot -* target for which the build fails -* package(s) for which the build fails -* the command that fails and its output -* any information you think that may be relevant - -Additionally, you should add the +.config+ file (or if you know how, a -+defconfig+; see xref:customize-store-buildroot-config[]). - -If some of these details are too large, do not hesitate to use a -pastebin service. Note that not all available pastebin services will -preserve Unix-style line terminators when downloading raw pastes. -Following pastebin services are known to work correctly: -- https://gist.github.com/ -- http://code.bulix.org/ - -=== Using the runtime tests framework - -Buildroot includes a run-time testing framework built upon Python -scripting and QEMU runtime execution. The goals of the framework are -the following: - -* build a well defined Buildroot configuration -* optionally, verify some properties of the build output -* optionally, boot the build results under Qemu, and verify that a - given feature is working as expected - -The entry point to use the runtime tests framework is the -+support/testing/run-tests+ tool, which has a series of options -documented in the tool's help '-h' description. Some common options -include setting the download folder, the output folder, keeping build -output, and for multiple test cases, you can set the JLEVEL for each. - -Here is an example walk through of running a test case. - -* For a first step, let us see what all the test case options are. The test -cases can be listed by executing +support/testing/run-tests -l+. These tests -can all be run individually during test development from the console. Both -one at a time and selectively as a group of a subset of tests. - ---------------------- -$ support/testing/run-tests -l -List of tests -test_run (tests.utils.test_check_package.TestCheckPackage) -test_run (tests.toolchain.test_external.TestExternalToolchainBuildrootMusl) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainBuildrootuClibc) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainCCache) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainCtngMusl) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainLinaroArm) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv4) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv5) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv7) ... ok -[snip] -test_run (tests.init.test_systemd.TestInitSystemSystemdRoFull) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRoIfupdown) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRoNetworkd) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRwFull) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRwIfupdown) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRwNetworkd) ... ok -test_run (tests.init.test_busybox.TestInitSystemBusyboxRo) ... ok -test_run (tests.init.test_busybox.TestInitSystemBusyboxRoNet) ... ok -test_run (tests.init.test_busybox.TestInitSystemBusyboxRw) ... ok -test_run (tests.init.test_busybox.TestInitSystemBusyboxRwNet) ... ok - -Ran 157 tests in 0.021s - -OK ---------------------- - -* Then, to run one test case: - ---------------------- -$ support/testing/run-tests -d dl -o output_folder -k tests.init.test_busybox.TestInitSystemBusyboxRw -15:03:26 TestInitSystemBusyboxRw Starting -15:03:28 TestInitSystemBusyboxRw Building -15:08:18 TestInitSystemBusyboxRw Building done -15:08:27 TestInitSystemBusyboxRw Cleaning up -. -Ran 1 test in 301.140s - -OK ---------------------- - -The standard output indicates if the test is successful or not. By -default, the output folder for the test is deleted automatically -unless the option +-k+ is passed to *keep* the output directory. - -==== Creating a test case - -Within the Buildroot repository, the testing framework is organized at the -top level in +support/testing/+ by folders of +conf+, +infra+ and +tests+. -All the test cases live under the +tests+ folder and are organized in various -folders representing the category of test. - -The best way to get familiar with how to create a test case is to look -at a few of the basic file system +support/testing/tests/fs/+ and init -+support/testing/tests/init/+ test scripts. Those tests give good -examples of a basic tests that include both checking the build -results, and doing runtime tests. There are other more advanced cases -that use things like nested +br2-external+ folders to provide -skeletons and additional packages. - -Creating a basic test case involves: - -* Defining a test class that inherits from +infra.basetest.BRTest+ - -* Defining the +config+ member of the test class, to the Buildroot - configuration to build for this test case. It can optionally rely on - configuration snippets provided by the runtime test infrastructure: - +infra.basetest.BASIC_TOOLCHAIN_CONFIG+ to get a basic - architecture/toolchain configuration, and - +infra.basetest.MINIMAL_CONFIG+ to not build any filesystem. The - advantage of using +infra.basetest.BASIC_TOOLCHAIN_CONFIG+ is that a - matching Linux kernel image is provided, which allows to boot the - resulting image in Qemu without having to build a Linux kernel image - as part of the test case, therefore significant decreasing the build - time required for the test case. - -* Implementing a +def test_run(self):+ function to implement the - actual tests to run after the build has completed. They may be tests - that verify the build output, by running command on the host using - the +run_cmd_on_host()+ helper function. Or they may boot the - generated system in Qemu using the +Emulator+ object available as - +self.emulator+ in the test case. For example +self.emulator.boot()+ - allows to boot the system in Qemu, +self.emulator.login()+ allows to - login, +self.emulator.run()+ allows to run shell commands inside - Qemu. - -After creating the test script, add yourself to the +DEVELOPERS+ file to -be the maintainer of that test case. - -==== Debugging a test case - -When a test case runs, the +output_folder+ will contain the following: - ---------------------- -$ ls output_folder/ -TestInitSystemBusyboxRw/ -TestInitSystemBusyboxRw-build.log -TestInitSystemBusyboxRw-run.log ---------------------- - -+TestInitSystemBusyboxRw/+ is the Buildroot output directory, and it -is preserved only if the +-k+ option is passed. - -+TestInitSystemBusyboxRw-build.log+ is the log of the Buildroot build. - -+TestInitSystemBusyboxRw-run.log+ is the log of the Qemu boot and -test. This file will only exist if the build was successful and the -test case involves booting under Qemu. - -If you want to manually run Qemu to do manual tests of the build -result, the first few lines of +TestInitSystemBusyboxRw-run.log+ -contain the Qemu command line to use. - -You can also make modifications to the current sources inside the -+output_folder+ (e.g. for debug purposes) and rerun the standard -Buildroot make targets (in order to regenerate the complete image with -the new modifications) and then rerun the test. - -==== Runtime tests and Gitlab CI - -All runtime tests are regularly executed by Buildroot Gitlab CI -infrastructure, see .gitlab.yml and -https://gitlab.com/buildroot.org/buildroot/-/jobs. - -You can also use Gitlab CI to test your new test cases, or verify that -existing tests continue to work after making changes in Buildroot. - -In order to achieve this, you need to create a fork of the Buildroot -project on Gitlab, and be able to push branches to your Buildroot fork -on Gitlab. - -The name of the branch that you push will determine if a Gitlab CI -pipeline will be triggered or not, and for which test cases. - -In the examples below, the component of the branch name is an -arbitrary string you choose. - -* To trigger all run-test test case jobs, push a branch that ends with - +-runtime-tests+: - ---------------------- - $ git push gitlab HEAD:-runtime-tests ---------------------- - -* To trigger one or several test case jobs, push a branch that ends - with the complete test case name - (+tests.init.test_busybox.TestInitSystemBusyboxRo+) or with the name - of a category of tests (+tests.init.test_busybox+): - ---------------------- - $ git push gitlab HEAD:- ---------------------- - -Example to run one test: - ---------------------- - $ git push gitlab HEAD:foo-tests.init.test_busybox.TestInitSystemBusyboxRo ---------------------- - -Examples to run several tests part of the same group: - ---------------------- - $ git push gitlab HEAD:foo-tests.init.test_busybox - $ git push gitlab HEAD:foo-tests.init ---------------------- diff --git a/docs/manual/customize-configuration.txt b/docs/manual/customize-configuration.txt deleted file mode 100644 index ae6cebe6c4..0000000000 --- a/docs/manual/customize-configuration.txt +++ /dev/null @@ -1,64 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[customize-store-buildroot-config]] -=== Storing the Buildroot configuration - -The Buildroot configuration can be stored using the command - +make savedefconfig+. - -This strips the Buildroot configuration down by removing configuration -options that are at their default value. The result is stored in a file -called +defconfig+. If you want to save it in another place, change the -+BR2_DEFCONFIG+ option in the Buildroot configuration itself, or call -make with +make savedefconfig BR2_DEFCONFIG=+. - -The recommended place to store this defconfig is -+configs/_defconfig+. If you follow this recommendation, the -configuration will be listed in +make help+ and can be set again by -running +make _defconfig+. - -Alternatively, you can copy the file to any other place and rebuild with -+make defconfig BR2_DEFCONFIG=+. - -[[customize-store-package-config]] -=== Storing the configuration of other components - -The configuration files for BusyBox, the Linux kernel, Barebox, U-Boot -and uClibc should be stored as well if changed. For each of these -components, a Buildroot configuration option exists to point to an input -configuration file, e.g. +BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE+. To store -their configuration, set these configuration options to a path where you -want to save the configuration files, and then use the helper targets -described below to actually store the configuration. - -As explained in xref:customize-dir-structure[], the recommended path to -store these configuration files is -+board///foo.config+. - -Make sure that you create a configuration file 'before' changing -the +BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE+ etc. options. Otherwise, -Buildroot will try to access this config file, which doesn't exist -yet, and will fail. You can create the configuration file by running -+make linux-menuconfig+ etc. - -Buildroot provides a few helper targets to make the saving of -configuration files easier. - -* +make linux-update-defconfig+ saves the linux configuration to the - path specified by +BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE+. It - simplifies the config file by removing default values. However, - this only works with kernels starting from 2.6.33. For earlier - kernels, use +make linux-update-config+. -* +make busybox-update-config+ saves the busybox configuration to the - path specified by +BR2_PACKAGE_BUSYBOX_CONFIG+. -* +make uclibc-update-config+ saves the uClibc configuration to the - path specified by +BR2_UCLIBC_CONFIG+. -* +make barebox-update-defconfig+ saves the barebox configuration to the - path specified by +BR2_TARGET_BAREBOX_CUSTOM_CONFIG_FILE+. -* +make uboot-update-defconfig+ saves the U-Boot configuration to the - path specified by +BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE+. -* For at91bootstrap3, no helper exists so you have to copy the config - file manually to +BR2_TARGET_AT91BOOTSTRAP3_CUSTOM_CONFIG_FILE+. - - diff --git a/docs/manual/customize-device-permission-tables.txt b/docs/manual/customize-device-permission-tables.txt deleted file mode 100644 index 02dd8ad982..0000000000 --- a/docs/manual/customize-device-permission-tables.txt +++ /dev/null @@ -1,30 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[customize-device-permission]] -==== Setting file permissions and ownership and adding custom devices nodes - -Sometimes it is needed to set specific permissions or ownership on files -or device nodes. For example, certain files may need to be owned by -root. Since the post-build scripts are not run as root, you cannot do -such changes from there unless you use an explicit fakeroot from the -post-build script. - -Instead, Buildroot provides support for so-called _permission tables_. -To use this feature, set config option +BR2_ROOTFS_DEVICE_TABLE+ to a -space-separated list of permission tables, regular text files following -the xref:makedev-syntax[makedev syntax]. - -If you are using a static device table (i.e. not using +devtmpfs+, -+mdev+, or +(e)udev+) then you can add device nodes using the same -syntax, in so-called _device tables_. To use this feature, set config -option +BR2_ROOTFS_STATIC_DEVICE_TABLE+ to a space-separated list of -device tables. - -As shown in xref:customize-dir-structure[], the recommended location for -such files is +board///+. - -It should be noted that if the specific permissions or device nodes are -related to a specific application, you should set variables -+FOO_PERMISSIONS+ and +FOO_DEVICES+ in the package's +.mk+ file instead -(see xref:generic-package-reference[]). diff --git a/docs/manual/customize-directory-structure.txt b/docs/manual/customize-directory-structure.txt deleted file mode 100644 index a3a7ad4cb9..0000000000 --- a/docs/manual/customize-directory-structure.txt +++ /dev/null @@ -1,111 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[customize-dir-structure]] -=== Recommended directory structure - -When customizing Buildroot for your project, you will be creating one or -more project-specific files that need to be stored somewhere. While most -of these files could be placed in _any_ location as their path is to be -specified in the Buildroot configuration, the Buildroot developers -recommend a specific directory structure which is described in this -section. - -Orthogonal to this directory structure, you can choose _where_ you place -this structure itself: either inside the Buildroot tree, or outside of -it using a br2-external tree. Both options are valid, the choice is up -to you. - ------ -+-- board/ -| +-- / -| +-- / -| +-- linux.config -| +-- busybox.config -| +-- -| +-- post_build.sh -| +-- post_image.sh -| +-- rootfs_overlay/ -| | +-- etc/ -| | +-- -| +-- patches/ -| +-- foo/ -| | +-- -| +-- libbar/ -| +-- -| -+-- configs/ -| +-- _defconfig -| -+-- package/ -| +-- / -| +-- Config.in (if not using a br2-external tree) -| +-- .mk (if not using a br2-external tree) -| +-- package1/ -| | +-- Config.in -| | +-- package1.mk -| +-- package2/ -| +-- Config.in -| +-- package2.mk -| -+-- Config.in (if using a br2-external tree) -+-- external.mk (if using a br2-external tree) -+-- external.desc (if using a br2-external tree) ------- - -Details on the files shown above are given further in this chapter. - -Note: if you choose to place this structure outside of the Buildroot -tree but in a br2-external tree, the and possibly -components may be superfluous and can be left out. - -==== Implementing layered customizations - -It is quite common for a user to have several related projects that partly -need the same customizations. Instead of duplicating these -customizations for each project, it is recommended to use a layered -customization approach, as explained in this section. - -Almost all of the customization methods available in Buildroot, like -post-build scripts and root filesystem overlays, accept a -space-separated list of items. The specified items are always treated in -order, from left to right. By creating more than one such item, one for -the common customizations and another one for the really -project-specific customizations, you can avoid unnecessary duplication. -Each layer is typically embodied by a separate directory inside -+board//+. Depending on your projects, you could even introduce -more than two layers. - -An example directory structure for where a user has two customization -layers 'common' and 'fooboard' is: - ------ -+-- board/ - +-- / - +-- common/ - | +-- post_build.sh - | +-- rootfs_overlay/ - | | +-- ... - | +-- patches/ - | +-- ... - | - +-- fooboard/ - +-- linux.config - +-- busybox.config - +-- - +-- post_build.sh - +-- rootfs_overlay/ - | +-- ... - +-- patches/ - +-- ... ------ - -For example, if the user has the +BR2_GLOBAL_PATCH_DIR+ configuration -option set as: - ------ -BR2_GLOBAL_PATCH_DIR="board//common/patches board//fooboard/patches" ------ - -then first the patches from the 'common' layer would be applied, -followed by the patches from the 'fooboard' layer. diff --git a/docs/manual/customize-outside-br.txt b/docs/manual/customize-outside-br.txt deleted file mode 100644 index 348f2b089c..0000000000 --- a/docs/manual/customize-outside-br.txt +++ /dev/null @@ -1,446 +0,0 @@ -// -*- mode:doc -*- ; -// vim: set syntax=asciidoc: - -[[outside-br-custom]] -=== Keeping customizations outside of Buildroot - -As already briefly mentioned in xref:customize-dir-structure[], you can -place project-specific customizations in two locations: - - * directly within the Buildroot tree, typically maintaining them using - branches in a version control system so that upgrading to a newer - Buildroot release is easy. - - * outside of the Buildroot tree, using the _br2-external_ mechanism. - This mechanism allows to keep package recipes, board support and - configuration files outside of the Buildroot tree, while still - having them nicely integrated in the build logic. We call this - location a _br2-external tree_. This section explains how to use - the br2-external mechanism and what to provide in a br2-external - tree. - -One can tell Buildroot to use one or more br2-external trees by setting -the +BR2_EXTERNAL+ make variable set to the path(s) of the br2-external -tree(s) to use. It can be passed to any Buildroot +make+ invocation. It -is automatically saved in the hidden +.br2-external.mk+ file in the output -directory. Thanks to this, there is no need to pass +BR2_EXTERNAL+ at -every +make+ invocation. It can however be changed at any time by -passing a new value, and can be removed by passing an empty value. - -.Note -The path to a br2-external tree can be either absolute or relative. -If it is passed as a relative path, it is important to note that it is -interpreted relative to the main Buildroot source directory, *not* to -the Buildroot output directory. - -.Note: -If using an br2-external tree from before Buildroot 2016.11, you need to -convert it before you can use it with Buildroot 2016.11 onward. See -xref:br2-external-converting[] for help on doing so. - -Some examples: - ------ -buildroot/ $ make BR2_EXTERNAL=/path/to/foo menuconfig ------ - -From now on, definitions from the +/path/to/foo+ br2-external tree -will be used: - ------ -buildroot/ $ make -buildroot/ $ make legal-info ------ - -We can switch to another br2-external tree at any time: - ------ -buildroot/ $ make BR2_EXTERNAL=/where/we/have/bar xconfig ------ - -We can also use multiple br2-external trees: - ----- -buildroot/ $ make BR2_EXTERNAL=/path/to/foo:/where/we/have/bar menuconfig ----- - -Or disable the usage of any br2-external tree: - ------ -buildroot/ $ make BR2_EXTERNAL= xconfig ------ - -==== Layout of a br2-external tree - -A br2-external tree must contain at least those three files, described -in the following chapters: - - * +external.desc+ - * +external.mk+ - * +Config.in+ - -Apart from those mandatory files, there may be additional and optional -content that may be present in a br2-external tree, like the +configs/+ -or +provides/+ directories. They are described in the following chapters -as well. - -A complete example br2-external tree layout is also described later. - -===== The +external.desc+ file - -That file describes the br2-external tree: the _name_ and _description_ -for that br2-external tree. - -The format for this file is line based, with each line starting by a -keyword, followed by a colon and one or more spaces, followed by the -value assigned to that keyword. There are two keywords currently -recognised: - - * +name+, mandatory, defines the name for that br2-external tree. That - name must only use ASCII characters in the set +[A-Za-z0-9_]+; any - other character is forbidden. Buildroot sets the variable - +BR2_EXTERNAL_$(NAME)_PATH+ to the absolute path of the br2-external - tree, so that you can use it to refer to your br2-external tree. This - variable is available both in Kconfig, so you can use it to source your - Kconfig files (see below) and in the Makefile, so that you can use it - to include other Makefiles (see below) or refer to other files (like - data files) from your br2-external tree. -+ -.Note: -Since it is possible to use multiple br2-external trees at once, this - name is used by Buildroot to generate variables for each of those trees. - That name is used to identify your br2-external tree, so try to come up - with a name that really describes your br2-external tree, in order for - it to be relatively unique, so that it does not clash with another name - from another br2-external tree, especially if you are planning on - somehow sharing your br2-external tree with third parties or using - br2-external trees from third parties. - - * +desc+, optional, provides a short description for that br2-external - tree. It shall fit on a single line, is mostly free-form (see below), - and is used when displaying information about a br2-external tree (e.g. - above the list of defconfig files, or as the prompt in the menuconfig); - as such, it should relatively brief (40 chars is probably a good upper - limit). The description is available in the +BR2_EXTERNAL_$(NAME)_DESC+ - variable. - -Examples of names and the corresponding +BR2_EXTERNAL_$(NAME)_PATH+ -variables: - - * +FOO+ -> +BR2_EXTERNAL_FOO_PATH+ - * +BAR_42+ -> +BR2_EXTERNAL_BAR_42_PATH+ - -In the following examples, it is assumed the name to be set to +BAR_42+. - -.Note: -Both +BR2_EXTERNAL_$(NAME)_PATH+ and `BR2_EXTERNAL_$(NAME)_DESC` are - available in the Kconfig files and the Makefiles. They are also - exported in the environment so are available in post-build, post-image - and in-fakeroot scripts. - -===== The +Config.in+ and +external.mk+ files - -Those files (which may each be empty) can be used to define package -recipes (i.e. +foo/Config.in+ and +foo/foo.mk+ like for packages bundled -in Buildroot itself) or other custom configuration options or make logic. - -Buildroot automatically includes the +Config.in+ from each br2-external -tree to make it appear in the top-level configuration menu, and includes -the +external.mk+ from each br2-external tree with the rest of the -makefile logic. - -The main usage of this is to store package recipes. The recommended way -to do this is to write a +Config.in+ file that looks like: - ------- -source "$BR2_EXTERNAL_BAR_42_PATH/package/package1/Config.in" -source "$BR2_EXTERNAL_BAR_42_PATH/package/package2/Config.in" ------- - -Then, have an +external.mk+ file that looks like: - ------- -include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/package/*/*.mk)) ------- - -And then in +$(BR2_EXTERNAL_BAR_42_PATH)/package/package1+ and -+$(BR2_EXTERNAL_BAR_42_PATH)/package/package2+ create normal -Buildroot package recipes, as explained in xref:adding-packages[]. -If you prefer, you can also group the packages in subdirectories -called and adapt the above paths accordingly. - -You can also define custom configuration options in +Config.in+ and -custom make logic in +external.mk+. - -===== The +configs/+ directory - -One can store Buildroot defconfigs in the +configs+ subdirectory of -the br2-external tree. Buildroot will automatically show them in the -output of +make list-defconfigs+ and allow them to be loaded with the -normal +make _defconfig+ command. They will be visible in the -'make list-defconfigs' output, below an +External configs+ label that -contains the name of the br2-external tree they are defined in. - -.Note: -If a defconfig file is present in more than one br2-external tree, then -the one from the last br2-external tree is used. It is thus possible -to override a defconfig bundled in Buildroot or another br2-external -tree. - -===== The +provides/+ directory - -For some packages, Buildroot provides a choice between two (or more) -implementations of API-compatible such packages. For example, there is -a choice to choose either libjpeg ot jpeg-turbo; there is one between -openssl or libressl; there is one to select one of the known, -pre-configured toolchains... - -It is possible for a br2-external to extend those choices, by providing -a set of files that define those alternatives: - -* +provides/toolchains.in+ defines the pre-configured toolchains, which - will then be listed in the toolchain selection; -* +provides/jpeg.in+ defines the alternative libjpeg implementations; -* +provides/openssl.in+ defines the alternative openssl implementations; -* +provides/skeleton.in+ defines the alternative skeleton implementations; -* +provides/init.in+ defines the alternative init system implementations, this - can be used to select a default skeleton for your init. - -===== Free-form content - -One can store all the board-specific configuration files there, such -as the kernel configuration, the root filesystem overlay, or any other -configuration file for which Buildroot allows to set the location (by -using the +BR2_EXTERNAL_$(NAME)_PATH+ variable). For example, you -could set the paths to a global patch directory, to a rootfs overlay -and to the kernel configuration file as follows (e.g. by running -`make menuconfig` and filling in these options): - ----- -BR2_GLOBAL_PATCH_DIR=$(BR2_EXTERNAL_BAR_42_PATH)/patches/ -BR2_ROOTFS_OVERLAY=$(BR2_EXTERNAL_BAR_42_PATH)/board//overlay/ -BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=$(BR2_EXTERNAL_BAR_42_PATH)/board//kernel.config ----- - -===== Additional Linux kernel extensions - -Additional Linux kernel extensions (see xref:linux-kernel-ext[]) can -be added by storing them in the `linux/` directory at the root of a -br2-external tree. - -===== Example layout - -Here is an example layout using all features of br2-external (the sample -content is shown for the file above it, when it is relevant to explain -the br2-external tree; this is all entirely made up just for the sake of -illustration, of course): - ----- -/path/to/br2-ext-tree/ - |- external.desc - | |name: BAR_42 - | |desc: Example br2-external tree - | `---- - | - |- Config.in - | |source "$BR2_EXTERNAL_BAR_42_PATH/toolchain/toolchain-external-mine/Config.in.options" - | |source "$BR2_EXTERNAL_BAR_42_PATH/package/pkg-1/Config.in" - | |source "$BR2_EXTERNAL_BAR_42_PATH/package/pkg-2/Config.in" - | |source "$BR2_EXTERNAL_BAR_42_PATH/package/my-jpeg/Config.in" - | | - | |config BAR_42_FLASH_ADDR - | | hex "my-board flash address" - | | default 0x10AD - | `---- - | - |- external.mk - | |include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/package/*/*.mk)) - | |include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/toolchain/*/*.mk)) - | | - | |flash-my-board: - | | $(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/flash-image \ - | | --image $(BINARIES_DIR)/image.bin \ - | | --address $(BAR_42_FLASH_ADDR) - | `---- - | - |- package/pkg-1/Config.in - | |config BR2_PACKAGE_PKG_1 - | | bool "pkg-1" - | | help - | | Some help about pkg-1 - | `---- - |- package/pkg-1/pkg-1.hash - |- package/pkg-1/pkg-1.mk - | |PKG_1_VERSION = 1.2.3 - | |PKG_1_SITE = /some/where/to/get/pkg-1 - | |PKG_1_LICENSE = blabla - | | - | |define PKG_1_INSTALL_INIT_SYSV - | | $(INSTALL) -D -m 0755 $(PKG_1_PKGDIR)/S99my-daemon \ - | | $(TARGET_DIR)/etc/init.d/S99my-daemon - | |endef - | | - | |$(eval $(autotools-package)) - | `---- - |- package/pkg-1/S99my-daemon - | - |- package/pkg-2/Config.in - |- package/pkg-2/pkg-2.hash - |- package/pkg-2/pkg-2.mk - | - |- provides/jpeg.in - | |config BR2_PACKAGE_MY_JPEG - | | bool "my-jpeg" - | `---- - |- package/my-jpeg/Config.in - | |config BR2_PACKAGE_PROVIDES_JPEG - | | default "my-jpeg" if BR2_PACKAGE_MY_JPEG - | `---- - |- package/my-jpeg/my-jpeg.mk - | |# This is a normal package .mk file - | |MY_JPEG_VERSION = 1.2.3 - | |MY_JPEG_SITE = https://example.net/some/place - | |MY_JPEG_PROVIDES = jpeg - | |$(eval $(autotools-package)) - | `---- - | - |- provides/init.in - | |config BR2_INIT_MINE - | | bool "my custom init" - | | select BR2_PACKAGE_MY_INIT - | | select BR2_PACKAGE_SKELETON_INIT_MINE if BR2_ROOTFS_SKELETON_DEFAULT - | `---- - | - |- provides/skeleton.in - | |config BR2_ROOTFS_SKELETON_MINE - | | bool "my custom skeleton" - | | select BR2_PACKAGE_SKELETON_MINE - | `---- - |- package/skeleton-mine/Config.in - | |config BR2_PACKAGE_SKELETON_MINE - | | bool - | | select BR2_PACKAGE_HAS_SKELETON - | | - | |config BR2_PACKAGE_PROVIDES_SKELETON - | | default "skeleton-mine" if BR2_PACKAGE_SKELETON_MINE - | `---- - |- package/skeleton-mine/skeleton-mine.mk - | |SKELETON_MINE_ADD_TOOLCHAIN_DEPENDENCY = NO - | |SKELETON_MINE_ADD_SKELETON_DEPENDENCY = NO - | |SKELETON_MINE_PROVIDES = skeleton - | |SKELETON_MINE_INSTALL_STAGING = YES - | |$(eval $(generic-package)) - | `---- - | - |- provides/toolchains.in - | |config BR2_TOOLCHAIN_EXTERNAL_MINE - | | bool "my custom toolchain" - | | depends on BR2_some_arch - | | select BR2_INSTALL_LIBSTDCPP - | `---- - |- toolchain/toolchain-external-mine/Config.in.options - | |if BR2_TOOLCHAIN_EXTERNAL_MINE - | |config BR2_TOOLCHAIN_EXTERNAL_PREFIX - | | default "arch-mine-linux-gnu" - | |config BR2_PACKAGE_PROVIDES_TOOLCHAIN_EXTERNAL - | | default "toolchain-external-mine" - | |endif - | `---- - |- toolchain/toolchain-external-mine/toolchain-external-mine.mk - | |TOOLCHAIN_EXTERNAL_MINE_SITE = https://example.net/some/place - | |TOOLCHAIN_EXTERNAL_MINE_SOURCE = my-toolchain.tar.gz - | |$(eval $(toolchain-external-package)) - | `---- - | - |- linux/Config.ext.in - | |config BR2_LINUX_KERNEL_EXT_EXAMPLE_DRIVER - | | bool "example-external-driver" - | | help - | | Example external driver - | |--- - |- linux/linux-ext-example-driver.mk - | - |- configs/my-board_defconfig - | |BR2_GLOBAL_PATCH_DIR="$(BR2_EXTERNAL_BAR_42_PATH)/patches/" - | |BR2_ROOTFS_OVERLAY="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/overlay/" - | |BR2_ROOTFS_POST_IMAGE_SCRIPT="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/post-image.sh" - | |BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/kernel.config" - | `---- - | - |- patches/linux/0001-some-change.patch - |- patches/linux/0002-some-other-change.patch - |- patches/busybox/0001-fix-something.patch - | - |- board/my-board/kernel.config - |- board/my-board/overlay/var/www/index.html - |- board/my-board/overlay/var/www/my.css - |- board/my-board/flash-image - `- board/my-board/post-image.sh - |#!/bin/sh - |generate-my-binary-image \ - | --root ${BINARIES_DIR}/rootfs.tar \ - | --kernel ${BINARIES_DIR}/zImage \ - | --dtb ${BINARIES_DIR}/my-board.dtb \ - | --output ${BINARIES_DIR}/image.bin - `---- ----- - -The br2-external tree will then be visible in the menuconfig (with -the layout expanded): - ----- -External options ---> - *** Example br2-external tree (in /path/to/br2-ext-tree/) - [ ] pkg-1 - [ ] pkg-2 - (0x10AD) my-board flash address ----- - -If you are using more than one br2-external tree, it would look like -(with the layout expanded and the second one with name +FOO_27+ but no -+desc:+ field in +external.desc+): - ----- -External options ---> - Example br2-external tree ---> - *** Example br2-external tree (in /path/to/br2-ext-tree) - [ ] pkg-1 - [ ] pkg-2 - (0x10AD) my-board flash address - FOO_27 ---> - *** FOO_27 (in /path/to/another-br2-ext) - [ ] foo - [ ] bar ----- - -Additionally, the jpeg provider will be visible in the jpeg choice: - ----- -Target packages ---> - Libraries ---> - Graphics ---> - [*] jpeg support - jpeg variant () ---> - ( ) jpeg - ( ) jpeg-turbo - *** jpeg from: Example br2-external tree *** - (X) my-jpeg - *** jpeg from: FOO_27 *** - ( ) another-jpeg ----- - -And similarly for the toolchains: - ----- -Toolchain ---> - Toolchain () ---> - ( ) Custom toolchain - *** Toolchains from: Example br2-external tree *** - (X) my custom toolchain ----- - -.Note -The toolchain options in +toolchain/toolchain-external-mine/Config.in.options+ -will not appear in the `Toolchain` menu. They must be explicitly included -from within the br2-external's top-level +Config.in+ and will thus appear -in the `External options` menu. diff --git a/docs/manual/customize-packages.txt b/docs/manual/customize-packages.txt deleted file mode 100644 index b57280ea10..0000000000 --- a/docs/manual/customize-packages.txt +++ /dev/null @@ -1,56 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[customize-packages]] -=== Adding project-specific packages - -In general, any new package should be added directly in the +package+ -directory and submitted to the Buildroot upstream project. How to add -packages to Buildroot in general is explained in full detail in -xref:adding-packages[] and will not be repeated here. However, your -project may need some proprietary packages that cannot be upstreamed. -This section will explain how you can keep such project-specific -packages in a project-specific directory. - -As shown in xref:customize-dir-structure[], the recommended location for -project-specific packages is +package//+. If you are using the -br2-external tree feature (see xref:outside-br-custom[]) the recommended -location is to put them in a sub-directory named +package/+ in your -br2-external tree. - -However, Buildroot will not be aware of the packages in this location, -unless we perform some additional steps. As explained in -xref:adding-packages[], a package in Buildroot basically consists of two -files: a +.mk+ file (describing how to build the package) and a -+Config.in+ file (describing the configuration options for this -package). - -Buildroot will automatically include the +.mk+ files in first-level -subdirectories of the +package+ directory (using the pattern -+package/\*/*.mk+). If we want Buildroot to include +.mk+ files from -deeper subdirectories (like +package//package1/+) then we -simply have to add a +.mk+ file in a first-level subdirectory that -includes these additional +.mk+ files. Therefore, create a file -+package//.mk+ with following contents (assuming you -have only one extra directory level below +package//+): - ------ -include $(sort $(wildcard package//*/*.mk)) ------ - -For the +Config.in+ files, create a file +package//Config.in+ -that includes the +Config.in+ files of all your packages. An exhaustive -list has to be provided since wildcards are not supported in the source command of kconfig. -For example: - ------ -source "package//package1/Config.in" -source "package//package2/Config.in" ------ - -Include this new file +package//Config.in+ from -+package/Config.in+, preferably in a company-specific menu to make -merges with future Buildroot versions easier. - -If using a br2-external tree, refer to xref:outside-br-custom[] for how -to fill in those files. diff --git a/docs/manual/customize-patches.txt b/docs/manual/customize-patches.txt deleted file mode 100644 index eb98d1bea2..0000000000 --- a/docs/manual/customize-patches.txt +++ /dev/null @@ -1,59 +0,0 @@ -// -*- mode:doc -*- ; -// vim: set syntax=asciidoc: - -[[customize-patches]] -=== Adding project-specific patches - -It is sometimes useful to apply 'extra' patches to packages - on top of -those provided in Buildroot. This might be used to support custom -features in a project, for example, or when working on a new -architecture. - -The +BR2_GLOBAL_PATCH_DIR+ configuration option can be used to specify -a space separated list of one or more directories containing package -patches. - -For a specific version ++ of a specific package -++, patches are applied from +BR2_GLOBAL_PATCH_DIR+ as -follows: - -. For every directory - ++ - that exists in - +BR2_GLOBAL_PATCH_DIR+, a ++ will be determined as - follows: -+ -* +///+ if the - directory exists. -+ -* Otherwise, +/+ if the directory - exists. - -. Patches will then be applied from a ++ as - follows: -+ -* If a +series+ file exists in the package directory, then patches are - applied according to the +series+ file; -+ -* Otherwise, patch files matching +*.patch+ are applied in - alphabetical order. So, to ensure they are applied in the right - order, it is highly recommended to name the patch files like this: - +-.patch+, where ++ refers to the - 'apply order'. - -For information about how patches are applied for a package, see -xref:patch-apply-order[] - -The +BR2_GLOBAL_PATCH_DIR+ option is the preferred method for -specifying a custom patch directory for packages. It can be used to -specify a patch directory for any package in buildroot. It should also -be used in place of the custom patch directory options that are -available for packages such as U-Boot and Barebox. By doing this, it -will allow a user to manage their patches from one top-level -directory. - -The exception to +BR2_GLOBAL_PATCH_DIR+ being the preferred method for -specifying custom patches is +BR2_LINUX_KERNEL_PATCH+. -+BR2_LINUX_KERNEL_PATCH+ should be used to specify kernel patches that -are available at a URL. *Note:* +BR2_LINUX_KERNEL_PATCH+ specifies kernel -patches that are applied after patches available in +BR2_GLOBAL_PATCH_DIR+, -as it is done from a post-patch hook of the Linux package. - diff --git a/docs/manual/customize-post-image.txt b/docs/manual/customize-post-image.txt deleted file mode 100644 index 5308093d06..0000000000 --- a/docs/manual/customize-post-image.txt +++ /dev/null @@ -1,38 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Customization _after_ the images have been created - -While post-build scripts (xref:rootfs-custom[]) are run _before_ -building the filesystem image, kernel and bootloader, *post-image -scripts* can be used to perform some specific actions _after_ all images -have been created. - -Post-image scripts can for example be used to automatically extract your -root filesystem tarball in a location exported by your NFS server, or -to create a special firmware image that bundles your root filesystem and -kernel image, or any other custom action required for your project. - -To enable this feature, specify a space-separated list of post-image -scripts in config option +BR2_ROOTFS_POST_IMAGE_SCRIPT+ (in the +System -configuration+ menu). If you specify a relative path, it will be -relative to the root of the Buildroot tree. - -Just like post-build scripts, post-image scripts are run with the main -Buildroot tree as current working directory. The path to the +images+ -output directory is passed as the first argument to each script. If the -config option +BR2_ROOTFS_POST_SCRIPT_ARGS+ is not empty, these -arguments will be passed to the script too. All the scripts will be -passed the exact same set of arguments, it is not possible to pass -different sets of arguments to each script. - -Again just like for the post-build scripts, the scripts have access to -the environment variables +BR2_CONFIG+, +HOST_DIR+, +STAGING_DIR+, -+TARGET_DIR+, +BUILD_DIR+, +BINARIES_DIR+, +CONFIG_DIR+ and -+BASE_DIR+. - -The post-image scripts will be executed as the user that executes -Buildroot, which should normally _not_ be the root user. Therefore, any -action requiring root permissions in one of these scripts will require -special handling (usage of fakeroot or sudo), which is left to the -script developer. diff --git a/docs/manual/customize-quick-guide.txt b/docs/manual/customize-quick-guide.txt deleted file mode 100644 index 627ecbacb1..0000000000 --- a/docs/manual/customize-quick-guide.txt +++ /dev/null @@ -1,66 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Quick guide to storing your project-specific customizations - -Earlier in this chapter, the different methods for making -project-specific customizations have been described. This section will -now summarize all this by providing step-by-step instructions to storing your -project-specific customizations. Clearly, the steps that are not relevant to -your project can be skipped. - -1. +make menuconfig+ to configure toolchain, packages and kernel. -1. +make linux-menuconfig+ to update the kernel config, similar for - other configuration like busybox, uclibc, ... -1. +mkdir -p board//+ -1. Set the following options to +board///.config+ - (as far as they are relevant): - * +BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE+ - * +BR2_PACKAGE_BUSYBOX_CONFIG+ - * +BR2_UCLIBC_CONFIG+ - * +BR2_TARGET_AT91BOOTSTRAP3_CUSTOM_CONFIG_FILE+ - * +BR2_TARGET_BAREBOX_CUSTOM_CONFIG_FILE+ - * +BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE+ -1. Write the configuration files: - * +make linux-update-defconfig+ - * +make busybox-update-config+ - * +make uclibc-update-config+ - * +cp /build/at91bootstrap3-*/.config - board///at91bootstrap3.config+ - * +make barebox-update-defconfig+ - * +make uboot-update-defconfig+ -1. Create +board///rootfs-overlay/+ and fill it - with additional files you need on your rootfs, e.g. - +board///rootfs-overlay/etc/inittab+. - Set +BR2_ROOTFS_OVERLAY+ - to +board///rootfs-overlay+. -1. Create a post-build script - +board///post_build.sh+. Set - +BR2_ROOTFS_POST_BUILD_SCRIPT+ to - +board///post_build.sh+ -1. If additional setuid permissions have to be set or device nodes have - to be created, create +board///device_table.txt+ - and add that path to +BR2_ROOTFS_DEVICE_TABLE+. -1. If additional user accounts have to be created, create - +board///users_table.txt+ and add that path - to +BR2_ROOTFS_USERS_TABLES+. -1. To add custom patches to certain packages, set +BR2_GLOBAL_PATCH_DIR+ - to +board///patches/+ and add your patches - for each package in a subdirectory named after the package. Each - patch should be called +--.patch+. -1. Specifically for the Linux kernel, there also exists the option - +BR2_LINUX_KERNEL_PATCH+ with as main advantage that it can also - download patches from a URL. If you do not need this, - +BR2_GLOBAL_PATCH_DIR+ is preferred. U-Boot, Barebox, at91bootstrap - and at91bootstrap3 also have separate options, but these do not - provide any advantage over +BR2_GLOBAL_PATCH_DIR+ and will likely be - removed in the future. -1. If you need to add project-specific packages, create - +package//+ and place your packages in that - directory. Create an overall +.mk+ file that - includes the +.mk+ files of all your packages. Create an overall - +Config.in+ file that sources the +Config.in+ files of all your - packages. Include this +Config.in+ file from Buildroot's - +package/Config.in+ file. -1. +make savedefconfig+ to save the buildroot configuration. -1. +cp defconfig configs/_defconfig+ diff --git a/docs/manual/customize-rootfs.txt b/docs/manual/customize-rootfs.txt deleted file mode 100644 index e46306fd2a..0000000000 --- a/docs/manual/customize-rootfs.txt +++ /dev/null @@ -1,156 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[rootfs-custom]] -=== Customizing the generated target filesystem - -Besides changing the configuration through +make *config+, -there are a few other ways to customize the resulting target filesystem. - -The two recommended methods, which can co-exist, are root filesystem -overlay(s) and post build script(s). - -Root filesystem overlays (+BR2_ROOTFS_OVERLAY+):: -+ -A filesystem overlay is a tree of files that is copied directly - over the target filesystem after it has been built. To enable this - feature, set config option +BR2_ROOTFS_OVERLAY+ (in the +System - configuration+ menu) to the root of the overlay. You can even specify - multiple overlays, space-separated. If you specify a relative path, - it will be relative to the root of the Buildroot tree. Hidden - directories of version control systems, like +.git+, +.svn+, +.hg+, - etc., files called +.empty+ and files ending in +~+ are excluded from - the copy. -+ -When +BR2_ROOTFS_MERGED_USR+ is enabled, then the overlay must not - contain the '/bin', '/lib' or '/sbin' directories, as Buildroot will - create them as symbolic links to the relevant folders in '/usr'. In - such a situation, should the overlay have any programs or libraries, - they should be placed in '/usr/bin', '/usr/sbin' and '/usr/lib'. -+ -As shown in xref:customize-dir-structure[], the recommended path for - this overlay is +board///rootfs-overlay+. - -Post-build scripts (+BR2_ROOTFS_POST_BUILD_SCRIPT+):: -+ -Post-build scripts are shell scripts called 'after' Buildroot builds - all the selected software, but 'before' the rootfs images are - assembled. To enable this feature, specify a space-separated list of - post-build scripts in config option +BR2_ROOTFS_POST_BUILD_SCRIPT+ (in - the +System configuration+ menu). If you specify a relative path, it - will be relative to the root of the Buildroot tree. -+ -Using post-build scripts, you can remove or modify any file in your - target filesystem. You should, however, use this feature with care. - Whenever you find that a certain package generates wrong or unneeded - files, you should fix that package rather than work around it with some - post-build cleanup scripts. -+ -As shown in xref:customize-dir-structure[], the recommended path for - this script is +board///post_build.sh+. -+ -The post-build scripts are run with the main Buildroot tree as current - working directory. The path to the target filesystem is passed as the - first argument to each script. If the config option - +BR2_ROOTFS_POST_SCRIPT_ARGS+ is not empty, these arguments will be - passed to the script too. All the scripts will be passed the exact - same set of arguments, it is not possible to pass different sets of - arguments to each script. -+ -In addition, you may also use these environment variables: - - - +BR2_CONFIG+: the path to the Buildroot .config file - - +CONFIG_DIR+: the directory containing the .config file, and - therefore the top-level Buildroot Makefile to use (which is - correct for both in-tree and out-of-tree builds) - - +HOST_DIR+, +STAGING_DIR+, +TARGET_DIR+: see - xref:generic-package-reference[] - - +BUILD_DIR+: the directory where packages are extracted and built - - +BINARIES_DIR+: the place where all binary files (aka images) are - stored - - +BASE_DIR+: the base output directory - -Below three more methods of customizing the target filesystem are -described, but they are not recommended. - -Direct modification of the target filesystem:: -+ -For temporary modifications, you can modify the target filesystem - directly and rebuild the image. The target filesystem is available - under +output/target/+. After making your changes, run +make+ to - rebuild the target filesystem image. -+ -This method allows you to do anything to the target filesystem, but if - you need to clean your Buildroot tree using +make clean+, these - changes will be lost. Such cleaning is necessary in several cases, - refer to xref:full-rebuild[] for details. This solution is therefore - only useful for quick tests: _changes do not survive the +make clean+ - command_. Once you have validated your changes, you should make sure - that they will persist after a +make clean+, using a root filesystem - overlay or a post-build script. - -Custom target skeleton (+BR2_ROOTFS_SKELETON_CUSTOM+):: -+ -The root filesystem image is created from a target skeleton, on top of - which all packages install their files. The skeleton is copied to the - target directory +output/target+ before any package is built and - installed. The default target skeleton provides the standard Unix - filesystem layout and some basic init scripts and configuration files. -+ -If the default skeleton (available under +system/skeleton+) does not - match your needs, you would typically use a root filesystem overlay or - post-build script to adapt it. However, if the default skeleton is - entirely different than what you need, using a custom skeleton may be - more suitable. -+ -To enable this feature, enable config option - +BR2_ROOTFS_SKELETON_CUSTOM+ and set +BR2_ROOTFS_SKELETON_CUSTOM_PATH+ - to the path of your custom skeleton. Both options are available in the - +System configuration+ menu. If you specify a relative path, it will - be relative to the root of the Buildroot tree. -+ -Custom skeletons don't need to contain the '/bin', '/lib' or '/sbin' - directories, since they are created automatically during the build. - When +BR2_ROOTFS_MERGED_USR+ is enabled, then the custom skeleton must - not contain the '/bin', '/lib' or '/sbin' directories, as Buildroot - will create them as symbolic links to the relevant folders in '/usr'. - In such a situation, should the skeleton have any programs or - libraries, they should be placed in '/usr/bin', '/usr/sbin' and - '/usr/lib'. -+ -This method is not recommended because it duplicates the entire - skeleton, which prevents taking advantage of the fixes or improvements - brought to the default skeleton in later Buildroot releases. - -Post-fakeroot scripts (+BR2_ROOTFS_POST_FAKEROOT_SCRIPT+):: -+ -When aggregating the final images, some parts of the process requires - root rights: creating device nodes in `/dev`, setting permissions or - ownership to files and directories... To avoid requiring actual root - rights, Buildroot uses +fakeroot+ to simulate root rights. This is not - a complete substitute for actually being root, but is enough for what - Buildroot needs. -+ -Post-fakeroot scripts are shell scripts that are called at the 'end' of - the fakeroot phase, 'right before' the filesystem image generator is - called. As such, they are called in the fakeroot context. -+ -Post-fakeroot scripts can be useful in case you need to tweak the - filesystem to do modifications that are usually only available to the - root user. -+ -.Note: -It is recommended to use the existing mechanisms to set file permissions - or create entries in `/dev` (see xref:customize-device-permission[]) or - to create users (see xref:customize-users[]) -+ -.Note: -The difference between post-build scripts (above) and fakeroot scripts, - is that post-build scripts are not called in the fakeroot context. -+ -.Note: -Using `fakeroot` is not an absolute substitute for actually being root. - `fakeroot` only ever fakes the file access rights and types (regular, - block-or-char device...) and uid/gid; these are emulated in-memory. - -include::customize-device-permission-tables.txt[] diff --git a/docs/manual/customize-users-tables.txt b/docs/manual/customize-users-tables.txt deleted file mode 100644 index e2d32e23f2..0000000000 --- a/docs/manual/customize-users-tables.txt +++ /dev/null @@ -1,18 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[customize-users]] -=== Adding custom user accounts - -Sometimes it is needed to add specific users in the target system. -To cover this requirement, Buildroot provides support for so-called -_users tables_. To use this feature, set config option -+BR2_ROOTFS_USERS_TABLES+ to a space-separated list of users tables, -regular text files following the xref:makeuser-syntax[makeusers syntax]. - -As shown in xref:customize-dir-structure[], the recommended location for -such files is +board///+. - -It should be noted that if the custom users are related to a specific -application, you should set variable +FOO_USERS+ in the package's +.mk+ -file instead (see xref:generic-package-reference[]). diff --git a/docs/manual/customize.txt b/docs/manual/customize.txt deleted file mode 100644 index 484413e4d8..0000000000 --- a/docs/manual/customize.txt +++ /dev/null @@ -1,60 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[customize]] -== Project-specific customization - -Typical actions you may need to perform for a given project are: - -* configuring Buildroot (including build options and toolchain, - bootloader, kernel, package and filesystem image type selection) -* configuring other components, like the Linux kernel and BusyBox -* customizing the generated target filesystem - ** adding or overwriting files on the target filesystem (using - +BR2_ROOTFS_OVERLAY+) - ** modifying or deleting files on the target filesystem (using - +BR2_ROOTFS_POST_BUILD_SCRIPT+) - ** running arbitrary commands prior to generating the filesystem image - (using +BR2_ROOTFS_POST_BUILD_SCRIPT+) - ** setting file permissions and ownership (using - +BR2_ROOTFS_DEVICE_TABLE+) - ** adding custom devices nodes (using - +BR2_ROOTFS_STATIC_DEVICE_TABLE+) -* adding custom user accounts (using +BR2_ROOTFS_USERS_TABLES+) -* running arbitrary commands after generating the filesystem image - (using +BR2_ROOTFS_POST_IMAGE_SCRIPT+) -* adding project-specific patches to some packages (using - +BR2_GLOBAL_PATCH_DIR+) -* adding project-specific packages - -An important note regarding such 'project-specific' customizations: -please carefully consider which changes are indeed project-specific and -which changes are also useful to developers outside your project. The -Buildroot community highly recommends and encourages the upstreaming of -improvements, packages and board support to the official Buildroot -project. Of course, it is sometimes not possible or desirable to -upstream because the changes are highly specific or proprietary. - -This chapter describes how to make such project-specific customizations -in Buildroot and how to store them in a way that you can build the same -image in a reproducible way, even after running 'make clean'. By -following the recommended strategy, you can even use the same Buildroot -tree to build multiple distinct projects! - -include::customize-directory-structure.txt[] - -include::customize-outside-br.txt[] - -include::customize-configuration.txt[] - -include::customize-rootfs.txt[] - -include::customize-users-tables.txt[] - -include::customize-post-image.txt[] - -include::customize-patches.txt[] - -include::customize-packages.txt[] - -include::customize-quick-guide.txt[] diff --git a/docs/manual/debugging-buildroot.txt b/docs/manual/debugging-buildroot.txt deleted file mode 100644 index f575fc48ee..0000000000 --- a/docs/manual/debugging-buildroot.txt +++ /dev/null @@ -1,43 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[debugging-buildroot]] - -== Debugging Buildroot - -It is possible to instrument the steps +Buildroot+ does when building -packages. Define the variable +BR2_INSTRUMENTATION_SCRIPTS+ to contain -the path of one or more scripts (or other executables), in a -space-separated list, you want called before and after each step. The -scripts are called in sequence, with three parameters: - - - +start+ or +end+ to denote the start (resp. the end) of a step; - - the name of the step about to be started, or which just ended; - - the name of the package. - -For example : - ----- -make BR2_INSTRUMENTATION_SCRIPTS="/path/to/my/script1 /path/to/my/script2" ----- - -The list of steps is: - - - +extract+ - - +patch+ - - +configure+ - - +build+ - - +install-host+, when a host-package is installed in +$(HOST_DIR)+ - - +install-target+, when a target-package is installed in +$(TARGET_DIR)+ - - +install-staging+, when a target-package is installed in +$(STAGING_DIR)+ - - +install-image+, when a target-package installs files in +$(BINARIES_DIR)+ - -The script has access to the following variables: - - - +BR2_CONFIG+: the path to the Buildroot .config file - - +HOST_DIR+, +STAGING_DIR+, +TARGET_DIR+: see - xref:generic-package-reference[] - - +BUILD_DIR+: the directory where packages are extracted and built - - +BINARIES_DIR+: the place where all binary files (aka images) are - stored - - +BASE_DIR+: the base output directory diff --git a/docs/manual/developers.txt b/docs/manual/developers.txt deleted file mode 100644 index 7058d57b20..0000000000 --- a/docs/manual/developers.txt +++ /dev/null @@ -1,49 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[DEVELOPERS]] -== DEVELOPERS file and get-developers - -The main Buildroot directory contains a file named +DEVELOPERS+ that -lists the developers involved with various areas of Buildroot. Thanks -to this file, the +get-developers+ tool allows to: - -- Calculate the list of developers to whom patches should be sent, by - parsing the patches and matching the modified files with the - relevant developers. See xref:submitting-patches[] for details. - -- Find which developers are taking care of a given architecture or - package, so that they can be notified when a build failure occurs on - this architecture or package. This is done in interaction with - Buildroot's autobuild infrastructure. - -We ask developers adding new packages, new boards, or generally new -functionality in Buildroot, to register themselves in the +DEVELOPERS+ -file. As an example, we expect a developer contributing a new package -to include in his patch the appropriate modification to the -+DEVELOPERS+ file. - -The +DEVELOPERS+ file format is documented in detail inside the file -itself. - -The +get-developers+ tool, located in +utils/+ allows to use -the +DEVELOPERS+ file for various tasks: - -- When passing one or several patches as command line argument, - +get-developers+ will return the appropriate +git send-email+ - command. If the +-e+ option is passed, only the email addresses are - printed in a format suitable for +git send-email --cc-cmd+. - -- When using the +-a + command line option, +get-developers+ will - return the list of developers in charge of the given architecture. - -- When using the +-p + command line option, +get-developers+ - will return the list of developers in charge of the given package. - -- When using the +-c+ command line option, +get-developers+ will look - at all files under version control in the Buildroot repository, and - list the ones that are not handled by any developer. The purpose of - this option is to help completing the +DEVELOPERS+ file. - -- When using without any arguments, it validates the integrity of the - DEVELOPERS file and will note WARNINGS for items that don't match. diff --git a/docs/manual/docbook-xsl.css b/docs/manual/docbook-xsl.css deleted file mode 100644 index ee9ca46d6f..0000000000 --- a/docs/manual/docbook-xsl.css +++ /dev/null @@ -1,329 +0,0 @@ -/* - CSS stylesheet for XHTML produced by DocBook XSL stylesheets. -*/ - -body { - font-family: Georgia,serif; -} - -code, pre { - font-family: "Courier New", Courier, monospace; -} - -span.strong { - font-weight: bold; -} - -body blockquote { - margin-top: .75em; - line-height: 1.5; - margin-bottom: .75em; -} - -html body { - margin: 1em 5% 1em 5%; - line-height: 1.2; -} - -body div { - margin: 0; -} - -h1, h2, h3, h4, h5, h6 -{ - color: #527bbd; - font-family: Arial,Helvetica,sans-serif; -} - -div.toc p:first-child, -div.list-of-figures p:first-child, -div.list-of-tables p:first-child, -div.list-of-examples p:first-child, -div.example p.title, -div.sidebar p.title -{ - font-weight: bold; - color: #527bbd; - font-family: Arial,Helvetica,sans-serif; - margin-bottom: 0.2em; -} - -body h1 { - margin: .0em 0 0 -4%; - line-height: 1.3; - border-bottom: 2px solid silver; -} - -body h2 { - margin: 0.5em 0 0 -4%; - line-height: 1.3; - border-bottom: 2px solid silver; -} - -body h3 { - margin: .8em 0 0 -3%; - line-height: 1.3; -} - -body h4 { - margin: .8em 0 0 -3%; - line-height: 1.3; -} - -body h5 { - margin: .8em 0 0 -2%; - line-height: 1.3; -} - -body h6 { - margin: .8em 0 0 -1%; - line-height: 1.3; -} - -body hr { - border: none; /* Broken on IE6 */ -} -div.footnotes hr { - border: 1px solid silver; -} - -div.navheader th, div.navheader td, div.navfooter td { - font-family: Arial,Helvetica,sans-serif; - font-size: 0.9em; - font-weight: bold; - color: #527bbd; -} -div.navheader img, div.navfooter img { - border-style: none; -} -div.navheader a, div.navfooter a { - font-weight: normal; -} -div.navfooter hr { - border: 1px solid silver; -} - -body td { - line-height: 1.2 -} - -body th { - line-height: 1.2; -} - -ol { - line-height: 1.2; -} - -ul, body dir, body menu { - line-height: 1.2; -} - -html { - margin: 0; - padding: 0; -} - -body h1, body h2, body h3, body h4, body h5, body h6 { - margin-left: 0 -} - -body pre { - margin: 0.5em 10% 0.5em 1em; - line-height: 1.0; - color: navy; -} - -tt.literal, code.literal { - color: navy; -} - -.programlisting, .screen { - border: 1px solid silver; - background: #f4f4f4; - margin: 0.5em 10% 0.5em 0; - padding: 0.5em 1em; -} - -div.sidebar { - background: #ffffee; - margin: 1.0em 10% 0.5em 0; - padding: 0.5em 1em; - border: 1px solid silver; -} -div.sidebar * { padding: 0; } -div.sidebar div { margin: 0; } -div.sidebar p.title { - margin-top: 0.5em; - margin-bottom: 0.2em; -} - -div.bibliomixed { - margin: 0.5em 5% 0.5em 1em; -} - -div.glossary dt { - font-weight: bold; -} -div.glossary dd p { - margin-top: 0.2em; -} - -dl { - margin: .8em 0; - line-height: 1.2; -} - -dt { - margin-top: 0.5em; -} - -dt span.term { - font-style: normal; - color: navy; -} - -div.variablelist dd p { - margin-top: 0; -} - -div.itemizedlist li, div.orderedlist li { - margin-left: -0.8em; - margin-top: 0.5em; -} - -ul, ol { - list-style-position: outside; -} - -div.sidebar ul, div.sidebar ol { - margin-left: 2.8em; -} - -div.itemizedlist p.title, -div.orderedlist p.title, -div.variablelist p.title -{ - margin-bottom: -0.8em; -} - -div.revhistory table { - border-collapse: collapse; - border: none; -} -div.revhistory th { - border: none; - color: #527bbd; - font-family: Arial,Helvetica,sans-serif; -} -div.revhistory td { - border: 1px solid silver; -} - -/* Keep TOC and index lines close together. */ -div.toc dl, div.toc dt, -div.list-of-figures dl, div.list-of-figures dt, -div.list-of-tables dl, div.list-of-tables dt, -div.indexdiv dl, div.indexdiv dt -{ - line-height: normal; - margin-top: 0; - margin-bottom: 0; -} - -/* - Table styling does not work because of overriding attributes in - generated HTML. -*/ -div.table table, -div.informaltable table -{ - margin-left: 0; - margin-right: 5%; - margin-bottom: 0.8em; -} -div.informaltable table -{ - margin-top: 0.4em -} -div.table thead, -div.table tfoot, -div.table tbody, -div.informaltable thead, -div.informaltable tfoot, -div.informaltable tbody -{ - /* No effect in IE6. */ - border-top: 3px solid #527bbd; - border-bottom: 3px solid #527bbd; -} -div.table thead, div.table tfoot, -div.informaltable thead, div.informaltable tfoot -{ - font-weight: bold; -} - -div.mediaobject img { - margin-bottom: 0.8em; -} -div.figure p.title, -div.table p.title -{ - margin-top: 1em; - margin-bottom: 0.4em; -} - -div.calloutlist p -{ - margin-top: 0em; - margin-bottom: 0.4em; -} - -a img { - border-style: none; -} - -@media print { - div.navheader, div.navfooter { display: none; } -} - -span.aqua { color: aqua; } -span.black { color: black; } -span.blue { color: blue; } -span.fuchsia { color: fuchsia; } -span.gray { color: gray; } -span.green { color: green; } -span.lime { color: lime; } -span.maroon { color: maroon; } -span.navy { color: navy; } -span.olive { color: olive; } -span.purple { color: purple; } -span.red { color: red; } -span.silver { color: silver; } -span.teal { color: teal; } -span.white { color: white; } -span.yellow { color: yellow; } - -span.aqua-background { background: aqua; } -span.black-background { background: black; } -span.blue-background { background: blue; } -span.fuchsia-background { background: fuchsia; } -span.gray-background { background: gray; } -span.green-background { background: green; } -span.lime-background { background: lime; } -span.maroon-background { background: maroon; } -span.navy-background { background: navy; } -span.olive-background { background: olive; } -span.purple-background { background: purple; } -span.red-background { background: red; } -span.silver-background { background: silver; } -span.teal-background { background: teal; } -span.white-background { background: white; } -span.yellow-background { background: yellow; } - -span.big { font-size: 2em; } -span.small { font-size: 0.6em; } - -span.underline { text-decoration: underline; } -span.overline { text-decoration: overline; } -span.line-through { text-decoration: line-through; } diff --git a/docs/manual/download-infra.txt b/docs/manual/download-infra.txt deleted file mode 100644 index f2ccd149d6..0000000000 --- a/docs/manual/download-infra.txt +++ /dev/null @@ -1,8 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[download-infra]] - -== Download infrastructure - -TODO diff --git a/docs/manual/download-location.txt b/docs/manual/download-location.txt deleted file mode 100644 index d485df94f5..0000000000 --- a/docs/manual/download-location.txt +++ /dev/null @@ -1,27 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[download-location]] - -==== Location of downloaded packages - -The various tarballs that are downloaded by Buildroot are all stored -in +BR2_DL_DIR+, which by default is the +dl+ directory. If you want -to keep a complete version of Buildroot which is known to be working -with the associated tarballs, you can make a copy of this directory. -This will allow you to regenerate the toolchain and the target -filesystem with exactly the same versions. - -If you maintain several Buildroot trees, it might be better to have a -shared download location. This can be achieved by pointing the -+BR2_DL_DIR+ environment variable to a directory. If this is -set, then the value of +BR2_DL_DIR+ in the Buildroot configuration is -overridden. The following line should be added to +<~/.bashrc>+. - ------------------ - export BR2_DL_DIR= ------------------ - -The download location can also be set in the +.config+ file, with the -+BR2_DL_DIR+ option. Unlike most options in the .config file, this value -is overridden by the +BR2_DL_DIR+ environment variable. diff --git a/docs/manual/eclipse-integration.txt b/docs/manual/eclipse-integration.txt deleted file mode 100644 index 1f726d8240..0000000000 --- a/docs/manual/eclipse-integration.txt +++ /dev/null @@ -1,30 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -=== Integration with Eclipse - -While a part of the embedded Linux developers like classical text -editors like Vim or Emacs, and command-line based interfaces, a number -of other embedded Linux developers like richer graphical interfaces to -do their development work. Eclipse being one of the most popular -Integrated Development Environment, Buildroot integrates with Eclipse -in order to ease the development work of Eclipse users. - -Our integration with Eclipse simplifies the compilation, remote -execution and remote debugging of applications and libraries that are -built on top of a Buildroot system. It does not integrate the -Buildroot configuration and build processes themselves with -Eclipse. Therefore, the typical usage model of our Eclipse integration -would be: - -* Configure your Buildroot system with +make menuconfig+, +make - xconfig+ or any other configuration interface provided with - Buildroot. -* Build your Buildroot system by running +make+. -* Start Eclipse to develop, execute and debug your own custom - applications and libraries, that will rely on the libraries built - and installed by Buildroot. - -The Buildroot Eclipse integration installation process and usage is -described in detail at -https://github.com/mbats/eclipse-buildroot-bundle/wiki. diff --git a/docs/manual/faq-troubleshooting.txt b/docs/manual/faq-troubleshooting.txt deleted file mode 100644 index 5adf3fa6ce..0000000000 --- a/docs/manual/faq-troubleshooting.txt +++ /dev/null @@ -1,244 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== Frequently Asked Questions & Troubleshooting - -[[faq-boot-hang-after-starting]] -=== The boot hangs after 'Starting network...' - -If the boot process seems to hang after the following messages -(messages not necessarily exactly similar, depending on the list of -packages selected): - ------------------------- -Freeing init memory: 3972K -Initializing random number generator... done. -Starting network... -Starting dropbear sshd: generating rsa key... generating dsa key... OK ------------------------- - -then it means that your system is running, but didn't start a shell on -the serial console. In order to have the system start a shell on your -serial console, you have to go into the Buildroot configuration, in -+System configuration+, modify +Run a getty (login prompt) after boot+ -and set the appropriate port and baud rate in the +getty options+ -submenu. This will automatically tune the +/etc/inittab+ file of the -generated system so that a shell starts on the correct serial port. - -[[faq-no-compiler-on-target]] -=== Why is there no compiler on the target? - -It has been decided that support for the _native compiler on the -target_ would be stopped from the Buildroot-2012.11 release because: - -* this feature was neither maintained nor tested, and often broken; -* this feature was only available for Buildroot toolchains; -* Buildroot mostly targets _small_ or _very small_ target hardware - with limited resource onboard (CPU, ram, mass-storage), for which - compiling on the target does not make much sense; -* Buildroot aims at easing the cross-compilation, making native - compilation on the target unnecessary. - -If you need a compiler on your target anyway, then Buildroot is not -suitable for your purpose. In such case, you need a _real -distribution_ and you should opt for something like: - -* http://www.openembedded.org[openembedded] -* https://www.yoctoproject.org[yocto] -* http://www.emdebian.org[emdebian] -* https://fedoraproject.org/wiki/Architectures[Fedora] -* http://en.opensuse.org/Portal:ARM[openSUSE ARM] -* http://archlinuxarm.org[Arch Linux ARM] -* ... - -[[faq-no-dev-files-on-target]] -=== Why are there no development files on the target? - -Since there is no compiler available on the target (see -xref:faq-no-compiler-on-target[]), it does not make sense to waste -space with headers or static libraries. - -Therefore, those files are always removed from the target since the -Buildroot-2012.11 release. - -[[faq-no-doc-on-target]] -=== Why is there no documentation on the target? - -Because Buildroot mostly targets _small_ or _very small_ target -hardware with limited resource onboard (CPU, ram, mass-storage), it -does not make sense to waste space with the documentation data. - -If you need documentation data on your target anyway, then Buildroot -is not suitable for your purpose, and you should look for a _real -distribution_ (see: xref:faq-no-compiler-on-target[]). - -[[faq-why-not-visible-package]] -=== Why are some packages not visible in the Buildroot config menu? - -If a package exists in the Buildroot tree and does not appear in the -config menu, this most likely means that some of the package's -dependencies are not met. - -To know more about the dependencies of a package, search for the -package symbol in the config menu (see xref:make-tips[]). - -Then, you may have to recursively enable several options (which -correspond to the unmet dependencies) to finally be able to select -the package. - -If the package is not visible due to some unmet toolchain options, -then you should certainly run a full rebuild (see xref:make-tips[] for -more explanations). - -[[faq-why-not-use-target-as-chroot]] -=== Why not use the target directory as a chroot directory? - -There are plenty of reasons to *not* use the target directory a chroot -one, among these: - -* file ownerships, modes and permissions are not correctly set in the - target directory; -* device nodes are not created in the target directory. - -For these reasons, commands run through chroot, using the target -directory as the new root, will most likely fail. - -If you want to run the target filesystem inside a chroot, or as an NFS -root, then use the tarball image generated in +images/+ and extract it -as root. - -[[faq-no-binary-packages]] -=== Why doesn't Buildroot generate binary packages (.deb, .ipkg...)? - -One feature that is often discussed on the Buildroot list is the -general topic of "package management". To summarize, the idea -would be to add some tracking of which Buildroot package installs -what files, with the goals of: - - * being able to remove files installed by a package when this package - gets unselected from the menuconfig; - - * being able to generate binary packages (ipk or other format) that - can be installed on the target without re-generating a new root - filesystem image. - -In general, most people think it is easy to do: just track which package -installed what and remove it when the package is unselected. However, it -is much more complicated than that: - - * It is not only about the +target/+ directory, but also the sysroot in - +host//sysroot+ and the +host/+ directory itself. All files - installed in those directories by various packages must be tracked. - - * When a package is unselected from the configuration, it is not - sufficient to remove just the files it installed. One must also - remove all its reverse dependencies (i.e. packages relying on it) - and rebuild all those packages. For example, package A depends - optionally on the OpenSSL library. Both are selected, and Buildroot - is built. Package A is built with crypto support using OpenSSL. - Later on, OpenSSL gets unselected from the configuration, but - package A remains (since OpenSSL is an optional dependency, this - is possible.) If only OpenSSL files are removed, then the files - installed by package A are broken: they use a library that is no - longer present on the target. Although this is technically doable, - it adds a lot of complexity to Buildroot, which goes against the - simplicity we try to stick to. - - * In addition to the previous problem, there is the case where the - optional dependency is not even known to Buildroot. For example, - package A in version 1.0 never used OpenSSL, but in version 2.0 it - automatically uses OpenSSL if available. If the Buildroot .mk file - hasn't been updated to take this into account, then package A will - not be part of the reverse dependencies of OpenSSL and will not be - removed and rebuilt when OpenSSL is removed. For sure, the .mk file - of package A should be fixed to mention this optional dependency, - but in the mean time, you can have non-reproducible behaviors. - - * The request is to also allow changes in the menuconfig to be - applied on the output directory without having to rebuild - everything from scratch. However, this is very difficult to achieve - in a reliable way: what happens when the suboptions of a package - are changed (we would have to detect this, and rebuild the package - from scratch and potentially all its reverse dependencies), what - happens if toolchain options are changed, etc. At the moment, what - Buildroot does is clear and simple so its behaviour is very - reliable and it is easy to support users. If configuration changes - done in menuconfig are applied after the next make, then it has to - work correctly and properly in all situations, and not have some - bizarre corner cases. The risk is to get bug reports like "I have - enabled package A, B and C, then ran make, then disabled package - C and enabled package D and ran make, then re-enabled package C - and enabled package E and then there is a build failure". Or worse - "I did some configuration, then built, then did some changes, - built, some more changes, built, some more changes, built, and now - it fails, but I don't remember all the changes I did and in which - order". This will be impossible to support. - -For all these reasons, the conclusion is that adding tracking of -installed files to remove them when the package is unselected, or to -generate a repository of binary packages, is something that is very -hard to achieve reliably and will add a lot of complexity. - -On this matter, the Buildroot developers make this position statement: - - * Buildroot strives to make it easy to generate a root filesystem (hence - the name, by the way.) That is what we want to make Buildroot good at: - building root filesystems. - - * Buildroot is not meant to be a distribution (or rather, a distribution - generator.) It is the opinion of most Buildroot developers that this - is not a goal we should pursue. We believe that there are other tools - better suited to generate a distro than Buildroot is. For example, - http://openembedded.org/[Open Embedded], or https://openwrt.org/[openWRT], - are such tools. - - * We prefer to push Buildroot in a direction that makes it easy (or even - easier) to generate complete root filesystems. This is what makes - Buildroot stands out in the crowd (among other things, of course!) - - * We believe that for most embedded Linux systems, binary packages are - not necessary, and potentially harmful. When binary packages are - used, it means that the system can be partially upgraded, which - creates an enormous number of possible combinations of package - versions that should be tested before doing the upgrade on the - embedded device. On the other hand, by doing complete system - upgrades by upgrading the entire root filesystem image at once, - the image deployed to the embedded system is guaranteed to really - be the one that has been tested and validated. - -[[faq-speeding-up-build]] -=== How to speed-up the build process? - -Since Buildroot often involves doing full rebuilds of the entire -system that can be quite long, we provide below a number of tips to -help reduce the build time: - - * Use a pre-built external toolchain instead of the default Buildroot - internal toolchain. By using a pre-built Linaro toolchain (on ARM) - or a Sourcery CodeBench toolchain (for ARM, x86, x86-64, MIPS, - etc.), you will save the build time of the toolchain at each - complete rebuild, approximately 15 to 20 minutes. Note that - temporarily using an external toolchain does not prevent you to - switch back to an internal toolchain (that may provide a higher - level of customization) once the rest of your system is working; - - * Use the +ccache+ compiler cache (see: xref:ccache[]); - - * Learn about rebuilding only the few packages you actually care - about (see xref:rebuild-pkg[]), but beware that sometimes full - rebuilds are anyway necessary (see xref:full-rebuild[]); - - * Make sure you are not using a virtual machine for the Linux system - used to run Buildroot. Most of the virtual machine technologies are - known to cause a significant performance impact on I/O, which is - really important for building source code; - - * Make sure that you're using only local files: do not attempt to do - a build over NFS, which significantly slows down the build. Having - the Buildroot download folder available locally also helps a bit. - - * Buy new hardware. SSDs and lots of RAM are key to speeding up the - builds. - - * Experiment with top-level parallel build, see - xref:top-level-parallel-build[]. diff --git a/docs/manual/getting.txt b/docs/manual/getting.txt index 549938a223..7c44e128a6 100644 --- a/docs/manual/getting.txt +++ b/docs/manual/getting.txt @@ -1,4 +1,4 @@ -// -*- mode:doc; -*- + // -*- mode:doc; -*- // vim: set syntax=asciidoc: [[getting-buildroot]] diff --git a/docs/manual/github_hash_mongrel2.png b/docs/manual/github_hash_mongrel2.png deleted file mode 100644 index c695c3181abc3bdf4661692fdbcc4332a02cd856..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19029 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 ADF6Tf diff --git a/docs/manual/how-buildroot-works.txt b/docs/manual/how-buildroot-works.txt deleted file mode 100644 index 1204d1ecab..0000000000 --- a/docs/manual/how-buildroot-works.txt +++ /dev/null @@ -1,69 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== How Buildroot works - -As mentioned above, Buildroot is basically a set of Makefiles that -download, configure, and compile software with the correct options. It -also includes patches for various software packages - mainly the ones -involved in the cross-compilation toolchain (+gcc+, +binutils+ and -+uClibc+). - -There is basically one Makefile per software package, and they are -named with the +.mk+ extension. Makefiles are split into many different -parts. - -* The +toolchain/+ directory contains the Makefiles - and associated files for all software related to the - cross-compilation toolchain: +binutils+, +gcc+, +gdb+, - +kernel-headers+ and +uClibc+. - -* The +arch/+ directory contains the definitions for all the processor - architectures that are supported by Buildroot. - -* The +package/+ directory contains the Makefiles and - associated files for all user-space tools and libraries that Buildroot - can compile and add to the target root filesystem. There is one - sub-directory per package. - -* The +linux/+ directory contains the Makefiles and associated files for - the Linux kernel. - -* The +boot/+ directory contains the Makefiles and associated files for - the bootloaders supported by Buildroot. - -* The +system/+ directory contains support for system integration, e.g. - the target filesystem skeleton and the selection of an init system. - -* The +fs/+ directory contains the Makefiles and - associated files for software related to the generation of the - target root filesystem image. - -Each directory contains at least 2 files: - -* +something.mk+ is the Makefile that downloads, configures, - compiles and installs the package +something+. - -* +Config.in+ is a part of the configuration tool - description file. It describes the options related to the - package. - -The main Makefile performs the following steps (once the -configuration is done): - -* Create all the output directories: +staging+, +target+, +build+, - etc. in the output directory (+output/+ by default, - another value can be specified using +O=+) - -* Generate the toolchain target. When an internal toolchain is used, this - means generating the cross-compilation toolchain. When an external - toolchain is used, this means checking the features of the external - toolchain and importing it into the Buildroot environment. - -* Generate all the targets listed in the +TARGETS+ variable. This - variable is filled by all the individual components' - Makefiles. Generating these targets will trigger the compilation of - the userspace packages (libraries, programs), the kernel, the - bootloader and the generation of the root filesystem images, - depending on the configuration. - diff --git a/docs/manual/introduction.txt b/docs/manual/introduction.txt index 476aa81edc..8d1c8b69c3 100644 --- a/docs/manual/introduction.txt +++ b/docs/manual/introduction.txt @@ -1,26 +1 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== About Buildroot - -Buildroot is a tool that simplifies and automates the process of -building a complete Linux system for an embedded system, using -cross-compilation. - -In order to achieve this, Buildroot is able to generate a -cross-compilation toolchain, a root filesystem, a Linux kernel image -and a bootloader for your target. Buildroot can be used for any -combination of these options, independently (you can for example use -an existing cross-compilation toolchain, and build only your root -filesystem with Buildroot). - -Buildroot is useful mainly for people working with embedded systems. -Embedded systems often use processors that are not the regular x86 -processors everyone is used to having in his PC. They can be PowerPC -processors, MIPS processors, ARM processors, etc. - -Buildroot supports numerous processors and their variants; it also -comes with default configurations for several boards available -off-the-shelf. Besides this, a number of third-party projects are based on, -or develop their BSP footnote:[BSP: Board Support Package] or -SDK footnote:[SDK: Software Development Kit] on top of Buildroot. + diff --git a/docs/manual/known-issues.txt b/docs/manual/known-issues.txt deleted file mode 100644 index ae29a48b38..0000000000 --- a/docs/manual/known-issues.txt +++ /dev/null @@ -1,15 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== Known issues - -* It is not possible to pass extra linker options via +BR2_TARGET_LDFLAGS+ - if such options contain a +$+ sign. For example, the following is known - to break: +BR2_TARGET_LDFLAGS="-Wl,-rpath=\'$ORIGIN/../lib'"+ - -* The +libffi+ package is not supported on the SuperH 2 and ARC - architectures. - -* The +prboom+ package triggers a compiler failure with the SuperH 4 - compiler from Sourcery CodeBench, version 2012.09. - diff --git a/docs/manual/legal-notice.txt b/docs/manual/legal-notice.txt deleted file mode 100644 index 179aa6b179..0000000000 --- a/docs/manual/legal-notice.txt +++ /dev/null @@ -1,122 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[legal-info]] - -== Legal notice and licensing - -=== Complying with open source licenses - -All of the end products of Buildroot (toolchain, root filesystem, kernel, -bootloaders) contain open source software, released under various licenses. - -Using open source software gives you the freedom to build rich embedded -systems, choosing from a wide range of packages, but also imposes some -obligations that you must know and honour. -Some licenses require you to publish the license text in the documentation of -your product. Others require you to redistribute the source code of the -software to those that receive your product. - -The exact requirements of each license are documented in each package, and -it is your responsibility (or that of your legal office) to comply with those -requirements. -To make this easier for you, Buildroot can collect for you some material you -will probably need. To produce this material, after you have configured -Buildroot with +make menuconfig+, +make xconfig+ or +make gconfig+, run: - --------------------- -make legal-info --------------------- - -Buildroot will collect legally-relevant material in your output directory, -under the +legal-info/+ subdirectory. -There you will find: - -* A +README+ file, that summarizes the produced material and contains warnings - about material that Buildroot could not produce. -* +buildroot.config+: this is the Buildroot configuration file that is usually - produced with +make menuconfig+, and which is necessary to reproduce the - build. -* The source code for all packages; this is saved in the +sources/+ and - +host-sources/+ subdirectories for target and host packages respectively. - The source code for packages that set +_REDISTRIBUTE = NO+ will not be - saved. - Patches that were applied are also saved, along with a file named +series+ - that lists the patches in the order they were applied. Patches are under the - same license as the files that they modify. - Note: Buildroot applies additional patches to Libtool scripts of - autotools-based packages. These patches can be found under - +support/libtool+ in the Buildroot source and, due to technical - limitations, are not saved with the package sources. You may need to - collect them manually. -* A manifest file (one for host and one for target packages) listing the - configured packages, their version, license and related information. - Some of this information might not be defined in Buildroot; such items are - marked as "unknown". -* The license texts of all packages, in the +licenses/+ and +host-licenses/+ - subdirectories for target and host packages respectively. - If the license file(s) are not defined in Buildroot, the file is not produced - and a warning in the +README+ indicates this. - -Please note that the aim of the +legal-info+ feature of Buildroot is to -produce all the material that is somehow relevant for legal compliance with the -package licenses. Buildroot does not try to produce the exact material that -you must somehow make public. Certainly, more material is produced than is -needed for a strict legal compliance. For example, it produces the source code -for packages released under BSD-like licenses, that you are not required to -redistribute in source form. - -Moreover, due to technical limitations, Buildroot does not produce some -material that you will or may need, such as the toolchain source code for -some of the external toolchains and the Buildroot source code itself. -When you run +make legal-info+, Buildroot produces warnings in the +README+ -file to inform you of relevant material that could not be saved. - -Finally, keep in mind that the output of +make legal-info+ is based on -declarative statements in each of the packages recipes. The Buildroot -developers try to do their best to keep those declarative statements as -accurate as possible, to the best of their knowledge. However, it is very -well possible that those declarative statements are not all fully accurate -nor exhaustive. You (or your legal department) _have_ to check the output -of +make legal-info+ before using it as your own compliance delivery. See -the _NO WARRANTY_ clauses (clauses 11 and 12) in the +COPYING+ file at the -root of the Buildroot distribution. - -[[legal-info-buildroot]] -=== Complying with the Buildroot license - -Buildroot itself is an open source software, released under the -http://www.gnu.org/licenses/old-licenses/gpl-2.0.html[GNU General -Public License, version 2] or (at your option) any later version, with -the exception of the package patches detailed below. -However, being a build system, it is not normally part of the end product: -if you develop the root filesystem, kernel, bootloader or toolchain for a -device, the code of Buildroot is only present on the development machine, not -in the device storage. - -Nevertheless, the general view of the Buildroot developers is that you should -release the Buildroot source code along with the source code of other packages -when releasing a product that contains GPL-licensed software. -This is because the -http://www.gnu.org/licenses/old-licenses/gpl-2.0.html[GNU GPL] -defines the "'complete source code'" for an executable work as "'all the -source code for all modules it contains, plus any associated interface -definition files, plus the scripts used to control compilation and installation -of the executable'". -Buildroot is part of the 'scripts used to control compilation and -installation of the executable', and as such it is considered part of the -material that must be redistributed. - -Keep in mind that this is only the Buildroot developers' opinion, and you -should consult your legal department or lawyer in case of any doubt. - -==== Patches to packages - -Buildroot also bundles patch files, which are applied to the sources -of the various packages. Those patches are not covered by the license -of Buildroot. Instead, they are covered by the license of the software -to which the patches are applied. When said software is available -under multiple licenses, the Buildroot patches are only provided under -the publicly accessible licenses. - -See xref:patch-policy[] for the technical details. diff --git a/docs/manual/logo.png b/docs/manual/logo.png deleted file mode 100644 index 2db743b4fa93820a2ad38bdafb1dbaafe7805fee..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 117499 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

@^9-lMJ|?5P$*(2?$!~9H(~3( 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

EVr2UX@4T=+T75|uU{D1 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�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 Y0Zm>X7-miADgXcg07*qoM6N<$f --------------------- - -.Display the list of boards with a defconfig: - --------------------- - $ make list-defconfigs --------------------- - -.Display all available targets: - --------------------- - $ make help --------------------- - -Not all targets are always available, -some settings in the +.config+ file may hide some targets: - -* +busybox-menuconfig+ only works when +busybox+ is enabled; -* +linux-menuconfig+ and +linux-savedefconfig+ only work when - +linux+ is enabled; -* +uclibc-menuconfig+ is only available when the uClibc C library is - selected in the internal toolchain backend; -* +barebox-menuconfig+ and +barebox-savedefconfig+ only work when the - +barebox+ bootloader is enabled. -* +uboot-menuconfig+ and +uboot-savedefconfig+ only work when the - +U-Boot+ bootloader is enabled. - -.Cleaning: - -Explicit cleaning is required when any of the architecture or toolchain -configuration options are changed. - -To delete all build products (including build directories, host, staging -and target trees, the images and the toolchain): - --------------------- - $ make clean --------------------- - -.Generating the manual: - -The present manual sources are located in the 'docs/manual' directory. -To generate the manual: - ---------------------------------- - $ make manual-clean - $ make manual ---------------------------------- - -The manual outputs will be generated in 'output/docs/manual'. - -.Notes -- A few tools are required to build the documentation (see: - xref:requirement-optional[]). - -.Resetting Buildroot for a new target: - -To delete all build products as well as the configuration: - --------------------- - $ make distclean --------------------- - -.Notes -If +ccache+ is enabled, running +make clean+ or +distclean+ does -not empty the compiler cache used by Buildroot. To delete it, refer -to xref:ccache[]. - -.Dumping the internal make variables: - -One can dump the variables known to make, along with their values: - ----- - $ make -s printvars VARS='VARIABLE1 VARIABLE2' - VARIABLE1=value_of_variable - VARIABLE2=value_of_variable ----- - -It is possible to tweak the output using some variables: - -- +VARS+ will limit the listing to variables which names match the - specified make-patterns - this must be set else nothing is printed -- +QUOTED_VARS+, if set to +YES+, will single-quote the value -- +RAW_VARS+, if set to +YES+, will print the unexpanded value - -For example: - ----- - $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES - BUSYBOX_DEPENDENCIES=skeleton toolchain - BUSYBOX_FINAL_ALL_DEPENDENCIES=skeleton toolchain - BUSYBOX_FINAL_DEPENDENCIES=skeleton toolchain - BUSYBOX_FINAL_PATCH_DEPENDENCIES= - BUSYBOX_RDEPENDENCIES=ncurses util-linux ----- - ----- - $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES QUOTED_VARS=YES - BUSYBOX_DEPENDENCIES='skeleton toolchain' - BUSYBOX_FINAL_ALL_DEPENDENCIES='skeleton toolchain' - BUSYBOX_FINAL_DEPENDENCIES='skeleton toolchain' - BUSYBOX_FINAL_PATCH_DEPENDENCIES='' - BUSYBOX_RDEPENDENCIES='ncurses util-linux' ----- - ----- - $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES RAW_VARS=YES - BUSYBOX_DEPENDENCIES=skeleton toolchain - BUSYBOX_FINAL_ALL_DEPENDENCIES=$(sort $(BUSYBOX_FINAL_DEPENDENCIES) $(BUSYBOX_FINAL_PATCH_DEPENDENCIES)) - BUSYBOX_FINAL_DEPENDENCIES=$(sort $(BUSYBOX_DEPENDENCIES)) - BUSYBOX_FINAL_PATCH_DEPENDENCIES=$(sort $(BUSYBOX_PATCH_DEPENDENCIES)) - BUSYBOX_RDEPENDENCIES=ncurses util-linux ----- - -The output of quoted variables can be reused in shell scripts, for example: - ----- - $ eval $(make -s printvars VARS=BUSYBOX_DEPENDENCIES QUOTED_VARS=YES) - $ echo $BUSYBOX_DEPENDENCIES - skeleton toolchain ----- diff --git a/docs/manual/makedev-syntax.txt b/docs/manual/makedev-syntax.txt deleted file mode 100644 index d6efb31d42..0000000000 --- a/docs/manual/makedev-syntax.txt +++ /dev/null @@ -1,103 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[makedev-syntax]] -== Makedev syntax documentation - -The makedev syntax is used in several places in Buildroot to -define changes to be made for permissions, or which device files to -create and how to create them, in order to avoid calls to mknod. - -This syntax is derived from the makedev utility, and more complete -documentation can be found in the +package/makedevs/README+ file. - -It takes the form of a space separated list of fields, one file per -line; the fields are: - -|=========================================================== -|name |type |mode |uid |gid |major |minor |start |inc |count -|=========================================================== - -There are a few non-trivial blocks: - -- +name+ is the path to the file you want to create/modify -- +type+ is the type of the file, being one of: - * f: a regular file - * d: a directory - * r: a directory recursively - * c: a character device file - * b: a block device file - * p: a named pipe -- +mode+ are the usual permissions settings (only numerical values - are allowed) -- +uid+ and +gid+ are the UID and GID to set on this file; can be - either numerical values or actual names -- +major+ and +minor+ are here for device files, set to +-+ for other - files -- +start+, +inc+ and +count+ are for when you want to create a batch - of files, and can be reduced to a loop, beginning at +start+, - incrementing its counter by +inc+ until it reaches +count+ - -Let's say you want to change the permissions of a given file; using -this syntax, you will need to write: - ----- -/usr/bin/foo f 755 0 0 - - - - - -/usr/bin/bar f 755 root root - - - - - -/data/buz f 644 buz-user buz-group - - - - - ----- - -Alternatively, if you want to change owner/permission of a directory -recursively, you can write (to set UID to foo, GID to bar and access -rights to rwxr-x--- for the directory /usr/share/myapp and all files -and directories below it): - ----- -/usr/share/myapp r 750 foo bar - - - - - ----- - -On the other hand, if you want to create the device file +/dev/hda+ -and the corresponding 15 files for the partitions, you will need for -+/dev/hda+: - ----- -/dev/hda b 640 root root 3 0 0 0 - ----- - -and then for device files corresponding to the partitions of -+/dev/hda+, +/dev/hdaX+, +X+ ranging from 1 to 15: - ----- -/dev/hda b 640 root root 3 1 1 1 15 ----- - -Extended attributes are supported if -+BR2_ROOTFS_DEVICE_TABLE_SUPPORTS_EXTENDED_ATTRIBUTES+ is enabled. -This is done by adding a line starting with +|xattr+ after -the line describing the file. Right now, only capability -is supported as extended attribute. - -|===================== -| \|xattr | capability -|===================== - -- +|xattr+ is a "flag" that indicate an extended attribute -- +capability+ is a capability to add to the previous file - -If you want to add the capability cap_sys_admin to the binary foo, -you will write : - ----- -/usr/bin/foo f 755 root root - - - - - -|xattr cap_sys_admin+eip ----- - -You can add several capabilities to a file by using several +|xattr+ lines. -If you want to add the capability cap_sys_admin and cap_net_admin to the -binary foo, you will write : - ----- -/usr/bin/foo f 755 root root - - - - - -|xattr cap_sys_admin+eip -|xattr cap_net_admin+eip ----- diff --git a/docs/manual/makeusers-syntax.txt b/docs/manual/makeusers-syntax.txt deleted file mode 100644 index 467e596230..0000000000 --- a/docs/manual/makeusers-syntax.txt +++ /dev/null @@ -1,89 +0,0 @@ -// -*- mode:doc -*- ; -// vim: set syntax=asciidoc: - -[[makeuser-syntax]] -== Makeusers syntax documentation - -The syntax to create users is inspired by the makedev syntax, above, but -is specific to Buildroot. - -The syntax for adding a user is a space-separated list of fields, one -user per line; the fields are: - -|================================================================= -|username |uid |group |gid |password |home |shell |groups |comment -|================================================================= - -Where: - -- +username+ is the desired user name (aka login name) for the user. - It can not be +root+, and must be unique. If set to +-+, then just a - group will be created. -- +uid+ is the desired UID for the user. It must be unique, and not - +0+. If set to +-1+, then a unique UID will be computed by Buildroot - in the range [1000...1999] -- +group+ is the desired name for the user's main group. It can not - be +root+. If the group does not exist, it will be created. -- +gid+ is the desired GID for the user's main group. It must be unique, - and not +0+. If set to +-1+, and the group does not already exist, then - a unique GID will be computed by Buildroot in the range [1000..1999] -- +password+ is the crypt(3)-encoded password. If prefixed with +!+, - then login is disabled. If prefixed with +=+, then it is interpreted - as clear-text, and will be crypt-encoded (using MD5). If prefixed with - +!=+, then the password will be crypt-encoded (using MD5) and login - will be disabled. If set to +*+, then login is not allowed. If set to - +-+, then no password value will be set. -- +home+ is the desired home directory for the user. If set to '-', no - home directory will be created, and the user's home will be +/+. - Explicitly setting +home+ to +/+ is not allowed. -- +shell+ is the desired shell for the user. If set to +-+, then - +/bin/false+ is set as the user's shell. -- +groups+ is the comma-separated list of additional groups the user - should be part of. If set to +-+, then the user will be a member of - no additional group. Missing groups will be created with an arbitrary - +gid+. -- +comment+ (aka https://en.wikipedia.org/wiki/Gecos_field[GECOS] - field) is an almost-free-form text. - -There are a few restrictions on the content of each field: - -* except for +comment+, all fields are mandatory. -* except for +comment+, fields may not contain spaces. -* no field may contain a colon (+:+). - -If +home+ is not +-+, then the home directory, and all files below, -will belong to the user and its main group. - -Examples: - ----- -foo -1 bar -1 !=blabla /home/foo /bin/sh alpha,bravo Foo user ----- - -This will create this user: - -- +username+ (aka login name) is: +foo+ -- +uid+ is computed by Buildroot -- main +group+ is: +bar+ -- main group +gid+ is computed by Buildroot -- clear-text +password+ is: +blabla+, will be crypt(3)-encoded, and login is disabled. -- +home+ is: +/home/foo+ -- +shell+ is: +/bin/sh+ -- +foo+ is also a member of +groups+: +alpha+ and +bravo+ -- +comment+ is: +Foo user+ - ----- -test 8000 wheel -1 = - /bin/sh - Test user ----- - -This will create this user: - -- +username+ (aka login name) is: +test+ -- +uid+ is : +8000+ -- main +group+ is: +wheel+ -- main group +gid+ is computed by Buildroot, and will use the value defined in the rootfs skeleton -- +password+ is empty (aka no password). -- +home+ is +/+ but will not belong to +test+ -- +shell+ is: +/bin/sh+ -- +test+ is not a member of any additional +groups+ -- +comment+ is: +Test user+ diff --git a/docs/manual/manual.html b/docs/manual/manual.html deleted file mode 100644 index af7f2fc3f4..0000000000 --- a/docs/manual/manual.html +++ /dev/null @@ -1,5898 +0,0 @@ - -The Buildroot user manual

The Buildroot user manual


Table of Contents

I. Getting started
1. About Buildroot
2. System requirements
2.1. Mandatory packages
2.2. Optional packages
3. Getting Buildroot
4. Buildroot quick start
5. Community resources
II. User guide
6. Buildroot configuration
6.1. Cross-compilation toolchain
6.2. /dev management
6.3. init system
7. Configuration of other components
8. General Buildroot usage
8.1. make tips
8.2. Understanding when a full rebuild is necessary
8.3. Understanding how to rebuild packages
8.4. Offline builds
8.5. Building out-of-tree
8.6. Environment variables
8.7. Dealing efficiently with filesystem images
8.8. Details about packages
8.9. Graphing the dependencies between packages
8.10. Graphing the build duration
8.11. Graphing the filesystem size contribution of packages
8.12. Top-level parallel build
8.13. Integration with Eclipse
8.14. Advanced usage
9. Project-specific customization
9.1. Recommended directory structure
9.2. Keeping customizations outside of Buildroot
9.3. Storing the Buildroot configuration
9.4. Storing the configuration of other components
9.5. Customizing the generated target filesystem
9.6. Adding custom user accounts
9.7. Customization after the images have been created
9.8. Adding project-specific patches
9.9. Adding project-specific packages
9.10. Quick guide to storing your project-specific customizations
10. Using SELinux in Buildroot
10.1. Enabling SELinux support
10.2. SELinux policy tweaking
11. Frequently Asked Questions & Troubleshooting
11.1. The boot hangs after Starting network…
11.2. Why is there no compiler on the target?
11.3. Why are there no development files on the target?
11.4. Why is there no documentation on the target?
11.5. Why are some packages not visible in the Buildroot config menu?
11.6. Why not use the target directory as a chroot directory?
11.7. Why doesn’t Buildroot generate binary packages (.deb, .ipkg…)?
11.8. How to speed-up the build process?
12. Known issues
13. Legal notice and licensing
13.1. Complying with open source licenses
13.2. Complying with the Buildroot license
14. Beyond Buildroot
14.1. Boot the generated images
14.2. Chroot
III. Developer guide
15. How Buildroot works
16. Coding style
16.1. Config.in file
16.2. The .mk file
16.3. The documentation
16.4. Support scripts
17. Adding support for a particular board
18. Adding new packages to Buildroot
18.1. Package directory
18.2. Config files
18.3. The .mk file
18.4. The .hash file
18.5. Infrastructure for packages with specific build systems
18.6. Infrastructure for autotools-based packages
18.7. Infrastructure for CMake-based packages
18.8. Infrastructure for Python packages
18.9. Infrastructure for LuaRocks-based packages
18.10. Infrastructure for Perl/CPAN packages
18.11. Infrastructure for virtual packages
18.12. Infrastructure for packages using kconfig for configuration files
18.13. Infrastructure for rebar-based packages
18.14. Infrastructure for Waf-based packages
18.15. Infrastructure for Meson-based packages
18.16. Integration of Cargo-based packages
18.17. Infrastructure for Go packages
18.18. Infrastructure for QMake-based packages
18.19. Infrastructure for packages building kernel modules
18.20. Infrastructure for asciidoc documents
18.21. Infrastructure specific to the Linux kernel package
18.22. Hooks available in the various build steps
18.23. Gettext integration and interaction with packages
18.24. Tips and tricks
18.25. Conclusion
19. Patching a package
19.1. Providing patches
19.2. How patches are applied
19.3. Format and licensing of the package patches
19.4. Integrating patches found on the Web
20. Download infrastructure
21. Debugging Buildroot
22. Contributing to Buildroot
22.1. Reproducing, analyzing and fixing bugs
22.2. Analyzing and fixing autobuild failures
22.3. Reviewing and testing patches
22.4. Work on items from the TODO list
22.5. Submitting patches
22.6. Reporting issues/bugs or getting help
22.7. Using the runtime tests framework
23. DEVELOPERS file and get-developers
24. Release Engineering
24.1. Releases
24.2. Development
IV. Appendix
25. Makedev syntax documentation
26. Makeusers syntax documentation
27. Migrating from older Buildroot versions
27.1. General approach
27.2. Migrating to 2016.11
27.3. Migrating to 2017.08

Buildroot 2021.08.2 manual generated on 2021-11-10 -13:24:54 UTC from git revision d815599e37

The Buildroot manual is written by the Buildroot developers. -It is licensed under the GNU General Public License, version 2. Refer to the -COPYING -file in the Buildroot sources for the full text of this license.

Copyright © 2004-2020 The Buildroot developers

logo.png

Part I. Getting started

Chapter 1. About Buildroot

Buildroot is a tool that simplifies and automates the process of -building a complete Linux system for an embedded system, using -cross-compilation.

In order to achieve this, Buildroot is able to generate a -cross-compilation toolchain, a root filesystem, a Linux kernel image -and a bootloader for your target. Buildroot can be used for any -combination of these options, independently (you can for example use -an existing cross-compilation toolchain, and build only your root -filesystem with Buildroot).

Buildroot is useful mainly for people working with embedded systems. -Embedded systems often use processors that are not the regular x86 -processors everyone is used to having in his PC. They can be PowerPC -processors, MIPS processors, ARM processors, etc.

Buildroot supports numerous processors and their variants; it also -comes with default configurations for several boards available -off-the-shelf. Besides this, a number of third-party projects are based on, -or develop their BSP [1] or -SDK [2] on top of Buildroot.



[1] BSP: Board Support Package

[2] SDK: Software Development Kit

Chapter 2. System requirements

Buildroot is designed to run on Linux systems.

While Buildroot itself will build most host packages it needs for the -compilation, certain standard Linux utilities are expected to be -already installed on the host system. Below you will find an overview of -the mandatory and optional packages (note that package names may vary -between distributions).

2.1. Mandatory packages

  • -Build tools: -

    • -which -
    • -sed -
    • -make (version 3.81 or any later) -
    • -binutils -
    • -build-essential (only for Debian based systems) -
    • -gcc (version 4.8 or any later) -
    • -g++ (version 4.8 or any later) -
    • -bash -
    • -patch -
    • -gzip -
    • -bzip2 -
    • -perl (version 5.8.7 or any later) -
    • -tar -
    • -cpio -
    • -unzip -
    • -rsync -
    • -file (must be in /usr/bin/file) -
    • -bc -
  • -Source fetching tools: -

    • -wget -

2.2. Optional packages

  • -Recommended dependencies: -

    Some features or utilities in Buildroot, like the legal-info, or the -graph generation tools, have additional dependencies. Although they -are not mandatory for a simple build, they are still highly recommended:

    • -python (version 2.7 or any later) -
  • -Configuration interface dependencies: -

    For these libraries, you need to install both runtime and development -data, which in many distributions are packaged separately. The -development packages typically have a -dev or -devel suffix.

    • -ncurses5 to use the menuconfig interface -
    • -qt5 to use the xconfig interface -
    • -glib2, gtk2 and glade2 to use the gconfig interface -
  • -Source fetching tools: -

    In the official tree, most of the package sources are retrieved using -wget from ftp, http or https locations. A few packages are only -available through a version control system. Moreover, Buildroot is -capable of downloading sources via other tools, like rsync or scp -(refer to Chapter 20, Download infrastructure for more details). If you enable -packages using any of these methods, you will need to install the -corresponding tool on the host system:

    • -bazaar -
    • -cvs -
    • -git -
    • -mercurial -
    • -rsync -
    • -scp -
    • -subversion -
  • -Java-related packages, if the Java Classpath needs to be built for - the target system: -

    • -The javac compiler -
    • -The jar tool -
  • -Documentation generation tools: -

    • -asciidoc, version 8.6.3 or higher -
    • -w3m -
    • -python with the argparse module (automatically present in 2.7+ and 3.2+) -
    • -dblatex (required for the pdf manual only) -
  • -Graph generation tools: -

    • -graphviz to use graph-depends and <pkg>-graph-depends -
    • -python-matplotlib to use graph-build -

Chapter 3. Getting Buildroot

Buildroot releases are made every 3 months, in February, May, August and -November. Release numbers are in the format YYYY.MM, so for example -2013.02, 2014.08.

Release tarballs are available at http://buildroot.org/downloads/.

For your convenience, a Vagrantfile is -available in support/misc/Vagrantfile in the Buildroot source tree -to quickly set up a virtual machine with the needed dependencies to -get started.

If you want to setup an isolated buildroot environment on Linux or Mac -Os X, paste this line onto your terminal:

curl -O https://buildroot.org/downloads/Vagrantfile; vagrant up

If you are on Windows, paste this into your powershell:

(new-object System.Net.WebClient).DownloadFile(
-"https://buildroot.org/downloads/Vagrantfile","Vagrantfile");
-vagrant up

If you want to follow development, you can use the daily snapshots or -make a clone of the Git repository. Refer to the -Download page of the Buildroot website -for more details.

Chapter 4. Buildroot quick start

Important: you can and should build everything as a normal user. There -is no need to be root to configure and use Buildroot. By running all -commands as a regular user, you protect your system against packages -behaving badly during compilation and installation.

The first step when using Buildroot is to create a configuration. -Buildroot has a nice configuration tool similar to the one you can -find in the Linux kernel or in -BusyBox.

From the buildroot directory, run

 $ make menuconfig

for the original curses-based configurator, or

 $ make nconfig

for the new curses-based configurator, or

 $ make xconfig

for the Qt-based configurator, or

 $ make gconfig

for the GTK-based configurator.

All of these "make" commands will need to build a configuration -utility (including the interface), so you may need to install -"development" packages for relevant libraries used by the -configuration utilities. Refer to Chapter 2, System requirements for more details, -specifically the optional requirements -to get the dependencies of your favorite interface.

For each menu entry in the configuration tool, you can find associated -help that describes the purpose of the entry. Refer to Chapter 6, Buildroot configuration -for details on some specific configuration aspects.

Once everything is configured, the configuration tool generates a -.config file that contains the entire configuration. This file will be -read by the top-level Makefile.

To start the build process, simply run:

 $ make

By default, Buildroot does not support top-level parallel build, so -running make -jN is not necessary. There is however experimental -support for top-level parallel build, see -Section 8.12, “Top-level parallel build”.

The make command will generally perform the following steps:

  • -download source files (as required); -
  • -configure, build and install the cross-compilation toolchain, or - simply import an external toolchain; -
  • -configure, build and install selected target packages; -
  • -build a kernel image, if selected; -
  • -build a bootloader image, if selected; -
  • -create a root filesystem in selected formats. -

Buildroot output is stored in a single directory, output/. -This directory contains several subdirectories:

  • -images/ where all the images (kernel image, bootloader and root - filesystem images) are stored. These are the files you need to put - on your target system. -
  • -build/ where all the components are built (this includes tools - needed by Buildroot on the host and packages compiled for the - target). This directory contains one subdirectory for each of these - components. -
  • -host/ contains both the tools built for the host, and the sysroot - of the target toolchain. The former is an installation of tools - compiled for the host that are needed for the proper execution of - Buildroot, including the cross-compilation toolchain. The latter - is a hierarchy similar to a root filesystem hierarchy. It contains - the headers and libraries of all user-space packages that provide - and install libraries used by other packages. However, this - directory is not intended to be the root filesystem for the target: - it contains a lot of development files, unstripped binaries and - libraries that make it far too big for an embedded system. These - development files are used to compile libraries and applications for - the target that depend on other libraries. -
  • -staging/ is a symlink to the target toolchain sysroot inside - host/, which exists for backwards compatibility. -
  • -target/ which contains almost the complete root filesystem for - the target: everything needed is present except the device files in - /dev/ (Buildroot can’t create them because Buildroot doesn’t run - as root and doesn’t want to run as root). Also, it doesn’t have the correct - permissions (e.g. setuid for the busybox binary). Therefore, this directory - should not be used on your target. Instead, you should use one of - the images built in the images/ directory. If you need an - extracted image of the root filesystem for booting over NFS, then - use the tarball image generated in images/ and extract it as - root. Compared to staging/, target/ contains only the files and - libraries needed to run the selected target applications: the - development files (headers, etc.) are not present, the binaries are - stripped. -

These commands, make menuconfig|nconfig|gconfig|xconfig and make, are the -basic ones that allow to easily and quickly generate images fitting -your needs, with all the features and applications you enabled.

More details about the "make" command usage are given in -Section 8.1, “make tips”.

Chapter 5. Community resources

Like any open source project, Buildroot has different ways to share -information in its community and outside.

Each of those ways may interest you if you are looking for some help, -want to understand Buildroot or contribute to the project.

-Mailing List -

Buildroot has a mailing list for discussion and development. It is the -main method of interaction for Buildroot users and developers.

Only subscribers to the Buildroot mailing list are allowed to post to -this list. You can subscribe via the -mailing list info -page.

Mails that are sent to the mailing list are also available in the -mailing list archives, available through -Mailman or at -lore.kernel.org.

-IRC -

The Buildroot IRC channel #buildroot is -hosted on OFTC. It is a useful place to -ask quick questions or discuss on certain topics.

When asking for help on IRC, share relevant logs or pieces of code -using a code sharing website, such as https://paste.ack.tf/.

Note that for certain questions, posting to the mailing list may be -better as it will reach more people, both developers and users.

-Bug tracker -
Bugs in Buildroot can be reported via the mailing list or alternatively -via the Buildroot -bugtracker. Please refer to Section 22.6, “Reporting issues/bugs or getting help” before creating a bug -report.
-Wiki -
The Buildroot wiki page is hosted on -the eLinux wiki. It contains some useful links, an -overview of past and upcoming events, and a TODO list.
-Patchwork -

Patchwork is a web-based patch tracking system designed to facilitate -the contribution and management of contributions to an open-source -project. Patches that have been sent to a mailing list are 'caught' by -the system, and appear on a web page. Any comments posted that -reference the patch are appended to the patch page too. For more -information on Patchwork see -http://jk.ozlabs.org/projects/patchwork/.

Buildroot’s Patchwork website is mainly for use by Buildroot’s -maintainer to ensure patches aren’t missed. It is also used by Buildroot -patch reviewers (see also Section 22.3.1, “Applying Patches from Patchwork”). -However, since the website exposes patches and their corresponding -review comments in a clean and concise web interface, it can be useful -for all Buildroot developers.

The Buildroot patch management interface is available at -http://patchwork.buildroot.org.

Part II. User guide

Chapter 6. Buildroot configuration

All the configuration options in make *config have a help text -providing details about the option.

The make *config commands also offer a search tool. Read the help -message in the different frontend menus to know how to use it:

  • -in menuconfig, the search tool is called by pressing /; -
  • -in xconfig, the search tool is called by pressing Ctrl + f. -

The result of the search shows the help message of the matching items. -In menuconfig, numbers in the left column provide a shortcut to the -corresponding entry. Just type this number to directly jump to the -entry, or to the containing menu in case the entry is not selectable due -to a missing dependency.

Although the menu structure and the help text of the entries should be -sufficiently self-explanatory, a number of topics require additional -explanation that cannot easily be covered in the help text and are -therefore covered in the following sections.

6.1. Cross-compilation toolchain

A compilation toolchain is the set of tools that allows you to compile -code for your system. It consists of a compiler (in our case, gcc), -binary utils like assembler and linker (in our case, binutils) and a -C standard library (for example -GNU Libc, -uClibc-ng).

The system installed on your development station certainly already has -a compilation toolchain that you can use to compile an application -that runs on your system. If you’re using a PC, your compilation -toolchain runs on an x86 processor and generates code for an x86 -processor. Under most Linux systems, the compilation toolchain uses -the GNU libc (glibc) as the C standard library. This compilation -toolchain is called the "host compilation toolchain". The machine on -which it is running, and on which you’re working, is called the "host -system" [3].

The compilation toolchain is provided by your distribution, and -Buildroot has nothing to do with it (other than using it to build a -cross-compilation toolchain and other tools that are run on the -development host).

As said above, the compilation toolchain that comes with your system -runs on and generates code for the processor in your host system. As -your embedded system has a different processor, you need a -cross-compilation toolchain - a compilation toolchain that runs on -your host system but generates code for your target system (and -target processor). For example, if your host system uses x86 and your -target system uses ARM, the regular compilation toolchain on your host -runs on x86 and generates code for x86, while the cross-compilation -toolchain runs on x86 and generates code for ARM.

Buildroot provides two solutions for the cross-compilation toolchain:

  • -The internal toolchain backend, called Buildroot toolchain in - the configuration interface. -
  • -The external toolchain backend, called External toolchain in - the configuration interface. -

The choice between these two solutions is done using the Toolchain -Type option in the Toolchain menu. Once one solution has been -chosen, a number of configuration options appear, they are detailed in -the following sections.

6.1.1. Internal toolchain backend

The internal toolchain backend is the backend where Buildroot builds -by itself a cross-compilation toolchain, before building the userspace -applications and libraries for your target embedded system.

This backend supports several C libraries: -uClibc-ng, -glibc and -musl.

Once you have selected this backend, a number of options appear. The -most important ones allow to:

  • -Change the version of the Linux kernel headers used to build the - toolchain. This item deserves a few explanations. In the process of - building a cross-compilation toolchain, the C library is being - built. This library provides the interface between userspace - applications and the Linux kernel. In order to know how to "talk" - to the Linux kernel, the C library needs to have access to the - Linux kernel headers (i.e. the .h files from the kernel), which - define the interface between userspace and the kernel (system - calls, data structures, etc.). Since this interface is backward - compatible, the version of the Linux kernel headers used to build - your toolchain do not need to match exactly the version of the - Linux kernel you intend to run on your embedded system. They only - need to have a version equal or older to the version of the Linux - kernel you intend to run. If you use kernel headers that are more - recent than the Linux kernel you run on your embedded system, then - the C library might be using interfaces that are not provided by - your Linux kernel. -
  • -Change the version of the GCC compiler, binutils and the C library. -
  • -Select a number of toolchain options (uClibc only): whether the - toolchain should have RPC support (used mainly for NFS), - wide-char support, locale support (for internationalization), - C++ support or thread support. Depending on which options you choose, - the number of userspace applications and libraries visible in - Buildroot menus will change: many applications and libraries require - certain toolchain options to be enabled. Most packages show a comment - when a certain toolchain option is required to be able to enable - those packages. If needed, you can further refine the uClibc - configuration by running make uclibc-menuconfig. Note however that - all packages in Buildroot are tested against the default uClibc - configuration bundled in Buildroot: if you deviate from this - configuration by removing features from uClibc, some packages may no - longer build. -

It is worth noting that whenever one of those options is modified, -then the entire toolchain and system must be rebuilt. See -Section 8.2, “Understanding when a full rebuild is necessary”.

Advantages of this backend:

  • -Well integrated with Buildroot -
  • -Fast, only builds what’s necessary -

Drawbacks of this backend:

  • -Rebuilding the toolchain is needed when doing make clean, which - takes time. If you’re trying to reduce your build time, consider - using the External toolchain backend. -

6.1.2. External toolchain backend

The external toolchain backend allows to use existing pre-built -cross-compilation toolchains. Buildroot knows about a number of -well-known cross-compilation toolchains (from -Linaro for ARM, -Sourcery -CodeBench for ARM, x86-64, PowerPC, and MIPS, and is capable of -downloading them automatically, or it can be pointed to a custom -toolchain, either available for download or installed locally.

Then, you have three solutions to use an external toolchain:

  • -Use a predefined external toolchain profile, and let Buildroot - download, extract and install the toolchain. Buildroot already knows - about a few CodeSourcery and Linaro toolchains. Just select the - toolchain profile in Toolchain from the available ones. This is - definitely the easiest solution. -
  • -Use a predefined external toolchain profile, but instead of having - Buildroot download and extract the toolchain, you can tell Buildroot - where your toolchain is already installed on your system. Just - select the toolchain profile in Toolchain through the available - ones, unselect Download toolchain automatically, and fill the - Toolchain path text entry with the path to your cross-compiling - toolchain. -
  • -Use a completely custom external toolchain. This is particularly - useful for toolchains generated using crosstool-NG or with Buildroot - itself. To do this, select the Custom toolchain solution in the - Toolchain list. You need to fill the Toolchain path, Toolchain - prefix and External toolchain C library options. Then, you have - to tell Buildroot what your external toolchain supports. If your - external toolchain uses the glibc library, you only have to tell - whether your toolchain supports C++ or not and whether it has - built-in RPC support. If your external toolchain uses the uClibc - library, then you have to tell Buildroot if it supports RPC, - wide-char, locale, program invocation, threads and C++. - At the beginning of the execution, Buildroot will tell you if - the selected options do not match the toolchain configuration. -

Our external toolchain support has been tested with toolchains from -CodeSourcery and Linaro, toolchains generated by -crosstool-NG, and toolchains generated by -Buildroot itself. In general, all toolchains that support the -sysroot feature should work. If not, do not hesitate to contact the -developers.

We do not support toolchains or SDK generated by OpenEmbedded or -Yocto, because these toolchains are not pure toolchains (i.e. just the -compiler, binutils, the C and C++ libraries). Instead these toolchains -come with a very large set of pre-compiled libraries and -programs. Therefore, Buildroot cannot import the sysroot of the -toolchain, as it would contain hundreds of megabytes of pre-compiled -libraries that are normally built by Buildroot.

We also do not support using the distribution toolchain (i.e. the -gcc/binutils/C library installed by your distribution) as the -toolchain to build software for the target. This is because your -distribution toolchain is not a "pure" toolchain (i.e. only with the -C/C++ library), so we cannot import it properly into the Buildroot -build environment. So even if you are building a system for a x86 or -x86_64 target, you have to generate a cross-compilation toolchain with -Buildroot or crosstool-NG.

If you want to generate a custom toolchain for your project, that can -be used as an external toolchain in Buildroot, our recommendation is -to build it either with Buildroot itself (see -Section 6.1.3, “Build an external toolchain with Buildroot”) or with -crosstool-NG.

Advantages of this backend:

  • -Allows to use well-known and well-tested cross-compilation - toolchains. -
  • -Avoids the build time of the cross-compilation toolchain, which is - often very significant in the overall build time of an embedded - Linux system. -

Drawbacks of this backend:

  • -If your pre-built external toolchain has a bug, may be hard to get a - fix from the toolchain vendor, unless you build your external - toolchain by yourself using Buildroot or Crosstool-NG. -

6.1.3. Build an external toolchain with Buildroot

The Buildroot internal toolchain option can be used to create an -external toolchain. Here are a series of steps to build an internal -toolchain and package it up for reuse by Buildroot itself (or other -projects).

Create a new Buildroot configuration, with the following details:

  • -Select the appropriate Target options for your target CPU - architecture -
  • -In the Toolchain menu, keep the default of Buildroot toolchain - for Toolchain type, and configure your toolchain as desired -
  • -In the System configuration menu, select None as the Init - system and none as /bin/sh -
  • -In the Target packages menu, disable BusyBox -
  • -In the Filesystem images menu, disable tar the root filesystem -

Then, we can trigger the build, and also ask Buildroot to generate a -SDK. This will conveniently generate for us a tarball which contains -our toolchain:

make sdk

This produces the SDK tarball in $(O)/images, with a name similar to -arm-buildroot-linux-uclibcgnueabi_sdk-buildroot.tar.gz. Save this -tarball, as it is now the toolchain that you can re-use as an external -toolchain in other Buildroot projects.

In those other Buildroot projects, in the Toolchain menu:

  • -Set Toolchain type to External toolchain -
  • -Set Toolchain to Custom toolchain -
  • -Set Toolchain origin to Toolchain to be downloaded and installed -
  • -Set Toolchain URL to file:///path/to/your/sdk/tarball.tar.gz -

External toolchain wrapper

When using an external toolchain, Buildroot generates a wrapper program, -that transparently passes the appropriate options (according to the -configuration) to the external toolchain programs. In case you need to -debug this wrapper to check exactly what arguments are passed, you can -set the environment variable BR2_DEBUG_WRAPPER to either one of:

  • -0, empty or not set: no debug -
  • -1: trace all arguments on a single line -
  • -2: trace one argument per line -

6.2. /dev management

On a Linux system, the /dev directory contains special files, called -device files, that allow userspace applications to access the -hardware devices managed by the Linux kernel. Without these device -files, your userspace applications would not be able to use the -hardware devices, even if they are properly recognized by the Linux -kernel.

Under System configuration, /dev management, Buildroot offers four -different solutions to handle the /dev directory :

  • -The first solution is Static using device table. This is the old - classical way of handling device files in Linux. With this method, - the device files are persistently stored in the root filesystem - (i.e. they persist across reboots), and there is nothing that will - automatically create and remove those device files when hardware - devices are added or removed from the system. Buildroot therefore - creates a standard set of device files using a device table, the - default one being stored in system/device_table_dev.txt in the - Buildroot source code. This file is processed when Buildroot - generates the final root filesystem image, and the device files - are therefore not visible in the output/target directory. The - BR2_ROOTFS_STATIC_DEVICE_TABLE option allows to change the - default device table used by Buildroot, or to add an additional - device table, so that additional device files are created by - Buildroot during the build. So, if you use this method, and a - device file is missing in your system, you can for example create - a board/<yourcompany>/<yourproject>/device_table_dev.txt file - that contains the description of your additional device files, - and then you can set BR2_ROOTFS_STATIC_DEVICE_TABLE to - system/device_table_dev.txt - board/<yourcompany>/<yourproject>/device_table_dev.txt. For more - details about the format of the device table file, see - Chapter 25, Makedev syntax documentation. -
  • -The second solution is Dynamic using devtmpfs only. devtmpfs is - a virtual filesystem inside the Linux kernel that has been - introduced in kernel 2.6.32 (if you use an older kernel, it is not - possible to use this option). When mounted in /dev, this virtual - filesystem will automatically make device files appear and - disappear as hardware devices are added and removed from the - system. This filesystem is not persistent across reboots: it is - filled dynamically by the kernel. Using devtmpfs requires the - following kernel configuration options to be enabled: - CONFIG_DEVTMPFS and CONFIG_DEVTMPFS_MOUNT. When Buildroot is in - charge of building the Linux kernel for your embedded device, it - makes sure that those two options are enabled. However, if you - build your Linux kernel outside of Buildroot, then it is your - responsibility to enable those two options (if you fail to do so, - your Buildroot system will not boot). -
  • -The third solution is Dynamic using devtmpfs + mdev. This method - also relies on the devtmpfs virtual filesystem detailed above (so - the requirement to have CONFIG_DEVTMPFS and - CONFIG_DEVTMPFS_MOUNT enabled in the kernel configuration still - apply), but adds the mdev userspace utility on top of it. mdev - is a program part of BusyBox that the kernel will call every time a - device is added or removed. Thanks to the /etc/mdev.conf - configuration file, mdev can be configured to for example, set - specific permissions or ownership on a device file, call a script - or application whenever a device appears or disappear, - etc. Basically, it allows userspace to react on device addition - and removal events. mdev can for example be used to automatically - load kernel modules when devices appear on the system. mdev is - also important if you have devices that require a firmware, as it - will be responsible for pushing the firmware contents to the - kernel. mdev is a lightweight implementation (with fewer - features) of udev. For more details about mdev and the syntax - of its configuration file, see - http://git.busybox.net/busybox/tree/docs/mdev.txt. -
  • -The fourth solution is Dynamic using devtmpfs + eudev. This - method also relies on the devtmpfs virtual filesystem detailed - above, but adds the eudev userspace daemon on top of it. eudev - is a daemon that runs in the background, and gets called by the - kernel when a device gets added or removed from the system. It is a - more heavyweight solution than mdev, but provides higher - flexibility. eudev is a standalone version of udev, the - original userspace daemon used in most desktop Linux distributions, - which is now part of Systemd. For more details, see - http://en.wikipedia.org/wiki/Udev. -

The Buildroot developers recommendation is to start with the Dynamic -using devtmpfs only solution, until you have the need for userspace -to be notified when devices are added/removed, or if firmwares are -needed, in which case Dynamic using devtmpfs + mdev is usually a -good solution.

Note that if systemd is chosen as init system, /dev management will -be performed by the udev program provided by systemd.

6.3. init system

The init program is the first userspace program started by the -kernel (it carries the PID number 1), and is responsible for starting -the userspace services and programs (for example: web server, -graphical applications, other network servers, etc.).

Buildroot allows to use three different types of init systems, which -can be chosen from System configuration, Init system:

  • -The first solution is BusyBox. Amongst many programs, BusyBox has - an implementation of a basic init program, which is sufficient - for most embedded systems. Enabling the BR2_INIT_BUSYBOX will - ensure BusyBox will build and install its init program. This is - the default solution in Buildroot. The BusyBox init program will - read the /etc/inittab file at boot to know what to do. The syntax - of this file can be found in - http://git.busybox.net/busybox/tree/examples/inittab (note that - BusyBox inittab syntax is special: do not use a random inittab - documentation from the Internet to learn about BusyBox - inittab). The default inittab in Buildroot is stored in - system/skeleton/etc/inittab. Apart from mounting a few important - filesystems, the main job the default inittab does is to start the - /etc/init.d/rcS shell script, and start a getty program (which - provides a login prompt). -
  • -The second solution is systemV. This solution uses the old - traditional sysvinit program, packed in Buildroot in - package/sysvinit. This was the solution used in most desktop - Linux distributions, until they switched to more recent - alternatives such as Upstart or Systemd. sysvinit also works with - an inittab file (which has a slightly different syntax than the - one from BusyBox). The default inittab installed with this init - solution is located in package/sysvinit/inittab. -
  • -The third solution is systemd. systemd is the new generation - init system for Linux. It does far more than traditional init - programs: aggressive parallelization capabilities, uses socket and - D-Bus activation for starting services, offers on-demand starting - of daemons, keeps track of processes using Linux control groups, - supports snapshotting and restoring of the system state, - etc. systemd will be useful on relatively complex embedded - systems, for example the ones requiring D-Bus and services - communicating between each other. It is worth noting that systemd - brings a fairly big number of large dependencies: dbus, udev - and more. For more details about systemd, see - http://www.freedesktop.org/wiki/Software/systemd. -

The solution recommended by Buildroot developers is to use the -BusyBox init as it is sufficient for most embedded -systems. systemd can be used for more complex situations.



[3] This terminology differs from what is used by GNU -configure, where the host is the machine on which the application will -run (which is usually the same as target)

Chapter 7. Configuration of other components

Before attempting to modify any of the components below, make sure you -have already configured Buildroot itself, and have enabled the -corresponding package.

-BusyBox -

If you already have a BusyBox configuration file, you can directly -specify this file in the Buildroot configuration, using -BR2_PACKAGE_BUSYBOX_CONFIG. Otherwise, Buildroot will start from a -default BusyBox configuration file.

To make subsequent changes to the configuration, use make -busybox-menuconfig to open the BusyBox configuration editor.

It is also possible to specify a BusyBox configuration file through an -environment variable, although this is not recommended. Refer to -Section 8.6, “Environment variables” for more details.

-uClibc -
Configuration of uClibc is done in the same way as for BusyBox. The -configuration variable to specify an existing configuration file is -BR2_UCLIBC_CONFIG. The command to make subsequent changes is make -uclibc-menuconfig.
-Linux kernel -

If you already have a kernel configuration file, you can directly -specify this file in the Buildroot configuration, using -BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG.

If you do not yet have a kernel configuration file, you can either start -by specifying a defconfig in the Buildroot configuration, using -BR2_LINUX_KERNEL_USE_DEFCONFIG, or start by creating an empty file and -specifying it as custom configuration file, using -BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG.

To make subsequent changes to the configuration, use make -linux-menuconfig to open the Linux configuration editor.

-Barebox -
Configuration of Barebox is done in the same way as for the Linux -kernel. The corresponding configuration variables are -BR2_TARGET_BAREBOX_USE_CUSTOM_CONFIG and -BR2_TARGET_BAREBOX_USE_DEFCONFIG. To open the configuration editor, -use make barebox-menuconfig.
-U-Boot -
Configuration of U-Boot (version 2015.04 or newer) is done in the same -way as for the Linux kernel. The corresponding configuration variables -are BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG and -BR2_TARGET_UBOOT_USE_DEFCONFIG. To open the configuration editor, -use make uboot-menuconfig.

Chapter 8. General Buildroot usage

8.1. make tips

This is a collection of tips that help you make the most of Buildroot.

Display all commands executed by make:  -

 $ make V=1 <target>

-

Display the list of boards with a defconfig:  -

 $ make list-defconfigs

-

Display all available targets:  -

 $ make help

-

Not all targets are always available, -some settings in the .config file may hide some targets:

  • -busybox-menuconfig only works when busybox is enabled; -
  • -linux-menuconfig and linux-savedefconfig only work when - linux is enabled; -
  • -uclibc-menuconfig is only available when the uClibc C library is - selected in the internal toolchain backend; -
  • -barebox-menuconfig and barebox-savedefconfig only work when the - barebox bootloader is enabled. -
  • -uboot-menuconfig and uboot-savedefconfig only work when the - U-Boot bootloader is enabled. -

Cleaning: Explicit cleaning is required when any of the architecture or toolchain -configuration options are changed.

To delete all build products (including build directories, host, staging -and target trees, the images and the toolchain):

 $ make clean

Generating the manual: The present manual sources are located in the docs/manual directory. -To generate the manual:

 $ make manual-clean
- $ make manual

The manual outputs will be generated in output/docs/manual.

Notes

Resetting Buildroot for a new target: To delete all build products as well as the configuration:

 $ make distclean

Notes. If ccache is enabled, running make clean or distclean does -not empty the compiler cache used by Buildroot. To delete it, refer -to Section 8.14.3, “Using ccache in Buildroot”.

Dumping the internal make variables: One can dump the variables known to make, along with their values:

 $ make -s printvars VARS='VARIABLE1 VARIABLE2'
- VARIABLE1=value_of_variable
- VARIABLE2=value_of_variable

It is possible to tweak the output using some variables:

  • -VARS will limit the listing to variables which names match the - specified make-patterns - this must be set else nothing is printed -
  • -QUOTED_VARS, if set to YES, will single-quote the value -
  • -RAW_VARS, if set to YES, will print the unexpanded value -

For example:

 $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES
- BUSYBOX_DEPENDENCIES=skeleton toolchain
- BUSYBOX_FINAL_ALL_DEPENDENCIES=skeleton toolchain
- BUSYBOX_FINAL_DEPENDENCIES=skeleton toolchain
- BUSYBOX_FINAL_PATCH_DEPENDENCIES=
- BUSYBOX_RDEPENDENCIES=ncurses util-linux
 $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES QUOTED_VARS=YES
- BUSYBOX_DEPENDENCIES='skeleton toolchain'
- BUSYBOX_FINAL_ALL_DEPENDENCIES='skeleton toolchain'
- BUSYBOX_FINAL_DEPENDENCIES='skeleton toolchain'
- BUSYBOX_FINAL_PATCH_DEPENDENCIES=''
- BUSYBOX_RDEPENDENCIES='ncurses util-linux'
 $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES RAW_VARS=YES
- BUSYBOX_DEPENDENCIES=skeleton toolchain
- BUSYBOX_FINAL_ALL_DEPENDENCIES=$(sort $(BUSYBOX_FINAL_DEPENDENCIES) $(BUSYBOX_FINAL_PATCH_DEPENDENCIES))
- BUSYBOX_FINAL_DEPENDENCIES=$(sort $(BUSYBOX_DEPENDENCIES))
- BUSYBOX_FINAL_PATCH_DEPENDENCIES=$(sort $(BUSYBOX_PATCH_DEPENDENCIES))
- BUSYBOX_RDEPENDENCIES=ncurses util-linux

The output of quoted variables can be reused in shell scripts, for example:

 $ eval $(make -s printvars VARS=BUSYBOX_DEPENDENCIES QUOTED_VARS=YES)
- $ echo $BUSYBOX_DEPENDENCIES
- skeleton toolchain

8.2. Understanding when a full rebuild is necessary

Buildroot does not attempt to detect what parts of the system should -be rebuilt when the system configuration is changed through make -menuconfig, make xconfig or one of the other configuration -tools. In some cases, Buildroot should rebuild the entire system, in -some cases, only a specific subset of packages. But detecting this in -a completely reliable manner is very difficult, and therefore the -Buildroot developers have decided to simply not attempt to do this.

Instead, it is the responsibility of the user to know when a full -rebuild is necessary. As a hint, here are a few rules of thumb that -can help you understand how to work with Buildroot:

  • -When the target architecture configuration is changed, a complete - rebuild is needed. Changing the architecture variant, the binary - format or the floating point strategy for example has an impact on - the entire system. -
  • -When the toolchain configuration is changed, a complete rebuild - generally is needed. Changing the toolchain configuration often - involves changing the compiler version, the type of C library or - its configuration, or some other fundamental configuration item, - and these changes have an impact on the entire system. -
  • -When an additional package is added to the configuration, a full - rebuild is not necessarily needed. Buildroot will detect that this - package has never been built, and will build it. However, if this - package is a library that can optionally be used by packages that - have already been built, Buildroot will not automatically rebuild - those. Either you know which packages should be rebuilt, and you - can rebuild them manually, or you should do a full rebuild. For - example, let’s suppose you have built a system with the ctorrent - package, but without openssl. Your system works, but you realize - you would like to have SSL support in ctorrent, so you enable the - openssl package in Buildroot configuration and restart the - build. Buildroot will detect that openssl should be built and - will be build it, but it will not detect that ctorrent should be - rebuilt to benefit from openssl to add OpenSSL support. You will - either have to do a full rebuild, or rebuild ctorrent itself. -
  • -When a package is removed from the configuration, Buildroot does - not do anything special. It does not remove the files installed by - this package from the target root filesystem or from the toolchain - sysroot. A full rebuild is needed to get rid of this - package. However, generally you don’t necessarily need this package - to be removed right now: you can wait for the next lunch break to - restart the build from scratch. -
  • -When the sub-options of a package are changed, the package is not - automatically rebuilt. After making such changes, rebuilding only - this package is often sufficient, unless enabling the package - sub-option adds some features to the package that are useful for - another package which has already been built. Again, Buildroot does - not track when a package should be rebuilt: once a package has been - built, it is never rebuilt unless explicitly told to do so. -
  • -When a change to the root filesystem skeleton is made, a full - rebuild is needed. However, when changes to the root filesystem - overlay, a post-build script or a post-image script are made, - there is no need for a full rebuild: a simple make invocation - will take the changes into account. -
  • -When a package listed in FOO_DEPENDENCIES is rebuilt or removed, - the package foo is not automatically rebuilt. For example, if a - package bar is listed in FOO_DEPENDENCIES with FOO_DEPENDENCIES - = bar and the configuration of the bar package is changed, the - configuration change would not result in a rebuild of package foo - automatically. In this scenario, you may need to either rebuild any - packages in your build which reference bar in their DEPENDENCIES, - or perform a full rebuild to ensure any bar dependent packages are - up to date. -

Generally speaking, when you’re facing a build error and you’re unsure -of the potential consequences of the configuration changes you’ve -made, do a full rebuild. If you get the same build error, then you are -sure that the error is not related to partial rebuilds of packages, -and if this error occurs with packages from the official Buildroot, do -not hesitate to report the problem! As your experience with Buildroot -progresses, you will progressively learn when a full rebuild is really -necessary, and you will save more and more time.

For reference, a full rebuild is achieved by running:

$ make clean all

8.3. Understanding how to rebuild packages

One of the most common questions asked by Buildroot users is how to -rebuild a given package or how to remove a package without rebuilding -everything from scratch.

Removing a package is unsupported by Buildroot without -rebuilding from scratch. This is because Buildroot doesn’t keep track -of which package installs what files in the output/staging and -output/target directories, or which package would be compiled differently -depending on the availability of another package.

The easiest way to rebuild a single package from scratch is to remove -its build directory in output/build. Buildroot will then re-extract, -re-configure, re-compile and re-install this package from scratch. You -can ask buildroot to do this with the make <package>-dirclean command.

On the other hand, if you only want to restart the build process of a -package from its compilation step, you can run make <package>-rebuild. It -will restart the compilation and installation of the package, but not from -scratch: it basically re-executes make and make install inside the package, -so it will only rebuild files that changed.

If you want to restart the build process of a package from its configuration -step, you can run make <package>-reconfigure. It will restart the -configuration, compilation and installation of the package.

While <package>-rebuild implies <package>-reinstall and -<package>-reconfigure implies <package>-rebuild, these targets as well -as <package> only act on the said package, and do not trigger re-creating -the root filesystem image. If re-creating the root filesystem in necessary, -one should in addition run make or make all.

Internally, Buildroot creates so-called stamp files to keep track of -which build steps have been completed for each package. They are -stored in the package build directory, -output/build/<package>-<version>/ and are named -.stamp_<step-name>. The commands detailed above simply manipulate -these stamp files to force Buildroot to restart a specific set of -steps of a package build process.

Further details about package special make targets are explained in -Section 8.14.5, “Package-specific make targets”.

8.4. Offline builds

If you intend to do an offline build and just want to download -all sources that you previously selected in the configurator -(menuconfig, nconfig, xconfig or gconfig), then issue:

 $ make source

You can now disconnect or copy the content of your dl -directory to the build-host.

8.5. Building out-of-tree

As default, everything built by Buildroot is stored in the directory -output in the Buildroot tree.

Buildroot also supports building out of tree with a syntax similar to -the Linux kernel. To use it, add O=<directory> to the make command -line:

 $ make O=/tmp/build

Or:

 $ cd /tmp/build; make O=$PWD -C path/to/buildroot

All the output files will be located under /tmp/build. If the O -path does not exist, Buildroot will create it.

Note: the O path can be either an absolute or a relative path, but if it’s -passed as a relative path, it is important to note that it is interpreted -relative to the main Buildroot source directory, not the current working -directory.

When using out-of-tree builds, the Buildroot .config and temporary -files are also stored in the output directory. This means that you can -safely run multiple builds in parallel using the same source tree as -long as they use unique output directories.

For ease of use, Buildroot generates a Makefile wrapper in the output -directory - so after the first run, you no longer need to pass O=<…> -and -C <…>, simply run (in the output directory):

 $ make <target>

8.6. Environment variables

Buildroot also honors some environment variables, when they are passed -to make or set in the environment:

  • -HOSTCXX, the host C++ compiler to use -
  • -HOSTCC, the host C compiler to use -
  • -UCLIBC_CONFIG_FILE=<path/to/.config>, path to - the uClibc configuration file, used to compile uClibc, if an - internal toolchain is being built. - - Note that the uClibc configuration file can also be set from the - configuration interface, so through the Buildroot .config file; this - is the recommended way of setting it. - -
  • -BUSYBOX_CONFIG_FILE=<path/to/.config>, path to - the BusyBox configuration file. - - Note that the BusyBox configuration file can also be set from the - configuration interface, so through the Buildroot .config file; this - is the recommended way of setting it. - -
  • -BR2_CCACHE_DIR to override the directory where - Buildroot stores the cached files when using ccache. - -
  • -BR2_DL_DIR to override the directory in which - Buildroot stores/retrieves downloaded files. - - Note that the Buildroot download directory can also be set from the - configuration interface, so through the Buildroot .config file. See - Section 8.14.4, “Location of downloaded packages” for more details on how you can set the download - directory. -
  • -BR2_GRAPH_ALT, if set and non-empty, to use an alternate color-scheme in - build-time graphs -
  • -BR2_GRAPH_OUT to set the filetype of generated graphs, either pdf (the - default), or png. -
  • -BR2_GRAPH_DEPS_OPTS to pass extra options to the dependency graph; see - Section 8.9, “Graphing the dependencies between packages” for the accepted options -
  • -BR2_GRAPH_DOT_OPTS is passed verbatim as options to the dot utility to - draw the dependency graph. -
  • -BR2_GRAPH_SIZE_OPTS to pass extra options to the size graph; see - Section 8.11, “Graphing the filesystem size contribution of packages” for the acepted options -

An example that uses config files located in the toplevel directory and -in your $HOME:

 $ make UCLIBC_CONFIG_FILE=uClibc.config BUSYBOX_CONFIG_FILE=$HOME/bb.config

If you want to use a compiler other than the default gcc -or g++ for building helper-binaries on your host, then do

 $ make HOSTCXX=g++-4.3-HEAD HOSTCC=gcc-4.3-HEAD

8.7. Dealing efficiently with filesystem images

Filesystem images can get pretty big, depending on the filesystem you choose, -the number of packages, whether you provisioned free space… Yet, some -locations in the filesystems images may just be empty (e.g. a long run of -zeroes); such a file is called a sparse file.

Most tools can handle sparse files efficiently, and will only store or write -those parts of a sparse file that are not empty.

For example:

  • -tar accepts the -S option to tell it to only store non-zero blocks - of sparse files: -

    • -tar cf archive.tar -S [files…] will efficiently store sparse files - in a tarball -
    • -tar xf archive.tar -S will efficiently store sparse files extracted - from a tarball -
  • -cp accepts the --sparse=WHEN option (WHEN is one of auto, - never or always): -

    • -cp --sparse=always source.file dest.file will make dest.file a - sparse file if source.file has long runs of zeroes -

Other tools may have similar options. Please consult their respective man -pages.

You can use sparse files if you need to store the filesystem images (e.g. -to transfer from one machine to another), or if you need to send them (e.g. -to the Q&A team).

Note however that flashing a filesystem image to a device while using the -sparse mode of dd may result in a broken filesystem (e.g. the block bitmap -of an ext2 filesystem may be corrupted; or, if you have sparse files in -your filesystem, those parts may not be all-zeroes when read back). You -should only use sparse files when handling files on the build machine, not -when transferring them to an actual device that will be used on the target.

8.8. Details about packages

Buildroot can produce a JSON blurb that describes the set of enabled -packages in the current configuration, together with their -dependencies, licenses and other metadata. This JSON blurb is produced -by using the show-info make target:

make show-info

Buildroot can also produce details about packages as HTML and JSON -output using the pkg-stats make target. Amongst other things, these -details include whether known CVEs (security vulnerabilities) affect -the packages in your current configuration. It also shows if there is -a newer upstream version for those packages.

make pkg-stats

8.9. Graphing the dependencies between packages

One of Buildroot’s jobs is to know the dependencies between packages, -and make sure they are built in the right order. These dependencies -can sometimes be quite complicated, and for a given system, it is -often not easy to understand why such or such package was brought into -the build by Buildroot.

In order to help understanding the dependencies, and therefore better -understand what is the role of the different components in your -embedded Linux system, Buildroot is capable of generating dependency -graphs.

To generate a dependency graph of the full system you have compiled, -simply run:

make graph-depends

You will find the generated graph in -output/graphs/graph-depends.pdf.

If your system is quite large, the dependency graph may be too complex -and difficult to read. It is therefore possible to generate the -dependency graph just for a given package:

make <pkg>-graph-depends

You will find the generated graph in -output/graph/<pkg>-graph-depends.pdf.

Note that the dependency graphs are generated using the dot tool -from the Graphviz project, which you must have installed on your -system to use this feature. In most distributions, it is available as -the graphviz package.

By default, the dependency graphs are generated in the PDF -format. However, by passing the BR2_GRAPH_OUT environment variable, you -can switch to other output formats, such as PNG, PostScript or -SVG. All formats supported by the -T option of the dot tool are -supported.

BR2_GRAPH_OUT=svg make graph-depends

The graph-depends behaviour can be controlled by setting options in the -BR2_GRAPH_DEPS_OPTS environment variable. The accepted options are:

  • ---depth N, -d N, to limit the dependency depth to N levels. The - default, 0, means no limit. -
  • ---stop-on PKG, -s PKG, to stop the graph on the package PKG. - PKG can be an actual package name, a glob, the keyword virtual - (to stop on virtual packages), or the keyword host (to stop on - host packages). The package is still present on the graph, but its - dependencies are not. -
  • ---exclude PKG, -x PKG, like --stop-on, but also omits PKG from - the graph. -
  • ---transitive, --no-transitive, to draw (or not) the transitive - dependencies. The default is to not draw transitive dependencies. -
  • ---colors R,T,H, the comma-separated list of colors to draw the - root package (R), the target packages (T) and the host packages - (H). Defaults to: lightblue,grey,gainsboro -
BR2_GRAPH_DEPS_OPTS='-d 3 --no-transitive --colors=red,green,blue' make graph-depends

8.10. Graphing the build duration

When the build of a system takes a long time, it is sometimes useful -to be able to understand which packages are the longest to build, to -see if anything can be done to speed up the build. In order to help -such build time analysis, Buildroot collects the build time of each -step of each package, and allows to generate graphs from this data.

To generate the build time graph after a build, run:

make graph-build

This will generate a set of files in output/graphs :

  • -build.hist-build.pdf, a histogram of the build time for each - package, ordered in the build order. -
  • -build.hist-duration.pdf, a histogram of the build time for each - package, ordered by duration (longest first) -
  • -build.hist-name.pdf, a histogram of the build time for each - package, order by package name. -
  • -build.pie-packages.pdf, a pie chart of the build time per package -
  • -build.pie-steps.pdf, a pie chart of the global time spent in each - step of the packages build process. -

This graph-build target requires the Python Matplotlib and Numpy -libraries to be installed (python-matplotlib and python-numpy on -most distributions), and also the argparse module if you’re using a -Python version older than 2.7 (python-argparse on most -distributions).

By default, the output format for the graph is PDF, but a different -format can be selected using the BR2_GRAPH_OUT environment variable. The -only other format supported is PNG:

BR2_GRAPH_OUT=png make graph-build

8.11. Graphing the filesystem size contribution of packages

When your target system grows, it is sometimes useful to understand -how much each Buildroot package is contributing to the overall root -filesystem size. To help with such an analysis, Buildroot collects -data about files installed by each package and using this data, -generates a graph and CSV files detailing the size contribution of -the different packages.

To generate these data after a build, run:

make graph-size

This will generate:

  • -output/graphs/graph-size.pdf, a pie chart of the contribution of - each package to the overall root filesystem size -
  • -output/graphs/package-size-stats.csv, a CSV file giving the size - contribution of each package to the overall root filesystem size -
  • -output/graphs/file-size-stats.csv, a CSV file giving the size - contribution of each installed file to the package it belongs, and - to the overall filesystem size. -

This graph-size target requires the Python Matplotlib library to be -installed (python-matplotlib on most distributions), and also the -argparse module if you’re using a Python version older than 2.7 -(python-argparse on most distributions).

Just like for the duration graph, a BR2_GRAPH_OUT environment variable -is supported to adjust the output file format. See Section 8.9, “Graphing the dependencies between packages” -for details about this environment variable.

Additionally, one may set the environment variable BR2_GRAPH_SIZE_OPTS -to further control the generated graph. Accepted options are:

  • ---size-limit X, -l X, will group all packages which individual - contribution is below X percent, to a single entry labelled Others - in the graph. By default, X=0.01, which means packages each - contributing less than 1% are grouped under Others. Accepted values - are in the range [0.0..1.0]. -
  • ---iec, --binary, --si, --decimal, to use IEC (binary, powers - of 1024) or SI (decimal, powers of 1000; the default) prefixes. -
  • ---biggest-first, to sort packages in decreasing size order, rather - than in increasing size order. -

Note. The collected filesystem size data is only meaningful after a complete -clean rebuild. Be sure to run make clean all before using make -graph-size.

To compare the root filesystem size of two different Buildroot compilations, -for example after adjusting the configuration or when switching to another -Buildroot release, use the size-stats-compare script. It takes two -file-size-stats.csv files (produced by make graph-size) as input. -Refer to the help text of this script for more details:

utils/size-stats-compare -h

8.12. Top-level parallel build

Note. This section deals with a very experimental feature, which is known to -break even in some non-unusual situations. Use at your own risk.

Buildroot has always been capable of using parallel build on a per -package basis: each package is built by Buildroot using make -jN (or -the equivalent invocation for non-make-based build systems). The level -of parallelism is by default number of CPUs + 1, but it can be -adjusted using the BR2_JLEVEL configuration option.

Until 2020.02, Buildroot was however building packages in a serial -fashion: each package was built one after the other, without -parallelization of the build between packages. As of 2020.02, -Buildroot has experimental support for top-level parallel build, -which allows some signicant build time savings by building packages -that have no dependency relationship in parallel. This feature is -however marked as experimental and is known not to work in some cases.

In order to use top-level parallel build, one must:

  1. -Enable the option BR2_PER_PACKAGE_DIRECTORIES in the Buildroot -configuration -
  2. -Use make -jN when starting the Buildroot build -

Internally, the BR2_PER_PACKAGE_DIRECTORIES will enable a mechanism -called per-package directories, which will have the following -effects:

  • -Instead of a global target directory and a global host directory - common to all packages, per-package target and host directories - will be used, in $(O)/per-package/<pkg>/target/ and - $(O)/per-package/<pkg>/host/ respectively. Those folders will be - populated from the corresponding folders of the package dependencies - at the beginning of <pkg> build. The compiler and all other tools - will therefore only be able to see and access files installed by - dependencies explicitly listed by <pkg>. -
  • -At the end of the build, the global target and host directories - will be populated, located in $(O)/target and $(O)/host - respectively. This means that during the build, those folders will - be empty and it’s only at the very end of the build that they will - be populated. -

8.13. Integration with Eclipse

While a part of the embedded Linux developers like classical text -editors like Vim or Emacs, and command-line based interfaces, a number -of other embedded Linux developers like richer graphical interfaces to -do their development work. Eclipse being one of the most popular -Integrated Development Environment, Buildroot integrates with Eclipse -in order to ease the development work of Eclipse users.

Our integration with Eclipse simplifies the compilation, remote -execution and remote debugging of applications and libraries that are -built on top of a Buildroot system. It does not integrate the -Buildroot configuration and build processes themselves with -Eclipse. Therefore, the typical usage model of our Eclipse integration -would be:

  • -Configure your Buildroot system with make menuconfig, make - xconfig or any other configuration interface provided with - Buildroot. -
  • -Build your Buildroot system by running make. -
  • -Start Eclipse to develop, execute and debug your own custom - applications and libraries, that will rely on the libraries built - and installed by Buildroot. -

The Buildroot Eclipse integration installation process and usage is -described in detail at -https://github.com/mbats/eclipse-buildroot-bundle/wiki.

8.14. Advanced usage

8.14.1. Using the generated toolchain outside Buildroot

You may want to compile, for your target, your own programs or other -software that are not packaged in Buildroot. In order to do this you -can use the toolchain that was generated by Buildroot.

The toolchain generated by Buildroot is located by default in -output/host/. The simplest way to use it is to add -output/host/bin/ to your PATH environment variable and then to -use ARCH-linux-gcc, ARCH-linux-objdump, ARCH-linux-ld, etc.

Alternatively, Buildroot can also export the toolchain and the development -files of all selected packages, as an SDK, by running the command -make sdk. This generates a tarball of the content of the host directory -output/host/, named <TARGET-TUPLE>_sdk-buildroot.tar.gz (which can be -overriden by setting the environment variable BR2_SDK_PREFIX) and -located in the output directory output/images/.

This tarball can then be distributed to application developers, when -they want to develop their applications that are not (yet) packaged as -a Buildroot package.

Upon extracting the SDK tarball, the user must run the script -relocate-sdk.sh (located at the top directory of the SDK), to make -sure all paths are updated with the new location.

Alternatively, if you just want to prepare the SDK without generating -the tarball (e.g. because you will just be moving the host directory, -or will be generating the tarball on your own), Buildroot also allows -you to just prepare the SDK with make prepare-sdk without actually -generating a tarball.

For your convenience, by selecting the option -BR2_PACKAGE_HOST_ENVIRONMENT_SETUP, you can get a -environment-setup script installed in output/host/ and therefore -in your SDK. This script can be sourced with -. your/sdk/path/environment-setup to export a number of environment -variables that will help cross-compile your projects using the -Buildroot SDK: the PATH will contain the SDK binaries, standard -autotools variables will be defined with the appropriate values, and -CONFIGURE_FLAGS will contain basic ./configure options to -cross-compile autotools projects. It also provides some useful -commands. Note however that once this script is sourced, the -environment is setup only for cross-compilation, and no longer for -native compilation.

8.14.2. Using gdb in Buildroot

Buildroot allows to do cross-debugging, where the debugger runs on the -build machine and communicates with gdbserver on the target to -control the execution of the program.

To achieve this:

  • -If you are using an internal toolchain (built by Buildroot), you - must enable BR2_PACKAGE_HOST_GDB, BR2_PACKAGE_GDB and - BR2_PACKAGE_GDB_SERVER. This ensures that both the cross gdb and - gdbserver get built, and that gdbserver gets installed to your target. -
  • -If you are using an external toolchain, you should enable - BR2_TOOLCHAIN_EXTERNAL_GDB_SERVER_COPY, which will copy the - gdbserver included with the external toolchain to the target. If your - external toolchain does not have a cross gdb or gdbserver, it is also - possible to let Buildroot build them, by enabling the same options as - for the internal toolchain backend. -

Now, to start debugging a program called foo, you should run on the -target:

gdbserver :2345 foo

This will cause gdbserver to listen on TCP port 2345 for a connection -from the cross gdb.

Then, on the host, you should start the cross gdb using the following -command line:

<buildroot>/output/host/bin/<tuple>-gdb -ix <buildroot>/output/staging/usr/share/buildroot/gdbinit foo

Of course, foo must be available in the current directory, built -with debugging symbols. Typically you start this command from the -directory where foo is built (and not from output/target/ as the -binaries in that directory are stripped).

The <buildroot>/output/staging/usr/share/buildroot/gdbinit file will tell the -cross gdb where to find the libraries of the target.

Finally, to connect to the target from the cross gdb:

(gdb) target remote <target ip address>:2345

8.14.3. Using ccache in Buildroot

ccache is a compiler cache. It stores the -object files resulting from each compilation process, and is able to -skip future compilation of the same source file (with same compiler -and same arguments) by using the pre-existing object files. When doing -almost identical builds from scratch a number of times, it can nicely -speed up the build process.

ccache support is integrated in Buildroot. You just have to enable -Enable compiler cache in Build options. This will automatically -build ccache and use it for every host and target compilation.

The cache is located in $HOME/.buildroot-ccache. It is stored -outside of Buildroot output directory so that it can be shared by -separate Buildroot builds. If you want to get rid of the cache, simply -remove this directory.

You can get statistics on the cache (its size, number of hits, -misses, etc.) by running make ccache-stats.

The make target ccache-options and the CCACHE_OPTIONS variable -provide more generic access to the ccache. For example

# set cache limit size
-make CCACHE_OPTIONS="--max-size=5G" ccache-options
-
-# zero statistics counters
-make CCACHE_OPTIONS="--zero-stats" ccache-options

ccache makes a hash of the source files and of the compiler options. -If a compiler option is different, the cached object file will not be -used. Many compiler options, however, contain an absolute path to the -staging directory. Because of this, building in a different output -directory would lead to many cache misses.

To avoid this issue, buildroot has the Use relative paths option -(BR2_CCACHE_USE_BASEDIR). This will rewrite all absolute paths that -point inside the output directory into relative paths. Thus, changing -the output directory no longer leads to cache misses.

A disadvantage of the relative paths is that they also end up to be -relative paths in the object file. Therefore, for example, the debugger -will no longer find the file, unless you cd to the output directory -first.

See the -ccache manual’s section on "Compiling in different directories" for -more details about this rewriting of absolute paths.

8.14.4. Location of downloaded packages

The various tarballs that are downloaded by Buildroot are all stored -in BR2_DL_DIR, which by default is the dl directory. If you want -to keep a complete version of Buildroot which is known to be working -with the associated tarballs, you can make a copy of this directory. -This will allow you to regenerate the toolchain and the target -filesystem with exactly the same versions.

If you maintain several Buildroot trees, it might be better to have a -shared download location. This can be achieved by pointing the -BR2_DL_DIR environment variable to a directory. If this is -set, then the value of BR2_DL_DIR in the Buildroot configuration is -overridden. The following line should be added to <~/.bashrc>.

 export BR2_DL_DIR=<shared download location>

The download location can also be set in the .config file, with the -BR2_DL_DIR option. Unlike most options in the .config file, this value -is overridden by the BR2_DL_DIR environment variable.

8.14.5. Package-specific make targets

Running make <package> builds and installs that particular package -and its dependencies.

For packages relying on the Buildroot infrastructure, there are -numerous special make targets that can be called independently like -this:

make <package>-<target>

The package build targets are (in the order they are executed):

command/target Description

source

Fetch the source (download the tarball, clone -the source repository, etc)

depends

Build and install all dependencies required to -build the package

extract

Put the source in the package build directory -(extract the tarball, copy the source, etc)

patch

Apply the patches, if any

configure

Run the configure commands, if any

build

Run the compilation commands

install-staging

target package: Run the installation of the package in the -staging directory, if necessary

install-target

target package: Run the installation of the package in the -target directory, if necessary

install

target package: Run the 2 previous installation commands

-

host package: Run the installation of the package in the host -directory

Additionally, there are some other useful make targets:

command/target Description

show-depends

Displays the first-order dependencies required to build the -package

show-recursive-depends

Recursively displays the dependencies - required to build the package

show-rdepends

Displays the first-order reverse dependencies of - the package (i.e packages that directly depend on it)

show-recursive-rdepends

Recursively displays the reverse - dependencies of the package (i.e the packages that depend on it, - directly or indirectly)

graph-depends

Generate a dependency graph of the package, in the -context of the current Buildroot configuration. See -this section for more details about dependency -graphs.

graph-rdepends

Generate a graph of this package reverse - dependencies (i.e the packages that depend on it, directly or - indirectly)

dirclean

Remove the whole package build directory

reinstall

Re-run the install commands

rebuild

Re-run the compilation commands - this only makes -sense when using the OVERRIDE_SRCDIR feature or when you modified a file -directly in the build directory

reconfigure

Re-run the configure commands, then rebuild - this only -makes sense when using the OVERRIDE_SRCDIR feature or when you modified a -file directly in the build directory

8.14.6. Using Buildroot during development

The normal operation of Buildroot is to download a tarball, extract -it, configure, compile and install the software component found inside -this tarball. The source code is extracted in -output/build/<package>-<version>, which is a temporary directory: -whenever make clean is used, this directory is entirely removed, and -re-created at the next make invocation. Even when a Git or -Subversion repository is used as the input for the package source -code, Buildroot creates a tarball out of it, and then behaves as it -normally does with tarballs.

This behavior is well-suited when Buildroot is used mainly as an -integration tool, to build and integrate all the components of an -embedded Linux system. However, if one uses Buildroot during the -development of certain components of the system, this behavior is not -very convenient: one would instead like to make a small change to the -source code of one package, and be able to quickly rebuild the system -with Buildroot.

Making changes directly in output/build/<package>-<version> is not -an appropriate solution, because this directory is removed on make -clean.

Therefore, Buildroot provides a specific mechanism for this use case: -the <pkg>_OVERRIDE_SRCDIR mechanism. Buildroot reads an override -file, which allows the user to tell Buildroot the location of the -source for certain packages.

The default location of the override file is $(CONFIG_DIR)/local.mk, -as defined by the BR2_PACKAGE_OVERRIDE_FILE configuration option. -$(CONFIG_DIR) is the location of the Buildroot .config file, so -local.mk by default lives side-by-side with the .config file, -which means:

  • -In the top-level Buildroot source directory for in-tree builds - (i.e., when O= is not used) -
  • -In the out-of-tree directory for out-of-tree builds (i.e., when - O= is used) -

If a different location than these defaults is required, it can be -specified through the BR2_PACKAGE_OVERRIDE_FILE configuration -option.

In this override file, Buildroot expects to find lines of the form:

<pkg1>_OVERRIDE_SRCDIR = /path/to/pkg1/sources
-<pkg2>_OVERRIDE_SRCDIR = /path/to/pkg2/sources

For example:

LINUX_OVERRIDE_SRCDIR = /home/bob/linux/
-BUSYBOX_OVERRIDE_SRCDIR = /home/bob/busybox/

When Buildroot finds that for a given package, an -<pkg>_OVERRIDE_SRCDIR has been defined, it will no longer attempt to -download, extract and patch the package. Instead, it will directly use -the source code available in the specified directory and make clean -will not touch this directory. This allows to point Buildroot to your -own directories, that can be managed by Git, Subversion, or any other -version control system. To achieve this, Buildroot will use rsync to -copy the source code of the component from the specified -<pkg>_OVERRIDE_SRCDIR to output/build/<package>-custom/.

This mechanism is best used in conjunction with the make -<pkg>-rebuild and make <pkg>-reconfigure targets. A make -<pkg>-rebuild all sequence will rsync the source code from -<pkg>_OVERRIDE_SRCDIR to output/build/<package>-custom (thanks to -rsync, only the modified files are copied), and restart the build -process of just this package.

In the example of the linux package above, the developer can then -make a source code change in /home/bob/linux and then run:

make linux-rebuild all

and in a matter of seconds gets the updated Linux kernel image in -output/images. Similarly, a change can be made to the BusyBox source -code in /home/bob/busybox, and after:

make busybox-rebuild all

the root filesystem image in output/images contains the updated -BusyBox.

Source trees for big projects often contain hundreds or thousands of -files which are not needed for building, but will slow down the process -of copying the sources with rsync. Optionally, it is possible define -<pkg>_OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS to skip syncing certain files -from the source tree. For example, when working on the webkitgtk -package, the following will exclude the tests and in-tree builds from -a local WebKit source tree:

WEBKITGTK_OVERRIDE_SRCDIR = /home/bob/WebKit
-WEBKITGTK_OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS = \
-        --exclude JSTests --exclude ManualTests --exclude PerformanceTests \
-        --exclude WebDriverTests --exclude WebKitBuild --exclude WebKitLibraries \
-        --exclude WebKit.xcworkspace --exclude Websites --exclude Examples

By default, Buildroot skips syncing of VCS artifacts (e.g., the .git and -.svn directories). Some packages prefer to have these VCS directories -available during build, for example for automatically determining a precise -commit reference for version information. To undo this built-in filtering at a -cost of a slower speed, add these directories back:

LINUX_OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS = --include .git

Chapter 9. Project-specific customization

Typical actions you may need to perform for a given project are:

  • -configuring Buildroot (including build options and toolchain, - bootloader, kernel, package and filesystem image type selection) -
  • -configuring other components, like the Linux kernel and BusyBox -
  • -customizing the generated target filesystem -

    • -adding or overwriting files on the target filesystem (using - BR2_ROOTFS_OVERLAY) -
    • -modifying or deleting files on the target filesystem (using - BR2_ROOTFS_POST_BUILD_SCRIPT) -
    • -running arbitrary commands prior to generating the filesystem image - (using BR2_ROOTFS_POST_BUILD_SCRIPT) -
    • -setting file permissions and ownership (using - BR2_ROOTFS_DEVICE_TABLE) -
    • -adding custom devices nodes (using - BR2_ROOTFS_STATIC_DEVICE_TABLE) -
  • -adding custom user accounts (using BR2_ROOTFS_USERS_TABLES) -
  • -running arbitrary commands after generating the filesystem image - (using BR2_ROOTFS_POST_IMAGE_SCRIPT) -
  • -adding project-specific patches to some packages (using - BR2_GLOBAL_PATCH_DIR) -
  • -adding project-specific packages -

An important note regarding such project-specific customizations: -please carefully consider which changes are indeed project-specific and -which changes are also useful to developers outside your project. The -Buildroot community highly recommends and encourages the upstreaming of -improvements, packages and board support to the official Buildroot -project. Of course, it is sometimes not possible or desirable to -upstream because the changes are highly specific or proprietary.

This chapter describes how to make such project-specific customizations -in Buildroot and how to store them in a way that you can build the same -image in a reproducible way, even after running make clean. By -following the recommended strategy, you can even use the same Buildroot -tree to build multiple distinct projects!

9.1. Recommended directory structure

When customizing Buildroot for your project, you will be creating one or -more project-specific files that need to be stored somewhere. While most -of these files could be placed in any location as their path is to be -specified in the Buildroot configuration, the Buildroot developers -recommend a specific directory structure which is described in this -section.

Orthogonal to this directory structure, you can choose where you place -this structure itself: either inside the Buildroot tree, or outside of -it using a br2-external tree. Both options are valid, the choice is up -to you.

+-- board/
-|   +-- <company>/
-|       +-- <boardname>/
-|           +-- linux.config
-|           +-- busybox.config
-|           +-- <other configuration files>
-|           +-- post_build.sh
-|           +-- post_image.sh
-|           +-- rootfs_overlay/
-|           |   +-- etc/
-|           |   +-- <some file>
-|           +-- patches/
-|               +-- foo/
-|               |   +-- <some patch>
-|               +-- libbar/
-|                   +-- <some other patches>
-|
-+-- configs/
-|   +-- <boardname>_defconfig
-|
-+-- package/
-|   +-- <company>/
-|       +-- Config.in (if not using a br2-external tree)
-|       +-- <company>.mk (if not using a br2-external tree)
-|       +-- package1/
-|       |    +-- Config.in
-|       |    +-- package1.mk
-|       +-- package2/
-|           +-- Config.in
-|           +-- package2.mk
-|
-+-- Config.in (if using a br2-external tree)
-+-- external.mk (if using a br2-external tree)
-+-- external.desc (if using a br2-external tree)

Details on the files shown above are given further in this chapter.

Note: if you choose to place this structure outside of the Buildroot -tree but in a br2-external tree, the <company> and possibly <boardname> -components may be superfluous and can be left out.

9.1.1. Implementing layered customizations

It is quite common for a user to have several related projects that partly -need the same customizations. Instead of duplicating these -customizations for each project, it is recommended to use a layered -customization approach, as explained in this section.

Almost all of the customization methods available in Buildroot, like -post-build scripts and root filesystem overlays, accept a -space-separated list of items. The specified items are always treated in -order, from left to right. By creating more than one such item, one for -the common customizations and another one for the really -project-specific customizations, you can avoid unnecessary duplication. -Each layer is typically embodied by a separate directory inside -board/<company>/. Depending on your projects, you could even introduce -more than two layers.

An example directory structure for where a user has two customization -layers common and fooboard is:

+-- board/
-    +-- <company>/
-        +-- common/
-        |   +-- post_build.sh
-        |   +-- rootfs_overlay/
-        |   |   +-- ...
-        |   +-- patches/
-        |       +-- ...
-        |
-        +-- fooboard/
-            +-- linux.config
-            +-- busybox.config
-            +-- <other configuration files>
-            +-- post_build.sh
-            +-- rootfs_overlay/
-            |   +-- ...
-            +-- patches/
-                +-- ...

For example, if the user has the BR2_GLOBAL_PATCH_DIR configuration -option set as:

BR2_GLOBAL_PATCH_DIR="board/<company>/common/patches board/<company>/fooboard/patches"

then first the patches from the common layer would be applied, -followed by the patches from the fooboard layer.

9.2. Keeping customizations outside of Buildroot

As already briefly mentioned in Section 9.1, “Recommended directory structure”, you can -place project-specific customizations in two locations:

  • -directly within the Buildroot tree, typically maintaining them using - branches in a version control system so that upgrading to a newer - Buildroot release is easy. -
  • -outside of the Buildroot tree, using the br2-external mechanism. - This mechanism allows to keep package recipes, board support and - configuration files outside of the Buildroot tree, while still - having them nicely integrated in the build logic. We call this - location a br2-external tree. This section explains how to use - the br2-external mechanism and what to provide in a br2-external - tree. -

One can tell Buildroot to use one or more br2-external trees by setting -the BR2_EXTERNAL make variable set to the path(s) of the br2-external -tree(s) to use. It can be passed to any Buildroot make invocation. It -is automatically saved in the hidden .br2-external.mk file in the output -directory. Thanks to this, there is no need to pass BR2_EXTERNAL at -every make invocation. It can however be changed at any time by -passing a new value, and can be removed by passing an empty value.

Note. The path to a br2-external tree can be either absolute or relative. -If it is passed as a relative path, it is important to note that it is -interpreted relative to the main Buildroot source directory, not to -the Buildroot output directory.

Note: If using an br2-external tree from before Buildroot 2016.11, you need to -convert it before you can use it with Buildroot 2016.11 onward. See -Section 27.2, “Migrating to 2016.11” for help on doing so.

Some examples:

buildroot/ $ make BR2_EXTERNAL=/path/to/foo menuconfig

From now on, definitions from the /path/to/foo br2-external tree -will be used:

buildroot/ $ make
-buildroot/ $ make legal-info

We can switch to another br2-external tree at any time:

buildroot/ $ make BR2_EXTERNAL=/where/we/have/bar xconfig

We can also use multiple br2-external trees:

buildroot/ $ make BR2_EXTERNAL=/path/to/foo:/where/we/have/bar menuconfig

Or disable the usage of any br2-external tree:

buildroot/ $ make BR2_EXTERNAL= xconfig

9.2.1. Layout of a br2-external tree

A br2-external tree must contain at least those three files, described -in the following chapters:

  • -external.desc -
  • -external.mk -
  • -Config.in -

Apart from those mandatory files, there may be additional and optional -content that may be present in a br2-external tree, like the configs/ -or provides/ directories. They are described in the following chapters -as well.

A complete example br2-external tree layout is also described later.

The external.desc file

That file describes the br2-external tree: the name and description -for that br2-external tree.

The format for this file is line based, with each line starting by a -keyword, followed by a colon and one or more spaces, followed by the -value assigned to that keyword. There are two keywords currently -recognised:

  • -name, mandatory, defines the name for that br2-external tree. That - name must only use ASCII characters in the set [A-Za-z0-9_]; any - other character is forbidden. Buildroot sets the variable - BR2_EXTERNAL_$(NAME)_PATH to the absolute path of the br2-external - tree, so that you can use it to refer to your br2-external tree. This - variable is available both in Kconfig, so you can use it to source your - Kconfig files (see below) and in the Makefile, so that you can use it - to include other Makefiles (see below) or refer to other files (like - data files) from your br2-external tree. -

    Note: Since it is possible to use multiple br2-external trees at once, this - name is used by Buildroot to generate variables for each of those trees. - That name is used to identify your br2-external tree, so try to come up - with a name that really describes your br2-external tree, in order for - it to be relatively unique, so that it does not clash with another name - from another br2-external tree, especially if you are planning on - somehow sharing your br2-external tree with third parties or using - br2-external trees from third parties.

  • -desc, optional, provides a short description for that br2-external - tree. It shall fit on a single line, is mostly free-form (see below), - and is used when displaying information about a br2-external tree (e.g. - above the list of defconfig files, or as the prompt in the menuconfig); - as such, it should relatively brief (40 chars is probably a good upper - limit). The description is available in the BR2_EXTERNAL_$(NAME)_DESC - variable. -

Examples of names and the corresponding BR2_EXTERNAL_$(NAME)_PATH -variables:

  • -FOOBR2_EXTERNAL_FOO_PATH -
  • -BAR_42BR2_EXTERNAL_BAR_42_PATH -

In the following examples, it is assumed the name to be set to BAR_42.

Note: Both BR2_EXTERNAL_$(NAME)_PATH and BR2_EXTERNAL_$(NAME)_DESC are - available in the Kconfig files and the Makefiles. They are also - exported in the environment so are available in post-build, post-image - and in-fakeroot scripts.

The Config.in and external.mk files

Those files (which may each be empty) can be used to define package -recipes (i.e. foo/Config.in and foo/foo.mk like for packages bundled -in Buildroot itself) or other custom configuration options or make logic.

Buildroot automatically includes the Config.in from each br2-external -tree to make it appear in the top-level configuration menu, and includes -the external.mk from each br2-external tree with the rest of the -makefile logic.

The main usage of this is to store package recipes. The recommended way -to do this is to write a Config.in file that looks like:

source "$BR2_EXTERNAL_BAR_42_PATH/package/package1/Config.in"
-source "$BR2_EXTERNAL_BAR_42_PATH/package/package2/Config.in"

Then, have an external.mk file that looks like:

include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/package/*/*.mk))

And then in $(BR2_EXTERNAL_BAR_42_PATH)/package/package1 and -$(BR2_EXTERNAL_BAR_42_PATH)/package/package2 create normal -Buildroot package recipes, as explained in Chapter 18, Adding new packages to Buildroot. -If you prefer, you can also group the packages in subdirectories -called <boardname> and adapt the above paths accordingly.

You can also define custom configuration options in Config.in and -custom make logic in external.mk.

The configs/ directory

One can store Buildroot defconfigs in the configs subdirectory of -the br2-external tree. Buildroot will automatically show them in the -output of make list-defconfigs and allow them to be loaded with the -normal make <name>_defconfig command. They will be visible in the -make list-defconfigs output, below an External configs label that -contains the name of the br2-external tree they are defined in.

Note: If a defconfig file is present in more than one br2-external tree, then -the one from the last br2-external tree is used. It is thus possible -to override a defconfig bundled in Buildroot or another br2-external -tree.

The provides/ directory

For some packages, Buildroot provides a choice between two (or more) -implementations of API-compatible such packages. For example, there is -a choice to choose either libjpeg ot jpeg-turbo; there is one between -openssl or libressl; there is one to select one of the known, -pre-configured toolchains…

It is possible for a br2-external to extend those choices, by providing -a set of files that define those alternatives:

  • -provides/toolchains.in defines the pre-configured toolchains, which - will then be listed in the toolchain selection; -
  • -provides/jpeg.in defines the alternative libjpeg implementations; -
  • -provides/openssl.in defines the alternative openssl implementations; -
  • -provides/skeleton.in defines the alternative skeleton implementations; -
  • -provides/init.in defines the alternative init system implementations, this - can be used to select a default skeleton for your init. -

Free-form content

One can store all the board-specific configuration files there, such -as the kernel configuration, the root filesystem overlay, or any other -configuration file for which Buildroot allows to set the location (by -using the BR2_EXTERNAL_$(NAME)_PATH variable). For example, you -could set the paths to a global patch directory, to a rootfs overlay -and to the kernel configuration file as follows (e.g. by running -make menuconfig and filling in these options):

BR2_GLOBAL_PATCH_DIR=$(BR2_EXTERNAL_BAR_42_PATH)/patches/
-BR2_ROOTFS_OVERLAY=$(BR2_EXTERNAL_BAR_42_PATH)/board/<boardname>/overlay/
-BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=$(BR2_EXTERNAL_BAR_42_PATH)/board/<boardname>/kernel.config

Additional Linux kernel extensions

Additional Linux kernel extensions (see Section 18.21.2, “linux-kernel-extensions”) can -be added by storing them in the linux/ directory at the root of a -br2-external tree.

Example layout

Here is an example layout using all features of br2-external (the sample -content is shown for the file above it, when it is relevant to explain -the br2-external tree; this is all entirely made up just for the sake of -illustration, of course):

/path/to/br2-ext-tree/
-  |- external.desc
-  |     |name: BAR_42
-  |     |desc: Example br2-external tree
-  |     `----
-  |
-  |- Config.in
-  |     |source "$BR2_EXTERNAL_BAR_42_PATH/toolchain/toolchain-external-mine/Config.in.options"
-  |     |source "$BR2_EXTERNAL_BAR_42_PATH/package/pkg-1/Config.in"
-  |     |source "$BR2_EXTERNAL_BAR_42_PATH/package/pkg-2/Config.in"
-  |     |source "$BR2_EXTERNAL_BAR_42_PATH/package/my-jpeg/Config.in"
-  |     |
-  |     |config BAR_42_FLASH_ADDR
-  |     |    hex "my-board flash address"
-  |     |    default 0x10AD
-  |     `----
-  |
-  |- external.mk
-  |     |include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/package/*/*.mk))
-  |     |include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/toolchain/*/*.mk))
-  |     |
-  |     |flash-my-board:
-  |     |    $(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/flash-image \
-  |     |        --image $(BINARIES_DIR)/image.bin \
-  |     |        --address $(BAR_42_FLASH_ADDR)
-  |     `----
-  |
-  |- package/pkg-1/Config.in
-  |     |config BR2_PACKAGE_PKG_1
-  |     |    bool "pkg-1"
-  |     |    help
-  |     |      Some help about pkg-1
-  |     `----
-  |- package/pkg-1/pkg-1.hash
-  |- package/pkg-1/pkg-1.mk
-  |     |PKG_1_VERSION = 1.2.3
-  |     |PKG_1_SITE = /some/where/to/get/pkg-1
-  |     |PKG_1_LICENSE = blabla
-  |     |
-  |     |define PKG_1_INSTALL_INIT_SYSV
-  |     |    $(INSTALL) -D -m 0755 $(PKG_1_PKGDIR)/S99my-daemon \
-  |     |                          $(TARGET_DIR)/etc/init.d/S99my-daemon
-  |     |endef
-  |     |
-  |     |$(eval $(autotools-package))
-  |     `----
-  |- package/pkg-1/S99my-daemon
-  |
-  |- package/pkg-2/Config.in
-  |- package/pkg-2/pkg-2.hash
-  |- package/pkg-2/pkg-2.mk
-  |
-  |- provides/jpeg.in
-  |     |config BR2_PACKAGE_MY_JPEG
-  |     |    bool "my-jpeg"
-  |     `----
-  |- package/my-jpeg/Config.in
-  |     |config BR2_PACKAGE_PROVIDES_JPEG
-  |     |    default "my-jpeg" if BR2_PACKAGE_MY_JPEG
-  |     `----
-  |- package/my-jpeg/my-jpeg.mk
-  |     |# This is a normal package .mk file
-  |     |MY_JPEG_VERSION = 1.2.3
-  |     |MY_JPEG_SITE = https://example.net/some/place
-  |     |MY_JPEG_PROVIDES = jpeg
-  |     |$(eval $(autotools-package))
-  |     `----
-  |
-  |- provides/init.in
-  |     |config BR2_INIT_MINE
-  |     |    bool "my custom init"
-  |     |    select BR2_PACKAGE_MY_INIT
-  |     |    select BR2_PACKAGE_SKELETON_INIT_MINE if BR2_ROOTFS_SKELETON_DEFAULT
-  |     `----
-  |
-  |- provides/skeleton.in
-  |     |config BR2_ROOTFS_SKELETON_MINE
-  |     |    bool "my custom skeleton"
-  |     |    select BR2_PACKAGE_SKELETON_MINE
-  |     `----
-  |- package/skeleton-mine/Config.in
-  |     |config BR2_PACKAGE_SKELETON_MINE
-  |     |    bool
-  |     |    select BR2_PACKAGE_HAS_SKELETON
-  |     |
-  |     |config BR2_PACKAGE_PROVIDES_SKELETON
-  |     |    default "skeleton-mine" if BR2_PACKAGE_SKELETON_MINE
-  |     `----
-  |- package/skeleton-mine/skeleton-mine.mk
-  |     |SKELETON_MINE_ADD_TOOLCHAIN_DEPENDENCY = NO
-  |     |SKELETON_MINE_ADD_SKELETON_DEPENDENCY = NO
-  |     |SKELETON_MINE_PROVIDES = skeleton
-  |     |SKELETON_MINE_INSTALL_STAGING = YES
-  |     |$(eval $(generic-package))
-  |     `----
-  |
-  |- provides/toolchains.in
-  |     |config BR2_TOOLCHAIN_EXTERNAL_MINE
-  |     |    bool "my custom toolchain"
-  |     |    depends on BR2_some_arch
-  |     |    select BR2_INSTALL_LIBSTDCPP
-  |     `----
-  |- toolchain/toolchain-external-mine/Config.in.options
-  |     |if BR2_TOOLCHAIN_EXTERNAL_MINE
-  |     |config BR2_TOOLCHAIN_EXTERNAL_PREFIX
-  |     |    default "arch-mine-linux-gnu"
-  |     |config BR2_PACKAGE_PROVIDES_TOOLCHAIN_EXTERNAL
-  |     |    default "toolchain-external-mine"
-  |     |endif
-  |     `----
-  |- toolchain/toolchain-external-mine/toolchain-external-mine.mk
-  |     |TOOLCHAIN_EXTERNAL_MINE_SITE = https://example.net/some/place
-  |     |TOOLCHAIN_EXTERNAL_MINE_SOURCE = my-toolchain.tar.gz
-  |     |$(eval $(toolchain-external-package))
-  |     `----
-  |
-  |- linux/Config.ext.in
-  |     |config BR2_LINUX_KERNEL_EXT_EXAMPLE_DRIVER
-  |     |    bool "example-external-driver"
-  |     |    help
-  |     |      Example external driver
-  |     |---
-  |- linux/linux-ext-example-driver.mk
-  |
-  |- configs/my-board_defconfig
-  |     |BR2_GLOBAL_PATCH_DIR="$(BR2_EXTERNAL_BAR_42_PATH)/patches/"
-  |     |BR2_ROOTFS_OVERLAY="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/overlay/"
-  |     |BR2_ROOTFS_POST_IMAGE_SCRIPT="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/post-image.sh"
-  |     |BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/kernel.config"
-  |     `----
-  |
-  |- patches/linux/0001-some-change.patch
-  |- patches/linux/0002-some-other-change.patch
-  |- patches/busybox/0001-fix-something.patch
-  |
-  |- board/my-board/kernel.config
-  |- board/my-board/overlay/var/www/index.html
-  |- board/my-board/overlay/var/www/my.css
-  |- board/my-board/flash-image
-  `- board/my-board/post-image.sh
-        |#!/bin/sh
-        |generate-my-binary-image \
-        |    --root ${BINARIES_DIR}/rootfs.tar \
-        |    --kernel ${BINARIES_DIR}/zImage \
-        |    --dtb ${BINARIES_DIR}/my-board.dtb \
-        |    --output ${BINARIES_DIR}/image.bin
-        `----

The br2-external tree will then be visible in the menuconfig (with -the layout expanded):

External options  --->
-    *** Example br2-external tree (in /path/to/br2-ext-tree/)
-    [ ] pkg-1
-    [ ] pkg-2
-    (0x10AD) my-board flash address

If you are using more than one br2-external tree, it would look like -(with the layout expanded and the second one with name FOO_27 but no -desc: field in external.desc):

External options  --->
-    Example br2-external tree  --->
-        *** Example br2-external tree (in /path/to/br2-ext-tree)
-        [ ] pkg-1
-        [ ] pkg-2
-        (0x10AD) my-board flash address
-    FOO_27  --->
-        *** FOO_27 (in /path/to/another-br2-ext)
-        [ ] foo
-        [ ] bar

Additionally, the jpeg provider will be visible in the jpeg choice:

Target packages  --->
-    Libraries  --->
-        Graphics  --->
-            [*] jpeg support
-                jpeg variant ()  --->
-                    ( ) jpeg
-                    ( ) jpeg-turbo
-                        *** jpeg from: Example br2-external tree ***
-                    (X) my-jpeg
-                        *** jpeg from: FOO_27 ***
-                    ( ) another-jpeg

And similarly for the toolchains:

Toolchain  --->
-    Toolchain ()  --->
-        ( ) Custom toolchain
-            *** Toolchains from: Example br2-external tree ***
-        (X) my custom toolchain

Note. The toolchain options in toolchain/toolchain-external-mine/Config.in.options -will not appear in the Toolchain menu. They must be explicitly included -from within the br2-external’s top-level Config.in and will thus appear -in the External options menu.

9.3. Storing the Buildroot configuration

The Buildroot configuration can be stored using the command - make savedefconfig.

This strips the Buildroot configuration down by removing configuration -options that are at their default value. The result is stored in a file -called defconfig. If you want to save it in another place, change the -BR2_DEFCONFIG option in the Buildroot configuration itself, or call -make with make savedefconfig BR2_DEFCONFIG=<path-to-defconfig>.

The recommended place to store this defconfig is -configs/<boardname>_defconfig. If you follow this recommendation, the -configuration will be listed in make help and can be set again by -running make <boardname>_defconfig.

Alternatively, you can copy the file to any other place and rebuild with -make defconfig BR2_DEFCONFIG=<path-to-defconfig-file>.

9.4. Storing the configuration of other components

The configuration files for BusyBox, the Linux kernel, Barebox, U-Boot -and uClibc should be stored as well if changed. For each of these -components, a Buildroot configuration option exists to point to an input -configuration file, e.g. BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE. To store -their configuration, set these configuration options to a path where you -want to save the configuration files, and then use the helper targets -described below to actually store the configuration.

As explained in Section 9.1, “Recommended directory structure”, the recommended path to -store these configuration files is -board/<company>/<boardname>/foo.config.

Make sure that you create a configuration file before changing -the BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE etc. options. Otherwise, -Buildroot will try to access this config file, which doesn’t exist -yet, and will fail. You can create the configuration file by running -make linux-menuconfig etc.

Buildroot provides a few helper targets to make the saving of -configuration files easier.

  • -make linux-update-defconfig saves the linux configuration to the - path specified by BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE. It - simplifies the config file by removing default values. However, - this only works with kernels starting from 2.6.33. For earlier - kernels, use make linux-update-config. -
  • -make busybox-update-config saves the busybox configuration to the - path specified by BR2_PACKAGE_BUSYBOX_CONFIG. -
  • -make uclibc-update-config saves the uClibc configuration to the - path specified by BR2_UCLIBC_CONFIG. -
  • -make barebox-update-defconfig saves the barebox configuration to the - path specified by BR2_TARGET_BAREBOX_CUSTOM_CONFIG_FILE. -
  • -make uboot-update-defconfig saves the U-Boot configuration to the - path specified by BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE. -
  • -For at91bootstrap3, no helper exists so you have to copy the config - file manually to BR2_TARGET_AT91BOOTSTRAP3_CUSTOM_CONFIG_FILE. -

9.5. Customizing the generated target filesystem

Besides changing the configuration through make *config, -there are a few other ways to customize the resulting target filesystem.

The two recommended methods, which can co-exist, are root filesystem -overlay(s) and post build script(s).

-Root filesystem overlays (BR2_ROOTFS_OVERLAY) -

A filesystem overlay is a tree of files that is copied directly - over the target filesystem after it has been built. To enable this - feature, set config option BR2_ROOTFS_OVERLAY (in the System - configuration menu) to the root of the overlay. You can even specify - multiple overlays, space-separated. If you specify a relative path, - it will be relative to the root of the Buildroot tree. Hidden - directories of version control systems, like .git, .svn, .hg, - etc., files called .empty and files ending in ~ are excluded from - the copy.

When BR2_ROOTFS_MERGED_USR is enabled, then the overlay must not - contain the /bin, /lib or /sbin directories, as Buildroot will - create them as symbolic links to the relevant folders in /usr. In - such a situation, should the overlay have any programs or libraries, - they should be placed in /usr/bin, /usr/sbin and /usr/lib.

As shown in Section 9.1, “Recommended directory structure”, the recommended path for - this overlay is board/<company>/<boardname>/rootfs-overlay.

-Post-build scripts (BR2_ROOTFS_POST_BUILD_SCRIPT) -

Post-build scripts are shell scripts called after Buildroot builds - all the selected software, but before the rootfs images are - assembled. To enable this feature, specify a space-separated list of - post-build scripts in config option BR2_ROOTFS_POST_BUILD_SCRIPT (in - the System configuration menu). If you specify a relative path, it - will be relative to the root of the Buildroot tree.

Using post-build scripts, you can remove or modify any file in your - target filesystem. You should, however, use this feature with care. - Whenever you find that a certain package generates wrong or unneeded - files, you should fix that package rather than work around it with some - post-build cleanup scripts.

As shown in Section 9.1, “Recommended directory structure”, the recommended path for - this script is board/<company>/<boardname>/post_build.sh.

The post-build scripts are run with the main Buildroot tree as current - working directory. The path to the target filesystem is passed as the - first argument to each script. If the config option - BR2_ROOTFS_POST_SCRIPT_ARGS is not empty, these arguments will be - passed to the script too. All the scripts will be passed the exact - same set of arguments, it is not possible to pass different sets of - arguments to each script.

In addition, you may also use these environment variables:

  • -BR2_CONFIG: the path to the Buildroot .config file -
  • -CONFIG_DIR: the directory containing the .config file, and - therefore the top-level Buildroot Makefile to use (which is - correct for both in-tree and out-of-tree builds) -
  • -HOST_DIR, STAGING_DIR, TARGET_DIR: see - Section 18.5.2, “generic-package reference” -
  • -BUILD_DIR: the directory where packages are extracted and built -
  • -BINARIES_DIR: the place where all binary files (aka images) are - stored -
  • -BASE_DIR: the base output directory -

Below three more methods of customizing the target filesystem are -described, but they are not recommended.

-Direct modification of the target filesystem -

For temporary modifications, you can modify the target filesystem - directly and rebuild the image. The target filesystem is available - under output/target/. After making your changes, run make to - rebuild the target filesystem image.

This method allows you to do anything to the target filesystem, but if - you need to clean your Buildroot tree using make clean, these - changes will be lost. Such cleaning is necessary in several cases, - refer to Section 8.2, “Understanding when a full rebuild is necessary” for details. This solution is therefore - only useful for quick tests: changes do not survive the make clean - command. Once you have validated your changes, you should make sure - that they will persist after a make clean, using a root filesystem - overlay or a post-build script.

-Custom target skeleton (BR2_ROOTFS_SKELETON_CUSTOM) -

The root filesystem image is created from a target skeleton, on top of - which all packages install their files. The skeleton is copied to the - target directory output/target before any package is built and - installed. The default target skeleton provides the standard Unix - filesystem layout and some basic init scripts and configuration files.

If the default skeleton (available under system/skeleton) does not - match your needs, you would typically use a root filesystem overlay or - post-build script to adapt it. However, if the default skeleton is - entirely different than what you need, using a custom skeleton may be - more suitable.

To enable this feature, enable config option - BR2_ROOTFS_SKELETON_CUSTOM and set BR2_ROOTFS_SKELETON_CUSTOM_PATH - to the path of your custom skeleton. Both options are available in the - System configuration menu. If you specify a relative path, it will - be relative to the root of the Buildroot tree.

Custom skeletons don’t need to contain the /bin, /lib or /sbin - directories, since they are created automatically during the build. - When BR2_ROOTFS_MERGED_USR is enabled, then the custom skeleton must - not contain the /bin, /lib or /sbin directories, as Buildroot - will create them as symbolic links to the relevant folders in /usr. - In such a situation, should the skeleton have any programs or - libraries, they should be placed in /usr/bin, /usr/sbin and - /usr/lib.

This method is not recommended because it duplicates the entire - skeleton, which prevents taking advantage of the fixes or improvements - brought to the default skeleton in later Buildroot releases.

-Post-fakeroot scripts (BR2_ROOTFS_POST_FAKEROOT_SCRIPT) -

When aggregating the final images, some parts of the process requires - root rights: creating device nodes in /dev, setting permissions or - ownership to files and directories… To avoid requiring actual root - rights, Buildroot uses fakeroot to simulate root rights. This is not - a complete substitute for actually being root, but is enough for what - Buildroot needs.

Post-fakeroot scripts are shell scripts that are called at the end of - the fakeroot phase, right before the filesystem image generator is - called. As such, they are called in the fakeroot context.

Post-fakeroot scripts can be useful in case you need to tweak the - filesystem to do modifications that are usually only available to the - root user.

Note: It is recommended to use the existing mechanisms to set file permissions - or create entries in /dev (see Section 9.5.1, “Setting file permissions and ownership and adding custom devices nodes”) or - to create users (see Section 9.6, “Adding custom user accounts”)

Note: The difference between post-build scripts (above) and fakeroot scripts, - is that post-build scripts are not called in the fakeroot context.

Note: Using fakeroot is not an absolute substitute for actually being root. - fakeroot only ever fakes the file access rights and types (regular, - block-or-char device…) and uid/gid; these are emulated in-memory.

9.5.1. Setting file permissions and ownership and adding custom devices nodes

Sometimes it is needed to set specific permissions or ownership on files -or device nodes. For example, certain files may need to be owned by -root. Since the post-build scripts are not run as root, you cannot do -such changes from there unless you use an explicit fakeroot from the -post-build script.

Instead, Buildroot provides support for so-called permission tables. -To use this feature, set config option BR2_ROOTFS_DEVICE_TABLE to a -space-separated list of permission tables, regular text files following -the makedev syntax.

If you are using a static device table (i.e. not using devtmpfs, -mdev, or (e)udev) then you can add device nodes using the same -syntax, in so-called device tables. To use this feature, set config -option BR2_ROOTFS_STATIC_DEVICE_TABLE to a space-separated list of -device tables.

As shown in Section 9.1, “Recommended directory structure”, the recommended location for -such files is board/<company>/<boardname>/.

It should be noted that if the specific permissions or device nodes are -related to a specific application, you should set variables -FOO_PERMISSIONS and FOO_DEVICES in the package’s .mk file instead -(see Section 18.5.2, “generic-package reference”).

9.6. Adding custom user accounts

Sometimes it is needed to add specific users in the target system. -To cover this requirement, Buildroot provides support for so-called -users tables. To use this feature, set config option -BR2_ROOTFS_USERS_TABLES to a space-separated list of users tables, -regular text files following the makeusers syntax.

As shown in Section 9.1, “Recommended directory structure”, the recommended location for -such files is board/<company>/<boardname>/.

It should be noted that if the custom users are related to a specific -application, you should set variable FOO_USERS in the package’s .mk -file instead (see Section 18.5.2, “generic-package reference”).

9.7. Customization after the images have been created

While post-build scripts (Section 9.5, “Customizing the generated target filesystem”) are run before -building the filesystem image, kernel and bootloader, post-image -scripts can be used to perform some specific actions after all images -have been created.

Post-image scripts can for example be used to automatically extract your -root filesystem tarball in a location exported by your NFS server, or -to create a special firmware image that bundles your root filesystem and -kernel image, or any other custom action required for your project.

To enable this feature, specify a space-separated list of post-image -scripts in config option BR2_ROOTFS_POST_IMAGE_SCRIPT (in the System -configuration menu). If you specify a relative path, it will be -relative to the root of the Buildroot tree.

Just like post-build scripts, post-image scripts are run with the main -Buildroot tree as current working directory. The path to the images -output directory is passed as the first argument to each script. If the -config option BR2_ROOTFS_POST_SCRIPT_ARGS is not empty, these -arguments will be passed to the script too. All the scripts will be -passed the exact same set of arguments, it is not possible to pass -different sets of arguments to each script.

Again just like for the post-build scripts, the scripts have access to -the environment variables BR2_CONFIG, HOST_DIR, STAGING_DIR, -TARGET_DIR, BUILD_DIR, BINARIES_DIR, CONFIG_DIR and -BASE_DIR.

The post-image scripts will be executed as the user that executes -Buildroot, which should normally not be the root user. Therefore, any -action requiring root permissions in one of these scripts will require -special handling (usage of fakeroot or sudo), which is left to the -script developer.

9.8. Adding project-specific patches

It is sometimes useful to apply extra patches to packages - on top of -those provided in Buildroot. This might be used to support custom -features in a project, for example, or when working on a new -architecture.

The BR2_GLOBAL_PATCH_DIR configuration option can be used to specify -a space separated list of one or more directories containing package -patches.

For a specific version <packageversion> of a specific package -<packagename>, patches are applied from BR2_GLOBAL_PATCH_DIR as -follows:

  1. -For every directory - <global-patch-dir> - that exists in - BR2_GLOBAL_PATCH_DIR, a <package-patch-dir> will be determined as - follows: -

    • -<global-patch-dir>/<packagename>/<packageversion>/ if the - directory exists. -
    • -Otherwise, <global-patch-dir>/<packagename> if the directory - exists. -
  2. -Patches will then be applied from a <package-patch-dir> as - follows: -

    • -If a series file exists in the package directory, then patches are - applied according to the series file; -
    • -Otherwise, patch files matching *.patch are applied in - alphabetical order. So, to ensure they are applied in the right - order, it is highly recommended to name the patch files like this: - <number>-<description>.patch, where <number> refers to the - apply order. -

For information about how patches are applied for a package, see -Section 19.2, “How patches are applied”

The BR2_GLOBAL_PATCH_DIR option is the preferred method for -specifying a custom patch directory for packages. It can be used to -specify a patch directory for any package in buildroot. It should also -be used in place of the custom patch directory options that are -available for packages such as U-Boot and Barebox. By doing this, it -will allow a user to manage their patches from one top-level -directory.

The exception to BR2_GLOBAL_PATCH_DIR being the preferred method for -specifying custom patches is BR2_LINUX_KERNEL_PATCH. -BR2_LINUX_KERNEL_PATCH should be used to specify kernel patches that -are available at a URL. Note: BR2_LINUX_KERNEL_PATCH specifies kernel -patches that are applied after patches available in BR2_GLOBAL_PATCH_DIR, -as it is done from a post-patch hook of the Linux package.

9.9. Adding project-specific packages

In general, any new package should be added directly in the package -directory and submitted to the Buildroot upstream project. How to add -packages to Buildroot in general is explained in full detail in -Chapter 18, Adding new packages to Buildroot and will not be repeated here. However, your -project may need some proprietary packages that cannot be upstreamed. -This section will explain how you can keep such project-specific -packages in a project-specific directory.

As shown in Section 9.1, “Recommended directory structure”, the recommended location for -project-specific packages is package/<company>/. If you are using the -br2-external tree feature (see Section 9.2, “Keeping customizations outside of Buildroot”) the recommended -location is to put them in a sub-directory named package/ in your -br2-external tree.

However, Buildroot will not be aware of the packages in this location, -unless we perform some additional steps. As explained in -Chapter 18, Adding new packages to Buildroot, a package in Buildroot basically consists of two -files: a .mk file (describing how to build the package) and a -Config.in file (describing the configuration options for this -package).

Buildroot will automatically include the .mk files in first-level -subdirectories of the package directory (using the pattern -package/*/*.mk). If we want Buildroot to include .mk files from -deeper subdirectories (like package/<company>/package1/) then we -simply have to add a .mk file in a first-level subdirectory that -includes these additional .mk files. Therefore, create a file -package/<company>/<company>.mk with following contents (assuming you -have only one extra directory level below package/<company>/):

include $(sort $(wildcard package/<company>/*/*.mk))

For the Config.in files, create a file package/<company>/Config.in -that includes the Config.in files of all your packages. An exhaustive -list has to be provided since wildcards are not supported in the source command of kconfig. -For example:

source "package/<company>/package1/Config.in"
-source "package/<company>/package2/Config.in"

Include this new file package/<company>/Config.in from -package/Config.in, preferably in a company-specific menu to make -merges with future Buildroot versions easier.

If using a br2-external tree, refer to Section 9.2, “Keeping customizations outside of Buildroot” for how -to fill in those files.

9.10. Quick guide to storing your project-specific customizations

Earlier in this chapter, the different methods for making -project-specific customizations have been described. This section will -now summarize all this by providing step-by-step instructions to storing your -project-specific customizations. Clearly, the steps that are not relevant to -your project can be skipped.

  1. -make menuconfig to configure toolchain, packages and kernel. -
  2. -make linux-menuconfig to update the kernel config, similar for - other configuration like busybox, uclibc, … -
  3. -mkdir -p board/<manufacturer>/<boardname> -
  4. -Set the following options to board/<manufacturer>/<boardname>/<package>.config - (as far as they are relevant): -

    • -BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE -
    • -BR2_PACKAGE_BUSYBOX_CONFIG -
    • -BR2_UCLIBC_CONFIG -
    • -BR2_TARGET_AT91BOOTSTRAP3_CUSTOM_CONFIG_FILE -
    • -BR2_TARGET_BAREBOX_CUSTOM_CONFIG_FILE -
    • -BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE -
  5. -Write the configuration files: -

    • -make linux-update-defconfig -
    • -make busybox-update-config -
    • -make uclibc-update-config -
    • -cp <output>/build/at91bootstrap3-*/.config - board/<manufacturer>/<boardname>/at91bootstrap3.config -
    • -make barebox-update-defconfig -
    • -make uboot-update-defconfig -
  6. -Create board/<manufacturer>/<boardname>/rootfs-overlay/ and fill it - with additional files you need on your rootfs, e.g. - board/<manufacturer>/<boardname>/rootfs-overlay/etc/inittab. - Set BR2_ROOTFS_OVERLAY - to board/<manufacturer>/<boardname>/rootfs-overlay. -
  7. -Create a post-build script - board/<manufacturer>/<boardname>/post_build.sh. Set - BR2_ROOTFS_POST_BUILD_SCRIPT to - board/<manufacturer>/<boardname>/post_build.sh -
  8. -If additional setuid permissions have to be set or device nodes have - to be created, create board/<manufacturer>/<boardname>/device_table.txt - and add that path to BR2_ROOTFS_DEVICE_TABLE. -
  9. -If additional user accounts have to be created, create - board/<manufacturer>/<boardname>/users_table.txt and add that path - to BR2_ROOTFS_USERS_TABLES. -
  10. -To add custom patches to certain packages, set BR2_GLOBAL_PATCH_DIR - to board/<manufacturer>/<boardname>/patches/ and add your patches - for each package in a subdirectory named after the package. Each - patch should be called <packagename>-<num>-<description>.patch. -
  11. -Specifically for the Linux kernel, there also exists the option - BR2_LINUX_KERNEL_PATCH with as main advantage that it can also - download patches from a URL. If you do not need this, - BR2_GLOBAL_PATCH_DIR is preferred. U-Boot, Barebox, at91bootstrap - and at91bootstrap3 also have separate options, but these do not - provide any advantage over BR2_GLOBAL_PATCH_DIR and will likely be - removed in the future. -
  12. -If you need to add project-specific packages, create - package/<manufacturer>/ and place your packages in that - directory. Create an overall <manufacturer>.mk file that - includes the .mk files of all your packages. Create an overall - Config.in file that sources the Config.in files of all your - packages. Include this Config.in file from Buildroot’s - package/Config.in file. -
  13. -make savedefconfig to save the buildroot configuration. -
  14. -cp defconfig configs/<boardname>_defconfig -

Chapter 10. Using SELinux in Buildroot

SELinux is a Linux kernel security module -enforcing access control policies. In addition to the traditional file -permissions and access control lists, SELinux allows to write rules -for users or processes to access specific functions of resources -(files, sockets…).

SELinux has three modes of operation:

  • -Disabled: the policy is not applied -
  • -Permissive: the policy is applied, and non-authorized actions are - simply logged. This mode is often used for troubleshooting SELinux - issues. -
  • -Enforcing: the policy is applied, and non-authorized actions are - denied -

In Buildroot the mode of operation is controlled by the -BR2_PACKAGE_REFPOLICY_POLICY_STATE_* configuration options. The -Linux kernel also has various configuration options that affect how -SELinux is enabled (see security/selinux/Kconfig in the Linux -kernel sources).

By default in Buildroot the SELinux policy is provided by the -upstream refpolicy -project, enabled with BR2_PACKAGE_REFPOLICY.

10.1. Enabling SELinux support

To have proper support for SELinux in a Buildroot generated system, -the following configuration options must be enabled:

  • -BR2_PACKAGE_LIBSELINUX -
  • -BR2_PACKAGE_REFPOLICY -

In addition, your filesystem image format must support extended -attributes.

10.2. SELinux policy tweaking

The SELinux refpolicy contains modules that can be enabled or -disabled when being built. Each module provide a number of SELinux -rules. In Buildroot the non-base modules are disabled by default and -several ways to enable such modules are provided:

  • -Packages can enable a list of SELinux modules within the refpolicy using - the <packagename>_SELINUX_MODULES variable. -
  • -Packages can provide additional SELinux modules by putting them (.fc, .if - and .te files) in package/<packagename>/selinux/. -
  • -Extra SELinux modules can be added in directories pointed by the - BR2_REFPOLICY_EXTRA_MODULES_DIRS configuration option. -
  • -Additional modules in the refpolicy can be enabled if listed in the - BR2_REFPOLICY_EXTRA_MODULES_DEPENDENCIES configuration option. -

Buildroot also allows to completely override the refpolicy. This -allows to provide a full custom policy designed specifically for a -given system. When going this way, all of the above mechanisms are -disabled: no extra SElinux module is added to the policy, and all -the available modules within the custom policy are enabled and built -into the final binary policy. The custom policy must be a fork of the -official refpolicy.

In order to fully override the refpolicy the following configuration -variables have to be set:

  • -BR2_PACKAGE_REFPOLICY_CUSTOM_GIT -
  • -BR2_PACKAGE_REFPOLICY_CUSTOM_REPO_URL -
  • -BR2_PACKAGE_REFPOLICY_CUSTOM_REPO_VERSION -

Chapter 11. Frequently Asked Questions & Troubleshooting

11.1. The boot hangs after Starting network…

If the boot process seems to hang after the following messages -(messages not necessarily exactly similar, depending on the list of -packages selected):

Freeing init memory: 3972K
-Initializing random number generator... done.
-Starting network...
-Starting dropbear sshd: generating rsa key... generating dsa key... OK

then it means that your system is running, but didn’t start a shell on -the serial console. In order to have the system start a shell on your -serial console, you have to go into the Buildroot configuration, in -System configuration, modify Run a getty (login prompt) after boot -and set the appropriate port and baud rate in the getty options -submenu. This will automatically tune the /etc/inittab file of the -generated system so that a shell starts on the correct serial port.

11.2. Why is there no compiler on the target?

It has been decided that support for the native compiler on the -target would be stopped from the Buildroot-2012.11 release because:

  • -this feature was neither maintained nor tested, and often broken; -
  • -this feature was only available for Buildroot toolchains; -
  • -Buildroot mostly targets small or very small target hardware - with limited resource onboard (CPU, ram, mass-storage), for which - compiling on the target does not make much sense; -
  • -Buildroot aims at easing the cross-compilation, making native - compilation on the target unnecessary. -

If you need a compiler on your target anyway, then Buildroot is not -suitable for your purpose. In such case, you need a real -distribution and you should opt for something like:

11.3. Why are there no development files on the target?

Since there is no compiler available on the target (see -Section 11.2, “Why is there no compiler on the target?”), it does not make sense to waste -space with headers or static libraries.

Therefore, those files are always removed from the target since the -Buildroot-2012.11 release.

11.4. Why is there no documentation on the target?

Because Buildroot mostly targets small or very small target -hardware with limited resource onboard (CPU, ram, mass-storage), it -does not make sense to waste space with the documentation data.

If you need documentation data on your target anyway, then Buildroot -is not suitable for your purpose, and you should look for a real -distribution (see: Section 11.2, “Why is there no compiler on the target?”).

11.5. Why are some packages not visible in the Buildroot config menu?

If a package exists in the Buildroot tree and does not appear in the -config menu, this most likely means that some of the package’s -dependencies are not met.

To know more about the dependencies of a package, search for the -package symbol in the config menu (see Section 8.1, “make tips”).

Then, you may have to recursively enable several options (which -correspond to the unmet dependencies) to finally be able to select -the package.

If the package is not visible due to some unmet toolchain options, -then you should certainly run a full rebuild (see Section 8.1, “make tips” for -more explanations).

11.6. Why not use the target directory as a chroot directory?

There are plenty of reasons to not use the target directory a chroot -one, among these:

  • -file ownerships, modes and permissions are not correctly set in the - target directory; -
  • -device nodes are not created in the target directory. -

For these reasons, commands run through chroot, using the target -directory as the new root, will most likely fail.

If you want to run the target filesystem inside a chroot, or as an NFS -root, then use the tarball image generated in images/ and extract it -as root.

11.7. Why doesn’t Buildroot generate binary packages (.deb, .ipkg…)?

One feature that is often discussed on the Buildroot list is the -general topic of "package management". To summarize, the idea -would be to add some tracking of which Buildroot package installs -what files, with the goals of:

  • -being able to remove files installed by a package when this package - gets unselected from the menuconfig; -
  • -being able to generate binary packages (ipk or other format) that - can be installed on the target without re-generating a new root - filesystem image. -

In general, most people think it is easy to do: just track which package -installed what and remove it when the package is unselected. However, it -is much more complicated than that:

  • -It is not only about the target/ directory, but also the sysroot in - host/<tuple>/sysroot and the host/ directory itself. All files - installed in those directories by various packages must be tracked. -
  • -When a package is unselected from the configuration, it is not - sufficient to remove just the files it installed. One must also - remove all its reverse dependencies (i.e. packages relying on it) - and rebuild all those packages. For example, package A depends - optionally on the OpenSSL library. Both are selected, and Buildroot - is built. Package A is built with crypto support using OpenSSL. - Later on, OpenSSL gets unselected from the configuration, but - package A remains (since OpenSSL is an optional dependency, this - is possible.) If only OpenSSL files are removed, then the files - installed by package A are broken: they use a library that is no - longer present on the target. Although this is technically doable, - it adds a lot of complexity to Buildroot, which goes against the - simplicity we try to stick to. -
  • -In addition to the previous problem, there is the case where the - optional dependency is not even known to Buildroot. For example, - package A in version 1.0 never used OpenSSL, but in version 2.0 it - automatically uses OpenSSL if available. If the Buildroot .mk file - hasn’t been updated to take this into account, then package A will - not be part of the reverse dependencies of OpenSSL and will not be - removed and rebuilt when OpenSSL is removed. For sure, the .mk file - of package A should be fixed to mention this optional dependency, - but in the mean time, you can have non-reproducible behaviors. -
  • -The request is to also allow changes in the menuconfig to be - applied on the output directory without having to rebuild - everything from scratch. However, this is very difficult to achieve - in a reliable way: what happens when the suboptions of a package - are changed (we would have to detect this, and rebuild the package - from scratch and potentially all its reverse dependencies), what - happens if toolchain options are changed, etc. At the moment, what - Buildroot does is clear and simple so its behaviour is very - reliable and it is easy to support users. If configuration changes - done in menuconfig are applied after the next make, then it has to - work correctly and properly in all situations, and not have some - bizarre corner cases. The risk is to get bug reports like "I have - enabled package A, B and C, then ran make, then disabled package - C and enabled package D and ran make, then re-enabled package C - and enabled package E and then there is a build failure". Or worse - "I did some configuration, then built, then did some changes, - built, some more changes, built, some more changes, built, and now - it fails, but I don’t remember all the changes I did and in which - order". This will be impossible to support. -

For all these reasons, the conclusion is that adding tracking of -installed files to remove them when the package is unselected, or to -generate a repository of binary packages, is something that is very -hard to achieve reliably and will add a lot of complexity.

On this matter, the Buildroot developers make this position statement:

  • -Buildroot strives to make it easy to generate a root filesystem (hence - the name, by the way.) That is what we want to make Buildroot good at: - building root filesystems. -
  • -Buildroot is not meant to be a distribution (or rather, a distribution - generator.) It is the opinion of most Buildroot developers that this - is not a goal we should pursue. We believe that there are other tools - better suited to generate a distro than Buildroot is. For example, - Open Embedded, or openWRT, - are such tools. -
  • -We prefer to push Buildroot in a direction that makes it easy (or even - easier) to generate complete root filesystems. This is what makes - Buildroot stands out in the crowd (among other things, of course!) -
  • -We believe that for most embedded Linux systems, binary packages are - not necessary, and potentially harmful. When binary packages are - used, it means that the system can be partially upgraded, which - creates an enormous number of possible combinations of package - versions that should be tested before doing the upgrade on the - embedded device. On the other hand, by doing complete system - upgrades by upgrading the entire root filesystem image at once, - the image deployed to the embedded system is guaranteed to really - be the one that has been tested and validated. -

11.8. How to speed-up the build process?

Since Buildroot often involves doing full rebuilds of the entire -system that can be quite long, we provide below a number of tips to -help reduce the build time:

  • -Use a pre-built external toolchain instead of the default Buildroot - internal toolchain. By using a pre-built Linaro toolchain (on ARM) - or a Sourcery CodeBench toolchain (for ARM, x86, x86-64, MIPS, - etc.), you will save the build time of the toolchain at each - complete rebuild, approximately 15 to 20 minutes. Note that - temporarily using an external toolchain does not prevent you to - switch back to an internal toolchain (that may provide a higher - level of customization) once the rest of your system is working; -
  • -Use the ccache compiler cache (see: Section 8.14.3, “Using ccache in Buildroot”); -
  • -Learn about rebuilding only the few packages you actually care - about (see Section 8.3, “Understanding how to rebuild packages”), but beware that sometimes full - rebuilds are anyway necessary (see Section 8.2, “Understanding when a full rebuild is necessary”); -
  • -Make sure you are not using a virtual machine for the Linux system - used to run Buildroot. Most of the virtual machine technologies are - known to cause a significant performance impact on I/O, which is - really important for building source code; -
  • -Make sure that you’re using only local files: do not attempt to do - a build over NFS, which significantly slows down the build. Having - the Buildroot download folder available locally also helps a bit. -
  • -Buy new hardware. SSDs and lots of RAM are key to speeding up the - builds. -
  • -Experiment with top-level parallel build, see - Section 8.12, “Top-level parallel build”. -

Chapter 12. Known issues

  • -It is not possible to pass extra linker options via BR2_TARGET_LDFLAGS - if such options contain a $ sign. For example, the following is known - to break: BR2_TARGET_LDFLAGS="-Wl,-rpath='$ORIGIN/../lib'" -
  • -The libffi package is not supported on the SuperH 2 and ARC - architectures. -
  • -The prboom package triggers a compiler failure with the SuperH 4 - compiler from Sourcery CodeBench, version 2012.09. -

Chapter 13. Legal notice and licensing

13.1. Complying with open source licenses

All of the end products of Buildroot (toolchain, root filesystem, kernel, -bootloaders) contain open source software, released under various licenses.

Using open source software gives you the freedom to build rich embedded -systems, choosing from a wide range of packages, but also imposes some -obligations that you must know and honour. -Some licenses require you to publish the license text in the documentation of -your product. Others require you to redistribute the source code of the -software to those that receive your product.

The exact requirements of each license are documented in each package, and -it is your responsibility (or that of your legal office) to comply with those -requirements. -To make this easier for you, Buildroot can collect for you some material you -will probably need. To produce this material, after you have configured -Buildroot with make menuconfig, make xconfig or make gconfig, run:

make legal-info

Buildroot will collect legally-relevant material in your output directory, -under the legal-info/ subdirectory. -There you will find:

  • -A README file, that summarizes the produced material and contains warnings - about material that Buildroot could not produce. -
  • -buildroot.config: this is the Buildroot configuration file that is usually - produced with make menuconfig, and which is necessary to reproduce the - build. -
  • -The source code for all packages; this is saved in the sources/ and - host-sources/ subdirectories for target and host packages respectively. - The source code for packages that set <PKG>_REDISTRIBUTE = NO will not be - saved. - Patches that were applied are also saved, along with a file named series - that lists the patches in the order they were applied. Patches are under the - same license as the files that they modify. - Note: Buildroot applies additional patches to Libtool scripts of - autotools-based packages. These patches can be found under - support/libtool in the Buildroot source and, due to technical - limitations, are not saved with the package sources. You may need to - collect them manually. -
  • -A manifest file (one for host and one for target packages) listing the - configured packages, their version, license and related information. - Some of this information might not be defined in Buildroot; such items are - marked as "unknown". -
  • -The license texts of all packages, in the licenses/ and host-licenses/ - subdirectories for target and host packages respectively. - If the license file(s) are not defined in Buildroot, the file is not produced - and a warning in the README indicates this. -

Please note that the aim of the legal-info feature of Buildroot is to -produce all the material that is somehow relevant for legal compliance with the -package licenses. Buildroot does not try to produce the exact material that -you must somehow make public. Certainly, more material is produced than is -needed for a strict legal compliance. For example, it produces the source code -for packages released under BSD-like licenses, that you are not required to -redistribute in source form.

Moreover, due to technical limitations, Buildroot does not produce some -material that you will or may need, such as the toolchain source code for -some of the external toolchains and the Buildroot source code itself. -When you run make legal-info, Buildroot produces warnings in the README -file to inform you of relevant material that could not be saved.

Finally, keep in mind that the output of make legal-info is based on -declarative statements in each of the packages recipes. The Buildroot -developers try to do their best to keep those declarative statements as -accurate as possible, to the best of their knowledge. However, it is very -well possible that those declarative statements are not all fully accurate -nor exhaustive. You (or your legal department) have to check the output -of make legal-info before using it as your own compliance delivery. See -the NO WARRANTY clauses (clauses 11 and 12) in the COPYING file at the -root of the Buildroot distribution.

13.2. Complying with the Buildroot license

Buildroot itself is an open source software, released under the -GNU General -Public License, version 2 or (at your option) any later version, with -the exception of the package patches detailed below. -However, being a build system, it is not normally part of the end product: -if you develop the root filesystem, kernel, bootloader or toolchain for a -device, the code of Buildroot is only present on the development machine, not -in the device storage.

Nevertheless, the general view of the Buildroot developers is that you should -release the Buildroot source code along with the source code of other packages -when releasing a product that contains GPL-licensed software. -This is because the -GNU GPL -defines the "complete source code" for an executable work as "all the -source code for all modules it contains, plus any associated interface -definition files, plus the scripts used to control compilation and installation -of the executable". -Buildroot is part of the scripts used to control compilation and -installation of the executable, and as such it is considered part of the -material that must be redistributed.

Keep in mind that this is only the Buildroot developers' opinion, and you -should consult your legal department or lawyer in case of any doubt.

13.2.1. Patches to packages

Buildroot also bundles patch files, which are applied to the sources -of the various packages. Those patches are not covered by the license -of Buildroot. Instead, they are covered by the license of the software -to which the patches are applied. When said software is available -under multiple licenses, the Buildroot patches are only provided under -the publicly accessible licenses.

See Chapter 19, Patching a package for the technical details.

Chapter 14. Beyond Buildroot

14.1. Boot the generated images

14.1.1. NFS boot

To achieve NFS-boot, enable tar root filesystem in the Filesystem -images menu.

After a complete build, just run the following commands to setup the -NFS-root directory:

sudo tar -xavf /path/to/output_dir/rootfs.tar -C /path/to/nfs_root_dir

Remember to add this path to /etc/exports.

Then, you can execute a NFS-boot from your target.

14.1.2. Live CD

To build a live CD image, enable the iso image option in the -Filesystem images menu. Note that this option is only available on -the x86 and x86-64 architectures, and if you are building your kernel -with Buildroot.

You can build a live CD image with either IsoLinux, Grub or Grub 2 as -a bootloader, but only Isolinux supports making this image usable both -as a live CD and live USB (through the Build hybrid image option).

You can test your live CD image using QEMU:

qemu-system-i386 -cdrom output/images/rootfs.iso9660

Or use it as a hard-drive image if it is a hybrid ISO:

qemu-system-i386 -hda output/images/rootfs.iso9660

It can be easily flashed to a USB drive with dd:

dd if=output/images/rootfs.iso9660 of=/dev/sdb

14.2. Chroot

If you want to chroot in a generated image, then there are few thing -you should be aware of:

  • -you should setup the new root from the tar root filesystem image; -
  • -either the selected target architecture is compatible with your host - machine, or you should use some qemu-* binary and correctly set it - within the binfmt properties to be able to run the binaries built - for the target on your host machine; -
  • -Buildroot does not currently provide host-qemu and binfmt - correctly built and set for that kind of use. -

Part III. Developer guide

Chapter 15. How Buildroot works

As mentioned above, Buildroot is basically a set of Makefiles that -download, configure, and compile software with the correct options. It -also includes patches for various software packages - mainly the ones -involved in the cross-compilation toolchain (gcc, binutils and -uClibc).

There is basically one Makefile per software package, and they are -named with the .mk extension. Makefiles are split into many different -parts.

  • -The toolchain/ directory contains the Makefiles - and associated files for all software related to the - cross-compilation toolchain: binutils, gcc, gdb, - kernel-headers and uClibc. -
  • -The arch/ directory contains the definitions for all the processor - architectures that are supported by Buildroot. -
  • -The package/ directory contains the Makefiles and - associated files for all user-space tools and libraries that Buildroot - can compile and add to the target root filesystem. There is one - sub-directory per package. -
  • -The linux/ directory contains the Makefiles and associated files for - the Linux kernel. -
  • -The boot/ directory contains the Makefiles and associated files for - the bootloaders supported by Buildroot. -
  • -The system/ directory contains support for system integration, e.g. - the target filesystem skeleton and the selection of an init system. -
  • -The fs/ directory contains the Makefiles and - associated files for software related to the generation of the - target root filesystem image. -

Each directory contains at least 2 files:

  • -something.mk is the Makefile that downloads, configures, - compiles and installs the package something. -
  • -Config.in is a part of the configuration tool - description file. It describes the options related to the - package. -

The main Makefile performs the following steps (once the -configuration is done):

  • -Create all the output directories: staging, target, build, - etc. in the output directory (output/ by default, - another value can be specified using O=) -
  • -Generate the toolchain target. When an internal toolchain is used, this - means generating the cross-compilation toolchain. When an external - toolchain is used, this means checking the features of the external - toolchain and importing it into the Buildroot environment. -
  • -Generate all the targets listed in the TARGETS variable. This - variable is filled by all the individual components' - Makefiles. Generating these targets will trigger the compilation of - the userspace packages (libraries, programs), the kernel, the - bootloader and the generation of the root filesystem images, - depending on the configuration. -

Chapter 16. Coding style

Overall, these coding style rules are here to help you to add new files in -Buildroot or refactor existing ones.

If you slightly modify some existing file, the important thing is -to keep the consistency of the whole file, so you can:

  • -either follow the potentially deprecated coding style used in this -file, -
  • -or entirely rework it in order to make it comply with these rules. -

16.1. Config.in file

Config.in files contain entries for almost anything configurable in -Buildroot.

An entry has the following pattern:

config BR2_PACKAGE_LIBFOO
-        bool "libfoo"
-        depends on BR2_PACKAGE_LIBBAZ
-        select BR2_PACKAGE_LIBBAR
-        help
-          This is a comment that explains what libfoo is. The help text
-          should be wrapped.
-
-          http://foosoftware.org/libfoo/
  • -The bool, depends on, select and help lines are indented - with one tab. -
  • -The help text itself should be indented with one tab and two - spaces. -
  • -The help text should be wrapped to fit 72 columns, where tab counts - for 8, so 62 characters in the text itself. -

The Config.in files are the input for the configuration tool -used in Buildroot, which is the regular Kconfig. For further -details about the Kconfig language, refer to -http://kernel.org/doc/Documentation/kbuild/kconfig-language.txt.

16.2. The .mk file

  • -Header: The file starts with a header. It contains the module name, -preferably in lowercase, enclosed between separators made of 80 hashes. A -blank line is mandatory after the header: -

    ################################################################################
    -#
    -# libfoo
    -#
    -################################################################################
  • -Assignment: use = preceded and followed by one space: -

    LIBFOO_VERSION = 1.0
    -LIBFOO_CONF_OPTS += --without-python-support

    Do not align the = signs.

  • -Indentation: use tab only: -

    define LIBFOO_REMOVE_DOC
    -        $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/doc \
    -                $(TARGET_DIR)/usr/share/man/man3/libfoo*
    -endef

    Note that commands inside a define block should always start with a tab, -so make recognizes them as commands.

  • -Optional dependency: -

    • -Prefer multi-line syntax. -

      YES:

      ifeq ($(BR2_PACKAGE_PYTHON),y)
      -LIBFOO_CONF_OPTS += --with-python-support
      -LIBFOO_DEPENDENCIES += python
      -else
      -LIBFOO_CONF_OPTS += --without-python-support
      -endif

      NO:

      LIBFOO_CONF_OPTS += --with$(if $(BR2_PACKAGE_PYTHON),,out)-python-support
      -LIBFOO_DEPENDENCIES += $(if $(BR2_PACKAGE_PYTHON),python,)
    • -Keep configure options and dependencies close together. -
  • -Optional hooks: keep hook definition and assignment together in one - if block. -

    YES:

    ifneq ($(BR2_LIBFOO_INSTALL_DATA),y)
    -define LIBFOO_REMOVE_DATA
    -        $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/data
    -endef
    -LIBFOO_POST_INSTALL_TARGET_HOOKS += LIBFOO_REMOVE_DATA
    -endif

    NO:

    define LIBFOO_REMOVE_DATA
    -        $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/data
    -endef
    -
    -ifneq ($(BR2_LIBFOO_INSTALL_DATA),y)
    -LIBFOO_POST_INSTALL_TARGET_HOOKS += LIBFOO_REMOVE_DATA
    -endif

16.3. The documentation

The documentation uses the -asciidoc format.

For further details about the asciidoc syntax, refer to -http://www.methods.co.nz/asciidoc/userguide.html.

16.4. Support scripts

Some scripts in the support/ and utils/ directories are written in -Python and should follow the -PEP8 Style Guide for Python Code.

Chapter 17. Adding support for a particular board

Buildroot contains basic configurations for several publicly available -hardware boards, so that users of such a board can easily build a system -that is known to work. You are welcome to add support for other boards -to Buildroot too.

To do so, you need to create a normal Buildroot configuration that -builds a basic system for the hardware: (internal) toolchain, kernel, -bootloader, filesystem and a simple BusyBox-only userspace. No specific -package should be selected: the configuration should be as minimal as -possible, and should only build a working basic BusyBox system for the -target platform. You can of course use more complicated configurations -for your internal projects, but the Buildroot project will only -integrate basic board configurations. This is because package -selections are highly application-specific.

Once you have a known working configuration, run make -savedefconfig. This will generate a minimal defconfig file at the -root of the Buildroot source tree. Move this file into the configs/ -directory, and rename it <boardname>_defconfig. If the configuration -is a bit more complicated, it is nice to manually reformat it and -separate it into sections, with a comment before each section. Typical -sections are Architecture, Toolchain options (typically just linux -headers version), Firmware, Bootloader, Kernel, and Filesystem.

Always use fixed versions or commit hashes for the different -components, not the "latest" version. For example, set -BR2_LINUX_KERNEL_CUSTOM_VERSION=y and -BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE to the kernel version you tested -with.

It is recommended to use as much as possible upstream versions of the -Linux kernel and bootloaders, and to use as much as possible default -kernel and bootloader configurations. If they are incorrect for your -board, or no default exists, we encourage you to send fixes to the -corresponding upstream projects.

However, in the mean time, you may want to store kernel or bootloader -configuration or patches specific to your target platform. To do so, -create a directory board/<manufacturer> and a subdirectory -board/<manufacturer>/<boardname>. You can then store your patches -and configurations in these directories, and reference them from the main -Buildroot configuration. Refer to Chapter 9, Project-specific customization for more details.

Chapter 18. Adding new packages to Buildroot

This section covers how new packages (userspace libraries or -applications) can be integrated into Buildroot. It also shows how -existing packages are integrated, which is needed for fixing issues or -tuning their configuration.

When you add a new package, be sure to test it in various conditions -(see Section 18.24.3, “How to test your package”) and also check it for coding style (see -Section 18.24.2, “How to check the coding style”).

18.1. Package directory

First of all, create a directory under the package directory for -your software, for example libfoo.

Some packages have been grouped by topic in a sub-directory: -x11r7, qt5 and gstreamer. If your package fits in -one of these categories, then create your package directory in these. -New subdirectories are discouraged, however.

18.2. Config files

For the package to be displayed in the configuration tool, you need to -create a Config file in your package directory. There are two types: -Config.in and Config.in.host.

18.2.1. Config.in file

For packages used on the target, create a file named Config.in. This -file will contain the option descriptions related to our libfoo software -that will be used and displayed in the configuration tool. It should basically -contain:

config BR2_PACKAGE_LIBFOO
-        bool "libfoo"
-        help
-          This is a comment that explains what libfoo is. The help text
-          should be wrapped.
-
-          http://foosoftware.org/libfoo/

The bool line, help line and other metadata information about the -configuration option must be indented with one tab. The help text -itself should be indented with one tab and two spaces, lines should -be wrapped to fit 72 columns, where tab counts for 8, so 62 characters -in the text itself. The help text must mention the upstream URL of the -project after an empty line.

As a convention specific to Buildroot, the ordering of the attributes -is as follows:

  1. -The type of option: bool, string… with the prompt -
  2. -If needed, the default value(s) -
  3. -Any dependencies on the target in depends on form -
  4. -Any dependencies on the toolchain in depends on form -
  5. -Any dependencies on other packages in depends on form -
  6. -Any dependency of the select form -
  7. -The help keyword and help text. -

You can add other sub-options into a if BR2_PACKAGE_LIBFOO…endif -statement to configure particular things in your software. You can look at -examples in other packages. The syntax of the Config.in file is the same -as the one for the kernel Kconfig file. The documentation for this syntax is -available at http://kernel.org/doc/Documentation/kbuild/kconfig-language.txt

Finally you have to add your new libfoo/Config.in to -package/Config.in (or in a category subdirectory if you decided to -put your package in one of the existing categories). The files -included there are sorted alphabetically per category and are NOT -supposed to contain anything but the bare name of the package.

source "package/libfoo/Config.in"

18.2.2. Config.in.host file

Some packages also need to be built for the host system. There are two -options here:

  • -The host package is only required to satisfy build-time - dependencies of one or more target packages. In this case, add - host-foo to the target package’s BAR_DEPENDENCIES variable. No - Config.in.host file should be created. -
  • -The host package should be explicitly selectable by the user from - the configuration menu. In this case, create a Config.in.host file - for that host package: -

    config BR2_PACKAGE_HOST_FOO
    -        bool "host foo"
    -        help
    -          This is a comment that explains what foo for the host is.
    -
    -          http://foosoftware.org/foo/

    The same coding style and options as for the Config.in file are valid.

    Finally you have to add your new libfoo/Config.in.host to -package/Config.in.host. The files included there are sorted alphabetically -and are NOT supposed to contain anything but the bare name of the package.

    source "package/foo/Config.in.host"

    The host package will then be available from the Host utilities menu.

18.2.3. Choosing depends on or select

The Config.in file of your package must also ensure that -dependencies are enabled. Typically, Buildroot uses the following -rules:

  • -Use a select type of dependency for dependencies on - libraries. These dependencies are generally not obvious and it - therefore make sense to have the kconfig system ensure that the - dependencies are selected. For example, the libgtk2 package uses - select BR2_PACKAGE_LIBGLIB2 to make sure this library is also - enabled. - The select keyword expresses the dependency with a backward - semantic. -
  • -Use a depends on type of dependency when the user really needs to - be aware of the dependency. Typically, Buildroot uses this type of - dependency for dependencies on target architecture, MMU support and - toolchain options (see Section 18.2.4, “Dependencies on target and toolchain options”), - or for dependencies on "big" things, such as the X.org system. - The depends on keyword expresses the dependency with a forward - semantic. -

Note. The current problem with the kconfig language is that these two -dependency semantics are not internally linked. Therefore, it may be -possible to select a package, whom one of its dependencies/requirement -is not met.

An example illustrates both the usage of select and depends on.

config BR2_PACKAGE_RRDTOOL
-        bool "rrdtool"
-        depends on BR2_USE_WCHAR
-        select BR2_PACKAGE_FREETYPE
-        select BR2_PACKAGE_LIBART
-        select BR2_PACKAGE_LIBPNG
-        select BR2_PACKAGE_ZLIB
-        help
-          RRDtool is the OpenSource industry standard, high performance
-          data logging and graphing system for time series data.
-
-          http://oss.oetiker.ch/rrdtool/
-
-comment "rrdtool needs a toolchain w/ wchar"
-        depends on !BR2_USE_WCHAR

Note that these two dependency types are only transitive with the -dependencies of the same kind.

This means, in the following example:

config BR2_PACKAGE_A
-        bool "Package A"
-
-config BR2_PACKAGE_B
-        bool "Package B"
-        depends on BR2_PACKAGE_A
-
-config BR2_PACKAGE_C
-        bool "Package C"
-        depends on BR2_PACKAGE_B
-
-config BR2_PACKAGE_D
-        bool "Package D"
-        select BR2_PACKAGE_B
-
-config BR2_PACKAGE_E
-        bool "Package E"
-        select BR2_PACKAGE_D
  • -Selecting Package C will be visible if Package B has been - selected, which in turn is only visible if Package A has been - selected. -
  • -Selecting Package E will select Package D, which will select - Package B, it will not check for the dependencies of Package B, - so it will not select Package A. -
  • -Since Package B is selected but Package A is not, this violates - the dependency of Package B on Package A. Therefore, in such a - situation, the transitive dependency has to be added explicitly: -
config BR2_PACKAGE_D
-        bool "Package D"
-        select BR2_PACKAGE_B
-        depends on BR2_PACKAGE_A
-
-config BR2_PACKAGE_E
-        bool "Package E"
-        select BR2_PACKAGE_D
-        depends on BR2_PACKAGE_A

Overall, for package library dependencies, select should be -preferred.

Note that such dependencies will ensure that the dependency option -is also enabled, but not necessarily built before your package. To do -so, the dependency also needs to be expressed in the .mk file of the -package.

Further formatting details: see the -coding style.

18.2.4. Dependencies on target and toolchain options

Many packages depend on certain options of the toolchain: the choice of -C library, C++ support, thread support, RPC support, wchar support, -or dynamic library support. Some packages can only be built on certain -target architectures, or if an MMU is available in the processor.

These dependencies have to be expressed with the appropriate depends -on statements in the Config.in file. Additionally, for dependencies on -toolchain options, a comment should be displayed when the option is -not enabled, so that the user knows why the package is not available. -Dependencies on target architecture or MMU support should not be -made visible in a comment: since it is unlikely that the user can -freely choose another target, it makes little sense to show these -dependencies explicitly.

The comment should only be visible if the config option itself would -be visible when the toolchain option dependencies are met. This means -that all other dependencies of the package (including dependencies on -target architecture and MMU support) have to be repeated on the -comment definition. To keep it clear, the depends on statement for -these non-toolchain option should be kept separate from the depends on -statement for the toolchain options. -If there is a dependency on a config option in that same file (typically -the main package) it is preferable to have a global if … endif -construct rather than repeating the depends on statement on the -comment and other config options.

The general format of a dependency comment for package foo is:

foo needs a toolchain w/ featA, featB, featC

for example:

mpd needs a toolchain w/ C++, threads, wchar

or

crda needs a toolchain w/ threads

Note that this text is kept brief on purpose, so that it will fit on a -80-character terminal.

The rest of this section enumerates the different target and toolchain -options, the corresponding config symbols to depend on, and the text to -use in the comment.

  • -Target architecture -

    • -Dependency symbol: BR2_powerpc, BR2_mips, … (see arch/Config.in) -
    • -Comment string: no comment to be added -
  • -MMU support -

    • -Dependency symbol: BR2_USE_MMU -
    • -Comment string: no comment to be added -
  • -Gcc _sync* built-ins used for atomic operations. They are - available in variants operating on 1 byte, 2 bytes, 4 bytes and 8 - bytes. Since different architectures support atomic operations on - different sizes, one dependency symbol is available for each size: -

    • -Dependency symbol: BR2_TOOLCHAIN_HAS_SYNC_1 for 1 byte, - BR2_TOOLCHAIN_HAS_SYNC_2 for 2 bytes, - BR2_TOOLCHAIN_HAS_SYNC_4 for 4 bytes, BR2_TOOLCHAIN_HAS_SYNC_8 - for 8 bytes. -
    • -Comment string: no comment to be added -
  • -Gcc _atomic* built-ins used for atomic operations. -

    • -Dependency symbol: BR2_TOOLCHAIN_HAS_ATOMIC. -
    • -Comment string: no comment to be added -
  • -Kernel headers -

    • -Dependency symbol: BR2_TOOLCHAIN_HEADERS_AT_LEAST_X_Y, (replace - X_Y with the proper version, see toolchain/Config.in) -
    • -Comment string: headers >= X.Y and/or headers <= X.Y (replace - X.Y with the proper version) -
  • -GCC version -

    • -Dependency symbol: BR2_TOOLCHAIN_GCC_AT_LEAST_X_Y, (replace - X_Y with the proper version, see toolchain/Config.in) -
    • -Comment string: gcc >= X.Y and/or gcc <= X.Y (replace - X.Y with the proper version) -
  • -Host GCC version -

    • -Dependency symbol: BR2_HOST_GCC_AT_LEAST_X_Y, (replace - X_Y with the proper version, see Config.in) -
    • -Comment string: no comment to be added -
    • -Note that it is usually not the package itself that has a minimum - host GCC version, but rather a host-package on which it depends. -
  • -C library -

    • -Dependency symbol: BR2_TOOLCHAIN_USES_GLIBC, - BR2_TOOLCHAIN_USES_MUSL, BR2_TOOLCHAIN_USES_UCLIBC -
    • -Comment string: for the C library, a slightly different comment text - is used: foo needs a glibc toolchain, or foo needs a glibc - toolchain w/ C++ -
  • -C++ support -

    • -Dependency symbol: BR2_INSTALL_LIBSTDCPP -
    • -Comment string: C++ -
  • -D support -

    • -Dependency symbol: BR2_TOOLCHAIN_HAS_DLANG -
    • -Comment string: Dlang -
  • -Fortran support -

    • -Dependency symbol: BR2_TOOLCHAIN_HAS_FORTRAN -
    • -Comment string: fortran -
  • -thread support -

    • -Dependency symbol: BR2_TOOLCHAIN_HAS_THREADS -
    • -Comment string: threads (unless BR2_TOOLCHAIN_HAS_THREADS_NPTL - is also needed, in which case, specifying only NPTL is sufficient) -
  • -NPTL thread support -

    • -Dependency symbol: BR2_TOOLCHAIN_HAS_THREADS_NPTL -
    • -Comment string: NPTL -
  • -RPC support -

    • -Dependency symbol: BR2_TOOLCHAIN_HAS_NATIVE_RPC -
    • -Comment string: RPC -
  • -wchar support -

    • -Dependency symbol: BR2_USE_WCHAR -
    • -Comment string: wchar -
  • -dynamic library -

    • -Dependency symbol: !BR2_STATIC_LIBS -
    • -Comment string: dynamic library -

18.2.5. Dependencies on a Linux kernel built by buildroot

Some packages need a Linux kernel to be built by buildroot. These are -typically kernel modules or firmware. A comment should be added in the -Config.in file to express this dependency, similar to dependencies on -toolchain options. The general format is:

foo needs a Linux kernel to be built

If there is a dependency on both toolchain options and the Linux -kernel, use this format:

foo needs a toolchain w/ featA, featB, featC and a Linux kernel to be built

18.2.6. Dependencies on udev /dev management

If a package needs udev /dev management, it should depend on symbol -BR2_PACKAGE_HAS_UDEV, and the following comment should be added:

foo needs udev /dev management

If there is a dependency on both toolchain options and udev /dev -management, use this format:

foo needs udev /dev management and a toolchain w/ featA, featB, featC

18.2.7. Dependencies on features provided by virtual packages

Some features can be provided by more than one package, such as the -openGL libraries.

See Section 18.11, “Infrastructure for virtual packages” for more on the virtual packages.

18.3. The .mk file

Finally, here’s the hardest part. Create a file named libfoo.mk. It -describes how the package should be downloaded, configured, built, -installed, etc.

Depending on the package type, the .mk file must be written in a -different way, using different infrastructures:

  • -Makefiles for generic packages (not using autotools or CMake): - These are based on an infrastructure similar to the one used for - autotools-based packages, but require a little more work from the - developer. They specify what should be done for the configuration, - compilation and installation of the package. This - infrastructure must be used for all packages that do not use the - autotools as their build system. In the future, other specialized - infrastructures might be written for other build systems. We cover - them through in a tutorial and a - reference. -
  • -Makefiles for autotools-based software (autoconf, automake, etc.): - We provide a dedicated infrastructure for such packages, since - autotools is a very common build system. This infrastructure must - be used for new packages that rely on the autotools as their build - system. We cover them through a tutorial - and reference. -
  • -Makefiles for cmake-based software: We provide a dedicated - infrastructure for such packages, as CMake is a more and more - commonly used build system and has a standardized behaviour. This - infrastructure must be used for new packages that rely on - CMake. We cover them through a tutorial - and reference. -
  • -Makefiles for Python modules: We have a dedicated infrastructure - for Python modules that use either the distutils or the - setuptools mechanism. We cover them through a - tutorial and a - reference. -
  • -Makefiles for Lua modules: We have a dedicated infrastructure for - Lua modules available through the LuaRocks web site. We cover them - through a tutorial and a - reference. -

Further formatting details: see the writing -rules.

18.4. The .hash file

When possible, you must add a third file, named libfoo.hash, that -contains the hashes of the downloaded files for the libfoo -package. The only reason for not adding a .hash file is when hash -checking is not possible due to how the package is downloaded.

When a package has a version selection choice, then the hash file may be -stored in a subdirectory named after the version, e.g. -package/libfoo/1.2.3/libfoo.hash. This is especially important if the -different versions have different licensing terms, but they are stored -in the same file. Otherwise, the hash file should stay in the package’s -directory.

The hashes stored in that file are used to validate the integrity of the -downloaded files and of the license files.

The format of this file is one line for each file for which to check the -hash, each line with the following three fields separated by two spaces:

  • -the type of hash, one of: -

    • -md5, sha1, sha224, sha256, sha384, sha512, none -
  • -the hash of the file: -

    • -for none, one or more non-space chars, usually just the string xxx -
    • -for md5, 32 hexadecimal characters -
    • -for sha1, 40 hexadecimal characters -
    • -for sha224, 56 hexadecimal characters -
    • -for sha256, 64 hexadecimal characters -
    • -for sha384, 96 hexadecimal characters -
    • -for sha512, 128 hexadecimal characters -
  • -the name of the file: -

    • -for a source archive: the basename of the file, without any directory - component, -
    • -for a license file: the path as it appears in FOO_LICENSE_FILES. -

Lines starting with a # sign are considered comments, and ignored. Empty -lines are ignored.

There can be more than one hash for a single file, each on its own line. In -this case, all hashes must match.

Note. Ideally, the hashes stored in this file should match the hashes published by -upstream, e.g. on their website, in the e-mail announcement… If upstream -provides more than one type of hash (e.g. sha1 and sha512), then it is -best to add all those hashes in the .hash file. If upstream does not -provide any hash, or only provides an md5 hash, then compute at least one -strong hash yourself (preferably sha256, but not md5), and mention -this in a comment line above the hashes.

Note. The hashes for license files are used to detect a license change when a -package version is bumped. The hashes are checked during the make legal-info -target run. For a package with multiple versions (like Qt5), -create the hash file in a subdirectory <packageversion> of that package -(see also Section 19.2, “How patches are applied”).

The none hash type is reserved to those archives downloaded from a -repository, like a git clone, a subversion checkout

The example below defines a sha1 and a sha256 published by upstream for -the main libfoo-1.2.3.tar.bz2 tarball, an md5 from upstream and a -locally-computed sha256 hashes for a binary blob, a sha256 for a -downloaded patch, and an archive with no hash:

# Hashes from: http://www.foosoftware.org/download/libfoo-1.2.3.tar.bz2.{sha1,sha256}:
-sha1  486fb55c3efa71148fe07895fd713ea3a5ae343a  libfoo-1.2.3.tar.bz2
-sha256  efc8103cc3bcb06bda6a781532d12701eb081ad83e8f90004b39ab81b65d4369  libfoo-1.2.3.tar.bz2
-
-# md5 from: http://www.foosoftware.org/download/libfoo-1.2.3.tar.bz2.md5, sha256 locally computed:
-md5  2d608f3c318c6b7557d551a5a09314f03452f1a1  libfoo-data.bin
-sha256  01ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546b  libfoo-data.bin
-
-# Locally computed:
-sha256  ff52101fb90bbfc3fe9475e425688c660f46216d7e751c4bbdb1dc85cdccacb9  libfoo-fix-blabla.patch
-
-# No hash for 1234:
-none  xxx  libfoo-1234.tar.gz
-
-# Hash for license files:
-sha256  a45a845012742796534f7e91fe623262ccfb99460a2bd04015bd28d66fba95b8  COPYING
-sha256  01b1f9f2c8ee648a7a596a1abe8aa4ed7899b1c9e5551bda06da6e422b04aa55  doc/COPYING.LGPL

If the .hash file is present, and it contains one or more hashes for a -downloaded file, the hash(es) computed by Buildroot (after download) must -match the hash(es) stored in the .hash file. If one or more hashes do -not match, Buildroot considers this an error, deletes the downloaded file, -and aborts.

If the .hash file is present, but it does not contain a hash for a -downloaded file, Buildroot considers this an error and aborts. However, -the downloaded file is left in the download directory since this -typically indicates that the .hash file is wrong but the downloaded -file is probably OK.

Hashes are currently checked for files fetched from http/ftp servers, -Git repositories, files copied using scp and local files. Hashes are -not checked for other version control systems (such as Subversion, -CVS, etc.) because Buildroot currently does not generate reproducible -tarballs when source code is fetched from such version control -systems.

Hashes should only be added in .hash files for files that are -guaranteed to be stable. For example, patches auto-generated by Github -are not guaranteed to be stable, and therefore their hashes can change -over time. Such patches should not be downloaded, and instead be added -locally to the package folder.

If the .hash file is missing, then no check is done at all.

18.5. Infrastructure for packages with specific build systems

By packages with specific build systems we mean all the packages -whose build system is not one of the standard ones, such as -autotools or CMake. This typically includes packages whose build -system is based on hand-written Makefiles or shell scripts.

18.5.1. generic-package tutorial

01: ################################################################################
-02: #
-03: # libfoo
-04: #
-05: ################################################################################
-06:
-07: LIBFOO_VERSION = 1.0
-08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz
-09: LIBFOO_SITE = http://www.foosoftware.org/download
-10: LIBFOO_LICENSE = GPL-3.0+
-11: LIBFOO_LICENSE_FILES = COPYING
-12: LIBFOO_INSTALL_STAGING = YES
-13: LIBFOO_CONFIG_SCRIPTS = libfoo-config
-14: LIBFOO_DEPENDENCIES = host-libaaa libbbb
-15:
-16: define LIBFOO_BUILD_CMDS
-17:     $(MAKE) $(TARGET_CONFIGURE_OPTS) -C $(@D) all
-18: endef
-19:
-20: define LIBFOO_INSTALL_STAGING_CMDS
-21:     $(INSTALL) -D -m 0755 $(@D)/libfoo.a $(STAGING_DIR)/usr/lib/libfoo.a
-22:     $(INSTALL) -D -m 0644 $(@D)/foo.h $(STAGING_DIR)/usr/include/foo.h
-23:     $(INSTALL) -D -m 0755 $(@D)/libfoo.so* $(STAGING_DIR)/usr/lib
-24: endef
-25:
-26: define LIBFOO_INSTALL_TARGET_CMDS
-27:     $(INSTALL) -D -m 0755 $(@D)/libfoo.so* $(TARGET_DIR)/usr/lib
-28:     $(INSTALL) -d -m 0755 $(TARGET_DIR)/etc/foo.d
-29: endef
-30:
-31: define LIBFOO_USERS
-32:     foo -1 libfoo -1 * - - - LibFoo daemon
-33: endef
-34:
-35: define LIBFOO_DEVICES
-36:     /dev/foo  c  666  0  0  42  0  -  -  -
-37: endef
-38:
-39: define LIBFOO_PERMISSIONS
-40:     /bin/foo  f  4755  foo  libfoo   -  -  -  -  -
-41: endef
-42:
-43: $(eval $(generic-package))

The Makefile begins on line 7 to 11 with metadata information: the -version of the package (LIBFOO_VERSION), the name of the -tarball containing the package (LIBFOO_SOURCE) (xz-ed tarball recommended) -the Internet location at which the tarball can be downloaded from -(LIBFOO_SITE), the license (LIBFOO_LICENSE) and file with the -license text (LIBFOO_LICENSE_FILES). All variables must start with -the same prefix, LIBFOO_ in this case. This prefix is always the -uppercased version of the package name (see below to understand where -the package name is defined).

On line 12, we specify that this package wants to install something to -the staging space. This is often needed for libraries, since they must -install header files and other development files in the staging space. -This will ensure that the commands listed in the -LIBFOO_INSTALL_STAGING_CMDS variable will be executed.

On line 13, we specify that there is some fixing to be done to some -of the libfoo-config files that were installed during -LIBFOO_INSTALL_STAGING_CMDS phase. -These *-config files are executable shell script files that are -located in $(STAGING_DIR)/usr/bin directory and are executed -by other 3rd party packages to find out the location and the linking -flags of this particular package.

The problem is that all these *-config files by default give wrong, -host system linking flags that are unsuitable for cross-compiling.

For example: -I/usr/include instead of -I$(STAGING_DIR)/usr/include -or: -L/usr/lib instead of -L$(STAGING_DIR)/usr/lib

So some sed magic is done to these scripts to make them give correct -flags. -The argument to be given to LIBFOO_CONFIG_SCRIPTS is the file name(s) -of the shell script(s) needing fixing. All these names are relative to -$(STAGING_DIR)/usr/bin and if needed multiple names can be given.

In addition, the scripts listed in LIBFOO_CONFIG_SCRIPTS are removed -from $(TARGET_DIR)/usr/bin, since they are not needed on the target.

Example 18.1. Config script: divine package

Package divine installs shell script $(STAGING_DIR)/usr/bin/divine-config.

So its fixup would be:

DIVINE_CONFIG_SCRIPTS = divine-config

Example 18.2. Config script: imagemagick package:

Package imagemagick installs the following scripts: -$(STAGING_DIR)/usr/bin/{Magick,Magick++,MagickCore,MagickWand,Wand}-config

So it’s fixup would be:

IMAGEMAGICK_CONFIG_SCRIPTS = \
-   Magick-config Magick++-config \
-   MagickCore-config MagickWand-config Wand-config

On line 14, we specify the list of dependencies this package relies -on. These dependencies are listed in terms of lower-case package names, -which can be packages for the target (without the host- -prefix) or packages for the host (with the host-) prefix). -Buildroot will ensure that all these packages are built and installed -before the current package starts its configuration.

The rest of the Makefile, lines 16..29, defines what should be done -at the different steps of the package configuration, compilation and -installation. -LIBFOO_BUILD_CMDS tells what steps should be performed to -build the package. LIBFOO_INSTALL_STAGING_CMDS tells what -steps should be performed to install the package in the staging space. -LIBFOO_INSTALL_TARGET_CMDS tells what steps should be -performed to install the package in the target space.

All these steps rely on the $(@D) variable, which -contains the directory where the source code of the package has been -extracted.

On lines 31..33, we define a user that is used by this package (e.g. -to run a daemon as non-root) (LIBFOO_USERS).

On line 35..37, we define a device-node file used by this package -(LIBFOO_DEVICES).

On line 39..41, we define the permissions to set to specific files -installed by this package (LIBFOO_PERMISSIONS).

Finally, on line 43, we call the generic-package function, which -generates, according to the variables defined previously, all the -Makefile code necessary to make your package working.

18.5.2. generic-package reference

There are two variants of the generic target. The generic-package macro is -used for packages to be cross-compiled for the target. The -host-generic-package macro is used for host packages, natively compiled -for the host. It is possible to call both of them in a single .mk -file: once to create the rules to generate a target -package and once to create the rules to generate a host package:

$(eval $(generic-package))
-$(eval $(host-generic-package))

This might be useful if the compilation of the target package requires -some tools to be installed on the host. If the package name is -libfoo, then the name of the package for the target is also -libfoo, while the name of the package for the host is -host-libfoo. These names should be used in the DEPENDENCIES -variables of other packages, if they depend on libfoo or -host-libfoo.

The call to the generic-package and/or host-generic-package macro -must be at the end of the .mk file, after all variable definitions. -The call to host-generic-package must be after the call to -generic-package, if any.

For the target package, the generic-package uses the variables defined by -the .mk file and prefixed by the uppercased package name: -LIBFOO_*. host-generic-package uses the HOST_LIBFOO_* variables. For -some variables, if the HOST_LIBFOO_ prefixed variable doesn’t -exist, the package infrastructure uses the corresponding variable -prefixed by LIBFOO_. This is done for variables that are likely to -have the same value for both the target and host packages. See below -for details.

The list of variables that can be set in a .mk file to give metadata -information is (assuming the package name is libfoo) :

  • -LIBFOO_VERSION, mandatory, must contain the version of the - package. Note that if HOST_LIBFOO_VERSION doesn’t exist, it is - assumed to be the same as LIBFOO_VERSION. It can also be a - revision number or a tag for packages that are fetched directly - from their version control system. Examples: -

    • -a version for a release tarball: LIBFOO_VERSION = 0.1.2 -
    • -a sha1 for a git tree: LIBFOO_VERSION = cb9d6aa9429e838f0e54faa3d455bcbab5eef057 -
    • -a tag for a git tree LIBFOO_VERSION = v0.1.2 -

      Note: Using a branch name as FOO_VERSION is not supported, because it does -not and can not work as people would expect it should:

      1. -due to local caching, Buildroot will not re-fetch the repository, - so people who expect to be able to follow the remote repository - would be quite surprised and disappointed; -
      2. -because two builds can never be perfectly simultaneous, and because - the remote repository may get new commits on the branch anytime, - two users, using the same Buildroot tree and building the same - configuration, may get different source, thus rendering the build - non reproducible, and people would be quite surprised and - disappointed. -
  • -LIBFOO_SOURCE may contain the name of the tarball of the package, - which Buildroot will use to download the tarball from - LIBFOO_SITE. If HOST_LIBFOO_SOURCE is not specified, it defaults - to LIBFOO_SOURCE. If none are specified, then the value is assumed - to be libfoo-$(LIBFOO_VERSION).tar.gz. - Example: LIBFOO_SOURCE = foobar-$(LIBFOO_VERSION).tar.bz2 -
  • -LIBFOO_PATCH may contain a space-separated list of patch file - names, that Buildroot will download and apply to the package source - code. If an entry contains ://, then Buildroot will assume it is a - full URL and download the patch from this location. Otherwise, - Buildroot will assume that the patch should be downloaded from - LIBFOO_SITE. If HOST_LIBFOO_PATCH is not specified, it defaults - to LIBFOO_PATCH. Note that patches that are included in Buildroot - itself use a different mechanism: all files of the form - *.patch present in the package directory inside - Buildroot will be applied to the package after extraction (see - patching a package). Finally, patches listed in - the LIBFOO_PATCH variable are applied before the patches stored - in the Buildroot package directory. -
  • -LIBFOO_SITE provides the location of the package, which can be a - URL or a local filesystem path. HTTP, FTP and SCP are supported URL - types for retrieving package tarballs. In these cases don’t include a - trailing slash: it will be added by Buildroot between the directory - and the filename as appropriate. Git, Subversion, Mercurial, - and Bazaar are supported URL types for retrieving packages directly - from source code management systems. There is a helper function to make - it easier to download source tarballs from GitHub (refer to - Section 18.24.4, “How to add a package from GitHub” for details). A filesystem path may be used - to specify either a tarball or a directory containing the package - source code. See LIBFOO_SITE_METHOD below for more details on how - retrieval works. - Note that SCP URLs should be of the form - scp://[user@]host:filepath, and that filepath is relative to the - user’s home directory, so you may want to prepend the path with a - slash for absolute paths: - scp://[user@]host:/absolutepath. - If HOST_LIBFOO_SITE is not specified, it defaults to - LIBFOO_SITE. - Examples: - LIBFOO_SITE=http://www.libfoosoftware.org/libfoo - LIBFOO_SITE=http://svn.xiph.org/trunk/Tremor - LIBFOO_SITE=/opt/software/libfoo.tar.gz - LIBFOO_SITE=$(TOPDIR)/../src/libfoo -
  • -LIBFOO_DL_OPTS is a space-separated list of additional options to - pass to the downloader. Useful for retrieving documents with - server-side checking for user logins and passwords, or to use a proxy. - All download methods valid for LIBFOO_SITE_METHOD are supported; - valid options depend on the download method (consult the man page - for the respective download utilities). -
  • -LIBFOO_EXTRA_DOWNLOADS is a space-separated list of additional - files that Buildroot should download. If an entry contains :// - then Buildroot will assume it is a complete URL and will download - the file using this URL. Otherwise, Buildroot will assume the file - to be downloaded is located at LIBFOO_SITE. Buildroot will not do - anything with those additional files, except download them: it will - be up to the package recipe to use them from $(LIBFOO_DL_DIR). -
  • -LIBFOO_SITE_METHOD determines the method used to fetch or copy the - package source code. In many cases, Buildroot guesses the method - from the contents of LIBFOO_SITE and setting LIBFOO_SITE_METHOD - is unnecessary. When HOST_LIBFOO_SITE_METHOD is not specified, it - defaults to the value of LIBFOO_SITE_METHOD. - The possible values of LIBFOO_SITE_METHOD are: -

    • -wget for normal FTP/HTTP downloads of tarballs. Used by - default when LIBFOO_SITE begins with http://, https:// or - ftp://. -
    • -scp for downloads of tarballs over SSH with scp. Used by - default when LIBFOO_SITE begins with scp://. -
    • -svn for retrieving source code from a Subversion repository. - Used by default when LIBFOO_SITE begins with svn://. When a - http:// Subversion repository URL is specified in - LIBFOO_SITE, one must specify LIBFOO_SITE_METHOD=svn. - Buildroot performs a checkout which is preserved as a tarball in - the download cache; subsequent builds use the tarball instead of - performing another checkout. -
    • -cvs for retrieving source code from a CVS repository. - Used by default when LIBFOO_SITE begins with cvs://. - The downloaded source code is cached as with the svn method. - Anonymous pserver mode is assumed otherwise explicitly defined - on LIBFOO_SITE. Both - LIBFOO_SITE=cvs://libfoo.net:/cvsroot/libfoo and - LIBFOO_SITE=cvs://:ext:libfoo.net:/cvsroot/libfoo - are accepted, on the former anonymous pserver access mode is - assumed. - LIBFOO_SITE must contain the source URL as well as the remote - repository directory. The module is the package name. - LIBFOO_VERSION is mandatory and must be a tag, a branch, or - a date (e.g. "2014-10-20", "2014-10-20 13:45", "2014-10-20 - 13:45+01" see "man cvs" for further details). -
    • -git for retrieving source code from a Git repository. Used by - default when LIBFOO_SITE begins with git://. The downloaded - source code is cached as with the svn - method. -
    • -hg for retrieving source code from a Mercurial repository. One - must specify LIBFOO_SITE_METHOD=hg when LIBFOO_SITE - contains a Mercurial repository URL. The downloaded source code - is cached as with the svn method. -
    • -bzr for retrieving source code from a Bazaar repository. Used - by default when LIBFOO_SITE begins with bzr://. The - downloaded source code is cached as with the svn method. -
    • -file for a local tarball. One should use this when - LIBFOO_SITE specifies a package tarball as a local filename. - Useful for software that isn’t available publicly or in version - control. -
    • -local for a local source code directory. One should use this - when LIBFOO_SITE specifies a local directory path containing - the package source code. Buildroot copies the contents of the - source directory into the package’s build directory. Note that - for local packages, no patches are applied. If you need to - still patch the source code, use LIBFOO_POST_RSYNC_HOOKS, see - Section 18.22.1, “Using the POST_RSYNC hook”. -
  • -LIBFOO_GIT_SUBMODULES can be set to YES to create an archive - with the git submodules in the repository. This is only available - for packages downloaded with git (i.e. when - LIBFOO_SITE_METHOD=git). Note that we try not to use such git - submodules when they contain bundled libraries, in which case we - prefer to use those libraries from their own package. -
  • -LIBFOO_STRIP_COMPONENTS is the number of leading components - (directories) that tar must strip from file names on extraction. - The tarball for most packages has one leading component named - "<pkg-name>-<pkg-version>", thus Buildroot passes - --strip-components=1 to tar to remove it. - For non-standard packages that don’t have this component, or - that have more than one leading component to strip, set this - variable with the value to be passed to tar. Default: 1. -
  • -LIBFOO_EXCLUDES is a space-separated list of patterns to exclude - when extracting the archive. Each item from that list is passed as - a tar’s --exclude option. By default, empty. -
  • -LIBFOO_DEPENDENCIES lists the dependencies (in terms of package - name) that are required for the current target package to - compile. These dependencies are guaranteed to be compiled and - installed before the configuration of the current package starts. - However, modifications to configuration of these dependencies will - not force a rebuild of the current package. In a similar way, - HOST_LIBFOO_DEPENDENCIES lists the dependencies for the current - host package. -
  • -LIBFOO_EXTRACT_DEPENDENCIES lists the dependencies (in terms of - package name) that are required for the current target package to be - extracted. These dependencies are guaranteed to be compiled and - installed before the extract step of the current package - starts. This is only used internally by the package infrastructure, - and should typically not be used directly by packages. -
  • -LIBFOO_PATCH_DEPENDENCIES lists the dependencies (in terms of - package name) that are required for the current package to be - patched. These dependencies are guaranteed to be extracted and - patched (but not necessarily built) before the current package is - patched. In a similar way, HOST_LIBFOO_PATCH_DEPENDENCIES lists - the dependencies for the current host package. - This is seldom used; usually, LIBFOO_DEPENDENCIES is what you - really want to use. -
  • -LIBFOO_PROVIDES lists all the virtual packages libfoo is an - implementation of. See Section 18.11, “Infrastructure for virtual packages”. -
  • -LIBFOO_INSTALL_STAGING can be set to YES or NO (default). If - set to YES, then the commands in the LIBFOO_INSTALL_STAGING_CMDS - variables are executed to install the package into the staging - directory. -
  • -LIBFOO_INSTALL_TARGET can be set to YES (default) or NO. If - set to YES, then the commands in the LIBFOO_INSTALL_TARGET_CMDS - variables are executed to install the package into the target - directory. -
  • -LIBFOO_INSTALL_IMAGES can be set to YES or NO (default). If - set to YES, then the commands in the LIBFOO_INSTALL_IMAGES_CMDS - variable are executed to install the package into the images - directory. -
  • -LIBFOO_CONFIG_SCRIPTS lists the names of the files in - $(STAGING_DIR)/usr/bin that need some special fixing to make them - cross-compiling friendly. Multiple file names separated by space can - be given and all are relative to $(STAGING_DIR)/usr/bin. The files - listed in LIBFOO_CONFIG_SCRIPTS are also removed from - $(TARGET_DIR)/usr/bin since they are not needed on the target. -
  • -LIBFOO_DEVICES lists the device files to be created by Buildroot - when using the static device table. The syntax to use is the - makedevs one. You can find some documentation for this syntax in the - Chapter 25, Makedev syntax documentation. This variable is optional. -
  • -LIBFOO_PERMISSIONS lists the changes of permissions to be done at - the end of the build process. The syntax is once again the makedevs one. - You can find some documentation for this syntax in the Chapter 25, Makedev syntax documentation. - This variable is optional. -
  • -LIBFOO_USERS lists the users to create for this package, if it installs - a program you want to run as a specific user (e.g. as a daemon, or as a - cron-job). The syntax is similar in spirit to the makedevs one, and is - described in the Chapter 26, Makeusers syntax documentation. This variable is optional. -
  • -LIBFOO_LICENSE defines the license (or licenses) under which the package - is released. - This name will appear in the manifest file produced by make legal-info. - If the license appears in the SPDX License List, - use the SPDX short identifier to make the manifest file uniform. - Otherwise, describe the license in a precise and concise way, avoiding - ambiguous names such as BSD which actually name a family of licenses. - This variable is optional. If it is not defined, unknown will appear in - the license field of the manifest file for this package. - The expected format for this variable must comply with the following rules: -

    • -If different parts of the package are released under different - licenses, then comma separate licenses (e.g. LIBFOO_LICENSE = - GPL-2.0+, LGPL-2.1+). If there is clear distinction between which - component is licensed under what license, then annotate the license - with that component, between parenthesis (e.g. LIBFOO_LICENSE = - GPL-2.0+ (programs), LGPL-2.1+ (libraries)). -
    • -If some licenses are conditioned on a sub-option being enabled, append - the conditional licenses with a comma (e.g.: FOO_LICENSE += , GPL-2.0+ - (programs)); the infrastructure will internally remove the space before - the comma. -
    • -If the package is dual licensed, then separate licenses with the - or keyword (e.g. LIBFOO_LICENSE = AFL-2.1 or GPL-2.0+). -
  • -LIBFOO_LICENSE_FILES is a space-separated list of files in the package - tarball that contain the license(s) under which the package is released. - make legal-info copies all of these files in the legal-info directory. - See Chapter 13, Legal notice and licensing for more information. - This variable is optional. If it is not defined, a warning will be produced - to let you know, and not saved will appear in the license files field - of the manifest file for this package. -
  • -LIBFOO_ACTUAL_SOURCE_TARBALL only applies to packages whose - LIBFOO_SITE / LIBFOO_SOURCE pair points to an archive that does - not actually contain source code, but binary code. This a very - uncommon case, only known to apply to external toolchains which come - already compiled, although theoretically it might apply to other - packages. In such cases a separate tarball is usually available with - the actual source code. Set LIBFOO_ACTUAL_SOURCE_TARBALL to the - name of the actual source code archive and Buildroot will download - it and use it when you run make legal-info to collect - legally-relevant material. Note this file will not be downloaded - during regular builds nor by make source. -
  • -LIBFOO_ACTUAL_SOURCE_SITE provides the location of the actual - source tarball. The default value is LIBFOO_SITE, so you don’t - need to set this variable if the binary and source archives are - hosted on the same directory. If LIBFOO_ACTUAL_SOURCE_TARBALL is - not set, it doesn’t make sense to define - LIBFOO_ACTUAL_SOURCE_SITE. -
  • -LIBFOO_REDISTRIBUTE can be set to YES (default) or NO to indicate if - the package source code is allowed to be redistributed. Set it to NO for - non-opensource packages: Buildroot will not save the source code for this - package when collecting the legal-info. -
  • -LIBFOO_FLAT_STACKSIZE defines the stack size of an application built into - the FLAT binary format. The application stack size on the NOMMU architecture - processors can’t be enlarged at run time. The default stack size for the - FLAT binary format is only 4k bytes. If the application consumes more stack, - append the required number here. -
  • -LIBFOO_BIN_ARCH_EXCLUDE is a space-separated list of paths (relative - to the target directory) to ignore when checking that the package - installs correctly cross-compiled binaries. You seldom need to set this - variable, unless the package installs binary blobs outside the default - locations, /lib/firmware, /usr/lib/firmware, /lib/modules, - /usr/lib/modules, and /usr/share, which are automatically excluded. -
  • -LIBFOO_IGNORE_CVES is a space-separated list of CVEs that tells - Buildroot CVE tracking tools which CVEs should be ignored for this - package. This is typically used when the CVE is fixed by a patch in - the package, or when the CVE for some reason does not affect the - Buildroot package. A Makefile comment must always precede the - addition of a CVE to this variable. Example: -
# 0001-fix-cve-2020-12345.patch
-LIBFOO_IGNORE_CVES += CVE-2020-12345
-# only when built with libbaz, which Buildroot doesn't support
-LIBFOO_IGNORE_CVES += CVE-2020-54321
  • -LIBFOO_CPE_ID_* variables is a set of variables that allows the - package to define its CPE - identifier. The available variables are: -

    • -LIBFOO_CPE_ID_PREFIX, specifies the prefix of the CPE identifier, - i.e the first three fields. When not defined, the default value is - cpe:2.3:a. -
    • -LIBFOO_CPE_ID_VENDOR, specifies the vendor part of the CPE - identifier. When not defined, the default value is - <pkgname>_project. -
    • -LIBFOO_CPE_ID_PRODUCT, specifies the product part of the CPE - identifier. When not defined, the default value is <pkgname>. -
    • -LIBFOO_CPE_ID_VERSION, specifies the version part of the CPE - identifier. When not defined the default value is - $(LIBFOO_VERSION). -
    • -LIBFOO_CPE_ID_UPDATE specifies the update part of the CPE - identifier. When not defined the default value is *. -

    If any of those variables is defined, then the generic package -infrastructure assumes the package provides valid CPE information. In -this case, the generic package infrastructure will define -LIBFOO_CPE_ID.

    For a host package, if its LIBFOO_CPE_ID_* variables are not -defined, it inherits the value of those variables from the -corresponding target package.

The recommended way to define these variables is to use the following -syntax:

LIBFOO_VERSION = 2.32

Now, the variables that define what should be performed at the -different steps of the build process.

  • -LIBFOO_EXTRACT_CMDS lists the actions to be performed to extract - the package. This is generally not needed as tarballs are - automatically handled by Buildroot. However, if the package uses a - non-standard archive format, such as a ZIP or RAR file, or has a - tarball with a non-standard organization, this variable allows to - override the package infrastructure default behavior. -
  • -LIBFOO_CONFIGURE_CMDS lists the actions to be performed to - configure the package before its compilation. -
  • -LIBFOO_BUILD_CMDS lists the actions to be performed to - compile the package. -
  • -HOST_LIBFOO_INSTALL_CMDS lists the actions to be performed - to install the package, when the package is a host package. The - package must install its files to the directory given by - $(HOST_DIR). All files, including development files such as - headers should be installed, since other packages might be compiled - on top of this package. -
  • -LIBFOO_INSTALL_TARGET_CMDS lists the actions to be - performed to install the package to the target directory, when the - package is a target package. The package must install its files to - the directory given by $(TARGET_DIR). Only the files required for - execution of the package have to be - installed. Header files, static libraries and documentation will be - removed again when the target filesystem is finalized. -
  • -LIBFOO_INSTALL_STAGING_CMDS lists the actions to be - performed to install the package to the staging directory, when the - package is a target package. The package must install its files to - the directory given by $(STAGING_DIR). All development files - should be installed, since they might be needed to compile other - packages. -
  • -LIBFOO_INSTALL_IMAGES_CMDS lists the actions to be performed to - install the package to the images directory, when the package is a - target package. The package must install its files to the directory - given by $(BINARIES_DIR). Only files that are binary images (aka - images) that do not belong in the TARGET_DIR but are necessary - for booting the board should be placed here. For example, a package - should utilize this step if it has binaries which would be similar - to the kernel image, bootloader or root filesystem images. -
  • -LIBFOO_INSTALL_INIT_SYSV, LIBFOO_INSTALL_INIT_OPENRC and - LIBFOO_INSTALL_INIT_SYSTEMD list the actions to install init - scripts either for the systemV-like init systems (busybox, - sysvinit, etc.), openrc or for the systemd units. These commands - will be run only when the relevant init system is installed (i.e. - if systemd is selected as the init system in the configuration, - only LIBFOO_INSTALL_INIT_SYSTEMD will be run). The only exception - is when openrc is chosen as init system and LIBFOO_INSTALL_INIT_OPENRC - has not been set, in such situation LIBFOO_INSTALL_INIT_SYSV will - be called, since openrc supports sysv init scripts. - When systemd is used as the init system, buildroot will automatically enable - all services using the systemctl preset-all command in the final phase of - image building. You can add preset files to prevent a particular unit from - being automatically enabled by buildroot. -
  • -LIBFOO_HELP_CMDS lists the actions to print the package help, which - is included to the main make help output. These commands can print - anything in any format. - This is seldom used, as packages rarely have custom rules. Do not use - this variable, unless you really know that you need to print help. -
  • -LIBFOO_LINUX_CONFIG_FIXUPS lists the Linux kernel configuration - options that are needed to build and use this package, and without - which the package is fundamentally broken. This shall be a set of - calls to one of the kconfig tweaking option: KCONFIG_ENABLE_OPT, - KCONFIG_DISABLE_OPT, or KCONFIG_SET_OPT. - This is seldom used, as package usually have no strict requirements on - the kernel options. -

The preferred way to define these variables is:

define LIBFOO_CONFIGURE_CMDS
-        action 1
-        action 2
-        action 3
-endef

In the action definitions, you can use the following variables:

  • -$(LIBFOO_PKGDIR) contains the path to the directory containing the - libfoo.mk and Config.in files. This variable is useful when it is - necessary to install a file bundled in Buildroot, like a runtime - configuration file, a splashscreen image… -
  • -$(@D), which contains the directory in which the package source - code has been uncompressed. -
  • -$(LIBFOO_DL_DIR) contains the path to the directory where all the downloads - made by Buildroot for libfoo are stored in. -
  • -$(TARGET_CC), $(TARGET_LD), etc. to get the target - cross-compilation utilities -
  • -$(TARGET_CROSS) to get the cross-compilation toolchain prefix -
  • -Of course the $(HOST_DIR), $(STAGING_DIR) and $(TARGET_DIR) - variables to install the packages properly. Those variables point to - the global host, staging and target directories, unless - per-package directory support is used, in which case they point to - the current package host, staging and target directories. In - both cases, it doesn’t make any difference from the package point of - view: it should simply use HOST_DIR, STAGING_DIR and - TARGET_DIR. See Section 8.12, “Top-level parallel build” for more details - about per-package directory support. -

Finally, you can also use hooks. See Section 18.22, “Hooks available in the various build steps” for more information.

18.6. Infrastructure for autotools-based packages

18.6.1. autotools-package tutorial

First, let’s see how to write a .mk file for an autotools-based -package, with an example :

01: ################################################################################
-02: #
-03: # libfoo
-04: #
-05: ################################################################################
-06:
-07: LIBFOO_VERSION = 1.0
-08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz
-09: LIBFOO_SITE = http://www.foosoftware.org/download
-10: LIBFOO_INSTALL_STAGING = YES
-11: LIBFOO_INSTALL_TARGET = NO
-12: LIBFOO_CONF_OPTS = --disable-shared
-13: LIBFOO_DEPENDENCIES = libglib2 host-pkgconf
-14:
-15: $(eval $(autotools-package))

On line 7, we declare the version of the package.

On line 8 and 9, we declare the name of the tarball (xz-ed tarball recommended) -and the location of the tarball on the Web. Buildroot will automatically -download the tarball from this location.

On line 10, we tell Buildroot to install the package to the staging -directory. The staging directory, located in output/staging/ -is the directory where all the packages are installed, including their -development files, etc. By default, packages are not installed to the -staging directory, since usually, only libraries need to be installed in -the staging directory: their development files are needed to compile -other libraries or applications depending on them. Also by default, when -staging installation is enabled, packages are installed in this location -using the make install command.

On line 11, we tell Buildroot to not install the package to the -target directory. This directory contains what will become the root -filesystem running on the target. For purely static libraries, it is -not necessary to install them in the target directory because they will -not be used at runtime. By default, target installation is enabled; setting -this variable to NO is almost never needed. Also by default, packages are -installed in this location using the make install command.

On line 12, we tell Buildroot to pass a custom configure option, that -will be passed to the ./configure script before configuring -and building the package.

On line 13, we declare our dependencies, so that they are built -before the build process of our package starts.

Finally, on line line 15, we invoke the autotools-package -macro that generates all the Makefile rules that actually allows the -package to be built.

18.6.2. autotools-package reference

The main macro of the autotools package infrastructure is -autotools-package. It is similar to the generic-package macro. The ability to -have target and host packages is also available, with the -host-autotools-package macro.

Just like the generic infrastructure, the autotools infrastructure -works by defining a number of variables before calling the -autotools-package macro.

First, all the package metadata information variables that exist in the -generic infrastructure also exist in the autotools infrastructure: -LIBFOO_VERSION, LIBFOO_SOURCE, -LIBFOO_PATCH, LIBFOO_SITE, -LIBFOO_SUBDIR, LIBFOO_DEPENDENCIES, -LIBFOO_INSTALL_STAGING, LIBFOO_INSTALL_TARGET.

A few additional variables, specific to the autotools infrastructure, -can also be defined. Many of them are only useful in very specific -cases, typical packages will therefore only use a few of them.

  • -LIBFOO_SUBDIR may contain the name of a subdirectory - inside the package that contains the configure script. This is useful, - if for example, the main configure script is not at the root of the - tree extracted by the tarball. If HOST_LIBFOO_SUBDIR is - not specified, it defaults to LIBFOO_SUBDIR. -
  • -LIBFOO_CONF_ENV, to specify additional environment - variables to pass to the configure script. By default, empty. -
  • -LIBFOO_CONF_OPTS, to specify additional configure - options to pass to the configure script. By default, empty. -
  • -LIBFOO_MAKE, to specify an alternate make - command. This is typically useful when parallel make is enabled in - the configuration (using BR2_JLEVEL) but that this - feature should be disabled for the given package, for one reason or - another. By default, set to $(MAKE). If parallel building - is not supported by the package, then it should be set to - LIBFOO_MAKE=$(MAKE1). -
  • -LIBFOO_MAKE_ENV, to specify additional environment - variables to pass to make in the build step. These are passed before - the make command. By default, empty. -
  • -LIBFOO_MAKE_OPTS, to specify additional variables to - pass to make in the build step. These are passed after the - make command. By default, empty. -
  • -LIBFOO_AUTORECONF, tells whether the package should - be autoreconfigured or not (i.e. if the configure script and - Makefile.in files should be re-generated by re-running autoconf, - automake, libtool, etc.). Valid values are YES and - NO. By default, the value is NO -
  • -LIBFOO_AUTORECONF_ENV, to specify additional environment - variables to pass to the autoreconf program if - LIBFOO_AUTORECONF=YES. These are passed in the environment of - the autoreconf command. By default, empty. -
  • -LIBFOO_AUTORECONF_OPTS to specify additional options - passed to the autoreconf program if - LIBFOO_AUTORECONF=YES. By default, empty. -
  • -LIBFOO_GETTEXTIZE, tells whether the package should be - gettextized or not (i.e. if the package uses a different gettext - version than Buildroot provides, and it is needed to run - gettextize.) Only valid when LIBFOO_AUTORECONF=YES. Valid - values are YES and NO. The default is NO. -
  • -LIBFOO_GETTEXTIZE_OPTS, to specify additional options passed to - the gettextize program, if LIBFOO_GETTEXTIZE=YES. You may - use that if, for example, the .po files are not located in the - standard place (i.e. in po/ at the root of the package.) By - default, -f. -
  • -LIBFOO_LIBTOOL_PATCH tells whether the Buildroot - patch to fix libtool cross-compilation issues should be applied or - not. Valid values are YES and NO. By - default, the value is YES -
  • -LIBFOO_INSTALL_STAGING_OPTS contains the make options - used to install the package to the staging directory. By default, the - value is DESTDIR=$(STAGING_DIR) install, which is - correct for most autotools packages. It is still possible to override - it. -
  • -LIBFOO_INSTALL_TARGET_OPTS contains the make options - used to install the package to the target directory. By default, the - value is DESTDIR=$(TARGET_DIR) install. The default - value is correct for most autotools packages, but it is still possible - to override it if needed. -

With the autotools infrastructure, all the steps required to build -and install the packages are already defined, and they generally work -well for most autotools-based packages. However, when required, it is -still possible to customize what is done in any particular step:

  • -By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the various build steps” for details. -
  • -By overriding one of the steps. For example, even if the autotools - infrastructure is used, if the package .mk file defines its - own LIBFOO_CONFIGURE_CMDS variable, it will be used - instead of the default autotools one. However, using this method - should be restricted to very specific cases. Do not use it in the - general case. -

18.7. Infrastructure for CMake-based packages

18.7.1. cmake-package tutorial

First, let’s see how to write a .mk file for a CMake-based package, -with an example :

01: ################################################################################
-02: #
-03: # libfoo
-04: #
-05: ################################################################################
-06:
-07: LIBFOO_VERSION = 1.0
-08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz
-09: LIBFOO_SITE = http://www.foosoftware.org/download
-10: LIBFOO_INSTALL_STAGING = YES
-11: LIBFOO_INSTALL_TARGET = NO
-12: LIBFOO_CONF_OPTS = -DBUILD_DEMOS=ON
-13: LIBFOO_DEPENDENCIES = libglib2 host-pkgconf
-14:
-15: $(eval $(cmake-package))

On line 7, we declare the version of the package.

On line 8 and 9, we declare the name of the tarball (xz-ed tarball recommended) -and the location of the tarball on the Web. Buildroot will automatically -download the tarball from this location.

On line 10, we tell Buildroot to install the package to the staging -directory. The staging directory, located in output/staging/ -is the directory where all the packages are installed, including their -development files, etc. By default, packages are not installed to the -staging directory, since usually, only libraries need to be installed in -the staging directory: their development files are needed to compile -other libraries or applications depending on them. Also by default, when -staging installation is enabled, packages are installed in this location -using the make install command.

On line 11, we tell Buildroot to not install the package to the -target directory. This directory contains what will become the root -filesystem running on the target. For purely static libraries, it is -not necessary to install them in the target directory because they will -not be used at runtime. By default, target installation is enabled; setting -this variable to NO is almost never needed. Also by default, packages are -installed in this location using the make install command.

On line 12, we tell Buildroot to pass custom options to CMake when it is -configuring the package.

On line 13, we declare our dependencies, so that they are built -before the build process of our package starts.

Finally, on line line 15, we invoke the cmake-package -macro that generates all the Makefile rules that actually allows the -package to be built.

18.7.2. cmake-package reference

The main macro of the CMake package infrastructure is -cmake-package. It is similar to the generic-package macro. The ability to -have target and host packages is also available, with the -host-cmake-package macro.

Just like the generic infrastructure, the CMake infrastructure works -by defining a number of variables before calling the cmake-package -macro.

First, all the package metadata information variables that exist in -the generic infrastructure also exist in the CMake infrastructure: -LIBFOO_VERSION, LIBFOO_SOURCE, LIBFOO_PATCH, LIBFOO_SITE, -LIBFOO_SUBDIR, LIBFOO_DEPENDENCIES, LIBFOO_INSTALL_STAGING, -LIBFOO_INSTALL_TARGET.

A few additional variables, specific to the CMake infrastructure, can -also be defined. Many of them are only useful in very specific cases, -typical packages will therefore only use a few of them.

  • -LIBFOO_SUBDIR may contain the name of a subdirectory inside the - package that contains the main CMakeLists.txt file. This is useful, - if for example, the main CMakeLists.txt file is not at the root of - the tree extracted by the tarball. If HOST_LIBFOO_SUBDIR is not - specified, it defaults to LIBFOO_SUBDIR. -
  • -LIBFOO_CONF_ENV, to specify additional environment variables to - pass to CMake. By default, empty. -
  • -LIBFOO_CONF_OPTS, to specify additional configure options to pass - to CMake. By default, empty. A number of common CMake options are - set by the cmake-package infrastructure; so it is normally not - necessary to set them in the package’s *.mk file unless you want - to override them: -

    • -CMAKE_BUILD_TYPE is driven by BR2_ENABLE_RUNTIME_DEBUG; -
    • -CMAKE_INSTALL_PREFIX; -
    • -BUILD_SHARED_LIBS is driven by BR2_STATIC_LIBS; -
    • -BUILD_DOC, BUILD_DOCS are disabled; -
    • -BUILD_EXAMPLE, BUILD_EXAMPLES are disabled; -
    • -BUILD_TEST, BUILD_TESTS, BUILD_TESTING are disabled. -
  • -LIBFOO_SUPPORTS_IN_SOURCE_BUILD = NO should be set when the package - cannot be built inside the source tree but needs a separate build - directory. -
  • -LIBFOO_MAKE, to specify an alternate make command. This is - typically useful when parallel make is enabled in the configuration - (using BR2_JLEVEL) but that this feature should be disabled for - the given package, for one reason or another. By default, set to - $(MAKE). If parallel building is not supported by the package, - then it should be set to LIBFOO_MAKE=$(MAKE1). -
  • -LIBFOO_MAKE_ENV, to specify additional environment variables to - pass to make in the build step. These are passed before the make - command. By default, empty. -
  • -LIBFOO_MAKE_OPTS, to specify additional variables to pass to make - in the build step. These are passed after the make command. By - default, empty. -
  • -LIBFOO_INSTALL_OPTS contains the make options used to - install the package to the host directory. By default, the value - is install, which is correct for most CMake packages. It is still - possible to override it. -
  • -LIBFOO_INSTALL_STAGING_OPTS contains the make options used to - install the package to the staging directory. By default, the value - is DESTDIR=$(STAGING_DIR) install/fast, which is correct for most - CMake packages. It is still possible to override it. -
  • -LIBFOO_INSTALL_TARGET_OPTS contains the make options used to - install the package to the target directory. By default, the value - is DESTDIR=$(TARGET_DIR) install/fast. The default value is correct - for most CMake packages, but it is still possible to override it if - needed. -

With the CMake infrastructure, all the steps required to build and -install the packages are already defined, and they generally work well -for most CMake-based packages. However, when required, it is still -possible to customize what is done in any particular step:

  • -By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the various build steps” for details. -
  • -By overriding one of the steps. For example, even if the CMake - infrastructure is used, if the package .mk file defines its own - LIBFOO_CONFIGURE_CMDS variable, it will be used instead of the - default CMake one. However, using this method should be restricted - to very specific cases. Do not use it in the general case. -

18.8. Infrastructure for Python packages

This infrastructure applies to Python packages that use the standard -Python setuptools mechanism as their build system, generally -recognizable by the usage of a setup.py script.

18.8.1. python-package tutorial

First, let’s see how to write a .mk file for a Python package, -with an example :

01: ################################################################################
-02: #
-03: # python-foo
-04: #
-05: ################################################################################
-06:
-07: PYTHON_FOO_VERSION = 1.0
-08: PYTHON_FOO_SOURCE = python-foo-$(PYTHON_FOO_VERSION).tar.xz
-09: PYTHON_FOO_SITE = http://www.foosoftware.org/download
-10: PYTHON_FOO_LICENSE = BSD-3-Clause
-11: PYTHON_FOO_LICENSE_FILES = LICENSE
-12: PYTHON_FOO_ENV = SOME_VAR=1
-13: PYTHON_FOO_DEPENDENCIES = libmad
-14: PYTHON_FOO_SETUP_TYPE = distutils
-15:
-16: $(eval $(python-package))

On line 7, we declare the version of the package.

On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location.

On line 10 and 11, we give licensing details about the package (its -license on line 10, and the file containing the license text on line -11).

On line 12, we tell Buildroot to pass custom options to the Python -setup.py script when it is configuring the package.

On line 13, we declare our dependencies, so that they are built -before the build process of our package starts.

On line 14, we declare the specific Python build system being used. In -this case the distutils Python build system is used. The two -supported ones are distutils and setuptools.

Finally, on line 16, we invoke the python-package macro that -generates all the Makefile rules that actually allow the package to be -built.

18.8.2. python-package reference

As a policy, packages that merely provide Python modules should all be -named python-<something> in Buildroot. Other packages that use the -Python build system, but are not Python modules, can freely choose -their name (existing examples in Buildroot are scons and -supervisor).

Packages that are only compatible with one version of Python (as in: -Python 2 or Python 3) should depend on that version explicitely in -their Config.in file (BR2_PACKAGE_PYTHON for Python 2, -BR2_PACKAGE_PYTHON3 for Python 3). Packages that are compatible -with both versions should not explicitely depend on them in their -Config.in file, since that condition is already expressed for the -whole "External python modules" menu.

The main macro of the Python package infrastructure is -python-package. It is similar to the generic-package macro. It is -also possible to create Python host packages with the -host-python-package macro.

Just like the generic infrastructure, the Python infrastructure works -by defining a number of variables before calling the python-package -or host-python-package macros.

All the package metadata information variables that exist in the -generic package infrastructure also -exist in the Python infrastructure: PYTHON_FOO_VERSION, -PYTHON_FOO_SOURCE, PYTHON_FOO_PATCH, PYTHON_FOO_SITE, -PYTHON_FOO_SUBDIR, PYTHON_FOO_DEPENDENCIES, PYTHON_FOO_LICENSE, -PYTHON_FOO_LICENSE_FILES, PYTHON_FOO_INSTALL_STAGING, etc.

Note that:

  • -It is not necessary to add python or host-python in the - PYTHON_FOO_DEPENDENCIES variable of a package, since these basic - dependencies are automatically added as needed by the Python - package infrastructure. -
  • -Similarly, it is not needed to add host-setuptools to - PYTHON_FOO_DEPENDENCIES for setuptools-based packages, since it’s - automatically added by the Python infrastructure as needed. -

One variable specific to the Python infrastructure is mandatory:

  • -PYTHON_FOO_SETUP_TYPE, to define which Python build system is used - by the package. The two supported values are distutils and - setuptools. If you don’t know which one is used in your package, - look at the setup.py file in your package source code, and see - whether it imports things from the distutils module or the - setuptools module. -

A few additional variables, specific to the Python infrastructure, can -optionally be defined, depending on the package’s needs. Many of them -are only useful in very specific cases, typical packages will -therefore only use a few of them, or none.

  • -PYTHON_FOO_SUBDIR may contain the name of a subdirectory inside the - package that contains the main setup.py file. This is useful, - if for example, the main setup.py file is not at the root of - the tree extracted by the tarball. If HOST_PYTHON_FOO_SUBDIR is not - specified, it defaults to PYTHON_FOO_SUBDIR. -
  • -PYTHON_FOO_ENV, to specify additional environment variables to - pass to the Python setup.py script (for both the build and install - steps). Note that the infrastructure is automatically passing - several standard variables, defined in PKG_PYTHON_DISTUTILS_ENV - (for distutils target packages), HOST_PKG_PYTHON_DISTUTILS_ENV - (for distutils host packages), PKG_PYTHON_SETUPTOOLS_ENV (for - setuptools target packages) and HOST_PKG_PYTHON_SETUPTOOLS_ENV - (for setuptools host packages). -
  • -PYTHON_FOO_BUILD_OPTS, to specify additional options to pass to the - Python setup.py script during the build step. For target distutils - packages, the PKG_PYTHON_DISTUTILS_BUILD_OPTS options are already - passed automatically by the infrastructure. -
  • -PYTHON_FOO_INSTALL_TARGET_OPTS, PYTHON_FOO_INSTALL_STAGING_OPTS, - HOST_PYTHON_FOO_INSTALL_OPTS to specify additional options to pass - to the Python setup.py script during the target installation step, - the staging installation step or the host installation, - respectively. Note that the infrastructure is automatically passing - some options, defined in PKG_PYTHON_DISTUTILS_INSTALL_TARGET_OPTS - or PKG_PYTHON_DISTUTILS_INSTALL_STAGING_OPTS (for target distutils - packages), HOST_PKG_PYTHON_DISTUTILS_INSTALL_OPTS (for host - distutils packages), PKG_PYTHON_SETUPTOOLS_INSTALL_TARGET_OPTS or - PKG_PYTHON_SETUPTOOLS_INSTALL_STAGING_OPTS (for target setuptools - packages) and HOST_PKG_PYTHON_SETUPTOOLS_INSTALL_OPTS (for host - setuptools packages). -
  • -HOST_PYTHON_FOO_NEEDS_HOST_PYTHON, to define the host python - interpreter. The usage of this variable is limited to host - packages. The two supported value are python2 and python3. It - will ensure the right host python package is available and will - invoke it for the build. If some build steps are overloaded, the - right python interpreter must be explicitly called in the commands. -

With the Python infrastructure, all the steps required to build and -install the packages are already defined, and they generally work well -for most Python-based packages. However, when required, it is still -possible to customize what is done in any particular step:

  • -By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the various build steps” for details. -
  • -By overriding one of the steps. For example, even if the Python - infrastructure is used, if the package .mk file defines its own - PYTHON_FOO_BUILD_CMDS variable, it will be used instead of the - default Python one. However, using this method should be restricted - to very specific cases. Do not use it in the general case. -

18.8.3. Generating a python-package from a PyPI repository

If the Python package for which you would like to create a Buildroot -package is available on PyPI, you may want to use the scanpypi tool -located in utils/ to automate the process.

You can find the list of existing PyPI packages -here.

scanpypi requires Python’s setuptools package to be installed on -your host.

When at the root of your buildroot directory just do :

utils/scanpypi foo bar -o package

This will generate packages python-foo and python-bar in the package -folder if they exist on https://pypi.python.org.

Find the external python modules menu and insert your package inside. -Keep in mind that the items inside a menu should be in alphabetical order.

Please keep in mind that you’ll most likely have to manually check the -package for any mistakes as there are things that cannot be guessed by -the generator (e.g. dependencies on any of the python core modules -such as BR2_PACKAGE_PYTHON_ZLIB). Also, please take note that the -license and license files are guessed and must be checked. You also -need to manually add the package to the package/Config.in file.

If your Buildroot package is not in the official Buildroot tree but in -a br2-external tree, use the -o flag as follows:

utils/scanpypi foo bar -o other_package_dir

This will generate packages python-foo and python-bar in the -other_package_directory instead of package.

Option -h will list the available options:

utils/scanpypi -h

18.8.4. python-package CFFI backend

C Foreign Function Interface for Python (CFFI) provides a convenient -and reliable way to call compiled C code from Python using interface -declarations written in C. Python packages relying on this backend can -be identified by the appearance of a cffi dependency in the -install_requires field of their setup.py file.

Such a package should:

  • -add python-cffi as a runtime dependency in order to install the -compiled C library wrapper on the target. This is achieved by adding -select BR2_PACKAGE_PYTHON_CFFI to the package Config.in. -
config BR2_PACKAGE_PYTHON_FOO
-        bool "python-foo"
-        select BR2_PACKAGE_PYTHON_CFFI # runtime
  • -add host-python-cffi as a build-time dependency in order to -cross-compile the C wrapper. This is achieved by adding -host-python-cffi to the PYTHON_FOO_DEPENDENCIES variable. -
################################################################################
-#
-# python-foo
-#
-################################################################################
-
-...
-
-PYTHON_FOO_DEPENDENCIES = host-python-cffi
-
-$(eval $(python-package))

18.9. Infrastructure for LuaRocks-based packages

18.9.1. luarocks-package tutorial

First, let’s see how to write a .mk file for a LuaRocks-based package, -with an example :

01: ################################################################################
-02: #
-03: # lua-foo
-04: #
-05: ################################################################################
-06:
-07: LUA_FOO_VERSION = 1.0.2-1
-08: LUA_FOO_NAME_UPSTREAM = foo
-09: LUA_FOO_DEPENDENCIES = bar
-10:
-11: LUA_FOO_BUILD_OPTS += BAR_INCDIR=$(STAGING_DIR)/usr/include
-12: LUA_FOO_BUILD_OPTS += BAR_LIBDIR=$(STAGING_DIR)/usr/lib
-13: LUA_FOO_LICENSE = luaFoo license
-14: LUA_FOO_LICENSE_FILES = $(LUA_FOO_SUBDIR)/COPYING
-15:
-16: $(eval $(luarocks-package))

On line 7, we declare the version of the package (the same as in the rockspec, -which is the concatenation of the upstream version and the rockspec revision, -separated by a hyphen -).

On line 8, we declare that the package is called "foo" on LuaRocks. In -Buildroot, we give Lua-related packages a name that starts with "lua", so the -Buildroot name is different from the upstream name. LUA_FOO_NAME_UPSTREAM -makes the link between the two names.

On line 9, we declare our dependencies against native libraries, so that they -are built before the build process of our package starts.

On lines 11-12, we tell Buildroot to pass custom options to LuaRocks when it is -building the package.

On lines 13-14, we specify the licensing terms for the package.

Finally, on line 16, we invoke the luarocks-package -macro that generates all the Makefile rules that actually allows the -package to be built.

Most of these details can be retrieved from the rock and rockspec. -So, this file and the Config.in file can be generated by running the -command luarocks buildroot foo lua-foo in the Buildroot -directory. This command runs a specific Buildroot addon of luarocks -that will automatically generate a Buildroot package. The result must -still be manually inspected and possibly modified.

  • -The package/Config.in file has to be updated manually to include the - generated Config.in files. -

18.9.2. luarocks-package reference

LuaRocks is a deployment and management system for Lua modules, and supports -various build.type: builtin, make and cmake. In the context of -Buildroot, the luarocks-package infrastructure only supports the builtin -mode. LuaRocks packages that use the make or cmake build mechanisms -should instead be packaged using the generic-package and cmake-package -infrastructures in Buildroot, respectively.

The main macro of the LuaRocks package infrastructure is luarocks-package: -like generic-package it works by defining a number of variables providing -metadata information about the package, and then calling luarocks-package.

Just like the generic infrastructure, the LuaRocks infrastructure works -by defining a number of variables before calling the luarocks-package -macro.

First, all the package metadata information variables that exist in -the generic infrastructure also exist in the LuaRocks infrastructure: -LUA_FOO_VERSION, LUA_FOO_SOURCE, LUA_FOO_SITE, -LUA_FOO_DEPENDENCIES, LUA_FOO_LICENSE, LUA_FOO_LICENSE_FILES.

Two of them are populated by the LuaRocks infrastructure (for the -download step). If your package is not hosted on the LuaRocks mirror -$(BR2_LUAROCKS_MIRROR), you can override them:

  • -LUA_FOO_SITE, which defaults to $(BR2_LUAROCKS_MIRROR) -
  • -LUA_FOO_SOURCE, which defaults to - $(lowercase LUA_FOO_NAME_UPSTREAM)-$(LUA_FOO_VERSION).src.rock -

A few additional variables, specific to the LuaRocks infrastructure, are -also defined. They can be overridden in specific cases.

  • -LUA_FOO_NAME_UPSTREAM, which defaults to lua-foo, i.e. the Buildroot - package name -
  • -LUA_FOO_ROCKSPEC, which defaults to - $(lowercase LUA_FOO_NAME_UPSTREAM)-$(LUA_FOO_VERSION).rockspec -
  • -LUA_FOO_SUBDIR, which defaults to - $(LUA_FOO_NAME_UPSTREAM)-$(LUA_FOO_VERSION_WITHOUT_ROCKSPEC_REVISION) -
  • -LUA_FOO_BUILD_OPTS contains additional build options for the - luarocks build call. -

18.10. Infrastructure for Perl/CPAN packages

18.10.1. perl-package tutorial

First, let’s see how to write a .mk file for a Perl/CPAN package, -with an example :

01: ################################################################################
-02: #
-03: # perl-foo-bar
-04: #
-05: ################################################################################
-06:
-07: PERL_FOO_BAR_VERSION = 0.02
-08: PERL_FOO_BAR_SOURCE = Foo-Bar-$(PERL_FOO_BAR_VERSION).tar.gz
-09: PERL_FOO_BAR_SITE = $(BR2_CPAN_MIRROR)/authors/id/M/MO/MONGER
-10: PERL_FOO_BAR_DEPENDENCIES = perl-strictures
-11: PERL_FOO_BAR_LICENSE = Artistic or GPL-1.0+
-12: PERL_FOO_BAR_LICENSE_FILES = LICENSE
-13: PERL_FOO_BAR_DISTNAME = Foo-Bar
-14:
-15: $(eval $(perl-package))

On line 7, we declare the version of the package.

On line 8 and 9, we declare the name of the tarball and the location -of the tarball on a CPAN server. Buildroot will automatically download -the tarball from this location.

On line 10, we declare our dependencies, so that they are built -before the build process of our package starts.

On line 11 and 12, we give licensing details about the package (its -license on line 11, and the file containing the license text on line -12).

On line 13, the name of the distribution as needed by the script -utils/scancpan (in order to regenerate/upgrade these package files).

Finally, on line 15, we invoke the perl-package macro that -generates all the Makefile rules that actually allow the package to be -built.

Most of these data can be retrieved from https://metacpan.org/. -So, this file and the Config.in can be generated by running -the script utils/scancpan Foo-Bar in the Buildroot directory -(or in a br2-external tree). -This script creates a Config.in file and foo-bar.mk file for the -requested package, and also recursively for all dependencies specified by -CPAN. You should still manually edit the result. In particular, the -following things should be checked.

  • -If the perl module links with a shared library that is provided by - another (non-perl) package, this dependency is not added automatically. - It has to be added manually to PERL_FOO_BAR_DEPENDENCIES. -
  • -The package/Config.in file has to be updated manually to include the - generated Config.in files. As a hint, the scancpan script prints out - the required source "…" statements, sorted alphabetically. -

18.10.2. perl-package reference

As a policy, packages that provide Perl/CPAN modules should all be -named perl-<something> in Buildroot.

This infrastructure handles various Perl build systems : -ExtUtils-MakeMaker (EUMM), Module-Build (MB) and Module-Build-Tiny. -Build.PL is preferred by default when a package provides a Makefile.PL -and a Build.PL.

The main macro of the Perl/CPAN package infrastructure is -perl-package. It is similar to the generic-package macro. The ability to -have target and host packages is also available, with the -host-perl-package macro.

Just like the generic infrastructure, the Perl/CPAN infrastructure -works by defining a number of variables before calling the -perl-package macro.

First, all the package metadata information variables that exist in the -generic infrastructure also exist in the Perl/CPAN infrastructure: -PERL_FOO_VERSION, PERL_FOO_SOURCE, -PERL_FOO_PATCH, PERL_FOO_SITE, -PERL_FOO_SUBDIR, PERL_FOO_DEPENDENCIES, -PERL_FOO_INSTALL_TARGET.

Note that setting PERL_FOO_INSTALL_STAGING to YES has no effect -unless a PERL_FOO_INSTALL_STAGING_CMDS variable is defined. The perl -infrastructure doesn’t define these commands since Perl modules generally -don’t need to be installed to the staging directory.

A few additional variables, specific to the Perl/CPAN infrastructure, -can also be defined. Many of them are only useful in very specific -cases, typical packages will therefore only use a few of them.

  • -PERL_FOO_PREFER_INSTALLER/HOST_PERL_FOO_PREFER_INSTALLER, - specifies the preferred installation method. Possible values are - EUMM (for Makefile.PL based installation using - ExtUtils-MakeMaker) and MB (for Build.PL based installation - using Module-Build). This variable is only used when the package - provides both installation methods. -
  • -PERL_FOO_CONF_ENV/HOST_PERL_FOO_CONF_ENV, to specify additional - environment variables to pass to the perl Makefile.PL or perl Build.PL. - By default, empty. -
  • -PERL_FOO_CONF_OPTS/HOST_PERL_FOO_CONF_OPTS, to specify additional - configure options to pass to the perl Makefile.PL or perl Build.PL. - By default, empty. -
  • -PERL_FOO_BUILD_OPTS/HOST_PERL_FOO_BUILD_OPTS, to specify additional - options to pass to make pure_all or perl Build build in the build step. - By default, empty. -
  • -PERL_FOO_INSTALL_TARGET_OPTS, to specify additional options to - pass to make pure_install or perl Build install in the install step. - By default, empty. -
  • -HOST_PERL_FOO_INSTALL_OPTS, to specify additional options to - pass to make pure_install or perl Build install in the install step. - By default, empty. -

18.11. Infrastructure for virtual packages

In Buildroot, a virtual package is a package whose functionalities are -provided by one or more packages, referred to as providers. The virtual -package management is an extensible mechanism allowing the user to choose -the provider used in the rootfs.

For example, OpenGL ES is an API for 2D and 3D graphics on embedded systems. -The implementation of this API is different for the Allwinner Tech Sunxi and -the Texas Instruments OMAP35xx platforms. So libgles will be a virtual -package and sunxi-mali and ti-gfx will be the providers.

18.11.1. virtual-package tutorial

In the following example, we will explain how to add a new virtual package -(something-virtual) and a provider for it (some-provider).

First, let’s create the virtual package.

18.11.2. Virtual package’s Config.in file

The Config.in file of virtual package something-virtual should contain:

01: config BR2_PACKAGE_HAS_SOMETHING_VIRTUAL
-02:     bool
-03:
-04: config BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL
-05:     depends on BR2_PACKAGE_HAS_SOMETHING_VIRTUAL
-06:     string

In this file, we declare two options, BR2_PACKAGE_HAS_SOMETHING_VIRTUAL and -BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL, whose values will be used by the -providers.

18.11.3. Virtual package’s .mk file

The .mk for the virtual package should just evaluate the virtual-package macro:

01: ################################################################################
-02: #
-03: # something-virtual
-04: #
-05: ################################################################################
-06:
-07: $(eval $(virtual-package))

The ability to have target and host packages is also available, with the -host-virtual-package macro.

18.11.4. Provider’s Config.in file

When adding a package as a provider, only the Config.in file requires some -modifications.

The Config.in file of the package some-provider, which provides the -functionalities of something-virtual, should contain:

01: config BR2_PACKAGE_SOME_PROVIDER
-02:     bool "some-provider"
-03:     select BR2_PACKAGE_HAS_SOMETHING_VIRTUAL
-04:     help
-05:       This is a comment that explains what some-provider is.
-06:
-07:       http://foosoftware.org/some-provider/
-08:
-09: if BR2_PACKAGE_SOME_PROVIDER
-10: config BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL
-11:     default "some-provider"
-12: endif

On line 3, we select BR2_PACKAGE_HAS_SOMETHING_VIRTUAL, and on line 11, we -set the value of BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL to the name of the -provider, but only if it is selected.

18.11.5. Provider’s .mk file

The .mk file should also declare an additional variable -SOME_PROVIDER_PROVIDES to contain the names of all the virtual -packages it is an implementation of:

01: SOME_PROVIDER_PROVIDES = something-virtual

Of course, do not forget to add the proper build and runtime dependencies for -this package!

18.11.6. Notes on depending on a virtual package

When adding a package that requires a certain FEATURE provided by a virtual -package, you have to use depends on BR2_PACKAGE_HAS_FEATURE, like so:

config BR2_PACKAGE_HAS_FEATURE
-    bool
-
-config BR2_PACKAGE_FOO
-    bool "foo"
-    depends on BR2_PACKAGE_HAS_FEATURE

18.11.7. Notes on depending on a specific provider

If your package really requires a specific provider, then you’ll have to -make your package depends on this provider; you can not select a -provider.

Let’s take an example with two providers for a FEATURE:

config BR2_PACKAGE_HAS_FEATURE
-    bool
-
-config BR2_PACKAGE_FOO
-    bool "foo"
-    select BR2_PACKAGE_HAS_FEATURE
-
-config BR2_PACKAGE_BAR
-    bool "bar"
-    select BR2_PACKAGE_HAS_FEATURE

And you are adding a package that needs FEATURE as provided by foo, -but not as provided by bar.

If you were to use select BR2_PACKAGE_FOO, then the user would still -be able to select BR2_PACKAGE_BAR in the menuconfig. This would create -a configuration inconsistency, whereby two providers of the same FEATURE -would be enabled at once, one explicitly set by the user, the other -implicitly by your select.

Instead, you have to use depends on BR2_PACKAGE_FOO, which avoids any -implicit configuration inconsistency.

18.12. Infrastructure for packages using kconfig for configuration files

A popular way for a software package to handle user-specified -configuration is kconfig. Among others, it is used by the Linux -kernel, Busybox, and Buildroot itself. The presence of a .config file -and a menuconfig target are two well-known symptoms of kconfig being -used.

Buildroot features an infrastructure for packages that use kconfig for -their configuration. This infrastructure provides the necessary logic to -expose the package’s menuconfig target as foo-menuconfig in -Buildroot, and to handle the copying back and forth of the configuration -file in a correct way.

The kconfig-package infrastructure is based on the generic-package -infrastructure. All variables supported by generic-package are -available in kconfig-package as well. See -Section 18.5.2, “generic-package reference” for more details.

In order to use the kconfig-package infrastructure for a Buildroot -package, the minimally required lines in the .mk file, in addition to -the variables required by the generic-package infrastructure, are:

FOO_KCONFIG_FILE = reference-to-source-configuration-file
-
-$(eval $(kconfig-package))

This snippet creates the following make targets:

  • -foo-menuconfig, which calls the package’s menuconfig target -
  • -foo-update-config, which copies the configuration back to the - source configuration file. It is not possible to use this target - when fragment files are set. -
  • -foo-update-defconfig, which copies the configuration back to the - source configuration file. The configuration file will only list the - options that differ from the default values. It is not possible to - use this target when fragment files are set. -
  • -foo-diff-config, which outputs the differences between the current - configuration and the one defined in the Buildroot configuration for - this kconfig package. The output is useful to identify the - configuration changes that may have to be propagated to - configuration fragments for example. -

and ensures that the source configuration file is copied to the build -directory at the right moment.

There are two options to specify a configuration file to use, either -FOO_KCONFIG_FILE (as in the example, above) or FOO_KCONFIG_DEFCONFIG. -It is mandatory to provide either, but not both:

  • -FOO_KCONFIG_FILE specifies the path to a defconfig or full-config file - to be used to configure the package. -
  • -FOO_KCONFIG_DEFCONFIG specifies the defconfig make rule to call to - configure the package. -

In addition to these minimally required lines, several optional variables can -be set to suit the needs of the package under consideration:

  • -FOO_KCONFIG_EDITORS: a space-separated list of kconfig editors to - support, for example menuconfig xconfig. By default, menuconfig. -
  • -FOO_KCONFIG_FRAGMENT_FILES: a space-separated list of configuration - fragment files that are merged to the main configuration file. - Fragment files are typically used when there is a desire to stay in sync - with an upstream (def)config file, with some minor modifications. -
  • -FOO_KCONFIG_OPTS: extra options to pass when calling the kconfig - editors. This may need to include $(FOO_MAKE_OPTS), for example. By - default, empty. -
  • -FOO_KCONFIG_FIXUP_CMDS: a list of shell commands needed to fixup the - configuration file after copying it or running a kconfig editor. Such - commands may be needed to ensure a configuration consistent with other - configuration of Buildroot, for example. By default, empty. -
  • -FOO_KCONFIG_DOTCONFIG: path (with filename) of the .config file, - relative to the package source tree. The default, .config, should - be well suited for all packages that use the standard kconfig - infrastructure as inherited from the Linux kernel; some packages use - a derivative of kconfig that use a different location. -
  • -FOO_KCONFIG_DEPENDENCIES: the list of packages (most probably, host - packages) that need to be built before this package’s kconfig is - interpreted. Seldom used. By default, empty. -
  • -FOO_KCONFIG_SUPPORTS_DEFCONFIG: whether the package’s kconfig system - supports using defconfig files; few packages do not. By default, YES. -

18.13. Infrastructure for rebar-based packages

18.13.1. rebar-package tutorial

First, let’s see how to write a .mk file for a rebar-based package, -with an example :

01: ################################################################################
-02: #
-03: # erlang-foobar
-04: #
-05: ################################################################################
-06:
-07: ERLANG_FOOBAR_VERSION = 1.0
-08: ERLANG_FOOBAR_SOURCE = erlang-foobar-$(ERLANG_FOOBAR_VERSION).tar.xz
-09: ERLANG_FOOBAR_SITE = http://www.foosoftware.org/download
-10: ERLANG_FOOBAR_DEPENDENCIES = host-libaaa libbbb
-11:
-12: $(eval $(rebar-package))

On line 7, we declare the version of the package.

On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location.

On line 10, we declare our dependencies, so that they are built -before the build process of our package starts.

Finally, on line 12, we invoke the rebar-package macro that -generates all the Makefile rules that actually allows the package to -be built.

18.13.2. rebar-package reference

The main macro of the rebar package infrastructure is -rebar-package. It is similar to the generic-package macro. The -ability to have host packages is also available, with the -host-rebar-package macro.

Just like the generic infrastructure, the rebar infrastructure works -by defining a number of variables before calling the rebar-package -macro.

First, all the package metadata information variables that exist in -the generic infrastructure also exist in the rebar infrastructure: -ERLANG_FOOBAR_VERSION, ERLANG_FOOBAR_SOURCE, -ERLANG_FOOBAR_PATCH, ERLANG_FOOBAR_SITE, -ERLANG_FOOBAR_SUBDIR, ERLANG_FOOBAR_DEPENDENCIES, -ERLANG_FOOBAR_INSTALL_STAGING, ERLANG_FOOBAR_INSTALL_TARGET, -ERLANG_FOOBAR_LICENSE and ERLANG_FOOBAR_LICENSE_FILES.

A few additional variables, specific to the rebar infrastructure, -can also be defined. Many of them are only useful in very specific -cases, typical packages will therefore only use a few of them.

  • -ERLANG_FOOBAR_USE_AUTOCONF, to specify that the package uses - autoconf at the configuration step. When a package sets this - variable to YES, the autotools infrastructure is used. -

    Note. You can also use some of the variables from the autotools - infrastructure: ERLANG_FOOBAR_CONF_ENV, ERLANG_FOOBAR_CONF_OPTS, - ERLANG_FOOBAR_AUTORECONF, ERLANG_FOOBAR_AUTORECONF_ENV and - ERLANG_FOOBAR_AUTORECONF_OPTS.

  • -ERLANG_FOOBAR_USE_BUNDLED_REBAR, to specify that the package has - a bundled version of rebar and that it shall be used. Valid - values are YES or NO (the default). -

    Note. If the package bundles a rebar utility, but can use the generic - one that Buildroot provides, just say NO (i.e., do not specify - this variable). Only set if it is mandatory to use the rebar - utility bundled in this package.

  • -ERLANG_FOOBAR_REBAR_ENV, to specify additional environment - variables to pass to the rebar utility. -
  • -ERLANG_FOOBAR_KEEP_DEPENDENCIES, to keep the dependencies - described in the rebar.config file. Valid values are YES or NO - (the default). Unless this variable is set to YES, the rebar - infrastructure removes such dependencies in a post-patch hook to - ensure rebar does not download nor compile them. -

With the rebar infrastructure, all the steps required to build -and install the packages are already defined, and they generally work -well for most rebar-based packages. However, when required, it is -still possible to customize what is done in any particular step:

  • -By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the various build steps” for details. -
  • -By overriding one of the steps. For example, even if the rebar - infrastructure is used, if the package .mk file defines its - own ERLANG_FOOBAR_BUILD_CMDS variable, it will be used instead - of the default rebar one. However, using this method should be - restricted to very specific cases. Do not use it in the general - case. -

18.14. Infrastructure for Waf-based packages

18.14.1. waf-package tutorial

First, let’s see how to write a .mk file for a Waf-based package, with -an example :

01: ################################################################################
-02: #
-03: # libfoo
-04: #
-05: ################################################################################
-06:
-07: LIBFOO_VERSION = 1.0
-08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz
-09: LIBFOO_SITE = http://www.foosoftware.org/download
-10: LIBFOO_CONF_OPTS = --enable-bar --disable-baz
-11: LIBFOO_DEPENDENCIES = bar
-12:
-13: $(eval $(waf-package))

On line 7, we declare the version of the package.

On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location.

On line 10, we tell Buildroot what options to enable for libfoo.

On line 11, we tell Buildroot the dependencies of libfoo.

Finally, on line line 13, we invoke the waf-package -macro that generates all the Makefile rules that actually allows the -package to be built.

18.14.2. waf-package reference

The main macro of the Waf package infrastructure is waf-package. -It is similar to the generic-package macro.

Just like the generic infrastructure, the Waf infrastructure works -by defining a number of variables before calling the waf-package -macro.

First, all the package metadata information variables that exist in -the generic infrastructure also exist in the Waf infrastructure: -LIBFOO_VERSION, LIBFOO_SOURCE, LIBFOO_PATCH, LIBFOO_SITE, -LIBFOO_SUBDIR, LIBFOO_DEPENDENCIES, LIBFOO_INSTALL_STAGING, -LIBFOO_INSTALL_TARGET.

An additional variable, specific to the Waf infrastructure, can -also be defined.

  • -LIBFOO_SUBDIR may contain the name of a subdirectory inside the - package that contains the main wscript file. This is useful, - if for example, the main wscript file is not at the root of - the tree extracted by the tarball. If HOST_LIBFOO_SUBDIR is not - specified, it defaults to LIBFOO_SUBDIR. -
  • -LIBFOO_NEEDS_EXTERNAL_WAF can be set to YES or NO to tell - Buildroot to use the bundled waf executable. If set to NO, the - default, then Buildroot will use the waf executable provided in the - package source tree; if set to YES, then Buildroot will download, - install waf as a host tool and use it to build the package. -
  • -LIBFOO_WAF_OPTS, to specify additional options to pass to the - waf script at every step of the package build process: configure, - build and installation. By default, empty. -
  • -LIBFOO_CONF_OPTS, to specify additional options to pass to the - waf script for the configuration step. By default, empty. -
  • -LIBFOO_BUILD_OPTS, to specify additional options to pass to the - waf script during the build step. By default, empty. -
  • -LIBFOO_INSTALL_STAGING_OPTS, to specify additional options to pass - to the waf script during the staging installation step. By default, - empty. -
  • -LIBFOO_INSTALL_TARGET_OPTS, to specify additional options to pass - to the waf script during the target installation step. By default, - empty. -

18.15. Infrastructure for Meson-based packages

18.15.1. meson-package tutorial

Meson is an open source build system meant to be both -extremely fast, and, even more importantly, as user friendly as possible. It -uses Ninja as a companion tool to perform the actual -build operations.

Let’s see how to write a .mk file for a Meson-based package, with an example:

01: ################################################################################
-02: #
-03: # foo
-04: #
-05: ################################################################################
-06:
-07: FOO_VERSION = 1.0
-08: FOO_SOURCE = foo-$(FOO_VERSION).tar.gz
-09: FOO_SITE = http://www.foosoftware.org/download
-10: FOO_LICENSE = GPL-3.0+
-11: FOO_LICENSE_FILES = COPYING
-12: FOO_INSTALL_STAGING = YES
-13:
-14: FOO_DEPENDENCIES = host-pkgconf bar
-15:
-16: ifeq ($(BR2_PACKAGE_BAZ),y)
-17: FOO_CONF_OPTS += -Dbaz=true
-18: FOO_DEPENDENCIES += baz
-19: else
-20: FOO_CONF_OPTS += -Dbaz=false
-21: endif
-22:
-23: $(eval $(meson-package))

The Makefile starts with the definition of the standard variables for package -declaration (lines 7 to 11).

On line line 23, we invoke the meson-package macro that generates all the -Makefile rules that actually allows the package to be built.

In the example, host-pkgconf and bar are declared as dependencies in -FOO_DEPENDENCIES at line 14 because the Meson build file of foo uses -pkg-config to determine the compilation flags and libraries of package bar.

Note that it is not necessary to add host-meson in the FOO_DEPENDENCIES -variable of a package, since this basic dependency is automatically added as -needed by the Meson package infrastructure.

If the "baz" package is selected, then support for the "baz" feature in "foo" is -activated by adding -Dbaz=true to FOO_CONF_OPTS at line 17, as specified in -the meson_options.txt file in "foo" source tree. The "baz" package is also -added to FOO_DEPENDENCIES. Note that the support for baz is explicitly -disabled at line 20, if the package is not selected.

To sum it up, to add a new meson-based package, the Makefile example can be -copied verbatim then edited to replace all occurences of FOO with the -uppercase name of the new package and update the values of the standard -variables.

18.15.2. meson-package reference

The main macro of the Meson package infrastructure is meson-package. It is -similar to the generic-package macro. The ability to have target and host -packages is also available, with the host-meson-package macro.

Just like the generic infrastructure, the Meson infrastructure works by defining -a number of variables before calling the meson-package macro.

First, all the package metadata information variables that exist in the generic -infrastructure also exist in the Meson infrastructure: FOO_VERSION, -FOO_SOURCE, FOO_PATCH, FOO_SITE, FOO_SUBDIR, FOO_DEPENDENCIES, -FOO_INSTALL_STAGING, FOO_INSTALL_TARGET.

A few additional variables, specific to the Meson infrastructure, can also be -defined. Many of them are only useful in very specific cases, typical packages -will therefore only use a few of them.

  • -FOO_SUBDIR may contain the name of a subdirectory inside the - package that contains the main meson.build file. This is useful, - if for example, the main meson.build file is not at the root of - the tree extracted by the tarball. If HOST_FOO_SUBDIR is not - specified, it defaults to FOO_SUBDIR. -
  • -FOO_CONF_ENV, to specify additional environment variables to pass to - meson for the configuration step. By default, empty. -
  • -FOO_CONF_OPTS, to specify additional options to pass to meson for the - configuration step. By default, empty. -
  • -FOO_CFLAGS, to specify compiler arguments added to the package specific - cross-compile.conf file c_args property. By default, the value of - TARGET_CFLAGS. -
  • -FOO_CXXFLAGS, to specify compiler arguments added to the package specific - cross-compile.conf file cpp_args property. By default, the value of - TARGET_CXXFLAGS. -
  • -FOO_LDFLAGS, to specify compiler arguments added to the package specific - cross-compile.conf file c_link_args and cpp_link_args properties. By - default, the value of TARGET_LDFLAGS. -
  • -FOO_MESON_EXTRA_BINARIES, to specify a space-separated list of programs - to add to the [binaries] section of the meson cross-compilation.conf - configuration file. The format is program-name='/path/to/program', with - no space around the = sign, and with the path of the program between - single quotes. By default, empty. Note that Buildroot already sets the - correct values for c, cpp, ar, strip, and pkgconfig. -
  • -FOO_MESON_EXTRA_PROPERTIES, to specify a space-separated list of - properties to add to the [properties] section of the meson - cross-compilation.conf configuration file. The format is - property-name=<value> with no space around the = sign, and with - single quotes around string values. By default, empty. Note that - Buildroot already sets values for needs_exe_wrapper, c_args, - c_link_args, cpp_args, cpp_link_args, sys_root, and - pkg_config_libdir. -
  • -FOO_NINJA_ENV, to specify additional environment variables to pass to - ninja, meson companion tool in charge of the build operations. By default, - empty. -
  • -FOO_NINJA_OPTS, to specify a space-separated list of targets to build. By - default, empty, to build the default target(s). -

18.16. Integration of Cargo-based packages

Cargo is the package manager for the Rust programming language. It allows the -user to build programs or libraries written in Rust, but it also downloads and -manages their dependencies, to ensure repeatable builds. Cargo packages are -called "crates".

18.16.1. Cargo-based package’s Config.in file

The Config.in file of Cargo-based package foo should contain:

01: config BR2_PACKAGE_FOO
-02:     bool "foo"
-03:     depends on BR2_PACKAGE_HOST_RUSTC_TARGET_ARCH_SUPPORTS
-04:     select BR2_PACKAGE_HOST_RUSTC
-05:     help
-06:       This is a comment that explains what foo is.
-07:
-08:       http://foosoftware.org/foo/

18.16.2. Cargo-based package’s .mk file

Buildroot does not (yet) provide a dedicated package infrastructure for -Cargo-based packages. So, we will explain how to write a .mk file for such a -package. Let’s start with an example:

01: ################################################################################
-02: #
-03: # foo
-04: #
-05: ################################################################################
-06:
-07: FOO_VERSION = 1.0
-08: FOO_SOURCE = foo-$(FOO_VERSION).tar.gz
-09: FOO_SITE = http://www.foosoftware.org/download
-10: FOO_LICENSE = GPL-3.0+
-11: FOO_LICENSE_FILES = COPYING
-12:
-13: FOO_DEPENDENCIES = host-rustc
-14:
-15: FOO_CARGO_ENV = CARGO_HOME=$(HOST_DIR)/share/cargo
-16:
-17: FOO_BIN_DIR = target/$(RUSTC_TARGET_NAME)/$(FOO_CARGO_MODE)
-18:
-19: FOO_CARGO_OPTS = \
-20:     $(if $(BR2_ENABLE_DEBUG),,--release) \
-21:     --target=$(RUSTC_TARGET_NAME) \
-22:     --manifest-path=$(@D)/Cargo.toml
-23:
-24: define FOO_BUILD_CMDS
-25:     $(TARGET_MAKE_ENV) $(FOO_CARGO_ENV) \
-26:             cargo build $(FOO_CARGO_OPTS)
-27: endef
-28:
-29: define FOO_INSTALL_TARGET_CMDS
-30:     $(INSTALL) -D -m 0755 $(@D)/$(FOO_BIN_DIR)/foo \
-31:             $(TARGET_DIR)/usr/bin/foo
-32: endef
-33:
-34: $(eval $(generic-package))

The Makefile starts with the definition of the standard variables for package -declaration (lines 7 to 11).

As seen in line 34, it is based on the -generic-package infrastructure. So, it defines -the variables required by this particular infrastructure, where Cargo is -invoked:

  • -FOO_BUILD_CMDS: Cargo is invoked to perform the build. The options required - to configure the cross-compilation of the package are passed via - FOO_CONF_OPTS. -
  • -FOO_INSTALL_TARGET_CMDS: The binary executable generated is installed on - the target. -

In order to have Cargo available for the build, FOO_DEPENDENCIES needs to -contain host-cargo.

To sum it up, to add a new Cargo-based package, the Makefile example can be -copied verbatim then edited to replace all occurences of FOO with the -uppercase name of the new package and update the values of the standard -variables.

18.16.3. About Dependencies Management

A crate can depend on other libraries from crates.io or git repositories, listed -in its Cargo.toml file. Before starting a build, Cargo usually downloads -automatically them. This step can also be performed independently, via the -cargo fetch command.

Cargo maintains a local cache of the registry index and of git checkouts of the -crates, whose location is given by $CARGO_HOME. As seen in the package -Makefile example at line 15, this environment variable is set to -$(HOST_DIR)/share/cargo.

This dependency download mechanism is not convenient when performing an offline -build, as Cargo will fail to fetch the dependencies. In that case, it is advised -to generate a tarball of the dependencies using the cargo vendor and add it to -FOO_EXTRA_DOWNLOADS.

18.17. Infrastructure for Go packages

This infrastructure applies to Go packages that use the standard -build system and use bundled dependencies.

18.17.1. golang-package tutorial

First, let’s see how to write a .mk file for a go package, -with an example :

01: ################################################################################
-02: #
-03: # foo
-04: #
-05: ################################################################################
-06:
-07: FOO_VERSION = 1.0
-08: FOO_SITE = $(call github,bar,foo,$(FOO_VERSION))
-09: FOO_LICENSE = BSD-3-Clause
-10: FOO_LICENSE_FILES = LICENSE
-11:
-12: $(eval $(golang-package))

On line 7, we declare the version of the package.

On line 8, we declare the upstream location of the package, here -fetched from Github, since a large number of Go packages are hosted on -Github.

On line 9 and 10, we give licensing details about the package.

Finally, on line 12, we invoke the golang-package macro that -generates all the Makefile rules that actually allow the package to be -built.

18.17.2. golang-package reference

In their Config.in file, packages using the golang-package -infrastructure should depend on BR2_PACKAGE_HOST_GO_TARGET_ARCH_SUPPORTS -because Buildroot will automatically add a dependency on host-go -to such packages. -If you need CGO support in your package, you must add a dependency on -BR2_PACKAGE_HOST_GO_TARGET_CGO_LINKING_SUPPORTS.

The main macro of the Go package infrastructure is -golang-package. It is similar to the generic-package macro. The -ability to build host packages is also available, with the -host-golang-package macro. -Host packages built by host-golang-package macro should depend on -BR2_PACKAGE_HOST_GO_HOST_ARCH_SUPPORTS.

Just like the generic infrastructure, the Go infrastructure works -by defining a number of variables before calling the golang-package.

All the package metadata information variables that exist in the -generic package infrastructure also -exist in the Go infrastructure: FOO_VERSION, FOO_SOURCE, -FOO_PATCH, FOO_SITE, FOO_SUBDIR, FOO_DEPENDENCIES, -FOO_LICENSE, FOO_LICENSE_FILES, FOO_INSTALL_STAGING, etc.

Note that it is not necessary to add host-go in the -FOO_DEPENDENCIES variable of a package, since this basic dependency -is automatically added as needed by the Go package infrastructure.

A few additional variables, specific to the Go infrastructure, can -optionally be defined, depending on the package’s needs. Many of them -are only useful in very specific cases, typical packages will -therefore only use a few of them, or none.

  • -The package must specify its Go module name in the FOO_GOMOD - variable. If not specified, it defaults to - URL-domain/1st-part-of-URL/2nd-part-of-URL, e.g FOO_GOMOD will - take the value github.com/bar/foo for a package that specifies - FOO_SITE = $(call github,bar,foo,$(FOO_VERSION)). The Go package - infrastructure will automatically generate a minimal go.mod file - in the package source tree if it doesn’t exist. -
  • -FOO_LDFLAGS and FOO_TAGS can be used to pass respectively the - LDFLAGS or the TAGS to the go build command. -
  • -FOO_BUILD_TARGETS can be used to pass the list of targets that - should be built. If FOO_BUILD_TARGETS is not specified, it - defaults to .. We then have two cases: -

    • -FOO_BUILD_TARGETS is .. In this case, we assume only one binary - will be produced, and that by default we name it after the package - name. If that is not appropriate, the name of the produced binary - can be overridden using FOO_BIN_NAME. -
    • -FOO_BUILD_TARGETS is not .. In this case, we iterate over the - values to build each target, and for each produced a binary that is - the non-directory component of the target. For example if - FOO_BUILD_TARGETS = cmd/docker cmd/dockerd the binaries produced - are docker and dockerd. -
  • -FOO_INSTALL_BINS can be used to pass the list of binaries that - should be installed in /usr/bin on the target. If - FOO_INSTALL_BINS is not specified, it defaults to the lower-case - name of package. -

With the Go infrastructure, all the steps required to build and -install the packages are already defined, and they generally work well -for most Go-based packages. However, when required, it is still -possible to customize what is done in any particular step:

  • -By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the various build steps” for details. -
  • -By overriding one of the steps. For example, even if the Go - infrastructure is used, if the package .mk file defines its own - FOO_BUILD_CMDS variable, it will be used instead of the default Go - one. However, using this method should be restricted to very - specific cases. Do not use it in the general case. -

18.18. Infrastructure for QMake-based packages

18.18.1. qmake-package tutorial

First, let’s see how to write a .mk file for a QMake-based package, with -an example :

01: ################################################################################
-02: #
-03: # libfoo
-04: #
-05: ################################################################################
-06:
-07: LIBFOO_VERSION = 1.0
-08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz
-09: LIBFOO_SITE = http://www.foosoftware.org/download
-10: LIBFOO_CONF_OPTS = QT_CONFIG+=bar QT_CONFIG-=baz
-11: LIBFOO_DEPENDENCIES = bar
-12:
-13: $(eval $(qmake-package))

On line 7, we declare the version of the package.

On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location.

On line 10, we tell Buildroot what options to enable for libfoo.

On line 11, we tell Buildroot the dependencies of libfoo.

Finally, on line line 13, we invoke the qmake-package -macro that generates all the Makefile rules that actually allows the -package to be built.

18.18.2. qmake-package reference

The main macro of the QMake package infrastructure is qmake-package. -It is similar to the generic-package macro.

Just like the generic infrastructure, the QMake infrastructure works -by defining a number of variables before calling the qmake-package -macro.

First, all the package metadata information variables that exist in -the generic infrastructure also exist in the QMake infrastructure: -LIBFOO_VERSION, LIBFOO_SOURCE, LIBFOO_PATCH, LIBFOO_SITE, -LIBFOO_SUBDIR, LIBFOO_DEPENDENCIES, LIBFOO_INSTALL_STAGING, -LIBFOO_INSTALL_TARGET.

An additional variable, specific to the QMake infrastructure, can -also be defined.

  • -LIBFOO_CONF_ENV, to specify additional environment variables to - pass to the qmake script for the configuration step. By default, empty. -
  • -LIBFOO_CONF_OPTS, to specify additional options to pass to the - qmake script for the configuration step. By default, empty. -
  • -LIBFOO_MAKE_ENV, to specify additional environment variables to the - make command during the build and install steps. By default, empty. -
  • -LIBFOO_MAKE_OPTS, to specify additional targets to pass to the - make command during the build step. By default, empty. -
  • -LIBFOO_INSTALL_STAGING_OPTS, to specify additional targets to pass - to the make command during the staging installation step. By default, - install. -
  • -LIBFOO_INSTALL_TARGET_OPTS, to specify additional targets to pass - to the make command during the target installation step. By default, - install. -
  • -LIBFOO_SYNC_QT_HEADERS, to run syncqt.pl before qmake. Some packages - need this to have a properly populated include directory before - running the build. -

18.19. Infrastructure for packages building kernel modules

Buildroot offers a helper infrastructure to make it easy to write packages that -build and install Linux kernel modules. Some packages only contain a kernel -module, other packages contain programs and libraries in addition to kernel -modules. Buildroot’s helper infrastructure supports either case.

18.19.1. kernel-module tutorial

Let’s start with an example on how to prepare a simple package that only -builds a kernel module, and no other component:

01: ################################################################################
-02: #
-03: # foo
-04: #
-05: ################################################################################
-06:
-07: FOO_VERSION = 1.2.3
-08: FOO_SOURCE = foo-$(FOO_VERSION).tar.xz
-09: FOO_SITE = http://www.foosoftware.org/download
-10: FOO_LICENSE = GPL-2.0
-11: FOO_LICENSE_FILES = COPYING
-12:
-13: $(eval $(kernel-module))
-14: $(eval $(generic-package))

Lines 7-11 define the usual meta-data to specify the version, archive name, -remote URI where to find the package source, licensing information.

On line 13, we invoke the kernel-module helper infrastructure, that -generates all the appropriate Makefile rules and variables to build -that kernel module.

Finally, on line 14, we invoke the -generic-package infrastructure.

The dependency on linux is automatically added, so it is not needed to -specify it in FOO_DEPENDENCIES.

What you may have noticed is that, unlike other package infrastructures, -we explicitly invoke a second infrastructure. This allows a package to -build a kernel module, but also, if needed, use any one of other package -infrastructures to build normal userland components (libraries, -executables…). Using the kernel-module infrastructure on its own is -not sufficient; another package infrastructure must be used.

Let’s look at a more complex example:

01: ################################################################################
-02: #
-03: # foo
-04: #
-05: ################################################################################
-06:
-07: FOO_VERSION = 1.2.3
-08: FOO_SOURCE = foo-$(FOO_VERSION).tar.xz
-09: FOO_SITE = http://www.foosoftware.org/download
-10: FOO_LICENSE = GPL-2.0
-11: FOO_LICENSE_FILES = COPYING
-12:
-13: FOO_MODULE_SUBDIRS = driver/base
-14: FOO_MODULE_MAKE_OPTS = KVERSION=$(LINUX_VERSION_PROBED)
-15:
-16: ifeq ($(BR2_PACKAGE_LIBBAR),y)
-17: FOO_DEPENDENCIES = libbar
-18: FOO_CONF_OPTS = --enable-bar
-19: FOO_MODULE_SUBDIRS += driver/bar
-20: else
-21: FOO_CONF_OPTS = --disable-bar
-22: endif
-23:
-24: $(eval $(kernel-module))
-26: $(eval $(autotools-package))

Here, we see that we have an autotools-based package, that also builds -the kernel module located in sub-directory driver/base and, if libbar -is enabled, the kernel module located in sub-directory driver/bar, and -defines the variable KVERSION to be passed to the Linux buildsystem -when building the module(s).

18.19.2. kernel-module reference

The main macro for the kernel module infrastructure is kernel-module. -Unlike other package infrastructures, it is not stand-alone, and requires -any of the other *-package macros be called after it.

The kernel-module macro defines post-build and post-target-install -hooks to build the kernel modules. If the package’s .mk needs access -to the built kernel modules, it should do so in a post-build hook, -registered after the call to kernel-module. Similarly, if the -package’s .mk needs access to the kernel module after it has been -installed, it should do so in a post-install hook, registered after -the call to kernel-module. Here’s an example:

$(eval $(kernel-module))
-
-define FOO_DO_STUFF_WITH_KERNEL_MODULE
-    # Do something with it...
-endef
-FOO_POST_BUILD_HOOKS += FOO_DO_STUFF_WITH_KERNEL_MODULE
-
-$(eval $(generic-package))

Finally, unlike the other package infrastructures, there is no -host-kernel-module variant to build a host kernel module.

The following additional variables can optionally be defined to further -configure the build of the kernel module:

  • -FOO_MODULE_SUBDIRS may be set to one or more sub-directories (relative - to the package source top-directory) where the kernel module sources are. - If empty or not set, the sources for the kernel module(s) are considered - to be located at the top of the package source tree. -
  • -FOO_MODULE_MAKE_OPTS may be set to contain extra variable definitions - to pass to the Linux buildsystem. -

You may also reference (but you may not set!) those variables:

  • -LINUX_DIR contains the path to where the Linux kernel has been - extracted and built. -
  • -LINUX_VERSION contains the version string as configured by the user. -
  • -LINUX_VERSION_PROBED contains the real version string of the kernel, - retrieved with running make -C $(LINUX_DIR) kernelrelease -
  • -KERNEL_ARCH contains the name of the current architecture, like arm, - mips… -

18.20. Infrastructure for asciidoc documents

The Buildroot manual, which you are currently reading, is entirely written -using the AsciiDoc mark-up syntax. The manual is then -rendered to many formats:

  • -html -
  • -split-html -
  • -pdf -
  • -epub -
  • -text -

Although Buildroot only contains one document written in AsciiDoc, there -is, as for packages, an infrastructure for rendering documents using the -AsciiDoc syntax.

Also as for packages, the AsciiDoc infrastructure is available from a -br2-external tree. This allows documentation for -a br2-external tree to match the Buildroot documentation, as it will be -rendered to the same formats and use the same layout and theme.

18.20.1. asciidoc-document tutorial

Whereas package infrastructures are suffixed with -package, the document -infrastructures are suffixed with -document. So, the AsciiDoc infrastructure -is named asciidoc-document.

Here is an example to render a simple AsciiDoc document.

01: ################################################################################
-02: #
-03: # foo-document
-04: #
-05: ################################################################################
-06:
-07: FOO_SOURCES = $(sort $(wildcard $(pkgdir)/*))
-08: $(eval $(call asciidoc-document))

On line 7, the Makefile declares what the sources of the document are. -Currently, it is expected that the document’s sources are only local; -Buildroot will not attempt to download anything to render a document. -Thus, you must indicate where the sources are. Usually, the string -above is sufficient for a document with no sub-directory structure.

On line 8, we call the asciidoc-document function, which generates all -the Makefile code necessary to render the document.

18.20.2. asciidoc-document reference

The list of variables that can be set in a .mk file to give metadata -information is (assuming the document name is foo) :

  • -FOO_SOURCES, mandatory, defines the source files for the document. -
  • -FOO_RESOURCES, optional, may contain a space-separated list of paths - to one or more directories containing so-called resources (like CSS or - images). By default, empty. -
  • -FOO_DEPENDENCIES, optional, the list of packages (most probably, - host-packages) that must be built before building this document. -

There are also additional hooks (see Section 18.22, “Hooks available in the various build steps” for general information -on hooks), that a document may set to define extra actions to be done at -various steps:

  • -FOO_POST_RSYNC_HOOKS to run additional commands after the sources - have been copied by Buildroot. This can for example be used to - generate part of the manual with information extracted from the - tree. As an example, Buildroot uses this hook to generate the tables - in the appendices. -
  • -FOO_CHECK_DEPENDENCIES_HOOKS to run additional tests on required - components to generate the document. In AsciiDoc, it is possible to - call filters, that is, programs that will parse an AsciiDoc block and - render it appropriately (e.g. ditaa or - aafigure). -
  • -FOO_CHECK_DEPENDENCIES_<FMT>_HOOKS, to run additional tests for - the specified format <FMT> (see the list of rendered formats, above). -

Here is a complete example that uses all variables and all hooks:

01: ################################################################################
-02: #
-03: # foo-document
-04: #
-05: ################################################################################
-06:
-07: FOO_SOURCES = $(sort $(wildcard $(pkgdir)/*))
-08: FOO_RESOURCES = $(sort $(wildcard $(pkgdir)/ressources))
-09:
-10: define FOO_GEN_EXTRA_DOC
-11:     /path/to/generate-script --outdir=$(@D)
-12: endef
-13: FOO_POST_RSYNC_HOOKS += FOO_GEN_EXTRA_DOC
-14:
-15: define FOO_CHECK_MY_PROG
-16:     if ! which my-prog >/dev/null 2>&1; then \
-17:         echo "You need my-prog to generate the foo document"; \
-18:         exit 1; \
-19:     fi
-20: endef
-21: FOO_CHECK_DEPENDENCIES_HOOKS += FOO_CHECK_MY_PROG
-22:
-23: define FOO_CHECK_MY_OTHER_PROG
-24:     if ! which my-other-prog >/dev/null 2>&1; then \
-25:         echo "You need my-other-prog to generate the foo document as PDF"; \
-26:         exit 1; \
-27:     fi
-28: endef
-29: FOO_CHECK_DEPENDENCIES_PDF_HOOKS += FOO_CHECK_MY_OTHER_PROG
-30:
-31: $(eval $(call asciidoc-document))

18.21. Infrastructure specific to the Linux kernel package

The Linux kernel package can use some specific infrastructures based on package -hooks for building Linux kernel tools or/and building Linux kernel extensions.

18.21.1. linux-kernel-tools

Buildroot offers a helper infrastructure to build some userspace tools -for the target available within the Linux kernel sources. Since their -source code is part of the kernel source code, a special package, -linux-tools, exists and re-uses the sources of the Linux kernel that -runs on the target.

Let’s look at an example of a Linux tool. For a new Linux tool named -foo, create a new menu entry in the existing -package/linux-tools/Config.in. This file will contain the option -descriptions related to each kernel tool that will be used and -displayed in the configuration tool. It would basically look like:

01: config BR2_PACKAGE_LINUX_TOOLS_FOO
-02:     bool "foo"
-03:     select BR2_PACKAGE_LINUX_TOOLS
-04:     help
-05:       This is a comment that explains what foo kernel tool is.
-06:
-07:       http://foosoftware.org/foo/

The name of the option starts with the prefix BR2_PACKAGE_LINUX_TOOLS_, -followed by the uppercase name of the tool (like is done for packages).

Note. Unlike other packages, the linux-tools package options appear in the -linux kernel menu, under the Linux Kernel Tools sub-menu, not under -the Target packages main menu.

Then for each linux tool, add a new .mk.in file named -package/linux-tools/linux-tool-foo.mk.in. It would basically look like:

01: ################################################################################
-02: #
-03: # foo
-04: #
-05: ################################################################################
-06:
-07: LINUX_TOOLS += foo
-08:
-09: FOO_DEPENDENCIES = libbbb
-10:
-11: define FOO_BUILD_CMDS
-12:     $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools foo
-13: endef
-14:
-15: define FOO_INSTALL_STAGING_CMDS
-16:     $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools \
-17:             DESTDIR=$(STAGING_DIR) \
-18:             foo_install
-19: endef
-20:
-21: define FOO_INSTALL_TARGET_CMDS
-22:     $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools \
-23:             DESTDIR=$(TARGET_DIR) \
-24:             foo_install
-25: endef

On line 7, we register the Linux tool foo to the list of available -Linux tools.

On line 9, we specify the list of dependencies this tool relies on. These -dependencies are added to the Linux package dependencies list only when the -foo tool is selected.

The rest of the Makefile, lines 11-25 defines what should be done at the -different steps of the Linux tool build process like for a -generic package. They will actually be -used only when the foo tool is selected. The only supported commands are -_BUILD_CMDS, _INSTALL_STAGING_CMDS and _INSTALL_TARGET_CMDS.

Note. One must not call $(eval $(generic-package)) or any other -package infrastructure! Linux tools are not packages by themselves, -they are part of the linux-tools package.

18.21.2. linux-kernel-extensions

Some packages provide new features that require the Linux kernel tree -to be modified. This can be in the form of patches to be applied on -the kernel tree, or in the form of new files to be added to the -tree. The Buildroot’s Linux kernel extensions infrastructure provides -a simple solution to automatically do this, just after the kernel -sources are extracted and before the kernel patches are -applied. Examples of extensions packaged using this mechanism are the -real-time extensions Xenomai and RTAI, as well as the set of -out-of-tree LCD screens drivers fbtft.

Let’s look at an example on how to add a new Linux extension foo.

First, create the package foo that provides the extension: this -package is a standard package; see the previous chapters on how to -create such a package. This package is in charge of downloading the -sources archive, checking the hash, defining the licence informations -and building user space tools if any.

Then create the Linux extension proper: create a new menu entry in -the existing linux/Config.ext.in. This file contains the option -descriptions related to each kernel extension that will be used and -displayed in the configuration tool. It would basically look like:

01: config BR2_LINUX_KERNEL_EXT_FOO
-02:     bool "foo"
-03:     help
-04:       This is a comment that explains what foo kernel extension is.
-05:
-06:       http://foosoftware.org/foo/

Then for each linux extension, add a new .mk file named -linux/linux-ext-foo.mk. It should basically contain:

01: ################################################################################
-02: #
-03: # foo
-04: #
-05: ################################################################################
-06:
-07: LINUX_EXTENSIONS += foo
-08:
-09: define FOO_PREPARE_KERNEL
-10:     $(FOO_DIR)/prepare-kernel-tree.sh --linux-dir=$(@D)
-11: endef

On line 7, we add the Linux extension foo to the list of available -Linux extensions.

On line 9-11, we define what should be done by the extension to modify -the Linux kernel tree; this is specific to the linux extension and can -use the variables defined by the foo package, like: $(FOO_DIR) or -$(FOO_VERSION)… as well as all the Linux variables, like: -$(LINUX_VERSION) or $(LINUX_VERSION_PROBED), $(KERNEL_ARCH)… -See the definition of those kernel variables.

18.22. Hooks available in the various build steps

The generic infrastructure (and as a result also the derived autotools -and cmake infrastructures) allow packages to specify hooks. -These define further actions to perform after existing steps. -Most hooks aren’t really useful for generic packages, since the .mk -file already has full control over the actions performed in each step -of the package construction.

The following hook points are available:

  • -LIBFOO_PRE_DOWNLOAD_HOOKS -
  • -LIBFOO_POST_DOWNLOAD_HOOKS -
  • -LIBFOO_PRE_EXTRACT_HOOKS -
  • -LIBFOO_POST_EXTRACT_HOOKS -
  • -LIBFOO_PRE_RSYNC_HOOKS -
  • -LIBFOO_POST_RSYNC_HOOKS -
  • -LIBFOO_PRE_PATCH_HOOKS -
  • -LIBFOO_POST_PATCH_HOOKS -
  • -LIBFOO_PRE_CONFIGURE_HOOKS -
  • -LIBFOO_POST_CONFIGURE_HOOKS -
  • -LIBFOO_PRE_BUILD_HOOKS -
  • -LIBFOO_POST_BUILD_HOOKS -
  • -LIBFOO_PRE_INSTALL_HOOKS (for host packages only) -
  • -LIBFOO_POST_INSTALL_HOOKS (for host packages only) -
  • -LIBFOO_PRE_INSTALL_STAGING_HOOKS (for target packages only) -
  • -LIBFOO_POST_INSTALL_STAGING_HOOKS (for target packages only) -
  • -LIBFOO_PRE_INSTALL_TARGET_HOOKS (for target packages only) -
  • -LIBFOO_POST_INSTALL_TARGET_HOOKS (for target packages only) -
  • -LIBFOO_PRE_INSTALL_IMAGES_HOOKS -
  • -LIBFOO_POST_INSTALL_IMAGES_HOOKS -
  • -LIBFOO_PRE_LEGAL_INFO_HOOKS -
  • -LIBFOO_POST_LEGAL_INFO_HOOKS -

These variables are lists of variable names containing actions to be -performed at this hook point. This allows several hooks to be -registered at a given hook point. Here is an example:

define LIBFOO_POST_PATCH_FIXUP
-        action1
-        action2
-endef
-
-LIBFOO_POST_PATCH_HOOKS += LIBFOO_POST_PATCH_FIXUP

18.22.1. Using the POST_RSYNC hook

The POST_RSYNC hook is run only for packages that use a local source, -either through the local site method or the OVERRIDE_SRCDIR -mechanism. In this case, package sources are copied using rsync from -the local location into the buildroot build directory. The rsync -command does not copy all files from the source directory, though. -Files belonging to a version control system, like the directories -.git, .hg, etc. are not copied. For most packages this is -sufficient, but a given package can perform additional actions using -the POST_RSYNC hook.

In principle, the hook can contain any command you want. One specific -use case, though, is the intentional copying of the version control -directory using rsync. The rsync command you use in the hook can, among -others, use the following variables:

  • -$(SRCDIR): the path to the overridden source directory -
  • -$(@D): the path to the build directory -

18.22.2. Target-finalize hook

Packages may also register hooks in LIBFOO_TARGET_FINALIZE_HOOKS. -These hooks are run after all packages are built, but before the -filesystem images are generated. They are seldom used, and your -package probably do not need them.

18.23. Gettext integration and interaction with packages

Many packages that support internationalization use the gettext -library. Dependencies for this library are fairly complicated and -therefore, deserve some explanation.

The glibc C library integrates a full-blown implementation of -gettext, supporting translation. Native Language Support is -therefore built-in in glibc.

On the other hand, the uClibc and musl C libraries only provide a -stub implementation of the gettext functionality, which allows to -compile libraries and programs using gettext functions, but without -providing the translation capabilities of a full-blown gettext -implementation. With such C libraries, if real Native Language Support -is necessary, it can be provided by the libintl library of the -gettext package.

Due to this, and in order to make sure that Native Language Support is -properly handled, packages in Buildroot that can use NLS support -should:

  1. -Ensure NLS support is enabled when BR2_SYSTEM_ENABLE_NLS=y. This - is done automatically for autotools packages and therefore should - only be done for packages using other package infrastructures. -
  2. -Add $(TARGET_NLS_DEPENDENCIES) to the package - <pkg>_DEPENDENCIES variable. This addition should be done - unconditionally: the value of this variable is automatically - adjusted by the core infrastructure to contain the relevant list of - packages. If NLS support is disabled, this variable is empty. If - NLS support is enabled, this variable contains host-gettext so - that tools needed to compile translation files are available on the - host. In addition, if uClibc or musl are used, this variable - also contains gettext in order to get the full-blown gettext - implementation. -
  3. -If needed, add $(TARGET_NLS_LIBS) to the linker flags, so that - the package gets linked with libintl. This is generally not - needed with autotools packages as they usually detect - automatically that they should link with libintl. However, - packages using other build systems, or problematic autotools-based - packages may need this. $(TARGET_NLS_LIBS) should be added - unconditionally to the linker flags, as the core automatically - makes it empty or defined to -lintl depending on the - configuration. -

No changes should be made to the Config.in file to support NLS.

Finally, certain packages need some gettext utilities on the target, -such as the gettext program itself, which allows to retrieve -translated strings, from the command line. In such a case, the package -should:

  • -use select BR2_PACKAGE_GETTEXT in their Config.in file, - indicating in a comment above that it’s a runtime dependency only. -
  • -not add any gettext dependency in the DEPENDENCIES variable of - their .mk file. -

18.24. Tips and tricks

18.24.1. Package name, config entry name and makefile variable relationship

In Buildroot, there is some relationship between:

  • -the package name, which is the package directory name (and the - name of the *.mk file); -
  • -the config entry name that is declared in the Config.in file; -
  • -the makefile variable prefix. -

It is mandatory to maintain consistency between these elements, -using the following rules:

  • -the package directory and the *.mk name are the package name - itself (e.g.: package/foo-bar_boo/foo-bar_boo.mk); -
  • -the make target name is the package name itself (e.g.: - foo-bar_boo); -
  • -the config entry is the upper case package name with . and - - characters substituted with _, prefixed with BR2_PACKAGE_ (e.g.: - BR2_PACKAGE_FOO_BAR_BOO); -
  • -the *.mk file variable prefix is the upper case package name - with . and - characters substituted with _ (e.g.: - FOO_BAR_BOO_VERSION). -

18.24.2. How to check the coding style

Buildroot provides a script in utils/check-package that checks new or -changed files for coding style. It is not a complete language validator, -but it catches many common mistakes. It is meant to run in the actual -files you created or modified, before creating the patch for submission.

This script can be used for packages, filesystem makefiles, Config.in -files, etc. It does not check the files defining the package -infrastructures and some other files containing similar common code.

To use it, run the check-package script, by telling which files you -created or changed:

$ ./utils/check-package package/new-package/*

If you have the utils directory in your path you can also run:

$ cd package/new-package/
-$ check-package *

The tool can also be used for packages in a br2-external:

$ check-package -b /path/to/br2-ext-tree/package/my-package/*

18.24.3. How to test your package

Once you have added your new package, it is important that you test it -under various conditions: does it build for all architectures? Does it -build with the different C libraries? Does it need threads, NPTL? And -so on…

Buildroot runs autobuilders which -continuously test random configurations. However, these only build the -master branch of the git tree, and your new fancy package is not yet -there.

Buildroot provides a script in utils/test-pkg that uses the same base -configurations as used by the autobuilders so you can test your package -in the same conditions.

First, create a config snippet that contains all the necessary options -needed to enable your package, but without any architecture or toolchain -option. For example, let’s create a config snippet that just enables -libcurl, without any TLS backend:

$ cat libcurl.config
-BR2_PACKAGE_LIBCURL=y

If your package needs more configuration options, you can add them to the -config snippet. For example, here’s how you would test libcurl with -openssl as a TLS backend and the curl program:

$ cat libcurl.config
-BR2_PACKAGE_LIBCURL=y
-BR2_PACKAGE_LIBCURL_CURL=y
-BR2_PACKAGE_OPENSSL=y

Then run the test-pkg script, by telling it what config snippet to use -and what package to test:

$ ./utils/test-pkg -c libcurl.config -p libcurl

By default, test-pkg will build your package against a subset of the -toolchains used by the autobuilders, which has been selected by the -Buildroot developers as being the most useful and representative -subset. If you want to test all toolchains, pass the -a option. Note -that in any case, internal toolchains are excluded as they take too -long to build.

The output lists all toolchains that are tested and the corresponding -result (excerpt, results are fake):

$ ./utils/test-pkg -c libcurl.config -p libcurl
-                armv5-ctng-linux-gnueabi [ 1/11]: OK
-              armv7-ctng-linux-gnueabihf [ 2/11]: OK
-                        br-aarch64-glibc [ 3/11]: SKIPPED
-                           br-arcle-hs38 [ 4/11]: SKIPPED
-                            br-arm-basic [ 5/11]: FAILED
-                  br-arm-cortex-a9-glibc [ 6/11]: OK
-                   br-arm-cortex-a9-musl [ 7/11]: FAILED
-                   br-arm-cortex-m4-full [ 8/11]: OK
-                             br-arm-full [ 9/11]: OK
-                    br-arm-full-nothread [10/11]: FAILED
-                      br-arm-full-static [11/11]: OK
-11 builds, 2 skipped, 2 build failed, 1 legal-info failed

The results mean:

  • -OK: the build was successful. -
  • -SKIPPED: one or more configuration options listed in the config - snippet were not present in the final configuration. This is due to - options having dependencies not satisfied by the toolchain, such as - for example a package that depends on BR2_USE_MMU with a noMMU - toolchain. The missing options are reported in missing.config in - the output build directory (~/br-test-pkg/TOOLCHAIN_NAME/ by - default). -
  • -FAILED: the build failed. Inspect the logfile file in the output - build directory to see what went wrong: -

    • -the actual build failed, -
    • -the legal-info failed, -
    • -one of the preliminary steps (downloading the config file, applying - the configuration, running dirclean for the package) failed. -

When there are failures, you can just re-run the script with the same -options (after you fixed your package); the script will attempt to -re-build the package specified with -p for all toolchains, without -the need to re-build all the dependencies of that package.

The test-pkg script accepts a few options, for which you can get some -help by running:

$ ./utils/test-pkg -h

18.24.4. How to add a package from GitHub

Packages on GitHub often don’t have a download area with release tarballs. -However, it is possible to download tarballs directly from the repository -on GitHub. As GitHub is known to have changed download mechanisms in the -past, the github helper function should be used as shown below.

# Use a tag or a full commit ID
-FOO_VERSION = 1.0
-FOO_SITE = $(call github,<user>,<package>,v$(FOO_VERSION))

Notes

  • -The FOO_VERSION can either be a tag or a commit ID. -
  • -The tarball name generated by github matches the default one from - Buildroot (e.g.: foo-f6fb6654af62045239caed5950bc6c7971965e60.tar.gz), - so it is not necessary to specify it in the .mk file. -
  • -When using a commit ID as version, you should use the full 40 hex characters. -
  • -When the tag contains a prefix such as v in v1.0, then the - VERSION variable should contain just 1.0, and the v should be - added directly in the SITE variable, as illustrated above. This - ensures that the VERSION variable value can be used to match - against release-monitoring.org - results. -

If the package you wish to add does have a release section on GitHub, the -maintainer may have uploaded a release tarball, or the release may just point -to the automatically generated tarball from the git tag. If there is a -release tarball uploaded by the maintainer, we prefer to use that since it -may be slightly different (e.g. it contains a configure script so we don’t -need to do AUTORECONF).

You can see on the release page if it’s an uploaded tarball or a git tag:

github_hash_mongrel2.png
  • -If it looks like the image above then it was uploaded by the - maintainer and you should use that link (in that example: - mongrel2-v1.9.2.tar.bz2) to specify FOO_SITE, and not use the - github helper. -
  • -On the other hand, if there’s is only the "Source code" link, then - it’s an automatically generated tarball and you should use the - github helper function. -

18.24.5. How to add a package from Gitlab

In a similar way to the github macro described in -Section 18.24.4, “How to add a package from GitHub”, Buildroot also provides the gitlab macro -to download from Gitlab repositories. It can be used to download -auto-generated tarballs produced by Gitlab, either for specific tags -or commits:

# Use a tag or a full commit ID
-FOO_VERSION = 1.0
-FOO_SITE = $(call gitlab,<user>,<package>,v$(FOO_VERSION))

By default, it will use a .tar.gz tarball, but Gitlab also provides -.tar.bz2 tarballs, so by adding a <pkg>_SOURCE variable, this -.tar.bz2 tarball can be used:

# Use a tag or a full commit ID
-FOO_VERSION = 1.0
-FOO_SITE = $(call gitlab,<user>,<package>,v$(FOO_VERSION))
-FOO_SOURCE = foo-$(FOO_VERSION).tar.bz2

If there is a specific tarball uploaded by the upstream developers in -https://gitlab.com/<project>/releases/, do not use this macro, but -rather use directly the link to the tarball.

18.25. Conclusion

As you can see, adding a software package to Buildroot is simply a -matter of writing a Makefile using an existing example and modifying it -according to the compilation process required by the package.

If you package software that might be useful for other people, don’t -forget to send a patch to the Buildroot mailing list (see -Section 22.5, “Submitting patches”)!

Chapter 19. Patching a package

While integrating a new package or updating an existing one, it may be -necessary to patch the source of the software to get it cross-built within -Buildroot.

Buildroot offers an infrastructure to automatically handle this during -the builds. It supports three ways of applying patch sets: downloaded patches, -patches supplied within buildroot and patches located in a user-defined -global patch directory.

19.1. Providing patches

19.1.1. Downloaded

If it is necessary to apply a patch that is available for download, then add it -to the <packagename>_PATCH variable. If an entry contains ://, -then Buildroot will assume it is a full URL and download the patch -from this location. Otherwise, Buildroot will assume that the patch should be -downloaded from <packagename>_SITE. It can be a single patch, -or a tarball containing a patch series.

Like for all downloads, a hash should be added to the <packagename>.hash -file.

This method is typically used for packages from Debian.

19.1.2. Within Buildroot

Most patches are provided within Buildroot, in the package -directory; these typically aim to fix cross-compilation, libc support, -or other such issues.

These patch files should be named <number>-<description>.patch.

Notes

  • -The patch files coming with Buildroot should not contain any package version - reference in their filename. -
  • -The field <number> in the patch file name refers to the apply order, - and shall start at 1; It is preferred to pad the number with zeros up to 4 - digits, like git-format-patch does. E.g.: 0001-foobar-the-buz.patch -
  • -Previously, it was mandatory for patches to be prefixed with the name of - the package, like <package>-<number>-<description>.patch, but that is - no longer the case. Existing packages will be fixed as time passes. Do - not prefix patches with the package name. -
  • -Previously, a series file, as used by quilt, could also be added in - the package directory. In that case, the series file defines the patch - application order. This is deprecated, and will be removed in the future. - Do not use a series file. -

19.1.3. Global patch directory

The BR2_GLOBAL_PATCH_DIR configuration file option can be -used to specify a space separated list of one or more directories -containing global package patches. See Section 9.8, “Adding project-specific patches” for -details.

19.2. How patches are applied

  1. -Run the <packagename>_PRE_PATCH_HOOKS commands if defined; -
  2. -Cleanup the build directory, removing any existing *.rej files; -
  3. -If <packagename>_PATCH is defined, then patches from these - tarballs are applied; -
  4. -If there are some *.patch files in the package’s Buildroot - directory or in a package subdirectory named <packageversion>, - then: -

    • -If a series file exists in the package directory, then patches are - applied according to the series file; -
    • -Otherwise, patch files matching *.patch are applied in alphabetical - order. - So, to ensure they are applied in the right order, it is highly - recommended to name the patch files like this: - <number>-<description>.patch, where <number> refers to the - apply order. -
  5. -If BR2_GLOBAL_PATCH_DIR is defined, the directories will be - enumerated in the order they are specified. The patches are applied - as described in the previous step. -
  6. -Run the <packagename>_POST_PATCH_HOOKS commands if defined. -

If something goes wrong in the steps 3 or 4, then the build fails.

19.3. Format and licensing of the package patches

Patches are released under the same license as the software they apply -to (see Section 13.2, “Complying with the Buildroot license”).

A message explaining what the patch does, and why it is needed, should -be added in the header commentary of the patch.

You should add a Signed-off-by statement in the header of the each -patch to help with keeping track of the changes and to certify that the -patch is released under the same license as the software that is modified.

If the software is under version control, it is recommended to use the -upstream SCM software to generate the patch set.

Otherwise, concatenate the header with the output of the -diff -purN package-version.orig/ package-version/ command.

If you update an existing patch (e.g. when bumping the package version), -make sure the existing From header and Signed-off-by tags are not -removed, but do update the rest of the patch comment when appropriate.

At the end, the patch should look like:

configure.ac: add C++ support test
-
-Signed-off-by: John Doe <john.doe@noname.org>
-
---- configure.ac.orig
-+++ configure.ac
-@@ -40,2 +40,12 @@
-
-AC_PROG_MAKE_SET
-+
-+AC_CACHE_CHECK([whether the C++ compiler works],
-+               [rw_cv_prog_cxx_works],
-+               [AC_LANG_PUSH([C++])
-+                AC_LINK_IFELSE([AC_LANG_PROGRAM([], [])],
-+                               [rw_cv_prog_cxx_works=yes],
-+                               [rw_cv_prog_cxx_works=no])
-+                AC_LANG_POP([C++])])
-+
-+AM_CONDITIONAL([CXX_WORKS], [test "x$rw_cv_prog_cxx_works" = "xyes"])

19.4. Integrating patches found on the Web

When integrating a patch of which you are not the author, you have to -add a few things in the header of the patch itself.

Depending on whether the patch has been obtained from the project -repository itself, or from somewhere on the web, add one of the -following tags:

Backported from: <some commit id>

or

Fetch from: <some url>

It is also sensible to add a few words about any changes to the patch -that may have been necessary.

Chapter 20. Download infrastructure

TODO

Chapter 21. Debugging Buildroot

It is possible to instrument the steps Buildroot does when building -packages. Define the variable BR2_INSTRUMENTATION_SCRIPTS to contain -the path of one or more scripts (or other executables), in a -space-separated list, you want called before and after each step. The -scripts are called in sequence, with three parameters:

  • -start or end to denote the start (resp. the end) of a step; -
  • -the name of the step about to be started, or which just ended; -
  • -the name of the package. -

For example :

make BR2_INSTRUMENTATION_SCRIPTS="/path/to/my/script1 /path/to/my/script2"

The list of steps is:

  • -extract -
  • -patch -
  • -configure -
  • -build -
  • -install-host, when a host-package is installed in $(HOST_DIR) -
  • -install-target, when a target-package is installed in $(TARGET_DIR) -
  • -install-staging, when a target-package is installed in $(STAGING_DIR) -
  • -install-image, when a target-package installs files in $(BINARIES_DIR) -

The script has access to the following variables:

  • -BR2_CONFIG: the path to the Buildroot .config file -
  • -HOST_DIR, STAGING_DIR, TARGET_DIR: see - Section 18.5.2, “generic-package reference” -
  • -BUILD_DIR: the directory where packages are extracted and built -
  • -BINARIES_DIR: the place where all binary files (aka images) are - stored -
  • -BASE_DIR: the base output directory -

Chapter 22. Contributing to Buildroot

There are many ways in which you can contribute to Buildroot: analyzing -and fixing bugs, analyzing and fixing package build failures detected by -the autobuilders, testing and reviewing patches sent by other -developers, working on the items in our TODO list and sending your own -improvements to Buildroot or its manual. The following sections give a -little more detail on each of these items.

If you are interested in contributing to Buildroot, the first thing you -should do is to subscribe to the Buildroot mailing list. This list is -the main way of interacting with other Buildroot developers and to send -contributions to. If you aren’t subscribed yet, then refer to -Chapter 5, Community resources for the subscription link.

If you are going to touch the code, it is highly recommended to use a -git repository of Buildroot, rather than starting from an extracted -source code tarball. Git is the easiest way to develop from and directly -send your patches to the mailing list. Refer to Chapter 3, Getting Buildroot -for more information on obtaining a Buildroot git tree.

22.1. Reproducing, analyzing and fixing bugs

A first way of contributing is to have a look at the open bug reports in -the Buildroot bug -tracker. As we strive to keep the bug count as small as possible, all -help in reproducing, analyzing and fixing reported bugs is more than -welcome. Don’t hesitate to add a comment to bug reports reporting your -findings, even if you don’t yet see the full picture.

22.2. Analyzing and fixing autobuild failures

The Buildroot autobuilders are a set of build machines that continuously -run Buildroot builds based on random configurations. This is done for -all architectures supported by Buildroot, with various toolchains, and -with a random selection of packages. With the large commit activity on -Buildroot, these autobuilders are a great help in detecting problems -very early after commit.

All build results are available at http://autobuild.buildroot.org, -statistics are at http://autobuild.buildroot.org/stats.php. Every day, -an overview of all failed packages is sent to the mailing list.

Detecting problems is great, but obviously these problems have to be -fixed as well. Your contribution is very welcome here! There are -basically two things that can be done:

  • -Analyzing the problems. The daily summary mails do not contain details - about the actual failures: in order to see what’s going on you have to - open the build log and check the last output. Having someone doing - this for all packages in the mail is very useful for other developers, - as they can make a quick initial analysis based on this output alone. -
  • -Fixing a problem. When fixing autobuild failures, you should follow - these steps: -

    1. -Check if you can reproduce the problem by building with the same - configuration. You can do this manually, or use the - br-reproduce-build - script that will automatically clone a Buildroot git repository, - checkout the correct revision, download and set the right - configuration, and start the build. -
    2. -Analyze the problem and create a fix. -
    3. -Verify that the problem is really fixed by starting from a clean - Buildroot tree and only applying your fix. -
    4. -Send the fix to the Buildroot mailing list (see - Section 22.5, “Submitting patches”). In case you created a patch against the - package sources, you should also send the patch upstream so that the - problem will be fixed in a later release, and the patch in Buildroot - can be removed. - In the commit message of a patch fixing an autobuild failure, add a - reference to the build result directory, as follows: -
Fixes: http://autobuild.buildroot.org/results/51000a9d4656afe9e0ea6f07b9f8ed374c2e4069

22.3. Reviewing and testing patches

With the amount of patches sent to the mailing list each day, the -maintainer has a very hard job to judge which patches are ready to apply -and which ones aren’t. Contributors can greatly help here by reviewing -and testing these patches.

In the review process, do not hesitate to respond to patch submissions -for remarks, suggestions or anything that will help everyone to -understand the patches and make them better. Please use internet -style replies in plain text emails when responding to patch -submissions.

To indicate approval of a patch, there are three formal tags that keep -track of this approval. To add your tag to a patch, reply to it with the -approval tag below the original author’s Signed-off-by line. These tags -will be picked up automatically by patchwork (see -Section 22.3.1, “Applying Patches from Patchwork”) and will be part of the commit log when -the patch is accepted.

-Tested-by -
-Indicates that the patch has been tested successfully. - You are encouraged to specify what kind of testing you performed - (compile-test on architecture X and Y, runtime test on target A, - …). This additional information helps other testers and the - maintainer. -
-Reviewed-by -
-Indicates that you code-reviewed the patch and did your - best in spotting problems, but you are not sufficiently familiar with - the area touched to provide an Acked-by tag. This means that there - may be remaining problems in the patch that would be spotted by - someone with more experience in that area. Should such problems be - detected, your Reviewed-by tag remains appropriate and you cannot - be blamed. -
-Acked-by -
-Indicates that you code-reviewed the patch and you are - familiar enough with the area touched to feel that the patch can be - committed as-is (no additional changes required). In case it later - turns out that something is wrong with the patch, your Acked-by could - be considered inappropriate. The difference between Acked-by and - Reviewed-by is thus mainly that you are prepared to take the blame on - Acked patches, but not on Reviewed ones. -

If you reviewed a patch and have comments on it, you should simply reply -to the patch stating these comments, without providing a Reviewed-by or -Acked-by tag. These tags should only be provided if you judge the patch -to be good as it is.

It is important to note that neither Reviewed-by nor Acked-by imply -that testing has been performed. To indicate that you both reviewed and -tested the patch, provide two separate tags (Reviewed/Acked-by and -Tested-by).

Note also that any developer can provide Tested/Reviewed/Acked-by -tags, without exception, and we encourage everyone to do this. Buildroot -does not have a defined group of core developers, it just so happens -that some developers are more active than others. The maintainer will -value tags according to the track record of their submitter. Tags -provided by a regular contributor will naturally be trusted more than -tags provided by a newcomer. As you provide tags more regularly, your -trustworthiness (in the eyes of the maintainer) will go up, but any -tag provided is valuable.

Buildroot’s Patchwork website can be used to pull in patches for testing -purposes. Please see Section 22.3.1, “Applying Patches from Patchwork” for more -information on using Buildroot’s Patchwork website to apply patches.

22.3.1. Applying Patches from Patchwork

The main use of Buildroot’s Patchwork website for a developer is for -pulling in patches into their local git repository for testing -purposes.

When browsing patches in the patchwork management interface, an mbox -link is provided at the top of the page. Copy this link address and -run the following commands:

$ git checkout -b <test-branch-name>
-$ wget -O - <mbox-url> | git am

Another option for applying patches is to create a bundle. A bundle is -a set of patches that you can group together using the patchwork -interface. Once the bundle is created and the bundle is made public, -you can copy the mbox link for the bundle and apply the bundle -using the above commands.

22.4. Work on items from the TODO list

If you want to contribute to Buildroot but don’t know where to start, -and you don’t like any of the above topics, you can always work on items -from the Buildroot TODO list. -Don’t hesitate to discuss an item first on the mailing list or on IRC. -Do edit the wiki to indicate when you start working on an item, so we -avoid duplicate efforts.

22.5. Submitting patches

Note

Please, do not attach patches to bugs, send them to the mailing list -instead.

If you made some changes to Buildroot and you would like to contribute -them to the Buildroot project, proceed as follows.

22.5.1. The formatting of a patch

We expect patches to be formatted in a specific way. This is necessary -to make it easy to review patches, to be able to apply them easily to -the git repository, to make it easy to find back in the history how -and why things have changed, and to make it possible to use git -bisect to locate the origin of a problem.

First of all, it is essential that the patch has a good commit -message. The commit message should start with a separate line with a -brief summary of the change, prefixed by the area touched by the -patch. A few examples of good commit titles:

  • -package/linuxptp: bump version to 2.0 -
  • -configs/imx23evk: bump Linux version to 4.19 -
  • -package/pkg-generic: postpone evaluation of dependency conditions -
  • -boot/uboot: needs host-{flex,bison} -
  • -support/testing: add python-ubjson tests -

The description that follows the prefix should start with a lower case -letter (i.e "bump", "needs", "postpone", "add" in the above examples).

Second, the body of the commit message should describe why this -change is needed, and if necessary also give details about how it -was done. When writing the commit message, think of how the reviewers -will read it, but also think about how you will read it when you look -at this change again a few years down the line.

Third, the patch itself should do only one change, but do it -completely. Two unrelated or weakly related changes should usually be -done in two separate patches. This usually means that a patch affects -only a single package. If several changes are related, it is often -still possible to split them up in small patches and apply them in a -specific order. Small patches make it easier to review, and often -make it easier to understand afterwards why a change was done. -However, each patch must be complete. It is not allowed that the -build is broken when only the first but not the second patch is -applied. This is necessary to be able to use git bisect afterwards.

Of course, while you’re doing your development, you’re probably going -back and forth between packages, and certainly not committing things -immediately in a way that is clean enough for submission. So most -developers rewrite the history of commits to produce a clean set of -commits that is appropriate for submission. To do this, you need to -use interactive rebasing. You can learn about it -in the Pro -Git book. Sometimes, it is even easier to discard you history with -git reset --soft origin/master and select individual changes with -git add -i or git add -p.

Finally, the patch should be signed off. This is done by adding -Signed-off-by: Your Real Name <your@email.address> at the end of the -commit message. git commit -s does that for you, if configured -properly. The Signed-off-by tag means that you publish the patch -under the Buildroot license (i.e. GPL-2.0+, except for package patches, -which have the upstream license), and that you are allowed to do so. -See the Developer Certificate of -Origin for details.

When adding new packages, you should submit every package in a -separate patch. This patch should have the update to -package/Config.in, the package Config.in file, the .mk file, the -.hash file, any init script, and all package patches. If the package -has many sub-options, these are sometimes better added as separate -follow-up patches. The summary line should be something like -<packagename>: new package. The body of the commit message can be -empty for simple packages, or it can contain the description of the -package (like the Config.in help text). If anything special has to be -done to build the package, this should also be explained explicitly in -the commit message body.

When you bump a package to a new version, you should also submit a -separate patch for each package. Don’t forget to update the .hash -file, or add it if it doesn’t exist yet. Also don’t forget to check if -the _LICENSE and _LICENSE_FILES are still valid. The summary line -should be something like <packagename>: bump to version <new -version>. If the new version only contains security updates compared -to the existing one, the summary should be <packagename>: security -bump to version <new version> and the commit message body should show -the CVE numbers that are fixed. If some package patches can be removed -in the new version, it should be explained explicitly why they can be -removed, preferably with the upstream commit ID. Also any other -required changes should be explained explicitly, like configure -options that no longer exist or are no longer needed.

If you are interested in getting notified of build failures and of -further changes in the packages you added or modified, please add -yourself to the DEVELOPERS file. This should be done in the same patch -creating or modifying the package. See the DEVELOPERS file -for more information.

Buildroot provides a handy tool to check for common coding style -mistakes on files you created or modified, called check-package (see -Section 18.24.2, “How to check the coding style” for more information).

22.5.2. Preparing a patch series

Starting from the changes committed in your local git view, rebase -your development branch on top of the upstream tree before generating -a patch set. To do so, run:

$ git fetch --all --tags
-$ git rebase origin/master

Now, you are ready to generate then submit your patch set.

To generate it, run:

$ git format-patch -M -n -s -o outgoing origin/master

This will generate patch files in the outgoing subdirectory, -automatically adding the Signed-off-by line.

Once patch files are generated, you can review/edit the commit message -before submitting them, using your favorite text editor.

Buildroot provides a handy tool to know to whom your patches should be -sent, called get-developers (see Chapter 23, DEVELOPERS file and get-developers for more -information). This tool reads your patches and outputs the appropriate -git send-email command to use:

$ ./utils/get-developers outgoing/*

Use the output of get-developers to send your patches:

$ git send-email --to buildroot@buildroot.org --cc bob --cc alice outgoing/*

Alternatively, get-developers -e can be used directly with the ---cc-cmd argument to git send-email to automatically CC the -affected developers:

$ git send-email --to buildroot@buildroot.org \
-      --cc-cmd './utils/get-developers -e' origin/master

git can be configured to automatically do this out of the box with:

$ git config sendemail.to buildroot@buildroot.org
-$ git config sendemail.ccCmd "$(pwd)/utils/get-developers -e"

And then just do:

$ git send-email origin/master

Note that git should be configured to use your mail account. -To configure git, see man git-send-email or google it.

If you do not use git send-email, make sure posted patches are not -line-wrapped, otherwise they cannot easily be applied. In such a case, -fix your e-mail client, or better yet, learn to use git send-email.

22.5.3. Cover letter

If you want to present the whole patch set in a separate mail, add ---cover-letter to the git format-patch command (see man -git-format-patch for further information). This will generate a -template for an introduction e-mail to your patch series.

A cover letter may be useful to introduce the changes you propose -in the following cases:

  • -large number of commits in the series; -
  • -deep impact of the changes in the rest of the project; -
  • -RFC [4]; -
  • -whenever you feel it will help presenting your work, your choices, - the review process, etc. -

22.5.4. Patches for maintenance branches

When fixing bugs on a maintenance branch, bugs should be fixed on the -master branch first. The commit log for such a patch may then contain a -post-commit note specifying what branches are affected:

package/foo: fix stuff
-
-Signed-off-by: Your Real Name <your@email.address>
----
-Backport to: 2020.02.x, 2020.05.x
-(2020.08.x not affected as the version was bumped)

Those changes will then be backported by a maintainer to the affected -branches.

However, some bugs may apply only to a specific release, for example -because it is using an older version of a package. In that case, patches -should be based off the maintenance branch, and the patch subject prefix -must include the maintenance branch name (for example "[PATCH 2020.02.x]"). -This can be done with the git format-patch flag --subject-prefix:

$ git format-patch --subject-prefix "PATCH 2020.02.x" \
-    -M -s -o outgoing origin/2020.02.x

Then send the patches with git send-email, as described above.

22.5.5. Patch revision changelog

When improvements are requested, the new revision of each commit -should include a changelog of the modifications between each -submission. Note that when your patch series is introduced by a cover -letter, an overall changelog may be added to the cover letter in -addition to the changelog in the individual commits. -The best thing to rework a patch series is by interactive rebasing: -git rebase -i origin/master. Consult the git manual for more -information.

When added to the individual commits, this changelog is added when -editing the commit message. Below the Signed-off-by section, add ---- and your changelog.

Although the changelog will be visible for the reviewers in the mail -thread, as well as in patchwork, git -will automatically ignores lines below --- when the patch will be -merged. This is the intended behavior: the changelog is not meant to -be preserved forever in the git history of the project.

Hereafter the recommended layout:

Patch title: short explanation, max 72 chars
-
-A paragraph that explains the problem, and how it manifests itself. If
-the problem is complex, it is OK to add more paragraphs. All paragraphs
-should be wrapped at 72 characters.
-
-A paragraph that explains the root cause of the problem. Again, more
-than one paragraph is OK.
-
-Finally, one or more paragraphs that explain how the problem is solved.
-Don't hesitate to explain complex solutions in detail.
-
-Signed-off-by: John DOE <john.doe@example.net>
-
----
-Changes v2 -> v3:
-  - foo bar  (suggested by Jane)
-  - bar buz
-
-Changes v1 -> v2:
-  - alpha bravo  (suggested by John)
-  - charly delta

Any patch revision should include the version number. The version number -is simply composed of the letter v followed by an integer greater or -equal to two (i.e. "PATCH v2", "PATCH v3" …).

This can be easily handled with git format-patch by using the option ---subject-prefix:

$ git format-patch --subject-prefix "PATCH v4" \
-    -M -s -o outgoing origin/master

Since git version 1.8.1, you can also use -v <n> (where <n> is the -version number):

$ git format-patch -v4 -M -s -o outgoing origin/master

When you provide a new version of a patch, please mark the old one as -superseded in patchwork. You need to -create an account on patchwork to be -able to modify the status of your patches. Note that you can only change -the status of patches you submitted yourself, which means the email -address you register in patchwork should -match the one you use for sending patches to the mailing list.

You can also add the --in-reply-to <message-id> option when -submitting a patch to the mailing list. The id of the mail to reply to -can be found under the "Message Id" tag on -patchwork. The advantage of -in-reply-to is that patchwork will automatically mark the previous -version of the patch as superseded.

22.6. Reporting issues/bugs or getting help

Before reporting any issue, please check in -the mailing list archive whether someone has -already reported and/or fixed a similar problem.

However you choose to report bugs or get help, either by -opening a bug in the bug tracker or by -sending a mail to the mailing list, there are -a number of details to provide in order to help people reproduce and -find a solution to the issue.

Try to think as if you were trying to help someone else; in -that case, what would you need?

Here is a short list of details to provide in such case:

  • -host machine (OS/release) -
  • -version of Buildroot -
  • -target for which the build fails -
  • -package(s) for which the build fails -
  • -the command that fails and its output -
  • -any information you think that may be relevant -

Additionally, you should add the .config file (or if you know how, a -defconfig; see Section 9.3, “Storing the Buildroot configuration”).

If some of these details are too large, do not hesitate to use a -pastebin service. Note that not all available pastebin services will -preserve Unix-style line terminators when downloading raw pastes. -Following pastebin services are known to work correctly: -- https://gist.github.com/ -- http://code.bulix.org/

22.7. Using the runtime tests framework

Buildroot includes a run-time testing framework built upon Python -scripting and QEMU runtime execution. The goals of the framework are -the following:

  • -build a well defined Buildroot configuration -
  • -optionally, verify some properties of the build output -
  • -optionally, boot the build results under Qemu, and verify that a - given feature is working as expected -

The entry point to use the runtime tests framework is the -support/testing/run-tests tool, which has a series of options -documented in the tool’s help -h description. Some common options -include setting the download folder, the output folder, keeping build -output, and for multiple test cases, you can set the JLEVEL for each.

Here is an example walk through of running a test case.

  • -For a first step, let us see what all the test case options are. The test -cases can be listed by executing support/testing/run-tests -l. These tests -can all be run individually during test development from the console. Both -one at a time and selectively as a group of a subset of tests. -
$ support/testing/run-tests -l
-List of tests
-test_run (tests.utils.test_check_package.TestCheckPackage)
-test_run (tests.toolchain.test_external.TestExternalToolchainBuildrootMusl) ... ok
-test_run (tests.toolchain.test_external.TestExternalToolchainBuildrootuClibc) ... ok
-test_run (tests.toolchain.test_external.TestExternalToolchainCCache) ... ok
-test_run (tests.toolchain.test_external.TestExternalToolchainCtngMusl) ... ok
-test_run (tests.toolchain.test_external.TestExternalToolchainLinaroArm) ... ok
-test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv4) ... ok
-test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv5) ... ok
-test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv7) ... ok
-[snip]
-test_run (tests.init.test_systemd.TestInitSystemSystemdRoFull) ... ok
-test_run (tests.init.test_systemd.TestInitSystemSystemdRoIfupdown) ... ok
-test_run (tests.init.test_systemd.TestInitSystemSystemdRoNetworkd) ... ok
-test_run (tests.init.test_systemd.TestInitSystemSystemdRwFull) ... ok
-test_run (tests.init.test_systemd.TestInitSystemSystemdRwIfupdown) ... ok
-test_run (tests.init.test_systemd.TestInitSystemSystemdRwNetworkd) ... ok
-test_run (tests.init.test_busybox.TestInitSystemBusyboxRo) ... ok
-test_run (tests.init.test_busybox.TestInitSystemBusyboxRoNet) ... ok
-test_run (tests.init.test_busybox.TestInitSystemBusyboxRw) ... ok
-test_run (tests.init.test_busybox.TestInitSystemBusyboxRwNet) ... ok
-
-Ran 157 tests in 0.021s
-
-OK
  • -Then, to run one test case: -
$ support/testing/run-tests -d dl -o output_folder -k tests.init.test_busybox.TestInitSystemBusyboxRw
-15:03:26 TestInitSystemBusyboxRw                  Starting
-15:03:28 TestInitSystemBusyboxRw                  Building
-15:08:18 TestInitSystemBusyboxRw                  Building done
-15:08:27 TestInitSystemBusyboxRw                  Cleaning up
-.
-Ran 1 test in 301.140s
-
-OK

The standard output indicates if the test is successful or not. By -default, the output folder for the test is deleted automatically -unless the option -k is passed to keep the output directory.

22.7.1. Creating a test case

Within the Buildroot repository, the testing framework is organized at the -top level in support/testing/ by folders of conf, infra and tests. -All the test cases live under the tests folder and are organized in various -folders representing the category of test.

The best way to get familiar with how to create a test case is to look -at a few of the basic file system support/testing/tests/fs/ and init -support/testing/tests/init/ test scripts. Those tests give good -examples of a basic tests that include both checking the build -results, and doing runtime tests. There are other more advanced cases -that use things like nested br2-external folders to provide -skeletons and additional packages.

Creating a basic test case involves:

  • -Defining a test class that inherits from infra.basetest.BRTest -
  • -Defining the config member of the test class, to the Buildroot - configuration to build for this test case. It can optionally rely on - configuration snippets provided by the runtime test infrastructure: - infra.basetest.BASIC_TOOLCHAIN_CONFIG to get a basic - architecture/toolchain configuration, and - infra.basetest.MINIMAL_CONFIG to not build any filesystem. The - advantage of using infra.basetest.BASIC_TOOLCHAIN_CONFIG is that a - matching Linux kernel image is provided, which allows to boot the - resulting image in Qemu without having to build a Linux kernel image - as part of the test case, therefore significant decreasing the build - time required for the test case. -
  • -Implementing a def test_run(self): function to implement the - actual tests to run after the build has completed. They may be tests - that verify the build output, by running command on the host using - the run_cmd_on_host() helper function. Or they may boot the - generated system in Qemu using the Emulator object available as - self.emulator in the test case. For example self.emulator.boot() - allows to boot the system in Qemu, self.emulator.login() allows to - login, self.emulator.run() allows to run shell commands inside - Qemu. -

After creating the test script, add yourself to the DEVELOPERS file to -be the maintainer of that test case.

22.7.2. Debugging a test case

When a test case runs, the output_folder will contain the following:

$ ls output_folder/
-TestInitSystemBusyboxRw/
-TestInitSystemBusyboxRw-build.log
-TestInitSystemBusyboxRw-run.log

TestInitSystemBusyboxRw/ is the Buildroot output directory, and it -is preserved only if the -k option is passed.

TestInitSystemBusyboxRw-build.log is the log of the Buildroot build.

TestInitSystemBusyboxRw-run.log is the log of the Qemu boot and -test. This file will only exist if the build was successful and the -test case involves booting under Qemu.

If you want to manually run Qemu to do manual tests of the build -result, the first few lines of TestInitSystemBusyboxRw-run.log -contain the Qemu command line to use.

You can also make modifications to the current sources inside the -output_folder (e.g. for debug purposes) and rerun the standard -Buildroot make targets (in order to regenerate the complete image with -the new modifications) and then rerun the test.

22.7.3. Runtime tests and Gitlab CI

All runtime tests are regularly executed by Buildroot Gitlab CI -infrastructure, see .gitlab.yml and -https://gitlab.com/buildroot.org/buildroot/-/jobs.

You can also use Gitlab CI to test your new test cases, or verify that -existing tests continue to work after making changes in Buildroot.

In order to achieve this, you need to create a fork of the Buildroot -project on Gitlab, and be able to push branches to your Buildroot fork -on Gitlab.

The name of the branch that you push will determine if a Gitlab CI -pipeline will be triggered or not, and for which test cases.

In the examples below, the <name> component of the branch name is an -arbitrary string you choose.

  • -To trigger all run-test test case jobs, push a branch that ends with - -runtime-tests: -
 $ git push gitlab HEAD:<name>-runtime-tests
  • -To trigger one or several test case jobs, push a branch that ends - with the complete test case name - (tests.init.test_busybox.TestInitSystemBusyboxRo) or with the name - of a category of tests (tests.init.test_busybox): -
 $ git push gitlab HEAD:<name>-<test case name>

Example to run one test:

 $ git push gitlab HEAD:foo-tests.init.test_busybox.TestInitSystemBusyboxRo

Examples to run several tests part of the same group:

 $ git push gitlab HEAD:foo-tests.init.test_busybox
- $ git push gitlab HEAD:foo-tests.init


[4] RFC: (Request for comments) change proposal

Chapter 23. DEVELOPERS file and get-developers

The main Buildroot directory contains a file named DEVELOPERS that -lists the developers involved with various areas of Buildroot. Thanks -to this file, the get-developers tool allows to:

  • -Calculate the list of developers to whom patches should be sent, by - parsing the patches and matching the modified files with the - relevant developers. See Section 22.5, “Submitting patches” for details. -
  • -Find which developers are taking care of a given architecture or - package, so that they can be notified when a build failure occurs on - this architecture or package. This is done in interaction with - Buildroot’s autobuild infrastructure. -

We ask developers adding new packages, new boards, or generally new -functionality in Buildroot, to register themselves in the DEVELOPERS -file. As an example, we expect a developer contributing a new package -to include in his patch the appropriate modification to the -DEVELOPERS file.

The DEVELOPERS file format is documented in detail inside the file -itself.

The get-developers tool, located in utils/ allows to use -the DEVELOPERS file for various tasks:

  • -When passing one or several patches as command line argument, - get-developers will return the appropriate git send-email - command. If the -e option is passed, only the email addresses are - printed in a format suitable for git send-email --cc-cmd. -
  • -When using the -a <arch> command line option, get-developers will - return the list of developers in charge of the given architecture. -
  • -When using the -p <package> command line option, get-developers - will return the list of developers in charge of the given package. -
  • -When using the -c command line option, get-developers will look - at all files under version control in the Buildroot repository, and - list the ones that are not handled by any developer. The purpose of - this option is to help completing the DEVELOPERS file. -
  • -When using without any arguments, it validates the integrity of the - DEVELOPERS file and will note WARNINGS for items that don’t match. -

Chapter 24. Release Engineering

24.1. Releases

The Buildroot project makes quarterly releases with monthly bugfix -releases. The first release of each year is a long term support -release, LTS.

  • -Quarterly releases: 2020.02, 2020.05, 2020.08, and 2020.11 -
  • -Bugfix releases: 2020.02.1, 2020.02.2, … -
  • -LTS releases: 2020.02, 2021.02, … -

Releases are supported until the first bugfix release of the next -release, e.g., 2020.05.x is EOL when 2020.08.1 is released.

LTS releases are supported until the first bugfix release of the next -LTS, e.g., 2020.02.x is supported until 2021.02.1 is released.

24.2. Development

Each release cycle consist of two months of development on the master -branch and one month stabilization before the release is made. During -this phase no new features are added to master, only bugfixes.

The stabilization phase starts with tagging -rc1, and every week until -the release, another release candidate is tagged.

To handle new features and version bumps during the stabilization phase, -a next branch may be created for these features. Once the current -release has been made, the next branch is merged into master and -the development cycle for the next release continues there.

Part IV. Appendix

Chapter 25. Makedev syntax documentation

The makedev syntax is used in several places in Buildroot to -define changes to be made for permissions, or which device files to -create and how to create them, in order to avoid calls to mknod.

This syntax is derived from the makedev utility, and more complete -documentation can be found in the package/makedevs/README file.

It takes the form of a space separated list of fields, one file per -line; the fields are:

name

type

mode

uid

gid

major

minor

start

inc

count

There are a few non-trivial blocks:

  • -name is the path to the file you want to create/modify -
  • -type is the type of the file, being one of: -

    • -f: a regular file -
    • -d: a directory -
    • -r: a directory recursively -
    • -c: a character device file -
    • -b: a block device file -
    • -p: a named pipe -
  • -mode are the usual permissions settings (only numerical values - are allowed) -
  • -uid and gid are the UID and GID to set on this file; can be - either numerical values or actual names -
  • -major and minor are here for device files, set to - for other - files -
  • -start, inc and count are for when you want to create a batch - of files, and can be reduced to a loop, beginning at start, - incrementing its counter by inc until it reaches count -

Let’s say you want to change the permissions of a given file; using -this syntax, you will need to write:

/usr/bin/foo f 755 0 0 - - - - -
-/usr/bin/bar f 755 root root - - - - -
-/data/buz f 644 buz-user buz-group - - - - -

Alternatively, if you want to change owner/permission of a directory -recursively, you can write (to set UID to foo, GID to bar and access -rights to rwxr-x--- for the directory /usr/share/myapp and all files -and directories below it):

/usr/share/myapp r 750 foo bar - - - - -

On the other hand, if you want to create the device file /dev/hda -and the corresponding 15 files for the partitions, you will need for -/dev/hda:

/dev/hda b 640 root root 3 0 0 0 -

and then for device files corresponding to the partitions of -/dev/hda, /dev/hdaX, X ranging from 1 to 15:

/dev/hda b 640 root root 3 1 1 1 15

Extended attributes are supported if -BR2_ROOTFS_DEVICE_TABLE_SUPPORTS_EXTENDED_ATTRIBUTES is enabled. -This is done by adding a line starting with |xattr after -the line describing the file. Right now, only capability -is supported as extended attribute.

|xattr

capability

  • -|xattr is a "flag" that indicate an extended attribute -
  • -capability is a capability to add to the previous file -

If you want to add the capability cap_sys_admin to the binary foo, -you will write :

/usr/bin/foo f 755 root root - - - - -
-|xattr cap_sys_admin+eip

You can add several capabilities to a file by using several |xattr lines. -If you want to add the capability cap_sys_admin and cap_net_admin to the -binary foo, you will write :

/usr/bin/foo f 755 root root - - - - -
-|xattr cap_sys_admin+eip
-|xattr cap_net_admin+eip

Chapter 26. Makeusers syntax documentation

The syntax to create users is inspired by the makedev syntax, above, but -is specific to Buildroot.

The syntax for adding a user is a space-separated list of fields, one -user per line; the fields are:

username

uid

group

gid

password

home

shell

groups

comment

Where:

  • -username is the desired user name (aka login name) for the user. - It can not be root, and must be unique. If set to -, then just a - group will be created. -
  • -uid is the desired UID for the user. It must be unique, and not - 0. If set to -1, then a unique UID will be computed by Buildroot - in the range [1000…1999] -
  • -group is the desired name for the user’s main group. It can not - be root. If the group does not exist, it will be created. -
  • -gid is the desired GID for the user’s main group. It must be unique, - and not 0. If set to -1, and the group does not already exist, then - a unique GID will be computed by Buildroot in the range [1000..1999] -
  • -password is the crypt(3)-encoded password. If prefixed with !, - then login is disabled. If prefixed with =, then it is interpreted - as clear-text, and will be crypt-encoded (using MD5). If prefixed with - !=, then the password will be crypt-encoded (using MD5) and login - will be disabled. If set to *, then login is not allowed. If set to - -, then no password value will be set. -
  • -home is the desired home directory for the user. If set to -, no - home directory will be created, and the user’s home will be /. - Explicitly setting home to / is not allowed. -
  • -shell is the desired shell for the user. If set to -, then - /bin/false is set as the user’s shell. -
  • -groups is the comma-separated list of additional groups the user - should be part of. If set to -, then the user will be a member of - no additional group. Missing groups will be created with an arbitrary - gid. -
  • -comment (aka GECOS - field) is an almost-free-form text. -

There are a few restrictions on the content of each field:

  • -except for comment, all fields are mandatory. -
  • -except for comment, fields may not contain spaces. -
  • -no field may contain a colon (:). -

If home is not -, then the home directory, and all files below, -will belong to the user and its main group.

Examples:

foo -1 bar -1 !=blabla /home/foo /bin/sh alpha,bravo Foo user

This will create this user:

  • -username (aka login name) is: foo -
  • -uid is computed by Buildroot -
  • -main group is: bar -
  • -main group gid is computed by Buildroot -
  • -clear-text password is: blabla, will be crypt(3)-encoded, and login is disabled. -
  • -home is: /home/foo -
  • -shell is: /bin/sh -
  • -foo is also a member of groups: alpha and bravo -
  • -comment is: Foo user -
test 8000 wheel -1 = - /bin/sh - Test user

This will create this user:

  • -username (aka login name) is: test -
  • -uid is : 8000 -
  • -main group is: wheel -
  • -main group gid is computed by Buildroot, and will use the value defined in the rootfs skeleton -
  • -password is empty (aka no password). -
  • -home is / but will not belong to test -
  • -shell is: /bin/sh -
  • -test is not a member of any additional groups -
  • -comment is: Test user - -

Chapter 27. Migrating from older Buildroot versions

Some versions have introduced backward incompatibilities. This section -explains those incompatibilities, and for each explains what to do to -complete the migration.

27.1. General approach

To migrate from an older Buildroot version, take the following steps.

  1. -For all your configurations, do a build in the old Buildroot - environment. Run make graph-size. Save - graphs/file-size-stats.csv in a different location. Run make - clean to remove the rest. -
  2. -Review the specific migration notes below and make the required - adaptations to external packages and custom build scripts. -
  3. -Update Buildroot. -
  4. -Run make menuconfig starting from the existing .config. -
  5. -If anything is enabled in the Legacy menu, check its help text, - unselect it, and save the configuration. -
  6. -For more details, review the git commit messages for the packages that - you need. Change into the packages directory and run - git log <old version>.. — <your packages>. -
  7. -Build in the new Buildroot environment. -
  8. -Fix build issues in external packages (usually due to updated - dependencies). -
  9. -Run make graph-size. -
  10. -Compare the new file-size-stats.csv with the original one, to - check if no required files have disappeared and if no new big unneeded - files have appeared. -
  11. -For configuration (and other) files in a custom overlay that overwrite - files created by Buildroot, check if there are changes in the - Buildroot-generated file that need to be propagated to your custom - file. -

27.2. Migrating to 2016.11

Before Buildroot 2016.11, it was possible to use only one br2-external -tree at once. With Buildroot 2016.11 came the possibility to use more -than one simultaneously (for details, see Section 9.2, “Keeping customizations outside of Buildroot”).

This however means that older br2-external trees are not usable as-is. -A minor change has to be made: adding a name to your br2-external tree.

This can be done very easily in just a few steps:

  • -First, create a new file named external.desc, at the root of your - br2-external tree, with a single line defining the name of your - br2-external tree: -

    $ echo 'name: NAME_OF_YOUR_TREE' >external.desc

    Note. Be careful when choosing a name: It has to be unique and be made -with only ASCII characters from the set [A-Za-z0-9_].

  • -Then, change every occurence of BR2_EXTERNAL in your br2-external - tree with the new variable: -

    $ find . -type f | xargs sed -i 's/BR2_EXTERNAL/BR2_EXTERNAL_NAME_OF_YOUR_TREE_PATH/g'

Now, your br2-external tree can be used with Buildroot 2016.11 onward.

Note: This change makes your br2-external tree incompatible with Buildroot -before 2016.11.

27.3. Migrating to 2017.08

Before Buildroot 2017.08, host packages were installed in $(HOST_DIR)/usr -(with e.g. the autotools' --prefix=$(HOST_DIR)/usr). With Buildroot -2017.08, they are now installed directly in $(HOST_DIR).

Whenever a package installs an executable that is linked with a library -in $(HOST_DIR)/lib, it must have an RPATH pointing to that directory.

An RPATH pointing to $(HOST_DIR)/usr/lib is no longer accepted.

\ No newline at end of file diff --git a/docs/manual/manual.mk b/docs/manual/manual.mk index 1d03b213db..ccfd3156af 100644 --- a/docs/manual/manual.mk +++ b/docs/manual/manual.mk @@ -4,7 +4,7 @@ # ################################################################################ -MANUAL_SOURCES = $(sort $(wildcard docs/manual/*.txt) $(wildcard docs/images/*)) +MANUAL_SOURCES = $(sort $(wildcard docs/manual/*.txt) $(wildcard docs/images/* )) MANUAL_RESOURCES = $(TOPDIR)/docs/images $(eval $(call asciidoc-document)) diff --git a/docs/manual/manual.pdf b/docs/manual/manual.pdf deleted file mode 100644 index a54742632378e108d876846fbfc4d86dff24447a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 587127 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%0A3Vm7B_^ThjkrNvtwu00$p{ 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�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

L^KDzHPy6=jK@{7@*aZs#aKKgBgTRa~s01 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

jyD9%f77;8*lQJz7CO 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

2ZQ<#Fupj}r*A6_soH`4=(0>8K)0^o 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 z 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 QWkkiK$hf%F4K&F94_Wuz7ytkO diff --git a/docs/manual/manual.text b/docs/manual/manual.text deleted file mode 100644 index e31d3f86aa..0000000000 --- a/docs/manual/manual.text +++ /dev/null @@ -1,8468 +0,0 @@ - ---------------------------------------------------------------------- - -The Buildroot user manual - ---------------------------------------------------------------------- ---------------------------------------------------------------------- - -Table of Contents - - -I. Getting started - - 1. About Buildroot - 2. System requirements - - 2.1. Mandatory packages - 2.2. Optional packages - - 3. Getting Buildroot - 4. Buildroot quick start - 5. Community resources - -II. User guide - - 6. Buildroot configuration - - 6.1. Cross-compilation toolchain - 6.2. /dev management - 6.3. init system - - 7. Configuration of other components - 8. General Buildroot usage - - 8.1. make tips - 8.2. Understanding when a full rebuild is necessary - 8.3. Understanding how to rebuild packages - 8.4. Offline builds - 8.5. Building out-of-tree - 8.6. Environment variables - 8.7. Dealing efficiently with filesystem images - 8.8. Details about packages - 8.9. Graphing the dependencies between packages - 8.10. Graphing the build duration - 8.11. Graphing the filesystem size contribution of packages - 8.12. Top-level parallel build - 8.13. Integration with Eclipse - 8.14. Advanced usage - - 9. Project-specific customization - - 9.1. Recommended directory structure - 9.2. Keeping customizations outside of Buildroot - 9.3. Storing the Buildroot configuration - 9.4. Storing the configuration of other components - 9.5. Customizing the generated target filesystem - 9.6. Adding custom user accounts - 9.7. Customization after the images have been created - 9.8. Adding project-specific patches - 9.9. Adding project-specific packages - 9.10. Quick guide to storing your project-specific - customizations - - 10. Using SELinux in Buildroot - - 10.1. Enabling SELinux support - 10.2. SELinux policy tweaking - - 11. Frequently Asked Questions & Troubleshooting - - 11.1. The boot hangs after Starting network… - 11.2. Why is there no compiler on the target? - 11.3. Why are there no development files on the target? - 11.4. Why is there no documentation on the target? - 11.5. Why are some packages not visible in the Buildroot - config menu? - 11.6. Why not use the target directory as a chroot directory? - 11.7. Why doesn’t Buildroot generate binary packages (.deb, - .ipkg…)? - 11.8. How to speed-up the build process? - - 12. Known issues - 13. Legal notice and licensing - - 13.1. Complying with open source licenses - 13.2. Complying with the Buildroot license - - 14. Beyond Buildroot - - 14.1. Boot the generated images - 14.2. Chroot - -III. Developer guide - - 15. How Buildroot works - 16. Coding style - - 16.1. Config.in file - 16.2. The .mk file - 16.3. The documentation - 16.4. Support scripts - - 17. Adding support for a particular board - 18. Adding new packages to Buildroot - - 18.1. Package directory - 18.2. Config files - 18.3. The .mk file - 18.4. The .hash file - 18.5. Infrastructure for packages with specific build systems - 18.6. Infrastructure for autotools-based packages - 18.7. Infrastructure for CMake-based packages - 18.8. Infrastructure for Python packages - 18.9. Infrastructure for LuaRocks-based packages - 18.10. Infrastructure for Perl/CPAN packages - 18.11. Infrastructure for virtual packages - 18.12. Infrastructure for packages using kconfig for - configuration files - 18.13. Infrastructure for rebar-based packages - 18.14. Infrastructure for Waf-based packages - 18.15. Infrastructure for Meson-based packages - 18.16. Integration of Cargo-based packages - 18.17. Infrastructure for Go packages - 18.18. Infrastructure for QMake-based packages - 18.19. Infrastructure for packages building kernel modules - 18.20. Infrastructure for asciidoc documents - 18.21. Infrastructure specific to the Linux kernel package - 18.22. Hooks available in the various build steps - 18.23. Gettext integration and interaction with packages - 18.24. Tips and tricks - 18.25. Conclusion - - 19. Patching a package - - 19.1. Providing patches - 19.2. How patches are applied - 19.3. Format and licensing of the package patches - 19.4. Integrating patches found on the Web - - 20. Download infrastructure - 21. Debugging Buildroot - 22. Contributing to Buildroot - - 22.1. Reproducing, analyzing and fixing bugs - 22.2. Analyzing and fixing autobuild failures - 22.3. Reviewing and testing patches - 22.4. Work on items from the TODO list - 22.5. Submitting patches - 22.6. Reporting issues/bugs or getting help - 22.7. Using the runtime tests framework - - 23. DEVELOPERS file and get-developers - 24. Release Engineering - - 24.1. Releases - 24.2. Development - -IV. Appendix - - 25. Makedev syntax documentation - 26. Makeusers syntax documentation - 27. Migrating from older Buildroot versions - - 27.1. General approach - 27.2. Migrating to 2016.11 - 27.3. Migrating to 2017.08 - -List of Examples - -18.1. Config script: divine package -18.2. Config script: imagemagick package: - - ---------------------------------------------------------------------- - ---------------------------------------------------------------------- - -Buildroot 2021.08.2 manual generated on 2021-11-10 13:25:05 UTC from -git revision d815599e37 - -The Buildroot manual is written by the Buildroot developers. It is -licensed under the GNU General Public License, version 2. Refer to -the COPYING [http://git.buildroot.org/buildroot/tree/COPYING?id= -d815599e371d759b193de4207bec6f2701827db0] file in the Buildroot -sources for the full text of this license. - -Copyright © 2004-2020 The Buildroot developers - -Part I. Getting started - -Table of Contents - -1. About Buildroot -2. System requirements - - 2.1. Mandatory packages - 2.2. Optional packages - -3. Getting Buildroot -4. Buildroot quick start -5. Community resources - -Chapter 1. About Buildroot - -Buildroot is a tool that simplifies and automates the process of -building a complete Linux system for an embedded system, using -cross-compilation. - -In order to achieve this, Buildroot is able to generate a -cross-compilation toolchain, a root filesystem, a Linux kernel image -and a bootloader for your target. Buildroot can be used for any -combination of these options, independently (you can for example use -an existing cross-compilation toolchain, and build only your root -filesystem with Buildroot). - -Buildroot is useful mainly for people working with embedded systems. -Embedded systems often use processors that are not the regular x86 -processors everyone is used to having in his PC. They can be PowerPC -processors, MIPS processors, ARM processors, etc. - -Buildroot supports numerous processors and their variants; it also -comes with default configurations for several boards available -off-the-shelf. Besides this, a number of third-party projects are -based on, or develop their BSP ^[1] or SDK ^[2] on top of Buildroot. - - ---------------------------------------------------------------------- - -^[1] BSP: Board Support Package - -^[2] SDK: Software Development Kit - -Chapter 2. System requirements - -Buildroot is designed to run on Linux systems. - -While Buildroot itself will build most host packages it needs for the -compilation, certain standard Linux utilities are expected to be -already installed on the host system. Below you will find an overview -of the mandatory and optional packages (note that package names may -vary between distributions). - -2.1. Mandatory packages - - * Build tools: - - + which - + sed - + make (version 3.81 or any later) - + binutils - + build-essential (only for Debian based systems) - + gcc (version 4.8 or any later) - + g++ (version 4.8 or any later) - + bash - + patch - + gzip - + bzip2 - + perl (version 5.8.7 or any later) - + tar - + cpio - + unzip - + rsync - + file (must be in /usr/bin/file) - + bc - * Source fetching tools: - - + wget - -2.2. Optional packages - - * Recommended dependencies: - - Some features or utilities in Buildroot, like the legal-info, or - the graph generation tools, have additional dependencies. - Although they are not mandatory for a simple build, they are - still highly recommended: - - + python (version 2.7 or any later) - * Configuration interface dependencies: - - For these libraries, you need to install both runtime and - development data, which in many distributions are packaged - separately. The development packages typically have a -dev or - -devel suffix. - - + ncurses5 to use the menuconfig interface - + qt5 to use the xconfig interface - + glib2, gtk2 and glade2 to use the gconfig interface - * Source fetching tools: - - In the official tree, most of the package sources are retrieved - using wget from ftp, http or https locations. A few packages are - only available through a version control system. Moreover, - Buildroot is capable of downloading sources via other tools, like - rsync or scp (refer to Chapter 20, Download infrastructure for - more details). If you enable packages using any of these methods, - you will need to install the corresponding tool on the host - system: - - + bazaar - + cvs - + git - + mercurial - + rsync - + scp - + subversion - * Java-related packages, if the Java Classpath needs to be built - for the target system: - - + The javac compiler - + The jar tool - * Documentation generation tools: - - + asciidoc, version 8.6.3 or higher - + w3m - + python with the argparse module (automatically present in - 2.7+ and 3.2+) - + dblatex (required for the pdf manual only) - * Graph generation tools: - - + graphviz to use graph-depends and -graph-depends - + python-matplotlib to use graph-build - -Chapter 3. Getting Buildroot - -Buildroot releases are made every 3 months, in February, May, August -and November. Release numbers are in the format YYYY.MM, so for -example 2013.02, 2014.08. - -Release tarballs are available at http://buildroot.org/downloads/. - -For your convenience, a Vagrantfile [https://www.vagrantup.com/] is -available in support/misc/Vagrantfile in the Buildroot source tree to -quickly set up a virtual machine with the needed dependencies to get -started. - -If you want to setup an isolated buildroot environment on Linux or -Mac Os X, paste this line onto your terminal: - -curl -O https://buildroot.org/downloads/Vagrantfile; vagrant up - -If you are on Windows, paste this into your powershell: - -(new-object System.Net.WebClient).DownloadFile( -"https://buildroot.org/downloads/Vagrantfile","Vagrantfile"); -vagrant up - -If you want to follow development, you can use the daily snapshots or -make a clone of the Git repository. Refer to the Download page [http: -//buildroot.org/download] of the Buildroot website for more details. - -Chapter 4. Buildroot quick start - -Important: you can and should build everything as a normal user. -There is no need to be root to configure and use Buildroot. By -running all commands as a regular user, you protect your system -against packages behaving badly during compilation and installation. - -The first step when using Buildroot is to create a configuration. -Buildroot has a nice configuration tool similar to the one you can -find in the Linux kernel [http://www.kernel.org/] or in BusyBox -[http://www.busybox.net/]. - -From the buildroot directory, run - - $ make menuconfig - -for the original curses-based configurator, or - - $ make nconfig - -for the new curses-based configurator, or - - $ make xconfig - -for the Qt-based configurator, or - - $ make gconfig - -for the GTK-based configurator. - -All of these "make" commands will need to build a configuration -utility (including the interface), so you may need to install -"development" packages for relevant libraries used by the -configuration utilities. Refer to Chapter 2, System requirements for -more details, specifically the optional requirements to get the -dependencies of your favorite interface. - -For each menu entry in the configuration tool, you can find -associated help that describes the purpose of the entry. Refer to -Chapter 6, Buildroot configuration for details on some specific -configuration aspects. - -Once everything is configured, the configuration tool generates a -.config file that contains the entire configuration. This file will -be read by the top-level Makefile. - -To start the build process, simply run: - - $ make - -By default, Buildroot does not support top-level parallel build, so -running make -jN is not necessary. There is however experimental -support for top-level parallel build, see Section 8.12, “Top-level -parallel build”. - -The make command will generally perform the following steps: - - * download source files (as required); - * configure, build and install the cross-compilation toolchain, or - simply import an external toolchain; - * configure, build and install selected target packages; - * build a kernel image, if selected; - * build a bootloader image, if selected; - * create a root filesystem in selected formats. - -Buildroot output is stored in a single directory, output/. This -directory contains several subdirectories: - - * images/ where all the images (kernel image, bootloader and root - filesystem images) are stored. These are the files you need to - put on your target system. - * build/ where all the components are built (this includes tools - needed by Buildroot on the host and packages compiled for the - target). This directory contains one subdirectory for each of - these components. - * host/ contains both the tools built for the host, and the sysroot - of the target toolchain. The former is an installation of tools - compiled for the host that are needed for the proper execution of - Buildroot, including the cross-compilation toolchain. The latter - is a hierarchy similar to a root filesystem hierarchy. It - contains the headers and libraries of all user-space packages - that provide and install libraries used by other packages. - However, this directory is not intended to be the root filesystem - for the target: it contains a lot of development files, - unstripped binaries and libraries that make it far too big for an - embedded system. These development files are used to compile - libraries and applications for the target that depend on other - libraries. - * staging/ is a symlink to the target toolchain sysroot inside host - /, which exists for backwards compatibility. - * target/ which contains almost the complete root filesystem for - the target: everything needed is present except the device files - in /dev/ (Buildroot can’t create them because Buildroot doesn’t - run as root and doesn’t want to run as root). Also, it doesn’t - have the correct permissions (e.g. setuid for the busybox - binary). Therefore, this directory should not be used on your - target. Instead, you should use one of the images built in the - images/ directory. If you need an extracted image of the root - filesystem for booting over NFS, then use the tarball image - generated in images/ and extract it as root. Compared to staging - /, target/ contains only the files and libraries needed to run - the selected target applications: the development files (headers, - etc.) are not present, the binaries are stripped. - -These commands, make menuconfig|nconfig|gconfig|xconfig and make, are -the basic ones that allow to easily and quickly generate images -fitting your needs, with all the features and applications you -enabled. - -More details about the "make" command usage are given in Section 8.1, -“make tips”. - -Chapter 5. Community resources - -Like any open source project, Buildroot has different ways to share -information in its community and outside. - -Each of those ways may interest you if you are looking for some help, -want to understand Buildroot or contribute to the project. - -Mailing List - - Buildroot has a mailing list for discussion and development. It - is the main method of interaction for Buildroot users and - developers. - - Only subscribers to the Buildroot mailing list are allowed to - post to this list. You can subscribe via the mailing list info - page [http://lists.buildroot.org/mailman/listinfo/buildroot]. - - Mails that are sent to the mailing list are also available in the - mailing list archives, available through Mailman [http:// - lists.buildroot.org/pipermail/buildroot] or at lore.kernel.org - [https://lore.kernel.org/buildroot/]. - -IRC - - The Buildroot IRC channel #buildroot [irc://irc.oftc.net/# - buildroot] is hosted on OFTC [https://www.oftc.net/WebChat/]. It - is a useful place to ask quick questions or discuss on certain - topics. - - When asking for help on IRC, share relevant logs or pieces of - code using a code sharing website, such as https://paste.ack.tf/. - - Note that for certain questions, posting to the mailing list may - be better as it will reach more people, both developers and - users. - -Bug tracker - Bugs in Buildroot can be reported via the mailing list or - alternatively via the Buildroot bugtracker [https:// - bugs.buildroot.org/buglist.cgi?product=buildroot]. Please refer - to Section 22.6, “Reporting issues/bugs or getting help” before - creating a bug report. -Wiki - The Buildroot wiki page [http://elinux.org/Buildroot] is hosted - on the eLinux [http://elinux.org] wiki. It contains some useful - links, an overview of past and upcoming events, and a TODO list. -Patchwork - - Patchwork is a web-based patch tracking system designed to - facilitate the contribution and management of contributions to an - open-source project. Patches that have been sent to a mailing - list are 'caught' by the system, and appear on a web page. Any - comments posted that reference the patch are appended to the - patch page too. For more information on Patchwork see http:// - jk.ozlabs.org/projects/patchwork/. - - Buildroot’s Patchwork website is mainly for use by Buildroot’s - maintainer to ensure patches aren’t missed. It is also used by - Buildroot patch reviewers (see also Section 22.3.1, “Applying - Patches from Patchwork”). However, since the website exposes - patches and their corresponding review comments in a clean and - concise web interface, it can be useful for all Buildroot - developers. - - The Buildroot patch management interface is available at http:// - patchwork.buildroot.org. - -Part II. User guide - -Table of Contents - -6. Buildroot configuration - - 6.1. Cross-compilation toolchain - 6.2. /dev management - 6.3. init system - -7. Configuration of other components -8. General Buildroot usage - - 8.1. make tips - 8.2. Understanding when a full rebuild is necessary - 8.3. Understanding how to rebuild packages - 8.4. Offline builds - 8.5. Building out-of-tree - 8.6. Environment variables - 8.7. Dealing efficiently with filesystem images - 8.8. Details about packages - 8.9. Graphing the dependencies between packages - 8.10. Graphing the build duration - 8.11. Graphing the filesystem size contribution of packages - 8.12. Top-level parallel build - 8.13. Integration with Eclipse - 8.14. Advanced usage - -9. Project-specific customization - - 9.1. Recommended directory structure - 9.2. Keeping customizations outside of Buildroot - 9.3. Storing the Buildroot configuration - 9.4. Storing the configuration of other components - 9.5. Customizing the generated target filesystem - 9.6. Adding custom user accounts - 9.7. Customization after the images have been created - 9.8. Adding project-specific patches - 9.9. Adding project-specific packages - 9.10. Quick guide to storing your project-specific customizations - -10. Using SELinux in Buildroot - - 10.1. Enabling SELinux support - 10.2. SELinux policy tweaking - -11. Frequently Asked Questions & Troubleshooting - - 11.1. The boot hangs after Starting network… - 11.2. Why is there no compiler on the target? - 11.3. Why are there no development files on the target? - 11.4. Why is there no documentation on the target? - 11.5. Why are some packages not visible in the Buildroot config - menu? - 11.6. Why not use the target directory as a chroot directory? - 11.7. Why doesn’t Buildroot generate binary packages (.deb, - .ipkg…)? - 11.8. How to speed-up the build process? - -12. Known issues -13. Legal notice and licensing - - 13.1. Complying with open source licenses - 13.2. Complying with the Buildroot license - -14. Beyond Buildroot - - 14.1. Boot the generated images - 14.2. Chroot - -Chapter 6. Buildroot configuration - -All the configuration options in make *config have a help text -providing details about the option. - -The make *config commands also offer a search tool. Read the help -message in the different frontend menus to know how to use it: - - * in menuconfig, the search tool is called by pressing /; - * in xconfig, the search tool is called by pressing Ctrl + f. - -The result of the search shows the help message of the matching -items. In menuconfig, numbers in the left column provide a shortcut -to the corresponding entry. Just type this number to directly jump to -the entry, or to the containing menu in case the entry is not -selectable due to a missing dependency. - -Although the menu structure and the help text of the entries should -be sufficiently self-explanatory, a number of topics require -additional explanation that cannot easily be covered in the help text -and are therefore covered in the following sections. - -6.1. Cross-compilation toolchain - -A compilation toolchain is the set of tools that allows you to -compile code for your system. It consists of a compiler (in our case, -gcc), binary utils like assembler and linker (in our case, binutils) -and a C standard library (for example GNU Libc [http://www.gnu.org/ -software/libc/libc.html], uClibc-ng [http://www.uclibc-ng.org/]). - -The system installed on your development station certainly already -has a compilation toolchain that you can use to compile an -application that runs on your system. If you’re using a PC, your -compilation toolchain runs on an x86 processor and generates code for -an x86 processor. Under most Linux systems, the compilation toolchain -uses the GNU libc (glibc) as the C standard library. This compilation -toolchain is called the "host compilation toolchain". The machine on -which it is running, and on which you’re working, is called the "host -system" ^[3]. - -The compilation toolchain is provided by your distribution, and -Buildroot has nothing to do with it (other than using it to build a -cross-compilation toolchain and other tools that are run on the -development host). - -As said above, the compilation toolchain that comes with your system -runs on and generates code for the processor in your host system. As -your embedded system has a different processor, you need a -cross-compilation toolchain - a compilation toolchain that runs on -your host system but generates code for your target system (and -target processor). For example, if your host system uses x86 and your -target system uses ARM, the regular compilation toolchain on your -host runs on x86 and generates code for x86, while the -cross-compilation toolchain runs on x86 and generates code for ARM. - -Buildroot provides two solutions for the cross-compilation toolchain: - - * The internal toolchain backend, called Buildroot toolchain in the - configuration interface. - * The external toolchain backend, called External toolchain in the - configuration interface. - -The choice between these two solutions is done using the Toolchain -Type option in the Toolchain menu. Once one solution has been chosen, -a number of configuration options appear, they are detailed in the -following sections. - -6.1.1. Internal toolchain backend - -The internal toolchain backend is the backend where Buildroot builds -by itself a cross-compilation toolchain, before building the -userspace applications and libraries for your target embedded system. - -This backend supports several C libraries: uClibc-ng [http:// -www.uclibc-ng.org], glibc [http://www.gnu.org/software/libc/ -libc.html] and musl [http://www.musl-libc.org]. - -Once you have selected this backend, a number of options appear. The -most important ones allow to: - - * Change the version of the Linux kernel headers used to build the - toolchain. This item deserves a few explanations. In the process - of building a cross-compilation toolchain, the C library is being - built. This library provides the interface between userspace - applications and the Linux kernel. In order to know how to "talk" - to the Linux kernel, the C library needs to have access to the - Linux kernel headers (i.e. the .h files from the kernel), which - define the interface between userspace and the kernel (system - calls, data structures, etc.). Since this interface is backward - compatible, the version of the Linux kernel headers used to build - your toolchain do not need to match exactly the version of the - Linux kernel you intend to run on your embedded system. They only - need to have a version equal or older to the version of the Linux - kernel you intend to run. If you use kernel headers that are more - recent than the Linux kernel you run on your embedded system, - then the C library might be using interfaces that are not - provided by your Linux kernel. - * Change the version of the GCC compiler, binutils and the C - library. - * Select a number of toolchain options (uClibc only): whether the - toolchain should have RPC support (used mainly for NFS), - wide-char support, locale support (for internationalization), C++ - support or thread support. Depending on which options you choose, - the number of userspace applications and libraries visible in - Buildroot menus will change: many applications and libraries - require certain toolchain options to be enabled. Most packages - show a comment when a certain toolchain option is required to be - able to enable those packages. If needed, you can further refine - the uClibc configuration by running make uclibc-menuconfig. Note - however that all packages in Buildroot are tested against the - default uClibc configuration bundled in Buildroot: if you deviate - from this configuration by removing features from uClibc, some - packages may no longer build. - -It is worth noting that whenever one of those options is modified, -then the entire toolchain and system must be rebuilt. See -Section 8.2, “Understanding when a full rebuild is necessary”. - -Advantages of this backend: - - * Well integrated with Buildroot - * Fast, only builds what’s necessary - -Drawbacks of this backend: - - * Rebuilding the toolchain is needed when doing make clean, which - takes time. If you’re trying to reduce your build time, consider - using the External toolchain backend. - -6.1.2. External toolchain backend - -The external toolchain backend allows to use existing pre-built -cross-compilation toolchains. Buildroot knows about a number of -well-known cross-compilation toolchains (from Linaro [http:// -www.linaro.org] for ARM, Sourcery CodeBench [http://www.mentor.com/ -embedded-software/sourcery-tools/sourcery-codebench/editions/ -lite-edition/] for ARM, x86-64, PowerPC, and MIPS, and is capable of -downloading them automatically, or it can be pointed to a custom -toolchain, either available for download or installed locally. - -Then, you have three solutions to use an external toolchain: - - * Use a predefined external toolchain profile, and let Buildroot - download, extract and install the toolchain. Buildroot already - knows about a few CodeSourcery and Linaro toolchains. Just select - the toolchain profile in Toolchain from the available ones. This - is definitely the easiest solution. - * Use a predefined external toolchain profile, but instead of - having Buildroot download and extract the toolchain, you can tell - Buildroot where your toolchain is already installed on your - system. Just select the toolchain profile in Toolchain through - the available ones, unselect Download toolchain automatically, - and fill the Toolchain path text entry with the path to your - cross-compiling toolchain. - * Use a completely custom external toolchain. This is particularly - useful for toolchains generated using crosstool-NG or with - Buildroot itself. To do this, select the Custom toolchain - solution in the Toolchain list. You need to fill the Toolchain - path, Toolchain prefix and External toolchain C library options. - Then, you have to tell Buildroot what your external toolchain - supports. If your external toolchain uses the glibc library, you - only have to tell whether your toolchain supports C++ or not and - whether it has built-in RPC support. If your external toolchain - uses the uClibc library, then you have to tell Buildroot if it - supports RPC, wide-char, locale, program invocation, threads and - C++. At the beginning of the execution, Buildroot will tell you - if the selected options do not match the toolchain configuration. - -Our external toolchain support has been tested with toolchains from -CodeSourcery and Linaro, toolchains generated by crosstool-NG [http:/ -/crosstool-ng.org], and toolchains generated by Buildroot itself. In -general, all toolchains that support the sysroot feature should work. -If not, do not hesitate to contact the developers. - -We do not support toolchains or SDK generated by OpenEmbedded or -Yocto, because these toolchains are not pure toolchains (i.e. just -the compiler, binutils, the C and C++ libraries). Instead these -toolchains come with a very large set of pre-compiled libraries and -programs. Therefore, Buildroot cannot import the sysroot of the -toolchain, as it would contain hundreds of megabytes of pre-compiled -libraries that are normally built by Buildroot. - -We also do not support using the distribution toolchain (i.e. the gcc -/binutils/C library installed by your distribution) as the toolchain -to build software for the target. This is because your distribution -toolchain is not a "pure" toolchain (i.e. only with the C/C++ -library), so we cannot import it properly into the Buildroot build -environment. So even if you are building a system for a x86 or x86_64 -target, you have to generate a cross-compilation toolchain with -Buildroot or crosstool-NG. - -If you want to generate a custom toolchain for your project, that can -be used as an external toolchain in Buildroot, our recommendation is -to build it either with Buildroot itself (see Section 6.1.3, “Build -an external toolchain with Buildroot”) or with crosstool-NG [http:// -crosstool-ng.org]. - -Advantages of this backend: - - * Allows to use well-known and well-tested cross-compilation - toolchains. - * Avoids the build time of the cross-compilation toolchain, which - is often very significant in the overall build time of an - embedded Linux system. - -Drawbacks of this backend: - - * If your pre-built external toolchain has a bug, may be hard to - get a fix from the toolchain vendor, unless you build your - external toolchain by yourself using Buildroot or Crosstool-NG. - -6.1.3. Build an external toolchain with Buildroot - -The Buildroot internal toolchain option can be used to create an -external toolchain. Here are a series of steps to build an internal -toolchain and package it up for reuse by Buildroot itself (or other -projects). - -Create a new Buildroot configuration, with the following details: - - * Select the appropriate Target options for your target CPU - architecture - * In the Toolchain menu, keep the default of Buildroot toolchain - for Toolchain type, and configure your toolchain as desired - * In the System configuration menu, select None as the Init system - and none as /bin/sh - * In the Target packages menu, disable BusyBox - * In the Filesystem images menu, disable tar the root filesystem - -Then, we can trigger the build, and also ask Buildroot to generate a -SDK. This will conveniently generate for us a tarball which contains -our toolchain: - -make sdk - -This produces the SDK tarball in $(O)/images, with a name similar to -arm-buildroot-linux-uclibcgnueabi_sdk-buildroot.tar.gz. Save this -tarball, as it is now the toolchain that you can re-use as an -external toolchain in other Buildroot projects. - -In those other Buildroot projects, in the Toolchain menu: - - * Set Toolchain type to External toolchain - * Set Toolchain to Custom toolchain - * Set Toolchain origin to Toolchain to be downloaded and installed - * Set Toolchain URL to file:///path/to/your/sdk/tarball.tar.gz - -6.1.3.1. External toolchain wrapper - -When using an external toolchain, Buildroot generates a wrapper -program, that transparently passes the appropriate options (according -to the configuration) to the external toolchain programs. In case you -need to debug this wrapper to check exactly what arguments are -passed, you can set the environment variable BR2_DEBUG_WRAPPER to -either one of: - - * 0, empty or not set: no debug - * 1: trace all arguments on a single line - * 2: trace one argument per line - -6.2. /dev management - -On a Linux system, the /dev directory contains special files, called -device files, that allow userspace applications to access the -hardware devices managed by the Linux kernel. Without these device -files, your userspace applications would not be able to use the -hardware devices, even if they are properly recognized by the Linux -kernel. - -Under System configuration, /dev management, Buildroot offers four -different solutions to handle the /dev directory : - - * The first solution is Static using device table. This is the old - classical way of handling device files in Linux. With this - method, the device files are persistently stored in the root - filesystem (i.e. they persist across reboots), and there is - nothing that will automatically create and remove those device - files when hardware devices are added or removed from the system. - Buildroot therefore creates a standard set of device files using - a device table, the default one being stored in system/ - device_table_dev.txt in the Buildroot source code. This file is - processed when Buildroot generates the final root filesystem - image, and the device files are therefore not visible in the - output/target directory. The BR2_ROOTFS_STATIC_DEVICE_TABLE - option allows to change the default device table used by - Buildroot, or to add an additional device table, so that - additional device files are created by Buildroot during the - build. So, if you use this method, and a device file is missing - in your system, you can for example create a board// - /device_table_dev.txt file that contains the - description of your additional device files, and then you can set - BR2_ROOTFS_STATIC_DEVICE_TABLE to system/device_table_dev.txt - board///device_table_dev.txt. For more - details about the format of the device table file, see - Chapter 25, Makedev syntax documentation. - * The second solution is Dynamic using devtmpfs only. devtmpfs is a - virtual filesystem inside the Linux kernel that has been - introduced in kernel 2.6.32 (if you use an older kernel, it is - not possible to use this option). When mounted in /dev, this - virtual filesystem will automatically make device files appear - and disappear as hardware devices are added and removed from the - system. This filesystem is not persistent across reboots: it is - filled dynamically by the kernel. Using devtmpfs requires the - following kernel configuration options to be enabled: - CONFIG_DEVTMPFS and CONFIG_DEVTMPFS_MOUNT. When Buildroot is in - charge of building the Linux kernel for your embedded device, it - makes sure that those two options are enabled. However, if you - build your Linux kernel outside of Buildroot, then it is your - responsibility to enable those two options (if you fail to do so, - your Buildroot system will not boot). - * The third solution is Dynamic using devtmpfs + mdev. This method - also relies on the devtmpfs virtual filesystem detailed above (so - the requirement to have CONFIG_DEVTMPFS and CONFIG_DEVTMPFS_MOUNT - enabled in the kernel configuration still apply), but adds the - mdev userspace utility on top of it. mdev is a program part of - BusyBox that the kernel will call every time a device is added or - removed. Thanks to the /etc/mdev.conf configuration file, mdev - can be configured to for example, set specific permissions or - ownership on a device file, call a script or application whenever - a device appears or disappear, etc. Basically, it allows - userspace to react on device addition and removal events. mdev - can for example be used to automatically load kernel modules when - devices appear on the system. mdev is also important if you have - devices that require a firmware, as it will be responsible for - pushing the firmware contents to the kernel. mdev is a - lightweight implementation (with fewer features) of udev. For - more details about mdev and the syntax of its configuration file, - see http://git.busybox.net/busybox/tree/docs/mdev.txt. - * The fourth solution is Dynamic using devtmpfs + eudev. This - method also relies on the devtmpfs virtual filesystem detailed - above, but adds the eudev userspace daemon on top of it. eudev is - a daemon that runs in the background, and gets called by the - kernel when a device gets added or removed from the system. It is - a more heavyweight solution than mdev, but provides higher - flexibility. eudev is a standalone version of udev, the original - userspace daemon used in most desktop Linux distributions, which - is now part of Systemd. For more details, see http:// - en.wikipedia.org/wiki/Udev. - -The Buildroot developers recommendation is to start with the Dynamic -using devtmpfs only solution, until you have the need for userspace -to be notified when devices are added/removed, or if firmwares are -needed, in which case Dynamic using devtmpfs + mdev is usually a good -solution. - -Note that if systemd is chosen as init system, /dev management will -be performed by the udev program provided by systemd. - -6.3. init system - -The init program is the first userspace program started by the kernel -(it carries the PID number 1), and is responsible for starting the -userspace services and programs (for example: web server, graphical -applications, other network servers, etc.). - -Buildroot allows to use three different types of init systems, which -can be chosen from System configuration, Init system: - - * The first solution is BusyBox. Amongst many programs, BusyBox has - an implementation of a basic init program, which is sufficient - for most embedded systems. Enabling the BR2_INIT_BUSYBOX will - ensure BusyBox will build and install its init program. This is - the default solution in Buildroot. The BusyBox init program will - read the /etc/inittab file at boot to know what to do. The syntax - of this file can be found in http://git.busybox.net/busybox/tree/ - examples/inittab (note that BusyBox inittab syntax is special: do - not use a random inittab documentation from the Internet to learn - about BusyBox inittab). The default inittab in Buildroot is - stored in system/skeleton/etc/inittab. Apart from mounting a few - important filesystems, the main job the default inittab does is - to start the /etc/init.d/rcS shell script, and start a getty - program (which provides a login prompt). - * The second solution is systemV. This solution uses the old - traditional sysvinit program, packed in Buildroot in package/ - sysvinit. This was the solution used in most desktop Linux - distributions, until they switched to more recent alternatives - such as Upstart or Systemd. sysvinit also works with an inittab - file (which has a slightly different syntax than the one from - BusyBox). The default inittab installed with this init solution - is located in package/sysvinit/inittab. - * The third solution is systemd. systemd is the new generation init - system for Linux. It does far more than traditional init - programs: aggressive parallelization capabilities, uses socket - and D-Bus activation for starting services, offers on-demand - starting of daemons, keeps track of processes using Linux control - groups, supports snapshotting and restoring of the system state, - etc. systemd will be useful on relatively complex embedded - systems, for example the ones requiring D-Bus and services - communicating between each other. It is worth noting that systemd - brings a fairly big number of large dependencies: dbus, udev and - more. For more details about systemd, see http:// - www.freedesktop.org/wiki/Software/systemd. - -The solution recommended by Buildroot developers is to use the -BusyBox init as it is sufficient for most embedded systems. systemd -can be used for more complex situations. - - ---------------------------------------------------------------------- - -^[3] This terminology differs from what is used by GNU configure, -where the host is the machine on which the application will run -(which is usually the same as target) - -Chapter 7. Configuration of other components - -Before attempting to modify any of the components below, make sure -you have already configured Buildroot itself, and have enabled the -corresponding package. - -BusyBox - - If you already have a BusyBox configuration file, you can - directly specify this file in the Buildroot configuration, using - BR2_PACKAGE_BUSYBOX_CONFIG. Otherwise, Buildroot will start from - a default BusyBox configuration file. - - To make subsequent changes to the configuration, use make - busybox-menuconfig to open the BusyBox configuration editor. - - It is also possible to specify a BusyBox configuration file - through an environment variable, although this is not - recommended. Refer to Section 8.6, “Environment variables” for - more details. - -uClibc - Configuration of uClibc is done in the same way as for BusyBox. - The configuration variable to specify an existing configuration - file is BR2_UCLIBC_CONFIG. The command to make subsequent changes - is make uclibc-menuconfig. -Linux kernel - - If you already have a kernel configuration file, you can directly - specify this file in the Buildroot configuration, using - BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG. - - If you do not yet have a kernel configuration file, you can - either start by specifying a defconfig in the Buildroot - configuration, using BR2_LINUX_KERNEL_USE_DEFCONFIG, or start by - creating an empty file and specifying it as custom configuration - file, using BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG. - - To make subsequent changes to the configuration, use make - linux-menuconfig to open the Linux configuration editor. - -Barebox - Configuration of Barebox is done in the same way as for the Linux - kernel. The corresponding configuration variables are - BR2_TARGET_BAREBOX_USE_CUSTOM_CONFIG and - BR2_TARGET_BAREBOX_USE_DEFCONFIG. To open the configuration - editor, use make barebox-menuconfig. -U-Boot - Configuration of U-Boot (version 2015.04 or newer) is done in the - same way as for the Linux kernel. The corresponding configuration - variables are BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG and - BR2_TARGET_UBOOT_USE_DEFCONFIG. To open the configuration editor, - use make uboot-menuconfig. - -Chapter 8. General Buildroot usage - -8.1. make tips - -This is a collection of tips that help you make the most of -Buildroot. - -Display all commands executed by make:  - - $ make V=1 - -Display the list of boards with a defconfig:  - - $ make list-defconfigs - -Display all available targets:  - - $ make help - -Not all targets are always available, some settings in the .config -file may hide some targets: - - * busybox-menuconfig only works when busybox is enabled; - * linux-menuconfig and linux-savedefconfig only work when linux is - enabled; - * uclibc-menuconfig is only available when the uClibc C library is - selected in the internal toolchain backend; - * barebox-menuconfig and barebox-savedefconfig only work when the - barebox bootloader is enabled. - * uboot-menuconfig and uboot-savedefconfig only work when the - U-Boot bootloader is enabled. - -Cleaning: Explicit cleaning is required when any of the architecture -or toolchain configuration options are changed. - -To delete all build products (including build directories, host, -staging and target trees, the images and the toolchain): - - $ make clean - -Generating the manual: The present manual sources are located in the -docs/manual directory. To generate the manual: - - $ make manual-clean - $ make manual - -The manual outputs will be generated in output/docs/manual. - -Notes - - * A few tools are required to build the documentation (see: - Section 2.2, “Optional packages”). - -Resetting Buildroot for a new target: To delete all build products as -well as the configuration: - - $ make distclean - -Notes. If ccache is enabled, running make clean or distclean does not -empty the compiler cache used by Buildroot. To delete it, refer to -Section 8.14.3, “Using ccache in Buildroot”. - -Dumping the internal make variables: One can dump the variables known -to make, along with their values: - - $ make -s printvars VARS='VARIABLE1 VARIABLE2' - VARIABLE1=value_of_variable - VARIABLE2=value_of_variable - -It is possible to tweak the output using some variables: - - * VARS will limit the listing to variables which names match the - specified make-patterns - this must be set else nothing is - printed - * QUOTED_VARS, if set to YES, will single-quote the value - * RAW_VARS, if set to YES, will print the unexpanded value - -For example: - - $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES - BUSYBOX_DEPENDENCIES=skeleton toolchain - BUSYBOX_FINAL_ALL_DEPENDENCIES=skeleton toolchain - BUSYBOX_FINAL_DEPENDENCIES=skeleton toolchain - BUSYBOX_FINAL_PATCH_DEPENDENCIES= - BUSYBOX_RDEPENDENCIES=ncurses util-linux - - $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES QUOTED_VARS=YES - BUSYBOX_DEPENDENCIES='skeleton toolchain' - BUSYBOX_FINAL_ALL_DEPENDENCIES='skeleton toolchain' - BUSYBOX_FINAL_DEPENDENCIES='skeleton toolchain' - BUSYBOX_FINAL_PATCH_DEPENDENCIES='' - BUSYBOX_RDEPENDENCIES='ncurses util-linux' - - $ make -s printvars VARS=BUSYBOX_%DEPENDENCIES RAW_VARS=YES - BUSYBOX_DEPENDENCIES=skeleton toolchain - BUSYBOX_FINAL_ALL_DEPENDENCIES=$(sort $(BUSYBOX_FINAL_DEPENDENCIES) $(BUSYBOX_FINAL_PATCH_DEPENDENCIES)) - BUSYBOX_FINAL_DEPENDENCIES=$(sort $(BUSYBOX_DEPENDENCIES)) - BUSYBOX_FINAL_PATCH_DEPENDENCIES=$(sort $(BUSYBOX_PATCH_DEPENDENCIES)) - BUSYBOX_RDEPENDENCIES=ncurses util-linux - -The output of quoted variables can be reused in shell scripts, for -example: - - $ eval $(make -s printvars VARS=BUSYBOX_DEPENDENCIES QUOTED_VARS=YES) - $ echo $BUSYBOX_DEPENDENCIES - skeleton toolchain - -8.2. Understanding when a full rebuild is necessary - -Buildroot does not attempt to detect what parts of the system should -be rebuilt when the system configuration is changed through make -menuconfig, make xconfig or one of the other configuration tools. In -some cases, Buildroot should rebuild the entire system, in some -cases, only a specific subset of packages. But detecting this in a -completely reliable manner is very difficult, and therefore the -Buildroot developers have decided to simply not attempt to do this. - -Instead, it is the responsibility of the user to know when a full -rebuild is necessary. As a hint, here are a few rules of thumb that -can help you understand how to work with Buildroot: - - * When the target architecture configuration is changed, a complete - rebuild is needed. Changing the architecture variant, the binary - format or the floating point strategy for example has an impact - on the entire system. - * When the toolchain configuration is changed, a complete rebuild - generally is needed. Changing the toolchain configuration often - involves changing the compiler version, the type of C library or - its configuration, or some other fundamental configuration item, - and these changes have an impact on the entire system. - * When an additional package is added to the configuration, a full - rebuild is not necessarily needed. Buildroot will detect that - this package has never been built, and will build it. However, if - this package is a library that can optionally be used by packages - that have already been built, Buildroot will not automatically - rebuild those. Either you know which packages should be rebuilt, - and you can rebuild them manually, or you should do a full - rebuild. For example, let’s suppose you have built a system with - the ctorrent package, but without openssl. Your system works, but - you realize you would like to have SSL support in ctorrent, so - you enable the openssl package in Buildroot configuration and - restart the build. Buildroot will detect that openssl should be - built and will be build it, but it will not detect that ctorrent - should be rebuilt to benefit from openssl to add OpenSSL support. - You will either have to do a full rebuild, or rebuild ctorrent - itself. - * When a package is removed from the configuration, Buildroot does - not do anything special. It does not remove the files installed - by this package from the target root filesystem or from the - toolchain sysroot. A full rebuild is needed to get rid of this - package. However, generally you don’t necessarily need this - package to be removed right now: you can wait for the next lunch - break to restart the build from scratch. - * When the sub-options of a package are changed, the package is not - automatically rebuilt. After making such changes, rebuilding only - this package is often sufficient, unless enabling the package - sub-option adds some features to the package that are useful for - another package which has already been built. Again, Buildroot - does not track when a package should be rebuilt: once a package - has been built, it is never rebuilt unless explicitly told to do - so. - * When a change to the root filesystem skeleton is made, a full - rebuild is needed. However, when changes to the root filesystem - overlay, a post-build script or a post-image script are made, - there is no need for a full rebuild: a simple make invocation - will take the changes into account. - * When a package listed in FOO_DEPENDENCIES is rebuilt or removed, - the package foo is not automatically rebuilt. For example, if a - package bar is listed in FOO_DEPENDENCIES with FOO_DEPENDENCIES = - bar and the configuration of the bar package is changed, the - configuration change would not result in a rebuild of package foo - automatically. In this scenario, you may need to either rebuild - any packages in your build which reference bar in their - DEPENDENCIES, or perform a full rebuild to ensure any bar - dependent packages are up to date. - -Generally speaking, when you’re facing a build error and you’re -unsure of the potential consequences of the configuration changes -you’ve made, do a full rebuild. If you get the same build error, then -you are sure that the error is not related to partial rebuilds of -packages, and if this error occurs with packages from the official -Buildroot, do not hesitate to report the problem! As your experience -with Buildroot progresses, you will progressively learn when a full -rebuild is really necessary, and you will save more and more time. - -For reference, a full rebuild is achieved by running: - -$ make clean all - -8.3. Understanding how to rebuild packages - -One of the most common questions asked by Buildroot users is how to -rebuild a given package or how to remove a package without rebuilding -everything from scratch. - -Removing a package is unsupported by Buildroot without rebuilding -from scratch. This is because Buildroot doesn’t keep track of which -package installs what files in the output/staging and output/target -directories, or which package would be compiled differently depending -on the availability of another package. - -The easiest way to rebuild a single package from scratch is to remove -its build directory in output/build. Buildroot will then re-extract, -re-configure, re-compile and re-install this package from scratch. -You can ask buildroot to do this with the make -dirclean -command. - -On the other hand, if you only want to restart the build process of a -package from its compilation step, you can run make --rebuild. It will restart the compilation and installation of the -package, but not from scratch: it basically re-executes make and make -install inside the package, so it will only rebuild files that -changed. - -If you want to restart the build process of a package from its -configuration step, you can run make -reconfigure. It will -restart the configuration, compilation and installation of the -package. - -While -rebuild implies -reinstall and --reconfigure implies -rebuild, these targets as well as - only act on the said package, and do not trigger -re-creating the root filesystem image. If re-creating the root -filesystem in necessary, one should in addition run make or make all. - -Internally, Buildroot creates so-called stamp files to keep track of -which build steps have been completed for each package. They are -stored in the package build directory, output/build/- -/ and are named .stamp_. The commands detailed -above simply manipulate these stamp files to force Buildroot to -restart a specific set of steps of a package build process. - -Further details about package special make targets are explained in -Section 8.14.5, “Package-specific make targets”. - -8.4. Offline builds - -If you intend to do an offline build and just want to download all -sources that you previously selected in the configurator (menuconfig, -nconfig, xconfig or gconfig), then issue: - - $ make source - -You can now disconnect or copy the content of your dl directory to -the build-host. - -8.5. Building out-of-tree - -As default, everything built by Buildroot is stored in the directory -output in the Buildroot tree. - -Buildroot also supports building out of tree with a syntax similar to -the Linux kernel. To use it, add O= to the make command -line: - - $ make O=/tmp/build - -Or: - - $ cd /tmp/build; make O=$PWD -C path/to/buildroot - -All the output files will be located under /tmp/build. If the O path -does not exist, Buildroot will create it. - -Note: the O path can be either an absolute or a relative path, but if -it’s passed as a relative path, it is important to note that it is -interpreted relative to the main Buildroot source directory, not the -current working directory. - -When using out-of-tree builds, the Buildroot .config and temporary -files are also stored in the output directory. This means that you -can safely run multiple builds in parallel using the same source tree -as long as they use unique output directories. - -For ease of use, Buildroot generates a Makefile wrapper in the output -directory - so after the first run, you no longer need to pass O=<…> -and -C <…>, simply run (in the output directory): - - $ make - -8.6. Environment variables - -Buildroot also honors some environment variables, when they are -passed to make or set in the environment: - - * HOSTCXX, the host C++ compiler to use - * HOSTCC, the host C compiler to use - * UCLIBC_CONFIG_FILE=, path to the uClibc - configuration file, used to compile uClibc, if an internal - toolchain is being built. Note that the uClibc configuration file - can also be set from the configuration interface, so through the - Buildroot .config file; this is the recommended way of setting - it. - * BUSYBOX_CONFIG_FILE=, path to the BusyBox - configuration file. Note that the BusyBox configuration file can - also be set from the configuration interface, so through the - Buildroot .config file; this is the recommended way of setting - it. - * BR2_CCACHE_DIR to override the directory where Buildroot stores - the cached files when using ccache. - * BR2_DL_DIR to override the directory in which Buildroot stores/ - retrieves downloaded files. Note that the Buildroot download - directory can also be set from the configuration interface, so - through the Buildroot .config file. See Section 8.14.4, “Location - of downloaded packages” for more details on how you can set the - download directory. - * BR2_GRAPH_ALT, if set and non-empty, to use an alternate - color-scheme in build-time graphs - * BR2_GRAPH_OUT to set the filetype of generated graphs, either pdf - (the default), or png. - * BR2_GRAPH_DEPS_OPTS to pass extra options to the dependency - graph; see Section 8.9, “Graphing the dependencies between - packages” for the accepted options - * BR2_GRAPH_DOT_OPTS is passed verbatim as options to the dot - utility to draw the dependency graph. - * BR2_GRAPH_SIZE_OPTS to pass extra options to the size graph; see - Section 8.11, “Graphing the filesystem size contribution of - packages” for the acepted options - -An example that uses config files located in the toplevel directory -and in your $HOME: - - $ make UCLIBC_CONFIG_FILE=uClibc.config BUSYBOX_CONFIG_FILE=$HOME/bb.config - -If you want to use a compiler other than the default gcc or g++ for -building helper-binaries on your host, then do - - $ make HOSTCXX=g++-4.3-HEAD HOSTCC=gcc-4.3-HEAD - -8.7. Dealing efficiently with filesystem images - -Filesystem images can get pretty big, depending on the filesystem you -choose, the number of packages, whether you provisioned free space… -Yet, some locations in the filesystems images may just be empty (e.g. -a long run of zeroes); such a file is called a sparse file. - -Most tools can handle sparse files efficiently, and will only store -or write those parts of a sparse file that are not empty. - -For example: - - * tar accepts the -S option to tell it to only store non-zero - blocks of sparse files: - - + tar cf archive.tar -S [files…] will efficiently store sparse - files in a tarball - + tar xf archive.tar -S will efficiently store sparse files - extracted from a tarball - * cp accepts the --sparse=WHEN option (WHEN is one of auto, never - or always): - - + cp --sparse=always source.file dest.file will make dest.file - a sparse file if source.file has long runs of zeroes - -Other tools may have similar options. Please consult their respective -man pages. - -You can use sparse files if you need to store the filesystem images -(e.g. to transfer from one machine to another), or if you need to -send them (e.g. to the Q&A team). - -Note however that flashing a filesystem image to a device while using -the sparse mode of dd may result in a broken filesystem (e.g. the -block bitmap of an ext2 filesystem may be corrupted; or, if you have -sparse files in your filesystem, those parts may not be all-zeroes -when read back). You should only use sparse files when handling files -on the build machine, not when transferring them to an actual device -that will be used on the target. - -8.8. Details about packages - -Buildroot can produce a JSON blurb that describes the set of enabled -packages in the current configuration, together with their -dependencies, licenses and other metadata. This JSON blurb is -produced by using the show-info make target: - -make show-info - -Buildroot can also produce details about packages as HTML and JSON -output using the pkg-stats make target. Amongst other things, these -details include whether known CVEs (security vulnerabilities) affect -the packages in your current configuration. It also shows if there is -a newer upstream version for those packages. - -make pkg-stats - -8.9. Graphing the dependencies between packages - -One of Buildroot’s jobs is to know the dependencies between packages, -and make sure they are built in the right order. These dependencies -can sometimes be quite complicated, and for a given system, it is -often not easy to understand why such or such package was brought -into the build by Buildroot. - -In order to help understanding the dependencies, and therefore better -understand what is the role of the different components in your -embedded Linux system, Buildroot is capable of generating dependency -graphs. - -To generate a dependency graph of the full system you have compiled, -simply run: - -make graph-depends - -You will find the generated graph in output/graphs/graph-depends.pdf. - -If your system is quite large, the dependency graph may be too -complex and difficult to read. It is therefore possible to generate -the dependency graph just for a given package: - -make -graph-depends - -You will find the generated graph in output/graph/ --graph-depends.pdf. - -Note that the dependency graphs are generated using the dot tool from -the Graphviz project, which you must have installed on your system to -use this feature. In most distributions, it is available as the -graphviz package. - -By default, the dependency graphs are generated in the PDF format. -However, by passing the BR2_GRAPH_OUT environment variable, you can -switch to other output formats, such as PNG, PostScript or SVG. All -formats supported by the -T option of the dot tool are supported. - -BR2_GRAPH_OUT=svg make graph-depends - -The graph-depends behaviour can be controlled by setting options in -the BR2_GRAPH_DEPS_OPTS environment variable. The accepted options -are: - - * --depth N, -d N, to limit the dependency depth to N levels. The - default, 0, means no limit. - * --stop-on PKG, -s PKG, to stop the graph on the package PKG. PKG - can be an actual package name, a glob, the keyword virtual (to - stop on virtual packages), or the keyword host (to stop on host - packages). The package is still present on the graph, but its - dependencies are not. - * --exclude PKG, -x PKG, like --stop-on, but also omits PKG from - the graph. - * --transitive, --no-transitive, to draw (or not) the transitive - dependencies. The default is to not draw transitive dependencies. - * --colors R,T,H, the comma-separated list of colors to draw the - root package (R), the target packages (T) and the host packages - (H). Defaults to: lightblue,grey,gainsboro - -BR2_GRAPH_DEPS_OPTS='-d 3 --no-transitive --colors=red,green,blue' make graph-depends - -8.10. Graphing the build duration - -When the build of a system takes a long time, it is sometimes useful -to be able to understand which packages are the longest to build, to -see if anything can be done to speed up the build. In order to help -such build time analysis, Buildroot collects the build time of each -step of each package, and allows to generate graphs from this data. - -To generate the build time graph after a build, run: - -make graph-build - -This will generate a set of files in output/graphs : - - * build.hist-build.pdf, a histogram of the build time for each - package, ordered in the build order. - * build.hist-duration.pdf, a histogram of the build time for each - package, ordered by duration (longest first) - * build.hist-name.pdf, a histogram of the build time for each - package, order by package name. - * build.pie-packages.pdf, a pie chart of the build time per package - * build.pie-steps.pdf, a pie chart of the global time spent in each - step of the packages build process. - -This graph-build target requires the Python Matplotlib and Numpy -libraries to be installed (python-matplotlib and python-numpy on most -distributions), and also the argparse module if you’re using a Python -version older than 2.7 (python-argparse on most distributions). - -By default, the output format for the graph is PDF, but a different -format can be selected using the BR2_GRAPH_OUT environment variable. -The only other format supported is PNG: - -BR2_GRAPH_OUT=png make graph-build - -8.11. Graphing the filesystem size contribution of packages - -When your target system grows, it is sometimes useful to understand -how much each Buildroot package is contributing to the overall root -filesystem size. To help with such an analysis, Buildroot collects -data about files installed by each package and using this data, -generates a graph and CSV files detailing the size contribution of -the different packages. - -To generate these data after a build, run: - -make graph-size - -This will generate: - - * output/graphs/graph-size.pdf, a pie chart of the contribution of - each package to the overall root filesystem size - * output/graphs/package-size-stats.csv, a CSV file giving the size - contribution of each package to the overall root filesystem size - * output/graphs/file-size-stats.csv, a CSV file giving the size - contribution of each installed file to the package it belongs, - and to the overall filesystem size. - -This graph-size target requires the Python Matplotlib library to be -installed (python-matplotlib on most distributions), and also the -argparse module if you’re using a Python version older than 2.7 -(python-argparse on most distributions). - -Just like for the duration graph, a BR2_GRAPH_OUT environment -variable is supported to adjust the output file format. See -Section 8.9, “Graphing the dependencies between packages” for details -about this environment variable. - -Additionally, one may set the environment variable -BR2_GRAPH_SIZE_OPTS to further control the generated graph. Accepted -options are: - - * --size-limit X, -l X, will group all packages which individual - contribution is below X percent, to a single entry labelled - Others in the graph. By default, X=0.01, which means packages - each contributing less than 1% are grouped under Others. Accepted - values are in the range [0.0..1.0]. - * --iec, --binary, --si, --decimal, to use IEC (binary, powers of - 1024) or SI (decimal, powers of 1000; the default) prefixes. - * --biggest-first, to sort packages in decreasing size order, - rather than in increasing size order. - -Note. The collected filesystem size data is only meaningful after a -complete clean rebuild. Be sure to run make clean all before using -make graph-size. - -To compare the root filesystem size of two different Buildroot -compilations, for example after adjusting the configuration or when -switching to another Buildroot release, use the size-stats-compare -script. It takes two file-size-stats.csv files (produced by make -graph-size) as input. Refer to the help text of this script for more -details: - -utils/size-stats-compare -h - -8.12. Top-level parallel build - -Note. This section deals with a very experimental feature, which is -known to break even in some non-unusual situations. Use at your own -risk. - -Buildroot has always been capable of using parallel build on a per -package basis: each package is built by Buildroot using make -jN (or -the equivalent invocation for non-make-based build systems). The -level of parallelism is by default number of CPUs + 1, but it can be -adjusted using the BR2_JLEVEL configuration option. - -Until 2020.02, Buildroot was however building packages in a serial -fashion: each package was built one after the other, without -parallelization of the build between packages. As of 2020.02, -Buildroot has experimental support for top-level parallel build, -which allows some signicant build time savings by building packages -that have no dependency relationship in parallel. This feature is -however marked as experimental and is known not to work in some -cases. - -In order to use top-level parallel build, one must: - - 1. Enable the option BR2_PER_PACKAGE_DIRECTORIES in the Buildroot - configuration - 2. Use make -jN when starting the Buildroot build - -Internally, the BR2_PER_PACKAGE_DIRECTORIES will enable a mechanism -called per-package directories, which will have the following -effects: - - * Instead of a global target directory and a global host directory - common to all packages, per-package target and host directories - will be used, in $(O)/per-package//target/ and $(O)/ - per-package//host/ respectively. Those folders will be - populated from the corresponding folders of the package - dependencies at the beginning of build. The compiler and - all other tools will therefore only be able to see and access - files installed by dependencies explicitly listed by . - * At the end of the build, the global target and host directories - will be populated, located in $(O)/target and $(O)/host - respectively. This means that during the build, those folders - will be empty and it’s only at the very end of the build that - they will be populated. - -8.13. Integration with Eclipse - -While a part of the embedded Linux developers like classical text -editors like Vim or Emacs, and command-line based interfaces, a -number of other embedded Linux developers like richer graphical -interfaces to do their development work. Eclipse being one of the -most popular Integrated Development Environment, Buildroot integrates -with Eclipse in order to ease the development work of Eclipse users. - -Our integration with Eclipse simplifies the compilation, remote -execution and remote debugging of applications and libraries that are -built on top of a Buildroot system. It does not integrate the -Buildroot configuration and build processes themselves with Eclipse. -Therefore, the typical usage model of our Eclipse integration would -be: - - * Configure your Buildroot system with make menuconfig, make - xconfig or any other configuration interface provided with - Buildroot. - * Build your Buildroot system by running make. - * Start Eclipse to develop, execute and debug your own custom - applications and libraries, that will rely on the libraries built - and installed by Buildroot. - -The Buildroot Eclipse integration installation process and usage is -described in detail at https://github.com/mbats/ -eclipse-buildroot-bundle/wiki. - -8.14. Advanced usage - -8.14.1. Using the generated toolchain outside Buildroot - -You may want to compile, for your target, your own programs or other -software that are not packaged in Buildroot. In order to do this you -can use the toolchain that was generated by Buildroot. - -The toolchain generated by Buildroot is located by default in output/ -host/. The simplest way to use it is to add output/host/bin/ to your -PATH environment variable and then to use ARCH-linux-gcc, -ARCH-linux-objdump, ARCH-linux-ld, etc. - -Alternatively, Buildroot can also export the toolchain and the -development files of all selected packages, as an SDK, by running the -command make sdk. This generates a tarball of the content of the host -directory output/host/, named _sdk-buildroot.tar.gz -(which can be overriden by setting the environment variable -BR2_SDK_PREFIX) and located in the output directory output/images/. - -This tarball can then be distributed to application developers, when -they want to develop their applications that are not (yet) packaged -as a Buildroot package. - -Upon extracting the SDK tarball, the user must run the script -relocate-sdk.sh (located at the top directory of the SDK), to make -sure all paths are updated with the new location. - -Alternatively, if you just want to prepare the SDK without generating -the tarball (e.g. because you will just be moving the host directory, -or will be generating the tarball on your own), Buildroot also allows -you to just prepare the SDK with make prepare-sdk without actually -generating a tarball. - -For your convenience, by selecting the option -BR2_PACKAGE_HOST_ENVIRONMENT_SETUP, you can get a environment-setup -script installed in output/host/ and therefore in your SDK. This -script can be sourced with . your/sdk/path/environment-setup to -export a number of environment variables that will help cross-compile -your projects using the Buildroot SDK: the PATH will contain the SDK -binaries, standard autotools variables will be defined with the -appropriate values, and CONFIGURE_FLAGS will contain basic ./ -configure options to cross-compile autotools projects. It also -provides some useful commands. Note however that once this script is -sourced, the environment is setup only for cross-compilation, and no -longer for native compilation. - -8.14.2. Using gdb in Buildroot - -Buildroot allows to do cross-debugging, where the debugger runs on -the build machine and communicates with gdbserver on the target to -control the execution of the program. - -To achieve this: - - * If you are using an internal toolchain (built by Buildroot), you - must enable BR2_PACKAGE_HOST_GDB, BR2_PACKAGE_GDB and - BR2_PACKAGE_GDB_SERVER. This ensures that both the cross gdb and - gdbserver get built, and that gdbserver gets installed to your - target. - * If you are using an external toolchain, you should enable - BR2_TOOLCHAIN_EXTERNAL_GDB_SERVER_COPY, which will copy the - gdbserver included with the external toolchain to the target. If - your external toolchain does not have a cross gdb or gdbserver, - it is also possible to let Buildroot build them, by enabling the - same options as for the internal toolchain backend. - -Now, to start debugging a program called foo, you should run on the -target: - -gdbserver :2345 foo - -This will cause gdbserver to listen on TCP port 2345 for a connection -from the cross gdb. - -Then, on the host, you should start the cross gdb using the following -command line: - -/output/host/bin/-gdb -ix /output/staging/usr/share/buildroot/gdbinit foo - -Of course, foo must be available in the current directory, built with -debugging symbols. Typically you start this command from the -directory where foo is built (and not from output/target/ as the -binaries in that directory are stripped). - -The /output/staging/usr/share/buildroot/gdbinit file will -tell the cross gdb where to find the libraries of the target. - -Finally, to connect to the target from the cross gdb: - -(gdb) target remote :2345 - -8.14.3. Using ccache in Buildroot - -ccache [http://ccache.samba.org] is a compiler cache. It stores the -object files resulting from each compilation process, and is able to -skip future compilation of the same source file (with same compiler -and same arguments) by using the pre-existing object files. When -doing almost identical builds from scratch a number of times, it can -nicely speed up the build process. - -ccache support is integrated in Buildroot. You just have to enable -Enable compiler cache in Build options. This will automatically build -ccache and use it for every host and target compilation. - -The cache is located in $HOME/.buildroot-ccache. It is stored outside -of Buildroot output directory so that it can be shared by separate -Buildroot builds. If you want to get rid of the cache, simply remove -this directory. - -You can get statistics on the cache (its size, number of hits, -misses, etc.) by running make ccache-stats. - -The make target ccache-options and the CCACHE_OPTIONS variable -provide more generic access to the ccache. For example - -# set cache limit size -make CCACHE_OPTIONS="--max-size=5G" ccache-options - -# zero statistics counters -make CCACHE_OPTIONS="--zero-stats" ccache-options - -ccache makes a hash of the source files and of the compiler options. -If a compiler option is different, the cached object file will not be -used. Many compiler options, however, contain an absolute path to the -staging directory. Because of this, building in a different output -directory would lead to many cache misses. - -To avoid this issue, buildroot has the Use relative paths option -(BR2_CCACHE_USE_BASEDIR). This will rewrite all absolute paths that -point inside the output directory into relative paths. Thus, changing -the output directory no longer leads to cache misses. - -A disadvantage of the relative paths is that they also end up to be -relative paths in the object file. Therefore, for example, the -debugger will no longer find the file, unless you cd to the output -directory first. - -See the ccache manual’s section on "Compiling in different -directories" [https://ccache.samba.org/manual.html# -_compiling_in_different_directories] for more details about this -rewriting of absolute paths. - -8.14.4. Location of downloaded packages - -The various tarballs that are downloaded by Buildroot are all stored -in BR2_DL_DIR, which by default is the dl directory. If you want to -keep a complete version of Buildroot which is known to be working -with the associated tarballs, you can make a copy of this directory. -This will allow you to regenerate the toolchain and the target -filesystem with exactly the same versions. - -If you maintain several Buildroot trees, it might be better to have a -shared download location. This can be achieved by pointing the -BR2_DL_DIR environment variable to a directory. If this is set, then -the value of BR2_DL_DIR in the Buildroot configuration is overridden. -The following line should be added to <~/.bashrc>. - - export BR2_DL_DIR= - -The download location can also be set in the .config file, with the -BR2_DL_DIR option. Unlike most options in the .config file, this -value is overridden by the BR2_DL_DIR environment variable. - -8.14.5. Package-specific make targets - -Running make builds and installs that particular package -and its dependencies. - -For packages relying on the Buildroot infrastructure, there are -numerous special make targets that can be called independently like -this: - -make - - -The package build targets are (in the order they are executed): - -+------------------------------------------------------------+ -|command/target |Description | -|---------------+--------------------------------------------| -| source |Fetch the source (download the tarball, | -| |clone the source repository, etc) | -|---------------+--------------------------------------------| -| depends |Build and install all dependencies required | -| |to build the package | -|---------------+--------------------------------------------| -| extract |Put the source in the package build | -| |directory (extract the tarball, copy the | -| |source, etc) | -|---------------+--------------------------------------------| -| patch |Apply the patches, if any | -|---------------+--------------------------------------------| -| configure |Run the configure commands, if any | -|---------------+--------------------------------------------| -| build |Run the compilation commands | -|---------------+--------------------------------------------| -|install-staging|target package: Run the installation of the | -| |package in the staging directory, if | -| |necessary | -|---------------+--------------------------------------------| -|install-target |target package: Run the installation of the | -| |package in the target directory, if | -| |necessary | -|---------------+--------------------------------------------| -| install |target package: Run the 2 previous | -| |installation commands | -| | | -| |host package: Run the installation of the | -| |package in the host directory | -+------------------------------------------------------------+ - -Additionally, there are some other useful make targets: - -+------------------------------------------------------------+ -| command/target |Description | -|-----------------------+------------------------------------| -| show-depends |Displays the first-order | -| |dependencies required to build the | -| |package | -|-----------------------+------------------------------------| -|show-recursive-depends |Recursively displays the | -| |dependencies required to build the | -| |package | -|-----------------------+------------------------------------| -| show-rdepends |Displays the first-order reverse | -| |dependencies of the package (i.e | -| |packages that directly depend on it)| -|-----------------------+------------------------------------| -|show-recursive-rdepends|Recursively displays the reverse | -| |dependencies of the package (i.e the| -| |packages that depend on it, directly| -| |or indirectly) | -|-----------------------+------------------------------------| -| graph-depends |Generate a dependency graph of the | -| |package, in the context of the | -| |current Buildroot configuration. See| -| |this section for more details about | -| |dependency graphs. | -|-----------------------+------------------------------------| -| graph-rdepends |Generate a graph of this package | -| |reverse dependencies (i.e the | -| |packages that depend on it, directly| -| |or indirectly) | -|-----------------------+------------------------------------| -| dirclean |Remove the whole package build | -| |directory | -|-----------------------+------------------------------------| -| reinstall |Re-run the install commands | -|-----------------------+------------------------------------| -| rebuild |Re-run the compilation commands - | -| |this only makes sense when using the| -| |OVERRIDE_SRCDIR feature or when you | -| |modified a file directly in the | -| |build directory | -|-----------------------+------------------------------------| -| reconfigure |Re-run the configure commands, then | -| |rebuild - this only makes sense when| -| |using the OVERRIDE_SRCDIR feature or| -| |when you modified a file directly in| -| |the build directory | -+------------------------------------------------------------+ - -8.14.6. Using Buildroot during development - -The normal operation of Buildroot is to download a tarball, extract -it, configure, compile and install the software component found -inside this tarball. The source code is extracted in output/build/ --, which is a temporary directory: whenever make -clean is used, this directory is entirely removed, and re-created at -the next make invocation. Even when a Git or Subversion repository is -used as the input for the package source code, Buildroot creates a -tarball out of it, and then behaves as it normally does with -tarballs. - -This behavior is well-suited when Buildroot is used mainly as an -integration tool, to build and integrate all the components of an -embedded Linux system. However, if one uses Buildroot during the -development of certain components of the system, this behavior is not -very convenient: one would instead like to make a small change to the -source code of one package, and be able to quickly rebuild the system -with Buildroot. - -Making changes directly in output/build/- is not an -appropriate solution, because this directory is removed on make -clean. - -Therefore, Buildroot provides a specific mechanism for this use case: -the _OVERRIDE_SRCDIR mechanism. Buildroot reads an override -file, which allows the user to tell Buildroot the location of the -source for certain packages. - -The default location of the override file is $(CONFIG_DIR)/local.mk, -as defined by the BR2_PACKAGE_OVERRIDE_FILE configuration option. $ -(CONFIG_DIR) is the location of the Buildroot .config file, so -local.mk by default lives side-by-side with the .config file, which -means: - - * In the top-level Buildroot source directory for in-tree builds - (i.e., when O= is not used) - * In the out-of-tree directory for out-of-tree builds (i.e., when O - = is used) - -If a different location than these defaults is required, it can be -specified through the BR2_PACKAGE_OVERRIDE_FILE configuration option. - -In this override file, Buildroot expects to find lines of the form: - -_OVERRIDE_SRCDIR = /path/to/pkg1/sources -_OVERRIDE_SRCDIR = /path/to/pkg2/sources - -For example: - -LINUX_OVERRIDE_SRCDIR = /home/bob/linux/ -BUSYBOX_OVERRIDE_SRCDIR = /home/bob/busybox/ - -When Buildroot finds that for a given package, an -_OVERRIDE_SRCDIR has been defined, it will no longer attempt to -download, extract and patch the package. Instead, it will directly -use the source code available in the specified directory and make -clean will not touch this directory. This allows to point Buildroot -to your own directories, that can be managed by Git, Subversion, or -any other version control system. To achieve this, Buildroot will use -rsync to copy the source code of the component from the specified -_OVERRIDE_SRCDIR to output/build/-custom/. - -This mechanism is best used in conjunction with the make --rebuild and make -reconfigure targets. A make -rebuild all -sequence will rsync the source code from _OVERRIDE_SRCDIR to -output/build/-custom (thanks to rsync, only the modified -files are copied), and restart the build process of just this -package. - -In the example of the linux package above, the developer can then -make a source code change in /home/bob/linux and then run: - -make linux-rebuild all - -and in a matter of seconds gets the updated Linux kernel image in -output/images. Similarly, a change can be made to the BusyBox source -code in /home/bob/busybox, and after: - -make busybox-rebuild all - -the root filesystem image in output/images contains the updated -BusyBox. - -Source trees for big projects often contain hundreds or thousands of -files which are not needed for building, but will slow down the -process of copying the sources with rsync. Optionally, it is possible -define _OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS to skip syncing certain -files from the source tree. For example, when working on the -webkitgtk package, the following will exclude the tests and in-tree -builds from a local WebKit source tree: - -WEBKITGTK_OVERRIDE_SRCDIR = /home/bob/WebKit -WEBKITGTK_OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS = \ - --exclude JSTests --exclude ManualTests --exclude PerformanceTests \ - --exclude WebDriverTests --exclude WebKitBuild --exclude WebKitLibraries \ - --exclude WebKit.xcworkspace --exclude Websites --exclude Examples - -By default, Buildroot skips syncing of VCS artifacts (e.g., the .git -and .svn directories). Some packages prefer to have these VCS -directories available during build, for example for automatically -determining a precise commit reference for version information. To -undo this built-in filtering at a cost of a slower speed, add these -directories back: - -LINUX_OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS = --include .git - -Chapter 9. Project-specific customization - -Typical actions you may need to perform for a given project are: - - * configuring Buildroot (including build options and toolchain, - bootloader, kernel, package and filesystem image type selection) - * configuring other components, like the Linux kernel and BusyBox - * customizing the generated target filesystem - - + adding or overwriting files on the target filesystem (using - BR2_ROOTFS_OVERLAY) - + modifying or deleting files on the target filesystem (using - BR2_ROOTFS_POST_BUILD_SCRIPT) - + running arbitrary commands prior to generating the filesystem - image (using BR2_ROOTFS_POST_BUILD_SCRIPT) - + setting file permissions and ownership (using - BR2_ROOTFS_DEVICE_TABLE) - + adding custom devices nodes (using - BR2_ROOTFS_STATIC_DEVICE_TABLE) - * adding custom user accounts (using BR2_ROOTFS_USERS_TABLES) - * running arbitrary commands after generating the filesystem image - (using BR2_ROOTFS_POST_IMAGE_SCRIPT) - * adding project-specific patches to some packages (using - BR2_GLOBAL_PATCH_DIR) - * adding project-specific packages - -An important note regarding such project-specific customizations: -please carefully consider which changes are indeed project-specific -and which changes are also useful to developers outside your project. -The Buildroot community highly recommends and encourages the -upstreaming of improvements, packages and board support to the -official Buildroot project. Of course, it is sometimes not possible -or desirable to upstream because the changes are highly specific or -proprietary. - -This chapter describes how to make such project-specific -customizations in Buildroot and how to store them in a way that you -can build the same image in a reproducible way, even after running -make clean. By following the recommended strategy, you can even use -the same Buildroot tree to build multiple distinct projects! - -9.1. Recommended directory structure - -When customizing Buildroot for your project, you will be creating one -or more project-specific files that need to be stored somewhere. -While most of these files could be placed in any location as their -path is to be specified in the Buildroot configuration, the Buildroot -developers recommend a specific directory structure which is -described in this section. - -Orthogonal to this directory structure, you can choose where you -place this structure itself: either inside the Buildroot tree, or -outside of it using a br2-external tree. Both options are valid, the -choice is up to you. - -+-- board/ -| +-- / -| +-- / -| +-- linux.config -| +-- busybox.config -| +-- -| +-- post_build.sh -| +-- post_image.sh -| +-- rootfs_overlay/ -| | +-- etc/ -| | +-- -| +-- patches/ -| +-- foo/ -| | +-- -| +-- libbar/ -| +-- -| -+-- configs/ -| +-- _defconfig -| -+-- package/ -| +-- / -| +-- Config.in (if not using a br2-external tree) -| +-- .mk (if not using a br2-external tree) -| +-- package1/ -| | +-- Config.in -| | +-- package1.mk -| +-- package2/ -| +-- Config.in -| +-- package2.mk -| -+-- Config.in (if using a br2-external tree) -+-- external.mk (if using a br2-external tree) -+-- external.desc (if using a br2-external tree) - -Details on the files shown above are given further in this chapter. - -Note: if you choose to place this structure outside of the Buildroot -tree but in a br2-external tree, the and possibly - components may be superfluous and can be left out. - -9.1.1. Implementing layered customizations - -It is quite common for a user to have several related projects that -partly need the same customizations. Instead of duplicating these -customizations for each project, it is recommended to use a layered -customization approach, as explained in this section. - -Almost all of the customization methods available in Buildroot, like -post-build scripts and root filesystem overlays, accept a -space-separated list of items. The specified items are always treated -in order, from left to right. By creating more than one such item, -one for the common customizations and another one for the really -project-specific customizations, you can avoid unnecessary -duplication. Each layer is typically embodied by a separate directory -inside board//. Depending on your projects, you could even -introduce more than two layers. - -An example directory structure for where a user has two customization -layers common and fooboard is: - -+-- board/ - +-- / - +-- common/ - | +-- post_build.sh - | +-- rootfs_overlay/ - | | +-- ... - | +-- patches/ - | +-- ... - | - +-- fooboard/ - +-- linux.config - +-- busybox.config - +-- - +-- post_build.sh - +-- rootfs_overlay/ - | +-- ... - +-- patches/ - +-- ... - -For example, if the user has the BR2_GLOBAL_PATCH_DIR configuration -option set as: - -BR2_GLOBAL_PATCH_DIR="board//common/patches board//fooboard/patches" - -then first the patches from the common layer would be applied, -followed by the patches from the fooboard layer. - -9.2. Keeping customizations outside of Buildroot - -As already briefly mentioned in Section 9.1, “Recommended directory -structure”, you can place project-specific customizations in two -locations: - - * directly within the Buildroot tree, typically maintaining them - using branches in a version control system so that upgrading to a - newer Buildroot release is easy. - * outside of the Buildroot tree, using the br2-external mechanism. - This mechanism allows to keep package recipes, board support and - configuration files outside of the Buildroot tree, while still - having them nicely integrated in the build logic. We call this - location a br2-external tree. This section explains how to use - the br2-external mechanism and what to provide in a br2-external - tree. - -One can tell Buildroot to use one or more br2-external trees by -setting the BR2_EXTERNAL make variable set to the path(s) of the -br2-external tree(s) to use. It can be passed to any Buildroot make -invocation. It is automatically saved in the hidden .br2-external.mk -file in the output directory. Thanks to this, there is no need to -pass BR2_EXTERNAL at every make invocation. It can however be changed -at any time by passing a new value, and can be removed by passing an -empty value. - -Note. The path to a br2-external tree can be either absolute or -relative. If it is passed as a relative path, it is important to note -that it is interpreted relative to the main Buildroot source -directory, not to the Buildroot output directory. - -Note: If using an br2-external tree from before Buildroot 2016.11, -you need to convert it before you can use it with Buildroot 2016.11 -onward. See Section 27.2, “Migrating to 2016.11” for help on doing -so. - -Some examples: - -buildroot/ $ make BR2_EXTERNAL=/path/to/foo menuconfig - -From now on, definitions from the /path/to/foo br2-external tree will -be used: - -buildroot/ $ make -buildroot/ $ make legal-info - -We can switch to another br2-external tree at any time: - -buildroot/ $ make BR2_EXTERNAL=/where/we/have/bar xconfig - -We can also use multiple br2-external trees: - -buildroot/ $ make BR2_EXTERNAL=/path/to/foo:/where/we/have/bar menuconfig - -Or disable the usage of any br2-external tree: - -buildroot/ $ make BR2_EXTERNAL= xconfig - -9.2.1. Layout of a br2-external tree - -A br2-external tree must contain at least those three files, -described in the following chapters: - - * external.desc - * external.mk - * Config.in - -Apart from those mandatory files, there may be additional and -optional content that may be present in a br2-external tree, like the -configs/ or provides/ directories. They are described in the -following chapters as well. - -A complete example br2-external tree layout is also described later. - -9.2.1.1. The external.desc file - -That file describes the br2-external tree: the name and description -for that br2-external tree. - -The format for this file is line based, with each line starting by a -keyword, followed by a colon and one or more spaces, followed by the -value assigned to that keyword. There are two keywords currently -recognised: - - * name, mandatory, defines the name for that br2-external tree. - That name must only use ASCII characters in the set [A-Za-z0-9_]; - any other character is forbidden. Buildroot sets the variable - BR2_EXTERNAL_$(NAME)_PATH to the absolute path of the - br2-external tree, so that you can use it to refer to your - br2-external tree. This variable is available both in Kconfig, so - you can use it to source your Kconfig files (see below) and in - the Makefile, so that you can use it to include other Makefiles - (see below) or refer to other files (like data files) from your - br2-external tree. - - Note: Since it is possible to use multiple br2-external trees at - once, this name is used by Buildroot to generate variables for - each of those trees. That name is used to identify your - br2-external tree, so try to come up with a name that really - describes your br2-external tree, in order for it to be - relatively unique, so that it does not clash with another name - from another br2-external tree, especially if you are planning on - somehow sharing your br2-external tree with third parties or - using br2-external trees from third parties. - - * desc, optional, provides a short description for that - br2-external tree. It shall fit on a single line, is mostly - free-form (see below), and is used when displaying information - about a br2-external tree (e.g. above the list of defconfig - files, or as the prompt in the menuconfig); as such, it should - relatively brief (40 chars is probably a good upper limit). The - description is available in the BR2_EXTERNAL_$(NAME)_DESC - variable. - -Examples of names and the corresponding BR2_EXTERNAL_$(NAME)_PATH -variables: - - * FOO → BR2_EXTERNAL_FOO_PATH - * BAR_42 → BR2_EXTERNAL_BAR_42_PATH - -In the following examples, it is assumed the name to be set to -BAR_42. - -Note: Both BR2_EXTERNAL_$(NAME)_PATH and BR2_EXTERNAL_$(NAME)_DESC -are available in the Kconfig files and the Makefiles. They are also -exported in the environment so are available in post-build, -post-image and in-fakeroot scripts. - -9.2.1.2. The Config.in and external.mk files - -Those files (which may each be empty) can be used to define package -recipes (i.e. foo/Config.in and foo/foo.mk like for packages bundled -in Buildroot itself) or other custom configuration options or make -logic. - -Buildroot automatically includes the Config.in from each br2-external -tree to make it appear in the top-level configuration menu, and -includes the external.mk from each br2-external tree with the rest of -the makefile logic. - -The main usage of this is to store package recipes. The recommended -way to do this is to write a Config.in file that looks like: - -source "$BR2_EXTERNAL_BAR_42_PATH/package/package1/Config.in" -source "$BR2_EXTERNAL_BAR_42_PATH/package/package2/Config.in" - -Then, have an external.mk file that looks like: - -include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/package/*/*.mk)) - -And then in $(BR2_EXTERNAL_BAR_42_PATH)/package/package1 and $ -(BR2_EXTERNAL_BAR_42_PATH)/package/package2 create normal Buildroot -package recipes, as explained in Chapter 18, Adding new packages to -Buildroot. If you prefer, you can also group the packages in -subdirectories called and adapt the above paths -accordingly. - -You can also define custom configuration options in Config.in and -custom make logic in external.mk. - -9.2.1.3. The configs/ directory - -One can store Buildroot defconfigs in the configs subdirectory of the -br2-external tree. Buildroot will automatically show them in the -output of make list-defconfigs and allow them to be loaded with the -normal make _defconfig command. They will be visible in the -make list-defconfigs output, below an External configs label that -contains the name of the br2-external tree they are defined in. - -Note: If a defconfig file is present in more than one br2-external -tree, then the one from the last br2-external tree is used. It is -thus possible to override a defconfig bundled in Buildroot or another -br2-external tree. - -9.2.1.4. The provides/ directory - -For some packages, Buildroot provides a choice between two (or more) -implementations of API-compatible such packages. For example, there -is a choice to choose either libjpeg ot jpeg-turbo; there is one -between openssl or libressl; there is one to select one of the known, -pre-configured toolchains… - -It is possible for a br2-external to extend those choices, by -providing a set of files that define those alternatives: - - * provides/toolchains.in defines the pre-configured toolchains, - which will then be listed in the toolchain selection; - * provides/jpeg.in defines the alternative libjpeg implementations; - * provides/openssl.in defines the alternative openssl - implementations; - * provides/skeleton.in defines the alternative skeleton - implementations; - * provides/init.in defines the alternative init system - implementations, this can be used to select a default skeleton - for your init. - -9.2.1.5. Free-form content - -One can store all the board-specific configuration files there, such -as the kernel configuration, the root filesystem overlay, or any -other configuration file for which Buildroot allows to set the -location (by using the BR2_EXTERNAL_$(NAME)_PATH variable). For -example, you could set the paths to a global patch directory, to a -rootfs overlay and to the kernel configuration file as follows (e.g. -by running make menuconfig and filling in these options): - -BR2_GLOBAL_PATCH_DIR=$(BR2_EXTERNAL_BAR_42_PATH)/patches/ -BR2_ROOTFS_OVERLAY=$(BR2_EXTERNAL_BAR_42_PATH)/board//overlay/ -BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=$(BR2_EXTERNAL_BAR_42_PATH)/board//kernel.config - -9.2.1.6. Additional Linux kernel extensions - -Additional Linux kernel extensions (see Section 18.21.2, -“linux-kernel-extensions”) can be added by storing them in the linux/ -directory at the root of a br2-external tree. - -9.2.1.7. Example layout - -Here is an example layout using all features of br2-external (the -sample content is shown for the file above it, when it is relevant to -explain the br2-external tree; this is all entirely made up just for -the sake of illustration, of course): - -/path/to/br2-ext-tree/ - |- external.desc - | |name: BAR_42 - | |desc: Example br2-external tree - | `---- - | - |- Config.in - | |source "$BR2_EXTERNAL_BAR_42_PATH/toolchain/toolchain-external-mine/Config.in.options" - | |source "$BR2_EXTERNAL_BAR_42_PATH/package/pkg-1/Config.in" - | |source "$BR2_EXTERNAL_BAR_42_PATH/package/pkg-2/Config.in" - | |source "$BR2_EXTERNAL_BAR_42_PATH/package/my-jpeg/Config.in" - | | - | |config BAR_42_FLASH_ADDR - | | hex "my-board flash address" - | | default 0x10AD - | `---- - | - |- external.mk - | |include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/package/*/*.mk)) - | |include $(sort $(wildcard $(BR2_EXTERNAL_BAR_42_PATH)/toolchain/*/*.mk)) - | | - | |flash-my-board: - | | $(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/flash-image \ - | | --image $(BINARIES_DIR)/image.bin \ - | | --address $(BAR_42_FLASH_ADDR) - | `---- - | - |- package/pkg-1/Config.in - | |config BR2_PACKAGE_PKG_1 - | | bool "pkg-1" - | | help - | | Some help about pkg-1 - | `---- - |- package/pkg-1/pkg-1.hash - |- package/pkg-1/pkg-1.mk - | |PKG_1_VERSION = 1.2.3 - | |PKG_1_SITE = /some/where/to/get/pkg-1 - | |PKG_1_LICENSE = blabla - | | - | |define PKG_1_INSTALL_INIT_SYSV - | | $(INSTALL) -D -m 0755 $(PKG_1_PKGDIR)/S99my-daemon \ - | | $(TARGET_DIR)/etc/init.d/S99my-daemon - | |endef - | | - | |$(eval $(autotools-package)) - | `---- - |- package/pkg-1/S99my-daemon - | - |- package/pkg-2/Config.in - |- package/pkg-2/pkg-2.hash - |- package/pkg-2/pkg-2.mk - | - |- provides/jpeg.in - | |config BR2_PACKAGE_MY_JPEG - | | bool "my-jpeg" - | `---- - |- package/my-jpeg/Config.in - | |config BR2_PACKAGE_PROVIDES_JPEG - | | default "my-jpeg" if BR2_PACKAGE_MY_JPEG - | `---- - |- package/my-jpeg/my-jpeg.mk - | |# This is a normal package .mk file - | |MY_JPEG_VERSION = 1.2.3 - | |MY_JPEG_SITE = https://example.net/some/place - | |MY_JPEG_PROVIDES = jpeg - | |$(eval $(autotools-package)) - | `---- - | - |- provides/init.in - | |config BR2_INIT_MINE - | | bool "my custom init" - | | select BR2_PACKAGE_MY_INIT - | | select BR2_PACKAGE_SKELETON_INIT_MINE if BR2_ROOTFS_SKELETON_DEFAULT - | `---- - | - |- provides/skeleton.in - | |config BR2_ROOTFS_SKELETON_MINE - | | bool "my custom skeleton" - | | select BR2_PACKAGE_SKELETON_MINE - | `---- - |- package/skeleton-mine/Config.in - | |config BR2_PACKAGE_SKELETON_MINE - | | bool - | | select BR2_PACKAGE_HAS_SKELETON - | | - | |config BR2_PACKAGE_PROVIDES_SKELETON - | | default "skeleton-mine" if BR2_PACKAGE_SKELETON_MINE - | `---- - |- package/skeleton-mine/skeleton-mine.mk - | |SKELETON_MINE_ADD_TOOLCHAIN_DEPENDENCY = NO - | |SKELETON_MINE_ADD_SKELETON_DEPENDENCY = NO - | |SKELETON_MINE_PROVIDES = skeleton - | |SKELETON_MINE_INSTALL_STAGING = YES - | |$(eval $(generic-package)) - | `---- - | - |- provides/toolchains.in - | |config BR2_TOOLCHAIN_EXTERNAL_MINE - | | bool "my custom toolchain" - | | depends on BR2_some_arch - | | select BR2_INSTALL_LIBSTDCPP - | `---- - |- toolchain/toolchain-external-mine/Config.in.options - | |if BR2_TOOLCHAIN_EXTERNAL_MINE - | |config BR2_TOOLCHAIN_EXTERNAL_PREFIX - | | default "arch-mine-linux-gnu" - | |config BR2_PACKAGE_PROVIDES_TOOLCHAIN_EXTERNAL - | | default "toolchain-external-mine" - | |endif - | `---- - |- toolchain/toolchain-external-mine/toolchain-external-mine.mk - | |TOOLCHAIN_EXTERNAL_MINE_SITE = https://example.net/some/place - | |TOOLCHAIN_EXTERNAL_MINE_SOURCE = my-toolchain.tar.gz - | |$(eval $(toolchain-external-package)) - | `---- - | - |- linux/Config.ext.in - | |config BR2_LINUX_KERNEL_EXT_EXAMPLE_DRIVER - | | bool "example-external-driver" - | | help - | | Example external driver - | |--- - |- linux/linux-ext-example-driver.mk - | - |- configs/my-board_defconfig - | |BR2_GLOBAL_PATCH_DIR="$(BR2_EXTERNAL_BAR_42_PATH)/patches/" - | |BR2_ROOTFS_OVERLAY="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/overlay/" - | |BR2_ROOTFS_POST_IMAGE_SCRIPT="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/post-image.sh" - | |BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE="$(BR2_EXTERNAL_BAR_42_PATH)/board/my-board/kernel.config" - | `---- - | - |- patches/linux/0001-some-change.patch - |- patches/linux/0002-some-other-change.patch - |- patches/busybox/0001-fix-something.patch - | - |- board/my-board/kernel.config - |- board/my-board/overlay/var/www/index.html - |- board/my-board/overlay/var/www/my.css - |- board/my-board/flash-image - `- board/my-board/post-image.sh - |#!/bin/sh - |generate-my-binary-image \ - | --root ${BINARIES_DIR}/rootfs.tar \ - | --kernel ${BINARIES_DIR}/zImage \ - | --dtb ${BINARIES_DIR}/my-board.dtb \ - | --output ${BINARIES_DIR}/image.bin - `---- - -The br2-external tree will then be visible in the menuconfig (with -the layout expanded): - -External options ---> - *** Example br2-external tree (in /path/to/br2-ext-tree/) - [ ] pkg-1 - [ ] pkg-2 - (0x10AD) my-board flash address - -If you are using more than one br2-external tree, it would look like -(with the layout expanded and the second one with name FOO_27 but no -desc: field in external.desc): - -External options ---> - Example br2-external tree ---> - *** Example br2-external tree (in /path/to/br2-ext-tree) - [ ] pkg-1 - [ ] pkg-2 - (0x10AD) my-board flash address - FOO_27 ---> - *** FOO_27 (in /path/to/another-br2-ext) - [ ] foo - [ ] bar - -Additionally, the jpeg provider will be visible in the jpeg choice: - -Target packages ---> - Libraries ---> - Graphics ---> - [*] jpeg support - jpeg variant () ---> - ( ) jpeg - ( ) jpeg-turbo - *** jpeg from: Example br2-external tree *** - (X) my-jpeg - *** jpeg from: FOO_27 *** - ( ) another-jpeg - -And similarly for the toolchains: - -Toolchain ---> - Toolchain () ---> - ( ) Custom toolchain - *** Toolchains from: Example br2-external tree *** - (X) my custom toolchain - -Note. The toolchain options in toolchain/toolchain-external-mine/ -Config.in.options will not appear in the Toolchain menu. They must be -explicitly included from within the br2-external’s top-level -Config.in and will thus appear in the External options menu. - -9.3. Storing the Buildroot configuration - -The Buildroot configuration can be stored using the command make -savedefconfig. - -This strips the Buildroot configuration down by removing -configuration options that are at their default value. The result is -stored in a file called defconfig. If you want to save it in another -place, change the BR2_DEFCONFIG option in the Buildroot configuration -itself, or call make with make savedefconfig BR2_DEFCONFIG= -. - -The recommended place to store this defconfig is configs/ -_defconfig. If you follow this recommendation, the configuration will -be listed in make help and can be set again by running make -_defconfig. - -Alternatively, you can copy the file to any other place and rebuild -with make defconfig BR2_DEFCONFIG=. - -9.4. Storing the configuration of other components - -The configuration files for BusyBox, the Linux kernel, Barebox, -U-Boot and uClibc should be stored as well if changed. For each of -these components, a Buildroot configuration option exists to point to -an input configuration file, e.g. -BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE. To store their configuration, -set these configuration options to a path where you want to save the -configuration files, and then use the helper targets described below -to actually store the configuration. - -As explained in Section 9.1, “Recommended directory structure”, the -recommended path to store these configuration files is board/ -//foo.config. - -Make sure that you create a configuration file before changing the -BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE etc. options. Otherwise, -Buildroot will try to access this config file, which doesn’t exist -yet, and will fail. You can create the configuration file by running -make linux-menuconfig etc. - -Buildroot provides a few helper targets to make the saving of -configuration files easier. - - * make linux-update-defconfig saves the linux configuration to the - path specified by BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE. It - simplifies the config file by removing default values. However, - this only works with kernels starting from 2.6.33. For earlier - kernels, use make linux-update-config. - * make busybox-update-config saves the busybox configuration to the - path specified by BR2_PACKAGE_BUSYBOX_CONFIG. - * make uclibc-update-config saves the uClibc configuration to the - path specified by BR2_UCLIBC_CONFIG. - * make barebox-update-defconfig saves the barebox configuration to - the path specified by BR2_TARGET_BAREBOX_CUSTOM_CONFIG_FILE. - * make uboot-update-defconfig saves the U-Boot configuration to the - path specified by BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE. - * For at91bootstrap3, no helper exists so you have to copy the - config file manually to - BR2_TARGET_AT91BOOTSTRAP3_CUSTOM_CONFIG_FILE. - -9.5. Customizing the generated target filesystem - -Besides changing the configuration through make *config, there are a -few other ways to customize the resulting target filesystem. - -The two recommended methods, which can co-exist, are root filesystem -overlay(s) and post build script(s). - -Root filesystem overlays (BR2_ROOTFS_OVERLAY) - - A filesystem overlay is a tree of files that is copied directly - over the target filesystem after it has been built. To enable - this feature, set config option BR2_ROOTFS_OVERLAY (in the System - configuration menu) to the root of the overlay. You can even - specify multiple overlays, space-separated. If you specify a - relative path, it will be relative to the root of the Buildroot - tree. Hidden directories of version control systems, like .git, - .svn, .hg, etc., files called .empty and files ending in ~ are - excluded from the copy. - - When BR2_ROOTFS_MERGED_USR is enabled, then the overlay must not - contain the /bin, /lib or /sbin directories, as Buildroot will - create them as symbolic links to the relevant folders in /usr. In - such a situation, should the overlay have any programs or - libraries, they should be placed in /usr/bin, /usr/sbin and /usr/ - lib. - - As shown in Section 9.1, “Recommended directory structure”, the - recommended path for this overlay is board/// - rootfs-overlay. - -Post-build scripts (BR2_ROOTFS_POST_BUILD_SCRIPT) - - Post-build scripts are shell scripts called after Buildroot - builds all the selected software, but before the rootfs images - are assembled. To enable this feature, specify a space-separated - list of post-build scripts in config option - BR2_ROOTFS_POST_BUILD_SCRIPT (in the System configuration menu). - If you specify a relative path, it will be relative to the root - of the Buildroot tree. - - Using post-build scripts, you can remove or modify any file in - your target filesystem. You should, however, use this feature - with care. Whenever you find that a certain package generates - wrong or unneeded files, you should fix that package rather than - work around it with some post-build cleanup scripts. - - As shown in Section 9.1, “Recommended directory structure”, the - recommended path for this script is board/// - post_build.sh. - - The post-build scripts are run with the main Buildroot tree as - current working directory. The path to the target filesystem is - passed as the first argument to each script. If the config option - BR2_ROOTFS_POST_SCRIPT_ARGS is not empty, these arguments will be - passed to the script too. All the scripts will be passed the - exact same set of arguments, it is not possible to pass different - sets of arguments to each script. - - In addition, you may also use these environment variables: - - + BR2_CONFIG: the path to the Buildroot .config file - + CONFIG_DIR: the directory containing the .config file, and - therefore the top-level Buildroot Makefile to use (which is - correct for both in-tree and out-of-tree builds) - + HOST_DIR, STAGING_DIR, TARGET_DIR: see Section 18.5.2, - “generic-package reference” - + BUILD_DIR: the directory where packages are extracted and - built - + BINARIES_DIR: the place where all binary files (aka images) - are stored - + BASE_DIR: the base output directory - -Below three more methods of customizing the target filesystem are -described, but they are not recommended. - -Direct modification of the target filesystem - - For temporary modifications, you can modify the target filesystem - directly and rebuild the image. The target filesystem is - available under output/target/. After making your changes, run - make to rebuild the target filesystem image. - - This method allows you to do anything to the target filesystem, - but if you need to clean your Buildroot tree using make clean, - these changes will be lost. Such cleaning is necessary in several - cases, refer to Section 8.2, “Understanding when a full rebuild - is necessary” for details. This solution is therefore only useful - for quick tests: changes do not survive the make clean command. - Once you have validated your changes, you should make sure that - they will persist after a make clean, using a root filesystem - overlay or a post-build script. - -Custom target skeleton (BR2_ROOTFS_SKELETON_CUSTOM) - - The root filesystem image is created from a target skeleton, on - top of which all packages install their files. The skeleton is - copied to the target directory output/target before any package - is built and installed. The default target skeleton provides the - standard Unix filesystem layout and some basic init scripts and - configuration files. - - If the default skeleton (available under system/skeleton) does - not match your needs, you would typically use a root filesystem - overlay or post-build script to adapt it. However, if the default - skeleton is entirely different than what you need, using a custom - skeleton may be more suitable. - - To enable this feature, enable config option - BR2_ROOTFS_SKELETON_CUSTOM and set - BR2_ROOTFS_SKELETON_CUSTOM_PATH to the path of your custom - skeleton. Both options are available in the System configuration - menu. If you specify a relative path, it will be relative to the - root of the Buildroot tree. - - Custom skeletons don’t need to contain the /bin, /lib or /sbin - directories, since they are created automatically during the - build. When BR2_ROOTFS_MERGED_USR is enabled, then the custom - skeleton must not contain the /bin, /lib or /sbin directories, as - Buildroot will create them as symbolic links to the relevant - folders in /usr. In such a situation, should the skeleton have - any programs or libraries, they should be placed in /usr/bin, / - usr/sbin and /usr/lib. - - This method is not recommended because it duplicates the entire - skeleton, which prevents taking advantage of the fixes or - improvements brought to the default skeleton in later Buildroot - releases. - -Post-fakeroot scripts (BR2_ROOTFS_POST_FAKEROOT_SCRIPT) - - When aggregating the final images, some parts of the process - requires root rights: creating device nodes in /dev, setting - permissions or ownership to files and directories… To avoid - requiring actual root rights, Buildroot uses fakeroot to simulate - root rights. This is not a complete substitute for actually being - root, but is enough for what Buildroot needs. - - Post-fakeroot scripts are shell scripts that are called at the - end of the fakeroot phase, right before the filesystem image - generator is called. As such, they are called in the fakeroot - context. - - Post-fakeroot scripts can be useful in case you need to tweak the - filesystem to do modifications that are usually only available to - the root user. - - Note: It is recommended to use the existing mechanisms to set - file permissions or create entries in /dev (see Section 9.5.1, - “Setting file permissions and ownership and adding custom devices - nodes”) or to create users (see Section 9.6, “Adding custom user - accounts”) - - Note: The difference between post-build scripts (above) and - fakeroot scripts, is that post-build scripts are not called in - the fakeroot context. - - Note: Using fakeroot is not an absolute substitute for actually - being root. fakeroot only ever fakes the file access rights and - types (regular, block-or-char device…) and uid/gid; these are - emulated in-memory. - -9.5.1. Setting file permissions and ownership and adding custom -devices nodes - -Sometimes it is needed to set specific permissions or ownership on -files or device nodes. For example, certain files may need to be -owned by root. Since the post-build scripts are not run as root, you -cannot do such changes from there unless you use an explicit fakeroot -from the post-build script. - -Instead, Buildroot provides support for so-called permission tables. -To use this feature, set config option BR2_ROOTFS_DEVICE_TABLE to a -space-separated list of permission tables, regular text files -following the makedev syntax. - -If you are using a static device table (i.e. not using devtmpfs, -mdev, or (e)udev) then you can add device nodes using the same -syntax, in so-called device tables. To use this feature, set config -option BR2_ROOTFS_STATIC_DEVICE_TABLE to a space-separated list of -device tables. - -As shown in Section 9.1, “Recommended directory structure”, the -recommended location for such files is board///. - -It should be noted that if the specific permissions or device nodes -are related to a specific application, you should set variables -FOO_PERMISSIONS and FOO_DEVICES in the package’s .mk file instead -(see Section 18.5.2, “generic-package reference”). - -9.6. Adding custom user accounts - -Sometimes it is needed to add specific users in the target system. To -cover this requirement, Buildroot provides support for so-called -users tables. To use this feature, set config option -BR2_ROOTFS_USERS_TABLES to a space-separated list of users tables, -regular text files following the makeusers syntax. - -As shown in Section 9.1, “Recommended directory structure”, the -recommended location for such files is board///. - -It should be noted that if the custom users are related to a specific -application, you should set variable FOO_USERS in the package’s .mk -file instead (see Section 18.5.2, “generic-package reference”). - -9.7. Customization after the images have been created - -While post-build scripts (Section 9.5, “Customizing the generated -target filesystem”) are run before building the filesystem image, -kernel and bootloader, post-image scripts can be used to perform some -specific actions after all images have been created. - -Post-image scripts can for example be used to automatically extract -your root filesystem tarball in a location exported by your NFS -server, or to create a special firmware image that bundles your root -filesystem and kernel image, or any other custom action required for -your project. - -To enable this feature, specify a space-separated list of post-image -scripts in config option BR2_ROOTFS_POST_IMAGE_SCRIPT (in the System -configuration menu). If you specify a relative path, it will be -relative to the root of the Buildroot tree. - -Just like post-build scripts, post-image scripts are run with the -main Buildroot tree as current working directory. The path to the -images output directory is passed as the first argument to each -script. If the config option BR2_ROOTFS_POST_SCRIPT_ARGS is not -empty, these arguments will be passed to the script too. All the -scripts will be passed the exact same set of arguments, it is not -possible to pass different sets of arguments to each script. - -Again just like for the post-build scripts, the scripts have access -to the environment variables BR2_CONFIG, HOST_DIR, STAGING_DIR, -TARGET_DIR, BUILD_DIR, BINARIES_DIR, CONFIG_DIR and BASE_DIR. - -The post-image scripts will be executed as the user that executes -Buildroot, which should normally not be the root user. Therefore, any -action requiring root permissions in one of these scripts will -require special handling (usage of fakeroot or sudo), which is left -to the script developer. - -9.8. Adding project-specific patches - -It is sometimes useful to apply extra patches to packages - on top of -those provided in Buildroot. This might be used to support custom -features in a project, for example, or when working on a new -architecture. - -The BR2_GLOBAL_PATCH_DIR configuration option can be used to specify -a space separated list of one or more directories containing package -patches. - -For a specific version of a specific package -, patches are applied from BR2_GLOBAL_PATCH_DIR as -follows: - - 1. For every directory - - that exists in - BR2_GLOBAL_PATCH_DIR, a will be determined as - follows: - - + /// if the - directory exists. - + Otherwise, / if the directory - exists. - 2. Patches will then be applied from a as - follows: - - + If a series file exists in the package directory, then - patches are applied according to the series file; - + Otherwise, patch files matching *.patch are applied in - alphabetical order. So, to ensure they are applied in the - right order, it is highly recommended to name the patch files - like this: -.patch, where - refers to the apply order. - -For information about how patches are applied for a package, see -Section 19.2, “How patches are applied” - -The BR2_GLOBAL_PATCH_DIR option is the preferred method for -specifying a custom patch directory for packages. It can be used to -specify a patch directory for any package in buildroot. It should -also be used in place of the custom patch directory options that are -available for packages such as U-Boot and Barebox. By doing this, it -will allow a user to manage their patches from one top-level -directory. - -The exception to BR2_GLOBAL_PATCH_DIR being the preferred method for -specifying custom patches is BR2_LINUX_KERNEL_PATCH. -BR2_LINUX_KERNEL_PATCH should be used to specify kernel patches that -are available at a URL. Note: BR2_LINUX_KERNEL_PATCH specifies kernel -patches that are applied after patches available in -BR2_GLOBAL_PATCH_DIR, as it is done from a post-patch hook of the -Linux package. - -9.9. Adding project-specific packages - -In general, any new package should be added directly in the package -directory and submitted to the Buildroot upstream project. How to add -packages to Buildroot in general is explained in full detail in -Chapter 18, Adding new packages to Buildroot and will not be repeated -here. However, your project may need some proprietary packages that -cannot be upstreamed. This section will explain how you can keep such -project-specific packages in a project-specific directory. - -As shown in Section 9.1, “Recommended directory structure”, the -recommended location for project-specific packages is package/ -/. If you are using the br2-external tree feature (see -Section 9.2, “Keeping customizations outside of Buildroot”) the -recommended location is to put them in a sub-directory named package/ -in your br2-external tree. - -However, Buildroot will not be aware of the packages in this -location, unless we perform some additional steps. As explained in -Chapter 18, Adding new packages to Buildroot, a package in Buildroot -basically consists of two files: a .mk file (describing how to build -the package) and a Config.in file (describing the configuration -options for this package). - -Buildroot will automatically include the .mk files in first-level -subdirectories of the package directory (using the pattern package/*/ -*.mk). If we want Buildroot to include .mk files from deeper -subdirectories (like package//package1/) then we simply have -to add a .mk file in a first-level subdirectory that includes these -additional .mk files. Therefore, create a file package// -.mk with following contents (assuming you have only one -extra directory level below package//): - -include $(sort $(wildcard package//*/*.mk)) - -For the Config.in files, create a file package//Config.in -that includes the Config.in files of all your packages. An exhaustive -list has to be provided since wildcards are not supported in the -source command of kconfig. For example: - -source "package//package1/Config.in" -source "package//package2/Config.in" - -Include this new file package//Config.in from package/ -Config.in, preferably in a company-specific menu to make merges with -future Buildroot versions easier. - -If using a br2-external tree, refer to Section 9.2, “Keeping -customizations outside of Buildroot” for how to fill in those files. - -9.10. Quick guide to storing your project-specific customizations - -Earlier in this chapter, the different methods for making -project-specific customizations have been described. This section -will now summarize all this by providing step-by-step instructions to -storing your project-specific customizations. Clearly, the steps that -are not relevant to your project can be skipped. - - 1. make menuconfig to configure toolchain, packages and kernel. - 2. make linux-menuconfig to update the kernel config, similar for - other configuration like busybox, uclibc, … - 3. mkdir -p board// - 4. Set the following options to board/// - .config (as far as they are relevant): - - + BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE - + BR2_PACKAGE_BUSYBOX_CONFIG - + BR2_UCLIBC_CONFIG - + BR2_TARGET_AT91BOOTSTRAP3_CUSTOM_CONFIG_FILE - + BR2_TARGET_BAREBOX_CUSTOM_CONFIG_FILE - + BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE - 5. Write the configuration files: - - + make linux-update-defconfig - + make busybox-update-config - + make uclibc-update-config - + cp /build/at91bootstrap3-*/.config board/ - //at91bootstrap3.config - + make barebox-update-defconfig - + make uboot-update-defconfig - 6. Create board///rootfs-overlay/ and fill - it with additional files you need on your rootfs, e.g. board/ - //rootfs-overlay/etc/inittab. Set - BR2_ROOTFS_OVERLAY to board/// - rootfs-overlay. - 7. Create a post-build script board/// - post_build.sh. Set BR2_ROOTFS_POST_BUILD_SCRIPT to board/ - //post_build.sh - 8. If additional setuid permissions have to be set or device nodes - have to be created, create board/// - device_table.txt and add that path to BR2_ROOTFS_DEVICE_TABLE. - 9. If additional user accounts have to be created, create board/ - //users_table.txt and add that path to - BR2_ROOTFS_USERS_TABLES. -10. To add custom patches to certain packages, set - BR2_GLOBAL_PATCH_DIR to board///patches/ - and add your patches for each package in a subdirectory named - after the package. Each patch should be called - - -.patch. -11. Specifically for the Linux kernel, there also exists the option - BR2_LINUX_KERNEL_PATCH with as main advantage that it can also - download patches from a URL. If you do not need this, - BR2_GLOBAL_PATCH_DIR is preferred. U-Boot, Barebox, at91bootstrap - and at91bootstrap3 also have separate options, but these do not - provide any advantage over BR2_GLOBAL_PATCH_DIR and will likely - be removed in the future. -12. If you need to add project-specific packages, create package/ - / and place your packages in that directory. Create - an overall .mk file that includes the .mk files of - all your packages. Create an overall Config.in file that sources - the Config.in files of all your packages. Include this Config.in - file from Buildroot’s package/Config.in file. -13. make savedefconfig to save the buildroot configuration. -14. cp defconfig configs/_defconfig - -Chapter 10. Using SELinux in Buildroot - -SELinux [https://selinuxproject.org] is a Linux kernel security -module enforcing access control policies. In addition to the -traditional file permissions and access control lists, SELinux allows -to write rules for users or processes to access specific functions of -resources (files, sockets…). - -SELinux has three modes of operation: - - * Disabled: the policy is not applied - * Permissive: the policy is applied, and non-authorized actions are - simply logged. This mode is often used for troubleshooting - SELinux issues. - * Enforcing: the policy is applied, and non-authorized actions are - denied - -In Buildroot the mode of operation is controlled by the -BR2_PACKAGE_REFPOLICY_POLICY_STATE_* configuration options. The Linux -kernel also has various configuration options that affect how SELinux -is enabled (see security/selinux/Kconfig in the Linux kernel -sources). - -By default in Buildroot the SELinux policy is provided by the -upstream refpolicy [https://github.com/SELinuxProject/refpolicy] -project, enabled with BR2_PACKAGE_REFPOLICY. - -10.1. Enabling SELinux support - -To have proper support for SELinux in a Buildroot generated system, -the following configuration options must be enabled: - - * BR2_PACKAGE_LIBSELINUX - * BR2_PACKAGE_REFPOLICY - -In addition, your filesystem image format must support extended -attributes. - -10.2. SELinux policy tweaking - -The SELinux refpolicy contains modules that can be enabled or -disabled when being built. Each module provide a number of SELinux -rules. In Buildroot the non-base modules are disabled by default and -several ways to enable such modules are provided: - - * Packages can enable a list of SELinux modules within the - refpolicy using the _SELINUX_MODULES variable. - * Packages can provide additional SELinux modules by putting them - (.fc, .if and .te files) in package//selinux/. - * Extra SELinux modules can be added in directories pointed by the - BR2_REFPOLICY_EXTRA_MODULES_DIRS configuration option. - * Additional modules in the refpolicy can be enabled if listed in - the BR2_REFPOLICY_EXTRA_MODULES_DEPENDENCIES configuration - option. - -Buildroot also allows to completely override the refpolicy. This -allows to provide a full custom policy designed specifically for a -given system. When going this way, all of the above mechanisms are -disabled: no extra SElinux module is added to the policy, and all the -available modules within the custom policy are enabled and built into -the final binary policy. The custom policy must be a fork of the -official refpolicy [https://github.com/SELinuxProject/refpolicy]. - -In order to fully override the refpolicy the following configuration -variables have to be set: - - * BR2_PACKAGE_REFPOLICY_CUSTOM_GIT - * BR2_PACKAGE_REFPOLICY_CUSTOM_REPO_URL - * BR2_PACKAGE_REFPOLICY_CUSTOM_REPO_VERSION - -Chapter 11. Frequently Asked Questions & Troubleshooting - -11.1. The boot hangs after Starting network… - -If the boot process seems to hang after the following messages -(messages not necessarily exactly similar, depending on the list of -packages selected): - -Freeing init memory: 3972K -Initializing random number generator... done. -Starting network... -Starting dropbear sshd: generating rsa key... generating dsa key... OK - -then it means that your system is running, but didn’t start a shell -on the serial console. In order to have the system start a shell on -your serial console, you have to go into the Buildroot configuration, -in System configuration, modify Run a getty (login prompt) after boot -and set the appropriate port and baud rate in the getty options -submenu. This will automatically tune the /etc/inittab file of the -generated system so that a shell starts on the correct serial port. - -11.2. Why is there no compiler on the target? - -It has been decided that support for the native compiler on the -target would be stopped from the Buildroot-2012.11 release because: - - * this feature was neither maintained nor tested, and often broken; - * this feature was only available for Buildroot toolchains; - * Buildroot mostly targets small or very small target hardware with - limited resource onboard (CPU, ram, mass-storage), for which - compiling on the target does not make much sense; - * Buildroot aims at easing the cross-compilation, making native - compilation on the target unnecessary. - -If you need a compiler on your target anyway, then Buildroot is not -suitable for your purpose. In such case, you need a real distribution -and you should opt for something like: - - * openembedded [http://www.openembedded.org] - * yocto [https://www.yoctoproject.org] - * emdebian [http://www.emdebian.org] - * Fedora [https://fedoraproject.org/wiki/Architectures] - * openSUSE ARM [http://en.opensuse.org/Portal:ARM] - * Arch Linux ARM [http://archlinuxarm.org] - * … - -11.3. Why are there no development files on the target? - -Since there is no compiler available on the target (see Section 11.2, -“Why is there no compiler on the target?”), it does not make sense to -waste space with headers or static libraries. - -Therefore, those files are always removed from the target since the -Buildroot-2012.11 release. - -11.4. Why is there no documentation on the target? - -Because Buildroot mostly targets small or very small target hardware -with limited resource onboard (CPU, ram, mass-storage), it does not -make sense to waste space with the documentation data. - -If you need documentation data on your target anyway, then Buildroot -is not suitable for your purpose, and you should look for a real -distribution (see: Section 11.2, “Why is there no compiler on the -target?”). - -11.5. Why are some packages not visible in the Buildroot config menu? - -If a package exists in the Buildroot tree and does not appear in the -config menu, this most likely means that some of the package’s -dependencies are not met. - -To know more about the dependencies of a package, search for the -package symbol in the config menu (see Section 8.1, “make tips”). - -Then, you may have to recursively enable several options (which -correspond to the unmet dependencies) to finally be able to select -the package. - -If the package is not visible due to some unmet toolchain options, -then you should certainly run a full rebuild (see Section 8.1, “make -tips” for more explanations). - -11.6. Why not use the target directory as a chroot directory? - -There are plenty of reasons to not use the target directory a chroot -one, among these: - - * file ownerships, modes and permissions are not correctly set in - the target directory; - * device nodes are not created in the target directory. - -For these reasons, commands run through chroot, using the target -directory as the new root, will most likely fail. - -If you want to run the target filesystem inside a chroot, or as an -NFS root, then use the tarball image generated in images/ and extract -it as root. - -11.7. Why doesn’t Buildroot generate binary packages (.deb, .ipkg…)? - -One feature that is often discussed on the Buildroot list is the -general topic of "package management". To summarize, the idea would -be to add some tracking of which Buildroot package installs what -files, with the goals of: - - * being able to remove files installed by a package when this - package gets unselected from the menuconfig; - * being able to generate binary packages (ipk or other format) that - can be installed on the target without re-generating a new root - filesystem image. - -In general, most people think it is easy to do: just track which -package installed what and remove it when the package is unselected. -However, it is much more complicated than that: - - * It is not only about the target/ directory, but also the sysroot - in host//sysroot and the host/ directory itself. All files - installed in those directories by various packages must be - tracked. - * When a package is unselected from the configuration, it is not - sufficient to remove just the files it installed. One must also - remove all its reverse dependencies (i.e. packages relying on it) - and rebuild all those packages. For example, package A depends - optionally on the OpenSSL library. Both are selected, and - Buildroot is built. Package A is built with crypto support using - OpenSSL. Later on, OpenSSL gets unselected from the - configuration, but package A remains (since OpenSSL is an - optional dependency, this is possible.) If only OpenSSL files are - removed, then the files installed by package A are broken: they - use a library that is no longer present on the target. Although - this is technically doable, it adds a lot of complexity to - Buildroot, which goes against the simplicity we try to stick to. - * In addition to the previous problem, there is the case where the - optional dependency is not even known to Buildroot. For example, - package A in version 1.0 never used OpenSSL, but in version 2.0 - it automatically uses OpenSSL if available. If the Buildroot .mk - file hasn’t been updated to take this into account, then package - A will not be part of the reverse dependencies of OpenSSL and - will not be removed and rebuilt when OpenSSL is removed. For - sure, the .mk file of package A should be fixed to mention this - optional dependency, but in the mean time, you can have - non-reproducible behaviors. - * The request is to also allow changes in the menuconfig to be - applied on the output directory without having to rebuild - everything from scratch. However, this is very difficult to - achieve in a reliable way: what happens when the suboptions of a - package are changed (we would have to detect this, and rebuild - the package from scratch and potentially all its reverse - dependencies), what happens if toolchain options are changed, - etc. At the moment, what Buildroot does is clear and simple so - its behaviour is very reliable and it is easy to support users. - If configuration changes done in menuconfig are applied after the - next make, then it has to work correctly and properly in all - situations, and not have some bizarre corner cases. The risk is - to get bug reports like "I have enabled package A, B and C, then - ran make, then disabled package C and enabled package D and ran - make, then re-enabled package C and enabled package E and then - there is a build failure". Or worse "I did some configuration, - then built, then did some changes, built, some more changes, - built, some more changes, built, and now it fails, but I don’t - remember all the changes I did and in which order". This will be - impossible to support. - -For all these reasons, the conclusion is that adding tracking of -installed files to remove them when the package is unselected, or to -generate a repository of binary packages, is something that is very -hard to achieve reliably and will add a lot of complexity. - -On this matter, the Buildroot developers make this position -statement: - - * Buildroot strives to make it easy to generate a root filesystem - (hence the name, by the way.) That is what we want to make - Buildroot good at: building root filesystems. - * Buildroot is not meant to be a distribution (or rather, a - distribution generator.) It is the opinion of most Buildroot - developers that this is not a goal we should pursue. We believe - that there are other tools better suited to generate a distro - than Buildroot is. For example, Open Embedded [http:// - openembedded.org/], or openWRT [https://openwrt.org/], are such - tools. - * We prefer to push Buildroot in a direction that makes it easy (or - even easier) to generate complete root filesystems. This is what - makes Buildroot stands out in the crowd (among other things, of - course!) - * We believe that for most embedded Linux systems, binary packages - are not necessary, and potentially harmful. When binary packages - are used, it means that the system can be partially upgraded, - which creates an enormous number of possible combinations of - package versions that should be tested before doing the upgrade - on the embedded device. On the other hand, by doing complete - system upgrades by upgrading the entire root filesystem image at - once, the image deployed to the embedded system is guaranteed to - really be the one that has been tested and validated. - -11.8. How to speed-up the build process? - -Since Buildroot often involves doing full rebuilds of the entire -system that can be quite long, we provide below a number of tips to -help reduce the build time: - - * Use a pre-built external toolchain instead of the default - Buildroot internal toolchain. By using a pre-built Linaro - toolchain (on ARM) or a Sourcery CodeBench toolchain (for ARM, - x86, x86-64, MIPS, etc.), you will save the build time of the - toolchain at each complete rebuild, approximately 15 to 20 - minutes. Note that temporarily using an external toolchain does - not prevent you to switch back to an internal toolchain (that may - provide a higher level of customization) once the rest of your - system is working; - * Use the ccache compiler cache (see: Section 8.14.3, “Using ccache - in Buildroot”); - * Learn about rebuilding only the few packages you actually care - about (see Section 8.3, “Understanding how to rebuild packages”), - but beware that sometimes full rebuilds are anyway necessary (see - Section 8.2, “Understanding when a full rebuild is necessary”); - * Make sure you are not using a virtual machine for the Linux - system used to run Buildroot. Most of the virtual machine - technologies are known to cause a significant performance impact - on I/O, which is really important for building source code; - * Make sure that you’re using only local files: do not attempt to - do a build over NFS, which significantly slows down the build. - Having the Buildroot download folder available locally also helps - a bit. - * Buy new hardware. SSDs and lots of RAM are key to speeding up the - builds. - * Experiment with top-level parallel build, see Section 8.12, - “Top-level parallel build”. - -Chapter 12. Known issues - - * It is not possible to pass extra linker options via - BR2_TARGET_LDFLAGS if such options contain a $ sign. For example, - the following is known to break: BR2_TARGET_LDFLAGS="-Wl,-rpath= - '$ORIGIN/../lib'" - * The libffi package is not supported on the SuperH 2 and ARC - architectures. - * The prboom package triggers a compiler failure with the SuperH 4 - compiler from Sourcery CodeBench, version 2012.09. - -Chapter 13. Legal notice and licensing - -13.1. Complying with open source licenses - -All of the end products of Buildroot (toolchain, root filesystem, -kernel, bootloaders) contain open source software, released under -various licenses. - -Using open source software gives you the freedom to build rich -embedded systems, choosing from a wide range of packages, but also -imposes some obligations that you must know and honour. Some licenses -require you to publish the license text in the documentation of your -product. Others require you to redistribute the source code of the -software to those that receive your product. - -The exact requirements of each license are documented in each -package, and it is your responsibility (or that of your legal office) -to comply with those requirements. To make this easier for you, -Buildroot can collect for you some material you will probably need. -To produce this material, after you have configured Buildroot with -make menuconfig, make xconfig or make gconfig, run: - -make legal-info - -Buildroot will collect legally-relevant material in your output -directory, under the legal-info/ subdirectory. There you will find: - - * A README file, that summarizes the produced material and contains - warnings about material that Buildroot could not produce. - * buildroot.config: this is the Buildroot configuration file that - is usually produced with make menuconfig, and which is necessary - to reproduce the build. - * The source code for all packages; this is saved in the sources/ - and host-sources/ subdirectories for target and host packages - respectively. The source code for packages that set - _REDISTRIBUTE = NO will not be saved. Patches that were applied - are also saved, along with a file named series that lists the - patches in the order they were applied. Patches are under the - same license as the files that they modify. Note: Buildroot - applies additional patches to Libtool scripts of autotools-based - packages. These patches can be found under support/libtool in the - Buildroot source and, due to technical limitations, are not saved - with the package sources. You may need to collect them manually. - * A manifest file (one for host and one for target packages) - listing the configured packages, their version, license and - related information. Some of this information might not be - defined in Buildroot; such items are marked as "unknown". - * The license texts of all packages, in the licenses/ and - host-licenses/ subdirectories for target and host packages - respectively. If the license file(s) are not defined in - Buildroot, the file is not produced and a warning in the README - indicates this. - -Please note that the aim of the legal-info feature of Buildroot is to -produce all the material that is somehow relevant for legal -compliance with the package licenses. Buildroot does not try to -produce the exact material that you must somehow make public. -Certainly, more material is produced than is needed for a strict -legal compliance. For example, it produces the source code for -packages released under BSD-like licenses, that you are not required -to redistribute in source form. - -Moreover, due to technical limitations, Buildroot does not produce -some material that you will or may need, such as the toolchain source -code for some of the external toolchains and the Buildroot source -code itself. When you run make legal-info, Buildroot produces -warnings in the README file to inform you of relevant material that -could not be saved. - -Finally, keep in mind that the output of make legal-info is based on -declarative statements in each of the packages recipes. The Buildroot -developers try to do their best to keep those declarative statements -as accurate as possible, to the best of their knowledge. However, it -is very well possible that those declarative statements are not all -fully accurate nor exhaustive. You (or your legal department) have to -check the output of make legal-info before using it as your own -compliance delivery. See the NO WARRANTY clauses (clauses 11 and 12) -in the COPYING file at the root of the Buildroot distribution. - -13.2. Complying with the Buildroot license - -Buildroot itself is an open source software, released under the GNU -General Public License, version 2 [http://www.gnu.org/licenses/ -old-licenses/gpl-2.0.html] or (at your option) any later version, -with the exception of the package patches detailed below. However, -being a build system, it is not normally part of the end product: if -you develop the root filesystem, kernel, bootloader or toolchain for -a device, the code of Buildroot is only present on the development -machine, not in the device storage. - -Nevertheless, the general view of the Buildroot developers is that -you should release the Buildroot source code along with the source -code of other packages when releasing a product that contains -GPL-licensed software. This is because the GNU GPL [http:// -www.gnu.org/licenses/old-licenses/gpl-2.0.html] defines the "complete -source code" for an executable work as "all the source code for all -modules it contains, plus any associated interface definition files, -plus the scripts used to control compilation and installation of the -executable". Buildroot is part of the scripts used to control -compilation and installation of the executable, and as such it is -considered part of the material that must be redistributed. - -Keep in mind that this is only the Buildroot developers' opinion, and -you should consult your legal department or lawyer in case of any -doubt. - -13.2.1. Patches to packages - -Buildroot also bundles patch files, which are applied to the sources -of the various packages. Those patches are not covered by the license -of Buildroot. Instead, they are covered by the license of the -software to which the patches are applied. When said software is -available under multiple licenses, the Buildroot patches are only -provided under the publicly accessible licenses. - -See Chapter 19, Patching a package for the technical details. - -Chapter 14. Beyond Buildroot - -14.1. Boot the generated images - -14.1.1. NFS boot - -To achieve NFS-boot, enable tar root filesystem in the Filesystem -images menu. - -After a complete build, just run the following commands to setup the -NFS-root directory: - -sudo tar -xavf /path/to/output_dir/rootfs.tar -C /path/to/nfs_root_dir - -Remember to add this path to /etc/exports. - -Then, you can execute a NFS-boot from your target. - -14.1.2. Live CD - -To build a live CD image, enable the iso image option in the -Filesystem images menu. Note that this option is only available on -the x86 and x86-64 architectures, and if you are building your kernel -with Buildroot. - -You can build a live CD image with either IsoLinux, Grub or Grub 2 as -a bootloader, but only Isolinux supports making this image usable -both as a live CD and live USB (through the Build hybrid image -option). - -You can test your live CD image using QEMU: - -qemu-system-i386 -cdrom output/images/rootfs.iso9660 - -Or use it as a hard-drive image if it is a hybrid ISO: - -qemu-system-i386 -hda output/images/rootfs.iso9660 - -It can be easily flashed to a USB drive with dd: - -dd if=output/images/rootfs.iso9660 of=/dev/sdb - -14.2. Chroot - -If you want to chroot in a generated image, then there are few thing -you should be aware of: - - * you should setup the new root from the tar root filesystem image; - * either the selected target architecture is compatible with your - host machine, or you should use some qemu-* binary and correctly - set it within the binfmt properties to be able to run the - binaries built for the target on your host machine; - * Buildroot does not currently provide host-qemu and binfmt - correctly built and set for that kind of use. - -Part III. Developer guide - -Table of Contents - -15. How Buildroot works -16. Coding style - - 16.1. Config.in file - 16.2. The .mk file - 16.3. The documentation - 16.4. Support scripts - -17. Adding support for a particular board -18. Adding new packages to Buildroot - - 18.1. Package directory - 18.2. Config files - 18.3. The .mk file - 18.4. The .hash file - 18.5. Infrastructure for packages with specific build systems - 18.6. Infrastructure for autotools-based packages - 18.7. Infrastructure for CMake-based packages - 18.8. Infrastructure for Python packages - 18.9. Infrastructure for LuaRocks-based packages - 18.10. Infrastructure for Perl/CPAN packages - 18.11. Infrastructure for virtual packages - 18.12. Infrastructure for packages using kconfig for - configuration files - 18.13. Infrastructure for rebar-based packages - 18.14. Infrastructure for Waf-based packages - 18.15. Infrastructure for Meson-based packages - 18.16. Integration of Cargo-based packages - 18.17. Infrastructure for Go packages - 18.18. Infrastructure for QMake-based packages - 18.19. Infrastructure for packages building kernel modules - 18.20. Infrastructure for asciidoc documents - 18.21. Infrastructure specific to the Linux kernel package - 18.22. Hooks available in the various build steps - 18.23. Gettext integration and interaction with packages - 18.24. Tips and tricks - 18.25. Conclusion - -19. Patching a package - - 19.1. Providing patches - 19.2. How patches are applied - 19.3. Format and licensing of the package patches - 19.4. Integrating patches found on the Web - -20. Download infrastructure -21. Debugging Buildroot -22. Contributing to Buildroot - - 22.1. Reproducing, analyzing and fixing bugs - 22.2. Analyzing and fixing autobuild failures - 22.3. Reviewing and testing patches - 22.4. Work on items from the TODO list - 22.5. Submitting patches - 22.6. Reporting issues/bugs or getting help - 22.7. Using the runtime tests framework - -23. DEVELOPERS file and get-developers -24. Release Engineering - - 24.1. Releases - 24.2. Development - -Chapter 15. How Buildroot works - -As mentioned above, Buildroot is basically a set of Makefiles that -download, configure, and compile software with the correct options. -It also includes patches for various software packages - mainly the -ones involved in the cross-compilation toolchain (gcc, binutils and -uClibc). - -There is basically one Makefile per software package, and they are -named with the .mk extension. Makefiles are split into many different -parts. - - * The toolchain/ directory contains the Makefiles and associated - files for all software related to the cross-compilation - toolchain: binutils, gcc, gdb, kernel-headers and uClibc. - * The arch/ directory contains the definitions for all the - processor architectures that are supported by Buildroot. - * The package/ directory contains the Makefiles and associated - files for all user-space tools and libraries that Buildroot can - compile and add to the target root filesystem. There is one - sub-directory per package. - * The linux/ directory contains the Makefiles and associated files - for the Linux kernel. - * The boot/ directory contains the Makefiles and associated files - for the bootloaders supported by Buildroot. - * The system/ directory contains support for system integration, - e.g. the target filesystem skeleton and the selection of an init - system. - * The fs/ directory contains the Makefiles and associated files for - software related to the generation of the target root filesystem - image. - -Each directory contains at least 2 files: - - * something.mk is the Makefile that downloads, configures, compiles - and installs the package something. - * Config.in is a part of the configuration tool description file. - It describes the options related to the package. - -The main Makefile performs the following steps (once the -configuration is done): - - * Create all the output directories: staging, target, build, etc. - in the output directory (output/ by default, another value can be - specified using O=) - * Generate the toolchain target. When an internal toolchain is - used, this means generating the cross-compilation toolchain. When - an external toolchain is used, this means checking the features - of the external toolchain and importing it into the Buildroot - environment. - * Generate all the targets listed in the TARGETS variable. This - variable is filled by all the individual components' Makefiles. - Generating these targets will trigger the compilation of the - userspace packages (libraries, programs), the kernel, the - bootloader and the generation of the root filesystem images, - depending on the configuration. - -Chapter 16. Coding style - -Overall, these coding style rules are here to help you to add new -files in Buildroot or refactor existing ones. - -If you slightly modify some existing file, the important thing is to -keep the consistency of the whole file, so you can: - - * either follow the potentially deprecated coding style used in - this file, - * or entirely rework it in order to make it comply with these - rules. - -16.1. Config.in file - -Config.in files contain entries for almost anything configurable in -Buildroot. - -An entry has the following pattern: - -config BR2_PACKAGE_LIBFOO - bool "libfoo" - depends on BR2_PACKAGE_LIBBAZ - select BR2_PACKAGE_LIBBAR - help - This is a comment that explains what libfoo is. The help text - should be wrapped. - - http://foosoftware.org/libfoo/ - - * The bool, depends on, select and help lines are indented with one - tab. - * The help text itself should be indented with one tab and two - spaces. - * The help text should be wrapped to fit 72 columns, where tab - counts for 8, so 62 characters in the text itself. - -The Config.in files are the input for the configuration tool used in -Buildroot, which is the regular Kconfig. For further details about -the Kconfig language, refer to http://kernel.org/doc/Documentation/ -kbuild/kconfig-language.txt. - -16.2. The .mk file - - * Header: The file starts with a header. It contains the module - name, preferably in lowercase, enclosed between separators made - of 80 hashes. A blank line is mandatory after the header: - - ################################################################################ - # - # libfoo - # - ################################################################################ - - * Assignment: use = preceded and followed by one space: - - LIBFOO_VERSION = 1.0 - LIBFOO_CONF_OPTS += --without-python-support - - Do not align the = signs. - - * Indentation: use tab only: - - define LIBFOO_REMOVE_DOC - $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/doc \ - $(TARGET_DIR)/usr/share/man/man3/libfoo* - endef - - Note that commands inside a define block should always start with - a tab, so make recognizes them as commands. - - * Optional dependency: - - + Prefer multi-line syntax. - - YES: - - ifeq ($(BR2_PACKAGE_PYTHON),y) - LIBFOO_CONF_OPTS += --with-python-support - LIBFOO_DEPENDENCIES += python - else - LIBFOO_CONF_OPTS += --without-python-support - endif - - NO: - - LIBFOO_CONF_OPTS += --with$(if $(BR2_PACKAGE_PYTHON),,out)-python-support - LIBFOO_DEPENDENCIES += $(if $(BR2_PACKAGE_PYTHON),python,) - - + Keep configure options and dependencies close together. - * Optional hooks: keep hook definition and assignment together in - one if block. - - YES: - - ifneq ($(BR2_LIBFOO_INSTALL_DATA),y) - define LIBFOO_REMOVE_DATA - $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/data - endef - LIBFOO_POST_INSTALL_TARGET_HOOKS += LIBFOO_REMOVE_DATA - endif - - NO: - - define LIBFOO_REMOVE_DATA - $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/data - endef - - ifneq ($(BR2_LIBFOO_INSTALL_DATA),y) - LIBFOO_POST_INSTALL_TARGET_HOOKS += LIBFOO_REMOVE_DATA - endif - -16.3. The documentation - -The documentation uses the asciidoc [http://www.methods.co.nz/ -asciidoc/] format. - -For further details about the asciidoc syntax, refer to http:// -www.methods.co.nz/asciidoc/userguide.html. - -16.4. Support scripts - -Some scripts in the support/ and utils/ directories are written in -Python and should follow the PEP8 Style Guide for Python Code [https: -//www.python.org/dev/peps/pep-0008/]. - -Chapter 17. Adding support for a particular board - -Buildroot contains basic configurations for several publicly -available hardware boards, so that users of such a board can easily -build a system that is known to work. You are welcome to add support -for other boards to Buildroot too. - -To do so, you need to create a normal Buildroot configuration that -builds a basic system for the hardware: (internal) toolchain, kernel, -bootloader, filesystem and a simple BusyBox-only userspace. No -specific package should be selected: the configuration should be as -minimal as possible, and should only build a working basic BusyBox -system for the target platform. You can of course use more -complicated configurations for your internal projects, but the -Buildroot project will only integrate basic board configurations. -This is because package selections are highly application-specific. - -Once you have a known working configuration, run make savedefconfig. -This will generate a minimal defconfig file at the root of the -Buildroot source tree. Move this file into the configs/ directory, -and rename it _defconfig. If the configuration is a bit -more complicated, it is nice to manually reformat it and separate it -into sections, with a comment before each section. Typical sections -are Architecture, Toolchain options (typically just linux headers -version), Firmware, Bootloader, Kernel, and Filesystem. - -Always use fixed versions or commit hashes for the different -components, not the "latest" version. For example, set -BR2_LINUX_KERNEL_CUSTOM_VERSION=y and -BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE to the kernel version you -tested with. - -It is recommended to use as much as possible upstream versions of the -Linux kernel and bootloaders, and to use as much as possible default -kernel and bootloader configurations. If they are incorrect for your -board, or no default exists, we encourage you to send fixes to the -corresponding upstream projects. - -However, in the mean time, you may want to store kernel or bootloader -configuration or patches specific to your target platform. To do so, -create a directory board/ and a subdirectory board/ -/. You can then store your patches and -configurations in these directories, and reference them from the main -Buildroot configuration. Refer to Chapter 9, Project-specific -customization for more details. - -Chapter 18. Adding new packages to Buildroot - -This section covers how new packages (userspace libraries or -applications) can be integrated into Buildroot. It also shows how -existing packages are integrated, which is needed for fixing issues -or tuning their configuration. - -When you add a new package, be sure to test it in various conditions -(see Section 18.24.3, “How to test your package”) and also check it -for coding style (see Section 18.24.2, “How to check the coding -style”). - -18.1. Package directory - -First of all, create a directory under the package directory for your -software, for example libfoo. - -Some packages have been grouped by topic in a sub-directory: x11r7, -qt5 and gstreamer. If your package fits in one of these categories, -then create your package directory in these. New subdirectories are -discouraged, however. - -18.2. Config files - -For the package to be displayed in the configuration tool, you need -to create a Config file in your package directory. There are two -types: Config.in and Config.in.host. - -18.2.1. Config.in file - -For packages used on the target, create a file named Config.in. This -file will contain the option descriptions related to our libfoo -software that will be used and displayed in the configuration tool. -It should basically contain: - -config BR2_PACKAGE_LIBFOO - bool "libfoo" - help - This is a comment that explains what libfoo is. The help text - should be wrapped. - - http://foosoftware.org/libfoo/ - -The bool line, help line and other metadata information about the -configuration option must be indented with one tab. The help text -itself should be indented with one tab and two spaces, lines should -be wrapped to fit 72 columns, where tab counts for 8, so 62 -characters in the text itself. The help text must mention the -upstream URL of the project after an empty line. - -As a convention specific to Buildroot, the ordering of the attributes -is as follows: - - 1. The type of option: bool, string… with the prompt - 2. If needed, the default value(s) - 3. Any dependencies on the target in depends on form - 4. Any dependencies on the toolchain in depends on form - 5. Any dependencies on other packages in depends on form - 6. Any dependency of the select form - 7. The help keyword and help text. - -You can add other sub-options into a if BR2_PACKAGE_LIBFOO…endif -statement to configure particular things in your software. You can -look at examples in other packages. The syntax of the Config.in file -is the same as the one for the kernel Kconfig file. The documentation -for this syntax is available at http://kernel.org/doc/Documentation/ -kbuild/kconfig-language.txt - -Finally you have to add your new libfoo/Config.in to package/ -Config.in (or in a category subdirectory if you decided to put your -package in one of the existing categories). The files included there -are sorted alphabetically per category and are NOT supposed to -contain anything but the bare name of the package. - -source "package/libfoo/Config.in" - -18.2.2. Config.in.host file - -Some packages also need to be built for the host system. There are -two options here: - - * The host package is only required to satisfy build-time - dependencies of one or more target packages. In this case, add - host-foo to the target package’s BAR_DEPENDENCIES variable. No - Config.in.host file should be created. - * The host package should be explicitly selectable by the user from - the configuration menu. In this case, create a Config.in.host - file for that host package: - - config BR2_PACKAGE_HOST_FOO - bool "host foo" - help - This is a comment that explains what foo for the host is. - - http://foosoftware.org/foo/ - - The same coding style and options as for the Config.in file are - valid. - - Finally you have to add your new libfoo/Config.in.host to package - /Config.in.host. The files included there are sorted - alphabetically and are NOT supposed to contain anything but the - bare name of the package. - - source "package/foo/Config.in.host" - - The host package will then be available from the Host utilities - menu. - -18.2.3. Choosing depends on or select - -The Config.in file of your package must also ensure that dependencies -are enabled. Typically, Buildroot uses the following rules: - - * Use a select type of dependency for dependencies on libraries. - These dependencies are generally not obvious and it therefore - make sense to have the kconfig system ensure that the - dependencies are selected. For example, the libgtk2 package uses - select BR2_PACKAGE_LIBGLIB2 to make sure this library is also - enabled. The select keyword expresses the dependency with a - backward semantic. - * Use a depends on type of dependency when the user really needs to - be aware of the dependency. Typically, Buildroot uses this type - of dependency for dependencies on target architecture, MMU - support and toolchain options (see Section 18.2.4, “Dependencies - on target and toolchain options”), or for dependencies on "big" - things, such as the X.org system. The depends on keyword - expresses the dependency with a forward semantic. - -Note. The current problem with the kconfig language is that these two -dependency semantics are not internally linked. Therefore, it may be -possible to select a package, whom one of its dependencies/ -requirement is not met. - -An example illustrates both the usage of select and depends on. - -config BR2_PACKAGE_RRDTOOL - bool "rrdtool" - depends on BR2_USE_WCHAR - select BR2_PACKAGE_FREETYPE - select BR2_PACKAGE_LIBART - select BR2_PACKAGE_LIBPNG - select BR2_PACKAGE_ZLIB - help - RRDtool is the OpenSource industry standard, high performance - data logging and graphing system for time series data. - - http://oss.oetiker.ch/rrdtool/ - -comment "rrdtool needs a toolchain w/ wchar" - depends on !BR2_USE_WCHAR - -Note that these two dependency types are only transitive with the -dependencies of the same kind. - -This means, in the following example: - -config BR2_PACKAGE_A - bool "Package A" - -config BR2_PACKAGE_B - bool "Package B" - depends on BR2_PACKAGE_A - -config BR2_PACKAGE_C - bool "Package C" - depends on BR2_PACKAGE_B - -config BR2_PACKAGE_D - bool "Package D" - select BR2_PACKAGE_B - -config BR2_PACKAGE_E - bool "Package E" - select BR2_PACKAGE_D - - * Selecting Package C will be visible if Package B has been - selected, which in turn is only visible if Package A has been - selected. - * Selecting Package E will select Package D, which will select - Package B, it will not check for the dependencies of Package B, - so it will not select Package A. - * Since Package B is selected but Package A is not, this violates - the dependency of Package B on Package A. Therefore, in such a - situation, the transitive dependency has to be added explicitly: - -config BR2_PACKAGE_D - bool "Package D" - select BR2_PACKAGE_B - depends on BR2_PACKAGE_A - -config BR2_PACKAGE_E - bool "Package E" - select BR2_PACKAGE_D - depends on BR2_PACKAGE_A - -Overall, for package library dependencies, select should be -preferred. - -Note that such dependencies will ensure that the dependency option is -also enabled, but not necessarily built before your package. To do -so, the dependency also needs to be expressed in the .mk file of the -package. - -Further formatting details: see the coding style. - -18.2.4. Dependencies on target and toolchain options - -Many packages depend on certain options of the toolchain: the choice -of C library, C++ support, thread support, RPC support, wchar -support, or dynamic library support. Some packages can only be built -on certain target architectures, or if an MMU is available in the -processor. - -These dependencies have to be expressed with the appropriate depends -on statements in the Config.in file. Additionally, for dependencies -on toolchain options, a comment should be displayed when the option -is not enabled, so that the user knows why the package is not -available. Dependencies on target architecture or MMU support should -not be made visible in a comment: since it is unlikely that the user -can freely choose another target, it makes little sense to show these -dependencies explicitly. - -The comment should only be visible if the config option itself would -be visible when the toolchain option dependencies are met. This means -that all other dependencies of the package (including dependencies on -target architecture and MMU support) have to be repeated on the -comment definition. To keep it clear, the depends on statement for -these non-toolchain option should be kept separate from the depends -on statement for the toolchain options. If there is a dependency on a -config option in that same file (typically the main package) it is -preferable to have a global if … endif construct rather than -repeating the depends on statement on the comment and other config -options. - -The general format of a dependency comment for package foo is: - -foo needs a toolchain w/ featA, featB, featC - -for example: - -mpd needs a toolchain w/ C++, threads, wchar - -or - -crda needs a toolchain w/ threads - -Note that this text is kept brief on purpose, so that it will fit on -a 80-character terminal. - -The rest of this section enumerates the different target and -toolchain options, the corresponding config symbols to depend on, and -the text to use in the comment. - - * Target architecture - - + Dependency symbol: BR2_powerpc, BR2_mips, … (see arch/ - Config.in) - + Comment string: no comment to be added - * MMU support - - + Dependency symbol: BR2_USE_MMU - + Comment string: no comment to be added - * Gcc _sync* built-ins used for atomic operations. They are - available in variants operating on 1 byte, 2 bytes, 4 bytes and 8 - bytes. Since different architectures support atomic operations on - different sizes, one dependency symbol is available for each - size: - - + Dependency symbol: BR2_TOOLCHAIN_HAS_SYNC_1 for 1 byte, - BR2_TOOLCHAIN_HAS_SYNC_2 for 2 bytes, - BR2_TOOLCHAIN_HAS_SYNC_4 for 4 bytes, - BR2_TOOLCHAIN_HAS_SYNC_8 for 8 bytes. - + Comment string: no comment to be added - * Gcc _atomic* built-ins used for atomic operations. - - + Dependency symbol: BR2_TOOLCHAIN_HAS_ATOMIC. - + Comment string: no comment to be added - * Kernel headers - - + Dependency symbol: BR2_TOOLCHAIN_HEADERS_AT_LEAST_X_Y, - (replace X_Y with the proper version, see toolchain/ - Config.in) - + Comment string: headers >= X.Y and/or headers <= X.Y (replace - X.Y with the proper version) - * GCC version - - + Dependency symbol: BR2_TOOLCHAIN_GCC_AT_LEAST_X_Y, (replace - X_Y with the proper version, see toolchain/Config.in) - + Comment string: gcc >= X.Y and/or gcc <= X.Y (replace X.Y - with the proper version) - * Host GCC version - - + Dependency symbol: BR2_HOST_GCC_AT_LEAST_X_Y, (replace X_Y - with the proper version, see Config.in) - + Comment string: no comment to be added - + Note that it is usually not the package itself that has a - minimum host GCC version, but rather a host-package on which - it depends. - * C library - - + Dependency symbol: BR2_TOOLCHAIN_USES_GLIBC, - BR2_TOOLCHAIN_USES_MUSL, BR2_TOOLCHAIN_USES_UCLIBC - + Comment string: for the C library, a slightly different - comment text is used: foo needs a glibc toolchain, or foo - needs a glibc toolchain w/ C++ - * C++ support - - + Dependency symbol: BR2_INSTALL_LIBSTDCPP - + Comment string: C++ - * D support - - + Dependency symbol: BR2_TOOLCHAIN_HAS_DLANG - + Comment string: Dlang - * Fortran support - - + Dependency symbol: BR2_TOOLCHAIN_HAS_FORTRAN - + Comment string: fortran - * thread support - - + Dependency symbol: BR2_TOOLCHAIN_HAS_THREADS - + Comment string: threads (unless - BR2_TOOLCHAIN_HAS_THREADS_NPTL is also needed, in which case, - specifying only NPTL is sufficient) - * NPTL thread support - - + Dependency symbol: BR2_TOOLCHAIN_HAS_THREADS_NPTL - + Comment string: NPTL - * RPC support - - + Dependency symbol: BR2_TOOLCHAIN_HAS_NATIVE_RPC - + Comment string: RPC - * wchar support - - + Dependency symbol: BR2_USE_WCHAR - + Comment string: wchar - * dynamic library - - + Dependency symbol: !BR2_STATIC_LIBS - + Comment string: dynamic library - -18.2.5. Dependencies on a Linux kernel built by buildroot - -Some packages need a Linux kernel to be built by buildroot. These are -typically kernel modules or firmware. A comment should be added in -the Config.in file to express this dependency, similar to -dependencies on toolchain options. The general format is: - -foo needs a Linux kernel to be built - -If there is a dependency on both toolchain options and the Linux -kernel, use this format: - -foo needs a toolchain w/ featA, featB, featC and a Linux kernel to be built - -18.2.6. Dependencies on udev /dev management - -If a package needs udev /dev management, it should depend on symbol -BR2_PACKAGE_HAS_UDEV, and the following comment should be added: - -foo needs udev /dev management - -If there is a dependency on both toolchain options and udev /dev -management, use this format: - -foo needs udev /dev management and a toolchain w/ featA, featB, featC - -18.2.7. Dependencies on features provided by virtual packages - -Some features can be provided by more than one package, such as the -openGL libraries. - -See Section 18.11, “Infrastructure for virtual packages” for more on -the virtual packages. - -18.3. The .mk file - -Finally, here’s the hardest part. Create a file named libfoo.mk. It -describes how the package should be downloaded, configured, built, -installed, etc. - -Depending on the package type, the .mk file must be written in a -different way, using different infrastructures: - - * Makefiles for generic packages (not using autotools or CMake): - These are based on an infrastructure similar to the one used for - autotools-based packages, but require a little more work from the - developer. They specify what should be done for the - configuration, compilation and installation of the package. This - infrastructure must be used for all packages that do not use the - autotools as their build system. In the future, other specialized - infrastructures might be written for other build systems. We - cover them through in a tutorial and a reference. - * Makefiles for autotools-based software (autoconf, automake, - etc.): We provide a dedicated infrastructure for such packages, - since autotools is a very common build system. This - infrastructure must be used for new packages that rely on the - autotools as their build system. We cover them through a tutorial - and reference. - * Makefiles for cmake-based software: We provide a dedicated - infrastructure for such packages, as CMake is a more and more - commonly used build system and has a standardized behaviour. This - infrastructure must be used for new packages that rely on CMake. - We cover them through a tutorial and reference. - * Makefiles for Python modules: We have a dedicated infrastructure - for Python modules that use either the distutils or the - setuptools mechanism. We cover them through a tutorial and a - reference. - * Makefiles for Lua modules: We have a dedicated infrastructure for - Lua modules available through the LuaRocks web site. We cover - them through a tutorial and a reference. - -Further formatting details: see the writing rules. - -18.4. The .hash file - -When possible, you must add a third file, named libfoo.hash, that -contains the hashes of the downloaded files for the libfoo package. -The only reason for not adding a .hash file is when hash checking is -not possible due to how the package is downloaded. - -When a package has a version selection choice, then the hash file may -be stored in a subdirectory named after the version, e.g. package/ -libfoo/1.2.3/libfoo.hash. This is especially important if the -different versions have different licensing terms, but they are -stored in the same file. Otherwise, the hash file should stay in the -package’s directory. - -The hashes stored in that file are used to validate the integrity of -the downloaded files and of the license files. - -The format of this file is one line for each file for which to check -the hash, each line with the following three fields separated by two -spaces: - - * the type of hash, one of: - - + md5, sha1, sha224, sha256, sha384, sha512, none - * the hash of the file: - - + for none, one or more non-space chars, usually just the - string xxx - + for md5, 32 hexadecimal characters - + for sha1, 40 hexadecimal characters - + for sha224, 56 hexadecimal characters - + for sha256, 64 hexadecimal characters - + for sha384, 96 hexadecimal characters - + for sha512, 128 hexadecimal characters - * the name of the file: - - + for a source archive: the basename of the file, without any - directory component, - + for a license file: the path as it appears in - FOO_LICENSE_FILES. - -Lines starting with a # sign are considered comments, and ignored. -Empty lines are ignored. - -There can be more than one hash for a single file, each on its own -line. In this case, all hashes must match. - -Note. Ideally, the hashes stored in this file should match the hashes -published by upstream, e.g. on their website, in the e-mail -announcement… If upstream provides more than one type of hash (e.g. -sha1 and sha512), then it is best to add all those hashes in the -.hash file. If upstream does not provide any hash, or only provides -an md5 hash, then compute at least one strong hash yourself -(preferably sha256, but not md5), and mention this in a comment line -above the hashes. - -Note. The hashes for license files are used to detect a license -change when a package version is bumped. The hashes are checked -during the make legal-info target run. For a package with multiple -versions (like Qt5), create the hash file in a subdirectory - of that package (see also Section 19.2, “How patches -are applied”). - -The none hash type is reserved to those archives downloaded from a -repository, like a git clone, a subversion checkout… - -The example below defines a sha1 and a sha256 published by upstream -for the main libfoo-1.2.3.tar.bz2 tarball, an md5 from upstream and a -locally-computed sha256 hashes for a binary blob, a sha256 for a -downloaded patch, and an archive with no hash: - -# Hashes from: http://www.foosoftware.org/download/libfoo-1.2.3.tar.bz2.{sha1,sha256}: -sha1 486fb55c3efa71148fe07895fd713ea3a5ae343a libfoo-1.2.3.tar.bz2 -sha256 efc8103cc3bcb06bda6a781532d12701eb081ad83e8f90004b39ab81b65d4369 libfoo-1.2.3.tar.bz2 - -# md5 from: http://www.foosoftware.org/download/libfoo-1.2.3.tar.bz2.md5, sha256 locally computed: -md5 2d608f3c318c6b7557d551a5a09314f03452f1a1 libfoo-data.bin -sha256 01ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546b libfoo-data.bin - -# Locally computed: -sha256 ff52101fb90bbfc3fe9475e425688c660f46216d7e751c4bbdb1dc85cdccacb9 libfoo-fix-blabla.patch - -# No hash for 1234: -none xxx libfoo-1234.tar.gz - -# Hash for license files: -sha256 a45a845012742796534f7e91fe623262ccfb99460a2bd04015bd28d66fba95b8 COPYING -sha256 01b1f9f2c8ee648a7a596a1abe8aa4ed7899b1c9e5551bda06da6e422b04aa55 doc/COPYING.LGPL - -If the .hash file is present, and it contains one or more hashes for -a downloaded file, the hash(es) computed by Buildroot (after -download) must match the hash(es) stored in the .hash file. If one or -more hashes do not match, Buildroot considers this an error, deletes -the downloaded file, and aborts. - -If the .hash file is present, but it does not contain a hash for a -downloaded file, Buildroot considers this an error and aborts. -However, the downloaded file is left in the download directory since -this typically indicates that the .hash file is wrong but the -downloaded file is probably OK. - -Hashes are currently checked for files fetched from http/ftp servers, -Git repositories, files copied using scp and local files. Hashes are -not checked for other version control systems (such as Subversion, -CVS, etc.) because Buildroot currently does not generate reproducible -tarballs when source code is fetched from such version control -systems. - -Hashes should only be added in .hash files for files that are -guaranteed to be stable. For example, patches auto-generated by -Github are not guaranteed to be stable, and therefore their hashes -can change over time. Such patches should not be downloaded, and -instead be added locally to the package folder. - -If the .hash file is missing, then no check is done at all. - -18.5. Infrastructure for packages with specific build systems - -By packages with specific build systems we mean all the packages -whose build system is not one of the standard ones, such as autotools -or CMake. This typically includes packages whose build system is -based on hand-written Makefiles or shell scripts. - -18.5.1. generic-package tutorial - -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_LICENSE = GPL-3.0+ -11: LIBFOO_LICENSE_FILES = COPYING -12: LIBFOO_INSTALL_STAGING = YES -13: LIBFOO_CONFIG_SCRIPTS = libfoo-config -14: LIBFOO_DEPENDENCIES = host-libaaa libbbb -15: -16: define LIBFOO_BUILD_CMDS -17: $(MAKE) $(TARGET_CONFIGURE_OPTS) -C $(@D) all -18: endef -19: -20: define LIBFOO_INSTALL_STAGING_CMDS -21: $(INSTALL) -D -m 0755 $(@D)/libfoo.a $(STAGING_DIR)/usr/lib/libfoo.a -22: $(INSTALL) -D -m 0644 $(@D)/foo.h $(STAGING_DIR)/usr/include/foo.h -23: $(INSTALL) -D -m 0755 $(@D)/libfoo.so* $(STAGING_DIR)/usr/lib -24: endef -25: -26: define LIBFOO_INSTALL_TARGET_CMDS -27: $(INSTALL) -D -m 0755 $(@D)/libfoo.so* $(TARGET_DIR)/usr/lib -28: $(INSTALL) -d -m 0755 $(TARGET_DIR)/etc/foo.d -29: endef -30: -31: define LIBFOO_USERS -32: foo -1 libfoo -1 * - - - LibFoo daemon -33: endef -34: -35: define LIBFOO_DEVICES -36: /dev/foo c 666 0 0 42 0 - - - -37: endef -38: -39: define LIBFOO_PERMISSIONS -40: /bin/foo f 4755 foo libfoo - - - - - -41: endef -42: -43: $(eval $(generic-package)) - -The Makefile begins on line 7 to 11 with metadata information: the -version of the package (LIBFOO_VERSION), the name of the tarball -containing the package (LIBFOO_SOURCE) (xz-ed tarball recommended) -the Internet location at which the tarball can be downloaded from -(LIBFOO_SITE), the license (LIBFOO_LICENSE) and file with the license -text (LIBFOO_LICENSE_FILES). All variables must start with the same -prefix, LIBFOO_ in this case. This prefix is always the uppercased -version of the package name (see below to understand where the -package name is defined). - -On line 12, we specify that this package wants to install something -to the staging space. This is often needed for libraries, since they -must install header files and other development files in the staging -space. This will ensure that the commands listed in the -LIBFOO_INSTALL_STAGING_CMDS variable will be executed. - -On line 13, we specify that there is some fixing to be done to some -of the libfoo-config files that were installed during -LIBFOO_INSTALL_STAGING_CMDS phase. These *-config files are -executable shell script files that are located in $(STAGING_DIR)/usr/ -bin directory and are executed by other 3rd party packages to find -out the location and the linking flags of this particular package. - -The problem is that all these *-config files by default give wrong, -host system linking flags that are unsuitable for cross-compiling. - -For example: -I/usr/include instead of -I$(STAGING_DIR)/usr/include -or: -L/usr/lib instead of -L$(STAGING_DIR)/usr/lib - -So some sed magic is done to these scripts to make them give correct -flags. The argument to be given to LIBFOO_CONFIG_SCRIPTS is the file -name(s) of the shell script(s) needing fixing. All these names are -relative to $(STAGING_DIR)/usr/bin and if needed multiple names can -be given. - -In addition, the scripts listed in LIBFOO_CONFIG_SCRIPTS are removed -from $(TARGET_DIR)/usr/bin, since they are not needed on the target. - -Example 18.1. Config script: divine package - -Package divine installs shell script $(STAGING_DIR)/usr/bin/ -divine-config. - -So its fixup would be: - -DIVINE_CONFIG_SCRIPTS = divine-config - - -Example 18.2. Config script: imagemagick package: - -Package imagemagick installs the following scripts: $(STAGING_DIR)/ -usr/bin/{Magick,Magick++,MagickCore,MagickWand,Wand}-config - -So it’s fixup would be: - -IMAGEMAGICK_CONFIG_SCRIPTS = \ - Magick-config Magick++-config \ - MagickCore-config MagickWand-config Wand-config - - -On line 14, we specify the list of dependencies this package relies -on. These dependencies are listed in terms of lower-case package -names, which can be packages for the target (without the host- -prefix) or packages for the host (with the host-) prefix). Buildroot -will ensure that all these packages are built and installed before -the current package starts its configuration. - -The rest of the Makefile, lines 16..29, defines what should be done -at the different steps of the package configuration, compilation and -installation. LIBFOO_BUILD_CMDS tells what steps should be performed -to build the package. LIBFOO_INSTALL_STAGING_CMDS tells what steps -should be performed to install the package in the staging space. -LIBFOO_INSTALL_TARGET_CMDS tells what steps should be performed to -install the package in the target space. - -All these steps rely on the $(@D) variable, which contains the -directory where the source code of the package has been extracted. - -On lines 31..33, we define a user that is used by this package (e.g. -to run a daemon as non-root) (LIBFOO_USERS). - -On line 35..37, we define a device-node file used by this package -(LIBFOO_DEVICES). - -On line 39..41, we define the permissions to set to specific files -installed by this package (LIBFOO_PERMISSIONS). - -Finally, on line 43, we call the generic-package function, which -generates, according to the variables defined previously, all the -Makefile code necessary to make your package working. - -18.5.2. generic-package reference - -There are two variants of the generic target. The generic-package -macro is used for packages to be cross-compiled for the target. The -host-generic-package macro is used for host packages, natively -compiled for the host. It is possible to call both of them in a -single .mk file: once to create the rules to generate a target -package and once to create the rules to generate a host package: - -$(eval $(generic-package)) -$(eval $(host-generic-package)) - -This might be useful if the compilation of the target package -requires some tools to be installed on the host. If the package name -is libfoo, then the name of the package for the target is also -libfoo, while the name of the package for the host is host-libfoo. -These names should be used in the DEPENDENCIES variables of other -packages, if they depend on libfoo or host-libfoo. - -The call to the generic-package and/or host-generic-package macro -must be at the end of the .mk file, after all variable definitions. -The call to host-generic-package must be after the call to -generic-package, if any. - -For the target package, the generic-package uses the variables -defined by the .mk file and prefixed by the uppercased package name: -LIBFOO_*. host-generic-package uses the HOST_LIBFOO_* variables. For -some variables, if the HOST_LIBFOO_ prefixed variable doesn’t exist, -the package infrastructure uses the corresponding variable prefixed -by LIBFOO_. This is done for variables that are likely to have the -same value for both the target and host packages. See below for -details. - -The list of variables that can be set in a .mk file to give metadata -information is (assuming the package name is libfoo) : - - * LIBFOO_VERSION, mandatory, must contain the version of the - package. Note that if HOST_LIBFOO_VERSION doesn’t exist, it is - assumed to be the same as LIBFOO_VERSION. It can also be a - revision number or a tag for packages that are fetched directly - from their version control system. Examples: - - + a version for a release tarball: LIBFOO_VERSION = 0.1.2 - + a sha1 for a git tree: LIBFOO_VERSION = - cb9d6aa9429e838f0e54faa3d455bcbab5eef057 - + a tag for a git tree LIBFOO_VERSION = v0.1.2 - - Note: Using a branch name as FOO_VERSION is not supported, - because it does not and can not work as people would expect - it should: - - 1. due to local caching, Buildroot will not re-fetch the - repository, so people who expect to be able to follow the - remote repository would be quite surprised and - disappointed; - 2. because two builds can never be perfectly simultaneous, - and because the remote repository may get new commits on - the branch anytime, two users, using the same Buildroot - tree and building the same configuration, may get - different source, thus rendering the build non - reproducible, and people would be quite surprised and - disappointed. - * LIBFOO_SOURCE may contain the name of the tarball of the package, - which Buildroot will use to download the tarball from - LIBFOO_SITE. If HOST_LIBFOO_SOURCE is not specified, it defaults - to LIBFOO_SOURCE. If none are specified, then the value is - assumed to be libfoo-$(LIBFOO_VERSION).tar.gz. Example: - LIBFOO_SOURCE = foobar-$(LIBFOO_VERSION).tar.bz2 - * LIBFOO_PATCH may contain a space-separated list of patch file - names, that Buildroot will download and apply to the package - source code. If an entry contains ://, then Buildroot will assume - it is a full URL and download the patch from this location. - Otherwise, Buildroot will assume that the patch should be - downloaded from LIBFOO_SITE. If HOST_LIBFOO_PATCH is not - specified, it defaults to LIBFOO_PATCH. Note that patches that - are included in Buildroot itself use a different mechanism: all - files of the form *.patch present in the package directory inside - Buildroot will be applied to the package after extraction (see - patching a package). Finally, patches listed in the LIBFOO_PATCH - variable are applied before the patches stored in the Buildroot - package directory. - * LIBFOO_SITE provides the location of the package, which can be a - URL or a local filesystem path. HTTP, FTP and SCP are supported - URL types for retrieving package tarballs. In these cases don’t - include a trailing slash: it will be added by Buildroot between - the directory and the filename as appropriate. Git, Subversion, - Mercurial, and Bazaar are supported URL types for retrieving - packages directly from source code management systems. There is a - helper function to make it easier to download source tarballs - from GitHub (refer to Section 18.24.4, “How to add a package from - GitHub” for details). A filesystem path may be used to specify - either a tarball or a directory containing the package source - code. See LIBFOO_SITE_METHOD below for more details on how - retrieval works. Note that SCP URLs should be of the form scp:// - [user@]host:filepath, and that filepath is relative to the user’s - home directory, so you may want to prepend the path with a slash - for absolute paths: scp://[user@]host:/absolutepath. If - HOST_LIBFOO_SITE is not specified, it defaults to LIBFOO_SITE. - Examples: LIBFOO_SITE=http://www.libfoosoftware.org/libfoo - LIBFOO_SITE=http://svn.xiph.org/trunk/Tremor LIBFOO_SITE=/opt/ - software/libfoo.tar.gz LIBFOO_SITE=$(TOPDIR)/../src/libfoo - * LIBFOO_DL_OPTS is a space-separated list of additional options to - pass to the downloader. Useful for retrieving documents with - server-side checking for user logins and passwords, or to use a - proxy. All download methods valid for LIBFOO_SITE_METHOD are - supported; valid options depend on the download method (consult - the man page for the respective download utilities). - * LIBFOO_EXTRA_DOWNLOADS is a space-separated list of additional - files that Buildroot should download. If an entry contains :// - then Buildroot will assume it is a complete URL and will download - the file using this URL. Otherwise, Buildroot will assume the - file to be downloaded is located at LIBFOO_SITE. Buildroot will - not do anything with those additional files, except download - them: it will be up to the package recipe to use them from $ - (LIBFOO_DL_DIR). - * LIBFOO_SITE_METHOD determines the method used to fetch or copy - the package source code. In many cases, Buildroot guesses the - method from the contents of LIBFOO_SITE and setting - LIBFOO_SITE_METHOD is unnecessary. When HOST_LIBFOO_SITE_METHOD - is not specified, it defaults to the value of LIBFOO_SITE_METHOD. - The possible values of LIBFOO_SITE_METHOD are: - - + wget for normal FTP/HTTP downloads of tarballs. Used by - default when LIBFOO_SITE begins with http://, https:// or - ftp://. - + scp for downloads of tarballs over SSH with scp. Used by - default when LIBFOO_SITE begins with scp://. - + svn for retrieving source code from a Subversion repository. - Used by default when LIBFOO_SITE begins with svn://. When a - http:// Subversion repository URL is specified in - LIBFOO_SITE, one must specify LIBFOO_SITE_METHOD=svn. - Buildroot performs a checkout which is preserved as a tarball - in the download cache; subsequent builds use the tarball - instead of performing another checkout. - + cvs for retrieving source code from a CVS repository. Used by - default when LIBFOO_SITE begins with cvs://. The downloaded - source code is cached as with the svn method. Anonymous - pserver mode is assumed otherwise explicitly defined on - LIBFOO_SITE. Both LIBFOO_SITE=cvs://libfoo.net:/cvsroot/ - libfoo and LIBFOO_SITE=cvs://:ext:libfoo.net:/cvsroot/libfoo - are accepted, on the former anonymous pserver access mode is - assumed. LIBFOO_SITE must contain the source URL as well as - the remote repository directory. The module is the package - name. LIBFOO_VERSION is mandatory and must be a tag, a - branch, or a date (e.g. "2014-10-20", "2014-10-20 13:45", - "2014-10-20 13:45+01" see "man cvs" for further details). - + git for retrieving source code from a Git repository. Used by - default when LIBFOO_SITE begins with git://. The downloaded - source code is cached as with the svn method. - + hg for retrieving source code from a Mercurial repository. - One must specify LIBFOO_SITE_METHOD=hg when LIBFOO_SITE - contains a Mercurial repository URL. The downloaded source - code is cached as with the svn method. - + bzr for retrieving source code from a Bazaar repository. Used - by default when LIBFOO_SITE begins with bzr://. The - downloaded source code is cached as with the svn method. - + file for a local tarball. One should use this when - LIBFOO_SITE specifies a package tarball as a local filename. - Useful for software that isn’t available publicly or in - version control. - + local for a local source code directory. One should use this - when LIBFOO_SITE specifies a local directory path containing - the package source code. Buildroot copies the contents of the - source directory into the package’s build directory. Note - that for local packages, no patches are applied. If you need - to still patch the source code, use LIBFOO_POST_RSYNC_HOOKS, - see Section 18.22.1, “Using the POST_RSYNC hook”. - * LIBFOO_GIT_SUBMODULES can be set to YES to create an archive with - the git submodules in the repository. This is only available for - packages downloaded with git (i.e. when LIBFOO_SITE_METHOD=git). - Note that we try not to use such git submodules when they contain - bundled libraries, in which case we prefer to use those libraries - from their own package. - * LIBFOO_STRIP_COMPONENTS is the number of leading components - (directories) that tar must strip from file names on extraction. - The tarball for most packages has one leading component named " - -", thus Buildroot passes - --strip-components=1 to tar to remove it. For non-standard - packages that don’t have this component, or that have more than - one leading component to strip, set this variable with the value - to be passed to tar. Default: 1. - * LIBFOO_EXCLUDES is a space-separated list of patterns to exclude - when extracting the archive. Each item from that list is passed - as a tar’s --exclude option. By default, empty. - * LIBFOO_DEPENDENCIES lists the dependencies (in terms of package - name) that are required for the current target package to - compile. These dependencies are guaranteed to be compiled and - installed before the configuration of the current package starts. - However, modifications to configuration of these dependencies - will not force a rebuild of the current package. In a similar - way, HOST_LIBFOO_DEPENDENCIES lists the dependencies for the - current host package. - * LIBFOO_EXTRACT_DEPENDENCIES lists the dependencies (in terms of - package name) that are required for the current target package to - be extracted. These dependencies are guaranteed to be compiled - and installed before the extract step of the current package - starts. This is only used internally by the package - infrastructure, and should typically not be used directly by - packages. - * LIBFOO_PATCH_DEPENDENCIES lists the dependencies (in terms of - package name) that are required for the current package to be - patched. These dependencies are guaranteed to be extracted and - patched (but not necessarily built) before the current package is - patched. In a similar way, HOST_LIBFOO_PATCH_DEPENDENCIES lists - the dependencies for the current host package. This is seldom - used; usually, LIBFOO_DEPENDENCIES is what you really want to - use. - * LIBFOO_PROVIDES lists all the virtual packages libfoo is an - implementation of. See Section 18.11, “Infrastructure for virtual - packages”. - * LIBFOO_INSTALL_STAGING can be set to YES or NO (default). If set - to YES, then the commands in the LIBFOO_INSTALL_STAGING_CMDS - variables are executed to install the package into the staging - directory. - * LIBFOO_INSTALL_TARGET can be set to YES (default) or NO. If set - to YES, then the commands in the LIBFOO_INSTALL_TARGET_CMDS - variables are executed to install the package into the target - directory. - * LIBFOO_INSTALL_IMAGES can be set to YES or NO (default). If set - to YES, then the commands in the LIBFOO_INSTALL_IMAGES_CMDS - variable are executed to install the package into the images - directory. - * LIBFOO_CONFIG_SCRIPTS lists the names of the files in $ - (STAGING_DIR)/usr/bin that need some special fixing to make them - cross-compiling friendly. Multiple file names separated by space - can be given and all are relative to $(STAGING_DIR)/usr/bin. The - files listed in LIBFOO_CONFIG_SCRIPTS are also removed from $ - (TARGET_DIR)/usr/bin since they are not needed on the target. - * LIBFOO_DEVICES lists the device files to be created by Buildroot - when using the static device table. The syntax to use is the - makedevs one. You can find some documentation for this syntax in - the Chapter 25, Makedev syntax documentation. This variable is - optional. - * LIBFOO_PERMISSIONS lists the changes of permissions to be done at - the end of the build process. The syntax is once again the - makedevs one. You can find some documentation for this syntax in - the Chapter 25, Makedev syntax documentation. This variable is - optional. - * LIBFOO_USERS lists the users to create for this package, if it - installs a program you want to run as a specific user (e.g. as a - daemon, or as a cron-job). The syntax is similar in spirit to the - makedevs one, and is described in the Chapter 26, Makeusers - syntax documentation. This variable is optional. - * LIBFOO_LICENSE defines the license (or licenses) under which the - package is released. This name will appear in the manifest file - produced by make legal-info. If the license appears in the SPDX - License List [https://spdx.org/licenses/], use the SPDX short - identifier to make the manifest file uniform. Otherwise, describe - the license in a precise and concise way, avoiding ambiguous - names such as BSD which actually name a family of licenses. This - variable is optional. If it is not defined, unknown will appear - in the license field of the manifest file for this package. The - expected format for this variable must comply with the following - rules: - - + If different parts of the package are released under - different licenses, then comma separate licenses (e.g. - LIBFOO_LICENSE = GPL-2.0+, LGPL-2.1+). If there is clear - distinction between which component is licensed under what - license, then annotate the license with that component, - between parenthesis (e.g. LIBFOO_LICENSE = GPL-2.0+ - (programs), LGPL-2.1+ (libraries)). - + If some licenses are conditioned on a sub-option being - enabled, append the conditional licenses with a comma (e.g.: - FOO_LICENSE += , GPL-2.0+ (programs)); the infrastructure - will internally remove the space before the comma. - + If the package is dual licensed, then separate licenses with - the or keyword (e.g. LIBFOO_LICENSE = AFL-2.1 or GPL-2.0+). - * LIBFOO_LICENSE_FILES is a space-separated list of files in the - package tarball that contain the license(s) under which the - package is released. make legal-info copies all of these files in - the legal-info directory. See Chapter 13, Legal notice and - licensing for more information. This variable is optional. If it - is not defined, a warning will be produced to let you know, and - not saved will appear in the license files field of the manifest - file for this package. - * LIBFOO_ACTUAL_SOURCE_TARBALL only applies to packages whose - LIBFOO_SITE / LIBFOO_SOURCE pair points to an archive that does - not actually contain source code, but binary code. This a very - uncommon case, only known to apply to external toolchains which - come already compiled, although theoretically it might apply to - other packages. In such cases a separate tarball is usually - available with the actual source code. Set - LIBFOO_ACTUAL_SOURCE_TARBALL to the name of the actual source - code archive and Buildroot will download it and use it when you - run make legal-info to collect legally-relevant material. Note - this file will not be downloaded during regular builds nor by - make source. - * LIBFOO_ACTUAL_SOURCE_SITE provides the location of the actual - source tarball. The default value is LIBFOO_SITE, so you don’t - need to set this variable if the binary and source archives are - hosted on the same directory. If LIBFOO_ACTUAL_SOURCE_TARBALL is - not set, it doesn’t make sense to define - LIBFOO_ACTUAL_SOURCE_SITE. - * LIBFOO_REDISTRIBUTE can be set to YES (default) or NO to indicate - if the package source code is allowed to be redistributed. Set it - to NO for non-opensource packages: Buildroot will not save the - source code for this package when collecting the legal-info. - * LIBFOO_FLAT_STACKSIZE defines the stack size of an application - built into the FLAT binary format. The application stack size on - the NOMMU architecture processors can’t be enlarged at run time. - The default stack size for the FLAT binary format is only 4k - bytes. If the application consumes more stack, append the - required number here. - * LIBFOO_BIN_ARCH_EXCLUDE is a space-separated list of paths - (relative to the target directory) to ignore when checking that - the package installs correctly cross-compiled binaries. You - seldom need to set this variable, unless the package installs - binary blobs outside the default locations, /lib/firmware, /usr/ - lib/firmware, /lib/modules, /usr/lib/modules, and /usr/share, - which are automatically excluded. - * LIBFOO_IGNORE_CVES is a space-separated list of CVEs that tells - Buildroot CVE tracking tools which CVEs should be ignored for - this package. This is typically used when the CVE is fixed by a - patch in the package, or when the CVE for some reason does not - affect the Buildroot package. A Makefile comment must always - precede the addition of a CVE to this variable. Example: - -# 0001-fix-cve-2020-12345.patch -LIBFOO_IGNORE_CVES += CVE-2020-12345 -# only when built with libbaz, which Buildroot doesn't support -LIBFOO_IGNORE_CVES += CVE-2020-54321 - - * LIBFOO_CPE_ID_* variables is a set of variables that allows the - package to define its CPE identifier [https://nvd.nist.gov/ - products/cpe]. The available variables are: - - + LIBFOO_CPE_ID_PREFIX, specifies the prefix of the CPE - identifier, i.e the first three fields. When not defined, the - default value is cpe:2.3:a. - + LIBFOO_CPE_ID_VENDOR, specifies the vendor part of the CPE - identifier. When not defined, the default value is - _project. - + LIBFOO_CPE_ID_PRODUCT, specifies the product part of the CPE - identifier. When not defined, the default value is . - + LIBFOO_CPE_ID_VERSION, specifies the version part of the CPE - identifier. When not defined the default value is $ - (LIBFOO_VERSION). - + LIBFOO_CPE_ID_UPDATE specifies the update part of the CPE - identifier. When not defined the default value is *. - - If any of those variables is defined, then the generic package - infrastructure assumes the package provides valid CPE - information. In this case, the generic package infrastructure - will define LIBFOO_CPE_ID. - - For a host package, if its LIBFOO_CPE_ID_* variables are not - defined, it inherits the value of those variables from the - corresponding target package. - -The recommended way to define these variables is to use the following -syntax: - -LIBFOO_VERSION = 2.32 - -Now, the variables that define what should be performed at the -different steps of the build process. - - * LIBFOO_EXTRACT_CMDS lists the actions to be performed to extract - the package. This is generally not needed as tarballs are - automatically handled by Buildroot. However, if the package uses - a non-standard archive format, such as a ZIP or RAR file, or has - a tarball with a non-standard organization, this variable allows - to override the package infrastructure default behavior. - * LIBFOO_CONFIGURE_CMDS lists the actions to be performed to - configure the package before its compilation. - * LIBFOO_BUILD_CMDS lists the actions to be performed to compile - the package. - * HOST_LIBFOO_INSTALL_CMDS lists the actions to be performed to - install the package, when the package is a host package. The - package must install its files to the directory given by $ - (HOST_DIR). All files, including development files such as - headers should be installed, since other packages might be - compiled on top of this package. - * LIBFOO_INSTALL_TARGET_CMDS lists the actions to be performed to - install the package to the target directory, when the package is - a target package. The package must install its files to the - directory given by $(TARGET_DIR). Only the files required for - execution of the package have to be installed. Header files, - static libraries and documentation will be removed again when the - target filesystem is finalized. - * LIBFOO_INSTALL_STAGING_CMDS lists the actions to be performed to - install the package to the staging directory, when the package is - a target package. The package must install its files to the - directory given by $(STAGING_DIR). All development files should - be installed, since they might be needed to compile other - packages. - * LIBFOO_INSTALL_IMAGES_CMDS lists the actions to be performed to - install the package to the images directory, when the package is - a target package. The package must install its files to the - directory given by $(BINARIES_DIR). Only files that are binary - images (aka images) that do not belong in the TARGET_DIR but are - necessary for booting the board should be placed here. For - example, a package should utilize this step if it has binaries - which would be similar to the kernel image, bootloader or root - filesystem images. - * LIBFOO_INSTALL_INIT_SYSV, LIBFOO_INSTALL_INIT_OPENRC and - LIBFOO_INSTALL_INIT_SYSTEMD list the actions to install init - scripts either for the systemV-like init systems (busybox, - sysvinit, etc.), openrc or for the systemd units. These commands - will be run only when the relevant init system is installed (i.e. - if systemd is selected as the init system in the configuration, - only LIBFOO_INSTALL_INIT_SYSTEMD will be run). The only exception - is when openrc is chosen as init system and - LIBFOO_INSTALL_INIT_OPENRC has not been set, in such situation - LIBFOO_INSTALL_INIT_SYSV will be called, since openrc supports - sysv init scripts. When systemd is used as the init system, - buildroot will automatically enable all services using the - systemctl preset-all command in the final phase of image - building. You can add preset files to prevent a particular unit - from being automatically enabled by buildroot. - * LIBFOO_HELP_CMDS lists the actions to print the package help, - which is included to the main make help output. These commands - can print anything in any format. This is seldom used, as - packages rarely have custom rules. Do not use this variable, - unless you really know that you need to print help. - * LIBFOO_LINUX_CONFIG_FIXUPS lists the Linux kernel configuration - options that are needed to build and use this package, and - without which the package is fundamentally broken. This shall be - a set of calls to one of the kconfig tweaking option: - KCONFIG_ENABLE_OPT, KCONFIG_DISABLE_OPT, or KCONFIG_SET_OPT. This - is seldom used, as package usually have no strict requirements on - the kernel options. - -The preferred way to define these variables is: - -define LIBFOO_CONFIGURE_CMDS - action 1 - action 2 - action 3 -endef - -In the action definitions, you can use the following variables: - - * $(LIBFOO_PKGDIR) contains the path to the directory containing - the libfoo.mk and Config.in files. This variable is useful when - it is necessary to install a file bundled in Buildroot, like a - runtime configuration file, a splashscreen image… - * $(@D), which contains the directory in which the package source - code has been uncompressed. - * $(LIBFOO_DL_DIR) contains the path to the directory where all the - downloads made by Buildroot for libfoo are stored in. - * $(TARGET_CC), $(TARGET_LD), etc. to get the target - cross-compilation utilities - * $(TARGET_CROSS) to get the cross-compilation toolchain prefix - * Of course the $(HOST_DIR), $(STAGING_DIR) and $(TARGET_DIR) - variables to install the packages properly. Those variables point - to the global host, staging and target directories, unless - per-package directory support is used, in which case they point - to the current package host, staging and target directories. In - both cases, it doesn’t make any difference from the package point - of view: it should simply use HOST_DIR, STAGING_DIR and - TARGET_DIR. See Section 8.12, “Top-level parallel build” for more - details about per-package directory support. - -Finally, you can also use hooks. See Section 18.22, “Hooks available -in the various build steps” for more information. - -18.6. Infrastructure for autotools-based packages - -18.6.1. autotools-package tutorial - -First, let’s see how to write a .mk file for an autotools-based -package, with an example : - -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_INSTALL_STAGING = YES -11: LIBFOO_INSTALL_TARGET = NO -12: LIBFOO_CONF_OPTS = --disable-shared -13: LIBFOO_DEPENDENCIES = libglib2 host-pkgconf -14: -15: $(eval $(autotools-package)) - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10, we tell Buildroot to install the package to the staging -directory. The staging directory, located in output/staging/ is the -directory where all the packages are installed, including their -development files, etc. By default, packages are not installed to the -staging directory, since usually, only libraries need to be installed -in the staging directory: their development files are needed to -compile other libraries or applications depending on them. Also by -default, when staging installation is enabled, packages are installed -in this location using the make install command. - -On line 11, we tell Buildroot to not install the package to the -target directory. This directory contains what will become the root -filesystem running on the target. For purely static libraries, it is -not necessary to install them in the target directory because they -will not be used at runtime. By default, target installation is -enabled; setting this variable to NO is almost never needed. Also by -default, packages are installed in this location using the make -install command. - -On line 12, we tell Buildroot to pass a custom configure option, that -will be passed to the ./configure script before configuring and -building the package. - -On line 13, we declare our dependencies, so that they are built -before the build process of our package starts. - -Finally, on line line 15, we invoke the autotools-package macro that -generates all the Makefile rules that actually allows the package to -be built. - -18.6.2. autotools-package reference - -The main macro of the autotools package infrastructure is -autotools-package. It is similar to the generic-package macro. The -ability to have target and host packages is also available, with the -host-autotools-package macro. - -Just like the generic infrastructure, the autotools infrastructure -works by defining a number of variables before calling the -autotools-package macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the autotools -infrastructure: LIBFOO_VERSION, LIBFOO_SOURCE, LIBFOO_PATCH, -LIBFOO_SITE, LIBFOO_SUBDIR, LIBFOO_DEPENDENCIES, -LIBFOO_INSTALL_STAGING, LIBFOO_INSTALL_TARGET. - -A few additional variables, specific to the autotools infrastructure, -can also be defined. Many of them are only useful in very specific -cases, typical packages will therefore only use a few of them. - - * LIBFOO_SUBDIR may contain the name of a subdirectory inside the - package that contains the configure script. This is useful, if - for example, the main configure script is not at the root of the - tree extracted by the tarball. If HOST_LIBFOO_SUBDIR is not - specified, it defaults to LIBFOO_SUBDIR. - * LIBFOO_CONF_ENV, to specify additional environment variables to - pass to the configure script. By default, empty. - * LIBFOO_CONF_OPTS, to specify additional configure options to pass - to the configure script. By default, empty. - * LIBFOO_MAKE, to specify an alternate make command. This is - typically useful when parallel make is enabled in the - configuration (using BR2_JLEVEL) but that this feature should be - disabled for the given package, for one reason or another. By - default, set to $(MAKE). If parallel building is not supported by - the package, then it should be set to LIBFOO_MAKE=$(MAKE1). - * LIBFOO_MAKE_ENV, to specify additional environment variables to - pass to make in the build step. These are passed before the make - command. By default, empty. - * LIBFOO_MAKE_OPTS, to specify additional variables to pass to make - in the build step. These are passed after the make command. By - default, empty. - * LIBFOO_AUTORECONF, tells whether the package should be - autoreconfigured or not (i.e. if the configure script and - Makefile.in files should be re-generated by re-running autoconf, - automake, libtool, etc.). Valid values are YES and NO. By - default, the value is NO - * LIBFOO_AUTORECONF_ENV, to specify additional environment - variables to pass to the autoreconf program if LIBFOO_AUTORECONF= - YES. These are passed in the environment of the autoreconf - command. By default, empty. - * LIBFOO_AUTORECONF_OPTS to specify additional options passed to - the autoreconf program if LIBFOO_AUTORECONF=YES. By default, - empty. - * LIBFOO_GETTEXTIZE, tells whether the package should be - gettextized or not (i.e. if the package uses a different gettext - version than Buildroot provides, and it is needed to run - gettextize.) Only valid when LIBFOO_AUTORECONF=YES. Valid values - are YES and NO. The default is NO. - * LIBFOO_GETTEXTIZE_OPTS, to specify additional options passed to - the gettextize program, if LIBFOO_GETTEXTIZE=YES. You may use - that if, for example, the .po files are not located in the - standard place (i.e. in po/ at the root of the package.) By - default, -f. - * LIBFOO_LIBTOOL_PATCH tells whether the Buildroot patch to fix - libtool cross-compilation issues should be applied or not. Valid - values are YES and NO. By default, the value is YES - * LIBFOO_INSTALL_STAGING_OPTS contains the make options used to - install the package to the staging directory. By default, the - value is DESTDIR=$(STAGING_DIR) install, which is correct for - most autotools packages. It is still possible to override it. - * LIBFOO_INSTALL_TARGET_OPTS contains the make options used to - install the package to the target directory. By default, the - value is DESTDIR=$(TARGET_DIR) install. The default value is - correct for most autotools packages, but it is still possible to - override it if needed. - -With the autotools infrastructure, all the steps required to build -and install the packages are already defined, and they generally work -well for most autotools-based packages. However, when required, it is -still possible to customize what is done in any particular step: - - * By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the - various build steps” for details. - * By overriding one of the steps. For example, even if the - autotools infrastructure is used, if the package .mk file defines - its own LIBFOO_CONFIGURE_CMDS variable, it will be used instead - of the default autotools one. However, using this method should - be restricted to very specific cases. Do not use it in the - general case. - -18.7. Infrastructure for CMake-based packages - -18.7.1. cmake-package tutorial - -First, let’s see how to write a .mk file for a CMake-based package, -with an example : - -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_INSTALL_STAGING = YES -11: LIBFOO_INSTALL_TARGET = NO -12: LIBFOO_CONF_OPTS = -DBUILD_DEMOS=ON -13: LIBFOO_DEPENDENCIES = libglib2 host-pkgconf -14: -15: $(eval $(cmake-package)) - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10, we tell Buildroot to install the package to the staging -directory. The staging directory, located in output/staging/ is the -directory where all the packages are installed, including their -development files, etc. By default, packages are not installed to the -staging directory, since usually, only libraries need to be installed -in the staging directory: their development files are needed to -compile other libraries or applications depending on them. Also by -default, when staging installation is enabled, packages are installed -in this location using the make install command. - -On line 11, we tell Buildroot to not install the package to the -target directory. This directory contains what will become the root -filesystem running on the target. For purely static libraries, it is -not necessary to install them in the target directory because they -will not be used at runtime. By default, target installation is -enabled; setting this variable to NO is almost never needed. Also by -default, packages are installed in this location using the make -install command. - -On line 12, we tell Buildroot to pass custom options to CMake when it -is configuring the package. - -On line 13, we declare our dependencies, so that they are built -before the build process of our package starts. - -Finally, on line line 15, we invoke the cmake-package macro that -generates all the Makefile rules that actually allows the package to -be built. - -18.7.2. cmake-package reference - -The main macro of the CMake package infrastructure is cmake-package. -It is similar to the generic-package macro. The ability to have -target and host packages is also available, with the -host-cmake-package macro. - -Just like the generic infrastructure, the CMake infrastructure works -by defining a number of variables before calling the cmake-package -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the CMake infrastructure: -LIBFOO_VERSION, LIBFOO_SOURCE, LIBFOO_PATCH, LIBFOO_SITE, -LIBFOO_SUBDIR, LIBFOO_DEPENDENCIES, LIBFOO_INSTALL_STAGING, -LIBFOO_INSTALL_TARGET. - -A few additional variables, specific to the CMake infrastructure, can -also be defined. Many of them are only useful in very specific cases, -typical packages will therefore only use a few of them. - - * LIBFOO_SUBDIR may contain the name of a subdirectory inside the - package that contains the main CMakeLists.txt file. This is - useful, if for example, the main CMakeLists.txt file is not at - the root of the tree extracted by the tarball. If - HOST_LIBFOO_SUBDIR is not specified, it defaults to - LIBFOO_SUBDIR. - * LIBFOO_CONF_ENV, to specify additional environment variables to - pass to CMake. By default, empty. - * LIBFOO_CONF_OPTS, to specify additional configure options to pass - to CMake. By default, empty. A number of common CMake options are - set by the cmake-package infrastructure; so it is normally not - necessary to set them in the package’s *.mk file unless you want - to override them: - - + CMAKE_BUILD_TYPE is driven by BR2_ENABLE_RUNTIME_DEBUG; - + CMAKE_INSTALL_PREFIX; - + BUILD_SHARED_LIBS is driven by BR2_STATIC_LIBS; - + BUILD_DOC, BUILD_DOCS are disabled; - + BUILD_EXAMPLE, BUILD_EXAMPLES are disabled; - + BUILD_TEST, BUILD_TESTS, BUILD_TESTING are disabled. - * LIBFOO_SUPPORTS_IN_SOURCE_BUILD = NO should be set when the - package cannot be built inside the source tree but needs a - separate build directory. - * LIBFOO_MAKE, to specify an alternate make command. This is - typically useful when parallel make is enabled in the - configuration (using BR2_JLEVEL) but that this feature should be - disabled for the given package, for one reason or another. By - default, set to $(MAKE). If parallel building is not supported by - the package, then it should be set to LIBFOO_MAKE=$(MAKE1). - * LIBFOO_MAKE_ENV, to specify additional environment variables to - pass to make in the build step. These are passed before the make - command. By default, empty. - * LIBFOO_MAKE_OPTS, to specify additional variables to pass to make - in the build step. These are passed after the make command. By - default, empty. - * LIBFOO_INSTALL_OPTS contains the make options used to install the - package to the host directory. By default, the value is install, - which is correct for most CMake packages. It is still possible to - override it. - * LIBFOO_INSTALL_STAGING_OPTS contains the make options used to - install the package to the staging directory. By default, the - value is DESTDIR=$(STAGING_DIR) install/fast, which is correct - for most CMake packages. It is still possible to override it. - * LIBFOO_INSTALL_TARGET_OPTS contains the make options used to - install the package to the target directory. By default, the - value is DESTDIR=$(TARGET_DIR) install/fast. The default value is - correct for most CMake packages, but it is still possible to - override it if needed. - -With the CMake infrastructure, all the steps required to build and -install the packages are already defined, and they generally work -well for most CMake-based packages. However, when required, it is -still possible to customize what is done in any particular step: - - * By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the - various build steps” for details. - * By overriding one of the steps. For example, even if the CMake - infrastructure is used, if the package .mk file defines its own - LIBFOO_CONFIGURE_CMDS variable, it will be used instead of the - default CMake one. However, using this method should be - restricted to very specific cases. Do not use it in the general - case. - -18.8. Infrastructure for Python packages - -This infrastructure applies to Python packages that use the standard -Python setuptools mechanism as their build system, generally -recognizable by the usage of a setup.py script. - -18.8.1. python-package tutorial - -First, let’s see how to write a .mk file for a Python package, with -an example : - -01: ################################################################################ -02: # -03: # python-foo -04: # -05: ################################################################################ -06: -07: PYTHON_FOO_VERSION = 1.0 -08: PYTHON_FOO_SOURCE = python-foo-$(PYTHON_FOO_VERSION).tar.xz -09: PYTHON_FOO_SITE = http://www.foosoftware.org/download -10: PYTHON_FOO_LICENSE = BSD-3-Clause -11: PYTHON_FOO_LICENSE_FILES = LICENSE -12: PYTHON_FOO_ENV = SOME_VAR=1 -13: PYTHON_FOO_DEPENDENCIES = libmad -14: PYTHON_FOO_SETUP_TYPE = distutils -15: -16: $(eval $(python-package)) - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10 and 11, we give licensing details about the package (its -license on line 10, and the file containing the license text on line -11). - -On line 12, we tell Buildroot to pass custom options to the Python -setup.py script when it is configuring the package. - -On line 13, we declare our dependencies, so that they are built -before the build process of our package starts. - -On line 14, we declare the specific Python build system being used. -In this case the distutils Python build system is used. The two -supported ones are distutils and setuptools. - -Finally, on line 16, we invoke the python-package macro that -generates all the Makefile rules that actually allow the package to -be built. - -18.8.2. python-package reference - -As a policy, packages that merely provide Python modules should all -be named python- in Buildroot. Other packages that use the -Python build system, but are not Python modules, can freely choose -their name (existing examples in Buildroot are scons and supervisor). - -Packages that are only compatible with one version of Python (as in: -Python 2 or Python 3) should depend on that version explicitely in -their Config.in file (BR2_PACKAGE_PYTHON for Python 2, -BR2_PACKAGE_PYTHON3 for Python 3). Packages that are compatible with -both versions should not explicitely depend on them in their -Config.in file, since that condition is already expressed for the -whole "External python modules" menu. - -The main macro of the Python package infrastructure is -python-package. It is similar to the generic-package macro. It is -also possible to create Python host packages with the -host-python-package macro. - -Just like the generic infrastructure, the Python infrastructure works -by defining a number of variables before calling the python-package -or host-python-package macros. - -All the package metadata information variables that exist in the -generic package infrastructure also exist in the Python -infrastructure: PYTHON_FOO_VERSION, PYTHON_FOO_SOURCE, -PYTHON_FOO_PATCH, PYTHON_FOO_SITE, PYTHON_FOO_SUBDIR, -PYTHON_FOO_DEPENDENCIES, PYTHON_FOO_LICENSE, -PYTHON_FOO_LICENSE_FILES, PYTHON_FOO_INSTALL_STAGING, etc. - -Note that: - - * It is not necessary to add python or host-python in the - PYTHON_FOO_DEPENDENCIES variable of a package, since these basic - dependencies are automatically added as needed by the Python - package infrastructure. - * Similarly, it is not needed to add host-setuptools to - PYTHON_FOO_DEPENDENCIES for setuptools-based packages, since it’s - automatically added by the Python infrastructure as needed. - -One variable specific to the Python infrastructure is mandatory: - - * PYTHON_FOO_SETUP_TYPE, to define which Python build system is - used by the package. The two supported values are distutils and - setuptools. If you don’t know which one is used in your package, - look at the setup.py file in your package source code, and see - whether it imports things from the distutils module or the - setuptools module. - -A few additional variables, specific to the Python infrastructure, -can optionally be defined, depending on the package’s needs. Many of -them are only useful in very specific cases, typical packages will -therefore only use a few of them, or none. - - * PYTHON_FOO_SUBDIR may contain the name of a subdirectory inside - the package that contains the main setup.py file. This is useful, - if for example, the main setup.py file is not at the root of the - tree extracted by the tarball. If HOST_PYTHON_FOO_SUBDIR is not - specified, it defaults to PYTHON_FOO_SUBDIR. - * PYTHON_FOO_ENV, to specify additional environment variables to - pass to the Python setup.py script (for both the build and - install steps). Note that the infrastructure is automatically - passing several standard variables, defined in - PKG_PYTHON_DISTUTILS_ENV (for distutils target packages), - HOST_PKG_PYTHON_DISTUTILS_ENV (for distutils host packages), - PKG_PYTHON_SETUPTOOLS_ENV (for setuptools target packages) and - HOST_PKG_PYTHON_SETUPTOOLS_ENV (for setuptools host packages). - * PYTHON_FOO_BUILD_OPTS, to specify additional options to pass to - the Python setup.py script during the build step. For target - distutils packages, the PKG_PYTHON_DISTUTILS_BUILD_OPTS options - are already passed automatically by the infrastructure. - * PYTHON_FOO_INSTALL_TARGET_OPTS, PYTHON_FOO_INSTALL_STAGING_OPTS, - HOST_PYTHON_FOO_INSTALL_OPTS to specify additional options to - pass to the Python setup.py script during the target installation - step, the staging installation step or the host installation, - respectively. Note that the infrastructure is automatically - passing some options, defined in - PKG_PYTHON_DISTUTILS_INSTALL_TARGET_OPTS or - PKG_PYTHON_DISTUTILS_INSTALL_STAGING_OPTS (for target distutils - packages), HOST_PKG_PYTHON_DISTUTILS_INSTALL_OPTS (for host - distutils packages), PKG_PYTHON_SETUPTOOLS_INSTALL_TARGET_OPTS or - PKG_PYTHON_SETUPTOOLS_INSTALL_STAGING_OPTS (for target setuptools - packages) and HOST_PKG_PYTHON_SETUPTOOLS_INSTALL_OPTS (for host - setuptools packages). - * HOST_PYTHON_FOO_NEEDS_HOST_PYTHON, to define the host python - interpreter. The usage of this variable is limited to host - packages. The two supported value are python2 and python3. It - will ensure the right host python package is available and will - invoke it for the build. If some build steps are overloaded, the - right python interpreter must be explicitly called in the - commands. - -With the Python infrastructure, all the steps required to build and -install the packages are already defined, and they generally work -well for most Python-based packages. However, when required, it is -still possible to customize what is done in any particular step: - - * By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the - various build steps” for details. - * By overriding one of the steps. For example, even if the Python - infrastructure is used, if the package .mk file defines its own - PYTHON_FOO_BUILD_CMDS variable, it will be used instead of the - default Python one. However, using this method should be - restricted to very specific cases. Do not use it in the general - case. - -18.8.3. Generating a python-package from a PyPI repository - -If the Python package for which you would like to create a Buildroot -package is available on PyPI, you may want to use the scanpypi tool -located in utils/ to automate the process. - -You can find the list of existing PyPI packages here [https:// -pypi.python.org]. - -scanpypi requires Python’s setuptools package to be installed on your -host. - -When at the root of your buildroot directory just do : - -utils/scanpypi foo bar -o package - -This will generate packages python-foo and python-bar in the package -folder if they exist on https://pypi.python.org. - -Find the external python modules menu and insert your package inside. -Keep in mind that the items inside a menu should be in alphabetical -order. - -Please keep in mind that you’ll most likely have to manually check -the package for any mistakes as there are things that cannot be -guessed by the generator (e.g. dependencies on any of the python core -modules such as BR2_PACKAGE_PYTHON_ZLIB). Also, please take note that -the license and license files are guessed and must be checked. You -also need to manually add the package to the package/Config.in file. - -If your Buildroot package is not in the official Buildroot tree but -in a br2-external tree, use the -o flag as follows: - -utils/scanpypi foo bar -o other_package_dir - -This will generate packages python-foo and python-bar in the -other_package_directory instead of package. - -Option -h will list the available options: - -utils/scanpypi -h - -18.8.4. python-package CFFI backend - -C Foreign Function Interface for Python (CFFI) provides a convenient -and reliable way to call compiled C code from Python using interface -declarations written in C. Python packages relying on this backend -can be identified by the appearance of a cffi dependency in the -install_requires field of their setup.py file. - -Such a package should: - - * add python-cffi as a runtime dependency in order to install the - compiled C library wrapper on the target. This is achieved by - adding select BR2_PACKAGE_PYTHON_CFFI to the package Config.in. - -config BR2_PACKAGE_PYTHON_FOO - bool "python-foo" - select BR2_PACKAGE_PYTHON_CFFI # runtime - - * add host-python-cffi as a build-time dependency in order to - cross-compile the C wrapper. This is achieved by adding - host-python-cffi to the PYTHON_FOO_DEPENDENCIES variable. - -################################################################################ -# -# python-foo -# -################################################################################ - -... - -PYTHON_FOO_DEPENDENCIES = host-python-cffi - -$(eval $(python-package)) - -18.9. Infrastructure for LuaRocks-based packages - -18.9.1. luarocks-package tutorial - -First, let’s see how to write a .mk file for a LuaRocks-based -package, with an example : - -01: ################################################################################ -02: # -03: # lua-foo -04: # -05: ################################################################################ -06: -07: LUA_FOO_VERSION = 1.0.2-1 -08: LUA_FOO_NAME_UPSTREAM = foo -09: LUA_FOO_DEPENDENCIES = bar -10: -11: LUA_FOO_BUILD_OPTS += BAR_INCDIR=$(STAGING_DIR)/usr/include -12: LUA_FOO_BUILD_OPTS += BAR_LIBDIR=$(STAGING_DIR)/usr/lib -13: LUA_FOO_LICENSE = luaFoo license -14: LUA_FOO_LICENSE_FILES = $(LUA_FOO_SUBDIR)/COPYING -15: -16: $(eval $(luarocks-package)) - -On line 7, we declare the version of the package (the same as in the -rockspec, which is the concatenation of the upstream version and the -rockspec revision, separated by a hyphen -). - -On line 8, we declare that the package is called "foo" on LuaRocks. -In Buildroot, we give Lua-related packages a name that starts with -"lua", so the Buildroot name is different from the upstream name. -LUA_FOO_NAME_UPSTREAM makes the link between the two names. - -On line 9, we declare our dependencies against native libraries, so -that they are built before the build process of our package starts. - -On lines 11-12, we tell Buildroot to pass custom options to LuaRocks -when it is building the package. - -On lines 13-14, we specify the licensing terms for the package. - -Finally, on line 16, we invoke the luarocks-package macro that -generates all the Makefile rules that actually allows the package to -be built. - -Most of these details can be retrieved from the rock and rockspec. -So, this file and the Config.in file can be generated by running the -command luarocks buildroot foo lua-foo in the Buildroot directory. -This command runs a specific Buildroot addon of luarocks that will -automatically generate a Buildroot package. The result must still be -manually inspected and possibly modified. - - * The package/Config.in file has to be updated manually to include - the generated Config.in files. - -18.9.2. luarocks-package reference - -LuaRocks is a deployment and management system for Lua modules, and -supports various build.type: builtin, make and cmake. In the context -of Buildroot, the luarocks-package infrastructure only supports the -builtin mode. LuaRocks packages that use the make or cmake build -mechanisms should instead be packaged using the generic-package and -cmake-package infrastructures in Buildroot, respectively. - -The main macro of the LuaRocks package infrastructure is -luarocks-package: like generic-package it works by defining a number -of variables providing metadata information about the package, and -then calling luarocks-package. - -Just like the generic infrastructure, the LuaRocks infrastructure -works by defining a number of variables before calling the -luarocks-package macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the LuaRocks infrastructure: -LUA_FOO_VERSION, LUA_FOO_SOURCE, LUA_FOO_SITE, LUA_FOO_DEPENDENCIES, -LUA_FOO_LICENSE, LUA_FOO_LICENSE_FILES. - -Two of them are populated by the LuaRocks infrastructure (for the -download step). If your package is not hosted on the LuaRocks mirror -$(BR2_LUAROCKS_MIRROR), you can override them: - - * LUA_FOO_SITE, which defaults to $(BR2_LUAROCKS_MIRROR) - * LUA_FOO_SOURCE, which defaults to $(lowercase - LUA_FOO_NAME_UPSTREAM)-$(LUA_FOO_VERSION).src.rock - -A few additional variables, specific to the LuaRocks infrastructure, -are also defined. They can be overridden in specific cases. - - * LUA_FOO_NAME_UPSTREAM, which defaults to lua-foo, i.e. the - Buildroot package name - * LUA_FOO_ROCKSPEC, which defaults to $(lowercase - LUA_FOO_NAME_UPSTREAM)-$(LUA_FOO_VERSION).rockspec - * LUA_FOO_SUBDIR, which defaults to $(LUA_FOO_NAME_UPSTREAM)-$ - (LUA_FOO_VERSION_WITHOUT_ROCKSPEC_REVISION) - * LUA_FOO_BUILD_OPTS contains additional build options for the - luarocks build call. - -18.10. Infrastructure for Perl/CPAN packages - -18.10.1. perl-package tutorial - -First, let’s see how to write a .mk file for a Perl/CPAN package, -with an example : - -01: ################################################################################ -02: # -03: # perl-foo-bar -04: # -05: ################################################################################ -06: -07: PERL_FOO_BAR_VERSION = 0.02 -08: PERL_FOO_BAR_SOURCE = Foo-Bar-$(PERL_FOO_BAR_VERSION).tar.gz -09: PERL_FOO_BAR_SITE = $(BR2_CPAN_MIRROR)/authors/id/M/MO/MONGER -10: PERL_FOO_BAR_DEPENDENCIES = perl-strictures -11: PERL_FOO_BAR_LICENSE = Artistic or GPL-1.0+ -12: PERL_FOO_BAR_LICENSE_FILES = LICENSE -13: PERL_FOO_BAR_DISTNAME = Foo-Bar -14: -15: $(eval $(perl-package)) - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball and the location -of the tarball on a CPAN server. Buildroot will automatically -download the tarball from this location. - -On line 10, we declare our dependencies, so that they are built -before the build process of our package starts. - -On line 11 and 12, we give licensing details about the package (its -license on line 11, and the file containing the license text on line -12). - -On line 13, the name of the distribution as needed by the script -utils/scancpan (in order to regenerate/upgrade these package files). - -Finally, on line 15, we invoke the perl-package macro that generates -all the Makefile rules that actually allow the package to be built. - -Most of these data can be retrieved from https://metacpan.org/. So, -this file and the Config.in can be generated by running the script -utils/scancpan Foo-Bar in the Buildroot directory (or in a -br2-external tree). This script creates a Config.in file and -foo-bar.mk file for the requested package, and also recursively for -all dependencies specified by CPAN. You should still manually edit -the result. In particular, the following things should be checked. - - * If the perl module links with a shared library that is provided - by another (non-perl) package, this dependency is not added - automatically. It has to be added manually to - PERL_FOO_BAR_DEPENDENCIES. - * The package/Config.in file has to be updated manually to include - the generated Config.in files. As a hint, the scancpan script - prints out the required source "…" statements, sorted - alphabetically. - -18.10.2. perl-package reference - -As a policy, packages that provide Perl/CPAN modules should all be -named perl- in Buildroot. - -This infrastructure handles various Perl build systems : -ExtUtils-MakeMaker (EUMM), Module-Build (MB) and Module-Build-Tiny. -Build.PL is preferred by default when a package provides a -Makefile.PL and a Build.PL. - -The main macro of the Perl/CPAN package infrastructure is -perl-package. It is similar to the generic-package macro. The ability -to have target and host packages is also available, with the -host-perl-package macro. - -Just like the generic infrastructure, the Perl/CPAN infrastructure -works by defining a number of variables before calling the -perl-package macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the Perl/CPAN -infrastructure: PERL_FOO_VERSION, PERL_FOO_SOURCE, PERL_FOO_PATCH, -PERL_FOO_SITE, PERL_FOO_SUBDIR, PERL_FOO_DEPENDENCIES, -PERL_FOO_INSTALL_TARGET. - -Note that setting PERL_FOO_INSTALL_STAGING to YES has no effect -unless a PERL_FOO_INSTALL_STAGING_CMDS variable is defined. The perl -infrastructure doesn’t define these commands since Perl modules -generally don’t need to be installed to the staging directory. - -A few additional variables, specific to the Perl/CPAN infrastructure, -can also be defined. Many of them are only useful in very specific -cases, typical packages will therefore only use a few of them. - - * PERL_FOO_PREFER_INSTALLER/HOST_PERL_FOO_PREFER_INSTALLER, - specifies the preferred installation method. Possible values are - EUMM (for Makefile.PL based installation using - ExtUtils-MakeMaker) and MB (for Build.PL based installation using - Module-Build). This variable is only used when the package - provides both installation methods. - * PERL_FOO_CONF_ENV/HOST_PERL_FOO_CONF_ENV, to specify additional - environment variables to pass to the perl Makefile.PL or perl - Build.PL. By default, empty. - * PERL_FOO_CONF_OPTS/HOST_PERL_FOO_CONF_OPTS, to specify additional - configure options to pass to the perl Makefile.PL or perl - Build.PL. By default, empty. - * PERL_FOO_BUILD_OPTS/HOST_PERL_FOO_BUILD_OPTS, to specify - additional options to pass to make pure_all or perl Build build - in the build step. By default, empty. - * PERL_FOO_INSTALL_TARGET_OPTS, to specify additional options to - pass to make pure_install or perl Build install in the install - step. By default, empty. - * HOST_PERL_FOO_INSTALL_OPTS, to specify additional options to pass - to make pure_install or perl Build install in the install step. - By default, empty. - -18.11. Infrastructure for virtual packages - -In Buildroot, a virtual package is a package whose functionalities -are provided by one or more packages, referred to as providers. The -virtual package management is an extensible mechanism allowing the -user to choose the provider used in the rootfs. - -For example, OpenGL ES is an API for 2D and 3D graphics on embedded -systems. The implementation of this API is different for the -Allwinner Tech Sunxi and the Texas Instruments OMAP35xx platforms. So -libgles will be a virtual package and sunxi-mali and ti-gfx will be -the providers. - -18.11.1. virtual-package tutorial - -In the following example, we will explain how to add a new virtual -package (something-virtual) and a provider for it (some-provider). - -First, let’s create the virtual package. - -18.11.2. Virtual package’s Config.in file - -The Config.in file of virtual package something-virtual should -contain: - -01: config BR2_PACKAGE_HAS_SOMETHING_VIRTUAL -02: bool -03: -04: config BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL -05: depends on BR2_PACKAGE_HAS_SOMETHING_VIRTUAL -06: string - -In this file, we declare two options, -BR2_PACKAGE_HAS_SOMETHING_VIRTUAL and -BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL, whose values will be used by -the providers. - -18.11.3. Virtual package’s .mk file - -The .mk for the virtual package should just evaluate the -virtual-package macro: - -01: ################################################################################ -02: # -03: # something-virtual -04: # -05: ################################################################################ -06: -07: $(eval $(virtual-package)) - -The ability to have target and host packages is also available, with -the host-virtual-package macro. - -18.11.4. Provider’s Config.in file - -When adding a package as a provider, only the Config.in file requires -some modifications. - -The Config.in file of the package some-provider, which provides the -functionalities of something-virtual, should contain: - -01: config BR2_PACKAGE_SOME_PROVIDER -02: bool "some-provider" -03: select BR2_PACKAGE_HAS_SOMETHING_VIRTUAL -04: help -05: This is a comment that explains what some-provider is. -06: -07: http://foosoftware.org/some-provider/ -08: -09: if BR2_PACKAGE_SOME_PROVIDER -10: config BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL -11: default "some-provider" -12: endif - -On line 3, we select BR2_PACKAGE_HAS_SOMETHING_VIRTUAL, and on line -11, we set the value of BR2_PACKAGE_PROVIDES_SOMETHING_VIRTUAL to the -name of the provider, but only if it is selected. - -18.11.5. Provider’s .mk file - -The .mk file should also declare an additional variable -SOME_PROVIDER_PROVIDES to contain the names of all the virtual -packages it is an implementation of: - -01: SOME_PROVIDER_PROVIDES = something-virtual - -Of course, do not forget to add the proper build and runtime -dependencies for this package! - -18.11.6. Notes on depending on a virtual package - -When adding a package that requires a certain FEATURE provided by a -virtual package, you have to use depends on BR2_PACKAGE_HAS_FEATURE, -like so: - -config BR2_PACKAGE_HAS_FEATURE - bool - -config BR2_PACKAGE_FOO - bool "foo" - depends on BR2_PACKAGE_HAS_FEATURE - -18.11.7. Notes on depending on a specific provider - -If your package really requires a specific provider, then you’ll have -to make your package depends on this provider; you can not select a -provider. - -Let’s take an example with two providers for a FEATURE: - -config BR2_PACKAGE_HAS_FEATURE - bool - -config BR2_PACKAGE_FOO - bool "foo" - select BR2_PACKAGE_HAS_FEATURE - -config BR2_PACKAGE_BAR - bool "bar" - select BR2_PACKAGE_HAS_FEATURE - -And you are adding a package that needs FEATURE as provided by foo, -but not as provided by bar. - -If you were to use select BR2_PACKAGE_FOO, then the user would still -be able to select BR2_PACKAGE_BAR in the menuconfig. This would -create a configuration inconsistency, whereby two providers of the -same FEATURE would be enabled at once, one explicitly set by the -user, the other implicitly by your select. - -Instead, you have to use depends on BR2_PACKAGE_FOO, which avoids any -implicit configuration inconsistency. - -18.12. Infrastructure for packages using kconfig for configuration -files - -A popular way for a software package to handle user-specified -configuration is kconfig. Among others, it is used by the Linux -kernel, Busybox, and Buildroot itself. The presence of a .config file -and a menuconfig target are two well-known symptoms of kconfig being -used. - -Buildroot features an infrastructure for packages that use kconfig -for their configuration. This infrastructure provides the necessary -logic to expose the package’s menuconfig target as foo-menuconfig in -Buildroot, and to handle the copying back and forth of the -configuration file in a correct way. - -The kconfig-package infrastructure is based on the generic-package -infrastructure. All variables supported by generic-package are -available in kconfig-package as well. See Section 18.5.2, -“generic-package reference” for more details. - -In order to use the kconfig-package infrastructure for a Buildroot -package, the minimally required lines in the .mk file, in addition to -the variables required by the generic-package infrastructure, are: - -FOO_KCONFIG_FILE = reference-to-source-configuration-file - -$(eval $(kconfig-package)) - -This snippet creates the following make targets: - - * foo-menuconfig, which calls the package’s menuconfig target - * foo-update-config, which copies the configuration back to the - source configuration file. It is not possible to use this target - when fragment files are set. - * foo-update-defconfig, which copies the configuration back to the - source configuration file. The configuration file will only list - the options that differ from the default values. It is not - possible to use this target when fragment files are set. - * foo-diff-config, which outputs the differences between the - current configuration and the one defined in the Buildroot - configuration for this kconfig package. The output is useful to - identify the configuration changes that may have to be propagated - to configuration fragments for example. - -and ensures that the source configuration file is copied to the build -directory at the right moment. - -There are two options to specify a configuration file to use, either -FOO_KCONFIG_FILE (as in the example, above) or FOO_KCONFIG_DEFCONFIG. -It is mandatory to provide either, but not both: - - * FOO_KCONFIG_FILE specifies the path to a defconfig or full-config - file to be used to configure the package. - * FOO_KCONFIG_DEFCONFIG specifies the defconfig make rule to call - to configure the package. - -In addition to these minimally required lines, several optional -variables can be set to suit the needs of the package under -consideration: - - * FOO_KCONFIG_EDITORS: a space-separated list of kconfig editors to - support, for example menuconfig xconfig. By default, menuconfig. - * FOO_KCONFIG_FRAGMENT_FILES: a space-separated list of - configuration fragment files that are merged to the main - configuration file. Fragment files are typically used when there - is a desire to stay in sync with an upstream (def)config file, - with some minor modifications. - * FOO_KCONFIG_OPTS: extra options to pass when calling the kconfig - editors. This may need to include $(FOO_MAKE_OPTS), for example. - By default, empty. - * FOO_KCONFIG_FIXUP_CMDS: a list of shell commands needed to fixup - the configuration file after copying it or running a kconfig - editor. Such commands may be needed to ensure a configuration - consistent with other configuration of Buildroot, for example. By - default, empty. - * FOO_KCONFIG_DOTCONFIG: path (with filename) of the .config file, - relative to the package source tree. The default, .config, should - be well suited for all packages that use the standard kconfig - infrastructure as inherited from the Linux kernel; some packages - use a derivative of kconfig that use a different location. - * FOO_KCONFIG_DEPENDENCIES: the list of packages (most probably, - host packages) that need to be built before this package’s - kconfig is interpreted. Seldom used. By default, empty. - * FOO_KCONFIG_SUPPORTS_DEFCONFIG: whether the package’s kconfig - system supports using defconfig files; few packages do not. By - default, YES. - -18.13. Infrastructure for rebar-based packages - -18.13.1. rebar-package tutorial - -First, let’s see how to write a .mk file for a rebar-based package, -with an example : - -01: ################################################################################ -02: # -03: # erlang-foobar -04: # -05: ################################################################################ -06: -07: ERLANG_FOOBAR_VERSION = 1.0 -08: ERLANG_FOOBAR_SOURCE = erlang-foobar-$(ERLANG_FOOBAR_VERSION).tar.xz -09: ERLANG_FOOBAR_SITE = http://www.foosoftware.org/download -10: ERLANG_FOOBAR_DEPENDENCIES = host-libaaa libbbb -11: -12: $(eval $(rebar-package)) - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10, we declare our dependencies, so that they are built -before the build process of our package starts. - -Finally, on line 12, we invoke the rebar-package macro that generates -all the Makefile rules that actually allows the package to be built. - -18.13.2. rebar-package reference - -The main macro of the rebar package infrastructure is rebar-package. -It is similar to the generic-package macro. The ability to have host -packages is also available, with the host-rebar-package macro. - -Just like the generic infrastructure, the rebar infrastructure works -by defining a number of variables before calling the rebar-package -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the rebar infrastructure: -ERLANG_FOOBAR_VERSION, ERLANG_FOOBAR_SOURCE, ERLANG_FOOBAR_PATCH, -ERLANG_FOOBAR_SITE, ERLANG_FOOBAR_SUBDIR, ERLANG_FOOBAR_DEPENDENCIES, -ERLANG_FOOBAR_INSTALL_STAGING, ERLANG_FOOBAR_INSTALL_TARGET, -ERLANG_FOOBAR_LICENSE and ERLANG_FOOBAR_LICENSE_FILES. - -A few additional variables, specific to the rebar infrastructure, can -also be defined. Many of them are only useful in very specific cases, -typical packages will therefore only use a few of them. - - * ERLANG_FOOBAR_USE_AUTOCONF, to specify that the package uses - autoconf at the configuration step. When a package sets this - variable to YES, the autotools infrastructure is used. - - Note. You can also use some of the variables from the autotools - infrastructure: ERLANG_FOOBAR_CONF_ENV, ERLANG_FOOBAR_CONF_OPTS, - ERLANG_FOOBAR_AUTORECONF, ERLANG_FOOBAR_AUTORECONF_ENV and - ERLANG_FOOBAR_AUTORECONF_OPTS. - - * ERLANG_FOOBAR_USE_BUNDLED_REBAR, to specify that the package has - a bundled version of rebar and that it shall be used. Valid - values are YES or NO (the default). - - Note. If the package bundles a rebar utility, but can use the - generic one that Buildroot provides, just say NO (i.e., do not - specify this variable). Only set if it is mandatory to use the - rebar utility bundled in this package. - - * ERLANG_FOOBAR_REBAR_ENV, to specify additional environment - variables to pass to the rebar utility. - * ERLANG_FOOBAR_KEEP_DEPENDENCIES, to keep the dependencies - described in the rebar.config file. Valid values are YES or NO - (the default). Unless this variable is set to YES, the rebar - infrastructure removes such dependencies in a post-patch hook to - ensure rebar does not download nor compile them. - -With the rebar infrastructure, all the steps required to build and -install the packages are already defined, and they generally work -well for most rebar-based packages. However, when required, it is -still possible to customize what is done in any particular step: - - * By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the - various build steps” for details. - * By overriding one of the steps. For example, even if the rebar - infrastructure is used, if the package .mk file defines its own - ERLANG_FOOBAR_BUILD_CMDS variable, it will be used instead of the - default rebar one. However, using this method should be - restricted to very specific cases. Do not use it in the general - case. - -18.14. Infrastructure for Waf-based packages - -18.14.1. waf-package tutorial - -First, let’s see how to write a .mk file for a Waf-based package, -with an example : - -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_CONF_OPTS = --enable-bar --disable-baz -11: LIBFOO_DEPENDENCIES = bar -12: -13: $(eval $(waf-package)) - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10, we tell Buildroot what options to enable for libfoo. - -On line 11, we tell Buildroot the dependencies of libfoo. - -Finally, on line line 13, we invoke the waf-package macro that -generates all the Makefile rules that actually allows the package to -be built. - -18.14.2. waf-package reference - -The main macro of the Waf package infrastructure is waf-package. It -is similar to the generic-package macro. - -Just like the generic infrastructure, the Waf infrastructure works by -defining a number of variables before calling the waf-package macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the Waf infrastructure: -LIBFOO_VERSION, LIBFOO_SOURCE, LIBFOO_PATCH, LIBFOO_SITE, -LIBFOO_SUBDIR, LIBFOO_DEPENDENCIES, LIBFOO_INSTALL_STAGING, -LIBFOO_INSTALL_TARGET. - -An additional variable, specific to the Waf infrastructure, can also -be defined. - - * LIBFOO_SUBDIR may contain the name of a subdirectory inside the - package that contains the main wscript file. This is useful, if - for example, the main wscript file is not at the root of the tree - extracted by the tarball. If HOST_LIBFOO_SUBDIR is not specified, - it defaults to LIBFOO_SUBDIR. - * LIBFOO_NEEDS_EXTERNAL_WAF can be set to YES or NO to tell - Buildroot to use the bundled waf executable. If set to NO, the - default, then Buildroot will use the waf executable provided in - the package source tree; if set to YES, then Buildroot will - download, install waf as a host tool and use it to build the - package. - * LIBFOO_WAF_OPTS, to specify additional options to pass to the waf - script at every step of the package build process: configure, - build and installation. By default, empty. - * LIBFOO_CONF_OPTS, to specify additional options to pass to the - waf script for the configuration step. By default, empty. - * LIBFOO_BUILD_OPTS, to specify additional options to pass to the - waf script during the build step. By default, empty. - * LIBFOO_INSTALL_STAGING_OPTS, to specify additional options to - pass to the waf script during the staging installation step. By - default, empty. - * LIBFOO_INSTALL_TARGET_OPTS, to specify additional options to pass - to the waf script during the target installation step. By - default, empty. - -18.15. Infrastructure for Meson-based packages - -18.15.1. meson-package tutorial - -Meson [http://mesonbuild.com] is an open source build system meant to -be both extremely fast, and, even more importantly, as user friendly -as possible. It uses Ninja [https://ninja-build.org] as a companion -tool to perform the actual build operations. - -Let’s see how to write a .mk file for a Meson-based package, with an -example: - -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.0 -08: FOO_SOURCE = foo-$(FOO_VERSION).tar.gz -09: FOO_SITE = http://www.foosoftware.org/download -10: FOO_LICENSE = GPL-3.0+ -11: FOO_LICENSE_FILES = COPYING -12: FOO_INSTALL_STAGING = YES -13: -14: FOO_DEPENDENCIES = host-pkgconf bar -15: -16: ifeq ($(BR2_PACKAGE_BAZ),y) -17: FOO_CONF_OPTS += -Dbaz=true -18: FOO_DEPENDENCIES += baz -19: else -20: FOO_CONF_OPTS += -Dbaz=false -21: endif -22: -23: $(eval $(meson-package)) - -The Makefile starts with the definition of the standard variables for -package declaration (lines 7 to 11). - -On line line 23, we invoke the meson-package macro that generates all -the Makefile rules that actually allows the package to be built. - -In the example, host-pkgconf and bar are declared as dependencies in -FOO_DEPENDENCIES at line 14 because the Meson build file of foo uses -pkg-config to determine the compilation flags and libraries of -package bar. - -Note that it is not necessary to add host-meson in the -FOO_DEPENDENCIES variable of a package, since this basic dependency -is automatically added as needed by the Meson package infrastructure. - -If the "baz" package is selected, then support for the "baz" feature -in "foo" is activated by adding -Dbaz=true to FOO_CONF_OPTS at line -17, as specified in the meson_options.txt file in "foo" source tree. -The "baz" package is also added to FOO_DEPENDENCIES. Note that the -support for baz is explicitly disabled at line 20, if the package is -not selected. - -To sum it up, to add a new meson-based package, the Makefile example -can be copied verbatim then edited to replace all occurences of FOO -with the uppercase name of the new package and update the values of -the standard variables. - -18.15.2. meson-package reference - -The main macro of the Meson package infrastructure is meson-package. -It is similar to the generic-package macro. The ability to have -target and host packages is also available, with the -host-meson-package macro. - -Just like the generic infrastructure, the Meson infrastructure works -by defining a number of variables before calling the meson-package -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the Meson infrastructure: -FOO_VERSION, FOO_SOURCE, FOO_PATCH, FOO_SITE, FOO_SUBDIR, -FOO_DEPENDENCIES, FOO_INSTALL_STAGING, FOO_INSTALL_TARGET. - -A few additional variables, specific to the Meson infrastructure, can -also be defined. Many of them are only useful in very specific cases, -typical packages will therefore only use a few of them. - - * FOO_SUBDIR may contain the name of a subdirectory inside the - package that contains the main meson.build file. This is useful, - if for example, the main meson.build file is not at the root of - the tree extracted by the tarball. If HOST_FOO_SUBDIR is not - specified, it defaults to FOO_SUBDIR. - * FOO_CONF_ENV, to specify additional environment variables to pass - to meson for the configuration step. By default, empty. - * FOO_CONF_OPTS, to specify additional options to pass to meson for - the configuration step. By default, empty. - * FOO_CFLAGS, to specify compiler arguments added to the package - specific cross-compile.conf file c_args property. By default, the - value of TARGET_CFLAGS. - * FOO_CXXFLAGS, to specify compiler arguments added to the package - specific cross-compile.conf file cpp_args property. By default, - the value of TARGET_CXXFLAGS. - * FOO_LDFLAGS, to specify compiler arguments added to the package - specific cross-compile.conf file c_link_args and cpp_link_args - properties. By default, the value of TARGET_LDFLAGS. - * FOO_MESON_EXTRA_BINARIES, to specify a space-separated list of - programs to add to the [binaries] section of the meson - cross-compilation.conf configuration file. The format is - program-name='/path/to/program', with no space around the = sign, - and with the path of the program between single quotes. By - default, empty. Note that Buildroot already sets the correct - values for c, cpp, ar, strip, and pkgconfig. - * FOO_MESON_EXTRA_PROPERTIES, to specify a space-separated list of - properties to add to the [properties] section of the meson - cross-compilation.conf configuration file. The format is - property-name= with no space around the = sign, and with - single quotes around string values. By default, empty. Note that - Buildroot already sets values for needs_exe_wrapper, c_args, - c_link_args, cpp_args, cpp_link_args, sys_root, and - pkg_config_libdir. - * FOO_NINJA_ENV, to specify additional environment variables to - pass to ninja, meson companion tool in charge of the build - operations. By default, empty. - * FOO_NINJA_OPTS, to specify a space-separated list of targets to - build. By default, empty, to build the default target(s). - -18.16. Integration of Cargo-based packages - -Cargo is the package manager for the Rust programming language. It -allows the user to build programs or libraries written in Rust, but -it also downloads and manages their dependencies, to ensure -repeatable builds. Cargo packages are called "crates". - -18.16.1. Cargo-based package’s Config.in file - -The Config.in file of Cargo-based package foo should contain: - -01: config BR2_PACKAGE_FOO -02: bool "foo" -03: depends on BR2_PACKAGE_HOST_RUSTC_TARGET_ARCH_SUPPORTS -04: select BR2_PACKAGE_HOST_RUSTC -05: help -06: This is a comment that explains what foo is. -07: -08: http://foosoftware.org/foo/ - -18.16.2. Cargo-based package’s .mk file - -Buildroot does not (yet) provide a dedicated package infrastructure -for Cargo-based packages. So, we will explain how to write a .mk file -for such a package. Let’s start with an example: - -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.0 -08: FOO_SOURCE = foo-$(FOO_VERSION).tar.gz -09: FOO_SITE = http://www.foosoftware.org/download -10: FOO_LICENSE = GPL-3.0+ -11: FOO_LICENSE_FILES = COPYING -12: -13: FOO_DEPENDENCIES = host-rustc -14: -15: FOO_CARGO_ENV = CARGO_HOME=$(HOST_DIR)/share/cargo -16: -17: FOO_BIN_DIR = target/$(RUSTC_TARGET_NAME)/$(FOO_CARGO_MODE) -18: -19: FOO_CARGO_OPTS = \ -20: $(if $(BR2_ENABLE_DEBUG),,--release) \ -21: --target=$(RUSTC_TARGET_NAME) \ -22: --manifest-path=$(@D)/Cargo.toml -23: -24: define FOO_BUILD_CMDS -25: $(TARGET_MAKE_ENV) $(FOO_CARGO_ENV) \ -26: cargo build $(FOO_CARGO_OPTS) -27: endef -28: -29: define FOO_INSTALL_TARGET_CMDS -30: $(INSTALL) -D -m 0755 $(@D)/$(FOO_BIN_DIR)/foo \ -31: $(TARGET_DIR)/usr/bin/foo -32: endef -33: -34: $(eval $(generic-package)) - -The Makefile starts with the definition of the standard variables for -package declaration (lines 7 to 11). - -As seen in line 34, it is based on the generic-package infrastructure -. So, it defines the variables required by this particular -infrastructure, where Cargo is invoked: - - * FOO_BUILD_CMDS: Cargo is invoked to perform the build. The - options required to configure the cross-compilation of the - package are passed via FOO_CONF_OPTS. - * FOO_INSTALL_TARGET_CMDS: The binary executable generated is - installed on the target. - -In order to have Cargo available for the build, FOO_DEPENDENCIES -needs to contain host-cargo. - -To sum it up, to add a new Cargo-based package, the Makefile example -can be copied verbatim then edited to replace all occurences of FOO -with the uppercase name of the new package and update the values of -the standard variables. - -18.16.3. About Dependencies Management - -A crate can depend on other libraries from crates.io or git -repositories, listed in its Cargo.toml file. Before starting a build, -Cargo usually downloads automatically them. This step can also be -performed independently, via the cargo fetch command. - -Cargo maintains a local cache of the registry index and of git -checkouts of the crates, whose location is given by $CARGO_HOME. As -seen in the package Makefile example at line 15, this environment -variable is set to $(HOST_DIR)/share/cargo. - -This dependency download mechanism is not convenient when performing -an offline build, as Cargo will fail to fetch the dependencies. In -that case, it is advised to generate a tarball of the dependencies -using the cargo vendor and add it to FOO_EXTRA_DOWNLOADS. - -18.17. Infrastructure for Go packages - -This infrastructure applies to Go packages that use the standard -build system and use bundled dependencies. - -18.17.1. golang-package tutorial - -First, let’s see how to write a .mk file for a go package, with an -example : - -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.0 -08: FOO_SITE = $(call github,bar,foo,$(FOO_VERSION)) -09: FOO_LICENSE = BSD-3-Clause -10: FOO_LICENSE_FILES = LICENSE -11: -12: $(eval $(golang-package)) - -On line 7, we declare the version of the package. - -On line 8, we declare the upstream location of the package, here -fetched from Github, since a large number of Go packages are hosted -on Github. - -On line 9 and 10, we give licensing details about the package. - -Finally, on line 12, we invoke the golang-package macro that -generates all the Makefile rules that actually allow the package to -be built. - -18.17.2. golang-package reference - -In their Config.in file, packages using the golang-package -infrastructure should depend on -BR2_PACKAGE_HOST_GO_TARGET_ARCH_SUPPORTS because Buildroot will -automatically add a dependency on host-go to such packages. If you -need CGO support in your package, you must add a dependency on -BR2_PACKAGE_HOST_GO_TARGET_CGO_LINKING_SUPPORTS. - -The main macro of the Go package infrastructure is golang-package. It -is similar to the generic-package macro. The ability to build host -packages is also available, with the host-golang-package macro. Host -packages built by host-golang-package macro should depend on -BR2_PACKAGE_HOST_GO_HOST_ARCH_SUPPORTS. - -Just like the generic infrastructure, the Go infrastructure works by -defining a number of variables before calling the golang-package. - -All the package metadata information variables that exist in the -generic package infrastructure also exist in the Go infrastructure: -FOO_VERSION, FOO_SOURCE, FOO_PATCH, FOO_SITE, FOO_SUBDIR, -FOO_DEPENDENCIES, FOO_LICENSE, FOO_LICENSE_FILES, -FOO_INSTALL_STAGING, etc. - -Note that it is not necessary to add host-go in the FOO_DEPENDENCIES -variable of a package, since this basic dependency is automatically -added as needed by the Go package infrastructure. - -A few additional variables, specific to the Go infrastructure, can -optionally be defined, depending on the package’s needs. Many of them -are only useful in very specific cases, typical packages will -therefore only use a few of them, or none. - - * The package must specify its Go module name in the FOO_GOMOD - variable. If not specified, it defaults to URL-domain/ - 1st-part-of-URL/2nd-part-of-URL, e.g FOO_GOMOD will take the - value github.com/bar/foo for a package that specifies FOO_SITE = - $(call github,bar,foo,$(FOO_VERSION)). The Go package - infrastructure will automatically generate a minimal go.mod file - in the package source tree if it doesn’t exist. - * FOO_LDFLAGS and FOO_TAGS can be used to pass respectively the - LDFLAGS or the TAGS to the go build command. - * FOO_BUILD_TARGETS can be used to pass the list of targets that - should be built. If FOO_BUILD_TARGETS is not specified, it - defaults to .. We then have two cases: - - + FOO_BUILD_TARGETS is .. In this case, we assume only one - binary will be produced, and that by default we name it after - the package name. If that is not appropriate, the name of the - produced binary can be overridden using FOO_BIN_NAME. - + FOO_BUILD_TARGETS is not .. In this case, we iterate over the - values to build each target, and for each produced a binary - that is the non-directory component of the target. For - example if FOO_BUILD_TARGETS = cmd/docker cmd/dockerd the - binaries produced are docker and dockerd. - * FOO_INSTALL_BINS can be used to pass the list of binaries that - should be installed in /usr/bin on the target. If - FOO_INSTALL_BINS is not specified, it defaults to the lower-case - name of package. - -With the Go infrastructure, all the steps required to build and -install the packages are already defined, and they generally work -well for most Go-based packages. However, when required, it is still -possible to customize what is done in any particular step: - - * By adding a post-operation hook (after extract, patch, configure, - build or install). See Section 18.22, “Hooks available in the - various build steps” for details. - * By overriding one of the steps. For example, even if the Go - infrastructure is used, if the package .mk file defines its own - FOO_BUILD_CMDS variable, it will be used instead of the default - Go one. However, using this method should be restricted to very - specific cases. Do not use it in the general case. - -18.18. Infrastructure for QMake-based packages - -18.18.1. qmake-package tutorial - -First, let’s see how to write a .mk file for a QMake-based package, -with an example : - -01: ################################################################################ -02: # -03: # libfoo -04: # -05: ################################################################################ -06: -07: LIBFOO_VERSION = 1.0 -08: LIBFOO_SOURCE = libfoo-$(LIBFOO_VERSION).tar.gz -09: LIBFOO_SITE = http://www.foosoftware.org/download -10: LIBFOO_CONF_OPTS = QT_CONFIG+=bar QT_CONFIG-=baz -11: LIBFOO_DEPENDENCIES = bar -12: -13: $(eval $(qmake-package)) - -On line 7, we declare the version of the package. - -On line 8 and 9, we declare the name of the tarball (xz-ed tarball -recommended) and the location of the tarball on the Web. Buildroot -will automatically download the tarball from this location. - -On line 10, we tell Buildroot what options to enable for libfoo. - -On line 11, we tell Buildroot the dependencies of libfoo. - -Finally, on line line 13, we invoke the qmake-package macro that -generates all the Makefile rules that actually allows the package to -be built. - -18.18.2. qmake-package reference - -The main macro of the QMake package infrastructure is qmake-package. -It is similar to the generic-package macro. - -Just like the generic infrastructure, the QMake infrastructure works -by defining a number of variables before calling the qmake-package -macro. - -First, all the package metadata information variables that exist in -the generic infrastructure also exist in the QMake infrastructure: -LIBFOO_VERSION, LIBFOO_SOURCE, LIBFOO_PATCH, LIBFOO_SITE, -LIBFOO_SUBDIR, LIBFOO_DEPENDENCIES, LIBFOO_INSTALL_STAGING, -LIBFOO_INSTALL_TARGET. - -An additional variable, specific to the QMake infrastructure, can -also be defined. - - * LIBFOO_CONF_ENV, to specify additional environment variables to - pass to the qmake script for the configuration step. By default, - empty. - * LIBFOO_CONF_OPTS, to specify additional options to pass to the - qmake script for the configuration step. By default, empty. - * LIBFOO_MAKE_ENV, to specify additional environment variables to - the make command during the build and install steps. By default, - empty. - * LIBFOO_MAKE_OPTS, to specify additional targets to pass to the - make command during the build step. By default, empty. - * LIBFOO_INSTALL_STAGING_OPTS, to specify additional targets to - pass to the make command during the staging installation step. By - default, install. - * LIBFOO_INSTALL_TARGET_OPTS, to specify additional targets to pass - to the make command during the target installation step. By - default, install. - * LIBFOO_SYNC_QT_HEADERS, to run syncqt.pl before qmake. Some - packages need this to have a properly populated include directory - before running the build. - -18.19. Infrastructure for packages building kernel modules - -Buildroot offers a helper infrastructure to make it easy to write -packages that build and install Linux kernel modules. Some packages -only contain a kernel module, other packages contain programs and -libraries in addition to kernel modules. Buildroot’s helper -infrastructure supports either case. - -18.19.1. kernel-module tutorial - -Let’s start with an example on how to prepare a simple package that -only builds a kernel module, and no other component: - -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.2.3 -08: FOO_SOURCE = foo-$(FOO_VERSION).tar.xz -09: FOO_SITE = http://www.foosoftware.org/download -10: FOO_LICENSE = GPL-2.0 -11: FOO_LICENSE_FILES = COPYING -12: -13: $(eval $(kernel-module)) -14: $(eval $(generic-package)) - -Lines 7-11 define the usual meta-data to specify the version, archive -name, remote URI where to find the package source, licensing -information. - -On line 13, we invoke the kernel-module helper infrastructure, that -generates all the appropriate Makefile rules and variables to build -that kernel module. - -Finally, on line 14, we invoke the generic-package infrastructure. - -The dependency on linux is automatically added, so it is not needed -to specify it in FOO_DEPENDENCIES. - -What you may have noticed is that, unlike other package -infrastructures, we explicitly invoke a second infrastructure. This -allows a package to build a kernel module, but also, if needed, use -any one of other package infrastructures to build normal userland -components (libraries, executables…). Using the kernel-module -infrastructure on its own is not sufficient; another package -infrastructure must be used. - -Let’s look at a more complex example: - -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: FOO_VERSION = 1.2.3 -08: FOO_SOURCE = foo-$(FOO_VERSION).tar.xz -09: FOO_SITE = http://www.foosoftware.org/download -10: FOO_LICENSE = GPL-2.0 -11: FOO_LICENSE_FILES = COPYING -12: -13: FOO_MODULE_SUBDIRS = driver/base -14: FOO_MODULE_MAKE_OPTS = KVERSION=$(LINUX_VERSION_PROBED) -15: -16: ifeq ($(BR2_PACKAGE_LIBBAR),y) -17: FOO_DEPENDENCIES = libbar -18: FOO_CONF_OPTS = --enable-bar -19: FOO_MODULE_SUBDIRS += driver/bar -20: else -21: FOO_CONF_OPTS = --disable-bar -22: endif -23: -24: $(eval $(kernel-module)) -26: $(eval $(autotools-package)) - -Here, we see that we have an autotools-based package, that also -builds the kernel module located in sub-directory driver/base and, if -libbar is enabled, the kernel module located in sub-directory driver/ -bar, and defines the variable KVERSION to be passed to the Linux -buildsystem when building the module(s). - -18.19.2. kernel-module reference - -The main macro for the kernel module infrastructure is kernel-module. -Unlike other package infrastructures, it is not stand-alone, and -requires any of the other *-package macros be called after it. - -The kernel-module macro defines post-build and post-target-install -hooks to build the kernel modules. If the package’s .mk needs access -to the built kernel modules, it should do so in a post-build hook, -registered after the call to kernel-module. Similarly, if the -package’s .mk needs access to the kernel module after it has been -installed, it should do so in a post-install hook, registered after -the call to kernel-module. Here’s an example: - -$(eval $(kernel-module)) - -define FOO_DO_STUFF_WITH_KERNEL_MODULE - # Do something with it... -endef -FOO_POST_BUILD_HOOKS += FOO_DO_STUFF_WITH_KERNEL_MODULE - -$(eval $(generic-package)) - -Finally, unlike the other package infrastructures, there is no -host-kernel-module variant to build a host kernel module. - -The following additional variables can optionally be defined to -further configure the build of the kernel module: - - * FOO_MODULE_SUBDIRS may be set to one or more sub-directories - (relative to the package source top-directory) where the kernel - module sources are. If empty or not set, the sources for the - kernel module(s) are considered to be located at the top of the - package source tree. - * FOO_MODULE_MAKE_OPTS may be set to contain extra variable - definitions to pass to the Linux buildsystem. - -You may also reference (but you may not set!) those variables: - - * LINUX_DIR contains the path to where the Linux kernel has been - extracted and built. - * LINUX_VERSION contains the version string as configured by the - user. - * LINUX_VERSION_PROBED contains the real version string of the - kernel, retrieved with running make -C $(LINUX_DIR) kernelrelease - * KERNEL_ARCH contains the name of the current architecture, like - arm, mips… - -18.20. Infrastructure for asciidoc documents - -The Buildroot manual, which you are currently reading, is entirely -written using the AsciiDoc [http://asciidoc.org/] mark-up syntax. The -manual is then rendered to many formats: - - * html - * split-html - * pdf - * epub - * text - -Although Buildroot only contains one document written in AsciiDoc, -there is, as for packages, an infrastructure for rendering documents -using the AsciiDoc syntax. - -Also as for packages, the AsciiDoc infrastructure is available from a -br2-external tree. This allows documentation for a br2-external tree -to match the Buildroot documentation, as it will be rendered to the -same formats and use the same layout and theme. - -18.20.1. asciidoc-document tutorial - -Whereas package infrastructures are suffixed with -package, the -document infrastructures are suffixed with -document. So, the -AsciiDoc infrastructure is named asciidoc-document. - -Here is an example to render a simple AsciiDoc document. - -01: ################################################################################ -02: # -03: # foo-document -04: # -05: ################################################################################ -06: -07: FOO_SOURCES = $(sort $(wildcard $(pkgdir)/*)) -08: $(eval $(call asciidoc-document)) - -On line 7, the Makefile declares what the sources of the document -are. Currently, it is expected that the document’s sources are only -local; Buildroot will not attempt to download anything to render a -document. Thus, you must indicate where the sources are. Usually, the -string above is sufficient for a document with no sub-directory -structure. - -On line 8, we call the asciidoc-document function, which generates -all the Makefile code necessary to render the document. - -18.20.2. asciidoc-document reference - -The list of variables that can be set in a .mk file to give metadata -information is (assuming the document name is foo) : - - * FOO_SOURCES, mandatory, defines the source files for the - document. - * FOO_RESOURCES, optional, may contain a space-separated list of - paths to one or more directories containing so-called resources - (like CSS or images). By default, empty. - * FOO_DEPENDENCIES, optional, the list of packages (most probably, - host-packages) that must be built before building this document. - -There are also additional hooks (see Section 18.22, “Hooks available -in the various build steps” for general information on hooks), that a -document may set to define extra actions to be done at various steps: - - * FOO_POST_RSYNC_HOOKS to run additional commands after the sources - have been copied by Buildroot. This can for example be used to - generate part of the manual with information extracted from the - tree. As an example, Buildroot uses this hook to generate the - tables in the appendices. - * FOO_CHECK_DEPENDENCIES_HOOKS to run additional tests on required - components to generate the document. In AsciiDoc, it is possible - to call filters, that is, programs that will parse an AsciiDoc - block and render it appropriately (e.g. ditaa [http:// - ditaa.sourceforge.net/] or aafigure [https://pythonhosted.org/ - aafigure/]). - * FOO_CHECK_DEPENDENCIES__HOOKS, to run additional tests for - the specified format (see the list of rendered formats, - above). - -Here is a complete example that uses all variables and all hooks: - -01: ################################################################################ -02: # -03: # foo-document -04: # -05: ################################################################################ -06: -07: FOO_SOURCES = $(sort $(wildcard $(pkgdir)/*)) -08: FOO_RESOURCES = $(sort $(wildcard $(pkgdir)/ressources)) -09: -10: define FOO_GEN_EXTRA_DOC -11: /path/to/generate-script --outdir=$(@D) -12: endef -13: FOO_POST_RSYNC_HOOKS += FOO_GEN_EXTRA_DOC -14: -15: define FOO_CHECK_MY_PROG -16: if ! which my-prog >/dev/null 2>&1; then \ -17: echo "You need my-prog to generate the foo document"; \ -18: exit 1; \ -19: fi -20: endef -21: FOO_CHECK_DEPENDENCIES_HOOKS += FOO_CHECK_MY_PROG -22: -23: define FOO_CHECK_MY_OTHER_PROG -24: if ! which my-other-prog >/dev/null 2>&1; then \ -25: echo "You need my-other-prog to generate the foo document as PDF"; \ -26: exit 1; \ -27: fi -28: endef -29: FOO_CHECK_DEPENDENCIES_PDF_HOOKS += FOO_CHECK_MY_OTHER_PROG -30: -31: $(eval $(call asciidoc-document)) - -18.21. Infrastructure specific to the Linux kernel package - -The Linux kernel package can use some specific infrastructures based -on package hooks for building Linux kernel tools or/and building -Linux kernel extensions. - -18.21.1. linux-kernel-tools - -Buildroot offers a helper infrastructure to build some userspace -tools for the target available within the Linux kernel sources. Since -their source code is part of the kernel source code, a special -package, linux-tools, exists and re-uses the sources of the Linux -kernel that runs on the target. - -Let’s look at an example of a Linux tool. For a new Linux tool named -foo, create a new menu entry in the existing package/linux-tools/ -Config.in. This file will contain the option descriptions related to -each kernel tool that will be used and displayed in the configuration -tool. It would basically look like: - -01: config BR2_PACKAGE_LINUX_TOOLS_FOO -02: bool "foo" -03: select BR2_PACKAGE_LINUX_TOOLS -04: help -05: This is a comment that explains what foo kernel tool is. -06: -07: http://foosoftware.org/foo/ - -The name of the option starts with the prefix -BR2_PACKAGE_LINUX_TOOLS_, followed by the uppercase name of the tool -(like is done for packages). - -Note. Unlike other packages, the linux-tools package options appear -in the linux kernel menu, under the Linux Kernel Tools sub-menu, not -under the Target packages main menu. - -Then for each linux tool, add a new .mk.in file named package/ -linux-tools/linux-tool-foo.mk.in. It would basically look like: - -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: LINUX_TOOLS += foo -08: -09: FOO_DEPENDENCIES = libbbb -10: -11: define FOO_BUILD_CMDS -12: $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools foo -13: endef -14: -15: define FOO_INSTALL_STAGING_CMDS -16: $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools \ -17: DESTDIR=$(STAGING_DIR) \ -18: foo_install -19: endef -20: -21: define FOO_INSTALL_TARGET_CMDS -22: $(TARGET_MAKE_ENV) $(MAKE) -C $(LINUX_DIR)/tools \ -23: DESTDIR=$(TARGET_DIR) \ -24: foo_install -25: endef - -On line 7, we register the Linux tool foo to the list of available -Linux tools. - -On line 9, we specify the list of dependencies this tool relies on. -These dependencies are added to the Linux package dependencies list -only when the foo tool is selected. - -The rest of the Makefile, lines 11-25 defines what should be done at -the different steps of the Linux tool build process like for a -generic package. They will actually be used only when the foo tool is -selected. The only supported commands are _BUILD_CMDS, -_INSTALL_STAGING_CMDS and _INSTALL_TARGET_CMDS. - -Note. One must not call $(eval $(generic-package)) or any other -package infrastructure! Linux tools are not packages by themselves, -they are part of the linux-tools package. - -18.21.2. linux-kernel-extensions - -Some packages provide new features that require the Linux kernel tree -to be modified. This can be in the form of patches to be applied on -the kernel tree, or in the form of new files to be added to the tree. -The Buildroot’s Linux kernel extensions infrastructure provides a -simple solution to automatically do this, just after the kernel -sources are extracted and before the kernel patches are applied. -Examples of extensions packaged using this mechanism are the -real-time extensions Xenomai and RTAI, as well as the set of -out-of-tree LCD screens drivers fbtft. - -Let’s look at an example on how to add a new Linux extension foo. - -First, create the package foo that provides the extension: this -package is a standard package; see the previous chapters on how to -create such a package. This package is in charge of downloading the -sources archive, checking the hash, defining the licence informations -and building user space tools if any. - -Then create the Linux extension proper: create a new menu entry in -the existing linux/Config.ext.in. This file contains the option -descriptions related to each kernel extension that will be used and -displayed in the configuration tool. It would basically look like: - -01: config BR2_LINUX_KERNEL_EXT_FOO -02: bool "foo" -03: help -04: This is a comment that explains what foo kernel extension is. -05: -06: http://foosoftware.org/foo/ - -Then for each linux extension, add a new .mk file named linux/ -linux-ext-foo.mk. It should basically contain: - -01: ################################################################################ -02: # -03: # foo -04: # -05: ################################################################################ -06: -07: LINUX_EXTENSIONS += foo -08: -09: define FOO_PREPARE_KERNEL -10: $(FOO_DIR)/prepare-kernel-tree.sh --linux-dir=$(@D) -11: endef - -On line 7, we add the Linux extension foo to the list of available -Linux extensions. - -On line 9-11, we define what should be done by the extension to -modify the Linux kernel tree; this is specific to the linux extension -and can use the variables defined by the foo package, like: $ -(FOO_DIR) or $(FOO_VERSION)… as well as all the Linux variables, -like: $(LINUX_VERSION) or $(LINUX_VERSION_PROBED), $(KERNEL_ARCH)… -See the definition of those kernel variables. - -18.22. Hooks available in the various build steps - -The generic infrastructure (and as a result also the derived -autotools and cmake infrastructures) allow packages to specify hooks. -These define further actions to perform after existing steps. Most -hooks aren’t really useful for generic packages, since the .mk file -already has full control over the actions performed in each step of -the package construction. - -The following hook points are available: - - * LIBFOO_PRE_DOWNLOAD_HOOKS - * LIBFOO_POST_DOWNLOAD_HOOKS - * LIBFOO_PRE_EXTRACT_HOOKS - * LIBFOO_POST_EXTRACT_HOOKS - * LIBFOO_PRE_RSYNC_HOOKS - * LIBFOO_POST_RSYNC_HOOKS - * LIBFOO_PRE_PATCH_HOOKS - * LIBFOO_POST_PATCH_HOOKS - * LIBFOO_PRE_CONFIGURE_HOOKS - * LIBFOO_POST_CONFIGURE_HOOKS - * LIBFOO_PRE_BUILD_HOOKS - * LIBFOO_POST_BUILD_HOOKS - * LIBFOO_PRE_INSTALL_HOOKS (for host packages only) - * LIBFOO_POST_INSTALL_HOOKS (for host packages only) - * LIBFOO_PRE_INSTALL_STAGING_HOOKS (for target packages only) - * LIBFOO_POST_INSTALL_STAGING_HOOKS (for target packages only) - * LIBFOO_PRE_INSTALL_TARGET_HOOKS (for target packages only) - * LIBFOO_POST_INSTALL_TARGET_HOOKS (for target packages only) - * LIBFOO_PRE_INSTALL_IMAGES_HOOKS - * LIBFOO_POST_INSTALL_IMAGES_HOOKS - * LIBFOO_PRE_LEGAL_INFO_HOOKS - * LIBFOO_POST_LEGAL_INFO_HOOKS - -These variables are lists of variable names containing actions to be -performed at this hook point. This allows several hooks to be -registered at a given hook point. Here is an example: - -define LIBFOO_POST_PATCH_FIXUP - action1 - action2 -endef - -LIBFOO_POST_PATCH_HOOKS += LIBFOO_POST_PATCH_FIXUP - -18.22.1. Using the POST_RSYNC hook - -The POST_RSYNC hook is run only for packages that use a local source, -either through the local site method or the OVERRIDE_SRCDIR -mechanism. In this case, package sources are copied using rsync from -the local location into the buildroot build directory. The rsync -command does not copy all files from the source directory, though. -Files belonging to a version control system, like the directories -.git, .hg, etc. are not copied. For most packages this is sufficient, -but a given package can perform additional actions using the -POST_RSYNC hook. - -In principle, the hook can contain any command you want. One specific -use case, though, is the intentional copying of the version control -directory using rsync. The rsync command you use in the hook can, -among others, use the following variables: - - * $(SRCDIR): the path to the overridden source directory - * $(@D): the path to the build directory - -18.22.2. Target-finalize hook - -Packages may also register hooks in LIBFOO_TARGET_FINALIZE_HOOKS. -These hooks are run after all packages are built, but before the -filesystem images are generated. They are seldom used, and your -package probably do not need them. - -18.23. Gettext integration and interaction with packages - -Many packages that support internationalization use the gettext -library. Dependencies for this library are fairly complicated and -therefore, deserve some explanation. - -The glibc C library integrates a full-blown implementation of gettext -, supporting translation. Native Language Support is therefore -built-in in glibc. - -On the other hand, the uClibc and musl C libraries only provide a -stub implementation of the gettext functionality, which allows to -compile libraries and programs using gettext functions, but without -providing the translation capabilities of a full-blown gettext -implementation. With such C libraries, if real Native Language -Support is necessary, it can be provided by the libintl library of -the gettext package. - -Due to this, and in order to make sure that Native Language Support -is properly handled, packages in Buildroot that can use NLS support -should: - - 1. Ensure NLS support is enabled when BR2_SYSTEM_ENABLE_NLS=y. This - is done automatically for autotools packages and therefore should - only be done for packages using other package infrastructures. - 2. Add $(TARGET_NLS_DEPENDENCIES) to the package _DEPENDENCIES - variable. This addition should be done unconditionally: the value - of this variable is automatically adjusted by the core - infrastructure to contain the relevant list of packages. If NLS - support is disabled, this variable is empty. If NLS support is - enabled, this variable contains host-gettext so that tools needed - to compile translation files are available on the host. In - addition, if uClibc or musl are used, this variable also contains - gettext in order to get the full-blown gettext implementation. - 3. If needed, add $(TARGET_NLS_LIBS) to the linker flags, so that - the package gets linked with libintl. This is generally not - needed with autotools packages as they usually detect - automatically that they should link with libintl. However, - packages using other build systems, or problematic - autotools-based packages may need this. $(TARGET_NLS_LIBS) should - be added unconditionally to the linker flags, as the core - automatically makes it empty or defined to -lintl depending on - the configuration. - -No changes should be made to the Config.in file to support NLS. - -Finally, certain packages need some gettext utilities on the target, -such as the gettext program itself, which allows to retrieve -translated strings, from the command line. In such a case, the -package should: - - * use select BR2_PACKAGE_GETTEXT in their Config.in file, - indicating in a comment above that it’s a runtime dependency - only. - * not add any gettext dependency in the DEPENDENCIES variable of - their .mk file. - -18.24. Tips and tricks - -18.24.1. Package name, config entry name and makefile variable -relationship - -In Buildroot, there is some relationship between: - - * the package name, which is the package directory name (and the - name of the *.mk file); - * the config entry name that is declared in the Config.in file; - * the makefile variable prefix. - -It is mandatory to maintain consistency between these elements, using -the following rules: - - * the package directory and the *.mk name are the package name - itself (e.g.: package/foo-bar_boo/foo-bar_boo.mk); - * the make target name is the package name itself (e.g.: - foo-bar_boo); - * the config entry is the upper case package name with . and - - characters substituted with _, prefixed with BR2_PACKAGE_ (e.g.: - BR2_PACKAGE_FOO_BAR_BOO); - * the *.mk file variable prefix is the upper case package name with - . and - characters substituted with _ (e.g.: - FOO_BAR_BOO_VERSION). - -18.24.2. How to check the coding style - -Buildroot provides a script in utils/check-package that checks new or -changed files for coding style. It is not a complete language -validator, but it catches many common mistakes. It is meant to run in -the actual files you created or modified, before creating the patch -for submission. - -This script can be used for packages, filesystem makefiles, Config.in -files, etc. It does not check the files defining the package -infrastructures and some other files containing similar common code. - -To use it, run the check-package script, by telling which files you -created or changed: - -$ ./utils/check-package package/new-package/* - -If you have the utils directory in your path you can also run: - -$ cd package/new-package/ -$ check-package * - -The tool can also be used for packages in a br2-external: - -$ check-package -b /path/to/br2-ext-tree/package/my-package/* - -18.24.3. How to test your package - -Once you have added your new package, it is important that you test -it under various conditions: does it build for all architectures? -Does it build with the different C libraries? Does it need threads, -NPTL? And so on… - -Buildroot runs autobuilders [http://autobuild.buildroot.org/] which -continuously test random configurations. However, these only build -the master branch of the git tree, and your new fancy package is not -yet there. - -Buildroot provides a script in utils/test-pkg that uses the same base -configurations as used by the autobuilders so you can test your -package in the same conditions. - -First, create a config snippet that contains all the necessary -options needed to enable your package, but without any architecture -or toolchain option. For example, let’s create a config snippet that -just enables libcurl, without any TLS backend: - -$ cat libcurl.config -BR2_PACKAGE_LIBCURL=y - -If your package needs more configuration options, you can add them to -the config snippet. For example, here’s how you would test libcurl -with openssl as a TLS backend and the curl program: - -$ cat libcurl.config -BR2_PACKAGE_LIBCURL=y -BR2_PACKAGE_LIBCURL_CURL=y -BR2_PACKAGE_OPENSSL=y - -Then run the test-pkg script, by telling it what config snippet to -use and what package to test: - -$ ./utils/test-pkg -c libcurl.config -p libcurl - -By default, test-pkg will build your package against a subset of the -toolchains used by the autobuilders, which has been selected by the -Buildroot developers as being the most useful and representative -subset. If you want to test all toolchains, pass the -a option. Note -that in any case, internal toolchains are excluded as they take too -long to build. - -The output lists all toolchains that are tested and the corresponding -result (excerpt, results are fake): - -$ ./utils/test-pkg -c libcurl.config -p libcurl - armv5-ctng-linux-gnueabi [ 1/11]: OK - armv7-ctng-linux-gnueabihf [ 2/11]: OK - br-aarch64-glibc [ 3/11]: SKIPPED - br-arcle-hs38 [ 4/11]: SKIPPED - br-arm-basic [ 5/11]: FAILED - br-arm-cortex-a9-glibc [ 6/11]: OK - br-arm-cortex-a9-musl [ 7/11]: FAILED - br-arm-cortex-m4-full [ 8/11]: OK - br-arm-full [ 9/11]: OK - br-arm-full-nothread [10/11]: FAILED - br-arm-full-static [11/11]: OK -11 builds, 2 skipped, 2 build failed, 1 legal-info failed - -The results mean: - - * OK: the build was successful. - * SKIPPED: one or more configuration options listed in the config - snippet were not present in the final configuration. This is due - to options having dependencies not satisfied by the toolchain, - such as for example a package that depends on BR2_USE_MMU with a - noMMU toolchain. The missing options are reported in - missing.config in the output build directory (~/br-test-pkg/ - TOOLCHAIN_NAME/ by default). - * FAILED: the build failed. Inspect the logfile file in the output - build directory to see what went wrong: - - + the actual build failed, - + the legal-info failed, - + one of the preliminary steps (downloading the config file, - applying the configuration, running dirclean for the package) - failed. - -When there are failures, you can just re-run the script with the same -options (after you fixed your package); the script will attempt to -re-build the package specified with -p for all toolchains, without -the need to re-build all the dependencies of that package. - -The test-pkg script accepts a few options, for which you can get some -help by running: - -$ ./utils/test-pkg -h - -18.24.4. How to add a package from GitHub - -Packages on GitHub often don’t have a download area with release -tarballs. However, it is possible to download tarballs directly from -the repository on GitHub. As GitHub is known to have changed download -mechanisms in the past, the github helper function should be used as -shown below. - -# Use a tag or a full commit ID -FOO_VERSION = 1.0 -FOO_SITE = $(call github,,,v$(FOO_VERSION)) - -Notes - - * The FOO_VERSION can either be a tag or a commit ID. - * The tarball name generated by github matches the default one from - Buildroot (e.g.: - foo-f6fb6654af62045239caed5950bc6c7971965e60.tar.gz), so it is - not necessary to specify it in the .mk file. - * When using a commit ID as version, you should use the full 40 hex - characters. - * When the tag contains a prefix such as v in v1.0, then the - VERSION variable should contain just 1.0, and the v should be - added directly in the SITE variable, as illustrated above. This - ensures that the VERSION variable value can be used to match - against release-monitoring.org [http://www.release-monitoring.org - /] results. - -If the package you wish to add does have a release section on GitHub, -the maintainer may have uploaded a release tarball, or the release -may just point to the automatically generated tarball from the git -tag. If there is a release tarball uploaded by the maintainer, we -prefer to use that since it may be slightly different (e.g. it -contains a configure script so we don’t need to do AUTORECONF). - -You can see on the release page if it’s an uploaded tarball or a git -tag: - - * If it looks like the image above then it was uploaded by the - maintainer and you should use that link (in that example: - mongrel2-v1.9.2.tar.bz2) to specify FOO_SITE, and not use the - github helper. - * On the other hand, if there’s is only the "Source code" link, - then it’s an automatically generated tarball and you should use - the github helper function. - -18.24.5. How to add a package from Gitlab - -In a similar way to the github macro described in Section 18.24.4, -“How to add a package from GitHub”, Buildroot also provides the -gitlab macro to download from Gitlab repositories. It can be used to -download auto-generated tarballs produced by Gitlab, either for -specific tags or commits: - -# Use a tag or a full commit ID -FOO_VERSION = 1.0 -FOO_SITE = $(call gitlab,,,v$(FOO_VERSION)) - -By default, it will use a .tar.gz tarball, but Gitlab also provides -.tar.bz2 tarballs, so by adding a _SOURCE variable, this -.tar.bz2 tarball can be used: - -# Use a tag or a full commit ID -FOO_VERSION = 1.0 -FOO_SITE = $(call gitlab,,,v$(FOO_VERSION)) -FOO_SOURCE = foo-$(FOO_VERSION).tar.bz2 - -If there is a specific tarball uploaded by the upstream developers in -https://gitlab.com//releases/, do not use this macro, but -rather use directly the link to the tarball. - -18.25. Conclusion - -As you can see, adding a software package to Buildroot is simply a -matter of writing a Makefile using an existing example and modifying -it according to the compilation process required by the package. - -If you package software that might be useful for other people, don’t -forget to send a patch to the Buildroot mailing list (see -Section 22.5, “Submitting patches”)! - -Chapter 19. Patching a package - -While integrating a new package or updating an existing one, it may -be necessary to patch the source of the software to get it -cross-built within Buildroot. - -Buildroot offers an infrastructure to automatically handle this -during the builds. It supports three ways of applying patch sets: -downloaded patches, patches supplied within buildroot and patches -located in a user-defined global patch directory. - -19.1. Providing patches - -19.1.1. Downloaded - -If it is necessary to apply a patch that is available for download, -then add it to the _PATCH variable. If an entry contains -://, then Buildroot will assume it is a full URL and download the -patch from this location. Otherwise, Buildroot will assume that the -patch should be downloaded from _SITE. It can be a -single patch, or a tarball containing a patch series. - -Like for all downloads, a hash should be added to the -.hash file. - -This method is typically used for packages from Debian. - -19.1.2. Within Buildroot - -Most patches are provided within Buildroot, in the package directory; -these typically aim to fix cross-compilation, libc support, or other -such issues. - -These patch files should be named -.patch. - -Notes - - * The patch files coming with Buildroot should not contain any - package version reference in their filename. - * The field in the patch file name refers to the apply - order, and shall start at 1; It is preferred to pad the number - with zeros up to 4 digits, like git-format-patch does. E.g.: - 0001-foobar-the-buz.patch - * Previously, it was mandatory for patches to be prefixed with the - name of the package, like --.patch, - but that is no longer the case. Existing packages will be fixed - as time passes. Do not prefix patches with the package name. - * Previously, a series file, as used by quilt, could also be added - in the package directory. In that case, the series file defines - the patch application order. This is deprecated, and will be - removed in the future. Do not use a series file. - -19.1.3. Global patch directory - -The BR2_GLOBAL_PATCH_DIR configuration file option can be used to -specify a space separated list of one or more directories containing -global package patches. See Section 9.8, “Adding project-specific -patches” for details. - -19.2. How patches are applied - - 1. Run the _PRE_PATCH_HOOKS commands if defined; - 2. Cleanup the build directory, removing any existing *.rej files; - 3. If _PATCH is defined, then patches from these - tarballs are applied; - 4. If there are some *.patch files in the package’s Buildroot - directory or in a package subdirectory named , - then: - - + If a series file exists in the package directory, then - patches are applied according to the series file; - + Otherwise, patch files matching *.patch are applied in - alphabetical order. So, to ensure they are applied in the - right order, it is highly recommended to name the patch files - like this: -.patch, where - refers to the apply order. - 5. If BR2_GLOBAL_PATCH_DIR is defined, the directories will be - enumerated in the order they are specified. The patches are - applied as described in the previous step. - 6. Run the _POST_PATCH_HOOKS commands if defined. - -If something goes wrong in the steps 3 or 4, then the build fails. - -19.3. Format and licensing of the package patches - -Patches are released under the same license as the software they -apply to (see Section 13.2, “Complying with the Buildroot license”). - -A message explaining what the patch does, and why it is needed, -should be added in the header commentary of the patch. - -You should add a Signed-off-by statement in the header of the each -patch to help with keeping track of the changes and to certify that -the patch is released under the same license as the software that is -modified. - -If the software is under version control, it is recommended to use -the upstream SCM software to generate the patch set. - -Otherwise, concatenate the header with the output of the diff -purN -package-version.orig/ package-version/ command. - -If you update an existing patch (e.g. when bumping the package -version), make sure the existing From header and Signed-off-by tags -are not removed, but do update the rest of the patch comment when -appropriate. - -At the end, the patch should look like: - -configure.ac: add C++ support test - -Signed-off-by: John Doe - ---- configure.ac.orig -+++ configure.ac -@@ -40,2 +40,12 @@ - -AC_PROG_MAKE_SET -+ -+AC_CACHE_CHECK([whether the C++ compiler works], -+ [rw_cv_prog_cxx_works], -+ [AC_LANG_PUSH([C++]) -+ AC_LINK_IFELSE([AC_LANG_PROGRAM([], [])], -+ [rw_cv_prog_cxx_works=yes], -+ [rw_cv_prog_cxx_works=no]) -+ AC_LANG_POP([C++])]) -+ -+AM_CONDITIONAL([CXX_WORKS], [test "x$rw_cv_prog_cxx_works" = "xyes"]) - -19.4. Integrating patches found on the Web - -When integrating a patch of which you are not the author, you have to -add a few things in the header of the patch itself. - -Depending on whether the patch has been obtained from the project -repository itself, or from somewhere on the web, add one of the -following tags: - -Backported from: - -or - -Fetch from: - -It is also sensible to add a few words about any changes to the patch -that may have been necessary. - -Chapter 20. Download infrastructure - -TODO - -Chapter 21. Debugging Buildroot - -It is possible to instrument the steps Buildroot does when building -packages. Define the variable BR2_INSTRUMENTATION_SCRIPTS to contain -the path of one or more scripts (or other executables), in a -space-separated list, you want called before and after each step. The -scripts are called in sequence, with three parameters: - - * start or end to denote the start (resp. the end) of a step; - * the name of the step about to be started, or which just ended; - * the name of the package. - -For example : - -make BR2_INSTRUMENTATION_SCRIPTS="/path/to/my/script1 /path/to/my/script2" - -The list of steps is: - - * extract - * patch - * configure - * build - * install-host, when a host-package is installed in $(HOST_DIR) - * install-target, when a target-package is installed in $ - (TARGET_DIR) - * install-staging, when a target-package is installed in $ - (STAGING_DIR) - * install-image, when a target-package installs files in $ - (BINARIES_DIR) - -The script has access to the following variables: - - * BR2_CONFIG: the path to the Buildroot .config file - * HOST_DIR, STAGING_DIR, TARGET_DIR: see Section 18.5.2, - “generic-package reference” - * BUILD_DIR: the directory where packages are extracted and built - * BINARIES_DIR: the place where all binary files (aka images) are - stored - * BASE_DIR: the base output directory - -Chapter 22. Contributing to Buildroot - -There are many ways in which you can contribute to Buildroot: -analyzing and fixing bugs, analyzing and fixing package build -failures detected by the autobuilders, testing and reviewing patches -sent by other developers, working on the items in our TODO list and -sending your own improvements to Buildroot or its manual. The -following sections give a little more detail on each of these items. - -If you are interested in contributing to Buildroot, the first thing -you should do is to subscribe to the Buildroot mailing list. This -list is the main way of interacting with other Buildroot developers -and to send contributions to. If you aren’t subscribed yet, then -refer to Chapter 5, Community resources for the subscription link. - -If you are going to touch the code, it is highly recommended to use a -git repository of Buildroot, rather than starting from an extracted -source code tarball. Git is the easiest way to develop from and -directly send your patches to the mailing list. Refer to Chapter 3, -Getting Buildroot for more information on obtaining a Buildroot git -tree. - -22.1. Reproducing, analyzing and fixing bugs - -A first way of contributing is to have a look at the open bug reports -in the Buildroot bug tracker [https://bugs.buildroot.org/buglist.cgi? -product=buildroot]. As we strive to keep the bug count as small as -possible, all help in reproducing, analyzing and fixing reported bugs -is more than welcome. Don’t hesitate to add a comment to bug reports -reporting your findings, even if you don’t yet see the full picture. - -22.2. Analyzing and fixing autobuild failures - -The Buildroot autobuilders are a set of build machines that -continuously run Buildroot builds based on random configurations. -This is done for all architectures supported by Buildroot, with -various toolchains, and with a random selection of packages. With the -large commit activity on Buildroot, these autobuilders are a great -help in detecting problems very early after commit. - -All build results are available at http://autobuild.buildroot.org, -statistics are at http://autobuild.buildroot.org/stats.php. Every -day, an overview of all failed packages is sent to the mailing list. - -Detecting problems is great, but obviously these problems have to be -fixed as well. Your contribution is very welcome here! There are -basically two things that can be done: - - * Analyzing the problems. The daily summary mails do not contain - details about the actual failures: in order to see what’s going - on you have to open the build log and check the last output. - Having someone doing this for all packages in the mail is very - useful for other developers, as they can make a quick initial - analysis based on this output alone. - * Fixing a problem. When fixing autobuild failures, you should - follow these steps: - - 1. Check if you can reproduce the problem by building with the - same configuration. You can do this manually, or use the - br-reproduce-build [http://git.buildroot.org/buildroot-test/ - tree/utils/br-reproduce-build] script that will automatically - clone a Buildroot git repository, checkout the correct - revision, download and set the right configuration, and start - the build. - 2. Analyze the problem and create a fix. - 3. Verify that the problem is really fixed by starting from a - clean Buildroot tree and only applying your fix. - 4. Send the fix to the Buildroot mailing list (see Section 22.5, - “Submitting patches”). In case you created a patch against - the package sources, you should also send the patch upstream - so that the problem will be fixed in a later release, and the - patch in Buildroot can be removed. In the commit message of a - patch fixing an autobuild failure, add a reference to the - build result directory, as follows: - -Fixes: http://autobuild.buildroot.org/results/51000a9d4656afe9e0ea6f07b9f8ed374c2e4069 - -22.3. Reviewing and testing patches - -With the amount of patches sent to the mailing list each day, the -maintainer has a very hard job to judge which patches are ready to -apply and which ones aren’t. Contributors can greatly help here by -reviewing and testing these patches. - -In the review process, do not hesitate to respond to patch -submissions for remarks, suggestions or anything that will help -everyone to understand the patches and make them better. Please use -internet style replies in plain text emails when responding to patch -submissions. - -To indicate approval of a patch, there are three formal tags that -keep track of this approval. To add your tag to a patch, reply to it -with the approval tag below the original author’s Signed-off-by line. -These tags will be picked up automatically by patchwork (see -Section 22.3.1, “Applying Patches from Patchwork”) and will be part -of the commit log when the patch is accepted. - -Tested-by - Indicates that the patch has been tested successfully. You are - encouraged to specify what kind of testing you performed - (compile-test on architecture X and Y, runtime test on target A, - …). This additional information helps other testers and the - maintainer. -Reviewed-by - Indicates that you code-reviewed the patch and did your best in - spotting problems, but you are not sufficiently familiar with the - area touched to provide an Acked-by tag. This means that there - may be remaining problems in the patch that would be spotted by - someone with more experience in that area. Should such problems - be detected, your Reviewed-by tag remains appropriate and you - cannot be blamed. -Acked-by - Indicates that you code-reviewed the patch and you are familiar - enough with the area touched to feel that the patch can be - committed as-is (no additional changes required). In case it - later turns out that something is wrong with the patch, your - Acked-by could be considered inappropriate. The difference - between Acked-by and Reviewed-by is thus mainly that you are - prepared to take the blame on Acked patches, but not on Reviewed - ones. - -If you reviewed a patch and have comments on it, you should simply -reply to the patch stating these comments, without providing a -Reviewed-by or Acked-by tag. These tags should only be provided if -you judge the patch to be good as it is. - -It is important to note that neither Reviewed-by nor Acked-by imply -that testing has been performed. To indicate that you both reviewed -and tested the patch, provide two separate tags (Reviewed/Acked-by -and Tested-by). - -Note also that any developer can provide Tested/Reviewed/Acked-by -tags, without exception, and we encourage everyone to do this. -Buildroot does not have a defined group of core developers, it just -so happens that some developers are more active than others. The -maintainer will value tags according to the track record of their -submitter. Tags provided by a regular contributor will naturally be -trusted more than tags provided by a newcomer. As you provide tags -more regularly, your trustworthiness (in the eyes of the maintainer) -will go up, but any tag provided is valuable. - -Buildroot’s Patchwork website can be used to pull in patches for -testing purposes. Please see Section 22.3.1, “Applying Patches from -Patchwork” for more information on using Buildroot’s Patchwork -website to apply patches. - -22.3.1. Applying Patches from Patchwork - -The main use of Buildroot’s Patchwork website for a developer is for -pulling in patches into their local git repository for testing -purposes. - -When browsing patches in the patchwork management interface, an mbox -link is provided at the top of the page. Copy this link address and -run the following commands: - -$ git checkout -b -$ wget -O - | git am - -Another option for applying patches is to create a bundle. A bundle -is a set of patches that you can group together using the patchwork -interface. Once the bundle is created and the bundle is made public, -you can copy the mbox link for the bundle and apply the bundle using -the above commands. - -22.4. Work on items from the TODO list - -If you want to contribute to Buildroot but don’t know where to start, -and you don’t like any of the above topics, you can always work on -items from the Buildroot TODO list [http://elinux.org/Buildroot# -Todo_list]. Don’t hesitate to discuss an item first on the mailing -list or on IRC. Do edit the wiki to indicate when you start working -on an item, so we avoid duplicate efforts. - -22.5. Submitting patches - -Note - -Please, do not attach patches to bugs, send them to the mailing list -instead. - -If you made some changes to Buildroot and you would like to -contribute them to the Buildroot project, proceed as follows. - -22.5.1. The formatting of a patch - -We expect patches to be formatted in a specific way. This is -necessary to make it easy to review patches, to be able to apply them -easily to the git repository, to make it easy to find back in the -history how and why things have changed, and to make it possible to -use git bisect to locate the origin of a problem. - -First of all, it is essential that the patch has a good commit -message. The commit message should start with a separate line with a -brief summary of the change, prefixed by the area touched by the -patch. A few examples of good commit titles: - - * package/linuxptp: bump version to 2.0 - * configs/imx23evk: bump Linux version to 4.19 - * package/pkg-generic: postpone evaluation of dependency conditions - * boot/uboot: needs host-{flex,bison} - * support/testing: add python-ubjson tests - -The description that follows the prefix should start with a lower -case letter (i.e "bump", "needs", "postpone", "add" in the above -examples). - -Second, the body of the commit message should describe why this -change is needed, and if necessary also give details about how it was -done. When writing the commit message, think of how the reviewers -will read it, but also think about how you will read it when you look -at this change again a few years down the line. - -Third, the patch itself should do only one change, but do it -completely. Two unrelated or weakly related changes should usually be -done in two separate patches. This usually means that a patch affects -only a single package. If several changes are related, it is often -still possible to split them up in small patches and apply them in a -specific order. Small patches make it easier to review, and often -make it easier to understand afterwards why a change was done. -However, each patch must be complete. It is not allowed that the -build is broken when only the first but not the second patch is -applied. This is necessary to be able to use git bisect afterwards. - -Of course, while you’re doing your development, you’re probably going -back and forth between packages, and certainly not committing things -immediately in a way that is clean enough for submission. So most -developers rewrite the history of commits to produce a clean set of -commits that is appropriate for submission. To do this, you need to -use interactive rebasing. You can learn about it in the Pro Git book -[https://git-scm.com/book/en/v2/Git-Tools-Rewriting-History]. -Sometimes, it is even easier to discard you history with git reset ---soft origin/master and select individual changes with git add -i or -git add -p. - -Finally, the patch should be signed off. This is done by adding -Signed-off-by: Your Real Name <> at the end of the commit message. -git commit -s does that for you, if configured properly. The -Signed-off-by tag means that you publish the patch under the -Buildroot license (i.e. GPL-2.0+, except for package patches, which -have the upstream license), and that you are allowed to do so. See -the Developer Certificate of Origin [http://developercertificate.org -/] for details. - -When adding new packages, you should submit every package in a -separate patch. This patch should have the update to package/ -Config.in, the package Config.in file, the .mk file, the .hash file, -any init script, and all package patches. If the package has many -sub-options, these are sometimes better added as separate follow-up -patches. The summary line should be something like : new -package. The body of the commit message can be empty for simple -packages, or it can contain the description of the package (like the -Config.in help text). If anything special has to be done to build the -package, this should also be explained explicitly in the commit -message body. - -When you bump a package to a new version, you should also submit a -separate patch for each package. Don’t forget to update the .hash -file, or add it if it doesn’t exist yet. Also don’t forget to check -if the _LICENSE and _LICENSE_FILES are still valid. The summary line -should be something like : bump to version . If the new version only contains security updates compared -to the existing one, the summary should be : security -bump to version and the commit message body should show -the CVE numbers that are fixed. If some package patches can be -removed in the new version, it should be explained explicitly why -they can be removed, preferably with the upstream commit ID. Also any -other required changes should be explained explicitly, like configure -options that no longer exist or are no longer needed. - -If you are interested in getting notified of build failures and of -further changes in the packages you added or modified, please add -yourself to the DEVELOPERS file. This should be done in the same -patch creating or modifying the package. See the DEVELOPERS file for -more information. - -Buildroot provides a handy tool to check for common coding style -mistakes on files you created or modified, called check-package (see -Section 18.24.2, “How to check the coding style” for more -information). - -22.5.2. Preparing a patch series - -Starting from the changes committed in your local git view, rebase -your development branch on top of the upstream tree before generating -a patch set. To do so, run: - -$ git fetch --all --tags -$ git rebase origin/master - -Now, you are ready to generate then submit your patch set. - -To generate it, run: - -$ git format-patch -M -n -s -o outgoing origin/master - -This will generate patch files in the outgoing subdirectory, -automatically adding the Signed-off-by line. - -Once patch files are generated, you can review/edit the commit -message before submitting them, using your favorite text editor. - -Buildroot provides a handy tool to know to whom your patches should -be sent, called get-developers (see Chapter 23, DEVELOPERS file and -get-developers for more information). This tool reads your patches -and outputs the appropriate git send-email command to use: - -$ ./utils/get-developers outgoing/* - -Use the output of get-developers to send your patches: - -$ git send-email --to buildroot@buildroot.org --cc bob --cc alice outgoing/* - -Alternatively, get-developers -e can be used directly with the ---cc-cmd argument to git send-email to automatically CC the affected -developers: - -$ git send-email --to buildroot@buildroot.org \ - --cc-cmd './utils/get-developers -e' origin/master - -git can be configured to automatically do this out of the box with: - -$ git config sendemail.to buildroot@buildroot.org -$ git config sendemail.ccCmd "$(pwd)/utils/get-developers -e" - -And then just do: - -$ git send-email origin/master - -Note that git should be configured to use your mail account. To -configure git, see man git-send-email or google it. - -If you do not use git send-email, make sure posted patches are not -line-wrapped, otherwise they cannot easily be applied. In such a -case, fix your e-mail client, or better yet, learn to use git -send-email. - -22.5.3. Cover letter - -If you want to present the whole patch set in a separate mail, add ---cover-letter to the git format-patch command (see man -git-format-patch for further information). This will generate a -template for an introduction e-mail to your patch series. - -A cover letter may be useful to introduce the changes you propose in -the following cases: - - * large number of commits in the series; - * deep impact of the changes in the rest of the project; - * RFC ^[4]; - * whenever you feel it will help presenting your work, your - choices, the review process, etc. - -22.5.4. Patches for maintenance branches - -When fixing bugs on a maintenance branch, bugs should be fixed on the -master branch first. The commit log for such a patch may then contain -a post-commit note specifying what branches are affected: - -package/foo: fix stuff - -Signed-off-by: Your Real Name ---- -Backport to: 2020.02.x, 2020.05.x -(2020.08.x not affected as the version was bumped) - -Those changes will then be backported by a maintainer to the affected -branches. - -However, some bugs may apply only to a specific release, for example -because it is using an older version of a package. In that case, -patches should be based off the maintenance branch, and the patch -subject prefix must include the maintenance branch name (for example -"[PATCH 2020.02.x]"). This can be done with the git format-patch flag ---subject-prefix: - -$ git format-patch --subject-prefix "PATCH 2020.02.x" \ - -M -s -o outgoing origin/2020.02.x - -Then send the patches with git send-email, as described above. - -22.5.5. Patch revision changelog - -When improvements are requested, the new revision of each commit -should include a changelog of the modifications between each -submission. Note that when your patch series is introduced by a cover -letter, an overall changelog may be added to the cover letter in -addition to the changelog in the individual commits. The best thing -to rework a patch series is by interactive rebasing: git rebase -i -origin/master. Consult the git manual for more information. - -When added to the individual commits, this changelog is added when -editing the commit message. Below the Signed-off-by section, add --- -and your changelog. - -Although the changelog will be visible for the reviewers in the mail -thread, as well as in patchwork [http://patchwork.buildroot.org], git -will automatically ignores lines below --- when the patch will be -merged. This is the intended behavior: the changelog is not meant to -be preserved forever in the git history of the project. - -Hereafter the recommended layout: - -Patch title: short explanation, max 72 chars - -A paragraph that explains the problem, and how it manifests itself. If -the problem is complex, it is OK to add more paragraphs. All paragraphs -should be wrapped at 72 characters. - -A paragraph that explains the root cause of the problem. Again, more -than one paragraph is OK. - -Finally, one or more paragraphs that explain how the problem is solved. -Don't hesitate to explain complex solutions in detail. - -Signed-off-by: John DOE - ---- -Changes v2 -> v3: - - foo bar (suggested by Jane) - - bar buz - -Changes v1 -> v2: - - alpha bravo (suggested by John) - - charly delta - -Any patch revision should include the version number. The version -number is simply composed of the letter v followed by an integer -greater or equal to two (i.e. "PATCH v2", "PATCH v3" …). - -This can be easily handled with git format-patch by using the option ---subject-prefix: - -$ git format-patch --subject-prefix "PATCH v4" \ - -M -s -o outgoing origin/master - -Since git version 1.8.1, you can also use -v (where is the -version number): - -$ git format-patch -v4 -M -s -o outgoing origin/master - -When you provide a new version of a patch, please mark the old one as -superseded in patchwork [http://patchwork.buildroot.org]. You need to -create an account on patchwork [http://patchwork.buildroot.org] to be -able to modify the status of your patches. Note that you can only -change the status of patches you submitted yourself, which means the -email address you register in patchwork [http:// -patchwork.buildroot.org] should match the one you use for sending -patches to the mailing list. - -You can also add the --in-reply-to option when -submitting a patch to the mailing list. The id of the mail to reply -to can be found under the "Message Id" tag on patchwork [http:// -patchwork.buildroot.org]. The advantage of in-reply-to is that -patchwork will automatically mark the previous version of the patch -as superseded. - -22.6. Reporting issues/bugs or getting help - -Before reporting any issue, please check in the mailing list archive -whether someone has already reported and/or fixed a similar problem. - -However you choose to report bugs or get help, either by opening a -bug in the bug tracker or by sending a mail to the mailing list, -there are a number of details to provide in order to help people -reproduce and find a solution to the issue. - -Try to think as if you were trying to help someone else; in that -case, what would you need? - -Here is a short list of details to provide in such case: - - * host machine (OS/release) - * version of Buildroot - * target for which the build fails - * package(s) for which the build fails - * the command that fails and its output - * any information you think that may be relevant - -Additionally, you should add the .config file (or if you know how, a -defconfig; see Section 9.3, “Storing the Buildroot configuration”). - -If some of these details are too large, do not hesitate to use a -pastebin service. Note that not all available pastebin services will -preserve Unix-style line terminators when downloading raw pastes. -Following pastebin services are known to work correctly: - https:// -gist.github.com/ - http://code.bulix.org/ - -22.7. Using the runtime tests framework - -Buildroot includes a run-time testing framework built upon Python -scripting and QEMU runtime execution. The goals of the framework are -the following: - - * build a well defined Buildroot configuration - * optionally, verify some properties of the build output - * optionally, boot the build results under Qemu, and verify that a - given feature is working as expected - -The entry point to use the runtime tests framework is the support/ -testing/run-tests tool, which has a series of options documented in -the tool’s help -h description. Some common options include setting -the download folder, the output folder, keeping build output, and for -multiple test cases, you can set the JLEVEL for each. - -Here is an example walk through of running a test case. - - * For a first step, let us see what all the test case options are. - The test cases can be listed by executing support/testing/ - run-tests -l. These tests can all be run individually during test - development from the console. Both one at a time and selectively - as a group of a subset of tests. - -$ support/testing/run-tests -l -List of tests -test_run (tests.utils.test_check_package.TestCheckPackage) -test_run (tests.toolchain.test_external.TestExternalToolchainBuildrootMusl) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainBuildrootuClibc) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainCCache) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainCtngMusl) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainLinaroArm) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv4) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv5) ... ok -test_run (tests.toolchain.test_external.TestExternalToolchainSourceryArmv7) ... ok -[snip] -test_run (tests.init.test_systemd.TestInitSystemSystemdRoFull) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRoIfupdown) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRoNetworkd) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRwFull) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRwIfupdown) ... ok -test_run (tests.init.test_systemd.TestInitSystemSystemdRwNetworkd) ... ok -test_run (tests.init.test_busybox.TestInitSystemBusyboxRo) ... ok -test_run (tests.init.test_busybox.TestInitSystemBusyboxRoNet) ... ok -test_run (tests.init.test_busybox.TestInitSystemBusyboxRw) ... ok -test_run (tests.init.test_busybox.TestInitSystemBusyboxRwNet) ... ok - -Ran 157 tests in 0.021s - -OK - - * Then, to run one test case: - -$ support/testing/run-tests -d dl -o output_folder -k tests.init.test_busybox.TestInitSystemBusyboxRw -15:03:26 TestInitSystemBusyboxRw Starting -15:03:28 TestInitSystemBusyboxRw Building -15:08:18 TestInitSystemBusyboxRw Building done -15:08:27 TestInitSystemBusyboxRw Cleaning up -. -Ran 1 test in 301.140s - -OK - -The standard output indicates if the test is successful or not. By -default, the output folder for the test is deleted automatically -unless the option -k is passed to keep the output directory. - -22.7.1. Creating a test case - -Within the Buildroot repository, the testing framework is organized -at the top level in support/testing/ by folders of conf, infra and -tests. All the test cases live under the tests folder and are -organized in various folders representing the category of test. - -The best way to get familiar with how to create a test case is to -look at a few of the basic file system support/testing/tests/fs/ and -init support/testing/tests/init/ test scripts. Those tests give good -examples of a basic tests that include both checking the build -results, and doing runtime tests. There are other more advanced cases -that use things like nested br2-external folders to provide skeletons -and additional packages. - -Creating a basic test case involves: - - * Defining a test class that inherits from infra.basetest.BRTest - * Defining the config member of the test class, to the Buildroot - configuration to build for this test case. It can optionally rely - on configuration snippets provided by the runtime test - infrastructure: infra.basetest.BASIC_TOOLCHAIN_CONFIG to get a - basic architecture/toolchain configuration, and - infra.basetest.MINIMAL_CONFIG to not build any filesystem. The - advantage of using infra.basetest.BASIC_TOOLCHAIN_CONFIG is that - a matching Linux kernel image is provided, which allows to boot - the resulting image in Qemu without having to build a Linux - kernel image as part of the test case, therefore significant - decreasing the build time required for the test case. - * Implementing a def test_run(self): function to implement the - actual tests to run after the build has completed. They may be - tests that verify the build output, by running command on the - host using the run_cmd_on_host() helper function. Or they may - boot the generated system in Qemu using the Emulator object - available as self.emulator in the test case. For example - self.emulator.boot() allows to boot the system in Qemu, - self.emulator.login() allows to login, self.emulator.run() allows - to run shell commands inside Qemu. - -After creating the test script, add yourself to the DEVELOPERS file -to be the maintainer of that test case. - -22.7.2. Debugging a test case - -When a test case runs, the output_folder will contain the following: - -$ ls output_folder/ -TestInitSystemBusyboxRw/ -TestInitSystemBusyboxRw-build.log -TestInitSystemBusyboxRw-run.log - -TestInitSystemBusyboxRw/ is the Buildroot output directory, and it is -preserved only if the -k option is passed. - -TestInitSystemBusyboxRw-build.log is the log of the Buildroot build. - -TestInitSystemBusyboxRw-run.log is the log of the Qemu boot and test. -This file will only exist if the build was successful and the test -case involves booting under Qemu. - -If you want to manually run Qemu to do manual tests of the build -result, the first few lines of TestInitSystemBusyboxRw-run.log -contain the Qemu command line to use. - -You can also make modifications to the current sources inside the -output_folder (e.g. for debug purposes) and rerun the standard -Buildroot make targets (in order to regenerate the complete image -with the new modifications) and then rerun the test. - -22.7.3. Runtime tests and Gitlab CI - -All runtime tests are regularly executed by Buildroot Gitlab CI -infrastructure, see .gitlab.yml and https://gitlab.com/buildroot.org/ -buildroot/-/jobs. - -You can also use Gitlab CI to test your new test cases, or verify -that existing tests continue to work after making changes in -Buildroot. - -In order to achieve this, you need to create a fork of the Buildroot -project on Gitlab, and be able to push branches to your Buildroot -fork on Gitlab. - -The name of the branch that you push will determine if a Gitlab CI -pipeline will be triggered or not, and for which test cases. - -In the examples below, the component of the branch name is an -arbitrary string you choose. - - * To trigger all run-test test case jobs, push a branch that ends - with -runtime-tests: - - $ git push gitlab HEAD:-runtime-tests - - * To trigger one or several test case jobs, push a branch that ends - with the complete test case name - (tests.init.test_busybox.TestInitSystemBusyboxRo) or with the - name of a category of tests (tests.init.test_busybox): - - $ git push gitlab HEAD:- - -Example to run one test: - - $ git push gitlab HEAD:foo-tests.init.test_busybox.TestInitSystemBusyboxRo - -Examples to run several tests part of the same group: - - $ git push gitlab HEAD:foo-tests.init.test_busybox - $ git push gitlab HEAD:foo-tests.init - - ---------------------------------------------------------------------- - -^[4] RFC: (Request for comments) change proposal - -Chapter 23. DEVELOPERS file and get-developers - -The main Buildroot directory contains a file named DEVELOPERS that -lists the developers involved with various areas of Buildroot. Thanks -to this file, the get-developers tool allows to: - - * Calculate the list of developers to whom patches should be sent, - by parsing the patches and matching the modified files with the - relevant developers. See Section 22.5, “Submitting patches” for - details. - * Find which developers are taking care of a given architecture or - package, so that they can be notified when a build failure occurs - on this architecture or package. This is done in interaction with - Buildroot’s autobuild infrastructure. - -We ask developers adding new packages, new boards, or generally new -functionality in Buildroot, to register themselves in the DEVELOPERS -file. As an example, we expect a developer contributing a new package -to include in his patch the appropriate modification to the -DEVELOPERS file. - -The DEVELOPERS file format is documented in detail inside the file -itself. - -The get-developers tool, located in utils/ allows to use the -DEVELOPERS file for various tasks: - - * When passing one or several patches as command line argument, - get-developers will return the appropriate git send-email - command. If the -e option is passed, only the email addresses are - printed in a format suitable for git send-email --cc-cmd. - * When using the -a command line option, get-developers will - return the list of developers in charge of the given - architecture. - * When using the -p command line option, get-developers - will return the list of developers in charge of the given - package. - * When using the -c command line option, get-developers will look - at all files under version control in the Buildroot repository, - and list the ones that are not handled by any developer. The - purpose of this option is to help completing the DEVELOPERS file. - * When using without any arguments, it validates the integrity of - the DEVELOPERS file and will note WARNINGS for items that don’t - match. - -Chapter 24. Release Engineering - -24.1. Releases - -The Buildroot project makes quarterly releases with monthly bugfix -releases. The first release of each year is a long term support -release, LTS. - - * Quarterly releases: 2020.02, 2020.05, 2020.08, and 2020.11 - * Bugfix releases: 2020.02.1, 2020.02.2, … - * LTS releases: 2020.02, 2021.02, … - -Releases are supported until the first bugfix release of the next -release, e.g., 2020.05.x is EOL when 2020.08.1 is released. - -LTS releases are supported until the first bugfix release of the next -LTS, e.g., 2020.02.x is supported until 2021.02.1 is released. - -24.2. Development - -Each release cycle consist of two months of development on the master -branch and one month stabilization before the release is made. During -this phase no new features are added to master, only bugfixes. - -The stabilization phase starts with tagging -rc1, and every week -until the release, another release candidate is tagged. - -To handle new features and version bumps during the stabilization -phase, a next branch may be created for these features. Once the -current release has been made, the next branch is merged into master -and the development cycle for the next release continues there. - -Part IV. Appendix - -Table of Contents - -25. Makedev syntax documentation -26. Makeusers syntax documentation -27. Migrating from older Buildroot versions - - 27.1. General approach - 27.2. Migrating to 2016.11 - 27.3. Migrating to 2017.08 - -Chapter 25. Makedev syntax documentation - -The makedev syntax is used in several places in Buildroot to define -changes to be made for permissions, or which device files to create -and how to create them, in order to avoid calls to mknod. - -This syntax is derived from the makedev utility, and more complete -documentation can be found in the package/makedevs/README file. - -It takes the form of a space separated list of fields, one file per -line; the fields are: - -+--------------------------------------------------+ -|name|type|mode|uid|gid|major|minor|start|inc|count| -+--------------------------------------------------+ - -There are a few non-trivial blocks: - - * name is the path to the file you want to create/modify - * type is the type of the file, being one of: - - + f: a regular file - + d: a directory - + r: a directory recursively - + c: a character device file - + b: a block device file - + p: a named pipe - * mode are the usual permissions settings (only numerical values - are allowed) - * uid and gid are the UID and GID to set on this file; can be - either numerical values or actual names - * major and minor are here for device files, set to - for other - files - * start, inc and count are for when you want to create a batch of - files, and can be reduced to a loop, beginning at start, - incrementing its counter by inc until it reaches count - -Let’s say you want to change the permissions of a given file; using -this syntax, you will need to write: - -/usr/bin/foo f 755 0 0 - - - - - -/usr/bin/bar f 755 root root - - - - - -/data/buz f 644 buz-user buz-group - - - - - - -Alternatively, if you want to change owner/permission of a directory -recursively, you can write (to set UID to foo, GID to bar and access -rights to rwxr-x--- for the directory /usr/share/myapp and all files -and directories below it): - -/usr/share/myapp r 750 foo bar - - - - - - -On the other hand, if you want to create the device file /dev/hda and -the corresponding 15 files for the partitions, you will need for /dev -/hda: - -/dev/hda b 640 root root 3 0 0 0 - - -and then for device files corresponding to the partitions of /dev/ -hda, /dev/hdaX, X ranging from 1 to 15: - -/dev/hda b 640 root root 3 1 1 1 15 - -Extended attributes are supported if -BR2_ROOTFS_DEVICE_TABLE_SUPPORTS_EXTENDED_ATTRIBUTES is enabled. This -is done by adding a line starting with |xattr after the line -describing the file. Right now, only capability is supported as -extended attribute. - -+------------------+ -||xattr|capability | -+------------------+ - - * |xattr is a "flag" that indicate an extended attribute - * capability is a capability to add to the previous file - -If you want to add the capability cap_sys_admin to the binary foo, -you will write : - -/usr/bin/foo f 755 root root - - - - - -|xattr cap_sys_admin+eip - -You can add several capabilities to a file by using several |xattr -lines. If you want to add the capability cap_sys_admin and -cap_net_admin to the binary foo, you will write : - -/usr/bin/foo f 755 root root - - - - - -|xattr cap_sys_admin+eip -|xattr cap_net_admin+eip - -Chapter 26. Makeusers syntax documentation - -The syntax to create users is inspired by the makedev syntax, above, -but is specific to Buildroot. - -The syntax for adding a user is a space-separated list of fields, one -user per line; the fields are: - -+---------------------------------------------------------+ -|username|uid|group|gid|password|home|shell|groups|comment| -+---------------------------------------------------------+ - -Where: - - * username is the desired user name (aka login name) for the user. - It can not be root, and must be unique. If set to -, then just a - group will be created. - * uid is the desired UID for the user. It must be unique, and not - 0. If set to -1, then a unique UID will be computed by Buildroot - in the range [1000…1999] - * group is the desired name for the user’s main group. It can not - be root. If the group does not exist, it will be created. - * gid is the desired GID for the user’s main group. It must be - unique, and not 0. If set to -1, and the group does not already - exist, then a unique GID will be computed by Buildroot in the - range [1000..1999] - * password is the crypt(3)-encoded password. If prefixed with !, - then login is disabled. If prefixed with =, then it is - interpreted as clear-text, and will be crypt-encoded (using MD5). - If prefixed with !=, then the password will be crypt-encoded - (using MD5) and login will be disabled. If set to *, then login - is not allowed. If set to -, then no password value will be set. - * home is the desired home directory for the user. If set to -, no - home directory will be created, and the user’s home will be /. - Explicitly setting home to / is not allowed. - * shell is the desired shell for the user. If set to -, then /bin/ - false is set as the user’s shell. - * groups is the comma-separated list of additional groups the user - should be part of. If set to -, then the user will be a member of - no additional group. Missing groups will be created with an - arbitrary gid. - * comment (aka GECOS [https://en.wikipedia.org/wiki/Gecos_field] - field) is an almost-free-form text. - -There are a few restrictions on the content of each field: - - * except for comment, all fields are mandatory. - * except for comment, fields may not contain spaces. - * no field may contain a colon (:). - -If home is not -, then the home directory, and all files below, will -belong to the user and its main group. - -Examples: - -foo -1 bar -1 !=blabla /home/foo /bin/sh alpha,bravo Foo user - -This will create this user: - - * username (aka login name) is: foo - * uid is computed by Buildroot - * main group is: bar - * main group gid is computed by Buildroot - * clear-text password is: blabla, will be crypt(3)-encoded, and - login is disabled. - * home is: /home/foo - * shell is: /bin/sh - * foo is also a member of groups: alpha and bravo - * comment is: Foo user - -test 8000 wheel -1 = - /bin/sh - Test user - -This will create this user: - - * username (aka login name) is: test - * uid is : 8000 - * main group is: wheel - * main group gid is computed by Buildroot, and will use the value - defined in the rootfs skeleton - * password is empty (aka no password). - * home is / but will not belong to test - * shell is: /bin/sh - * test is not a member of any additional groups - * comment is: Test user - -Chapter 27. Migrating from older Buildroot versions - -Some versions have introduced backward incompatibilities. This -section explains those incompatibilities, and for each explains what -to do to complete the migration. - -27.1. General approach - -To migrate from an older Buildroot version, take the following steps. - - 1. For all your configurations, do a build in the old Buildroot - environment. Run make graph-size. Save graphs/file-size-stats.csv - in a different location. Run make clean to remove the rest. - 2. Review the specific migration notes below and make the required - adaptations to external packages and custom build scripts. - 3. Update Buildroot. - 4. Run make menuconfig starting from the existing .config. - 5. If anything is enabled in the Legacy menu, check its help text, - unselect it, and save the configuration. - 6. For more details, review the git commit messages for the packages - that you need. Change into the packages directory and run git log - .. — . - 7. Build in the new Buildroot environment. - 8. Fix build issues in external packages (usually due to updated - dependencies). - 9. Run make graph-size. -10. Compare the new file-size-stats.csv with the original one, to - check if no required files have disappeared and if no new big - unneeded files have appeared. -11. For configuration (and other) files in a custom overlay that - overwrite files created by Buildroot, check if there are changes - in the Buildroot-generated file that need to be propagated to - your custom file. - -27.2. Migrating to 2016.11 - -Before Buildroot 2016.11, it was possible to use only one -br2-external tree at once. With Buildroot 2016.11 came the -possibility to use more than one simultaneously (for details, see -Section 9.2, “Keeping customizations outside of Buildroot”). - -This however means that older br2-external trees are not usable -as-is. A minor change has to be made: adding a name to your -br2-external tree. - -This can be done very easily in just a few steps: - - * First, create a new file named external.desc, at the root of your - br2-external tree, with a single line defining the name of your - br2-external tree: - - $ echo 'name: NAME_OF_YOUR_TREE' >external.desc - - Note. Be careful when choosing a name: It has to be unique and be - made with only ASCII characters from the set [A-Za-z0-9_]. - - * Then, change every occurence of BR2_EXTERNAL in your br2-external - tree with the new variable: - - $ find . -type f | xargs sed -i 's/BR2_EXTERNAL/BR2_EXTERNAL_NAME_OF_YOUR_TREE_PATH/g' - -Now, your br2-external tree can be used with Buildroot 2016.11 -onward. - -Note: This change makes your br2-external tree incompatible with -Buildroot before 2016.11. - -27.3. Migrating to 2017.08 - -Before Buildroot 2017.08, host packages were installed in $(HOST_DIR) -/usr (with e.g. the autotools' --prefix=$(HOST_DIR)/usr). With -Buildroot 2017.08, they are now installed directly in $(HOST_DIR). - -Whenever a package installs an executable that is linked with a -library in $(HOST_DIR)/lib, it must have an RPATH pointing to that -directory. - -An RPATH pointing to $(HOST_DIR)/usr/lib is no longer accepted. - diff --git a/docs/manual/manual.txt b/docs/manual/manual.txt index b5cc044805..19ca0d0066 100644 --- a/docs/manual/manual.txt +++ b/docs/manual/manual.txt @@ -1,75 +1,60 @@ // -*- mode:doc; -*- // vim: set syntax=asciidoc: -= The Buildroot user manual += The ShredOS user and developer manual + +image::shred_db.png[] + :toc: -Buildroot {sys:echo $\{BR2_VERSION%%-git*\}} manual generated on {localdate} +ShredOS {sys:echo $\{BR2_VERSION%%-git*\}} manual generated on {localdate} {localtime} from git revision {sys:git rev-parse --short HEAD} -The Buildroot manual is written by the Buildroot developers. +---- +The ShredOS user and developer manual is written by the PartialVolume and the ShredOS developers. It is licensed under the GNU General Public License, version 2. Refer to the http://git.buildroot.org/buildroot/tree/COPYING?id={sys:git rev-parse HEAD}[COPYING] file in the Buildroot sources for the full text of this license. +---- -Copyright (C) 2004-2020 The Buildroot developers + + + +WARNING: Warning. + + + +Copyright (C) 2018-2021 PartialVolume and The ShredOS developers -image::logo.png[] = Getting started include::introduction.txt[] -include::prerequisite.txt[] +//include::prerequisite.txt[] -include::getting.txt[] +//include::getting.txt[] -include::quickstart.txt[] +//= User guide -include::resources.txt[] +//include::configure.txt[] -= User guide +//include::graphical_user_interface.txt[] -include::configure.txt[] +//include::known-issues.txt[] -include::configure-other-components.txt[] +//include::legal-notice.txt[] -include::common-usage.txt[] +//include::beyond-buildroot.txt[] -include::customize.txt[] +//= Developer guide -include::selinux-support.txt[] +//include::key_shredos_components.txt[] -include::faq-troubleshooting.txt[] +//include::build_procedure.txt[] -include::known-issues.txt[] +//include::contributing_to_the_shredos_manual.txt[] -include::legal-notice.txt[] +//= Appendix -include::beyond-buildroot.txt[] - -= Developer guide - -include::how-buildroot-works.txt[] - -include::writing-rules.txt[] - -include::adding-board-support.txt[] - -include::adding-packages.txt[] - -include::patch-policy.txt[] - -include::download-infra.txt[] - -include::debugging-buildroot.txt[] - -include::contribute.txt[] - -include::developers.txt[] - -include::release-engineering.txt[] - -= Appendix - -include::appendix.txt[] +//include::appendix.txt[] diff --git a/docs/manual/migrating.txt b/docs/manual/migrating.txt deleted file mode 100644 index cb1f5eacc9..0000000000 --- a/docs/manual/migrating.txt +++ /dev/null @@ -1,88 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[migrating-from-ol-versions]] -== Migrating from older Buildroot versions - -Some versions have introduced backward incompatibilities. This section -explains those incompatibilities, and for each explains what to do to -complete the migration. - -[[migrating-approach]] -=== General approach - -To migrate from an older Buildroot version, take the following steps. - -. For all your configurations, do a build in the old Buildroot - environment. Run +make graph-size+. Save - +graphs/file-size-stats.csv+ in a different location. Run +make - clean+ to remove the rest. -. Review the specific migration notes below and make the required - adaptations to external packages and custom build scripts. -. Update Buildroot. -. Run +make menuconfig+ starting from the existing +.config+. -. If anything is enabled in the Legacy menu, check its help text, - unselect it, and save the configuration. -. For more details, review the git commit messages for the packages that - you need. Change into the +packages+ directory and run - +git log .. -- +. -. Build in the new Buildroot environment. -. Fix build issues in external packages (usually due to updated - dependencies). -. Run +make graph-size+. -. Compare the new +file-size-stats.csv+ with the original one, to - check if no required files have disappeared and if no new big unneeded - files have appeared. -. For configuration (and other) files in a custom overlay that overwrite - files created by Buildroot, check if there are changes in the - Buildroot-generated file that need to be propagated to your custom - file. - -[[br2-external-converting]] -=== Migrating to 2016.11 - -Before Buildroot 2016.11, it was possible to use only one br2-external -tree at once. With Buildroot 2016.11 came the possibility to use more -than one simultaneously (for details, see xref:outside-br-custom[]). - -This however means that older br2-external trees are not usable as-is. -A minor change has to be made: adding a name to your br2-external tree. - -This can be done very easily in just a few steps: - - * First, create a new file named +external.desc+, at the root of your - br2-external tree, with a single line defining the name of your - br2-external tree: -+ ----- -$ echo 'name: NAME_OF_YOUR_TREE' >external.desc ----- -+ -.Note -Be careful when choosing a name: It has to be unique and be made -with only ASCII characters from the set +[A-Za-z0-9_]+. - - * Then, change every occurence of +BR2_EXTERNAL+ in your br2-external - tree with the new variable: -+ ----- -$ find . -type f | xargs sed -i 's/BR2_EXTERNAL/BR2_EXTERNAL_NAME_OF_YOUR_TREE_PATH/g' ----- - -Now, your br2-external tree can be used with Buildroot 2016.11 onward. - -.Note: -This change makes your br2-external tree incompatible with Buildroot -before 2016.11. - -[[migrating-host-usr]] -=== Migrating to 2017.08 - -Before Buildroot 2017.08, host packages were installed in +$(HOST_DIR)/usr+ -(with e.g. the autotools' +--prefix=$(HOST_DIR)/usr+). With Buildroot -2017.08, they are now installed directly in +$(HOST_DIR)+. - -Whenever a package installs an executable that is linked with a library -in +$(HOST_DIR)/lib+, it must have an RPATH pointing to that directory. - -An RPATH pointing to +$(HOST_DIR)/usr/lib+ is no longer accepted. diff --git a/docs/manual/package-make-target.txt b/docs/manual/package-make-target.txt deleted file mode 100644 index 795c7d46de..0000000000 --- a/docs/manual/package-make-target.txt +++ /dev/null @@ -1,96 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[pkg-build-steps]] - -==== Package-specific _make_ targets - -Running +make + builds and installs that particular package -and its dependencies. - -For packages relying on the Buildroot infrastructure, there are -numerous special make targets that can be called independently like -this: - ------------- -make - ------------- - -The package build targets are (in the order they are executed): - -[width="90%",cols="^1,4",options="header"] -|=================================================== -| command/target | Description - -| +source+ | Fetch the source (download the tarball, clone -the source repository, etc) - -| +depends+ | Build and install all dependencies required to -build the package - -| +extract+ | Put the source in the package build directory -(extract the tarball, copy the source, etc) - -| +patch+ | Apply the patches, if any - -| +configure+ | Run the configure commands, if any - -| +build+ | Run the compilation commands - -| +install-staging+ | -*target package:* Run the installation of the package in the -staging directory, if necessary - -| +install-target+ | -*target package:* Run the installation of the package in the -target directory, if necessary - -| +install+ | -*target package:* Run the 2 previous installation commands - -*host package:* Run the installation of the package in the host -directory - -|=================================================== - -Additionally, there are some other useful make targets: - -[width="90%",cols="^1,4",options="header"] -|=================================================== -| command/target | Description - -| +show-depends+ | Displays the first-order dependencies required to build the -package - -| +show-recursive-depends+ | Recursively displays the dependencies - required to build the package - -| +show-rdepends+ | Displays the first-order reverse dependencies of - the package (i.e packages that directly depend on it) - -| +show-recursive-rdepends+ | Recursively displays the reverse - dependencies of the package (i.e the packages that depend on it, - directly or indirectly) - -| +graph-depends+ | Generate a dependency graph of the package, in the -context of the current Buildroot configuration. See -xref:graph-depends[this section] for more details about dependency -graphs. - -| +graph-rdepends+ | Generate a graph of this package reverse - dependencies (i.e the packages that depend on it, directly or - indirectly) - -| +dirclean+ | Remove the whole package build directory - -| +reinstall+ | Re-run the install commands - -| +rebuild+ | Re-run the compilation commands - this only makes -sense when using the +OVERRIDE_SRCDIR+ feature or when you modified a file -directly in the build directory - -| +reconfigure+ | Re-run the configure commands, then rebuild - this only -makes sense when using the +OVERRIDE_SRCDIR+ feature or when you modified a -file directly in the build directory - -|=================================================== diff --git a/docs/manual/patch-policy.txt b/docs/manual/patch-policy.txt deleted file mode 100644 index e704a0d3f3..0000000000 --- a/docs/manual/patch-policy.txt +++ /dev/null @@ -1,162 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[patch-policy]] - -== Patching a package - -While integrating a new package or updating an existing one, it may be -necessary to patch the source of the software to get it cross-built within -Buildroot. - -Buildroot offers an infrastructure to automatically handle this during -the builds. It supports three ways of applying patch sets: downloaded patches, -patches supplied within buildroot and patches located in a user-defined -global patch directory. - -=== Providing patches - -==== Downloaded - -If it is necessary to apply a patch that is available for download, then add it -to the +_PATCH+ variable. If an entry contains +://+, -then Buildroot will assume it is a full URL and download the patch -from this location. Otherwise, Buildroot will assume that the patch should be -downloaded from +_SITE+. It can be a single patch, -or a tarball containing a patch series. - -Like for all downloads, a hash should be added to the +.hash+ -file. - -This method is typically used for packages from Debian. - -==== Within Buildroot - -Most patches are provided within Buildroot, in the package -directory; these typically aim to fix cross-compilation, libc support, -or other such issues. - -These patch files should be named +-.patch+. - -.Notes -- The patch files coming with Buildroot should not contain any package version - reference in their filename. -- The field ++ in the patch file name refers to the 'apply order', - and shall start at 1; It is preferred to pad the number with zeros up to 4 - digits, like 'git-format-patch' does. E.g.: +0001-foobar-the-buz.patch+ -- Previously, it was mandatory for patches to be prefixed with the name of - the package, like +--.patch+, but that is - no longer the case. Existing packages will be fixed as time passes. 'Do - not prefix patches with the package name.' -- Previously, a +series+ file, as used by +quilt+, could also be added in - the package directory. In that case, the +series+ file defines the patch - application order. This is deprecated, and will be removed in the future. - 'Do not use a series file.' - - -==== Global patch directory - -The +BR2_GLOBAL_PATCH_DIR+ configuration file option can be -used to specify a space separated list of one or more directories -containing global package patches. See xref:customize-patches[] for -details. - -[[patch-apply-order]] -=== How patches are applied - -. Run the +_PRE_PATCH_HOOKS+ commands if defined; - -. Cleanup the build directory, removing any existing +*.rej+ files; - -. If +_PATCH+ is defined, then patches from these - tarballs are applied; - -. If there are some +*.patch+ files in the package's Buildroot - directory or in a package subdirectory named ++, - then: -+ -* If a +series+ file exists in the package directory, then patches are - applied according to the +series+ file; -+ -* Otherwise, patch files matching +*.patch+ are applied in alphabetical - order. - So, to ensure they are applied in the right order, it is highly - recommended to name the patch files like this: - +-.patch+, where ++ refers to the - 'apply order'. - -. If +BR2_GLOBAL_PATCH_DIR+ is defined, the directories will be - enumerated in the order they are specified. The patches are applied - as described in the previous step. - -. Run the +_POST_PATCH_HOOKS+ commands if defined. - -If something goes wrong in the steps _3_ or _4_, then the build fails. - -=== Format and licensing of the package patches - -Patches are released under the same license as the software they apply -to (see xref:legal-info-buildroot[]). - -A message explaining what the patch does, and why it is needed, should -be added in the header commentary of the patch. - -You should add a +Signed-off-by+ statement in the header of the each -patch to help with keeping track of the changes and to certify that the -patch is released under the same license as the software that is modified. - -If the software is under version control, it is recommended to use the -upstream SCM software to generate the patch set. - -Otherwise, concatenate the header with the output of the -+diff -purN package-version.orig/ package-version/+ command. - -If you update an existing patch (e.g. when bumping the package version), -make sure the existing From header and Signed-off-by tags are not -removed, but do update the rest of the patch comment when appropriate. - -At the end, the patch should look like: - ---------------- -configure.ac: add C++ support test - -Signed-off-by: John Doe - ---- configure.ac.orig -+++ configure.ac -@@ -40,2 +40,12 @@ - -AC_PROG_MAKE_SET -+ -+AC_CACHE_CHECK([whether the C++ compiler works], -+ [rw_cv_prog_cxx_works], -+ [AC_LANG_PUSH([C++]) -+ AC_LINK_IFELSE([AC_LANG_PROGRAM([], [])], -+ [rw_cv_prog_cxx_works=yes], -+ [rw_cv_prog_cxx_works=no]) -+ AC_LANG_POP([C++])]) -+ -+AM_CONDITIONAL([CXX_WORKS], [test "x$rw_cv_prog_cxx_works" = "xyes"]) ---------------- - -=== Integrating patches found on the Web - -When integrating a patch of which you are not the author, you have to -add a few things in the header of the patch itself. - -Depending on whether the patch has been obtained from the project -repository itself, or from somewhere on the web, add one of the -following tags: - ---------------- -Backported from: ---------------- - -or - ---------------- -Fetch from: ---------------- - -It is also sensible to add a few words about any changes to the patch -that may have been necessary. diff --git a/docs/manual/prerequisite.txt b/docs/manual/prerequisite.txt index 4e614cfa1b..8d1c8b69c3 100644 --- a/docs/manual/prerequisite.txt +++ b/docs/manual/prerequisite.txt @@ -1,96 +1 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[requirement]] -== System requirements - -Buildroot is designed to run on Linux systems. - -While Buildroot itself will build most host packages it needs for the -compilation, certain standard Linux utilities are expected to be -already installed on the host system. Below you will find an overview of -the mandatory and optional packages (note that package names may vary -between distributions). - -[[requirement-mandatory]] - -=== Mandatory packages - -* Build tools: - -** +which+ -** +sed+ -** +make+ (version 3.81 or any later) -** +binutils+ -** +build-essential+ (only for Debian based systems) -** +gcc+ (version 4.8 or any later) -** `g++` (version 4.8 or any later) -** +bash+ -** +patch+ -** +gzip+ -** +bzip2+ -** +perl+ (version 5.8.7 or any later) -** +tar+ -** +cpio+ -** +unzip+ -** +rsync+ -** +file+ (must be in +/usr/bin/file+) -** +bc+ - -* Source fetching tools: -** +wget+ - -[[requirement-optional]] - -=== Optional packages - -* Recommended dependencies: -+ -Some features or utilities in Buildroot, like the legal-info, or the -graph generation tools, have additional dependencies. Although they -are not mandatory for a simple build, they are still highly recommended: -+ -** +python+ (version 2.7 or any later) - -* Configuration interface dependencies: -+ -For these libraries, you need to install both runtime and development -data, which in many distributions are packaged separately. The -development packages typically have a _-dev_ or _-devel_ suffix. -+ -** +ncurses5+ to use the 'menuconfig' interface -** +qt5+ to use the 'xconfig' interface -** +glib2+, +gtk2+ and +glade2+ to use the 'gconfig' interface - -* Source fetching tools: -+ -In the official tree, most of the package sources are retrieved using -+wget+ from _ftp_, _http_ or _https_ locations. A few packages are only -available through a version control system. Moreover, Buildroot is -capable of downloading sources via other tools, like +rsync+ or +scp+ -(refer to xref:download-infra[] for more details). If you enable -packages using any of these methods, you will need to install the -corresponding tool on the host system: -+ -** +bazaar+ -** +cvs+ -** +git+ -** +mercurial+ -** +rsync+ -** +scp+ -** +subversion+ - -* Java-related packages, if the Java Classpath needs to be built for - the target system: -** The +javac+ compiler -** The +jar+ tool - -* Documentation generation tools: -** +asciidoc+, version 8.6.3 or higher -** +w3m+ -** +python+ with the +argparse+ module (automatically present in 2.7+ and 3.2+) -** +dblatex+ (required for the pdf manual only) - -* Graph generation tools: -** +graphviz+ to use 'graph-depends' and '-graph-depends' -** +python-matplotlib+ to use 'graph-build' + diff --git a/docs/manual/quickstart.txt b/docs/manual/quickstart.txt deleted file mode 100644 index 80569e85f4..0000000000 --- a/docs/manual/quickstart.txt +++ /dev/null @@ -1,125 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== Buildroot quick start - -*Important*: you can and should *build everything as a normal user*. There -is no need to be root to configure and use Buildroot. By running all -commands as a regular user, you protect your system against packages -behaving badly during compilation and installation. - -The first step when using Buildroot is to create a configuration. -Buildroot has a nice configuration tool similar to the one you can -find in the http://www.kernel.org/[Linux kernel] or in -http://www.busybox.net/[BusyBox]. - -From the buildroot directory, run - --------------------- - $ make menuconfig --------------------- - -for the original curses-based configurator, or - --------------------- - $ make nconfig --------------------- - -for the new curses-based configurator, or - --------------------- - $ make xconfig --------------------- - -for the Qt-based configurator, or - --------------------- - $ make gconfig --------------------- - -for the GTK-based configurator. - -All of these "make" commands will need to build a configuration -utility (including the interface), so you may need to install -"development" packages for relevant libraries used by the -configuration utilities. Refer to xref:requirement[] for more details, -specifically the xref:requirement-optional[optional requirements] -to get the dependencies of your favorite interface. - -For each menu entry in the configuration tool, you can find associated -help that describes the purpose of the entry. Refer to xref:configure[] -for details on some specific configuration aspects. - -Once everything is configured, the configuration tool generates a -+.config+ file that contains the entire configuration. This file will be -read by the top-level Makefile. - -To start the build process, simply run: - --------------------- - $ make --------------------- - -By default, Buildroot does not support top-level parallel build, so -running +make -jN+ is not necessary. There is however experimental -support for top-level parallel build, see -xref:top-level-parallel-build[]. - -The `make` command will generally perform the following steps: - -* download source files (as required); -* configure, build and install the cross-compilation toolchain, or - simply import an external toolchain; -* configure, build and install selected target packages; -* build a kernel image, if selected; -* build a bootloader image, if selected; -* create a root filesystem in selected formats. - -Buildroot output is stored in a single directory, +output/+. -This directory contains several subdirectories: - -* +images/+ where all the images (kernel image, bootloader and root - filesystem images) are stored. These are the files you need to put - on your target system. - -* +build/+ where all the components are built (this includes tools - needed by Buildroot on the host and packages compiled for the - target). This directory contains one subdirectory for each of these - components. - -* +host/+ contains both the tools built for the host, and the sysroot - of the target toolchain. The former is an installation of tools - compiled for the host that are needed for the proper execution of - Buildroot, including the cross-compilation toolchain. The latter - is a hierarchy similar to a root filesystem hierarchy. It contains - the headers and libraries of all user-space packages that provide - and install libraries used by other packages. However, this - directory is 'not' intended to be the root filesystem for the target: - it contains a lot of development files, unstripped binaries and - libraries that make it far too big for an embedded system. These - development files are used to compile libraries and applications for - the target that depend on other libraries. - -* +staging/+ is a symlink to the target toolchain sysroot inside - +host/+, which exists for backwards compatibility. - -* +target/+ which contains 'almost' the complete root filesystem for - the target: everything needed is present except the device files in - +/dev/+ (Buildroot can't create them because Buildroot doesn't run - as root and doesn't want to run as root). Also, it doesn't have the correct - permissions (e.g. setuid for the busybox binary). Therefore, this directory - *should not be used on your target*. Instead, you should use one of - the images built in the +images/+ directory. If you need an - extracted image of the root filesystem for booting over NFS, then - use the tarball image generated in +images/+ and extract it as - root. Compared to +staging/+, +target/+ contains only the files and - libraries needed to run the selected target applications: the - development files (headers, etc.) are not present, the binaries are - stripped. - -These commands, +make menuconfig|nconfig|gconfig|xconfig+ and +make+, are the -basic ones that allow to easily and quickly generate images fitting -your needs, with all the features and applications you enabled. - -More details about the "make" command usage are given in -xref:make-tips[]. diff --git a/docs/manual/rebuilding-packages.txt b/docs/manual/rebuilding-packages.txt deleted file mode 100644 index 06d3855148..0000000000 --- a/docs/manual/rebuilding-packages.txt +++ /dev/null @@ -1,136 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[full-rebuild]] -=== Understanding when a full rebuild is necessary - -Buildroot does not attempt to detect what parts of the system should -be rebuilt when the system configuration is changed through +make -menuconfig+, +make xconfig+ or one of the other configuration -tools. In some cases, Buildroot should rebuild the entire system, in -some cases, only a specific subset of packages. But detecting this in -a completely reliable manner is very difficult, and therefore the -Buildroot developers have decided to simply not attempt to do this. - -Instead, it is the responsibility of the user to know when a full -rebuild is necessary. As a hint, here are a few rules of thumb that -can help you understand how to work with Buildroot: - - * When the target architecture configuration is changed, a complete - rebuild is needed. Changing the architecture variant, the binary - format or the floating point strategy for example has an impact on - the entire system. - - * When the toolchain configuration is changed, a complete rebuild - generally is needed. Changing the toolchain configuration often - involves changing the compiler version, the type of C library or - its configuration, or some other fundamental configuration item, - and these changes have an impact on the entire system. - - * When an additional package is added to the configuration, a full - rebuild is not necessarily needed. Buildroot will detect that this - package has never been built, and will build it. However, if this - package is a library that can optionally be used by packages that - have already been built, Buildroot will not automatically rebuild - those. Either you know which packages should be rebuilt, and you - can rebuild them manually, or you should do a full rebuild. For - example, let's suppose you have built a system with the +ctorrent+ - package, but without +openssl+. Your system works, but you realize - you would like to have SSL support in +ctorrent+, so you enable the - +openssl+ package in Buildroot configuration and restart the - build. Buildroot will detect that +openssl+ should be built and - will be build it, but it will not detect that +ctorrent+ should be - rebuilt to benefit from +openssl+ to add OpenSSL support. You will - either have to do a full rebuild, or rebuild +ctorrent+ itself. - - * When a package is removed from the configuration, Buildroot does - not do anything special. It does not remove the files installed by - this package from the target root filesystem or from the toolchain - _sysroot_. A full rebuild is needed to get rid of this - package. However, generally you don't necessarily need this package - to be removed right now: you can wait for the next lunch break to - restart the build from scratch. - - * When the sub-options of a package are changed, the package is not - automatically rebuilt. After making such changes, rebuilding only - this package is often sufficient, unless enabling the package - sub-option adds some features to the package that are useful for - another package which has already been built. Again, Buildroot does - not track when a package should be rebuilt: once a package has been - built, it is never rebuilt unless explicitly told to do so. - - * When a change to the root filesystem skeleton is made, a full - rebuild is needed. However, when changes to the root filesystem - overlay, a post-build script or a post-image script are made, - there is no need for a full rebuild: a simple +make+ invocation - will take the changes into account. - - * When a package listed in +FOO_DEPENDENCIES+ is rebuilt or removed, - the package +foo+ is not automatically rebuilt. For example, if a - package +bar+ is listed in +FOO_DEPENDENCIES+ with +FOO_DEPENDENCIES - = bar+ and the configuration of the +bar+ package is changed, the - configuration change would not result in a rebuild of package +foo+ - automatically. In this scenario, you may need to either rebuild any - packages in your build which reference +bar+ in their +DEPENDENCIES+, - or perform a full rebuild to ensure any +bar+ dependent packages are - up to date. - -Generally speaking, when you're facing a build error and you're unsure -of the potential consequences of the configuration changes you've -made, do a full rebuild. If you get the same build error, then you are -sure that the error is not related to partial rebuilds of packages, -and if this error occurs with packages from the official Buildroot, do -not hesitate to report the problem! As your experience with Buildroot -progresses, you will progressively learn when a full rebuild is really -necessary, and you will save more and more time. - -For reference, a full rebuild is achieved by running: - ---------------- -$ make clean all ---------------- - -[[rebuild-pkg]] -=== Understanding how to rebuild packages - -One of the most common questions asked by Buildroot users is how to -rebuild a given package or how to remove a package without rebuilding -everything from scratch. - -Removing a package is unsupported by Buildroot without -rebuilding from scratch. This is because Buildroot doesn't keep track -of which package installs what files in the +output/staging+ and -+output/target+ directories, or which package would be compiled differently -depending on the availability of another package. - -The easiest way to rebuild a single package from scratch is to remove -its build directory in +output/build+. Buildroot will then re-extract, -re-configure, re-compile and re-install this package from scratch. You -can ask buildroot to do this with the +make -dirclean+ command. - -On the other hand, if you only want to restart the build process of a -package from its compilation step, you can run +make -rebuild+. It -will restart the compilation and installation of the package, but not from -scratch: it basically re-executes +make+ and +make install+ inside the package, -so it will only rebuild files that changed. - -If you want to restart the build process of a package from its configuration -step, you can run +make -reconfigure+. It will restart the -configuration, compilation and installation of the package. - -While +-rebuild+ implies +-reinstall+ and -+-reconfigure+ implies +-rebuild+, these targets as well -as ++ only act on the said package, and do not trigger re-creating -the root filesystem image. If re-creating the root filesystem in necessary, -one should in addition run +make+ or +make all+. - -Internally, Buildroot creates so-called _stamp files_ to keep track of -which build steps have been completed for each package. They are -stored in the package build directory, -+output/build/-/+ and are named -+.stamp_+. The commands detailed above simply manipulate -these stamp files to force Buildroot to restart a specific set of -steps of a package build process. - -Further details about package special make targets are explained in -xref:pkg-build-steps[]. diff --git a/docs/manual/release-engineering.txt b/docs/manual/release-engineering.txt deleted file mode 100644 index 0cf38183f9..0000000000 --- a/docs/manual/release-engineering.txt +++ /dev/null @@ -1,34 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[RELENG]] -== Release Engineering -=== Releases - -The Buildroot project makes quarterly releases with monthly bugfix -releases. The first release of each year is a long term support -release, LTS. - - - Quarterly releases: 2020.02, 2020.05, 2020.08, and 2020.11 - - Bugfix releases: 2020.02.1, 2020.02.2, ... - - LTS releases: 2020.02, 2021.02, ... - -Releases are supported until the first bugfix release of the next -release, e.g., 2020.05.x is EOL when 2020.08.1 is released. - -LTS releases are supported until the first bugfix release of the next -LTS, e.g., 2020.02.x is supported until 2021.02.1 is released. - -=== Development - -Each release cycle consist of two months of development on the +master+ -branch and one month stabilization before the release is made. During -this phase no new features are added to +master+, only bugfixes. - -The stabilization phase starts with tagging +-rc1+, and every week until -the release, another release candidate is tagged. - -To handle new features and version bumps during the stabilization phase, -a +next+ branch may be created for these features. Once the current -release has been made, the +next+ branch is merged into +master+ and -the development cycle for the next release continues there. diff --git a/docs/manual/resources.txt b/docs/manual/resources.txt deleted file mode 100644 index e90a49b2ab..0000000000 --- a/docs/manual/resources.txt +++ /dev/null @@ -1,71 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[community-resources]] -== Community resources - -Like any open source project, Buildroot has different ways to share -information in its community and outside. - -Each of those ways may interest you if you are looking for some help, -want to understand Buildroot or contribute to the project. - -Mailing List:: -+ -Buildroot has a mailing list for discussion and development. It is the -main method of interaction for Buildroot users and developers. -+ -Only subscribers to the Buildroot mailing list are allowed to post to -this list. You can subscribe via the -http://lists.buildroot.org/mailman/listinfo/buildroot[mailing list info -page]. -+ -Mails that are sent to the mailing list are also available in the -mailing list archives, available through -http://lists.buildroot.org/pipermail/buildroot[Mailman] or at -https://lore.kernel.org/buildroot/[lore.kernel.org]. - -IRC:: -+ -The Buildroot IRC channel irc://irc.oftc.net/#buildroot[#buildroot] is -hosted on https://www.oftc.net/WebChat/[OFTC]. It is a useful place to -ask quick questions or discuss on certain topics. -+ -When asking for help on IRC, share relevant logs or pieces of code -using a code sharing website, such as https://paste.ack.tf/. -+ -Note that for certain questions, posting to the mailing list may be -better as it will reach more people, both developers and users. - -Bug tracker:: -+ -Bugs in Buildroot can be reported via the mailing list or alternatively -via the https://bugs.buildroot.org/buglist.cgi?product=buildroot[Buildroot -bugtracker]. Please refer to xref:reporting-bugs[] before creating a bug -report. - -Wiki:: -+ -http://elinux.org/Buildroot[The Buildroot wiki page] is hosted on -the http://elinux.org[eLinux] wiki. It contains some useful links, an -overview of past and upcoming events, and a TODO list. - -Patchwork:: -+ -Patchwork is a web-based patch tracking system designed to facilitate -the contribution and management of contributions to an open-source -project. Patches that have been sent to a mailing list are \'caught' by -the system, and appear on a web page. Any comments posted that -reference the patch are appended to the patch page too. For more -information on Patchwork see -http://jk.ozlabs.org/projects/patchwork/[]. -+ -Buildroot's Patchwork website is mainly for use by Buildroot's -maintainer to ensure patches aren't missed. It is also used by Buildroot -patch reviewers (see also xref:apply-patches-patchwork[]). -However, since the website exposes patches and their corresponding -review comments in a clean and concise web interface, it can be useful -for all Buildroot developers. -+ -The Buildroot patch management interface is available at -http://patchwork.buildroot.org[]. diff --git a/docs/manual/selinux-support.txt b/docs/manual/selinux-support.txt deleted file mode 100644 index 21137ae6c3..0000000000 --- a/docs/manual/selinux-support.txt +++ /dev/null @@ -1,74 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -[[selinux]] -== Using SELinux in Buildroot - -https://selinuxproject.org[SELinux] is a Linux kernel security module -enforcing access control policies. In addition to the traditional file -permissions and access control lists, +SELinux+ allows to write rules -for users or processes to access specific functions of resources -(files, sockets...). - -_SELinux_ has three modes of operation: - -* _Disabled_: the policy is not applied -* _Permissive_: the policy is applied, and non-authorized actions are - simply logged. This mode is often used for troubleshooting SELinux - issues. -* _Enforcing_: the policy is applied, and non-authorized actions are - denied - -In Buildroot the mode of operation is controlled by the -+BR2_PACKAGE_REFPOLICY_POLICY_STATE_*+ configuration options. The -Linux kernel also has various configuration options that affect how -+SELinux+ is enabled (see +security/selinux/Kconfig+ in the Linux -kernel sources). - -By default in Buildroot the +SELinux+ policy is provided by the -upstream https://github.com/SELinuxProject/refpolicy[refpolicy] -project, enabled with +BR2_PACKAGE_REFPOLICY+. - -[[enabling-selinux]] -=== Enabling SELinux support - -To have proper support for +SELinux+ in a Buildroot generated system, -the following configuration options must be enabled: - -* +BR2_PACKAGE_LIBSELINUX+ -* +BR2_PACKAGE_REFPOLICY+ - -In addition, your filesystem image format must support extended -attributes. - -[[selinux-policy-tweaking]] -=== SELinux policy tweaking - -The +SELinux refpolicy+ contains modules that can be enabled or -disabled when being built. Each module provide a number of +SELinux+ -rules. In Buildroot the non-base modules are disabled by default and -several ways to enable such modules are provided: - -- Packages can enable a list of +SELinux+ modules within the +refpolicy+ using - the +_SELINUX_MODULES+ variable. -- Packages can provide additional +SELinux+ modules by putting them (.fc, .if - and .te files) in +package//selinux/+. -- Extra +SELinux+ modules can be added in directories pointed by the - +BR2_REFPOLICY_EXTRA_MODULES_DIRS+ configuration option. -- Additional modules in the +refpolicy+ can be enabled if listed in the - +BR2_REFPOLICY_EXTRA_MODULES_DEPENDENCIES+ configuration option. - -Buildroot also allows to completely override the +refpolicy+. This -allows to provide a full custom policy designed specifically for a -given system. When going this way, all of the above mechanisms are -disabled: no extra +SElinux+ module is added to the policy, and all -the available modules within the custom policy are enabled and built -into the final binary policy. The custom policy must be a fork of the -official https://github.com/SELinuxProject/refpolicy[refpolicy]. - -In order to fully override the +refpolicy+ the following configuration -variables have to be set: - -- +BR2_PACKAGE_REFPOLICY_CUSTOM_GIT+ -- +BR2_PACKAGE_REFPOLICY_CUSTOM_REPO_URL+ -- +BR2_PACKAGE_REFPOLICY_CUSTOM_REPO_VERSION+ diff --git a/docs/manual/using-buildroot-debugger.txt b/docs/manual/using-buildroot-debugger.txt deleted file mode 100644 index 9a8a7dfbaf..0000000000 --- a/docs/manual/using-buildroot-debugger.txt +++ /dev/null @@ -1,53 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -==== Using +gdb+ in Buildroot - -Buildroot allows to do cross-debugging, where the debugger runs on the -build machine and communicates with +gdbserver+ on the target to -control the execution of the program. - -To achieve this: - -* If you are using an _internal toolchain_ (built by Buildroot), you - must enable +BR2_PACKAGE_HOST_GDB+, +BR2_PACKAGE_GDB+ and - +BR2_PACKAGE_GDB_SERVER+. This ensures that both the cross gdb and - gdbserver get built, and that gdbserver gets installed to your target. - -* If you are using an _external toolchain_, you should enable - +BR2_TOOLCHAIN_EXTERNAL_GDB_SERVER_COPY+, which will copy the - gdbserver included with the external toolchain to the target. If your - external toolchain does not have a cross gdb or gdbserver, it is also - possible to let Buildroot build them, by enabling the same options as - for the _internal toolchain backend_. - -Now, to start debugging a program called +foo+, you should run on the -target: - ----------------------------- -gdbserver :2345 foo ----------------------------- - -This will cause +gdbserver+ to listen on TCP port 2345 for a connection -from the cross gdb. - -Then, on the host, you should start the cross gdb using the following -command line: - ----------------------------- -/output/host/bin/-gdb -ix /output/staging/usr/share/buildroot/gdbinit foo ----------------------------- - -Of course, +foo+ must be available in the current directory, built -with debugging symbols. Typically you start this command from the -directory where +foo+ is built (and not from +output/target/+ as the -binaries in that directory are stripped). - -The +/output/staging/usr/share/buildroot/gdbinit+ file will tell the -cross gdb where to find the libraries of the target. - -Finally, to connect to the target from the cross gdb: - ----------------------------- -(gdb) target remote :2345 ----------------------------- diff --git a/docs/manual/using-buildroot-development.txt b/docs/manual/using-buildroot-development.txt deleted file mode 100644 index da6dd822fb..0000000000 --- a/docs/manual/using-buildroot-development.txt +++ /dev/null @@ -1,121 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -==== Using Buildroot during development - -The normal operation of Buildroot is to download a tarball, extract -it, configure, compile and install the software component found inside -this tarball. The source code is extracted in -+output/build/-+, which is a temporary directory: -whenever +make clean+ is used, this directory is entirely removed, and -re-created at the next +make+ invocation. Even when a Git or -Subversion repository is used as the input for the package source -code, Buildroot creates a tarball out of it, and then behaves as it -normally does with tarballs. - -This behavior is well-suited when Buildroot is used mainly as an -integration tool, to build and integrate all the components of an -embedded Linux system. However, if one uses Buildroot during the -development of certain components of the system, this behavior is not -very convenient: one would instead like to make a small change to the -source code of one package, and be able to quickly rebuild the system -with Buildroot. - -Making changes directly in +output/build/-+ is not -an appropriate solution, because this directory is removed on +make -clean+. - -Therefore, Buildroot provides a specific mechanism for this use case: -the +_OVERRIDE_SRCDIR+ mechanism. Buildroot reads an _override_ -file, which allows the user to tell Buildroot the location of the -source for certain packages. - -The default location of the override file is +$(CONFIG_DIR)/local.mk+, -as defined by the +BR2_PACKAGE_OVERRIDE_FILE+ configuration option. -+$(CONFIG_DIR)+ is the location of the Buildroot +.config+ file, so -+local.mk+ by default lives side-by-side with the +.config+ file, -which means: - -* In the top-level Buildroot source directory for in-tree builds - (i.e., when +O=+ is not used) -* In the out-of-tree directory for out-of-tree builds (i.e., when - +O=+ is used) - -If a different location than these defaults is required, it can be -specified through the +BR2_PACKAGE_OVERRIDE_FILE+ configuration -option. - -In this _override_ file, Buildroot expects to find lines of the form: - ------------------- -_OVERRIDE_SRCDIR = /path/to/pkg1/sources -_OVERRIDE_SRCDIR = /path/to/pkg2/sources ------------------- - -For example: - ------------------- -LINUX_OVERRIDE_SRCDIR = /home/bob/linux/ -BUSYBOX_OVERRIDE_SRCDIR = /home/bob/busybox/ ------------------- - -When Buildroot finds that for a given package, an -+_OVERRIDE_SRCDIR+ has been defined, it will no longer attempt to -download, extract and patch the package. Instead, it will directly use -the source code available in the specified directory and +make clean+ -will not touch this directory. This allows to point Buildroot to your -own directories, that can be managed by Git, Subversion, or any other -version control system. To achieve this, Buildroot will use _rsync_ to -copy the source code of the component from the specified -+_OVERRIDE_SRCDIR+ to +output/build/-custom/+. - -This mechanism is best used in conjunction with the +make --rebuild+ and +make -reconfigure+ targets. A +make --rebuild all+ sequence will _rsync_ the source code from -+_OVERRIDE_SRCDIR+ to +output/build/-custom+ (thanks to -_rsync_, only the modified files are copied), and restart the build -process of just this package. - -In the example of the +linux+ package above, the developer can then -make a source code change in +/home/bob/linux+ and then run: - ------------------------ -make linux-rebuild all ------------------------ - -and in a matter of seconds gets the updated Linux kernel image in -+output/images+. Similarly, a change can be made to the BusyBox source -code in +/home/bob/busybox+, and after: - ------------------------ -make busybox-rebuild all ------------------------ - -the root filesystem image in +output/images+ contains the updated -BusyBox. - -Source trees for big projects often contain hundreds or thousands of -files which are not needed for building, but will slow down the process -of copying the sources with _rsync_. Optionally, it is possible define -+_OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS+ to skip syncing certain files -from the source tree. For example, when working on the +webkitgtk+ -package, the following will exclude the tests and in-tree builds from -a local WebKit source tree: - ------------------- -WEBKITGTK_OVERRIDE_SRCDIR = /home/bob/WebKit -WEBKITGTK_OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS = \ - --exclude JSTests --exclude ManualTests --exclude PerformanceTests \ - --exclude WebDriverTests --exclude WebKitBuild --exclude WebKitLibraries \ - --exclude WebKit.xcworkspace --exclude Websites --exclude Examples ------------------- - -By default, Buildroot skips syncing of VCS artifacts (e.g., the *.git* and -*.svn* directories). Some packages prefer to have these VCS directories -available during build, for example for automatically determining a precise -commit reference for version information. To undo this built-in filtering at a -cost of a slower speed, add these directories back: - ------------------- -LINUX_OVERRIDE_SRCDIR_RSYNC_EXCLUSIONS = --include .git ------------------- diff --git a/docs/manual/using-buildroot-toolchain.txt b/docs/manual/using-buildroot-toolchain.txt deleted file mode 100644 index 09408ef05a..0000000000 --- a/docs/manual/using-buildroot-toolchain.txt +++ /dev/null @@ -1,48 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -==== Using the generated toolchain outside Buildroot - -You may want to compile, for your target, your own programs or other -software that are not packaged in Buildroot. In order to do this you -can use the toolchain that was generated by Buildroot. - -The toolchain generated by Buildroot is located by default in -+output/host/+. The simplest way to use it is to add -+output/host/bin/+ to your PATH environment variable and then to -use +ARCH-linux-gcc+, +ARCH-linux-objdump+, +ARCH-linux-ld+, etc. - -Alternatively, Buildroot can also export the toolchain and the development -files of all selected packages, as an SDK, by running the command -+make sdk+. This generates a tarball of the content of the host directory -+output/host/+, named +_sdk-buildroot.tar.gz+ (which can be -overriden by setting the environment variable +BR2_SDK_PREFIX+) and -located in the output directory +output/images/+. - -This tarball can then be distributed to application developers, when -they want to develop their applications that are not (yet) packaged as -a Buildroot package. - -Upon extracting the SDK tarball, the user must run the script -+relocate-sdk.sh+ (located at the top directory of the SDK), to make -sure all paths are updated with the new location. - -Alternatively, if you just want to prepare the SDK without generating -the tarball (e.g. because you will just be moving the +host+ directory, -or will be generating the tarball on your own), Buildroot also allows -you to just prepare the SDK with +make prepare-sdk+ without actually -generating a tarball. - -For your convenience, by selecting the option -+BR2_PACKAGE_HOST_ENVIRONMENT_SETUP+, you can get a -+environment-setup+ script installed in +output/host/+ and therefore -in your SDK. This script can be sourced with -+. your/sdk/path/environment-setup+ to export a number of environment -variables that will help cross-compile your projects using the -Buildroot SDK: the +PATH+ will contain the SDK binaries, standard -_autotools_ variables will be defined with the appropriate values, and -+CONFIGURE_FLAGS+ will contain basic +./configure+ options to -cross-compile _autotools_ projects. It also provides some useful -commands. Note however that once this script is sourced, the -environment is setup only for cross-compilation, and no longer for -native compilation. diff --git a/docs/manual/writing-rules.txt b/docs/manual/writing-rules.txt deleted file mode 100644 index 3b809d5c48..0000000000 --- a/docs/manual/writing-rules.txt +++ /dev/null @@ -1,151 +0,0 @@ -// -*- mode:doc; -*- -// vim: set syntax=asciidoc: - -== Coding style - -Overall, these coding style rules are here to help you to add new files in -Buildroot or refactor existing ones. - -If you slightly modify some existing file, the important thing is -to keep the consistency of the whole file, so you can: - -* either follow the potentially deprecated coding style used in this -file, - -* or entirely rework it in order to make it comply with these rules. - -[[writing-rules-config-in]] - -=== +Config.in+ file - -+Config.in+ files contain entries for almost anything configurable in -Buildroot. - -An entry has the following pattern: - ---------------------- -config BR2_PACKAGE_LIBFOO - bool "libfoo" - depends on BR2_PACKAGE_LIBBAZ - select BR2_PACKAGE_LIBBAR - help - This is a comment that explains what libfoo is. The help text - should be wrapped. - - http://foosoftware.org/libfoo/ ---------------------- - -* The +bool+, +depends on+, +select+ and +help+ lines are indented - with one tab. - -* The help text itself should be indented with one tab and two - spaces. - -* The help text should be wrapped to fit 72 columns, where tab counts - for 8, so 62 characters in the text itself. - -The +Config.in+ files are the input for the configuration tool -used in Buildroot, which is the regular _Kconfig_. For further -details about the _Kconfig_ language, refer to -http://kernel.org/doc/Documentation/kbuild/kconfig-language.txt[]. - -[[writing-rules-mk]] - -=== The +.mk+ file - -* Header: The file starts with a header. It contains the module name, -preferably in lowercase, enclosed between separators made of 80 hashes. A -blank line is mandatory after the header: -+ ---------------------- -################################################################################ -# -# libfoo -# -################################################################################ ---------------------- -+ -* Assignment: use +=+ preceded and followed by one space: -+ ---------------------- -LIBFOO_VERSION = 1.0 -LIBFOO_CONF_OPTS += --without-python-support ---------------------- -+ -Do not align the +=+ signs. - -* Indentation: use tab only: -+ ---------------------- -define LIBFOO_REMOVE_DOC - $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/doc \ - $(TARGET_DIR)/usr/share/man/man3/libfoo* -endef ---------------------- -+ -Note that commands inside a +define+ block should always start with a tab, -so _make_ recognizes them as commands. - -* Optional dependency: - -** Prefer multi-line syntax. -+ -YES: -+ ---------------------- -ifeq ($(BR2_PACKAGE_PYTHON),y) -LIBFOO_CONF_OPTS += --with-python-support -LIBFOO_DEPENDENCIES += python -else -LIBFOO_CONF_OPTS += --without-python-support -endif ---------------------- -+ -NO: -+ ---------------------- -LIBFOO_CONF_OPTS += --with$(if $(BR2_PACKAGE_PYTHON),,out)-python-support -LIBFOO_DEPENDENCIES += $(if $(BR2_PACKAGE_PYTHON),python,) ---------------------- - -** Keep configure options and dependencies close together. - -* Optional hooks: keep hook definition and assignment together in one - if block. -+ -YES: -+ ---------------------- -ifneq ($(BR2_LIBFOO_INSTALL_DATA),y) -define LIBFOO_REMOVE_DATA - $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/data -endef -LIBFOO_POST_INSTALL_TARGET_HOOKS += LIBFOO_REMOVE_DATA -endif ---------------------- -+ -NO: -+ ---------------------- -define LIBFOO_REMOVE_DATA - $(RM) -fr $(TARGET_DIR)/usr/share/libfoo/data -endef - -ifneq ($(BR2_LIBFOO_INSTALL_DATA),y) -LIBFOO_POST_INSTALL_TARGET_HOOKS += LIBFOO_REMOVE_DATA -endif ---------------------- - -=== The documentation - -The documentation uses the -http://www.methods.co.nz/asciidoc/[asciidoc] format. - -For further details about the asciidoc syntax, refer to -http://www.methods.co.nz/asciidoc/userguide.html[]. - -=== Support scripts - -Some scripts in the +support/+ and +utils/+ directories are written in -Python and should follow the -https://www.python.org/dev/peps/pep-0008/[PEP8 Style Guide for Python Code]. diff --git a/docs/website/.htaccess b/docs/website/.htaccess deleted file mode 100644 index b02beb8854..0000000000 --- a/docs/website/.htaccess +++ /dev/null @@ -1,62 +0,0 @@ -# BEGIN Compress text files - - - SetOutputFilter DEFLATE - - -# END Compress text files - -# BEGIN Expire headers - - ExpiresActive On - ExpiresDefault "access plus 1 seconds" - ExpiresByType image/x-icon "access plus 2592000 seconds" - ExpiresByType image/jpeg "access plus 2592000 seconds" - ExpiresByType image/png "access plus 2592000 seconds" - ExpiresByType image/gif "access plus 2592000 seconds" - ExpiresByType application/x-shockwave-flash "access plus 2592000 seconds" - ExpiresByType text/css "access plus 604800 seconds" - ExpiresByType text/javascript "access plus 216000 seconds" - ExpiresByType application/javascript "access plus 216000 seconds" - ExpiresByType application/x-javascript "access plus 216000 seconds" - ExpiresByType text/html "access plus 600 seconds" - ExpiresByType application/xhtml+xml "access plus 600 seconds" - -# END Expire headers - -# BEGIN Cache-Control Headers - - - Header set Cache-Control "max-age=2592000, public" - - - Header set Cache-Control "max-age=604800, public" - - - Header set Cache-Control "max-age=216000, private" - - - Header set Cache-Control "max-age=600, private, must-revalidate" - - -# END Cache-Control Headers - -# BEGIN Turn ETags Off - - Header unset ETag - -FileETag None -# END Turn ETags Off - -# BEGIN gzip - -mod_gzip_on Yes -mod_gzip_dechunk Yes -mod_gzip_item_include file .(html?|txt|css|js)$ -mod_gzip_item_include handler ^cgi-script$ -mod_gzip_item_include mime ^text/.* -mod_gzip_item_include mime ^application/x-javascript.* -mod_gzip_item_exclude mime ^image/.* -mod_gzip_item_exclude rspheader ^Content-Encoding:.*gzip.* - -# END gzip diff --git a/docs/website/association.html b/docs/website/association.html deleted file mode 100644 index 0215f85874..0000000000 --- a/docs/website/association.html +++ /dev/null @@ -1,122 +0,0 @@ - - -

- - diff --git a/docs/website/contribute.html b/docs/website/contribute.html deleted file mode 100644 index aa1cf93f1b..0000000000 --- a/docs/website/contribute.html +++ /dev/null @@ -1,44 +0,0 @@ - - -
-
-
- -
-
Contribute
-
-

Buildroot is an open source project and you are very welcome to contribute to - it.
- There are many different ways to contribute:

- - - -

For more details on these topics, check out the - - Contributing to buildroot chapter in the Buildroot manual. Thanks for your help!

- -

If you need any support yourself, have a look at - Support.

-
-
- -
-
-
- - diff --git a/docs/website/copyright.txt b/docs/website/copyright.txt deleted file mode 100644 index b15ac5f919..0000000000 --- a/docs/website/copyright.txt +++ /dev/null @@ -1,30 +0,0 @@ - -The code and graphics on this website (and it's mirror sites, if any) are -Copyright (c) 1999-2005 by Erik Andersen, 2006-2020 The Buildroot -developers. All rights reserved. - -Documents on this Web site including their graphical elements, design, and -layout are protected by trade dress and other laws and MAY BE COPIED OR -IMITATED IN WHOLE OR IN PART. THIS WEBSITE IS LICENSED FREE OF CHARGE, THERE -IS NO WARRANTY FOR THE WEBSITE TO THE EXTENT PERMITTED BY APPLICABLE LAW. -SHOULD THIS WEBSITE PROVE DEFECTIVE, YOU MAY ASSUME THAT SOMEONE MIGHT GET -AROUND TO SERVICING, REPAIRING OR CORRECTING IT SOMETIME WHEN THEY HAVE NOTHING -BETTER TO DO. REGARDLESS, YOU GET TO KEEP BOTH PIECES. - -IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY -COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THIS -WEBSITE AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY -GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR -INABILITY TO USE THIS WEBSITE (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR -LOSS OF HAIR, LOSS OF LIFE, LOSS OF MEMORY, LOSS OF YOUR CARKEYS, MISPLACEMENT -OF YOUR PAYCHECK, OR COMMANDER DATA BEING RENDERED UNABLE TO ASSIST THE -STARFLEET OFFICERS ABORD THE STARSHIP ENTERPRISE TO RECALIBRATE THE MAIN -DEFLECTOR ARRAY, LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE -WEBSITE TO OPERATE WITH YOUR WEBBROWSER), EVEN IF SUCH HOLDER OR OTHER PARTY -HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. - -You have been warned. - -You can contact the webmaster at if you have some sort -of problem with this. - diff --git a/docs/website/css/main.css b/docs/website/css/main.css deleted file mode 100644 index 5255531b30..0000000000 --- a/docs/website/css/main.css +++ /dev/null @@ -1,260 +0,0 @@ -/* - * Author: Carlos Alvarez - * URL: http://alvarez.is - * - * Project Name: FLATTY - Free Bootstrap 3 Theme - * Version: 1.0 - * URL: http://blacktie.co - */ - -body { - background-color: #f2f2f2; - font-family: 'Roboto', sans-serif; - font-weight: 300; - font-size: 16px; - color: #555; - - -webkit-font-smoothing: antialiased; - -webkit-overflow-scrolling: touch; -} - -/* Titles */ -h1, h2, h3, h4, h5, h6 { - font-family: 'Roboto', sans-serif; - font-weight: 300; - color: #333; -} - -h1 { - font-size: 40px; -} - -h3 { - color: #95a5a6; - font-weight: 400; -} - -h4 { - color: #95a5a6; - font-weight: 400; - font-size: 20px; -} - -.ellipsis p { - margin-bottom:10px; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; -} - -.centered { - text-align: center; -} - -/* Links */ -a { - color: #3498db; - word-wrap: break-word; - - -webkit-transition: color 0.1s ease-in, background 0.1s ease-in; - -moz-transition: color 0.1s ease-in, background 0.1s ease-in; - -ms-transition: color 0.1s ease-in, background 0.1s ease-in; - -o-transition: color 0.1s ease-in, background 0.1s ease-in; - transition: color 0.1s ease-in, background 0.1s ease-in; -} - -a:hover, -a:focus { - color: #7b7b7b; - text-decoration: none; - outline: 0; -} - -a:before, -a:after { - -webkit-transition: color 0.1s ease-in, background 0.1s ease-in; - -moz-transition: color 0.1s ease-in, background 0.1s ease-in; - -ms-transition: color 0.1s ease-in, background 0.1s ease-in; - -o-transition: color 0.1s ease-in, background 0.1s ease-in; - transition: color 0.1s ease-in, background 0.1s ease-in; -} - - hr { - display: block; - height: 1px; - border: 0; - border-top: 1px solid #ccc; - margin: 1em 0; - padding: 0; -} - -.navbar-default { - background-color: #3498db; - border-color: transparent; -} - -.navbar-default .navbar-brand { - color: white; -} - -.navbar-default .navbar-nav > li > a { - color: white; -} - -/* Helpers */ - -.mt { - margin-top: 40px; - margin-bottom: 40px; -} - -.nh { - margin-top: 80px; - margin-bottom: 40px; -} - -.form-control { - height: 42px; - font-size: 18px; - width: 280px; -} - -i { - margin: 8px; - color: #3498db; -} - - -/* HeaderWrap */ -#headerwrap { - /* background: url(../img/bg01.jpg) no-repeat center top; */ - background-color: #3498db; - margin-top: -20px; - padding-top:120px; - background-attachment: relative; - background-position: center center; - min-height: 400px; - max-height: 800px; - width: 100%; - - -webkit-background-size: 100%; - -moz-background-size: 100%; - -o-background-size: 100%; - background-size: 100%; - - -webkit-background-size: cover; - -moz-background-size: cover; - -o-background-size: cover; - background-size: cover; -} - -#headerwrap h1 { - color: white; - font-size: 60px; - font-weight: bold; - letter-spacing: 1px; -} - -#menubutton { - max-height: 50px; - margin-top: 6px; - padding-top: 15px; - margin-left: 10px; -} - -.panel-sponsor { - min-height: 350px; - text-align: justify; - text-justify: inter-word; -} - -@media (min-width: 768px) and (max-width: 991px) { - .navbar-collapse.collapse { - display: none !important; - } - .navbar-collapse.collapse.in { - display: block !important; - } - .navbar-header .collapse, .navbar-toggle { - display:block !important; - } - .navbar-header { - float:none; - } - .navbar-collapse { - overflow:hidden; - } - #menubutton { - margin-right: 40px; - width: 45px; - } - .text-shrink { - visibility: hidden; - } -} - -@media (max-width:767px) { - #menubutton { - max-height: 50px; - margin-top: 6px; - padding-top: 15px; - margin-left: 15px; - margin-right: 15px; - } -} - -/* entire container, keeps perspective */ -.flip-container { - perspective: 1000; -} - /* flip the pane when hovered */ - .flip-container:hover .flipper, .flip-container.hover .flipper { - transform: rotateY(180deg); - } - -.flip-container, .front, .back { - width: 180px; - height: 180px; -} - -/* flip speed goes here */ -.flipper { - transition: 0.6s; - transform-style: preserve-3d; - - position: relative; -} - -/* hide back of pane during swap */ -.front, .back { - backface-visibility: hidden; - - position: absolute; - top: 0; - left: 0; -} - -/* front pane, placed above back */ -.front { - z-index: 2; - /* for firefox 31 */ - transform: rotateY(0deg); -} - -/* back, initially hidden pane */ -.back { - transform: rotateY(180deg); -} - -.back img { - -moz-transform: scaleX(-1); - -o-transform: scaleX(-1); - -webkit-transform: scaleX(-1); - transform: scaleX(-1); - filter: FlipH; - -ms-filter: "FlipH"; -} - -.panel-box p { - height: 1.5em; -} diff --git a/docs/website/css/timeline.css b/docs/website/css/timeline.css deleted file mode 100644 index df58461ae2..0000000000 --- a/docs/website/css/timeline.css +++ /dev/null @@ -1,184 +0,0 @@ -.timeline { - list-style: none; - padding: 20px 0 20px; - position: relative; -} - -.timeline:before { - top: 0; - bottom: 0; - position: absolute; - content: " "; - width: 3px; - background-color: #E4E4E4; - left: 50%; - margin-left: -1.5px; - } - -.timeline > li { - margin-bottom: 20px; - position: relative; -} - -.timeline > li:before, -.timeline > li:after { - content: " "; - display: table; -} - -.timeline > li:after { - clear: both; -} - -.timeline > li:before, -.timeline > li:after { - content: " "; - display: table; -} - -.timeline > li:after { - clear: both; -} - -.timeline > li > .timeline-panel { - width: 46%; - float: left; - border: 1px solid #d4d4d4; - border-radius: 2px; - padding: 20px; - position: relative; - -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175); - box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175); - background-color: white; -} - -.timeline > li > .timeline-panel:before { - position: absolute; - top: 26px; - right: -15px; - display: inline-block; - border-top: 15px solid transparent; - border-left: 15px solid #ccc; - border-right: 0 solid #ccc; - border-bottom: 15px solid transparent; - content: " "; -} - -.timeline > li > .timeline-panel:after { - position: absolute; - top: 27px; - right: -14px; - display: inline-block; - border-top: 14px solid transparent; - border-left: 14px solid #fff; - border-right: 0 solid #fff; - border-bottom: 14px solid transparent; - content: " "; -} - -.timeline > li > .timeline-badge { - color: #fff; - width: 50px; - height: 50px; - line-height: 50px; - font-size: 1.4em; - text-align: center; - position: absolute; - top: 16px; - left: 50%; - margin-left: -25px; - background-color: #E6E6E6; - z-index: 100; - border-top-right-radius: 50%; - border-top-left-radius: 50%; - border-bottom-right-radius: 50%; - border-bottom-left-radius: 50%; -} - -.timeline > li.timeline-inverted > .timeline-panel { - float: right; -} - -.timeline > li.timeline-inverted > .timeline-panel:before { - border-left-width: 0; - border-right-width: 15px; - left: -15px; - right: auto; -} - -.timeline > li.timeline-inverted > .timeline-panel:after { - border-left-width: 0; - border-right-width: 14px; - left: -14px; - right: auto; -} - -.timeline-badge.primary { - background-color: #2e6da4 !important; -} - -.timeline-badge.success { - background-color: #3f903f !important; -} - -.timeline-badge.warning { - background-color: #f0ad4e !important; -} - -.timeline-badge.danger { - background-color: #d9534f !important; -} - -.timeline-badge.info { - background-color: #5bc0de !important; -} - -.timeline-title { - margin-top: 0; - color: inherit; -} - -.timeline-body > p, -.timeline-body > ul { - margin-bottom: 0; -} - -.timeline-body > p + p { - margin-top: 5px; -} - -@media (max-width: 767px) { - ul.timeline:before { - left: 40px; - } - - ul.timeline > li > .timeline-panel { - width: calc(100% - 90px); - width: -moz-calc(100% - 90px); - width: -webkit-calc(100% - 90px); - } - - ul.timeline > li > .timeline-badge { - left: 15px; - margin-left: 0; - top: 16px; - } - - ul.timeline > li > .timeline-panel { - float: right; - } - - ul.timeline > li > .timeline-panel:before { - border-left-width: 0; - border-right-width: 15px; - left: -15px; - right: auto; - } - - ul.timeline > li > .timeline-panel:after { - border-left-width: 0; - border-right-width: 14px; - left: -14px; - right: auto; - } -} diff --git a/docs/website/docs.html b/docs/website/docs.html deleted file mode 100644 index 85b005004d..0000000000 --- a/docs/website/docs.html +++ /dev/null @@ -1,130 +0,0 @@ - - -
-
-
- -
-
Documentation
-
-

The Buildroot user manual is where you want to start reading if you - wish to understand how Buildroot works, or wish to change/extend/fix - things. It is available as:

- -
-
-
-
-
- -
-
- -
-
-
- -

HTML
- Stable | - Nightly -

- -
- -
-
-
-
- -
-
- -
-
-
- -

PDF
- Stable | - Nightly -

- -
- -
-
-
-
- -
-
- -
-
-
- -

ASCII
- Stable | - Nightly -

- -
-
- -

If you find any errors (factual, grammatical, whatever) please - report them to us.

-
-
- -
-
Training
-
-

Bootlin (formerly Free Electrons) - offers a complete 3-days - training course on Buildroot. They also make the training - materials freely available:

- -
-
-
-
Slides preview
-
-
- buildroot slides -
-
-
-
- -
-
-
Training materials
- -
- -
-
Public online training course
-
- Regular online training courses, available to individual - registration, are proposed by Bootlin, with Thomas - Petazzoni as - trainer. See next - dates and registration details. -
-
-
-
-
-
- -
-
-
- - - diff --git a/docs/website/download.html b/docs/website/download.html deleted file mode 100644 index 5fea085ef9..0000000000 --- a/docs/website/download.html +++ /dev/null @@ -1,217 +0,0 @@ - - -
-
-
- -
-
Download
-
- -

Latest long term support release: 2021.02.4

- -
-
-
-
-
- -
-
- -
-
-
-

buildroot-2021.02.4.tar.gz

-

PGP signature

-
-
-
-
-
- -
-
- -
-
-
- -

buildroot-2021.02.4.tar.bz2

-

PGP signature

-
-
- -

Latest stable release: 2021.08

- -
-
-
-
-
- -
-
- -
-
-
-

buildroot-2021.08.tar.gz

-

PGP signature

-
-
-
-
-
- -
-
- -
-
-
- -

buildroot-2021.08.tar.bz2

-

PGP signature

-
-
- - This and earlier releases (and their PGP signatures) can always be downloaded from - http://buildroot.net/downloads/. -
-
- -
-
Source code
-
- -
-
-
-
Repository
-
-

The buildroot repository can be browsed online through cgit at - http://git.buildroot.net/buildroot. - To grab a copy of the repository use

- - -
- - - - -

- -

- Or if you're behind a firewall blocking git: -

- -
- - - - -

- -

- - Please use the native git protocol if at all possible, as it's a lot - more efficient than HTTP. - -

- - If you are not already familiar with using Git, we recommend you visit the Git website. - -

- - Once you've checked out a copy of the source tree, you can update your source - tree at any time so it is in sync with the latest and greatest by entering your - buildroot directory and running the command: - -

-git pull
-
- - Because you've only been granted anonymous access to the tree, you won't be - able to push your changes to the repo. Changes can instead be submitted for - inclusion by posting them to the buildroot mailing list. -
-
-
- -
-
-
Tarballs
-
- You can also obtain daily snapshots of the latest Buildroot source tree if you - want to follow development, but cannot or do not wish to use Git. - - - -

- Older versions can be downloaded from the release archive. -

-
-
-
-
-
-
- -
-
-
- - diff --git a/docs/website/favicon.ico b/docs/website/favicon.ico deleted file mode 100644 index fa9d24079be70cfff5e014e0ecd1f4236deb7ab6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2238 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 - - - - - - diff --git a/docs/website/header.html b/docs/website/header.html deleted file mode 100644 index e1909291f6..0000000000 --- a/docs/website/header.html +++ /dev/null @@ -1,54 +0,0 @@ - - - - - - - - - - - Buildroot - Making Embedded Linux Easy - - - - - - - - - - diff --git a/docs/website/images/amarula-solutions-logo.png b/docs/website/images/amarula-solutions-logo.png deleted file mode 100644 index 3fe4aeef8162bd4c8233d89da93e4606c479a9b5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16768 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 diff --git a/docs/website/images/bootlin-logo.png b/docs/website/images/bootlin-logo.png deleted file mode 100644 index 4f918750ec4538baa801ef4e0a0cc6bc0abe534b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6171 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 Dysydb diff --git a/docs/website/images/browser.png b/docs/website/images/browser.png deleted file mode 100644 index 56039dfaae032dc97033ece6e64e3ee0ec973cc4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18175 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 diff --git a/docs/website/images/buildroot-slides.png b/docs/website/images/buildroot-slides.png deleted file mode 100644 index 6ecba3d479623a3a92689d5eea7523e7f1084453..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 32837 zcmce;WmHvb_%AvU=@g_T1?iTMmJR_$1(607>6DP}lu|-TNkLLUx>Er`KtMo3T98ya z?lbrQoDX;0d&an*u6r=H;97Id`Ns47>Luc~mI@I*Ek1%EL~5#vItYTX4_}_R*zl9U z0gG7pAGW!MiXw83{+HEQ@DhH4=cuahf*>Sj=oiL2*#ay0A&#q>rV`E!J^{rwW_CR* zIs{=t)D&;t^O#uw>3;9B9v#l?%m>$t@hqKzSQHvO9O03Xf!Outt<#$2$}d(dH$`*@ z$IV|*U|yqwE(~=GT zNS7Qgb8sB3Lg)v7QhD6Bvs&;iDgH+A|NA$$9ogYu!d+jUG6-v`hPStejcv`f(=9CG zF>!N~U}9cPNhOghd053ch6h*ut>b*Y#Z0(1s@XMOAv^c|ed^N@)l0k&M{b@Teel>> zU{Q{K8dG9m$s#J6;G6-U7{8Zr+!+<-xYWn^;FB%h*R&rv6cmZ_RtX6Sjwc6reQ7_) z-P}?K3u6Dc&$M{$^O@~$D6!1HO0;Qh$-?UE$7z{(&U0`Q`8m{Xa%uKk&YHN71SuDn zwNk#5^F)}irJGrM=6GB+yAWV%ztlGFY0@2#}G

Mj?d?ob8k(4fh6eKjH8nLkxWt;Gokd=jqiRl?Oc_W)M&4mdsHh;L_{{2h1wesy*xln_w<+i!Xl^efa zgc7CRk4mS%vL0pJ_$l^jvpWW6mH&pdu#Xh{rjDTce^WG zmeYi=#&#lOW0egJFB1|?`ghNN`v%J^SD9ni&XXkeCAIW(ao1DH5X$M{`uhoEE=0A#$mrPgFHD zIA1NT|B&`L`in7Ic22jyS(t9lr^-ob~`BdoG1dNvS~4 zpHu1TcUr|TkSU9eOw}z0hli6QEkk+7%-q~6mKT_VZ-1uW+Hr1e@N}t}d$u$uWhdzWddofm~XJgyv<(mkJR%cK@5BC@r8*fM2^HJtyty`zI{`7732 zt6@Vr9f6u->>2P|9dIgJ@*GI~0 z>BUR-Y6|uJojlo%DW`yRBZp#rVVd~(xwvFK|JVVdXu2^Be&d52gX*){-N$AQ4ngUX zRN=SywIpb0d;>Ox;D_ABi3qywZ#$C^?}fb9SLylUn=aKH>S0wqW?^m~my~o(s8qM) z;X9LNJ{fOZg&^$Ena2tSpVlwB?4BY19UTK6|F{q;zI6q8c^*n$Xa6@3)A5arpFhWU z+c3n{)HD*mA-%kT6dQ;UZEUDSeNI(PlRhRPBz(wp;|7M!=&jKBJ1SSi9a9OumKda( zcgGwGh*SmE9wHUPn(1|fzP=e-drkNny_Zr1%r4QN!e(XLFJq8t2&NIvkBm0>_=L!~ z*_TLKx{<8lnTtz%mCYFbi%dZap@znvO_QOYtSln$*VYsNQBnQp zRpq|mXn2{u3ah#b)W$%s2pPW^#rdumN?o6OdtK%)Uck6;;ezAp5L<9aNJQ>?lV+JW z*R6D(W~56zlUG!9%(FkymVIs3cF`+1^bAvbfPg|`lY}vt7a=5kqfseyD6epifsDLo ze>33hyfZjDy6j6OMh|nt7}im}C@d@-mzem_oc3qk!>8HIIMO2eQc<^5-e*pjwSO{N z8LzOY7~VScW@YOP5Y#Oc8GGjX8xv{rj^Gqb&#gNA{=Eu8I5{KCwR4IMqmD~UO3r6O zUadS|TwG*kW~Ssda7*BTk0Rx&rCMtXX}qn=*R*P&qeFJ_$Lks~V`593-7W8YeDn5< zw$1H%o#piS_`vz@>U$GimX?-tzdGAzw><=e*9=zn1Eu>rJ5)y*ec$U|L;SmA9U`K& zwY4wVJSTrSjriBQ8!2_kK3@n}U*~b%uw}a=F^BbP-OpXud8G&13I2wBZS94$8z1S4 zimDuc+W4MVKjl=dgXJ&tYe_7+Y%3qN$CM49ABG^2)vp6sA`jmIN$tPg4I=#aF z=XGl8%9f6ZC^mH*MDtB0HiGWM+13e z%2_@kKoI>}!jIA)Djpwanm=>R$;}OiI;~qwP2h8i4HfBRS7X`5B~YSVsR6P_75VbzDyZb$?BlG_$iKqM@N#SX`VNEiriT z@rg98m}pm9h*#6G%ONa+j&2nN4UOul({grpzkt9%o!7@%meI^IGPKWrKTRH=ixyv{ zwg`_p#(nn8uBVrKkOrEFNZfe!VzYO|O}Q3nM9$pYIl@Ykrn)^#m{YZM7&}ZmjneCJ zTYI~p^Mb0B-`SPZpDlu0stzIc$lF5usm#n_ZwuqS_^Dny*trf4>YjCine>HV?bR?y? zeQlU=Tv)KGz?4L6$ICGaw9*5kqX{!){fGnPZZBZTJ$Z6%Z_~Y_@NTNr<|TPt=0&^> zSlPGlz7L|86qM zC+>6P9a1bOCx-+E1+^~kDs}aK`NAT!gE_kQs{3aI*8w%>gu<2B?)Kw-GgZ~_oW}p2 zgRO>&m7P7d>&0Yi?|W~NQ5uUB5gW=6A0mCPPIlSVm$ypdT*9mE;T@!~ZAweC6_?yB z_@6h5)nNLU{JFqm+;HW_jmMh>Q|;}TXJ=^qYOIRngN!Teo%k58d|I+n|u4YpkqUVfySHQ^y2P zti%MLJeB3(ESigzL~hGlQ{E62^$1^&~lNcF!iFpoOcp&VGIHBgku4`JZErw&<*`$9?Q*1PMiz7bBE92b7kyu*EThlS-&TJNOm(Bu zf&z9!Bctu*Our!pR=6-1S4}})-c1z^%nFU`Q74UK6^hZ0s;gC1#i~7{i&&Bl=bcCTYbsYoqThp{^?Y` zJIR|jZz^%niF9~%__`i|JMGHa>;qHmi{~OY&*NT2x!k0oo=d~RlD--o8fyOamSnWm zdqa+LO#d`O)7qnF;YsJ!e9~?r*`ps9jJma5O=jFB&m)|BGt96$LXc1jSYd4l9HmLVoP=^ z=Y-Xw`8@*c;UnjF1zjrn{;kri>CcAMrYAaX&hSJxr{IOj zlKh&THhP+NN{fU29s^M}>1!)LoD_WgO;Ovs8ClttMS%Yjq*rXUXk7qUyKr&zgNt zzs})$NA-0G_{@Bg5*)v)}c zGMdNLcK8a_R9TMGeAj;?PijT9fskIld@;7S)bz%WIKA(3Gnpmd@-^uuG|)SKM)V(3 z<&>rQasl>4aG)ftVR?=kU@HHw-?XMfEn>br1(QlD|Ns2v{~P_q#d1e4|36&#|Mt!Q z`Gf!GU;d9D{J(DL|H!-l7bE{ae(?Xgi~qkKU(l$|6)!Y2lqGZT&t&`PC?&ggMz9>y zyYk2VuZ3~oA5^up_(c1ge2z_@J`L}VWgL!2Wrjd6{oMR~7AdJK`T6_Vzi~tDx~zhNLT+xZoSItU#G?i|COKFQO?<*(^M>FM;je?TrpMDZZKPk;N81-EmKohl9G~e@$u#1hl)dhYUxne zf;R>APuzI{H#<99ap;kyB~^XjOLpySzw@)Lot?m@CYgrD#tOU1Px7lLr>Aqjeg#f9 zdRgo&e8wdq2@4FoU_Vt8Kuj;uGBd-7;w>l*wzjtArmYv^S3A|Zmv@^t5E`1EFJI(! zb(3P0Vb4%xtFx#B@EL6O^Fvye2Qn{_lKKONU=|gnBqk<)ceg+*gpZ$%4U2$^FSxXn z4+Td=L_|nSrPVMqatVeA+2oTf83uch6HPFvFc}fpP%fK zAX!l7Sgc@azbz{pIOVgK0BMaB_oBz?kqAJe?YVXw?~{W|f`WoQ{rwbb1wewH|NDJY zTbrc+jfleJCp&nXHjOGrO;iqu4~TzCN($Mq+QdCA4GjV$E+vIy?|PN>_g_uRnH@8w zdd9{K<`x#;3h%N<3|*2hQhxqiVq?0I0I;l-#})!B;c?U5cO@k+N{#BXz4kX&e%6ak zR6A(%`h<_fy~%fkK@s;p5b%&=9{Yd$bkCq?x%8V=EOHfu;)@^-U zaP*U%0k;32i7JgpZ-B)MA?qWBcX>cafie}r$;Aaf03H%8*aeW}D^eaDe9^wnq5H*^ z8wnVuHe;oa-@bjj-Vs55%h)&r!_<9qdNH3)%>D{yOLk6<(&&8kjIV_hLu`ru$53g% zvoxa`$AHz9m2y~4<&~A!BZfP>x`dEo*fV`&W67GSqA#F93&^W>;^N_%!P0nSZEZ~` zm**QD9X-DBvtD0a9sdum4qFjxjo-1LfPkq&81ds+Mp?e={ZJwFK{TkTgw5X9)usGv zHX|*q51WLc4+j0^%a<0El$5r!Edk~@`v68ixh!ktmz4A)0ssj_-PRxM9quj*LvE8^lvC0Ot{*)+~d*t6B45D}Zv=8{%nxD7oj#KZnNRVkM%{JKk_U+r? z_wT&!vg;;I-T?^-z~bHli<6K*5p3Mcm)v?1UDPtZC%ATYb{rfWgLbU)U*>=zJ^-dN z_4B7jadP|ow&|ls7eVB3-I$`GmvC*-mOW+N^OL`Ii!ejRC$gnQ?%?RCZETFn$;pXL zDop$UTZXWkx4)G4E|yn6`q(ot^KF5s~>i(j(( zm0AI)#?;i5<6IjS05!_g(ZNAd91@0w-^>340-EO5)}m;HpUlDtDxFQgyK{B?#}BiU zgY9>)$nuJZb5vrX`rLtnk>4|>w(B8vD?^HAvf6=a)jg+A=&payg?`)b|1e6fv1#vi z5qNB15Ki)(IiL9uUaUjfs}rTPrmTeT`sY5CTW-Gg$PvK zMmOInxX7zk?W_*7M_;)?Ha$J9lr$n{Hxc|TM@7#w)rFUrx7e_j?4#vCR}!zm?CdPl z&N$PxYuE~*gso6YE1Vaj$8da$wx|S25mm%jy8<&CmZVdC`LkzyC0N-BZ@iPgvcMDp$g<4R* zqB4Dt3U8b0-M-xdcS}l38!2efrF!2|h?bUi{F5D>F{ohxA;M3Rl9R)r8s|WVR#jEy zIF@f?#8Bxbko{KX&%YUbbF(_NCCsu#8#BNpJ)rk}fK-4ZZKG~W8n;}dsQ=ozf3jFe z^}zCpyBKo|9&QtUuqWonserHN|7ahMh&vVVsyP#G3D&gK&5$M?WQybYX`gTqo*`Q| zE`)nxR?-m~KE(F0y z_VOACRT2QLa708z;%Cq{3-(0f1DY~Lq89;|CPNti87MO$P}#1Ei$B<*>E*m&UDp;{+_2&xMdQCnahAb<#Fk~nwq#o~a@Vh`FlXOzpA3+(5x_&M&ZyoAm=%T>Qd;%R7Por#N%Fhe1~Z zWWx{|HM#k(ozZms)0J!`)sfg)-^vf3iLMhH>a#aUZY@fi$`~D_ydBt-o4ncbb-HbG zuTI%@$p1~-CHdU(^RsH1pqj8!a`Tm`aWGjK} z5uQdk3bafMblk>N~)D9 zLv;WCciO5FkS?etTsg9{o2K1HM@BmSOjds@HIkH|Mmd1$Klg(zvy+`(ewO)bns0)k za>*;_KhdRletsqm*de6aVaEBtQQX{&#U`R1ym=F4CPe@O_#f!&M>G(70=xrAsQQ9v z9ShTYbGq>o1H;!BHZx7qfCb-XXUpT@{C9i4GTsLWwEm8c4#)W?U(+H0#;M(({I{8o z)A;-!8QzwtsHmfxTPcI*?W7Gyw$_yL)A|OXbOE-ke8*tYLQu6s?&K&(Ty!%qFc6oJ zI1>nswx4K5Hz~zP#(SHp&Y~PNPomq=etmfnVU?$e5E1JH9)4 z>Iq&=rQ!Ik(s;Z}!m!qPF^p&(F}1eF2Q?ftctpsu5P-`-vWy(gbJ;s&g4!EnT zQQDa@W~0UWQ{{Da63{2#78V}1FKeEkomM!_E8B~6aTVR>zEJqr&b_Ad89DdWtLq{I z-gR3dl}gVnQZtE3_a5Nj7R1L>G$}5%n$1p0F>!}zT|~p4f|24F4-M`_n#l&aa&_e{05FIq%oM=w4{N}(A_Bc5Z1ge08qzGDI-_q3lR&J)S zYPjl9-+o_*drFfBk#fQ&leyqz*2d@f?BV5&u04Yn{lN|uQ3N>m*6=fbu=`$4I{Q2} zAIdcXNLAk3Tk4I7O=w4lBGOi!e+qi;yZi4cA8TE*pKidjv9T#-d=9H9P13#e$o{sk z-O){(5QpMEP){NL5# z%i|h@)ea_o>5|EGGJa=L3{oDqeZ*8Xsou>n+%Dp!9mg;$=jVK|`zYAw`>u!o8)7Us zu3B>W+*aTR-(Zn0Ea96h*8<&$kF>~r3Pp2eq>vn~k8%%krpLzi!+zuVqbrvsFNxpe zE7l%tP1D6MiLW@#Z{NGu0kUn48Q`;;nwr~PDASKCdbYcySyNx{(hdc8p~B#QX93m^ z-cEkh_%bv^2D@vjys=SQNLZND;=i5$UBAK{YrhfjEVa-h+{cl@qV`j`zzGpKMa7H6 zj54=g|EG%-m5yv|Zt|b(#>cn96s>wX(NNRSm;v>i+5(UqpPsHsqkz@~t{FzZlU5%_ zK*AEPE4PA^THg2K+}xa_vol!|hldoX$TfYt5`Jgi z@ldd07^J!GPo5rcHdEoRBaWNX(jFcjue{Cx@~6n0+El;CV)Tk*G)Uaz%>)tG#l-~_ zjfiMQ>F2I5zAONDr92Y09(i{suN2dQFd`xX_%AX2zuX~uS>H69vFZ1E{FOky`*yij z506l?OhXfK^lwe?P_(-n_E~#a=h?>md=TJ>WUm`8%U?TTAu*BSI__^60nE+z++A`V zyz{y7x9xNT&CQ!P;{X5!1z}1_OV7>D`UA-LoImACBgW-*+ z-9xLJKSxF`b8&HvH+TxuZ|4qyV>q|)`Q_BshsV8NM4EwU>I4;4PL*)17Fs@d@F0Yz zyQKvIPn5hijwM$;=orie1VI%KaD~jQtRiY%mgSX{^12?CgGf+ZQUVT9|0(C|)KtBR z9q?L-{rvpEscC6z3yks5S!Iy%4hOJ{iGaou1dBA;#@Ab>dBjDF_VP2yGq2ZT4h;LJ z>pwnb72V4n8VG##>T;Tl4=pDrXLxkG(7ACr2pXXkXc%q9)c@vz#QM^=U@Ba?KB*rF?E=imp8XM zT#$$Dt~R;}3uNo>Uqujq4!mVxoFYNy$%cW%B_Id_QJO*4w=d6c`xn+e`y>>Fl-IA- z(gr}Q5{HT+ub==d6N8S94#qCLSP%B3x3~A!#!pFTpmLg;M8NG<0G__J1C=K5{d;b- zy*_^Ycx7!ZMB@)kdcwGYO(XFExAJx+SqStX>so7zkdA{lr@Ui`~}*XPof0@n|vVKJv`W+ zCtKcy1^5~iq@GP7A)&s{pCdHLsi?X=q>STtCmOw~d-f#6#V^-R0XqNC&>*E;)C{Z{ z^uI1d03Lvnoc!*FXI*VAg_q&}+L*TWC+VwKg9_ihyIfz2HIN!v4lLJx`fmQMw?UgY zdaJEJJ3B*O(22#+(9#MaxAgU2qu(4$`5e8{m;_ar&%e_8dnC$fU#Fx97#SHQy?OJ6 z+M=(!I}FTvVWik$rfD6hlP$EXshhrg>-rHx5gJ2>C5E-21r!w(-C`nr<>?DkbxT1Z z2*VV3KT3{y0bce)b3p&TxUeA5MGc|_9V!yc?;a8&$EyXIiaUo; z?6`OTer;5&Hvk#KIv^$GunC0N*x0cBL6nKq*kA0WviI`(yV82)$`xQLljGr+u8xDo zp=tSq$Z2Eh#)bztYo&3XOYni@ngWN}md@L{L*x3g>;=(aCI6)x7yywKCQV~w%Q)V%pBp0&<|Br zi+j6J8n|qmDk>^$LGqo#dIE*_2O#-8`(xno1V-VYSC)h3hlf!NBwdjeGO^I}9!jz!^`CpdU~KENhk@7`!0`3fGS`ibA^KPoXhkY_BS1%ZTP z`=fG*hM32eDYif4do&laS!A_gPvp&??0M>fB3olQ z`70m2TUZU3_K$zoyZ1^p&v(Zr(-srJj-p*Nxk%Q`sj1)Cc$lks_-tyqg`F0Lb+tD zY;1x64Y2)Dl}Bg+N0-e`8A2>In?Ue*g!+SUNDu_>g1_R4r!UbDm@z0{n9rX-Uzwf z%`uLdT2&?TSe5Pe-Mb3a_CL{1+u*s24f8H={d#URV1&f^&o80p07qi+(oxsYKqdXc zn*~svkzo4HTW_wbv3fN4oihNFeZ`Sp!-Z=dVlWu$>gu?}#7oat6I>+`)6=7W z59-}`L61i%%IvJE>+cb@N3|e8846dguiJv0%_1N`3gUZkWMt&{VR2p_7UFTZ!vTZ*JUjZk8U&iG)3JY`q)5p7>(Ik~S*uYk0%Du` z(*W+vD-Qy7J-uWNo2O5ECaP?@VUwmnk?mMzt^LRL`GlB3swXcoG4U}x>@8*G(Dx$z z8z)e%A3z;cT1uShQw8mFacL=%N35C5#8>mz$>g)cf&R{ZODZZVzI3SD5RG(;*QBa{ zw$_D|V_;%C&UZ!Av?BtrQ|zarX@sc}w5C6-vhD;ExaLqZMId0K;5!1%eTm_l_px}G zw+R;adtw@)V4>iQT0O`-v|zD%c^$J17eA~j>Ud&-1%D`tUVNF~R^)O}OVBb*=;Ob7 zRe^PI>3oi&*pzkS1TtU!&q0S<`QaT!$@@S@CqZ=r+EJv`Fm?;5t2Ls#2@AWh%oHce z*4EZOHlH17Jfho8{bUE)30>xly&sqZQ#DYZg&#j&lcG*yM&qZzv!V3WigcHZBY^b32;L44+KZL2`dPH;Q&K-ao!9_(} zKwFu1ylZ$?xt`Y^R_BnDk!2MW;20VGguW>w!@wxxjaU%E?im~&<`yyn86KK)SZ*%s z%IfM(6_tX%Nm?qZFtFsa-2O}m2nlhGmF%XaT?q~jo`o_71VIsic2-f5di9WXIAki! zV2L7#ySqCf?R8b_F%f?LSg*%Lb#>2Qtk5|1r3i|+BO^d> z9DIEIgPlbJWG?ls{Y;alQ8bwjCJ~L$#f^=PsgQRtd-sanE@h&2W`G{d{^18LoiXSdyWkA=K7F`@C~T94#00K7v40Y;bZa z9QsEi>njCXiP6SkPj9aUbeQoPr<{?g2o5dqpRLDAUqB^-!BELvyzn-`E9B1o`+4~S z!6!@rox6NC2j40rmT5y8tx4FgG`zGt{*Z+oNP$GKe@ zy4Qhak29enT#@o1{rdGQe9+Y=eJL0ad@7v60qp#Aw3tR-US4sUPz~iqs;>q-8dQM2z zyLY%gKBrtpnNZ2%C${RUzU(EB8EQ~2+pd{9xqr(q+}qpJspkh`-sQ9Z?_Vd_Mk`1j znjcRvsC8!BH`3HB`7*}dOt9qr%qH=aKUQ$|%i1mb8c=<}^sF4&h&r*)*@ZfKYoU?h zKjZ$@7XWu&`j`Bj-AV6XN_hEFDfIj0FK5ZilnD{Z6&LJ1J}0n2eVn$|n8Dr$9syM+ z|8~ZI*0>I9fSf-x#Hi@Iy1J!1|BgOs))&eDI2!G-XkjF2YD$CzUtNm0Q}(@0axAP6 z`T4fCHi2iq?@5?)qEoX97H^K)}|R`lzyW9>U=jIZ8EC>d_x zR#W8`=m%z$R~Ool3y6+{o16Rk(?Nf_~F}VltT~i)(rXTJ-UA9nn%11=4h{Fb1}G?8hN9fQe1` z?#?m)jT^7u%WlCCnYRXFJsr%#fVu&zU1lT1BrhT+CNwMzN4NMv0A#~kfs?{LsDP)K z&Wc7UzJCTGYj$~AuQAXo-=kIfBnlxYWpiprrGEgh|BhU!cJoB}`1rsOQUtZ20$M1G zN##{epqqVfL?)zH3`zGJvfD*pF$=b>a$XQOYxH7DZNfMg* z{$_0jdQP{M5;7lz~A`}YdK<~%(;!DN7#BFl7x zXArvGI-{t-*<~5_gUtoE(hh<-`jih042B~Vz{X-J0dsb4X-Suvt$P!c3cR|yIzy|! zM&_%nK66!%PIgyq9#?{0Y&Mju_T8Rw+vBm#aOO-2WO{j_-?Q&|LpPsYU5xU%KK94Jv-AqHbr;*RN-Mt$EoZ)+6D^3}<-@vrXT* zDcCdeUD{z&c7QWmv?!Bs{Twi90MzbT(3w#+04!ntZ&Cn{1i(#1F&((mXmbR$hdrU| z^Jlzk*RJ6b66U@PhcJrb8-cDZDCmiA`1tv?xkjs@eNFApYIll}NdDu&T-)^hQ>=Xd zJ_Qw@VO*rlPP3)sCJ1MszM;n;a-ifK&GQn6achOKh%~i4GRY|u!*x#QhK1J%?1kmC%>~pb`+hI?B7*uZ3M!AilEoD(jIWeYX2T73<6O7 z3&aH$9}*sePlRyC1ur9Eh;q3=VrT{BwYYL-G_8~i5O^?jf3fx5GaI9Tc8t}OjW^*_ z7vgyyKy2f9zURsR9Z52ZX)_Aw6{^Zfu~19-f|WVZ$N*P`LrQyz8MNjsGww_?(xNS&WWiqmP$Wc76BU9_c*qRFP1W@lV!2|O&)lG<7)A0_{9ajsD0Qj` zSGnbrC*})1@rI_=U>ie-BbTonQw{(&AY3BY&Mw{KAiAwS`tRv^fP5ry_yB?)DX!1Y zfAaQ;9XL>-Wo7&l?i+?Vd&BTju%`(SIS|8~KwgN)4;kv}>A{5(u)rrHYB!;nK7|Iy z?j^zY)SH|omdmx81S?}3RMhzCHS0iN9N;2R_?J7JL-$tzUHkW#*I?Go^6F|FChrqr z2>TQk#;L)A)Ug20#lplSmu=Nia^FP1&V7>@LCtjtM}kqKGru(8L%1zffW{4q)UZ101H9lkY_)xwSA1MBBH)QNCwZ1{M1m)>*#Km&5q)5Z(`-h!`_M|koTwRPpj|Jtn% z<(X^m{~_?-S-$%X4u~m+g3w~{JDmwsKQ!-(kWx~H!krJs(yP^k~d!mEfGHAuLDDT9lYS5(}5c}=q;LzIh4{m}u4Q!|h0 z0p8%hAYV>Nk@gY=G)#m*7W?`iTfhTxk@to&n}F!S>JfC9mMRSs1fvMH!v#_qhkqb< z+&a;MutD2>@t1$|#15%U5AmBU8(9{cujDfU)zK+H&(1->=9(xRGj8B&{poa+E@MCwufNVd1z`&0w_j^$~&) zOJ*~%J>Tu(&H-%rX_$sw5}Z%eNq}8WdBYcWm?7S&0Z68BY!0GPA%GE}b}P{6w*ot; zIXh#&mBO?gWd^C0$no(97cXAS0v#RI*xdECp-E3QdI767^aq{y8oY9^60Y=gsz&ha zbl(Klodqa_mGhm7(qKNRkAQ>>Au`INVW{bpj~++yGrFz}Vu0#|i3Ep*Y5bK+c~v?) zxt<~AdBMVBp0+j}a4{H{lCUDS0fQBK*QZ}E8Zm@par_^gl>iZd(DLOpJ0d(BcVS`S z@^QT!(`?gnGx7H1CYz?7K)U!EEd@mg#CCuHGKq-X&;AQ&AkUtJIdN{%WfWv~SbS{Q zdnW|`fdS$7ct}V{kT%O@2+zE$n7m=yf*^8+hF6|Nvc72j+1iR>(H)}%TBXt()2U`Z zMqrLXFJF=aP~_V?2_>Qng>+%Olbf5{!O5ZUz9ktA&F9lkk3N$@oRSn`b?tyG1VR52 z7Z(rrwv29tItFBc>$*{n@{1Z*zmshofP5GTNQ<2iI3&cu36o!|@z^#;8ypVtl@`EK z>Ob=XSHW)~l9a4xsoy+to5U?Fp5^1_jv{B*k^>{P*yVa=ZdnvtUay}Qe*FT7i31@e$mu!Fd>VQ=3uqeebz>UM-*s&Sgf1`99-Z1`W$u^%*f-#~#Qg8G>d z54h9p>w~mFW&nL!9+Rdkpihn0y0Bls#004eg<+cbws&`OP_zdrrk0VBSG{5I zo?lRD#a&lOp+TysNO9^p&Qw_7Jl|XA9CZbNt^mohxVSjf|6+zCVKx(rU)VW0@jx8L z**fKFqhN;!CJBR73rMB$X=#MW;K+#LSgFxB5Uq7KS5(z+-o$_&(U!=qH#0NiVF^8G@3>LWDDpS z3$dN3!~+o+P-s_c5Do-#!%>-0U!MjmKPRGAu9L|>dqBE4a=a1S3GKcbo)gA_&ZdUtnjWy%6L*I7t}` zWz@y*0>DhrWpZ=UU#XoDr~=3f2eU0gnjYLGNKDj5nHK#qbP5a%j59GR0_Ha3;|VH~ zmX;Re6Z~Uhh?S$M1Awer0HhnQd&Ug_3=%CaPpz%ny1KAo<8bU-j5_dN#`t|%?RTIT zOdJ~ghZGJBT*S#u^zaahvS7JYSPn1{f`kL|2et4MLc|op8!I!-vcBi1?x@Mf|tHq*UyfCw|K}l(His+3SG*tY?9gvjX z22h7@5OyM&3c6bh6pj^yH0a()5+oC$=x`e?EiDBOEW`e!g>`^RG%$O(Fi5CE{HPAn z*K#T zETWmk#H!mI65|w}|r3}ocw%wTFk!AGgIP*qweAc?Y%I%OjueDtRJW@`QjZV}YhZfqhyt@s{jD>q!pbNG>lP(scyy_zO4Yc4} z<0Io>R_sqZ>Fh;8;*S?n>3~zt>Z`QR54NwOK42A@^@CIpsHy}$ydb;$II6Uz`nMat zn+JgbHtZSVPoF+fe3Ai{8XghRiVi$_9w*>7exbbp2)#H0pQFOg4hQ_+oM$lX;_&aE{1wuXrS zSkJaloe1<&sdt(!%)D+zhKBhke2xzeTKfBm;GPU6?ID57V^~89(T!G63{Byr z;gD!UuGt&T99KcgM(+y%)MabN42Y=${*pH` zqPP5-)(Yk44$QM*llSZTy8izDPPCpl&dDQf$@bt{&jSQk)znmib%@pjwD7_o!!rm@ zh1fWll#76jgaIe99FP85o%|a!f!`t!0{4J6M<`d64`(2>+0xsqk^4uA`M%v!-)nTR z;g})lcp*Th2Ddpex~O6BZ?EXOKbA_EDmTM~Q;mcm1I`DmrhM1O;;oD%ruW3!NJ`ed z^FRmdSQQpa$j6T^Zdj_UIHex8b0l9;#P)*PS2!(}K zZ$HhkRlS50A6>sXqb|X;fNV1lvJcBVs0J12Nr%6Ob{$dHjMJbujZaK~^g@rSCm5>#$Nu^6Zdu=yh2z2m^WcmWbi#0W5Me24`c93MxeH7Hf(kbt`D z=7zR3R3L|;cbqgCIfBQ&&+3O8kNtvHgv^Sv8uFQ6F5|&c!$vbM*JaLQ=JrR5?sIR% z1Tc{tEb6d0M|m!!vmG2MC^gHAHV-6t8+@{TYq>c@Iz{lwa-f-a->%*Pf@>Q@_pm0N z2H@^snNy3}K7c3At9l6`YD3}j6RVx>Z4W7GT3Sl=%;eUaEA;GOz+A=vwhbsM$k*G0Hhvv63T0)0TFQmHTKkX}h zc9_qYsVtfOblGqQXohq1@<1x76?%GPqaLOyVl#r>q_eX#LTc$fKAJSLkHYcpYrWZ= zJyVjQ&s4+B!EtXz!rO}((qQMaUlO@p{a-oO7YqSNs{k`deje)r24vwu?oR@^CREBX zbGG-#TjPyx+Tr4WFgts}t;v+MG(+n*um!qKlAkpy^amN$LK?bCft6luBiGZ)lF0TfP6MD3f~h&dKVN!;JCUUXxF@`fvYi z!odl8rp|XG6FX82Wj*${cQg9|BsuC?vPqX6?o~T1bFY5P$R67DXb^gK(l)=1YA)7q zvL)&`OLkLF{_)uPa3ASYF;nE3b`HS-g2DM5or^d)E2 z2Ep{Ta2aK9`tzy;10}KH zi@J$7Fs!}ajloIgUp?_xr6|^ST?NrAbS zW$hK_T*@FXI5q&lb7oZ(oY^ga*R*9+jEu2Ro$tS2eymB>+jH%EAx~?}x|q(7pua}f z7MT}(zzvL@BK>S{Z{IU8P!P)5-rKttRIJyV#CwUB79V6Qh|lQ=9&M`LTzPrn(Lyq7 zt<~hGKL(5gfNwJ3Hx+=~I)t&?6nG3gAQqU1^X_Bv(UFC!$mxa6rsGoOH8@pz1rSUy zXm+&>g^{C~(0&0Byf2P|U;}FF+t=}cZ-X8<0LJAUVf$!|M%0!X4pJ?UO_A;h9z$*P zJbwc~MyKiUKhFoS+r72GB_C7-J3CtAfBN((!cj}VS>AlzN)u8%(?_D*^%4cfyZ9rz z1C3y%y-62$3KZ;0frt_voP&~tSOQ2wG#@{FF!$P9Hv>p(31H3w(B)%*_~sB^>w_IY zarrXjTwL7Tp1_Hi$B^Z+1e2?8V&VfzX%3mSJfeAuS z#uXgI+s9|_&mW>LYW{tA)CY~vpS=)PhBOK4wJ!1NbN(TsrU&hO6)Fd`3mS z0XSUK4i4D#p|(3?6wJbXo7(+!?kts9h8pifArQLzm+>wJx;rl#>z5vZ76)}9j5uxI z$$$Yt2?q#^sDB$C6&3V=Cp07k3*4Sq@aAsvQ1-Gt0#QF+$kN5a0&L zA@HUQMEQ=;6|0?8V1mCul5(ydFfueWg^V9iPk}w&MohSq(E0G;!&l`Yaj}Nr+)jM5i-H@zz;Rdz zx~0p?P@YEZ<4$wZ>v*~9jxOU~M0p6@LU z0av%Rw!Uo(X0PIvm1S&gZG{7vQZf*21JXf=o~O!Hdsz4wTqzg$uqLPc90Av-MI-4pDDy9@Fi~*a^j5# z8b9QDZszlUmG|9IImZ9rcSR*7N{S>6v!N7G8rs@4r6G42X)C2^741Spdm!y04QWRd z+Jn+gG__f#`?-aME z^#a48gQLmMO+FOY&7F97>XZg!xVj3JJ1`;4bp7dE3ssU`kxZ*IY?j#@CdXZ|@ z)zVB>i9xhEbYlj7G8Txe2wcWtmi>g~LtvlYau!g7GRl0;$-$1cY##gw)?fCz ziH|HqA#x;W?`cXzu#iGlmVEBJ383k#MB@925PR1g%e1z z-aUPXVeGM8^EpoPk5oB>UnRcEqyU@rpfM4Krt)IT;u*k#kDv^k3A#lLphQdpQd)f0 zJb8BfyND6&{G=g8CjOf!DzF2c(3H?1z5LNll)zw3yaAFDu4CwmiJq1)c{@*}Q~~sbMaHB8X^_v7f=2rEvZFVI3WvJ{Za& z+N(yR0J%&N^0@$vQE+f@5X=U5C@tRP6l#^L4RL`mX9DNk2`!K!#uX|A!aR%}psJ>3 z6KQb<Eec zBk8HBm5q%#h9j*&GY7HqKYsl9E{ftqPHL-@UK=n1aEB`YJ%3ICoAj#5vcc*|cK6E{ zaywlCxnXji(SMIJj*zQB5HVe82C;U|^(Jm8J(5wT5p0g>I$BjMO%=en`$tAYsp&vQ~yQ>(#n z$;CsC5qI*F{>II5N{N3L8I+a70~DpHGYbo~gd2Oqq(`4UzRhjzCZhlg#cJ*E#9W(m zb`}9=!} zI&dX7a#9<_%94WKOZ{{em49ZgoRuDJX}WBu?Di8NI@-i50MXx5`8wu=Lq1u@u#Jbw zcai-g+aT3jWiL5qU-`=c(-ha!_LwU+kwh$LazZ^5An_metPV9cxeax$%GeT^Gs0?s zLU!`ncX6!5vujra!q`t;1D0&NW-kBf(Lv~KFrkLMylj#JZWy2FEi#f*=c448OUN{I zn2V2(4+d3L-WEDS)MTihXUn78S^8UFjMCh`827+wXnAYQDSJu`^{^~5>|v0$k`6fU zl72~VO+i6{#IGZyzG&OBL`D^c(vI$#E4c=L^$JjfX&sigw-?3|mtGo|w1kQ{2-*&~ zHU1MgAVd7qvu7CF`*-;-6}%Wz9pl>NKU}sY+}I>MU+p{Tn6as0mR0P|woA8*^STZW zX}`t8grkT=dgd+DxsxhCHG8$aj?ptDc$(tn^9e{BO#f zAI(;A4`(YaILISh!do8)g6wZ^IWm{n^^3j%`VdBpT~By?-6vOY#!4xbw~m5B2&Ff^Qr z-+dx%^C_wGoE!nYtE!)SLznDMX)Rlr!{Y8Bees#Djt*fBule|q@K``=IV7#=nei=N zI+!RHNyO>_e7^b7OP_V-hT<0DgCh|r@|mjS$#%OxiAx#Hu`N(rqQqm3NBmmVJ2P{6+T(M9O%>3sxhO(KCDsYO95HA+Uv z;p{zotXYd?I|#Bgm_%0l>u06IJ}36>rSWbC3yS&REPwHh^>q_1Es~qt%ARYY<*p& z8KCNRPEMP(ns*QaJI-O@(C5#6IXxHenZ8AF86$O=)71{v7aB$tz~Y@q?kN7_hh>2d zcwcz522@T!7=~QqJ6h4OH)2-OnPzMJ?4ka?#uxo5ImseDjh##nlX+WQ_H}lAYL??# z-h{sH&zmL2pC1XJ3)Cd0S^Hd%2hD|&a7zR8i^~THZVZmAqhjLG+yE^@ReiKIwI54v zbK+upAN@{aER8FoGAk{er~zj*s?p#R{`k2j4rah5LraUXv9V2{jFuDLzcL)t>d3QD z1@KOSX1EGe6QPnJQUw|sf;EqUs6+*~h(;(hGV+t#UEGnKQc_az{qKv9lW-P<6p5s+ zu8y4>trj($1^?NQP&k1QCiYl~B3D-@Fka z@)S_#?1y$8-jMCS@_6P7D7%Z7(3xBgNCcN@P-w%^t4NT3aOq*`xQsoNU?_pfb z`K5V&Wumax<)@RQqa7?mxGThcCB6c*2X~^O5DV@wUS?xln*0N7!mIU`uC(4b_n_P;_Y4_NDZ>t3Kj@ajO+Q%hX#$OsXq(_LgQXA_U$ zmwxbNXb%V-5L7ai&9te-{fr6+|!u!1us_X_B}y2a&Oq16iQMEMDoyCFgS) zw6#MQL?N{x@26WdrMUzJw=FF#5eYcBf%<>f!ZO{k-Ji7W2|#g-_{zCR40Hl?iT)ZX z{GcOtRg8s|wVp#sl0Ch>XF`P{hx|hD$DM;*2MUKmMbKPfWE@qpe`;u+I`@sr?Q>hn zLC?}>5AxqXasAtwo7~(d1@|~`8yb)VXAve!c*F1Bz3VXYl2P5rD5kq*tMuAG=FRhB zlHYFLltY23ZGg@$@Cs5PJxnG`r8Vf>xtp6HV5_nPB=;pat7=bgU0 z>gg&fjOps7RW8HEXE6 zAEQY~M1+rF-apXgVDS$vUWzDJ-Wk4uQOhJgSyUjcy4j`Vh535!e~UcNH$0G2fO}Qc z>}1Y7PU|fTgqw`!!=aw{;K2d(4Zw@=Zt0@uzm3&3G}MAT`ods&jAzg`;#SUYgU>8E%Dh#!S={8^Ug9e(D%<6_QbigFQy-7pyU zh$%uciVjE?^B0-kTlDoi97-p_oD#Nt^sj$1TQ7-U=s`o1&Kj_Z68?#4DXO8bTAtdn z%9-h4X!o43tchopp36_ryDvemm}f6u?05N-IRVc3GGr@s5fKvsCug^QHDnw=aF+3R zx6JO^eG!hNXCCf3$I+cDT3PWE*=G=9pM5~xKbBqo5%8)D<-Uu6jF1ri6M~C&v2VjD zK^7{?b_k4VC)6HG!m+q=z93vbWv;3Pjur z)nB!-dEP1Mv$ zxDe7^Ks&&E9!zR;=u(V#y(SycIIWAwnVE4B%(|&*Z%0--s#`Fi(9h~QY(BE-c2Jr> z3Zh0m78x|Pw&Iq3Rj5y&F6BX3l^86(w2g?lTUt<2|B)+t^etNpV;J?%!UH8CT#IL= zzyl<8h4Vg?67*R83NaMKhhghwd<+33yVC_z)u(QBBoOG}7JL>plEaFZf+kw+Z8apv z_on(w`-~3UyCvDP5-;onLE06tpV_+Q&^b)WOQ&&DQ0|=*N^)8{v~|yQf4kL79&x*n zOA#gBOi0<>$6-b0aX!vi6!BcQ%ijet+J-XoKTDr(K2NnO-xQK|t;i>Xw*VPcla(A)p6vE#7h zTE}^o%h__qaV;j?p~N~)OH2E@sQ@tZqP7qvsYlLnN_WDJN!AfMJD^>QMNWkj?z8p72Psh zWH)pC*;+#{y!*--7u^6i-w#Fc1`q3V6_h`vo!aaG@|qyxkO1@2P`_fwjvWZiXYjJp zR8_buAm_wl;#>CSMaO&&40y{DlXakn4r*UyXz&Zv&7m-NmuhLGPG0FasdS~kg`gpfP zJV)R1QuSdYM%kgv85De=C?zF@up=&xziEK`Pb1UR8*>zi?=L*7 ziz7WxQIQ(Ku^E-z4wTwyo6zogOB#?5H9Z^2%WI=!^tC-C*!VtI7N`1gro*|+lTRGG zNIjqDE$SnFenfEJ&TZ$G1b=WJIN*J#R7)o%?OEp7ic9%X%k0rbfVuVn`o($PD*^pO z?mrg_@P~jXlVGE4Gi-q15H67lM(NeNV2ycsdH2IUhWeZhrUmxRw-bg=FK(<&dI3T9 zH@f(NY5$bxKI*?JXSIXn)udzYJz$(&n*D8?r1hn5N4NlMr?)H@auZD_j(aZuIV9Ei zr8O(6ZQD30A^BjltT?chfvy~3;|J(u&?Jdw=KAG>P-qiBJ^Qz zSH!kww;&FeS5j(uG(awLD9p{R1n6>yCJgZxs7{F?2t6TS_A_9YLjV|nSm6>C-KicW zS_x4bQ4JF023ijy!;7%DKyN?cNdE|+`1(URlWQ42Uhee z_(X79lIVB>aI*;QK9I+ls(B4{b#It32{GdEus5KEam*pS13)L#kOIF?cQLBL)Qxb4 z00;p0y#|Vskeo~fo&(_tY-s7;>cs=8HN%QP)YbAA?6=$ANO<@+P={a?tOK7l7L*-l ze8v(gw4Xbb%}a5JTpMUqtl>z?0X1P6e1A6!%Vtn6=nh^V*<#mQ9M?^ItBu9(7-KK> zOMSN`Q>)R-?X1}wo<*y%6!ABUNhCPzpa$`m+LWEz{-hJ+A~#R+P`D~KOwXlZR%nWo zL3$BUAc$lLB$n2>(KcAuxCzAxN{z=Ku7Fb{;y(!46ft(tI+T^6!a*mM3-N9Mhr}+J z5V!k((9-6cnBtZ=hU^POEg%h#f}5Kgr6CoulA=@p)dJCnkeFC4p|>QHAE1$i6J
1M)tdcryQ+e*m6Z-dy)P%X8_=oChtsAQD-(G>E6%?y4 z(QMv4eT>tzP~R&PIeqiit@Z~BXnP`Vr5P1ClUcru&tEmoUl!9Jt~3_EvVW<hb&D>DiQ6jJ>%2GtZjOSdo91{*tGzuF}WI?%e%u4{o4-1J8IjDryf%iK>WH z4L8+WT_PWc>e`!|U9;CVf2#d}R2~4|N?<|ZjhzCVkc90o%p~lPx$lmB+K;hjPnSm* zcY2l%^;SMwD%zv}LMSKt`Evrj$3X(>fuo0_4cikZqUUT4*K|4D&C)ImJ8T{hE8oJu z;$i~b6vuVWYU?|Hw!DR=%{2AMp6l`|%TeRUEh6;urO5QaqlrNZG7zezr859B77 zKnN8$h7%zx1nGuTPo!X{BS;R+HZ&(?J!3W{d28qM%Pr208Q#{4toxx*Aecv0idm0W zc%M~kN)XB$*2~Wtzg;J&tsAXd7!<~Fh($nK*RA7)m2BD=fG2_|A<#=ae;$N*HFque zJ(lN2BQ-$4gpl9zab%neMRD*tHT5iasEn!H<7-<-%k8g~FY*hEuZ2I%prnRm0IJcm z`uePdrXA+Ba=w+HBYPH?(#0EfJWCmDO5*%adxbq4{%>&f?40nX1x5yP0OMsY33Xa7 zTRDW30S3TfD1W(*9;Jhc9k%MTAWlpbwY8aHTD^C-np@Jgu$ zlyzO08t5&fZri;UL^ymxHXfpo!+d}8`eQ~Gt@B8$+u(8M-ntL@atHKVVPXhb`M!fh zEPRM3`@D9BnxsDF*Z5Uuv$5K z8`Bz}pzu2&V;J}FTF=ubx1Yc;B2XHNa!0&X_#?4yt#_#@{I{;iVHTR*EW5}mF-QVG zXdlqi2~I0u=im@naD}uIp~WVd);dGR<9u905FIy;XEFOBbe0rKWuV$(wnr3C~ z#`TdUx)O8BlG0KS@8A@t$sP^>J2-=c2~x)g$Ok)YBq*SH|Jsc!HRg}&H_t;2xu2gu zfO4hQaTtGhgu;>szz!iquq#GSb_E~fzPAtiX);CzQ6&&iIA>VewmjoBh7Kbsn?OUc;^OlO1Pl`I>H1^k@PEHZ`bQT$=Ah+ z!?{X7;lLT5a#vQ;Z}KZY&#yX7JqBCmL>093clGH8vH5;ylILX^RCM2wRm;L%Su`Qs2966mfe zVr5vdy?j8`h5gSTka7almqhwD_$MO6!*Q&g0ed8P#E~r*u`5siZsLiH+)T1%6cZD} zI};yA*ozPdgZ&mkwA4f&0a)owZUBT98gXYXT2QjzVB)}>fp}|b=&T=8Nn})1bISb? zO&M^%gmndq!45$=cw?W-zf>U|v{&$+rRzX9Yb0c2Jx5YCvP= zfvTMZI{mA!uL8vBb3o3~;!a0Pz@-zK8~rS!(5?{_EpITfb8#c{F!{o}4uS1mFLbD+~U3D*TowNK;?y=62CNEPi zTAep|l5fx-gd=b(a4|IPExi-@W57KG%V9~U!LKud4!829eDoTeBm=X1FX4V zDXo9PkA<2C&?it7hb>m?>npa!Lqgbo5HV8)+KDKpA;lqlgLEC|TW^DPibtVK$Y+S6 zfY7j`7$=4(NUfof5jpG%@Es5?CNMERz?IAF1wCgtO9UF&c!VRDbvX}aboV&3HwK6+yB>@1MUeATQ?#9 z{=a`D*7E=PhyPng5d43B0>l5aU;hNo!TO($*7!dT-T1F_HbNMqnV>kv%Re1r>9*}o zP~4BdOC2DB82#i&9>d$=cYo-(-ym*&djY@z3zP?~4~MXT0`7EXM;g-ub_C zi;E+N1qCk@+1T6f7#NHXi`M%mPU1cIale?@O5kX8$aZ5hkE0iwqzlL zYMgu=6vV%<9Ce}vK=W(6p8)|oGYsd9i*G1oQ{9c|SSWHn7PC=$xpHdHB!UONK)I(9 z*q(Zwv#x#8X;gc+g7v`o8QSQR0vYo&exrKd9hz_Vly*@eTfMTkckFFf%E7AY;K8=^ z&cgQFI9IPal&9p*^AmS$kEZ!29q;)knLS$S!aDJLsPzHOP<}q|L!ZAR8~VeeZQ7^o zE{kkP<1{|)l=(`W%v5$e)_KD4(YdFtx{Iz(V~U@mf4r^dsP;J#QNo4;wKT0dg;=w) z=4t7c!E%*UefY5L5#waV>Qc4P&2WZodpr5{gPtU%t1vQNgJh3lZY;X$`f zOjQua&Fvf<$gX7PmX>CfUN71@IvPb-C3Rfxtlj^lUNgPF0y13fec^LGJ z+_`hR$sbP*MwnhrA}gtabQ-MXjNQMJPS|Tb8&+NxZXVl26G>(Wj$p-!H7IW0vb?Nl zkaJnvn;|JHYqPbrG5T|4SX#oSpkQW3VPvdISv@n{n_w#K_8TW~iaJWi#B@U@F1J@a zpO70V1&#N&9MYuTkADdWWal|PvrC@)ym!}$lQ#7DS|}2dy}W2(qupHXqyDkLIz1sN z$;WeT9NFDY?h8MU7tei*-(ZI0q3X-H2naqH{%nZ5{N%|1%q0|XrmU}VB)oVL(AcHGKY36Hjkph#!x z?k-5ecV1j^>;Lgq1Pu9u`1nIOHL|h1oC?g;G1F0m3JQr@-DMa11~VG_-@k8I1dnBE zZme%Z`US5Kz5V@Md-8S5_Rw@^3ut;DeT&T$x~|1@{l=ex-%XOlDS5W#91&f|4jmFB zRitX4ExI+rg#T6bQdMbs=(F*^KO&TjoF;OLifP@#_6s(rWaSnx;H$n~UJS}M*djHd`y-cnqA5xN2{o1b(zu=3hvTWKI`{8dn8!#O9h^#02iQDPt( zzcUzYO1?zPC`}<*x{L#CAKS|5caW|%`1CE>OXK)NZ`(3^1%O6brqcdp9!iP&*=HSC z)gNuMmcsy{rw@Q(%Ms^+a(w)#-uS|I^RKU6GNFN&s~&pOZd-q_vDRU_QJrv>S<4_Y zc%n<6M?{1{(zUbd+h6w8DyO8xnU-ehUK+BU6OUzf>6pnG*<{6E?(1QEhnlkECH1np8MgXs z2%WGF3gdI;!cgh`2;7G;Sy8<Dnc>ak;c-`Db=Xc~5uIG2!z>x@bJ#RQD6_LiA0 zz4s$FhldZZt3~E)=i-ubSwBO0`t(I*4NqT_QtHaD*8F=pV(T+U`uhXSst;DzUOSMj zi934rt6^YL5~WF8zTlrfpNH#0GT%7<%+J>c$RulKCUw##=23&xSY16NTvB)~L!#Cu zU->V+(ioGZibT1tkeHZ?LV-(Vt^L(qp}5+Cfh$-B5~_yLSqtC#)j+#t8g#_uqu_>M z;))P=b{d*nbQ2t^tgOf4|NAFTQDiwpAG?rgr8H?{uBt`#4rYwUDc15;$Ina*eXGOHfP< zKk`vYQBh8frEWK#TLg#o^-05XL@iOW}PkoLu{wyA-C? z-R~vy-iW|Ic$J?03fsBS;VUZ zzrDFO-KL*>hoi(XH@r(x`IBBzQO3qXP`fyKOr%z_`}*brJ9Aj!7dR#%K_w_S)<3zy zj%h-SxyQ7wR=&@G^lxWf*crIz?Oh+AlNp&x_@MObt)KSB#bw#qPXiPi6uMHQ8IF`7ul*KcvWRX!_$VzCNgQ; zzHT2Xnv-(;f{K`+^Ajt&HtbHLzo(ztw7kkhNM!&N%EY36#>H-;_vwA9_ROs{F{j6d zMmg}%iRA?<*Zn*F_A?#%ytWG|B)tEA3nOwt9P1Q}C4YZf_y0P%i!}7=Wj#9fnLBxB zBw5MxR+oyqDr6IB1B4@^3UDTHFdVmvC`ORT4@KK--|(Cy_RpE&j;uN8L`2XM%bReL zfZc`jX&SN~v9%RL*B5Kiv6`UpNb(_Y%#Tuo%KVNhjwWxG&KkLvC< zReU#*H>}Eg#i(eCwZM97^(%ERo>MM2U)HnlIe9m%O^e^?6y?d2LGGU4hmX2ydU)uY zeT%tg@V=9sM^Wvb0ly-4r{Q^jVQTD<$I74ew)?U4CS7Z|hsQP?wB`HB(Dw3k%v-Ix zPjMnD%wfXHT9Qdn@HWmmbt_&wa#6pkO9z)FCH1oKkwrbfTLuh(eamxiT$YY2+PGPC zhzJS&nhfoJw9xBtlutkH-J~!%qsk-HTJujnWT)0wE?=gnq8fCVczxJzi#Inmd8*6A zYL%|92}i?hk?Wl3HqM?PRBcGnrY&{-o|v$o(QBhLn&wk>d0g#=zC6Yl&^(M|h*D%` ze_3;FrzO^1?5@GngRBXvtT)#o0N>SFwssAKku2|pf!VTUOHm`Eal7$ODHEK$T3ByQ zoYidS9B=Hvu5)g8fH1f=Y9c`b+ZD$D?Fk1OD5_munYw>oBR3{&A?{4srjU&SkCl_$ zDB%ziUx_VcYH7q{v3R3qix)^gX6;w*zO2Xgktcf?04p6vpG?b_Zsssdn`O)=DPex~ z70%IV0#MF`s|l#$Tms^YIf2Y+T>zfm*;~D3m3dzt+VN*~V1T$SXAkd8EGnXvP1O3k z_5QyFR~D8N#ZT2uOtv9+tLJrP&A=5;hX~~w_maF>76BfKY;iX7c7Oj3N&7H5l#Em~ zK_k-SPhJwt5jP+CnH;;M;WT#W5;d8g$=Bej=>e=%!=pw|XZS9eG_AMgcl*^HkdM3M|aW@Ll( zZPD_9TlZgdpUxJy_>`ru>p>g(_Uc#1q9PX=V`Jt3VKms`{#*gVJFx($t0xciX?#lI z#)`6MkKqYAp|^pA$4j&|HF=>jg0Cx%Q?83?=E!4zH#%nKHywr%|LKZne3zuDZhoV` To-(XP!mo1*8uD4Pm+${CYnMJd diff --git a/docs/website/images/calao-logo.png b/docs/website/images/calao-logo.png deleted file mode 100644 index c01ecf675282e86e736a7ee3c24886727946e156..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15386 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 Ef*adUIsgCw diff --git a/docs/website/images/circuitco-logo.png b/docs/website/images/circuitco-logo.png deleted file mode 100644 index 8b315da4d8ff1b1fa373f5675d45599df446c321..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10750 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 - - \ No newline at end of file diff --git a/docs/website/images/email.png b/docs/website/images/email.png deleted file mode 100644 index 367dadc7f13ec85ef6e89085b38bb480332741ea..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4101 zcmaKvc|4Ts`^Rs?L1e3AP0=(*w(Q#>M`Rg%ktL*&$rh7n>_=sWvJVPF2t{*nWH-q& zObJ;hGWM;6W7iq7jOF|2yuQEXkKgZ^*UU5bbuaJhzCPFUyskU$ilqq;mlziSfX5VR zXafKX^p^#2vO_nNe~~A2V|O(-F$9N4pXZdqRLFAdF7jFcG-K%K%VHp%9SRva0!=N9 zIHtIc^Xmu`axmQh@THg<>f42mu1xeKqa2*tzs-*al=xDbgRf3t9I{Qld|X?TOpVwrjrX z;4t(+SAP8a@Y%SMF}kzjJoB2=%IesBE>nl5OP?1Pfc*KtFC}iwq~b>rTS0-C>rp?Y z$&$Wv;yWb13kvK+#NKx>EQ>`xjFCt<1A|vxfFJ$>Ka_{#O4CN+;NY<3kOThrJly6b z4IOtn_CuaD=^!3#&$b-4!~YiE;Bow#oMxj}^BW*2E5?4H86wQ{@J0p#bIX`eY zYnf7t6}caB&CmF3#(pFKo`gqOokx^*8kq6jvBO2b9#1vv4l{H@;~G zod0tg8^G7qT*-rZnG99=&Y3X$bwx|BHL}8{yE_F<$Z{lu>@oIrE`SH%68LY}e;oYB z{J&fO<&pU%i`}R-%GTr>PfW{H-W*>!9Yd;}3|qQ4&OW?Yko?Q`uC{IKPR*BlYVzl;5B@%M!!e?y%oQH^S6_%2vPCF~*ZFvL)*se}ebcDA)s zi@dbE-vkZpnDuvI2DKXK$49{^oZQ|Q&vdo5MT?7f)2c*6ZYUruY)3{$o}d)Y(=k`Y zV1lHP^7LSBN1I z$82rog-+5KsCvcRcC-?5^})BOlSX|u;a_Xg_+pifd15YW#^=YSi?X^1wO5YU2bl*4 z2dCFFG~)<5@)uu*5ue)hU4K&Prq%}nIn5nW!b^3Y~k-=yPB`(wBhirCYQ zMcAr>4s(N4_t>a$?D2MA(0g}vBZ5aFecn!OZi#Fj!>1zik%*+sQ;yTt&A7u{L&7c_ zHK3PAgtQs{3?V4yu57&D(&wcle!R0yq*D_%T_=-@Aflwsk)1418B*B}R^spU9Z!N! zf<{j^m=9!#W;U{wGT#~#cNt+DLM#>Tr|;l!hu^Yb>7q1xk(C=ixOI*b_WSyDgq^G) zWcvsgrx*cwta?Rl?fIE+PcdkAmPTn4KLH>V*cRTbNHjD0d*>pLf2YvOUl(9hn0Hp^ z>T20C5Bo!xJ*n*B(E@yq>$1f=o$jeIcgxt*H5j$zGV1uY{#VWu{|l zGh-RT0v~Oa7akYG5&(6kE&|HjeqVS}LFTDY%z$RY*x15f=noAiSSpqSSSy2xa%7B! zinzOMLqmiA5^k+XIzDv!7|?l--5YoZKUETOK4~)lGCv3wZkNgV#-bn3JnK6OH_0@J=>buScq=ceB&wL^zw0^PKvwST9#cg_+PDLv{ z?(V4hX4F^27SwWrXREA2F%d<-qCC5g(7m!8DTZI%<+XK~ z9&Ja8p*4~xTRhrE1#@zG*mQoZQmGc#N=W^P4fHYWb#I#xapR3{*{4vPlP2LniCN5& zYLTLKUHa#jHpR~t$Ekg1#p91a-I;w}2z`EJseS5lnhUqqQIKKCl&{56MxTn5YZ zmzK(zWRm^8CJU2)EMfkipx5>NSGcYt@6wCJLe(^tI#k?_SQYO1(kUGKO#;^XvMJ0z z%az;S-_sfE*k1ow(8>wqPr0SVc6ggW8In7iyZ0AAucn3VE-MS3)ElApLVNh8l17e7Ci!Z(rJB}g_uT#RyPknsL*7)NK3s@UYo{2!~^Oh{b^>?z*3Od zLx3+m`F~ig`lhNRk1n9G*(}j~O z!8ryIpPHfm68n-4vyux*mmS~$P4a0YCasw(Nl`+1HUk zD5{i2A8i9b^&KI|HLWH4@9aGteCkRxI*E?>IV&;xrMGN$c6JTBAnzk!1876s39Vmto~Z^96$%Cf5ecB*da>1g$XCXAN}ydju?1J^d|ur zctkD0T)J)X5Ryrq6LMn!qyCRDSD=g?TB_`R3h+JpAD1>?q7+VoK#pN)NS2H)|JCtd zOG;Q^z+Sb@(HRo?xft?9v7K!HN^t2Iv=Q(%ql-Yx(YZxeaf5+v8}%#YL!_~l6VPIG z>gZ_JSN~sOpn@#srIBq;ffyjynn#}T$2m5jbW^>8ke$R2B}(pap!>59_Y=@aRZjm> z``Zmyq*3Pq&>>^Uqf0rK^KPU81s33lyuBa2#wduRRg1OPsVPIW5ido%8%p?AgXCuo2~JEJk={#0{LkEb91kN(}x&dzdm zvBWJS1Ofo&n>y6$=;GpH^isXv5#QOXc5J?czQ{ByhPJw#DkqdMq@B~tGZduB38)51 zGmYcEwK{an<^uuKV}SbGj%#IT&({9ofD=w1fM9#p@?h;8|2ovcV`#RWLPnQgh;|Mx zM120tKf77+t<9Drn(4s-;1+fJlV~>EV_C?k91OeX3!`GiTUJezd3em$&uGz{Joi%LN(gQ!d_!H`@8*W}4H?zHydm>Hk%Zfmx4rOw>1w2|eCoUSF>;N(l-8TpHfYTy0ouYv0{EzyCI5ZIbc~(XmCeY5oPS7>}I)y-5P^HezG8KQ6+koYBI~ kGY^8Yp!3rIcR7MX4pat%FT;5H#nCuZBTK_F19arS0T-}iZ2$lO diff --git a/docs/website/images/fluendo-logo.png b/docs/website/images/fluendo-logo.png deleted file mode 100644 index b4d02cb668cc4e17d667fba42419747ff9284a63..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9098 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 XT%7x#fXc-ti804-ZR(j}>veKt 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
-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 diff --git a/docs/website/images/gift.png b/docs/website/images/gift.png deleted file mode 100644 index f527f82837ea6b14e38e54f0b6224b70e9faf8e9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15906 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 ADF6Tf diff --git a/docs/website/images/google-logo.png b/docs/website/images/google-logo.png deleted file mode 100644 index bceab166196918575f204d14cce4a4e6d9776008..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12005 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 diff --git a/docs/website/images/hammer.png b/docs/website/images/hammer.png deleted file mode 100644 index 454a5e5814db549970f8504d4633857a6a100f3f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18353 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

AR^W z^bNgG_jMNVW)@>?ax+l6fcnC0c{4rX3q@eYh-08*z|00dkUspy@zdi%;a`Iv(ySs;oD^O|c5dIXddTCIrp!y& z9UYb9xOAUO^FCVV${|FHulS|y>#a} zQ%4t5r_;%*ZOWmZTVi! zmjCu&@v@9GaEIB`}b4?z=Z4 zDhMd>8D=K#<;1k{QneC$g>j`r?$ufu!p%d@jR)MA`1avH9B^|rBOtrOOx1U8*;bRh z5-{Ht>8P((AiP?;47-6j=hW({yH0yh9vdmkvEjueL}N~ElDb+vd_?mOa9rCI#VDa+ zBb3Co>9@=C3*zI5t~v!#1I(_t@`^S!Ayk&q+8!(sEid%$yz_oobm1oTP-CDPzS0XO zf|0r+^{eSwQ`bzON)^N*P-vR$uHZ&Vh7%D6L)%)0+WVTxED4kYRNXX7U=c~1Qg|Pw z)xS1V-JEK!{W{0>WNk>;gqf3>DG{8&%p|m9%eFdJZm(pcFV#snBsYL;KyP4oG9v{$ z$eoM`ZdQE5J6pP8D^v0i9g-PD2Jq${9jWy_Ra$fQ_UOLFlt|s$l!k+KY(^(K+%q?{ z6e9M0;{cXxjqP~3Z%x{dbF|~U?JZOq8|GhbFoPx5NA7=0=lc*g&CHQBtR2w||J{HP zIN|6)Uvs`D~J-G3j1#yrp6%`9K@`fEyQX{^kgRl!t>%&MyH|N4C(88GX}d?YcM zauBh8>lSXm`Hp9wobOb1kN|Q+%4m`;Vc{kxKmo^ATKeJWM zTz58tzzA>w(V2VB$a#@L0af7WrqGf60|ODF zaL(*$lc-(^!tbUL#hS+V3be)CjSX;iGP3FIlQU<}Ej_sikE!jW1`=(S^1R ztUIsDd~a1J;3Qbqm)~bWO3Fmnp0fvzGLU`c`YsAWtVbIXX?AB}QF8Xo`Klkh^2R^@ zqO>ZVsNRr?%jT_@QBag3?ELIQPu=>rx4+^0Uw5Q`SR#WEMAjmz2WxSu+55n=2cDWI z?hGUV$Jp#cMHgRrQI?h=W=O7q$dbDm#ps%wrU42Vl3-56vyK6`bQVI z+tsEGb=OoKMv4PZA3pHdvrwTBM1%-NV8CO;MWVdSLPCIKsq0R+BQeGpC4{ZpI^Bth znVHGyEi-f5=C;kw9a&tiD$cnn5@-%nTi2%AKy5E~$cE#*f#|{Uq&Dkv2S?v^wljO> zY3B{p3tkz|e^&(ID4c{3`UZ(nmy|T+CQirmF1_H9yPovaM`X|_?I$zoRGJM+1g2`@ zv0Lw*oteGh)#qkTIb{)sxx&X9=?gf%tU8Zbjx z;nda{PQ#&snX(yivxr6u;F{@?2B;XW$bED|=uW)mO&9Lkb;j(L8Df>laCHi64?;Iz z;hV12*gq+YLsLc!JE!L+(J{+T^2(_Gr4B+Xu4+i8k*W>t^5W{8C_})+6?Kel`>RiX zbf~i~I4nBQk z??X?1^UIHN>>4Y`j-|RM7PV@TQjlqFnrbdw_fxN3NDDP}bIu`pN~!P$%g$nizNXIB z*?!Xk!WEIWPNM{71cR`#p(Bc~E7deRvI1e~hFvBkiWQ2N0|b>d0I+h^82D0DT^RCW zd;5p(yxngLTc^+6bJp1xpMK5-yDVmH5{MbWnTvzX#s|gZ<_t17FtNeLh#eVlfgJ;2 zfMqdR%5Q${6)>a_YJUYV^IemU62Ww!lC)t?Rmd+6SJz0gW5?EWE?BsZKT7-7>qSpZZHn3wfd6_AK=>B$#Fp726aVSfC;~PE{{B{)I1wU%$>dE>Nj1LylLA+%%#`QBEA_^ z>6krjV%P5Nh_0SoGhSj7OiJwniLqD_$YDrxD1H3TKK1OAhbnX}d-7Dw1kGJd%}vYX z){n!ge)z=7-nr7?VOGC%+nKcqy{xqjzgL40T*wV>E0med(2W@S{e}bcWW3_~tJ}`< zSUV{NfZ_0_0Ry=;Z=G~#d`;Q%NM*#0OUg_-QDgdnfA9kq+FB|js9BqHn{!sxH8P5; zZQfv4zVRxVC9Tv1o?hCgs$*Hpubg53+gm9r6IhDQ-c-`neVT&}2w`sM@V{P%kJ z5z&kL76bJBNe@EbPz_=oPTvRS5bo|wD_PA-Gy-r(+fS#xYUk^J>^j=%tt{2CD@$Ds z+0v2+_nI9IScOd3nH`jY1Wp4jG$JAa0w93E0B0b=f;EO^s<`&H&r_`F;N{m}{)Ts6 zzir3X?0Ep;8f5^y$$!s8S$nyv>Np*L=)G^b?%l6-ZQQfNpov7x04DRIG9Ji7;M!H) z@?f@`WKXB(arKy+)M39xDV6{p=uA0!y2p+kUeTi*LTV1o~ z(lY+E!SdyoLpu6meurY-iR08OJ$^pnC}_n>E@x&sC{Jj^-*d+xBcr zc7$s8B;1*G4c2pb4UO7Qn#>f?B2Ormva1$CE8GEw^&puk0S$4gCMCqWZF@8unHFFB zX8RVHQKDnNN@3`$U1it_~Q6R?35})!4^yU@=19 zGq>6%d-H`?&T>U+&gAPg-Cnt#@2oxk4flAue+3ZiBS@m|4raKkYEeL3QHxoDn1Vok zv0#g|^!j&RcjT(YryqFY@jIT;-Xd5+=vbL+*McGJ!=0c&7}8D22n49mmYiB6V_`FG z78_K(v-X_5^~_Vwy7{5FMUI)0-Qi78TiZK81xsnyF?hugAAmY#)-)jA@%wu zr=%4(B`^&HDMsmA8&p6!XRc^+XJ_}^xtF}=vgh{g|MvagKJw&qP=W#A!Eq-QI}f#s z3PgKge42ZQF*yO4>2kGw%UNfgchPIkoZK?4tQ^p!hFMgd!6k#rs#!IPtfXxl70QPH zS?7tzAKH887j9j8ZW&w&S5{F7RaSuA%|K4YY*br^Ld4r1h0ba!LQKrQNg()Ssgg0+ zTs^q98IHpT<`R1C%GiFvd@)OZ-H#nKGW0CX?+jgH4CVilZ?BX==vi}~BL*JCv zo%D3n&0sc6M8>j@3)|#ll&JGv8ySU6Up?!>AJ%-C}3 zRMm|$b5k>?%uGyoIB+j(wnQAnWmK6lm>{OwUf_dhme|5B;-s|QHV{`M5F0yf&euOK~#;{wocD( zpIb6Gf{}_pzv`jG&1R>kXJR)CEfZa}>!O;X!pw?O>pI-c*4f#mz7xce#(;H`0NuJ8 zvpczMX6DG;7OpCcCr&ldjhn^VM>a%>Xxq%pk-24zRofCkiyc1RAe@_?I;Gc;0g=eY zf-BL9NVwZcv{ZX3EAoPc^`Y45?|tl}zxbQ~JH_Cp5GJCPjCwU?bw}Wfx9|La|Kq>E zcF!dz^dSiFr=EIp@6ys^Pd@d~H)&Vma0s15eT!+&H zLy-GF_`yrgJ%9DN_;=8V_tiOtjUp}?pk|T3BO2=HxvrzgUY&sdQJFlA292zF$78+q z^Iu7GkWhM#FFa8i+_d8Z7o89yT|M|E6Euy&T zaBdA0a~M^Wq89+s_7H#f-~HA#doEdFENsvVeV&Cf*!75Z?K*3h;hGEfz#T$ImzEb6 zm;UV^{6ByAp+E00H&jn*n} zW)y2;Fg=o*w9P&{y8|E2GIht?g>Hl$?@XMMif z<1PPu=o243_tY~is|3#O1d_4fcmttG=79sVm2N7WY@n1)uJhU6bi+^G{qVySs-Q@l zJ~TN41|c{+r>V)QNB;7|+qdtqlsSf#GjN4!PpkZ-@gCP2N(|^2T5l)z${Uk{jeody z)JbDDV`;2h_e3%&TH^-qz7mt;98oLsgJXW4aH46;i`8ISyNe$yi#WmerV%N;2@BJw zzVL-?32g;lov_i+Hf;mnVyZi7gEN81O?a$NG!SbVE;sPMO*Q2r=cH zM>>HMv*koAaGY_*8QZt-fMWnjFa0+$QS@G*|!ecL>4UW`fu3oIYe`EaKSn22}G4>a2&~mbNvN3{?SXy@>eD$_lL8w>~ zt%~XnNKzsL4^uPC8BO!>Lyzvf>I!#gQn0ykIb@&zlgn^Gvhq+Jsn}&3k;54b=cQir z?EYs-#I)#Hj6P5if~!OGwO3p@%uNcK(D?sv@9JLcx~lkZt-a5==iVDGgL;8zj<06`Ib5Xpnkf(lASh(#MDwN>j&v1$+!Yp~;_ zDcVkq#war}nYrhlbJm9s=Ozr!OudcG!)?xw^LqEbXRp1^UTd$lerv-v;OnHk!KZD_ zLA2SavSH=gkfz;`=HhGWxVpBP>}KQFin8{HF<6_hZ#0aNrbPudAyG)vYF&VIfUI?XO2?FkmR9TI%=y-Oqpe+_T4?_|fm@&nXjP3O6eX z>a@LFM>EyyCuzG%s;n$NbL7ZayWMQ!Q3u^%zx6i;48~yh`3o2Jec*lAGBHf5H5pMF ztiK9Z6a|uW@1D7RZ+Y|F?Cf~jnwgv$+p>k3LWo<(#qPXv~pE`MFewcJy206JCL5%{tDYO6w#0W>iA(*3+P^B?RnHeG=B4;r5 zi^5$MkUU2#gD5yaJ%k8%W29+X_Hqvd_ef#Ag-lLBH9_IzPfqN)ea5tmNvqk%jX659 zE+JrWXBzKz4}I{yQ)m8Ef$A`%Z~hw!ZelUbq%7FU(pInl4pJ!yRV7uL;)*bHSyW_R z>upIs7`o0`&9+ckaZJqx2`MSuAt-t)NFzdms#4U6bJr6iYqBME_UE4Z#oW}SlEs)b zn|S1%qFdVxKp0dH;K73j-+K35&;g@2OsQ6xnkvE#Zp_T&Y5=oHiAc)kQVF}b)D5Z- z0#w0nP=yMcu$8PJbE=EA9Bxqc!0I+26;OgP1u#c84g&T7P=qiU97#yn38K^8_VJ_N z+`DZ;r64nrhW4c~M@Jbd<`EHqz{OWk&3)*@mzI~&?l=I|Hpg5G49LIXA|Xv{-o%?C z3|I(>il8h!ZCwkxvr83XROwG{-}d}tkMG#NEs&cDh2Tz1O}TAz5{@jwph^c-kyFBN zYGuDY{^Naj?jlu~0Gi8yA7dv(Rk|iNa>C-8^A%3|jPJyDPmM{r==_(?{-q z;Ng#dVs6(R=H_+Iw@BbnGZ3)XEN~4PB^*tZumo&*71E@xJ`e`0vQ|h_1wZ|}(_j70 zx6Upsiz65a}U>HJ@xJ$>r*xtGqq^77*O3m2D{R#&gu>I#@ajHCrq z5F-Sb5eH_{^$F83Cqh|)8EW7F5tJo5otVa{$*nU})6)|Zdw1`?XV0Dk``>Z*&K=Fl zH%i!`_8SdM0Eu}~6us5_az9_`_42AXGe5uh_kUcx^shf&IA5u({&x^>$^gia1 z>Gtj0XSPl4n7(a%>-gJeci**Z*Up)lw3T+VY@*xALXu@!2-nyXVc;ek=8cd40K7`h UXbAGL9RL6T07*qoM6N<$f_}VOMF0Q* diff --git a/docs/website/images/logo.png b/docs/website/images/logo.png deleted file mode 100644 index 2db743b4fa93820a2ad38bdafb1dbaafe7805fee..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 117499 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

@^9-lMJ|?5P$*(2?$!~9H(~3( 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

EVr2UX@4T=+T75|uU{D1 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�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%0ArAu0SRq3#`KMKh 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


XXVNMj`#2KQ-cm`J9&grNf0 z-`}4(bs~+K_$Mrv9}G_8MGxpLWkTOW`=6G)fy`*RkWOxw4eqBqaq7$$%iRE2e+i;zeTsy_YKKw zO}OoVt&C0l?gioFp#8+JGKY{D)8evgLj-vhP5i!0hKn)LvWy{uzE1eIREBrSdr1R? zQ(Xga8ofRL|9_*5+k~-+KR^%!h}I%4y~_on1iAtEo=EaOQqslP#IG}lp$1f&L^rnz zh%V_SUC3{KEPx++5+(acP*z-R5#X5YyAK7hTC=Oo!X(AjCIP(DlfKR<8wMbA3NGLO z0l7B_)5gDDCrlszcC9dD{M*&So8#ZE5@wEnyFz$dGy)0NA?mqQwTnka0ddx}p=!WPA+mvy5UueQ>s&1zYteKH`8Mz|R( zwucppwuvOli&u+GctOlYLd5F8wWAJ3r?Sl5k;j*a8ux)Uy6Ny5=hI8P`YyMl@O zV33Z&Bi10IAHWH4L@Wc2nIfPv{QNopk$|AUPzd2dDhZ#ZE@LbsL-p;8eH=CXq+EfGC2o1Eeo}VXc2)puc}$NN{KvRwf_;0%Bt0uibxe zFZ1>-D*Z<3Ef^E|>9i~e$OZ=j1i%hB`?2U*P@sRHUqEP32p3Wu7J@Ym<>`Zh=LjKBp3Dk#R)0mhTUq98or7zzx4{^22^;avDYXjphuRP6Ov zctXiFcQiKCRFu9f##7jb*cP9a1yTVXC*IL9bsf+F%qvfdLV{6?09sNB@4W78e!CIX7@LUmpLshtQ)>io$||f`fuWgHZ=@SVstq z5ET2gxxE9YKX>=`fp(7TYsG^-(DpS05(VNNaK3;u2c$LJlQIw%Jq0|=KM2i;l^iVV z;3Xo=_gWnj(9;VvG>(FP30_E$S%R++l1NZ37_jij7SO1duVO=>L0~B54hae8!^c7b z0-k_xPukf7$~vxp6bFoh+Z1Pfk4V6)3QFE4qB^C=jbP<%#`D;^_|VYcpa8ZGB_lHo z!V11uYCAf+L9Zwo=d>o`B-f@sNIC6Q(BwA__W4cO?4n3n+F0K|_RL;${ukPoEPjPsDfU0F?9LS#7n7!R9hbuBC;DB)#OJ0$dgy$@W7 z+<+9ybD-sg7GrV)5HBRkpCB8!o){e!5r*Zq&@gdWOL*|Lmz9kuA31yR zZd5Fph$GI2h3iT22~kmzd}JdW4h09LE3aZ% zo^a=SdK%W~l9RD)7#kZ6IATa-RBS>@>b0Bq?>{Phj`NAD8=70XJ7G9#G~_4U75Q@o z@cP`y$RHV4QxfB1A_G0qc2Tjh@d=4naQNh%>_?A_aLRKcb?}p>ZWk7_o%v9tD zVxLTKw&0|@^i*J%q5`}EkUugeCN3@>3w}u{>DO=GyZiBJQB@b&Ar?|?4~2N*wj_L9UjG_~SE zJZOf%&61sc?+!R`P=i1(3;`h#q2bXn(a<3}o^(jOk|;mT@W#zdHWTIL7e0IO;&nxJ z4G5z!rKIFO0L8?ujP&H#ATO+BV-O3A#0ZKpG%h9{T97T0lhZICVH5_77T7^@2)17I zjM%;k0Bp~Bkag$gwJWi~-u}T{Fc&%o0kjCr#fsw#6D}uULc_6wDQP$*4?G=U{~$8O zhmU|TDkP#eK!omPq6TpRUj8Va5AC7+r~zvV%x2u>=Sf$RQd8NfkT-6kBA{RczsW;F z$B>A}k8-oK@Mto?8>2XS?madY!3da7v4)L>W7q*IV3C(}z)XT!nP^Uck|7bGNqltw z-mUa_KW`d&_;5a=G7>A;$dBv^Xp8tOr~({~4pl_{TgVT#la|+D|AGimJpy8MCnMh9 z8!Zru)p9O!C}La!7bi=I=i<49yel}`GA-?DMh20dfDZ{m9)NoB1z5;1o)}9HSo2WfN(n367Z6Ln{l^KBk**D?> z@w6LJNhI`;MMjCEMrlHhg9=Rvm(i4PZ5;84GahlQBT2}5lo;4(J0#d5v{W3iN%?OfJb)7Q4RsI!%yAi!0^W-XMnpyPd^;!m<^omY(9rR6^h_1Sc9hhsEw6(V*`sr?>cmv=(U;*#k$hdZuyUL|V z-~hN7OG&<(n#QL!;_OWFCQ#8ZL)_0L4r$P?cR&u;)(md&=BE1En)343#ZU9|Fj(A3 z#{six6Vqhr*TmOauY)!V@f|uP2-8OBED21O-CQ@2I$HWp*)8K>L0pcwNF*Mi9^$hiP8*kPcb>%WEBx0h(15jk~ZTJ7pY zJVzX~HI*O$Eq(%oV(x=`ceC%}+-;Em+`FHf_qYWU&M;;Q)Mp5~5VbaVn{hFOAfR@z zcc8bw8^Imu!CRXe;kE$ZJxAXG+boetakdZ2>PQwM-zP;l-##(3u%fvevo|}$0$j=nUIvHxVSZ48vo9c1 zHZn9}h#SqO$Z(Jd%X@kdsJ3t>sygQy7TUEa|@IEq3kTA+gu6!xL9EW`xggf&3ihcx7nR3`gJr9XJt*p0?#0S`UbBjRrbVi4?-f^BDiQn|b9;y>!L^l!8%UB@_nQXJV_KD4ReEW6e^o zez(w{9~qRGRZ!MG1SV^WX$MhlYB2Ue9xWm<6o4q6^ps-lQi0Fx6gn{BUcLLY7R1^x zENczo(k6mzTI-=RkyuN@2Fj$-Btd?hkxbTfBPcvA=VfC*Hd>OcC^?Rh!RisI3iD#4 zC5l9G_%}_UC#ICFIyEr**5i`aL4@FB8dv~1C^PhyD2`(yY14%cB!{fgR|z3k?iST{ zQadV>Q{gU1&*@nwH4Q$ABsDm;Q%&tKox!V)V_1*j9MhAU8fQ*xpE-N(oQ|$Or{AKd zf6?HAp|OcMc3BY6oq+W=wg9+y*gF85?sOCfh~l8nBRED>9fyy;R;PnZHBW16;jq@T zI=bie_4M=&E?zXah>ap9W`OuxSXtUY0%yzFaSpuW)1$|Zs;Q|S!D+g5qA8t4iu~GI z+LWITo4uf~ck!a(MFRu2)x?ss9I>*rwqYtr?HwF>$7gD)syGRl4*bNCp*S}brIyylG)ni9haP;UgR0mQ> z2@S0?r_Y^*8FchGy%+iyPzM78L+m)g#v@CZ!Wuw%TRRxR-rf=Cr9uf6)uS*5tk8?9 z97i=Sm;qv=ugB~0`jU$(}2fDRpzKN
    =!h!?TVMci4(PJ?RD*PgHpb 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 u5Hh_ll#71V^~U@wTr5{~b# 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 )H{ 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%0D?-1;)~#gDoq0zwj{Da2X2t~xe{ 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 diff --git a/docs/website/images/nconfig.png b/docs/website/images/nconfig.png deleted file mode 100644 index cc05d6e8e82c07298b1be7863f735e946191e4a6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 88055 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 bSEm=7>jXG}mp)rxID_tAhT2t7>(KuKfC%_i diff --git a/docs/website/images/package.png b/docs/website/images/package.png deleted file mode 100644 index 9dd8b1e0a196ccd62ce55256e72664195f071063..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7746 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 diff --git a/docs/website/images/rockwell-collins-logo.png b/docs/website/images/rockwell-collins-logo.png deleted file mode 100644 index b5956a82a75a8d16de29983413313f3a30a5a231..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6124 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 R7PRXjnrgc6@(0#o{|{tIyRQHM diff --git a/docs/website/images/scaleway-logo.png b/docs/website/images/scaleway-logo.png deleted file mode 100644 index 16859145480183b7b59ea61b2da40f66004de932..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12331 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 XLMHAA0mVSZelQsc1@UT8qo4l=0b?Wu diff --git a/docs/website/images/smile-logo.png b/docs/website/images/smile-logo.png deleted file mode 100644 index 046c999a251fa7e50107a786278a59c9e3d853de..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 28422 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 Gjqrc_5zfE> diff --git a/docs/website/images/tap2open-logo.png b/docs/website/images/tap2open-logo.png deleted file mode 100644 index 136019b6215490e090cab8637580869b8d37c020..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9064 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 diff --git a/docs/website/images/text.png b/docs/website/images/text.png deleted file mode 100644 index e2eee546f8952544f408776a2c4587e0a09dcbe3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6437 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¨++u>zAB_ufk9*c8js+ei_oUeMQWp$3&2V|&+k^X-+ikD z(1Dnn1*bQc_FQyo5dP}A{*^Vv|73EN44YCmeid3*{aQ^q(`~m?-g|duELI<~7E`{} z()3ZHD9MFpK4C%bzpKx@owJ3X&0c#07Uf}Zmx;{a-%>xHPtOhatEEgN7zzr3Dk(c?Uu4(|2#=AX zKZ;nD`q}$ePH|&?xU++Bb@bl+2g2!Ccg`t+0XeD^vjIc+KxMIA$0HS&T;UwJib{cE z;=XCU#KMBcK>6)Z>Btu!I`lK`SXjQSCn`i!WJ$XQj}(@GQ3PR4?PfL6pgPEV7w5m%V^--wN*w0t$ zhMU(=p`HdqzDW!Hxj4ubX?6~9p%I5|Qr5zg&%e9{=L%aW{K+S3YtM9URoWAJ|F9wiBhhjXy3Z`^W zFgK=@|HdQKcbH0R@ko>jbO^X-VD2daoQcfy7k&*YvjKl-V}HpznyK7&bwoFz+47tF zLa&!b>RN@pFkzmi68g3Y7@N567Kcztk9c>{;br%4mYqE9i8@&yx2I?qCYiE4#pHTj z_ZG=tr^SbWH&*6Nh_oY%J-NT>A@KkDo8`TIYyc}=EZ9H9JS@|B^$xbVr$$mILo@kp zsO)u@k~H;FJ<+Wy-;>lR5!Yk!V1MGq(V0`AOqdd2iF8~3|aTx&nfqbY-%Tz`=rY7- z$XD`5a*LE*U4lcRZ@6AQa{;rQ5+ORYv4flqT_lA~-p>6BNHlH5xNe;2?14i`lHFRip^osX<;u$xgVylIX$DI;wD0x8^cZ{h+%VFfu zlsIohOs>X4h_f02PPmP?#Jl6Q7Xy7%!s!5SziWH{SD!ywlk3A5%vBUH!@NOB1X?lq vI3{PVYPJ~$U+4mb;z2>Hf$pW2Q@+mr`sqQXsBG{L4M0!ZSgZ1;bL{^BA9?dx diff --git a/docs/website/images/tkos-logo.png b/docs/website/images/tkos-logo.png deleted file mode 100644 index 6fe58826e10adad4fc3d3fd0cd31d004df0c684b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10101 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 Eg6Od0od5s; diff --git a/docs/website/images/xconfig.png b/docs/website/images/xconfig.png deleted file mode 100644 index cb99a3a353e62103b811d5669d51da3f16f61def..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 224081 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
          !M;m-nASb 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 B7+e4V diff --git a/docs/website/images/zillabit-logo.png b/docs/website/images/zillabit-logo.png deleted file mode 100644 index 6a2ac31f51e82eac7dc2242ff224c9e52d85ede1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5394 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 Q0Pv?I_d>Q*+BES006BgvSO5S3 diff --git a/docs/website/index.html b/docs/website/index.html deleted file mode 100644 index 300adbb83d..0000000000 --- a/docs/website/index.html +++ /dev/null @@ -1,151 +0,0 @@ - - - - - -
          -
          -
          -

          Buildroot is a simple, efficient and easy-to-use tool to - generate embedded Linux systems through cross-compilation.

          -
          -
          - -
          -
          -
          -
          -
          - -
          -
          - -
          -
          -
          - -

          Can handle everything

          -

          Cross-compilation toolchain, root filesystem generation, - kernel image compilation and bootloader compilation.

          -
          - -
          -
          -
          -
          - -
          -
          - -
          -
          -
          - -

          Is very easy

          -

          Thanks to its kernel-like menuconfig, gconfig and - xconfig configuration interfaces, building a basic system with - Buildroot is easy and typically takes 15-30 minutes.

          - -
          - -
          -
          -
          -
          - -
          -
          - -
          -
          -
          - -

          Supports several thousand packages

          -

          X.org stack, Gtk3, Qt 5, GStreamer, Webkit, Kodi, a large number of network-related and system-related utilities are supported.

          - -
          -
          -
          -
          - -
          -
          -
          -

          Buildroot is for Everyone.

          -

          Has a simple structure that makes it easy to understand and extend. It relies only on the well-known Makefile language.

          -
          -
          - -
          -
          - -
          -
          -
          - -
          -
          -
          -

          Our recent activity.

          -

          Buildroot is an open source project: many developers contribute to it daily.

          -
          -
          -
          - -
          -
          -
          -
          - -
          -
          -
          -
          -
          - -
          -
          -
          - - diff --git a/docs/website/js/buildroot.js b/docs/website/js/buildroot.js deleted file mode 100644 index bf80f11d7a..0000000000 --- a/docs/website/js/buildroot.js +++ /dev/null @@ -1,93 +0,0 @@ -function load_activity(feedurl, divid) { - let container = document.getElementById(divid); - $.ajax({ - url: "https://cors-anywhere.herokuapp.com/" + feedurl - }) - .done(function(data){ - let x2js = new X2JS(); - let result = x2js.xml_str2json(data.documentElement.outerHTML); - let loaded = 0; - let nb_display = 8; - if (result==null) return; - for (let i = 0; i < result.feed.entry.length; i++) { - let entry = result.feed.entry[i]; - if (entry.title.indexOf("git commit") !== -1) - continue; - loaded += 1; - if (loaded > nb_display) - break; - let div = document.createElement("p"); - let link = document.createElement("a"); - let d = new Date(entry.published); - let data = '[' + d.toLocaleDateString() + '] ' + entry.title; - let text = document.createTextNode(data); - link.appendChild(text); - link.title = entry.title; - link.href = entry.link._href; - div.appendChild(link); - container.appendChild(div); - } - let empty = nb_display - loaded; - for (let i = 0; i < empty; i++) { - container.appendChild(document.createElement("p")); - } - }); -} - -function google_analytics() { - let _gaq = _gaq || []; - _gaq.push(['_setAccount', 'UA-21761074-1']); - _gaq.push(['_setDomainName', 'none']); - _gaq.push(['_setAllowLinker', true]); - _gaq.push(['_trackPageview']); - - let ga = document.createElement('script'); - ga.type = 'text/javascript'; - ga.async = true; - ga.src = ('https:' === document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js'; - let s = document.getElementsByTagName('script')[0]; - s.parentNode.insertBefore(ga, s); -} - -function showTooltip(elem, msg) { - elem.setAttribute('class', 'btn tooltipped tooltipped-s'); - elem.setAttribute('aria-label', msg); -} - -let clipboard = new Clipboard('.btn'); - -$(function () { - $('[data-toggle="tooltip"]').tooltip() -}); - -clipboard.on('success', function(e) { - e.clearSelection(); - $(e.trigger).tooltip('show'); -}); - -$(function() { - $('a[href*=\\#]:not([href=\\#])').click(function() { - if (location.pathname.replace(/^\//,'') === this.pathname.replace(/^\//,'') && location.hostname === this.hostname) { - let target = $(this.hash); - target = target.length ? target : $('[name=' + this.hash.slice(1) +']'); - if (target.length) { - $('html,body').animate({ - scrollTop: target.offset().top - }, 1000); - return false; - } - } - }); -}); - -jQuery(document).ready(function($) { - let url = window.location.href; - // Get the basename of the URL - url = url.split(/[\\/]/).pop(); - $('.nav a[href="/' + url + '"]').parent().addClass('active'); - - load_activity("http://buildroot-busybox.2317881.n4.nabble.com/Buildroot-busybox-ft2.xml", "mailing-list-activity"); - load_activity("http://git.buildroot.org/buildroot/atom/?h=master", "commit-activity"); - - $('#slides').html('') -}); diff --git a/docs/website/news.html b/docs/website/news.html deleted file mode 100644 index d3db1b28ed..0000000000 --- a/docs/website/news.html +++ /dev/null @@ -1,6515 +0,0 @@ - - - - -
          -
          -
          - -

          News

          -
            - -
          • -
            -
            -
            -

            2021.08 released

            -

            4 September 2021

            -
            -
            -

            The stable 2021.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details - and go to the downloads page to pick up the - 2021.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.08-rc3 released

            -

            31 August 2021

            -
            -
            -

            2021.08-rc3 has been released with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2021.08-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.08-rc2 released

            -

            18 August 2021

            -
            -
            -

            2021.08-rc2 has been released with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2021.08-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.02.4 released

            -

            11 August 2021

            -
            -
            -

            The 2021.02.4 bugfix release is out, fixing a number of important / - security related issues discovered since the 2021.02.3 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2021.02.4 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.05.1 released

            -

            10 August 2021

            -
            -
            -

            The 2021.05.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2021.05 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2021.05.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.08-rc1 released

            -

            3 August 2021

            -
            -
            -

            We have a new release candidate! Lots of changes all over the tree, see the - CHANGES - file for more details.

            - -

            Go to the downloads page to pick up the - 2021.08-rc1 - release, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.02.3 released

            -

            12 June 2021

            -
            -
            -

            The 2021.02.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2021.02.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2021.02.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.05 released

            -

            6 June 2021

            -
            -
            -

            The stable 2021.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2021.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.05-rc3 released

            -

            31 May 2021

            -
            -
            -

            2021.05-rc3 has been released with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2021.05-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.05-rc2 released

            -

            22 May 2021

            -
            -
            -

            2021.05-rc2 has been released with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2021.05-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.02.2 released

            -

            12 May 2021

            -
            -
            -

            The 2021.02.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2021.02.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2021.02.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.05-rc1 released

            -

            12 May 2021

            -
            -
            -

            We have a new release candidate! Lots of changes all over the tree, see the - CHANGES - file for more details.

            - -

            Go to the downloads page to pick up the - 2021.05-rc1 - release, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.02.1 released

            -

            7 April 2021

            -
            -
            -

            The 2021.02.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2021.02 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2021.02.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.12 released, 2020.02.x series EOL

            -

            5 April 2021

            -
            -
            -

            The 2020.02.12 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.11 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.12 release.

            - -

            Notice that the 2020.02.x series is now end of life. Please migrate to - the 2021.02 series instead which will be supported until March 2022.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.11.4 released, 2020.11.x series EOL

            -

            5 April 2021

            -
            -
            -

            The 2020.11.4 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.11.3 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.11.4 release.

            - -

            Notice that the 2020.11.x series is now end of life. Please migrate to - the 2021.02 series instead which will be supported until March 2022.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.02 released

            -

            6 March 2021

            -
            -
            -

            The stable 2021.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2021.02 release.

            - -

            Notice that this is a long term support release which will be - supported with security and other important fixes until March 2022.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.02-rc3 released

            -

            27 February 2021

            -
            -
            -

            2021.02-rc3 has been released with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2021.02-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.11 released

            -

            17 February 2021

            -
            -
            -

            The 2020.02.11 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.10 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.11.3 released

            -

            17 February 2021

            -
            -
            -

            The 2020.11.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.11.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.11.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.02-rc2 released

            -

            17 February 2021

            -
            -
            -

            2021.02-rc2 has been released with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2021.02-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2021.02-rc1 released

            -

            9 February 2021

            -
            -
            -

            We have a new release candidate! Lots of changes all over the tree, see the - CHANGES - file for more details.

            - -

            Go to the downloads page to pick up the - 2021.02-rc1 - release, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.10 released

            -

            31 January 2021

            -
            -
            -

            The 2020.02.10 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.9 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.10 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.11.2 released

            -

            31 January 2021

            -
            -
            -

            The 2020.11.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.11.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.11.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.9 released

            -

            27 December 2020

            -
            -
            -

            The 2020.02.9 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.8 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.9 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.08.3 released, 2020.08.x series EOL

            -

            27 December 2020

            -
            -
            -

            The 2020.08.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.08.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.08.3 release.

            - -

            Notice that the 2020.08.x series is now end of life. Please migrate to - the 2020.11 series instead which will be supported until March 2021.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.11.1 released

            -

            27 December 2020

            -
            -
            -

            The 2020.11.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.11 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.11.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.11 released

            -

            2 December 2020

            -
            -
            -

            The stable 2020.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.11-rc3 released

            -

            28 November 2020

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2020.11-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.8 released

            -

            17 November 2020

            -
            -
            -

            The 2020.02.8 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.7 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.8 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.08.2 released

            -

            16 November 2020

            -
            -
            -

            The 2020.08.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.08.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.08.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.11-rc2 released

            -

            14 November 2020

            -
            -
            -

            2020.11-rc2 has been released with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2020.11-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.11-rc1 released

            -

            4 November 2020

            -
            -
            -

            We have a new release candidate! Lots of changes all over the tree, see the - CHANGES - file for more details.

            - -

            Go to the downloads page to pick up the - 2020.11-rc1 - release, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.7 released

            -

            12 October 2020

            -
            -
            -

            The 2020.02.7 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.6 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.7 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.05.3 released

            -

            12 October 2020

            -
            -
            -

            The 2020.05.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.05.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.05.3 release.

            - -

            Notice that the 2020.05.x series is now end of life. Please migrate to - the 2020.08 series instead which will be supported until December 2020.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.08.1 released

            -

            12 October 2020

            -
            -
            -

            The 2020.08.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.08 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.08.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.6 released

            -

            5 September 2020

            -
            -
            -

            The 2020.02.6 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.5 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.6 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.08 released

            -

            1 September 2020

            -
            -
            -

            The stable 2020.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.5 released

            -

            29 august 2020

            -
            -
            -

            The 2020.02.5 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.4 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.5 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.05.2 released

            -

            29 August 2020

            -
            -
            -

            The 2020.05.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.05.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.05.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.08-rc3 released

            -

            28 August 2020

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2020.08-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.08-rc2 released

            -

            24 August 2020

            -
            -
            -

            2020.08-rc2 has been released with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2020.08-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.08-rc1 released

            -

            6 August 2020

            -
            -
            -

            The 2020.08-rc1 release candidate is out. It is the first - release candidate for 2020.08, which we aim at releasing end - of August 2020. It contains a number of new packages, new - defconfigs, toolchain improvements, package updates and - more. See - the CHANGES. Go - to the downloads page to pick up the - 2020.08-rc1 - release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.4 released

            -

            26 July 2020

            -
            -
            -

            The 2020.02.4 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.3 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.4 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.05.1 released

            -

            25 July 2020

            -
            -
            -

            The 2020.05.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.05 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.05.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.3 released

            -

            3 June 2020

            -
            -
            -

            The 2020.02.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.05 released

            -

            1 June 2020

            -
            -
            -

            The stable 2020.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.05-rc3 released

            -

            29 May 2020

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2020.05-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.05-rc2 released

            -

            22 May 2020

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2020.05-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.2 released

            -

            12 May 2020

            -
            -
            -

            The 2020.02.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.05-rc1 released

            -

            10 April 2020

            -
            -
            -

            We have a new release candidate! Lots of changes all over the tree, see the - CHANGES - file for more details.

            - -

            Go to the downloads page to pick up the - 2020.05-rc1 - release, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02.1 released

            -

            10 April 2020

            -
            -
            -

            The 2020.02.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2020.02 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.11.3 released, 2019.11.x series EOL

            -

            10 April 2020

            -
            -
            -

            The 2019.11.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.11.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.11.3 release.

            - -

            Notice that the 2019.11.x series is now end of life. Please migrate to - the 2020.02 series instead which will be supported until April 2021.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.11 released, 2019.02.x series EOL

            -

            9 April 2020

            -
            -
            -

            The 2019.02.11 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.10 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.11 release.

            - -

            Notice that the 2019.02.x series is now end of life. Please migrate to - the 2020.02 series instead which will be supported until April 2021.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.10 released

            -

            16 march 2020

            -
            -
            -

            The 2019.02.10 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.9 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.10 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.11.2 released

            -

            16 March 2020

            -
            -
            -

            The 2019.11.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.11.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.11.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02 released

            -

            8 March 2020

            -
            -
            -

            The stable 2020.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2020.02 release.

            - -

            Notice that this is a long term support release which will be - supported with security and other important fixes until March 2021.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02-rc3 released

            -

            2 March 2020

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2020.02-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02-rc2 released

            -

            26 February 2020

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2020.02-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2020.02-rc1 released

            -

            18 February 2020

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2020.02-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.9 released

            -

            12 January 2020

            -
            -
            -

            The 2019.02.9 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.8 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.9 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.11.1 released

            -

            12 January 2020

            -
            -
            -

            The 2019.11.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.11 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.11.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.8 released

            -

            7 December 2019

            -
            -
            -

            The 2019.02.8 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.7 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.8 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.08.3 released

            -

            7 December 2019

            -
            -
            -

            The 2019.08.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.08.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.08.3 release.

            - -

            Notice that the 2019.08.x series is now end of life. Please migrate to - the 2019.02 or 2019.11 series instead.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.11 released

            -

            1 December 2019

            -
            -
            -

            The stable 2019.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.11-rc3 released

            -

            24 November 2019

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2019.11-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.11-rc2 released

            -

            16 November 2019

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2019.11-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.7 released

            -

            10 November 2019

            -
            -
            -

            The 2019.02.7 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.6 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.7 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.08.2 released

            -

            9 November 2019

            -
            -
            -

            The 2019.08.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.08.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.08.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.11-rc1 released

            -

            5 November 2019

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2019.11-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.6 released

            -

            4 October 2019

            -
            -
            -

            The 2019.02.6 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.5 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.6 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.05.3 released

            -

            4 October 2019

            -
            -
            -

            The 2019.05.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.05.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.05.3 release.

            - -

            Notice that the 2019.05.x series is now end of life. Please migrate to - the 2019.02 or 2019.08 series instead.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.08.1 released

            -

            4 October 2019

            -
            -
            -

            The 2019.08.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.08 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.08.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.05.2 released

            -

            3 September 2019

            -
            -
            -

            The 2019.05.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.05.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.05.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.5 released

            -

            2 September 2019

            -
            -
            -

            The 2019.02.5 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.4 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.5 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.08 released

            -

            1 September 2019

            -
            -
            -

            The stable 2019.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.08-rc3 released

            -

            28 August 2019

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2019.08-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.08-rc2 released

            -

            20 August 2019

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2019.08-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.08-rc1 released

            -

            9 August 2019

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2019.08-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.4 released

            -

            7 June 2019

            -
            -
            -

            The 2019.02.4 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.4 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.05.1 released

            -

            7 July 2019

            -
            -
            -

            The 2019.05.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.05 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.05.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.3 released

            -

            7 June 2019

            -
            -
            -

            The 2019.02.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.05 released

            -

            2 June 2019

            -
            -
            -

            The stable 2019.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.05-rc3 released

            -

            25 May 2019

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2019.05-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.05-rc2 released

            -

            15 May 2019

            -
            -
            -

            Another week, another release candidate with more cleanups and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2019.05-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.05-rc1 released

            -

            8 May 2019

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details, and read the - announcement. -

            - -

            Head to the downloads page to pick up the - 2019.05-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.2 released

            -

            29 April 2019

            -
            -
            -

            The 2019.02.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02.1 released

            -

            29 March 2019

            -
            -
            -

            The 2019.02.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2019.02 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.12 released, 2018.02.x series EOL

            -

            29 March 2019

            -
            -
            -

            The 2018.02.12 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.11 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.12 release.

            - -

            Notice that the 2018.02.x series is now end of life. Please migrate to - the 2019.02 series instead which will be supported until March 2020.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.11.4 released

            -

            28 March 2019

            -
            -
            -

            The 2018.11.4 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.11.3 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.11.4 release.

            - -

            Notice that the 2018.11.x series is now end of life. Please migrate to - the 2019.02 series instead which will be supported until March 2020.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02 released

            -

            4 March 2019

            -
            -
            -

            The stable 2019.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2019.02 release.

            - -

            Notice that this is a long term support release which will be - supported with security and other important fixes until March 2020.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02-rc3 released

            -

            1 March 2019

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2019.02-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.11.3 released

            -

            23 February 2019

            -
            -
            -

            The 2018.11.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.11.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.11.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.11 released

            -

            23 February 2019

            -
            -
            -

            The 2018.02.11 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.10 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02-rc2 released

            -

            23 February 2019

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2019.02-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2019.02-rc1 released

            -

            13 February 2019

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details and read the - announcement. -

            - -

            Head to the downloads page to pick up the - 2019.02-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.10 released

            -

            31 January 2019

            -
            -
            -

            The 2018.02.10 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.9 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.10 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.11.2 released

            -

            30 January 2019

            -
            -
            -

            The 2018.11.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.11.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.11.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.9 released

            -

            20 December 2018

            -
            -
            -

            The 2018.02.9 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.8 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.9 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.08.4 released, 2018.08 series EOL

            -

            20 December 2018

            -
            -
            -

            The 2018.08.4 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.08.3 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.08.4 release.

            -

            Notice that the 2018.08 series is now end of life, please - consider migrating to 2018.11 instead.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.11.1 released

            -

            19 December 2018

            -
            -
            -

            The 2018.11.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.11 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.11.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.11 released

            -

            1 December 2018

            -
            -
            -

            The stable 2018.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.11-rc3 released

            -

            30 November 2018

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2018.11-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.8 released

            -

            26 November 2018

            -
            -
            -

            The 2018.02.8 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.7 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.8 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.08.3 released

            -

            26 November 2018

            -
            -
            -

            The 2018.08.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.08.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.08.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.11-rc2 released

            -

            21 November 2018

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2018.11-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.11-rc1 released

            -

            9 November 2018

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details and/or read - the announcement. -

            - -

            Head to the downloads page to pick up the - 2018.11-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.7 released

            -

            25 October 2018

            -
            -
            -

            The 2018.02.7 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.6 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.7 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.08.2 released

            -

            25 October 2018

            -
            -
            -

            The 2018.08.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.08.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.08.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.08.1 released

            -

            7 October 2018

            -
            -
            -

            The 2018.08.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.08 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.08.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.6 released

            -

            7 October 2018

            -
            -
            -

            The 2018.02.6 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.5 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.6 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.05.3 released

            -

            6 October 2018

            -
            -
            -

            The 2018.05.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.05.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.05.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.08 released

            -

            6 September 2018

            -
            -
            -

            The stable 2018.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.08-rc3 released

            -

            31 August 2018

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2018.08-rc3 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.5 released

            -

            29 August 2018

            -
            -
            -

            The 2018.02.5 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.4 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.5 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.05.2 released

            -

            28 August 2018

            -
            -
            -

            The 2018.05.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.05.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.05.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.08-rc2 released

            -

            20 August 2018

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2018.08-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.08-rc1 released

            -

            5 August 2018

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details and/or read - the announcement. -

            - -

            Head to the downloads page to pick up the - 2018.08-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.4 released

            -

            21 July 2018

            -
            -
            -

            The 2018.02.4 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.3 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.4 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.05.1 released

            -

            20 July 2018

            -
            -
            -

            The 2018.05.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.05 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.05.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.3 released

            -

            18 June 2018

            -
            -
            -

            The 2018.02.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.05 released

            -

            1 June 2018

            -
            -
            -

            The stable 2018.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.05-rc3 released

            -

            28 May 2018

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2018.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.05-rc2 released

            -

            22 May 2018

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2018.05-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.05-rc1 released

            -

            9 May 2018

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details and read the - announcement. -

            - -

            Head to the downloads page to pick up the - 2018.05-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.2 released

            -

            4 May 2018

            -
            -
            -

            The 2018.02.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.11 released

            -

            11 April 2018

            -
            -
            -

            The 2017.02.11 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.10 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.11 release.

            -

            Notice that the 2017.02 series is now end of life, so please consider - updating to 2018.02 instead.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02.1 released

            -

            10 April 2018

            -
            -
            -

            The 2018.02.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2018.02 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02 released

            -

            4 March 2018

            -
            -
            -

            The stable 2018.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2018.02 release.

            - -

            Notice that this is a long term support release which will be - supported with security and other important fixes until February 2019.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02-rc3 released

            -

            27 February 2018

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2018.02-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02-rc2 released

            -

            15 February 2018

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2018.02-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2018.02-rc1 released

            -

            5 February 2018

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the - CHANGES - file for details and read the - announcement. -

            - -

            Head to the downloads page to pick up the - 2018.02-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.10 released

            -

            31 January 2018

            -
            -
            -

            The 2017.02.10 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.9 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.10 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.11.2 released

            -

            21 January 2018

            -
            -
            -

            The 2017.11.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.11.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.11.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.9 released

            -

            1 January 2018

            -
            -
            -

            The 2017.02.9 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.8 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.9 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.11.1 released

            -

            31 December 2017

            -
            -
            -

            The 2017.11.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.11 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.11.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.11 released

            -

            30 November 2017

            -
            -
            -

            The stable 2017.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.08.2 released

            -

            29 November 2017

            -
            -
            -

            The 2017.08.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.08.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.08.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.8 released

            -

            27 November 2017

            -
            -
            -

            The 2017.02.8 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.7 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.8 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.11-rc2 released

            -

            13 November 2017

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2017.11-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.11-rc1 released

            -

            6 November 2017

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2017.11-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.7 released

            -

            28 October 2017

            -
            -
            -

            The 2017.02.7 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.6 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.7 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.08.1 released

            -

            23 October 2017

            -
            -
            -

            The 2017.08.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.08 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.08.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.6 released

            -

            24 September 2017

            -
            -
            -

            The 2017.02.6 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.5 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.6 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.08 released

            -

            1 September 2017

            -
            -
            -

            The stable 2017.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details - and go to the downloads page to pick up the - 2017.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.08-rc3 released

            -

            23 August 2017

            -
            -
            -

            Another release candidate, on the road to the final 2017.08 - release. A number of fixes and cleanups in various packages - and defconfigs. See - the CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2017.08-rc3 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.08-rc2 released

            -

            11 August 2017

            -
            -
            -

            Another release candidate, on the road to the final 2017.08 - release. A number of fixes and cleanups in various packages - and defconfigs. See - the CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2017.08-rc2 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.08-rc1 released

            -

            2 August 2017

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2017.08-rc1 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.05.2 released

            -

            27 July 2017

            -
            -
            -

            The 2017.05.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.05.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.05.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.5 released

            -

            27 July 2017

            -
            -
            -

            The 2017.02.5 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.4 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.5 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.05.1 released

            -

            4 July 2017

            -
            -
            -

            The 2017.05.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.05 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.05.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.4 released

            -

            4 July 2017

            -
            -
            -

            The 2017.02.4 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.3 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.4 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.3 released

            -

            2 June 2017

            -
            -
            -

            The 2017.02.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.3 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.05 released

            -

            31 May 2017

            -
            -
            -

            The stable 2017.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.05-rc3 released

            -

            30 May 2017

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2017.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.05-rc2 released

            -

            17 May 2017

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2017.05-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.05-rc1 released

            -

            8 May 2017

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2017.05-rc1 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.2 released

            -

            1 May 2017

            -
            -
            -

            The 2017.02.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02.1 released

            -

            4 April 2017

            -
            -
            -

            The 2017.02.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2017.02 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.11.3 released

            -

            10 March 2017

            -
            -
            -

            The 2016.11.3 bugfix release is out, fixing a number of important / - security related issues discovered since the 2016.11.2 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2016.11.3 release.

            -

            Notice that this is the final 2016.11.x release. Users are - urged to migrate to the 2017.02.x series instead.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02 released

            -

            28 February 2017

            -
            -
            -

            The stable 2017.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2017.02 release.

            - -

            Notice that this is a long term support release which will be - supported with security and other important fixes until February 2018.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02-rc3 released

            -

            26 February 2017

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2017.02-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02-rc2 released

            -

            20 February 2017

            -
            -
            -

            We have a new release candidate! Lots of changes all over the tree, see - the CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2017.02-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2017.02-rc1 released

            -

            11 February 2017

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, read - the announcement. -

            - -

            Head to the downloads page to pick up the - 2017.12-rc1 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.11.2 released

            -

            25 January 2017

            -
            -
            -

            The 2016.11.2 bugfix release is out, fixing a number of important / - security related issues discovered since the 2016.11.1 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2016.11.2 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.11.1 released

            -

            29 December 2016

            -
            -
            -

            The 2016.11.1 bugfix release is out, fixing a number of important / - security related issues discovered since the 2016.11 release. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2016.11.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.11 released

            -

            30 November 2016

            -
            -
            -

            The stable 2016.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2016.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.11-rc3 released

            -

            28 November 2016

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2016.11-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.11-rc2 released

            -

            13 November 2016

            -
            -
            -

            We have a new release candidate! Lots of - changes all over the tree, see - the CHANGES - file for details. -

            - -

            Head to the downloads page to pick up the - 2016.11-rc2 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.11-rc1 released

            -

            3 November 2016

            -
            -
            -

            We have a new release candidate! Lots of - changes all over the tree, see - the CHANGES - file for details, read the - announcement. -

            - -

            Head to the downloads page to pick up the - 2016.11-rc1 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.08.1 released

            -

            21 September 2016

            -
            -
            -

            The 2016.08.1 bugfix release is out. This release fixes a - potential entire root filesystem removal issue with the - external toolchain handling discovered since the 2016.08 - release. See the - CHANGES - file for more details, read the - announcement and go to the - downloads page to pick up the - 2016.08.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.08 released

            -

            1 September 2016

            -
            -
            -

            The stable 2016.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2016.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.08-rc3 released

            -

            30 August 2016

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2016.08-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.08-rc2 released

            -

            17 August 2016

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2016.08-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.08-rc1 released

            -

            6 August 2016

            -
            -
            -

            We have a new release candidate! Lots of - changes all over the tree, see - the CHANGES - file for details and read the - announcement -

            - -

            Head to the downloads page to pick up the - 2016.08-rc1 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.05 released

            -

            1 March 2016

            -
            -
            -

            The stable 2016.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2016.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.05-rc3 released

            -

            26 May 2016

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2016.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.05-rc2 released

            -

            17 May 2016

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2016.05-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.05-rc1 released

            -

            10 May 2016

            -
            -
            -

            We have a new release candidate! Lots of - changes all over the tree, see - the CHANGES - file for details and read the - announcement. -

            - -

            Head to the downloads page to pick up the - 2016.05-rc1 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.02 released

            -

            1 March 2016

            -
            -
            -

            The stable 2016.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2016.02 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.02-rc3 released

            -

            27 February 2016

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2016.02-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.02-rc2 released

            -

            18 February 2016

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2016.02-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2016.02-rc1 released

            -

            10 February 2016

            -
            -
            -

            We have a new release candidate! Lots of - changes all over the tree, see - the CHANGES - file for details and read the - announcement. -

            - -

            Head to the downloads page to pick up the - 2016.02-rc1 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.11.1 released

            -

            5 December 2015

            -
            -
            -

            The 2015.11.1 bugfix release is out - Thanks to everyone - contributing. This release fixes critical issues discovered - since the 2015.11 release. See the - CHANGES - file for more details, and go to the - downloads page to pick up the - 2015.11.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.11 released

            -

            30 November 2015

            -
            -
            -

            The stable 2015.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2015.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.11-rc3 released

            -

            26 November 2015

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2015.11-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.11-rc2 released

            -

            19 November 2015

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See the - CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2015.11-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.11-rc1 released

            -

            7 November 2015

            -
            -
            -

            We have a new release candidate! Lots of - changes all over the tree, see - the CHANGES - file for details. See also - the announcement - e-mail.

            - -

            Head to the downloads page to pick up the - 2015.11-rc1 - release candidate, and report any - problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.08.1 released

            -

            6 September 2015

            -
            -
            -

            The 2015.08.1 bugfix release is out - Thanks to everyone - contributing. This release fixes critical issues discovered since - the 2015.08 release. See the - CHANGES - file for more details, - and go to the downloads page to pick up the - 2015.08.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.08 released

            -

            31 August 2015

            -
            -
            -

            The stable 2015.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2015.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.08-rc2 released

            -

            24 August 2015

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see - the CHANGES - file for details, and - the release - announcement.

            - -

            Head to the downloads page to pick up the - 2015.08-rc2 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.08-rc1 released

            -

            5 August 2015

            -
            -
            -

            We have a new release candidate! Lots of changes all over the tree, see - the CHANGES - file for details, read - the announcement.

            - -

            Head to the downloads page to pick up the - 2015.08-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.05 released

            -

            31 May 2015

            -
            -
            -

            The stable 2015.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2015.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.05-rc3 released

            -

            22 May 2015

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up - the 2015.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.05-rc2 released

            -

            11 May 2015

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up the - 2015.05-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.05-rc1 released

            -

            4 May 2015

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2015.05-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.02 released

            -

            1 March 2015

            -
            -
            -

            The stable 2015.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2015.02 release.

            -
            -
            -
          • - - -
          • -
            -
            -
            -

            2015.02-rc3 released

            -

            24 February 2015

            -
            -
            -

            Release candidate 3 is out with more cleanups and security - / build fixes. See - the CHANGES - file for details.

            -

            Head to the downloads page to - pick up the - 2015.02-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.02-rc2 released

            -

            15 February 2015

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2015.02-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2015.02-rc1 released

            -

            8 February 2015

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2015.02-rc1 - release candidate, and report any problems found to - the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.11 released

            -

            1 December 2014

            -
            -
            -

            The stable 2014.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, - and go to the downloads page to pick up the - 2014.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.11-rc3 released

            -

            28 November 2014

            -
            -
            -

            Release candidate 3 is out with more cleanups and build - fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to - pick up the - 2014.11-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.11-rc2 released

            -

            21 November 2014

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2014.11-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Report from Buildroot Developers Meeting

            -

            13 November 2014

            -
            -
            -

            A report from the recent - - Buildroot Developers Meeting is now - available.

            - -

            Once again, thanks to all the participants and to - Mind for sponsoring the event.

            - -

            The next Developer Days will take place on February 2nd and - 3rd in Brussels, Belgium, right - after FOSDEM. See - the wiki - for more details.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.11-rc1 released

            -

            12 November 2014

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2014.11-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.08 released

            -

            1 September 2014

            -
            -
            -

            The stable 2014.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2014.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.08-rc3 released

            -

            26 August 2014

            -
            -
            -

            Release candidate 3 is out with more cleanups and build - fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2014.08-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.08-rc2 released

            -

            18 August 2014

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2014.08-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.08-rc1 released

            -

            8 August 2014

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2014.08-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.05 released

            -

            31 May 2014

            -
            -
            -

            The stable 2014.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2014.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.05-rc3 released

            -

            28 May 2014

            -
            -
            -

            Release candidate 3 is out with more cleanups and build - fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2014.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.05-rc2 released

            -

            21 May 2014

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to - pick up the - 2014.05-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.05-rc1 released

            -

            13 May 2014

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2014.05-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            27 February 2014

            -

            2014.02 released

            -
            -
            -

            The stable 2014.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, - and go to the downloads page to pick up the - 2014.02 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            25 February 2014

            -

            2014.02-rc3 released

            -
            -
            -

            Release candidate 3 is out with more cleanups and build - fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2014.02-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            20 February 2014

            -

            2014.02-rc2 released

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2014.02-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2014.02-rc1 released

            -

            11 February 2014

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2014.02-rc1 - release candidate, and report any problems found to the - mailing list or - bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            9 February 2014

            -

            Report from Buildroot Developers Meeting

            -
            -
            -

            A report from the recent - - Buildroot Developers Meeting is now - available.

            - -

            Once again, thanks to all the participants and to - Google and - Mind for sponsoring the event.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Upcoming Buildroot Developers meeting

            -

            30 January 2014

            -
            -
            -

            The upcoming Buildroot Developers meeting will take place in - Brussels on February, 3rd and 4th, after the - FOSDEM conference. Additional - details about the meeting can be found on the corresponding - - wiki page.

            - -

            Persons not able to join the meeting in Brussels can participate - remotely using Google Hangouts. Simply give your Google address to - thomas.petazzoni@free-electrons.com.

            - -

            This meeting is sponsored by - Google (for the meeting room) - and Mind (for the dinner). - Thanks to our sponsors!

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.11 released

            -

            30 November 2013

            -
            -
            -

            The stable 2013.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the announcement - and go to the downloads page to pick up the - 2013.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Slides from Embedded Linux Conference Europe

            -

            30 November 2013

            -
            -
            -

            The slides from the Buildroot presentation at the recent - Embedded Linux Conference Europe 2013 - are now - available.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.11-rc3 released

            -

            18 November 2013

            -
            -
            -

            Another week, another release candidate with more - fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.11-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.11-rc2 released

            -

            18 November 2013

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.11-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Announcement of the next Buildroot Developer Days

            -

            13 November 2013

            -
            -
            -

            The next Buildroot Developer Days meeting will take - place on Monday 3rd and Tuesday 4th February 2014 in Brussels, - Belgium - Just after - FOSDEM (February - 1st/2nd). This two days meeting is mainly open to Buildroot - developers and contributors, or Buildroot users having a prior - experience with the tool. It will allow developers to work on - Buildroot and discuss current issues, the future directions, and - more.

            - -

            In addition to the Buildroot event, we encourage embedded Linux - developers to propose talks for the Embedded and Mobile Developer - Room at FOSDEM. See - the CFP.

            - -

            We would like to thank our - sponsor Google for sponsoring - the event by providing all the needed logistics.

            - -

            For more details, see the - wiki - page dedicated to the meeting.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.11-rc1 released

            -

            12 November 2013

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2013.11-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Report from Buildroot Developers Meeting

            -

            11 November 2013

            -
            -
            -

            A report from the recent - - Buildroot Developers Meeting is now - available.

            - -

            Once again, thanks to all the participants and to - Imagination Technologies - for sponsoring the event.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.08.1 released

            -

            17 September 2013

            -
            -
            -

            The 2013.08.1 bugfix release is out - Thanks to everyone - contributing. This release fixes critical issues discovered since - the 2013.08 release. See the - CHANGES - file for more details, - and go to the downloads page to pick up the - 2013.08.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Buildroot Developer Days

            -

            16 September 2013

            -
            -
            -

            The next Buildroot Developer Days meeting will take - place on Saturday October 26th and Sunday October 27th 2013 in - Edinburgh, UK - Just after the - Embedded Linux Conference Europe (October 23th-24th). This two - days meeting is mainly open to Buildroot developers and - contributors, or Buildroot users having a prior experience with - the tool. It will allow developers to work on Buildroot and - discuss current issues, the future directions, and more.

            - -

            For more details, see the - wiki - page dedicated to the meeting.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.08 released

            -

            31 August 2013

            -
            -
            -

            The stable 2013.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the announcement - and go to the downloads page to pick up the - 2013.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.08-rc3 released

            -

            29 August 2013

            -
            -
            -

            Another week, another release candidate with more cleanups and - build fixes. See the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.08-rc3 - release candidate, and report any problems found to the mailing list or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.08-rc2 released

            -

            16 August 2013

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.08-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.08-rc1 released

            -

            5 August 2013

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.08-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.05 released

            -

            31 May 2013

            -
            -
            -

            The stable 2013.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2013.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.05-rc3 released

            -

            25 May 2013

            -
            -
            -

            Another week, another release candidate with more cleanups and - build fixes. See the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.05-rc2 released

            -

            15 May 2013

            -
            -
            -

            Another week, another release candidate with more cleanups and - build fixes. See the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.05-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.05-rc1 released

            -

            8 May 2013

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2013.05-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.02 released

            -

            28 February 2013

            -
            -
            -

            The stable 2013.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details - and go to the downloads page to pick up the - 2013.02 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.02-rc3 released

            -

            26 February 2013

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.02-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.02-rc2 released

            -

            19 February 2013

            -
            -
            -

            Another week, another release candidate with more cleanups and - build fixes. See the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2013.02-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2013.02-rc1 released

            -

            10 February 2013

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2013.02-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Report from Buildroot Developers Meeting

            -

            10 February 2013

            -
            -
            -

            A report from the recent Buildroot Developers Meeting is now - available. - Embedded Linux News also has a - - writeup about the event, including photos.

            - -

            Once again, thanks to all the participants and to - Google for sponsoring the event.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Next Buildroot Developers Meeting next to FOSDEM, Brussels

            -

            12 January 2013

            -
            -
            -

            The next Buildroot Developers Meeting will take place on Monday - 4th February 2013 and Tuesday 5th February 2013 in Brussels, - Belgium. Those dates have been chosen to immediately follow the - great FOSDEM conference.

            - -

            Attending this meeting is free, after registration by - contacting Thomas - Petazzoni. For more details about the meeting, please see - the related - Wiki page.

            - -

            We would like to - thank Google for providing the - meeting location and the Internet connection, and offering free - lunch and refreshments to the participants.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.11.1 released

            -

            3 January 2013

            -
            -
            -

            The 2012.11.1 bugfix release is out - Thanks to everyone - contributing. This release fixes critical issues discovered since - the 2012.11 release, most importantly with non-largefile builds on - recent Ubuntu versions. See the - CHANGES - file for more details, - and go to the downloads page to pick up the - 2012.11.1 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.11 released

            -

            2 December 2012

            -
            -
            -

            The stable 2012.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details - and go to the downloads page to pick up the - 2012.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.11-rc2 released

            -

            30 November 2012

            -
            -
            -

            RC2 is out with more bugfixes - See - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2012.11-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.11-rc1 released

            -

            17 November 2012

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2012.11-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Buildroot Developer Day

            -

            17 November 2012

            -
            -
            -

            A report from the recent Buildroot Developer Days - meeting in Barcelona, Spain is - now available. - Many thanks to all the participants, and a special thanks to - Arnout Vandecappelle from mind - for taking notes and Thomas Petazzoni - from Free Electrons - for handling all the practical arrangements, and naturally - our sponsors, Fluendo - and Synopsis. -

            -

            The next Developer Days will take place on February 4th and - 5th in Brussels, Belgium, right - after FOSDEM.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.08 released

            -

            31 August 2012

            -
            -
            -

            The stable 2012.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details and go to the downloads page to pick up the - 2012.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.08-rc3 released

            -

            25 August 2012

            -
            -
            -

            We have a new release candidate! Various fixes, and - addition of licensing informations on many - packages. See CHANGES - file for details

            - -

            Head to the downloads page to pick up the - 2012.08-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.08-rc2 released

            -

            15 August 2012

            -
            -
            -

            We have a new release candidate! Various fixes, and addition - of licensing informations on many - packages. See CHANGES - file for details

            - -

            Head to the downloads page to pick up the - 2012.08-rc2 - release candidate, and report any problems found to the mailing list or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.08-rc1 released

            -

            1 August 2012

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details

            - -

            Head to the downloads page to pick up the - 2012.08-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Buildroot Developer Day

            -

            22 July 2012

            -
            -
            -

            The next Buildroot Developer Day meeting will take place - on Saturday November 3th and Sunday November 4th 2012 in - Barcelona, Spain, just before - the Embedded - Linux Conference Europe (November 5th-7th). This two days - meeting is mainly opened to Buildroot developers and contributors, - or Buildroot users having a prior experience with the tool. This - meeting will allow developers to work and Buildroot, and discuss - current issues, the future directions, and more.

            - -

            For more details, see - the wiki - page dedicated to the meeting.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.05 released

            -

            30 May 2012

            -
            -
            -

            The stable 2012.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2012.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.05-rc3 released

            -

            25 May 2012

            -
            -
            -

            RC3 is out with more bugfixes - See - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2012.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.05-rc2 released

            -

            18 May 2012

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2012.05-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.05-rc1 released

            -

            10 May 2012

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2012.05-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Autobuilder Results Online

            -

            20 April 2012

            -
            -
            -

            The status of the autobuilders, which do repeated - randpackageconfig builds for continuous - integration testing, is now online - at autobuild.buildroot.org. The - code behind it can be found - in git.

            - -

            Thanks to Thomas Petazzoni for running the web interface, and - to The GCC Compile - Farm and Free - Electrons for hosting builders. Thomas also sends out a daily - summary of the build status to the mailing list.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.02 released

            -

            29 February 2012

            -
            -
            -

            The stable 2012.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2012.02 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.02-rc3 released

            -

            27 February 2012

            -
            -
            -

            RC3 is out with more bugfixes - See - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2012.02-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.02-rc2 released

            -

            19 February 2012

            -
            -
            -

            Another week, another release candidate with more cleanups - and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2012.02-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2012.02-rc1 released

            -

            12 February 2012

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, and read the - announcement.

            - -

            Head to the downloads page to pick up the - 2012.02-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Buildroot Developer Day

            -

            31 January 2012

            -
            -
            -

            Another Buildroot Developer Day will take place on - Friday, February 3rd in Brussels, Belgium - The day - before FOSDEM. See the - announcement - or - the Free - Electrons blog for more info.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.11 released

            -

            30 November 2011

            -
            -
            -

            The stable 2011.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2011.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.11-rc3 released

            -

            26 November 2011

            -
            -
            -

            RC3 is out with more bugfixes - See - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2011.11-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.11-rc2 released

            -

            18 November 2011

            -
            -
            -

            Another week, another release candidate with a bunch of - cleanups and build fixes. See - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2011.11-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.11-rc1 released

            -

            11 November 2011

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, and read the - announcement - -

            Head to the downloads page to pick up the - 2011.11-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.08 released

            -

            31 August 2011

            -
            -
            -

            The stable 2011.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, and go to the downloads page to pick up the - 2011.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.08-rc2 released

            -

            29 August 2011

            -
            -
            -

            RC2 is out with more bugfixes. See - the CHANGES - file for details, and read the - announcement. - -

            Head to the downloads page to pick up the - 2011.08-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.08-rc1 released

            -

            4 August 2011

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, and read the - announcement. - -

            Head to the downloads page to pick up the - 2011.08-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.05 released

            -

            27 May 2011

            -
            -
            -

            The stable 2011.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, and go to the downloads page to pick up the - 2011.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.05-rc2 released

            -

            24 May 2011

            -
            -
            -

            RC2 is out with more bugfixes. See - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2011.05-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.05-rc1 released

            -

            18 May 2011

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, and read the - announcement. - -

            Head to the downloads page to pick up the - 2011.05-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.02 released

            -

            28 February 2011

            -
            -
            -

            The stable 2011.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2011.02 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.02-rc2 released

            -

            24 February 2011

            -
            -
            -

            RC2 is out with more cleanups and bugfixes, see - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2011.02-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2011.02-rc1 released

            -

            14 February 2011

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, and read the - announcement. - -

            Head to the downloads page to pick up the - 2011.02-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.11 released

            -

            30 November 2010

            -
            -
            -

            The stable 2010.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2010.11 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.11-rc2 released

            -

            25 November 2010

            -
            -
            -

            RC2 is out with more cleanups and bugfixes, see - the CHANGES - file for details.

            - -

            Head to the downloads page to pick up the - 2010.11-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.11-rc1 released

            -

            8 November 2010

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details, and read the - announcement. - -

            Head to the downloads page to pick up the - 2010.11-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Buildroot Developer Day

            -

            28 September 2010

            -
            -
            -

            A Buildroot Developer Day will take place on - Friday, October 29th in Cambridge, UK - Just the day after the - Embedded - Linux Conference Europe. This Developer Day - aims at allowing Buildroot developers to meet and exchange - ideas on the project and its future. See the - announcement - for more info.

            - -

            Thanks to Thomas Petazzoni for taking care of the practical - arrangements.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.08 released

            -

            31 August 2010

            -
            -
            -

            The stable 2010.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2010.08 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.08-rc2 released

            -

            30 August 2010

            -
            -
            -

            RC2 is out with more cleanups and bugfixes, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2010.08-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            - - This is very much expected to be the final release candidate, - so give it a good test and expect a final 2010.08 release - before September unless critical issues are found.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.08-rc1 released

            -

            30 July 2010

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2010.08-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.05 released

            -

            30 May 2010

            -
            -
            -

            The stable 2010.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, read the - announcement - and go to the downloads page to pick up the - 2010.05 release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.05-rc3 released

            -

            27 May 2010

            -
            -
            -

            RC3 is out with more cleanups and bugfixes, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2010.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.05-rc2 released

            -

            11 May 2010

            -
            -
            -

            Another week, another release candidate with a bunch of - cleanups and build fixes.

            - -

            Head to the downloads page to pick up the - 2010.05-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.05-rc1 released

            -

            3 May 2010

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2010.05-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            FOSDEM slides online

            -

            2 May 2010

            -
            -
            -

            The slides from - the Cross - Build Systems: Present & Future session - at FOSDEM are - now online. -

            -
            -
          • - -
          • -
            -
            -
            -

            2010.02 released

            -

            26 February 2010

            -
            -
            -

            The stable 2010.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - CHANGES - file for more details, and go to - the downloads page to pick up - the 2010.02 - release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.02-rc2 released

            -

            23 February 2010

            -
            -
            -

            RC2 is out with more cleanups and bugfixes, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2010.02-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2010.02-rc1 released

            -

            9 February 2010

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2010.02-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.11 released

            -

            1 December 2009

            -
            -
            -

            The stable 2009.11 release is out - Thanks to everyone - contributing and testing the release candidates. See the - announcement - or CHANGES - for more details, and go to the downloads page - to pick up the 2009.11 - release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.11-rc2 released

            -

            29 November 2009

            -
            -
            -

            RC2 is out with more cleanups and bugfixes, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2009.11-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.11-rc1 released

            -

            23 November 2009

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2009.11-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            First Buildroot Developer Day

            -

            7 September 2009

            -
            -
            -

            The first Buildroot Developer Day will take place on - Saturday, October 17th in Grenoble, France, just the day after - Embedded Linux Conference Europe. This Developer Day aims - at allowing Buildroot developers to meet and exchange ideas on the - project and its future.

            - -

            As the number of places is limited, interested candidates are - invited to send an e-mail to Peter Korsgaard (jacmet at - uclibc dot org) and Thomas Petazzoni (thomas dot - petazzoni at free-electrons dot com).

            - -

            This Developer Day will take place thanks to the - sponsoring of Calao - Systems and Free - Electrons.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.08 released

            -

            31 August 2009

            -
            -
            -

            The stable 2009.08 release is out - Thanks to everyone - contributing and testing the release candidates. See the - announcement - or CHANGES - for more details, and go to the downloads page - to pick up the 2009.08 - release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.08-rc3 released

            -

            26 August 2009

            -
            -
            -

            A number of bugfixes have been added to the tree since RC2 - (especially thanks to Thomas Petazzoni) - See - the CHANGES - file for details. This is very much expected to be the final - release candidate, so give it a good test and expect a final - 2009.08 release next weekend unless critical issues are - found.

            - -

            Head to the downloads page to - pick up the - 2009.08-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.08-rc2 released

            -

            6 August 2009

            -
            -
            -

            RC2 is out with more cleanups and bugfixes, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2009.08-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.08-rc1 released

            -

            2 August 2009

            -
            -
            -

            We have a new release candidate! Lots of changes all over - the tree, see - the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2009.08-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.05 released

            -

            1 June 2009

            -
            -
            -

            The stable 2009.05 release is out - Thanks to everyone - contributing and testing the release candidates. See the - announcement - or CHANGES - for more details, and go to the downloads page - to pick up the 2009.05 - release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.05-rc3 released

            -

            27 May 2009

            -
            -
            -

            We had a number of fixes post-RC2, so RC3 is out - (see CHANGES - for details). Now is the moment to test and verify that - everything is working for your favorite config - Expect a - final 2009.05 very soon.

            - -

            Head to the downloads page to pick up the - 2009.05-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.05-rc2 released

            -

            19 May 2009

            -
            -
            -

            RC2 is out with more cleanups and bug fixes - (see CHANGES). - Unless big issues are found, expect this to be the last - release candidate before the release - So give it a good - test.

            - -

            Head to the downloads page to pick up the - 2009.05-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Buildroot.org

            -

            14 May 2009

            -
            -
            -

            Earl Levine has been so kind to donate - the buildroot.org domain to us, so the website can - now also be reached - at www.buildroot.org - (and git at - git.buildroot.org). - - Thanks a lot Earl!

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.05-rc1 released

            -

            5 May 2009

            -
            -
            -

            We have a new release candidate! Lots of changes all over the - tree, see the CHANGES - file for details. - -

            Head to the downloads page to pick up the - 2009.05-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Moved to git

            -

            3 May 2009

            -
            -
            -

            We've moved the source code - from Subversion - to Git. You can browse the - repo online - here, and clone - the repo using: -

            git clone git://git.buildroot.net/buildroot
            - See the Git Access page for more details. -

            -
            -
            -
          • - -
          • -
            -
            -
            -

            -

            27 March 2009

            -

            -
            -

            We have a logo! We have so - far been using the Busybox - logo on the website, as the website was a copy of - the Busybox one - But not - anymore, we now have a shiny new logo of our own.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.02 released

            -

            12 February 2009

            -
            -
            -

            The stable 2009.02 release is out - Thanks to everyone - contributing and testing the release candidates. See the - announcement - for more details, and go to the downloads page - to pick up the 2009.02 - release.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.02-rc4 released

            -

            9 February 2009

            -
            -
            -

            We had more than 50 changes since RC3, several of them - toolchain related, so decided to make a RC4 as well. This is - very much expected to be the final release candidate, so - give it a good test and expect a final 2009.02 release this - week unless critical issues are found.

            - -

            Head to the downloads page to - pick up the - 2009.02-rc4 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.02-rc3 released

            -

            31 January 2009

            -
            -
            -

            RC3 is out with more cleanups and bug fixes. Unless big - issues are found, expect this to be the last release - candidate before the release - So give it a good test.

            - -

            Head to the downloads page to - pick up the - 2009.02-rc3 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            2009.02-rc2 released

            -

            23 January 2009

            -
            -
            -

            Another week, another release candidate with a bunch of - cleanups and build fixes.

            -

            Head to the downloads page to - pick up the - 2009.02-rc2 - release candidate, and report any problems found to - the mailing list - or bug tracker.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Release candidate and new maintainer

            -

            16 January 2009

            -
            -
            - -

            It has been a long time coming, but we finally have a new - release candidate! - And a new maintainer to match (Peter - Korsgaard).

            - -

            Head to the downloads page to - pick up the - 2009.02-rc1 - release candidate, and report any problems found to - the mailing list - or bug tracker. The - plan is to release 2009.02 in time - for FOSDEM.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Buildroot mailing list

            -

            16 July 2006

            -
            -
            -

            Buildroot now has its own mailing list.

            -
            -
            -
          • - -
          • -
            -
            -
            -

            Buildroot webpage added

            -

            21 February 2005

            - -

            Buildroot is a set of Makefiles and patches that makes it easy generate a - cross-compilation toolchain and root filesystem for your target Linux - system using the uClibc C library. - Buildroot is useful mainly for people working with small or embedded - systems. Embedded systems often use processors that are not the regular - x86 processors everyone is used to using on their PC. It can be PowerPC - processors, MIPS processors, ARM processors, etc. And to be extra safe, - you do not need to be root to build or run buildroot.

            - -

            And as of today buildroot even has its own webpage, making it a first class - citizen of uclibc.org and busybox.net, and more importantly, make it easy - to find and point to buildroot.

            - -

            If you find a bug in buildroot, or wish to submit a patch - to fix a problem or add a shiny new feature, please use - the Bug and Patch - Tracking System to post the details, to make certain - your work is not lost

            -
            -
            -
          • -
          - -
          -
          -
          - - - diff --git a/docs/website/robots.txt b/docs/website/robots.txt deleted file mode 100644 index 1b425ee0f5..0000000000 --- a/docs/website/robots.txt +++ /dev/null @@ -1,2 +0,0 @@ -User-agent: * -Disallow: /cgi-bin/ diff --git a/docs/website/sponsors.html b/docs/website/sponsors.html deleted file mode 100644 index 2f3f6309ae..0000000000 --- a/docs/website/sponsors.html +++ /dev/null @@ -1,350 +0,0 @@ - - -
          -
          -
          - -
          -
          Current sponsors
          -
          - -
          -
          -
          -
          -
          - - - -
          -
          - Tap2Open - financially sponsored the Buildroot Association - in 2020.
          -
          -
          -
          - -
          -
          -
          -
          - - - -
          -
          - Logilin - financially sponsored the Buildroot Association - in 2020.
          -
          -
          -
          -
          -
          -
          - -
          -
          Sponsor of the Buildroot.org domain
          -
          -
          -

          The Buildroot community would like to thank - Zillabit for - donating the buildroot.org domain name and sponsoring - the registration fees 2009 - 2019.

          -
          -
          - - - -
          -
          -
          - -
          -
          Past sponsors
          -
          -

          Throughout its history, the Buildroot project has been sponsored by - various companies, that we would like to thank below.

          - -
          -
          -
          -
          -
          - - - -
          -
          - Smile provided the meeting location for the - ELCE 2019 - meeting and sponsored the Buildroot Summer Camp that took place on July 1-5 2016 - in Toulouse, France. Smile sponsored the participation of Romain Naour and paid - the food expenses for the meeting participants. - In 2018, Smile sponsored of LLVM/Clang integration into Buildroot, see the final - report. -
          -
          -
          -
          - -
          -
          -
          -
          - - - -
          -
          - Mind sponsored - financially the Buildroot Association for the ELCE - 2018 meeting, sponsored the dinner of the FOSDEM 2014, - 2015, 2016, 2017 and 2018 Developers Meeting - (Brussels) and ELCE 2016 (Berlin) and 2017 (Prague), - and the meeting room and the dinner for the ELCE 2014 - Developers Meeting (Düsseldorf). -
          -
          -
          -
          - -
          -
          -
          -
          -

          -

          -
          -
          -

          Google provided - the logistics for the FOSDEM 2013, FOSDEM 2014, - FOSDEM 2015, FOSDEM 2016, FOSDEM 2017, FOSDEM 2018, - FOSDEM 2019 and FOSDEM 2020 Developer Days in Brussels, - Belgium.

          -
          -
          -
          -
          -
          - -
          - -
          -
          -
          -
          -

          -

          -
          -
          - Amarula - Solutions sponsored the event by contributing - financially to the Buildroot Association. -
          -
          -
          -
          - -
          -
          -
          -
          -

          -

          -
          - -
          -

          Bootlin - sponsored financially the Buildroot Association for - the ELCE 2018 meeting, sponsored the meeting - location for the ELCE 2016 Developer Days in Berlin, - Germany, and the lunch for the ELCE 2009 Developer - Days in Grenoble, France.

          -
          -
          -
          -
          - -
          -
          -
          -
          - - - -
          -
          - Logilin sponsored - the ELCE 2018 Buildroot Developers meeting by - contributing financially to the Buildroot - Association. -
          -
          -
          -
          - -
          - -
          - -
          -
          -
          -
          - - - -
          -
          - Tk Open Systems - sponsored the ELCE 2018 Buildroot Developers meeting - by contributing financially to the Buildroot - Association. -
          -
          -
          -
          - -
          -
          -
          -
          - - - -
          -
          - Rockwell - Collins sponsored the ELCE 2018 Buildroot - Developers meeting by funding the social Saturday - dinner for the participants. -
          -
          -
          -
          - -
          -
          -
          -
          - - - -
          -
          - Scaleway - sponsored the complete logistics to organize our Buildroot - Hackathon in Paris in March 2018: meeting room, Internet - connectivity and accommodation. -
          -
          -
          -
          -
          - -
          -
          -
          -
          -
          -

          -

          -
          -
          - Imagination Technologies - sponsored the meeting room and dinner of the ELCE 2013 - Developer Days in Edinburgh, UK. -
          -
          -
          -
          - -
          -
          -
          -
          -

          -

          -
          -
          -

          CircuitCo sponsored - several development boards for the Google Summer of Code - 2013 project on Buildroot.

          -
          -
          -
          -
          - -
          -
          -
          -
          -

          -

          -
          -
          -

          BoundaryDevices - sponsored an i.MX6 development board for the Google Summer of - Code 2013 project on Buildroot.

          -
          -
          -
          -
          -
          - -
          -
          -
          -
          -
          -

          -

          -
          -
          -

          Fluendo sponsored the - meeting room for the ELCE 2012 Developer Days in Barcelona - Spain.

          -
          -
          -
          -
          - -
          -
          -
          -
          -

          -

          -
          -
          -

          Synopsys sponsored the - dinner for the ELCE 2012 Developer Days in Barcelona, Spain.

          -
          -
          -
          -
          - -
          -
          -
          -
          -

          -

          -
          -
          -

          Calao Systems - provided a a meeting room for the ELCE 2009 Developer Days - in Grenoble, France.

          -
          -
          -
          -
          -
          - -
          -
          -
          - - diff --git a/docs/website/support.html b/docs/website/support.html deleted file mode 100644 index 90231f601c..0000000000 --- a/docs/website/support.html +++ /dev/null @@ -1,124 +0,0 @@ - - -
          -
          -
          - -
          -
          Support
          -
          -

          You can get support for Buildroot through three main channels:

          - -
          -
          -
          -
          IRC
          -
          -
          -
          - -
          -
          -

          The Buildroot IRC channel is - #buildroot, hosted on OFTC. If you do not have an IRC client, you can - use the OFTC web interface. - When asking for help on IRC, share relevant logs or pieces of code using a code - sharing website.

          - -

          Note that due to excessive spamming on IRC, the channel can only be - joined if you are a registered user with - OFTC NickServ - service. Follow the instructions to register as a user with a password, - and then join the #buildroot channel.

          -
          -
          -
          -
          -
          - -
          -
          -
          Mailing List Information
          -
          -
          -
          - -
          -
          -

          The mailing list is for discussion and - development. You can subscribe by visiting - this - page. Only subscribers to the Buildroot - mailing list are allowed to post to this - list. Archives are available - from Mailman - and lore.kernel.org. - -

          Search the List Archives

          -

          Please search the mailing list archives before asking questions on the mailing - list, since there is a good chance someone else has asked the same question - before.

          - -
          - - -
          -
          -
          -
          -
          -
          - -
          -
          -
          Bug Tracker
          -
          -
          -
          - -
          -
          -

          If you think you found a bug in Buildroot, you can use the - Bug Tracker to post your bugs and/or - participate to find solutions to existing problems.

          - -

          Note: patches are only accepted through the mailing list.

          -
          -
          -
          -
          -
          -
          -
          -
          - -
          -
          Commercial support
          -
          -

          In addition, the following companies are able to provide commercial - support. Only companies heavily involved in Buildroot maintenance and - community are listed here.

          - -
          -
          -
          - - - - - - - - - -
          -
          -
          -
          -
          - -
          -
          -
          - - diff --git a/package/Config.in b/package/Config.in index cced7997ab..dcbdf62819 100644 --- a/package/Config.in +++ b/package/Config.in @@ -1992,6 +1992,7 @@ endif source "package/qlibc/Config.in" source "package/riemann-c-client/Config.in" source "package/shapelib/Config.in" + source "package/shredos/Config.in" source "package/skalibs/Config.in" source "package/sphinxbase/Config.in" source "package/startup-notification/Config.in" diff --git a/package/nwipe/nwipe.hash b/package/nwipe/nwipe.hash index 3d28fca2e5..4aa1fe18ab 100644 --- a/package/nwipe/nwipe.hash +++ b/package/nwipe/nwipe.hash @@ -1,2 +1 @@ -sha1 04805645ef11b5773167c6b432cc7844a4f27b97 nwipe-v0.32.014.tar.gz - +sha1 95286cb23de3d54137ddf544bf55874c30b75857 nwipe-v0.32.023.tar.gz diff --git a/package/nwipe/nwipe.mk b/package/nwipe/nwipe.mk index efeaa0297b..18fe2dacb9 100644 --- a/package/nwipe/nwipe.mk +++ b/package/nwipe/nwipe.mk @@ -4,7 +4,7 @@ # ################################################################################ -NWIPE_VERSION = v0.32.014 +NWIPE_VERSION = v0.32.023 NWIPE_SITE = $(call github,partialvolume,nwipe,$(NWIPE_VERSION)) NWIPE_DEPENDENCIES = ncurses parted dmidecode coreutils

        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 YaKC5#2#L<9JbB_0*dOS6x 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

-
-
- - -
-
Becoming a member
-
- -

To become a member, an individual or a company simply has - to pay its yearly membership. For an individual, the minimum - membership fee per year is 10 EUR. For a company, the - minimum membership fee per year is 150 EUR. Individuals and - companies are free to give more than the minimum - required.

- -

The membership is valid for the current civil year, i.e - any membership fee paid in 2019 is valid through December 31, - 2019.

- -

Once the membership fee is received, it will be listed in - the - association accounting - files, which serve as the official list of - members. Therefore, members accept that their name and the - amount of their membership fee is made public.

- -

There are two possibilities to pay the membership - fee:

- -
    - -
  • A direct wire-transfer to the association bank - account. Since the bank account is located in France, this - is completely free of charge for any person or company - located in the European Union. The IBAN number of the - association bank account is FR53 2004 1010 1615 0958 - 0P03 772.
  • - -
  • A Paypal payment to the association Paypal account, - whose address - is buildroot-association@buildroot.org.
  • - -
- -
-
- -
-
Sponsoring the project
-
- -

Companies willing to help the Buildroot project can do so - by making a donation to the Buildroot - Association. In exchange for these donations, companies - will be listed on our Sponsors - page and will be thanked in our release announcements.

- -

As the Buildroot Association is a legal entity - registered in France, it is able to deliver a bill and/or - receipt.

- -

Please - contact buildroot-association@buildroot.org - if you are a company interested in making a donation.

- -
-
- -
-
-