Go to file
Thomas Petazzoni 487e21cff6 New, simpler, infrastructure for building the Linux kernel
This patch introduces a single, simple, infrastructure to build the
Linux kernel. The configuration is limited to :

 * Kernel version: a fixed recent stable version, same as kernel
   headers version (for internal toolchains only), custom stable
   version, or custom tarball URL

 * Kernel patch: either a local file, directory or an URL

 * Kernel configuration: either the name of a defconfig or the
   location of a custom configuration file

 * Kernel image: either uImage, bzImage, zImage or vmlinux.

Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
2010-06-22 21:20:25 +02:00
boot at91dataflashboot: fix patch target 2010-06-14 23:06:37 +02:00
configs Config.in.mirrors: Use sources.buildroot.net as default backup site 2010-06-21 23:02:31 +02:00
docs docs: Document location of .config for out-of-tree builds 2010-06-21 23:07:12 +02:00
fs jffs2: let makedevs create device files 2010-06-05 21:23:28 +02:00
linux New, simpler, infrastructure for building the Linux kernel 2010-06-22 21:20:25 +02:00
package check-lxdialog.sh: use mktemp for temporary file 2010-06-21 23:02:24 +02:00
scripts Merge branch 'pkg-stats-fixes' of git://git.busybox.net/~tpetazzoni/git/buildroot 2010-05-27 14:11:53 +02:00
target Config.in.mirrors: Use sources.buildroot.net as default backup site 2010-06-21 23:02:31 +02:00
toolchain check-host-sed.sh: use mktemp for temporary file 2010-06-21 23:02:31 +02:00
.defconfig
.gitignore .gitignore: Update to the new directory hierachy 2009-09-23 09:16:07 +02:00
CHANGES Move config files into output directory for out-of-tree build 2010-06-21 22:06:00 +02:00
Config.in New, simpler, infrastructure for building the Linux kernel 2010-06-22 21:20:25 +02:00
COPYING
Makefile New, simpler, infrastructure for building the Linux kernel 2010-06-22 21:20:25 +02:00
TODO

To build and use the buildroot stuff, do the following:

1) run 'make menuconfig'
2) select the packages you wish to compile
3) run 'make'
4) wait while it compiles
5) Use your shiny new root filesystem.  Depending on which sortof
    root filesystem you selected, you may want to loop mount it,
    chroot into it, nfs mount it on your target device, burn it
    to flash, or whatever is appropriate for your target system.

You do not need to be root to build or run buildroot.  Have fun!

 -Erik

Offline build:
==============

In order to do an offline-build (not connected to the net), fetch all
selected source by issuing a
$ make source

before you disconnect.
If your build-host is never connected, then you have to copy buildroot
and your toplevel .config to a machine that has an internet-connection
and issue "make source" there, then copy the content of your dl/ dir to
the build-host.

Building out-of-tree:
=====================

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

$ make O=/tmp/build

And all the output files (including .config) will be located under /tmp/build.

More finegrained configuration:
===============================

You can specify a config-file for uClibc:
$ make UCLIBC_CONFIG_FILE=/my/uClibc.config

And you can specify a config-file for busybox:
$ make BUSYBOX_CONFIG_FILE=/my/busybox.config

To use a non-standard host-compiler (if you do not have 'gcc'),
make sure that the compiler is in your PATH and that the library paths are
setup properly, if your compiler is built dynamically:
$ make HOSTCC=gcc-4.3.orig HOSTCXX=gcc-4.3-mine

Depending on your configuration, there are some targets you can use to
use menuconfig of certain packages. This includes:
$ make HOSTCC=gcc-4.3 linux26-menuconfig
$ make HOSTCC=gcc-4.3 uclibc-menuconfig
$ make HOSTCC=gcc-4.3 busybox-menuconfig

Please feed suggestions, bug reports, insults, and bribes back to the
buildroot mailing list: buildroot@uclibc.org