support/misc: Adding Vagrant file for provisioning
[buildroot-gz.git] / docs / manual / customize.txt
blob484413e4d8b98d4b20f659ef22620bc78e3bf414
1 // -*- mode:doc; -*-
2 // vim: set syntax=asciidoc:
4 [[customize]]
5 == Project-specific customization
7 Typical actions you may need to perform for a given project are:
9 * configuring Buildroot (including build options and toolchain,
10   bootloader, kernel, package and filesystem image type selection)
11 * configuring other components, like the Linux kernel and BusyBox
12 * customizing the generated target filesystem
13   ** adding or overwriting files on the target filesystem (using
14      +BR2_ROOTFS_OVERLAY+)
15   ** modifying or deleting files on the target filesystem (using
16      +BR2_ROOTFS_POST_BUILD_SCRIPT+)
17   ** running arbitrary commands prior to generating the filesystem image
18      (using +BR2_ROOTFS_POST_BUILD_SCRIPT+)
19   ** setting file permissions and ownership (using
20      +BR2_ROOTFS_DEVICE_TABLE+)
21   ** adding custom devices nodes (using
22      +BR2_ROOTFS_STATIC_DEVICE_TABLE+)
23 * adding custom user accounts (using +BR2_ROOTFS_USERS_TABLES+)
24 * running arbitrary commands after generating the filesystem image
25   (using +BR2_ROOTFS_POST_IMAGE_SCRIPT+)
26 * adding project-specific patches to some packages (using
27   +BR2_GLOBAL_PATCH_DIR+)
28 * adding project-specific packages
30 An important note regarding such 'project-specific' customizations:
31 please carefully consider which changes are indeed project-specific and
32 which changes are also useful to developers outside your project. The
33 Buildroot community highly recommends and encourages the upstreaming of
34 improvements, packages and board support to the official Buildroot
35 project. Of course, it is sometimes not possible or desirable to
36 upstream because the changes are highly specific or proprietary.
38 This chapter describes how to make such project-specific customizations
39 in Buildroot and how to store them in a way that you can build the same
40 image in a reproducible way, even after running 'make clean'. By
41 following the recommended strategy, you can even use the same Buildroot
42 tree to build multiple distinct projects!
44 include::customize-directory-structure.txt[]
46 include::customize-outside-br.txt[]
48 include::customize-configuration.txt[]
50 include::customize-rootfs.txt[]
52 include::customize-users-tables.txt[]
54 include::customize-post-image.txt[]
56 include::customize-patches.txt[]
58 include::customize-packages.txt[]
60 include::customize-quick-guide.txt[]