blob: 3ba08d0dace5771c23b762aac245afc993b0305b [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001# SPDX-License-Identifier: GPL-2.0+
Simon Glassc05694f2013-04-03 11:07:16 +00002# Copyright (c) 2013 The Chromium OS Authors.
Simon Glassc05694f2013-04-03 11:07:16 +00003
Simon Glass3ec03d42014-08-09 15:32:58 -06004(Please read 'How to change from MAKEALL' if you are used to that tool)
5
Simon Glassd7c8a7d2016-07-27 20:33:06 -06006Quick-start
7===========
8
9If you just want to quickly set up buildman so you can build something (for
10example Raspberry Pi 2):
11
12 cd /path/to/u-boot
13 PATH=$PATH:`pwd`/tools/buildman
14 buildman --fetch-arch arm
15 buildman -k rpi_2
16 ls ../current/rpi_2
17 # u-boot.bin is the output image
18
19
Simon Glassc05694f2013-04-03 11:07:16 +000020What is this?
21=============
22
23This tool handles building U-Boot to check that you have not broken it
24with your patch series. It can build each individual commit and report
25which boards fail on which commits, and which errors come up. It aims
26to make full use of multi-processor machines.
27
28A key feature of buildman is its output summary, which allows warnings,
29errors or image size increases in a particular commit or board to be
30quickly identified and the offending commit pinpointed. This can be a big
31help for anyone working with >10 patches at a time.
32
33
34Caveats
35=======
36
Simon Glassc05694f2013-04-03 11:07:16 +000037Buildman can be stopped and restarted, in which case it will continue
38where it left off. This should happen cleanly and without side-effects.
39If not, it is a bug, for which a patch would be welcome.
40
41Buildman gets so tied up in its work that it can ignore the outside world.
42You may need to press Ctrl-C several times to quit it. Also it will print
Simon Glass7b94ab52016-07-27 20:32:58 -060043out various exceptions when stopped. You may have to kill it since the
44Ctrl-C handling is somewhat broken.
Simon Glassc05694f2013-04-03 11:07:16 +000045
46
47Theory of Operation
48===================
49
50(please read this section in full twice or you will be perpetually confused)
51
52Buildman is a builder. It is not make, although it runs make. It does not
53produce any useful output on the terminal while building, except for
Simon Glass4d7efb52020-04-09 15:08:48 -060054progress information (but see -v below). All the output (errors, warnings and
55binaries if you ask for them) is stored in output directories, which you can
56look at from a separate 'buildman -s' instance while the build is progressing,
57or when it is finished.
Simon Glassc05694f2013-04-03 11:07:16 +000058
Simon Glass7b94ab52016-07-27 20:32:58 -060059Buildman is designed to build entire git branches, i.e. muliple commits. It
Simon Glass4d7efb52020-04-09 15:08:48 -060060can be run repeatedly on the same branch after making changes to commits on
61that branch. In this case it will automatically rebuild commits which have
62changed (and remove its old results for that commit). It is possible to build
63a branch for one board, then later build it for another board. This adds to
64the output, so now you have results for two boards. If you want buildman to
65re-build a commit it has already built (e.g. because of a toolchain update),
66use the -f flag.
Simon Glass7b94ab52016-07-27 20:32:58 -060067
Simon Glassc05694f2013-04-03 11:07:16 +000068Buildman produces a concise summary of which boards succeeded and failed.
69It shows which commit introduced which board failure using a simple
Simon Glass4d7efb52020-04-09 15:08:48 -060070red/green colour coding (with yellow/cyan for warnings). Full error
71information can be requested, in which case it is de-duped and displayed
72against the commit that introduced the error. An example workflow is below.
Simon Glassc05694f2013-04-03 11:07:16 +000073
74Buildman stores image size information and can report changes in image size
75from commit to commit. An example of this is below.
76
77Buildman starts multiple threads, and each thread builds for one board at
78a time. A thread starts at the first commit, configures the source for your
79board and builds it. Then it checks out the next commit and does an
Simon Glass4d7efb52020-04-09 15:08:48 -060080incremental build (i.e. not using 'make xxx_defconfig' unless you use -C).
81Eventually the thread reaches the last commit and stops. If a commit causes
82an error or warning, buildman will try it again after reconfiguring (but see
83-Q). Thus some commits may be built twice, with the first result silently
84discarded. Lots of errors and warnings will causes lots of reconfigures and your
85build will be very slow. This is because a file that produces just a warning
86would not normally be rebuilt in an incremental build. Once a thread finishes
87building all the commits for a board, it starts on the commits for another
88board.
Simon Glassc05694f2013-04-03 11:07:16 +000089
90Buildman works in an entirely separate place from your U-Boot repository.
91It creates a separate working directory for each thread, and puts the
92output files in the working directory, organised by commit name and board
Simon Glass4d7efb52020-04-09 15:08:48 -060093name, in a two-level hierarchy (but see -P).
Simon Glassc05694f2013-04-03 11:07:16 +000094
95Buildman is invoked in your U-Boot directory, the one with the .git
96directory. It clones this repository into a copy for each thread, and the
97threads do not affect the state of your git repository. Any checkouts done
98by the thread affect only the working directory for that thread.
99
Simon Glassfa1cfee2014-08-09 15:32:57 -0600100Buildman automatically selects the correct tool chain for each board. You
Simon Glass4d7efb52020-04-09 15:08:48 -0600101must supply suitable tool chains (see --fetch-arch), but buildman takes care
102of selecting the right one.
Simon Glassc05694f2013-04-03 11:07:16 +0000103
Simon Glass78e418e2014-08-09 15:33:03 -0600104Buildman generally builds a branch (with the -b flag), and in this case
Simon Glass4d7efb52020-04-09 15:08:48 -0600105builds the upstream commit as well, for comparison. So even if you have one
106commit in your branch, two commits will be built. Put all your commits in a
107branch, set the branch's upstream to a valid value, and all will be well.
108Otherwise buildman will perform random actions. Use -n to check what the
109random actions might be.
110
111Buildman effectively has two modes: without -s it builds, with -s it
112summarises the results of previous (or active) builds.
Simon Glass78e418e2014-08-09 15:33:03 -0600113
Simon Glass4d7efb52020-04-09 15:08:48 -0600114If you just want to build the current source tree, leave off the -b flag.
115This will display results and errors as they happen. You can still look at
116them later using -se. Note that buildman will assume that the source has
117changed, and will build all specified boards in this case.
Simon Glassc05694f2013-04-03 11:07:16 +0000118
119Buildman is optimised for building many commits at once, for many boards.
120On multi-core machines, Buildman is fast because it uses most of the
121available CPU power. When it gets to the end, or if you are building just
122a few commits or boards, it will be pretty slow. As a tip, if you don't
123plan to use your machine for anything else, you can use -T to increase the
124number of threads beyond the default.
125
Simon Glassd9eb9f02018-06-11 23:26:46 -0600126
127Selecting which boards to build
128===============================
129
Stephen Warren08447632013-10-10 10:00:20 -0600130Buildman lets you build all boards, or a subset. Specify the subset by passing
Simon Glass0c477b72022-07-11 19:04:04 -0600131command-line arguments that list the desired build target, architecture,
132CPU, board name, vendor, SoC or options. Multiple arguments are allowed. Each
133argument will be interpreted as a regular expression, so behaviour is a superset
134of exact or substring matching. Examples are:
Stephen Warren08447632013-10-10 10:00:20 -0600135
136* 'tegra20' All boards with a Tegra20 SoC
137* 'tegra' All boards with any Tegra Soc (Tegra20, Tegra30, Tegra114...)
138* '^tegra[23]0$' All boards with either Tegra20 or Tegra30 SoC
139* 'powerpc' All PowerPC boards
Simon Glassc05694f2013-04-03 11:07:16 +0000140
Simon Glassaa40f9a2014-08-09 15:33:08 -0600141While the default is to OR the terms together, you can also make use of
142the '&' operator to limit the selection:
143
144* 'freescale & arm sandbox' All Freescale boards with ARM architecture,
145 plus sandbox
146
Simon Glass924c73a2014-08-28 09:43:41 -0600147You can also use -x to specifically exclude some boards. For example:
148
Baruch Siach752db5b2019-07-11 12:57:41 +0300149 buildman arm -x nvidia,freescale,.*ball$
Simon Glass924c73a2014-08-28 09:43:41 -0600150
151means to build all arm boards except nvidia, freescale and anything ending
152with 'ball'.
153
Simon Glass9aad8ce2020-04-09 15:08:49 -0600154For building specific boards you can use the --boards (or --bo) option, which
155takes a comma-separated list of board target names and be used multiple times
156on the command line:
Simon Glassd9eb9f02018-06-11 23:26:46 -0600157
Baruch Siach752db5b2019-07-11 12:57:41 +0300158 buildman --boards sandbox,snow --boards
Simon Glassd9eb9f02018-06-11 23:26:46 -0600159
Dirk Behme5f01c7a2014-12-23 07:41:26 +0100160It is convenient to use the -n option to see what will be built based on
Simon Glass6af145f2017-01-23 05:38:56 -0700161the subset given. Use -v as well to get an actual list of boards.
Simon Glassaa40f9a2014-08-09 15:33:08 -0600162
Simon Glassc05694f2013-04-03 11:07:16 +0000163Buildman does not store intermediate object files. It optionally copies
Simon Glassd9eb9f02018-06-11 23:26:46 -0600164the binary output into a directory when a build is successful (-k). Size
Simon Glassc05694f2013-04-03 11:07:16 +0000165information is always recorded. It needs a fair bit of disk space to work,
166typically 250MB per thread.
167
168
169Setting up
170==========
171
1721. Get the U-Boot source. You probably already have it, but if not these
173steps should get you started with a repo and some commits for testing.
174
175$ cd /path/to/u-boot
176$ git clone git://git.denx.de/u-boot.git .
177$ git checkout -b my-branch origin/master
178$ # Add some commits to the branch, reading for testing
179
Simon Glass3cb033e2014-12-01 17:34:02 -07001802. Create ~/.buildman to tell buildman where to find tool chains (see 'The
181.buildman file' later for details). As an example:
Simon Glassc05694f2013-04-03 11:07:16 +0000182
183# Buildman settings file
184
185[toolchain]
186root: /
187rest: /toolchains/*
188eldk: /opt/eldk-4.2
Simon Glass9a016392014-08-09 15:33:07 -0600189arm: /opt/linaro/gcc-linaro-arm-linux-gnueabihf-4.8-2013.08_linux
190aarch64: /opt/linaro/gcc-linaro-aarch64-none-elf-4.8-2013.10_linux
Simon Glassc05694f2013-04-03 11:07:16 +0000191
192[toolchain-alias]
193x86: i386
194blackfin: bfin
Bin Meng07a50f92016-02-21 21:18:02 -0800195openrisc: or1k
Simon Glassc05694f2013-04-03 11:07:16 +0000196
197
198This selects the available toolchain paths. Add the base directory for
199each of your toolchains here. Buildman will search inside these directories
200and also in any '/usr' and '/usr/bin' subdirectories.
201
202Make sure the tags (here root: rest: and eldk:) are unique.
203
204The toolchain-alias section indicates that the i386 toolchain should be used
205to build x86 commits.
206
Simon Glassf5902732016-03-12 18:50:32 -0700207Note that you can also specific exactly toolchain prefixes if you like:
208
209[toolchain-prefix]
210arm: /opt/arm-eabi-4.6/bin/arm-eabi-
211
212or even:
213
214[toolchain-prefix]
215arm: /opt/arm-eabi-4.6/bin/arm-eabi-gcc
216
217This tells buildman that you want to use this exact toolchain for the arm
218architecture. This will override any toolchains found by searching using the
219[toolchain] settings.
220
221Since the toolchain prefix is an explicit request, buildman will report an
222error if a toolchain is not found with that prefix. The current PATH will be
223searched, so it is possible to use:
224
225[toolchain-prefix]
226arm: arm-none-eabi-
227
228and buildman will find arm-none-eabi-gcc in /usr/bin if you have it installed.
Simon Glassc05694f2013-04-03 11:07:16 +0000229
York Sunfb197a82016-10-04 14:33:51 -0700230[toolchain-wrapper]
231wrapper: ccache
232
233This tells buildman to use a compiler wrapper in front of CROSS_COMPILE. In
234this example, ccache. It doesn't affect the toolchain scan. The wrapper is
235added when CROSS_COMPILE environtal variable is set. The name in this
236section is ignored. If more than one line is provided, only the last one
237is taken.
238
Simon Glass91075712014-12-01 17:34:01 -07002393. Make sure you have the require Python pre-requisites
240
Simon Glass7e803e12014-12-01 17:34:06 -0700241Buildman uses multiprocessing, Queue, shutil, StringIO, ConfigParser and
242urllib2. These should normally be available, but if you get an error like
243this then you will need to obtain those modules:
Simon Glass91075712014-12-01 17:34:01 -0700244
245 ImportError: No module named multiprocessing
246
247
2484. Check the available toolchains
Simon Glassc05694f2013-04-03 11:07:16 +0000249
250Run this check to make sure that you have a toolchain for every architecture.
251
252$ ./tools/buildman/buildman --list-tool-chains
253Scanning for tool chains
Simon Glassf5902732016-03-12 18:50:32 -0700254 - scanning prefix '/opt/gcc-4.6.3-nolibc/x86_64-linux/bin/x86_64-linux-'
255Tool chain test: OK, arch='x86', priority 1
256 - scanning prefix '/opt/arm-eabi-4.6/bin/arm-eabi-'
257Tool chain test: OK, arch='arm', priority 1
258 - scanning path '/toolchains/gcc-4.9.0-nolibc/i386-linux'
259 - looking in '/toolchains/gcc-4.9.0-nolibc/i386-linux/.'
260 - looking in '/toolchains/gcc-4.9.0-nolibc/i386-linux/bin'
261 - found '/toolchains/gcc-4.9.0-nolibc/i386-linux/bin/i386-linux-gcc'
262 - looking in '/toolchains/gcc-4.9.0-nolibc/i386-linux/usr/bin'
263Tool chain test: OK, arch='i386', priority 4
264 - scanning path '/toolchains/gcc-4.9.0-nolibc/aarch64-linux'
265 - looking in '/toolchains/gcc-4.9.0-nolibc/aarch64-linux/.'
266 - looking in '/toolchains/gcc-4.9.0-nolibc/aarch64-linux/bin'
267 - found '/toolchains/gcc-4.9.0-nolibc/aarch64-linux/bin/aarch64-linux-gcc'
268 - looking in '/toolchains/gcc-4.9.0-nolibc/aarch64-linux/usr/bin'
269Tool chain test: OK, arch='aarch64', priority 4
270 - scanning path '/toolchains/gcc-4.9.0-nolibc/microblaze-linux'
271 - looking in '/toolchains/gcc-4.9.0-nolibc/microblaze-linux/.'
272 - looking in '/toolchains/gcc-4.9.0-nolibc/microblaze-linux/bin'
273 - found '/toolchains/gcc-4.9.0-nolibc/microblaze-linux/bin/microblaze-linux-gcc'
274 - looking in '/toolchains/gcc-4.9.0-nolibc/microblaze-linux/usr/bin'
275Tool chain test: OK, arch='microblaze', priority 4
276 - scanning path '/toolchains/gcc-4.9.0-nolibc/mips64-linux'
277 - looking in '/toolchains/gcc-4.9.0-nolibc/mips64-linux/.'
278 - looking in '/toolchains/gcc-4.9.0-nolibc/mips64-linux/bin'
279 - found '/toolchains/gcc-4.9.0-nolibc/mips64-linux/bin/mips64-linux-gcc'
280 - looking in '/toolchains/gcc-4.9.0-nolibc/mips64-linux/usr/bin'
281Tool chain test: OK, arch='mips64', priority 4
282 - scanning path '/toolchains/gcc-4.9.0-nolibc/sparc64-linux'
283 - looking in '/toolchains/gcc-4.9.0-nolibc/sparc64-linux/.'
284 - looking in '/toolchains/gcc-4.9.0-nolibc/sparc64-linux/bin'
285 - found '/toolchains/gcc-4.9.0-nolibc/sparc64-linux/bin/sparc64-linux-gcc'
286 - looking in '/toolchains/gcc-4.9.0-nolibc/sparc64-linux/usr/bin'
287Tool chain test: OK, arch='sparc64', priority 4
288 - scanning path '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi'
289 - looking in '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/.'
290 - looking in '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/bin'
291 - found '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/bin/arm-unknown-linux-gnueabi-gcc'
292 - looking in '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/usr/bin'
293Tool chain test: OK, arch='arm', priority 3
294Toolchain '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/bin/arm-unknown-linux-gnueabi-gcc' at priority 3 will be ignored because another toolchain for arch 'arm' has priority 1
295 - scanning path '/toolchains/gcc-4.9.0-nolibc/sparc-linux'
296 - looking in '/toolchains/gcc-4.9.0-nolibc/sparc-linux/.'
297 - looking in '/toolchains/gcc-4.9.0-nolibc/sparc-linux/bin'
298 - found '/toolchains/gcc-4.9.0-nolibc/sparc-linux/bin/sparc-linux-gcc'
299 - looking in '/toolchains/gcc-4.9.0-nolibc/sparc-linux/usr/bin'
300Tool chain test: OK, arch='sparc', priority 4
301 - scanning path '/toolchains/gcc-4.9.0-nolibc/mips-linux'
302 - looking in '/toolchains/gcc-4.9.0-nolibc/mips-linux/.'
303 - looking in '/toolchains/gcc-4.9.0-nolibc/mips-linux/bin'
304 - found '/toolchains/gcc-4.9.0-nolibc/mips-linux/bin/mips-linux-gcc'
305 - looking in '/toolchains/gcc-4.9.0-nolibc/mips-linux/usr/bin'
306Tool chain test: OK, arch='mips', priority 4
307 - scanning path '/toolchains/gcc-4.9.0-nolibc/x86_64-linux'
308 - looking in '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/.'
309 - looking in '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin'
310 - found '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-gcc'
311 - found '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-x86_64-linux-gcc'
312 - looking in '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/usr/bin'
313Tool chain test: OK, arch='x86_64', priority 4
314Tool chain test: OK, arch='x86_64', priority 4
315Toolchain '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-x86_64-linux-gcc' at priority 4 will be ignored because another toolchain for arch 'x86_64' has priority 4
316 - scanning path '/toolchains/gcc-4.9.0-nolibc/m68k-linux'
317 - looking in '/toolchains/gcc-4.9.0-nolibc/m68k-linux/.'
318 - looking in '/toolchains/gcc-4.9.0-nolibc/m68k-linux/bin'
319 - found '/toolchains/gcc-4.9.0-nolibc/m68k-linux/bin/m68k-linux-gcc'
320 - looking in '/toolchains/gcc-4.9.0-nolibc/m68k-linux/usr/bin'
321Tool chain test: OK, arch='m68k', priority 4
322 - scanning path '/toolchains/gcc-4.9.0-nolibc/powerpc-linux'
323 - looking in '/toolchains/gcc-4.9.0-nolibc/powerpc-linux/.'
324 - looking in '/toolchains/gcc-4.9.0-nolibc/powerpc-linux/bin'
325 - found '/toolchains/gcc-4.9.0-nolibc/powerpc-linux/bin/powerpc-linux-gcc'
326 - looking in '/toolchains/gcc-4.9.0-nolibc/powerpc-linux/usr/bin'
327Tool chain test: OK, arch='powerpc', priority 4
328 - scanning path '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux'
329 - looking in '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux/.'
330 - looking in '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux/bin'
331 - found '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux/bin/bfin-uclinux-gcc'
332 - looking in '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux/usr/bin'
333Tool chain test: OK, arch='bfin', priority 6
334 - scanning path '/toolchains/gcc-4.6.3-nolibc/sparc-linux'
335 - looking in '/toolchains/gcc-4.6.3-nolibc/sparc-linux/.'
336 - looking in '/toolchains/gcc-4.6.3-nolibc/sparc-linux/bin'
337 - found '/toolchains/gcc-4.6.3-nolibc/sparc-linux/bin/sparc-linux-gcc'
338 - looking in '/toolchains/gcc-4.6.3-nolibc/sparc-linux/usr/bin'
339Tool chain test: OK, arch='sparc', priority 4
340Toolchain '/toolchains/gcc-4.6.3-nolibc/sparc-linux/bin/sparc-linux-gcc' at priority 4 will be ignored because another toolchain for arch 'sparc' has priority 4
341 - scanning path '/toolchains/gcc-4.6.3-nolibc/mips-linux'
342 - looking in '/toolchains/gcc-4.6.3-nolibc/mips-linux/.'
343 - looking in '/toolchains/gcc-4.6.3-nolibc/mips-linux/bin'
344 - found '/toolchains/gcc-4.6.3-nolibc/mips-linux/bin/mips-linux-gcc'
345 - looking in '/toolchains/gcc-4.6.3-nolibc/mips-linux/usr/bin'
346Tool chain test: OK, arch='mips', priority 4
347Toolchain '/toolchains/gcc-4.6.3-nolibc/mips-linux/bin/mips-linux-gcc' at priority 4 will be ignored because another toolchain for arch 'mips' has priority 4
348 - scanning path '/toolchains/gcc-4.6.3-nolibc/m68k-linux'
349 - looking in '/toolchains/gcc-4.6.3-nolibc/m68k-linux/.'
350 - looking in '/toolchains/gcc-4.6.3-nolibc/m68k-linux/bin'
351 - found '/toolchains/gcc-4.6.3-nolibc/m68k-linux/bin/m68k-linux-gcc'
352 - looking in '/toolchains/gcc-4.6.3-nolibc/m68k-linux/usr/bin'
353Tool chain test: OK, arch='m68k', priority 4
354Toolchain '/toolchains/gcc-4.6.3-nolibc/m68k-linux/bin/m68k-linux-gcc' at priority 4 will be ignored because another toolchain for arch 'm68k' has priority 4
355 - scanning path '/toolchains/gcc-4.6.3-nolibc/powerpc-linux'
356 - looking in '/toolchains/gcc-4.6.3-nolibc/powerpc-linux/.'
357 - looking in '/toolchains/gcc-4.6.3-nolibc/powerpc-linux/bin'
358 - found '/toolchains/gcc-4.6.3-nolibc/powerpc-linux/bin/powerpc-linux-gcc'
359 - looking in '/toolchains/gcc-4.6.3-nolibc/powerpc-linux/usr/bin'
360Tool chain test: OK, arch='powerpc', priority 4
361Tool chain test: OK, arch='or32', priority 4
Simon Glassc05694f2013-04-03 11:07:16 +0000362 - scanning path '/'
363 - looking in '/.'
364 - looking in '/bin'
365 - looking in '/usr/bin'
Simon Glassf5902732016-03-12 18:50:32 -0700366 - found '/usr/bin/i586-mingw32msvc-gcc'
Simon Glassc05694f2013-04-03 11:07:16 +0000367 - found '/usr/bin/c89-gcc'
Simon Glassc05694f2013-04-03 11:07:16 +0000368 - found '/usr/bin/x86_64-linux-gnu-gcc'
Simon Glassf5902732016-03-12 18:50:32 -0700369 - found '/usr/bin/gcc'
370 - found '/usr/bin/c99-gcc'
371 - found '/usr/bin/arm-linux-gnueabi-gcc'
372 - found '/usr/bin/aarch64-linux-gnu-gcc'
373 - found '/usr/bin/winegcc'
374 - found '/usr/bin/arm-linux-gnueabihf-gcc'
375Tool chain test: OK, arch='i586', priority 11
376Tool chain test: OK, arch='c89', priority 11
377Tool chain test: OK, arch='x86_64', priority 4
378Toolchain '/usr/bin/x86_64-linux-gnu-gcc' at priority 4 will be ignored because another toolchain for arch 'x86_64' has priority 4
379Tool chain test: OK, arch='sandbox', priority 11
380Tool chain test: OK, arch='c99', priority 11
381Tool chain test: OK, arch='arm', priority 4
382Toolchain '/usr/bin/arm-linux-gnueabi-gcc' at priority 4 will be ignored because another toolchain for arch 'arm' has priority 1
383Tool chain test: OK, arch='aarch64', priority 4
384Toolchain '/usr/bin/aarch64-linux-gnu-gcc' at priority 4 will be ignored because another toolchain for arch 'aarch64' has priority 4
385Tool chain test: OK, arch='sandbox', priority 11
386Toolchain '/usr/bin/winegcc' at priority 11 will be ignored because another toolchain for arch 'sandbox' has priority 11
387Tool chain test: OK, arch='arm', priority 4
388Toolchain '/usr/bin/arm-linux-gnueabihf-gcc' at priority 4 will be ignored because another toolchain for arch 'arm' has priority 1
389List of available toolchains (34):
390aarch64 : /toolchains/gcc-4.9.0-nolibc/aarch64-linux/bin/aarch64-linux-gcc
391alpha : /toolchains/gcc-4.9.0-nolibc/alpha-linux/bin/alpha-linux-gcc
392am33_2.0 : /toolchains/gcc-4.9.0-nolibc/am33_2.0-linux/bin/am33_2.0-linux-gcc
393arm : /opt/arm-eabi-4.6/bin/arm-eabi-gcc
Simon Glassf5902732016-03-12 18:50:32 -0700394bfin : /toolchains/gcc-4.6.3-nolibc/bfin-uclinux/bin/bfin-uclinux-gcc
Simon Glassc05694f2013-04-03 11:07:16 +0000395c89 : /usr/bin/c89-gcc
396c99 : /usr/bin/c99-gcc
Simon Glassf5902732016-03-12 18:50:32 -0700397frv : /toolchains/gcc-4.9.0-nolibc/frv-linux/bin/frv-linux-gcc
398h8300 : /toolchains/gcc-4.9.0-nolibc/h8300-elf/bin/h8300-elf-gcc
399hppa : /toolchains/gcc-4.9.0-nolibc/hppa-linux/bin/hppa-linux-gcc
400hppa64 : /toolchains/gcc-4.9.0-nolibc/hppa64-linux/bin/hppa64-linux-gcc
401i386 : /toolchains/gcc-4.9.0-nolibc/i386-linux/bin/i386-linux-gcc
402i586 : /usr/bin/i586-mingw32msvc-gcc
403ia64 : /toolchains/gcc-4.9.0-nolibc/ia64-linux/bin/ia64-linux-gcc
404m32r : /toolchains/gcc-4.9.0-nolibc/m32r-linux/bin/m32r-linux-gcc
405m68k : /toolchains/gcc-4.9.0-nolibc/m68k-linux/bin/m68k-linux-gcc
406microblaze: /toolchains/gcc-4.9.0-nolibc/microblaze-linux/bin/microblaze-linux-gcc
407mips : /toolchains/gcc-4.9.0-nolibc/mips-linux/bin/mips-linux-gcc
408mips64 : /toolchains/gcc-4.9.0-nolibc/mips64-linux/bin/mips64-linux-gcc
409or32 : /toolchains/gcc-4.5.1-nolibc/or32-linux/bin/or32-linux-gcc
410powerpc : /toolchains/gcc-4.9.0-nolibc/powerpc-linux/bin/powerpc-linux-gcc
411powerpc64 : /toolchains/gcc-4.9.0-nolibc/powerpc64-linux/bin/powerpc64-linux-gcc
412ppc64le : /toolchains/gcc-4.9.0-nolibc/ppc64le-linux/bin/ppc64le-linux-gcc
413s390x : /toolchains/gcc-4.9.0-nolibc/s390x-linux/bin/s390x-linux-gcc
Simon Glassc05694f2013-04-03 11:07:16 +0000414sandbox : /usr/bin/gcc
Simon Glassf5902732016-03-12 18:50:32 -0700415sh4 : /toolchains/gcc-4.6.3-nolibc/sh4-linux/bin/sh4-linux-gcc
416sparc : /toolchains/gcc-4.9.0-nolibc/sparc-linux/bin/sparc-linux-gcc
417sparc64 : /toolchains/gcc-4.9.0-nolibc/sparc64-linux/bin/sparc64-linux-gcc
418tilegx : /toolchains/gcc-4.6.2-nolibc/tilegx-linux/bin/tilegx-linux-gcc
419x86 : /opt/gcc-4.6.3-nolibc/x86_64-linux/bin/x86_64-linux-gcc
420x86_64 : /toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-gcc
Simon Glassc05694f2013-04-03 11:07:16 +0000421
422
423You can see that everything is covered, even some strange ones that won't
424be used (c88 and c99). This is a feature.
425
426
Simon Glass7e803e12014-12-01 17:34:06 -07004275. Install new toolchains if needed
428
429You can download toolchains and update the [toolchain] section of the
430settings file to find them.
431
432To make this easier, buildman can automatically download and install
433toolchains from kernel.org. First list the available architectures:
434
Bin Meng05a50922015-07-16 19:43:46 -0700435$ ./tools/buildman/buildman --fetch-arch list
Simon Glass7e803e12014-12-01 17:34:06 -0700436Checking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.6.3/
437Checking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.6.2/
438Checking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.5.1/
439Checking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.2.4/
Andy Shevchenko8cb5cdd2017-07-05 16:25:22 +0300440Available architectures: alpha am33_2.0 arm bfin cris crisv32 frv h8300
Simon Glass7e803e12014-12-01 17:34:06 -0700441hppa hppa64 i386 ia64 m32r m68k mips mips64 or32 powerpc powerpc64 s390x sh4
442sparc sparc64 tilegx x86_64 xtensa
443
444Then pick one and download it:
445
Bin Meng05a50922015-07-16 19:43:46 -0700446$ ./tools/buildman/buildman --fetch-arch or32
Simon Glass7e803e12014-12-01 17:34:06 -0700447Checking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.6.3/
448Checking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.6.2/
449Checking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.5.1/
450Downloading: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.5.1//x86_64-gcc-4.5.1-nolibc_or32-linux.tar.xz
451Unpacking to: /home/sjg/.buildman-toolchains
452Testing
453 - looking in '/home/sjg/.buildman-toolchains/gcc-4.5.1-nolibc/or32-linux/.'
454 - looking in '/home/sjg/.buildman-toolchains/gcc-4.5.1-nolibc/or32-linux/bin'
455 - found '/home/sjg/.buildman-toolchains/gcc-4.5.1-nolibc/or32-linux/bin/or32-linux-gcc'
456Tool chain test: OK
457
Thomas Chou4acc2d42015-11-12 09:29:09 +0800458Or download them all from kernel.org and move them to /toolchains directory,
459
Simon Glass7b94ab52016-07-27 20:32:58 -0600460$ ./tools/buildman/buildman --fetch-arch all
Thomas Chou4acc2d42015-11-12 09:29:09 +0800461$ sudo mkdir -p /toolchains
462$ sudo mv ~/.buildman-toolchains/*/* /toolchains/
463
464For those not available from kernel.org, download from the following links.
465
466arc: https://github.com/foss-for-synopsys-dwc-arc-processors/toolchain/releases/
Alexey Brodkin14c0bde2017-01-26 17:25:59 +0300467 download/arc-2016.09-release/arc_gnu_2016.09_prebuilt_uclibc_le_archs_linux_install.tar.gz
Thomas Chou4acc2d42015-11-12 09:29:09 +0800468blackfin: http://sourceforge.net/projects/adi-toolchain/files/
469 blackfin-toolchain-elf-gcc-4.5-2014R1_45-RC2.x86_64.tar.bz2
Thomas Chou4acc2d42015-11-12 09:29:09 +0800470nios2: http://sourcery.mentor.com/public/gnu_toolchain/nios2-linux-gnu/
471 sourceryg++-2015.11-27-nios2-linux-gnu-i686-pc-linux-gnu.tar.bz2
472sh: http://sourcery.mentor.com/public/gnu_toolchain/sh-linux-gnu/
473 renesas-4.4-200-sh-linux-gnu-i686-pc-linux-gnu.tar.bz2
474
Simon Glass7b94ab52016-07-27 20:32:58 -0600475Note openrisc kernel.org toolchain is out of date. Download the latest one from
476http://opencores.org/or1k/OpenRISC_GNU_tool_chain#Prebuilt_versions - eg:
Bin Meng07a50f92016-02-21 21:18:02 -0800477ftp://ocuser:ocuser@openrisc.opencores.org/toolchain/gcc-or1k-elf-4.8.1-x86.tar.bz2.
478
Simon Glass7e803e12014-12-01 17:34:06 -0700479Buildman should now be set up to use your new toolchain.
480
481At the time of writing, U-Boot has these architectures:
482
Tom Rini53320122022-04-06 09:21:25 -0400483 arc, arm, blackfin, m68k, microblaze, mips, nios2, openrisc
Simon Glass7e803e12014-12-01 17:34:06 -0700484 powerpc, sandbox, sh, sparc, x86
485
Tom Rini53320122022-04-06 09:21:25 -0400486Of these, only arc is not available at kernel.org..
Simon Glass7e803e12014-12-01 17:34:06 -0700487
488
Simon Glassc05694f2013-04-03 11:07:16 +0000489How to run it
490=============
491
492First do a dry run using the -n flag: (replace <branch> with a real, local
493branch with a valid upstream)
494
495$ ./tools/buildman/buildman -b <branch> -n
496
497If it can't detect the upstream branch, try checking out the branch, and
Simon Glassf204ab12014-12-01 17:33:54 -0700498doing something like 'git branch --set-upstream-to upstream/master'
499or something similar. Buildman will try to guess a suitable upstream branch
500if it can't find one (you will see a message like" Guessing upstream as ...).
Simon Glass1be6ccc2020-04-09 15:08:50 -0600501You can also use the -c option to manually specify the number of commits to
502build.
Simon Glassc05694f2013-04-03 11:07:16 +0000503
Simon Glassfa1cfee2014-08-09 15:32:57 -0600504As an example:
Simon Glassc05694f2013-04-03 11:07:16 +0000505
506Dry run, so not doing much. But I would do this:
507
508Building 18 commits for 1059 boards (4 threads, 1 job per thread)
509Build directory: ../lcd9b
510 5bb3505 Merge branch 'master' of git://git.denx.de/u-boot-arm
511 c18f1b4 tegra: Use const for pinmux_config_pingroup/table()
512 2f043ae tegra: Add display support to funcmux
513 e349900 tegra: fdt: Add pwm binding and node
514 424a5f0 tegra: fdt: Add LCD definitions for Tegra
515 0636ccf tegra: Add support for PWM
516 a994fe7 tegra: Add SOC support for display/lcd
517 fcd7350 tegra: Add LCD driver
518 4d46e9d tegra: Add LCD support to Nvidia boards
519 991bd48 arm: Add control over cachability of memory regions
520 54e8019 lcd: Add CONFIG_LCD_ALIGNMENT to select frame buffer alignment
521 d92aff7 lcd: Add support for flushing LCD fb from dcache after update
522 dbd0677 tegra: Align LCD frame buffer to section boundary
523 0cff9b8 tegra: Support control of cache settings for LCD
524 9c56900 tegra: fdt: Add LCD definitions for Seaboard
525 5cc29db lcd: Add CONFIG_CONSOLE_SCROLL_LINES option to speed console
526 cac5a23 tegra: Enable display/lcd support on Seaboard
527 49ff541 wip
528
529Total boards to build for each commit: 1059
530
531This shows that it will build all 1059 boards, using 4 threads (because
532we have a 4-core CPU). Each thread will run with -j1, meaning that each
533make job will use a single CPU. The list of commits to be built helps you
534confirm that things look about right. Notice that buildman has chosen a
535'base' directory for you, immediately above your source tree.
536
537Buildman works entirely inside the base directory, here ../lcd9b,
538creating a working directory for each thread, and creating output
539directories for each commit and board.
540
541
542Suggested Workflow
543==================
544
545To run the build for real, take off the -n:
546
547$ ./tools/buildman/buildman -b <branch>
548
549Buildman will set up some working directories, and get started. After a
550minute or so it will settle down to a steady pace, with a display like this:
551
552Building 18 commits for 1059 boards (4 threads, 1 job per thread)
Simon Glass1be6ccc2020-04-09 15:08:50 -0600553 528 36 124 /19062 -18374 1:13:30 : SIMPC8313_SP
Simon Glassc05694f2013-04-03 11:07:16 +0000554
555This means that it is building 19062 board/commit combinations. So far it
Simon Glassfa1cfee2014-08-09 15:32:57 -0600556has managed to successfully build 528. Another 36 have built with warnings,
Simon Glass1be6ccc2020-04-09 15:08:50 -0600557and 124 more didn't build at all. It has 18374 builds left to complete.
558Buildman expects to complete the process in around an hour and a quarter.
559Use this time to buy a faster computer.
Simon Glassc05694f2013-04-03 11:07:16 +0000560
561
562To find out how the build went, ask for a summary with -s. You can do this
Dirk Behme5f01c7a2014-12-23 07:41:26 +0100563either before the build completes (presumably in another terminal) or
Simon Glassc05694f2013-04-03 11:07:16 +0000564afterwards. Let's work through an example of how this is used:
565
566$ ./tools/buildman/buildman -b lcd9b -s
567...
56801: Merge branch 'master' of git://git.denx.de/u-boot-arm
569 powerpc: + galaxy5200_LOWBOOT
57002: tegra: Use const for pinmux_config_pingroup/table()
57103: tegra: Add display support to funcmux
57204: tegra: fdt: Add pwm binding and node
57305: tegra: fdt: Add LCD definitions for Tegra
57406: tegra: Add support for PWM
57507: tegra: Add SOC support for display/lcd
57608: tegra: Add LCD driver
57709: tegra: Add LCD support to Nvidia boards
57810: arm: Add control over cachability of memory regions
57911: lcd: Add CONFIG_LCD_ALIGNMENT to select frame buffer alignment
58012: lcd: Add support for flushing LCD fb from dcache after update
581 arm: + lubbock
58213: tegra: Align LCD frame buffer to section boundary
58314: tegra: Support control of cache settings for LCD
58415: tegra: fdt: Add LCD definitions for Seaboard
58516: lcd: Add CONFIG_CONSOLE_SCROLL_LINES option to speed console
58617: tegra: Enable display/lcd support on Seaboard
58718: wip
588
589This shows which commits have succeeded and which have failed. In this case
590the build is still in progress so many boards are not built yet (use -u to
Simon Glass1be6ccc2020-04-09 15:08:50 -0600591see which ones). But already we can see a few failures. The galaxy5200_LOWBOOT
Simon Glassc05694f2013-04-03 11:07:16 +0000592never builds correctly. This could be a problem with our toolchain, or it
593could be a bug in the upstream. The good news is that we probably don't need
Simon Glass7b94ab52016-07-27 20:32:58 -0600594to blame our commits. The bad news is that our commits are not tested on that
595board.
Simon Glassc05694f2013-04-03 11:07:16 +0000596
Simon Glass1be6ccc2020-04-09 15:08:50 -0600597Commit 12 broke lubbock. That's what the '+ lubbock', in red, means. The
598failure is never fixed by a later commit, or you would see lubbock again, in
599green, without the +.
Simon Glassc05694f2013-04-03 11:07:16 +0000600
601To see the actual error:
602
Simon Glass1be6ccc2020-04-09 15:08:50 -0600603$ ./tools/buildman/buildman -b <branch> -se
Simon Glassc05694f2013-04-03 11:07:16 +0000604...
60512: lcd: Add support for flushing LCD fb from dcache after update
606 arm: + lubbock
607+common/libcommon.o: In function `lcd_sync':
Simon Glass1be6ccc2020-04-09 15:08:50 -0600608+common/lcd.c:120: undefined reference to `flush_dcache_range'
Simon Glassc05694f2013-04-03 11:07:16 +0000609+arm-none-linux-gnueabi-ld: BFD (Sourcery G++ Lite 2010q1-202) 2.19.51.20090709 assertion fail /scratch/julian/2010q1-release-linux-lite/obj/binutils-src-2010q1-202-arm-none-linux-gnueabi-i686-pc-linux-gnu/bfd/elf32-arm.c:12572
Simon Glass1be6ccc2020-04-09 15:08:50 -0600610+make: *** [build/u-boot] Error 139
Simon Glassc05694f2013-04-03 11:07:16 +000061113: tegra: Align LCD frame buffer to section boundary
61214: tegra: Support control of cache settings for LCD
61315: tegra: fdt: Add LCD definitions for Seaboard
61416: lcd: Add CONFIG_CONSOLE_SCROLL_LINES option to speed console
Simon Glass1be6ccc2020-04-09 15:08:50 -0600615-common/lcd.c:120: undefined reference to `flush_dcache_range'
616+common/lcd.c:125: undefined reference to `flush_dcache_range'
Simon Glassc05694f2013-04-03 11:07:16 +000061717: tegra: Enable display/lcd support on Seaboard
61818: wip
619
620So the problem is in lcd.c, due to missing cache operations. This information
621should be enough to work out what that commit is doing to break these
622boards. (In this case pxa did not have cache operations defined).
623
Simon Glass1be6ccc2020-04-09 15:08:50 -0600624Note that if there were other boards with errors, the above command would
625show their errors also. Each line is shown only once. So if lubbock and snow
626produce the same error, we just see:
627
62812: lcd: Add support for flushing LCD fb from dcache after update
629 arm: + lubbock snow
630+common/libcommon.o: In function `lcd_sync':
631+common/lcd.c:120: undefined reference to `flush_dcache_range'
632+arm-none-linux-gnueabi-ld: BFD (Sourcery G++ Lite 2010q1-202) 2.19.51.20090709 assertion fail /scratch/julian/2010q1-release-linux-lite/obj/binutils-src-2010q1-202-arm-none-linux-gnueabi-i686-pc-linux-gnu/bfd/elf32-arm.c:12572
633+make: *** [build/u-boot] Error 139
634
635But if you did want to see just the errors for lubbock, use:
636
637$ ./tools/buildman/buildman -b <branch> -se lubbock
638
Simon Glass7b94ab52016-07-27 20:32:58 -0600639If you see error lines marked with '-', that means that the errors were fixed
Simon Glassc05694f2013-04-03 11:07:16 +0000640by that commit. Sometimes commits can be in the wrong order, so that a
641breakage is introduced for a few commits and fixed by later commits. This
642shows up clearly with buildman. You can then reorder the commits and try
643again.
644
Simon Glass7b94ab52016-07-27 20:32:58 -0600645At commit 16, the error moves: you can see that the old error at line 120
Simon Glassc05694f2013-04-03 11:07:16 +0000646is fixed, but there is a new one at line 126. This is probably only because
Dirk Behme5f01c7a2014-12-23 07:41:26 +0100647we added some code and moved the broken line further down the file.
Simon Glassc05694f2013-04-03 11:07:16 +0000648
Simon Glass1be6ccc2020-04-09 15:08:50 -0600649As mentioned, if many boards have the same error, then -e will display the
650error only once. This makes the output as concise as possible. To see which
651boards have each error, use -l. So it is safe to omit the board name - you
652will not get lots of repeated output for every board.
Simon Glassc05694f2013-04-03 11:07:16 +0000653
Simon Glass03749d42014-08-28 09:43:44 -0600654Buildman tries to distinguish warnings from errors, and shows warning lines
Simon Glass1be6ccc2020-04-09 15:08:50 -0600655separately with a 'w' prefix. Warnings introduced show as yellow. Warnings
656fixed show as cyan.
Simon Glass03749d42014-08-28 09:43:44 -0600657
Simon Glassc05694f2013-04-03 11:07:16 +0000658The full build output in this case is available in:
659
660../lcd9b/12_of_18_gd92aff7_lcd--Add-support-for/lubbock/
661
662 done: Indicates the build was done, and holds the return code from make.
663 This is 0 for a good build, typically 2 for a failure.
664
665 err: Output from stderr, if any. Errors and warnings appear here.
666
667 log: Output from stdout. Normally there isn't any since buildman runs
Simon Glass54e628e2016-03-12 18:50:33 -0700668 in silent mode. Use -V to force a verbose build (this passes V=1
669 to 'make')
Simon Glassc05694f2013-04-03 11:07:16 +0000670
671 toolchain: Shows information about the toolchain used for the build.
672
673 sizes: Shows image size information.
674
Simon Glass7b94ab52016-07-27 20:32:58 -0600675It is possible to get the build binary output there also. Use the -k option
676for this. In that case you will also see some output files, like:
Simon Glassc05694f2013-04-03 11:07:16 +0000677
678 System.map toolchain u-boot u-boot.bin u-boot.map autoconf.mk
679 (also SPL versions u-boot-spl and u-boot-spl.bin if available)
680
681
682Checking Image Sizes
683====================
684
685A key requirement for U-Boot is that you keep code/data size to a minimum.
686Where a new feature increases this noticeably it should normally be put
Simon Glass7b94ab52016-07-27 20:32:58 -0600687behind a CONFIG flag so that boards can leave it disabled and keep the image
Simon Glassc05694f2013-04-03 11:07:16 +0000688size more or less the same with each new release.
689
690To check the impact of your commits on image size, use -S. For example:
691
692$ ./tools/buildman/buildman -b us-x86 -sS
693Summary of 10 commits for 1066 boards (4 threads, 1 job per thread)
69401: MAKEALL: add support for per architecture toolchains
69502: x86: Add function to get top of usable ram
696 x86: (for 1/3 boards) text -272.0 rodata +41.0
69703: x86: Add basic cache operations
69804: x86: Permit bootstage and timer data to be used prior to relocation
699 x86: (for 1/3 boards) data +16.0
70005: x86: Add an __end symbol to signal the end of the U-Boot binary
701 x86: (for 1/3 boards) text +76.0
70206: x86: Rearrange the output input to remove BSS
703 x86: (for 1/3 boards) bss -2140.0
70407: x86: Support relocation of FDT on start-up
705 x86: + coreboot-x86
70608: x86: Add error checking to x86 relocation code
70709: x86: Adjust link device tree include file
70810: x86: Enable CONFIG_OF_CONTROL on coreboot
709
710
711You can see that image size only changed on x86, which is good because this
712series is not supposed to change any other board. From commit 7 onwards the
713build fails so we don't get code size numbers. The numbers are fractional
714because they are an average of all boards for that architecture. The
715intention is to allow you to quickly find image size problems introduced by
716your commits.
717
718Note that the 'text' region and 'rodata' are split out. You should add the
719two together to get the total read-only size (reported as the first column
720in the output from binutil's 'size' utility).
721
722A useful option is --step which lets you skip some commits. For example
723--step 2 will show the image sizes for only every 2nd commit (so it will
724compare the image sizes of the 1st, 3rd, 5th... commits). You can also use
725--step 0 which will compare only the first and last commits. This is useful
Simon Glass7b94ab52016-07-27 20:32:58 -0600726for an overview of how your entire series affects code size. It will build
727only the upstream commit and your final branch commit.
Simon Glassc05694f2013-04-03 11:07:16 +0000728
729You can also use -d to see a detailed size breakdown for each board. This
730list is sorted in order from largest growth to largest reduction.
731
Simon Glass7b94ab52016-07-27 20:32:58 -0600732It is even possible to go a little further with the -B option (--bloat). This
Simon Glassfa1cfee2014-08-09 15:32:57 -0600733shows where U-Boot has bloated, breaking the size change down to the function
Simon Glassc05694f2013-04-03 11:07:16 +0000734level. Example output is below:
735
736$ ./tools/buildman/buildman -b us-mem4 -sSdB
737...
73819: Roll crc32 into hash infrastructure
739 arm: (for 10/10 boards) all -143.4 bss +1.2 data -4.8 rodata -48.2 text -91.6
740 paz00 : all +23 bss -4 rodata -29 text +56
741 u-boot: add: 1/0, grow: 3/-2 bytes: 168/-104 (64)
742 function old new delta
743 hash_command 80 160 +80
744 crc32_wd_buf - 56 +56
745 ext4fs_read_file 540 568 +28
746 insert_var_value_sub 688 692 +4
747 run_list_real 1996 1992 -4
748 do_mem_crc 168 68 -100
749 trimslice : all -9 bss +16 rodata -29 text +4
750 u-boot: add: 1/0, grow: 1/-3 bytes: 136/-124 (12)
751 function old new delta
752 hash_command 80 160 +80
753 crc32_wd_buf - 56 +56
754 ext4fs_iterate_dir 672 668 -4
755 ext4fs_read_file 568 548 -20
756 do_mem_crc 168 68 -100
757 whistler : all -9 bss +16 rodata -29 text +4
758 u-boot: add: 1/0, grow: 1/-3 bytes: 136/-124 (12)
759 function old new delta
760 hash_command 80 160 +80
761 crc32_wd_buf - 56 +56
762 ext4fs_iterate_dir 672 668 -4
763 ext4fs_read_file 568 548 -20
764 do_mem_crc 168 68 -100
765 seaboard : all -9 bss -28 rodata -29 text +48
766 u-boot: add: 1/0, grow: 3/-2 bytes: 160/-104 (56)
767 function old new delta
768 hash_command 80 160 +80
769 crc32_wd_buf - 56 +56
770 ext4fs_read_file 548 568 +20
771 run_list_real 1996 2000 +4
772 do_nandboot 760 756 -4
773 do_mem_crc 168 68 -100
Marcel Ziswilercad18b82015-03-26 01:31:54 +0100774 colibri_t20 : all -9 rodata -29 text +20
Simon Glassc05694f2013-04-03 11:07:16 +0000775 u-boot: add: 1/0, grow: 2/-3 bytes: 140/-112 (28)
776 function old new delta
777 hash_command 80 160 +80
778 crc32_wd_buf - 56 +56
779 read_abs_bbt 204 208 +4
780 do_nandboot 760 756 -4
781 ext4fs_read_file 576 568 -8
782 do_mem_crc 168 68 -100
783 ventana : all -37 bss -12 rodata -29 text +4
784 u-boot: add: 1/0, grow: 1/-3 bytes: 136/-124 (12)
785 function old new delta
786 hash_command 80 160 +80
787 crc32_wd_buf - 56 +56
788 ext4fs_iterate_dir 672 668 -4
789 ext4fs_read_file 568 548 -20
790 do_mem_crc 168 68 -100
791 harmony : all -37 bss -16 rodata -29 text +8
792 u-boot: add: 1/0, grow: 2/-3 bytes: 140/-124 (16)
793 function old new delta
794 hash_command 80 160 +80
795 crc32_wd_buf - 56 +56
796 nand_write_oob_syndrome 428 432 +4
797 ext4fs_iterate_dir 672 668 -4
798 ext4fs_read_file 568 548 -20
799 do_mem_crc 168 68 -100
800 medcom-wide : all -417 bss +28 data -16 rodata -93 text -336
801 u-boot: add: 1/-1, grow: 1/-2 bytes: 88/-376 (-288)
802 function old new delta
803 crc32_wd_buf - 56 +56
804 do_fat_read_at 2872 2904 +32
805 hash_algo 16 - -16
806 do_mem_crc 168 68 -100
807 hash_command 420 160 -260
808 tec : all -449 bss -4 data -16 rodata -93 text -336
809 u-boot: add: 1/-1, grow: 1/-2 bytes: 88/-376 (-288)
810 function old new delta
811 crc32_wd_buf - 56 +56
812 do_fat_read_at 2872 2904 +32
813 hash_algo 16 - -16
814 do_mem_crc 168 68 -100
815 hash_command 420 160 -260
816 plutux : all -481 bss +16 data -16 rodata -93 text -388
817 u-boot: add: 1/-1, grow: 1/-3 bytes: 68/-408 (-340)
818 function old new delta
819 crc32_wd_buf - 56 +56
820 do_load_serial_bin 1688 1700 +12
821 hash_algo 16 - -16
822 do_fat_read_at 2904 2872 -32
823 do_mem_crc 168 68 -100
824 hash_command 420 160 -260
825 powerpc: (for 5/5 boards) all +37.4 data -3.2 rodata -41.8 text +82.4
826 MPC8610HPCD : all +55 rodata -29 text +84
827 u-boot: add: 1/0, grow: 0/-1 bytes: 176/-96 (80)
828 function old new delta
829 hash_command - 176 +176
830 do_mem_crc 184 88 -96
831 MPC8641HPCN : all +55 rodata -29 text +84
832 u-boot: add: 1/0, grow: 0/-1 bytes: 176/-96 (80)
833 function old new delta
834 hash_command - 176 +176
835 do_mem_crc 184 88 -96
836 MPC8641HPCN_36BIT: all +55 rodata -29 text +84
837 u-boot: add: 1/0, grow: 0/-1 bytes: 176/-96 (80)
838 function old new delta
839 hash_command - 176 +176
840 do_mem_crc 184 88 -96
841 sbc8641d : all +55 rodata -29 text +84
842 u-boot: add: 1/0, grow: 0/-1 bytes: 176/-96 (80)
843 function old new delta
844 hash_command - 176 +176
845 do_mem_crc 184 88 -96
846 xpedite517x : all -33 data -16 rodata -93 text +76
847 u-boot: add: 1/-1, grow: 0/-1 bytes: 176/-112 (64)
848 function old new delta
849 hash_command - 176 +176
850 hash_algo 16 - -16
851 do_mem_crc 184 88 -96
852...
853
854
Simon Glass7b94ab52016-07-27 20:32:58 -0600855This shows that commit 19 has reduced codesize for arm slightly and increased
856it for powerpc. This increase was offset in by reductions in rodata and
857data/bss.
Simon Glassc05694f2013-04-03 11:07:16 +0000858
Dirk Behme5f01c7a2014-12-23 07:41:26 +0100859Shown below the summary lines are the sizes for each board. Below each board
860are the sizes for each function. This information starts with:
Simon Glassc05694f2013-04-03 11:07:16 +0000861
862 add - number of functions added / removed
863 grow - number of functions which grew / shrunk
864 bytes - number of bytes of code added to / removed from all functions,
865 plus the total byte change in brackets
866
867The change seems to be that hash_command() has increased by more than the
868do_mem_crc() function has decreased. The function sizes typically add up to
869roughly the text area size, but note that every read-only section except
870rodata is included in 'text', so the function total does not exactly
871correspond.
872
873It is common when refactoring code for the rodata to decrease as the text size
874increases, and vice versa.
875
876
Simon Glass3cb033e2014-12-01 17:34:02 -0700877The .buildman file
878==================
879
880The .buildman file provides information about the available toolchains and
881also allows build flags to be passed to 'make'. It consists of several
882sections, with the section name in square brackets. Within each section are
883a set of (tag, value) pairs.
884
885'[toolchain]' section
886
887 This lists the available toolchains. The tag here doesn't matter, but
888 make sure it is unique. The value is the path to the toolchain. Buildman
889 will look in that path for a file ending in 'gcc'. It will then execute
890 it to check that it is a C compiler, passing only the --version flag to
891 it. If the return code is 0, buildman assumes that it is a valid C
892 compiler. It uses the first part of the name as the architecture and
893 strips off the last part when setting the CROSS_COMPILE environment
894 variable (parts are delimited with a hyphen).
895
896 For example powerpc-linux-gcc will be noted as a toolchain for 'powerpc'
897 and CROSS_COMPILE will be set to powerpc-linux- when using it.
898
899'[toolchain-alias]' section
900
901 This converts toolchain architecture names to U-Boot names. For example,
902 if an x86 toolchains is called i386-linux-gcc it will not normally be
Simon Glassc1528c12014-12-01 17:34:05 -0700903 used for architecture 'x86'. Adding 'x86: i386 x86_64' to this section
904 will tell buildman that the i386 and x86_64 toolchains can be used for
905 the x86 architecture.
Simon Glass3cb033e2014-12-01 17:34:02 -0700906
907'[make-flags]' section
908
909 U-Boot's build system supports a few flags (such as BUILD_TAG) which
910 affect the build product. These flags can be specified in the buildman
911 settings file. They can also be useful when building U-Boot against other
912 open source software.
913
914 [make-flags]
915 at91-boards=ENABLE_AT91_TEST=1
916 snapper9260=${at91-boards} BUILD_TAG=442
917 snapper9g45=${at91-boards} BUILD_TAG=443
Simon Glasscc246fb2013-09-23 17:35:17 -0600918
Simon Glass3cb033e2014-12-01 17:34:02 -0700919 This will use 'make ENABLE_AT91_TEST=1 BUILD_TAG=442' for snapper9260
920 and 'make ENABLE_AT91_TEST=1 BUILD_TAG=443' for snapper9g45. A special
921 variable ${target} is available to access the target name (snapper9260
922 and snapper9g20 in this case). Variables are resolved recursively. Note
923 that variables can only contain the characters A-Z, a-z, 0-9, hyphen (-)
924 and underscore (_).
Simon Glasscc246fb2013-09-23 17:35:17 -0600925
Simon Glass3cb033e2014-12-01 17:34:02 -0700926 It is expected that any variables added are dealt with in U-Boot's
927 config.mk file and documented in the README.
Simon Glasscc246fb2013-09-23 17:35:17 -0600928
Simon Glass3cb033e2014-12-01 17:34:02 -0700929 Note that you can pass ad-hoc options to the build using environment
930 variables, for example:
Simon Glasscc246fb2013-09-23 17:35:17 -0600931
Simon Glass3cb033e2014-12-01 17:34:02 -0700932 SOME_OPTION=1234 ./tools/buildman/buildman my_board
Simon Glasscc246fb2013-09-23 17:35:17 -0600933
934
Simon Glass78e418e2014-08-09 15:33:03 -0600935Quick Sanity Check
936==================
937
938If you have made changes and want to do a quick sanity check of the
Simon Glassd8158f92014-10-16 01:05:56 -0600939currently checked-out source, run buildman without the -b flag. This will
940build the selected boards and display build status as it runs (i.e. -v is
941enabled automatically). Use -e to see errors/warnings as well.
Simon Glass78e418e2014-08-09 15:33:03 -0600942
943
Simon Glass5eeef462014-12-01 17:33:57 -0700944Building Ranges
945===============
946
947You can build a range of commits by specifying a range instead of a branch
948when using the -b flag. For example:
949
950 upstream/master..us-buildman
951
952will build commits in us-buildman that are not in upstream/master.
953
954
Stephen Warren97c96902016-04-11 10:48:44 -0600955Building Faster
956===============
957
Simon Glass6029af12020-04-09 15:08:51 -0600958By default, buildman doesn't execute 'make mrproper' prior to building the
959first commit for each board. This reduces the amount of work 'make' does, and
960hence speeds up the build. To force use of 'make mrproper', use -the -m flag.
961This flag will slow down any buildman invocation, since it increases the amount
962of work done on any build.
Stephen Warren97c96902016-04-11 10:48:44 -0600963
964One possible application of buildman is as part of a continual edit, build,
965edit, build, ... cycle; repeatedly applying buildman to the same change or
966series of changes while making small incremental modifications to the source
967each time. This provides quick feedback regarding the correctness of recent
968modifications. In this scenario, buildman's default choice of build directory
969causes more build work to be performed than strictly necessary.
970
971By default, each buildman thread uses a single directory for all builds. When a
972thread builds multiple boards, the configuration built in this directory will
973cycle through various different configurations, one per board built by the
974thread. Variations in the configuration will force a rebuild of affected source
975files when a thread switches between boards. Ideally, such buildman-induced
976rebuilds would not happen, thus allowing the build to operate as efficiently as
977the build system and source changes allow. buildman's -P flag may be used to
978enable this; -P causes each board to be built in a separate (board-specific)
979directory, thus avoiding any buildman-induced configuration changes in any
980build directory.
981
982U-Boot's build system embeds information such as a build timestamp into the
983final binary. This information varies each time U-Boot is built. This causes
984various files to be rebuilt even if no source changes are made, which in turn
985requires that the final U-Boot binary be re-linked. This unnecessary work can
986be avoided by turning off the timestamp feature. This can be achieved by
987setting the SOURCE_DATE_EPOCH environment variable to 0.
988
989Combining all of these options together yields the command-line shown below.
990This will provide the quickest possible feedback regarding the current content
991of the source tree, thus allowing rapid tested evolution of the code.
992
Simon Glass6029af12020-04-09 15:08:51 -0600993 SOURCE_DATE_EPOCH=0 ./tools/buildman/buildman -P tegra
Stephen Warren97c96902016-04-11 10:48:44 -0600994
995
Simon Glassb50ce022016-11-13 14:25:52 -0700996Checking configuration
997======================
998
999A common requirement when converting CONFIG options to Kconfig is to check
1000that the effective configuration has not changed due to the conversion.
1001Buildman supports this with the -K option, used after a build. This shows
1002differences in effective configuration between one commit and the next.
1003
1004For example:
1005
1006 $ buildman -b kc4 -sK
1007 ...
1008 43: Convert CONFIG_SPL_USBETH_SUPPORT to Kconfig
1009 arm:
Simon Glass041a0ac2021-08-08 12:20:30 -06001010 + u-boot.cfg: CONFIG_SPL_ENV_SUPPORT=1 CONFIG_SPL_NET=1
Simon Glassb58bfe02021-08-08 12:20:09 -06001011 + u-boot-spl.cfg: CONFIG_SPL_MMC=1 CONFIG_SPL_NAND_SUPPORT=1
Simon Glass041a0ac2021-08-08 12:20:30 -06001012 + all: CONFIG_SPL_ENV_SUPPORT=1 CONFIG_SPL_MMC=1 CONFIG_SPL_NAND_SUPPORT=1 CONFIG_SPL_NET=1
Simon Glassb50ce022016-11-13 14:25:52 -07001013 am335x_evm_usbspl :
Simon Glass041a0ac2021-08-08 12:20:30 -06001014 + u-boot.cfg: CONFIG_SPL_ENV_SUPPORT=1 CONFIG_SPL_NET=1
Simon Glassb58bfe02021-08-08 12:20:09 -06001015 + u-boot-spl.cfg: CONFIG_SPL_MMC=1 CONFIG_SPL_NAND_SUPPORT=1
Simon Glass041a0ac2021-08-08 12:20:30 -06001016 + all: CONFIG_SPL_ENV_SUPPORT=1 CONFIG_SPL_MMC=1 CONFIG_SPL_NAND_SUPPORT=1 CONFIG_SPL_NET=1
Simon Glass1f2440c2021-07-10 21:14:29 -06001017 44: Convert CONFIG_SPL_USB_HOST to Kconfig
Simon Glassb50ce022016-11-13 14:25:52 -07001018 ...
1019
1020This shows that commit 44 enabled three new options for the board
1021am335x_evm_usbspl which were not enabled in commit 43. There is also a
1022summary for 'arm' showing all the changes detected for that architecture.
1023In this case there is only one board with changes, so 'arm' output is the
1024same as 'am335x_evm_usbspl'/
1025
1026The -K option uses the u-boot.cfg, spl/u-boot-spl.cfg and tpl/u-boot-tpl.cfg
1027files which are produced by a build. If all you want is to check the
1028configuration you can in fact avoid doing a full build, using -D. This tells
1029buildman to configuration U-Boot and create the .cfg files, but not actually
1030build the source. This is 5-10 times faster than doing a full build.
1031
Simon Glasscde5c302016-11-13 14:25:53 -07001032By default buildman considers the follow two configuration methods
1033equivalent:
1034
1035 #define CONFIG_SOME_OPTION
1036
1037 CONFIG_SOME_OPTION=y
1038
1039The former would appear in a header filer and the latter in a defconfig
1040file. The achieve this, buildman considers 'y' to be '1' in configuration
1041variables. This avoids lots of useless output when converting a CONFIG
1042option to Kconfig. To disable this behaviour, use --squash-config-y.
1043
Simon Glassb50ce022016-11-13 14:25:52 -07001044
Alex Kiernan4059e302018-05-31 04:48:34 +00001045Checking the environment
1046========================
1047
1048When converting CONFIG options which manipulate the default environment,
1049a common requirement is to check that the default environment has not
1050changed due to the conversion. Buildman supports this with the -U option,
1051used after a build. This shows differences in the default environment
1052between one commit and the next.
1053
1054For example:
1055
1056$ buildman -b squash brppt1 -sU
Alex Kiernan4059e302018-05-31 04:48:34 +00001057Summary of 2 commits for 3 boards (3 threads, 3 jobs per thread)
105801: Migrate bootlimit to Kconfig
105902: Squashed commit of the following:
1060 c brppt1_mmc: altbootcmd=mmc dev 1; run mmcboot0; -> mmc dev 1; run mmcboot0
1061 c brppt1_spi: altbootcmd=mmc dev 1; run mmcboot0; -> mmc dev 1; run mmcboot0
1062 + brppt1_nand: altbootcmd=run usbscript
1063 - brppt1_nand: altbootcmd=run usbscript
1064(no errors to report)
1065
1066This shows that commit 2 modified the value of 'altbootcmd' for 'brppt1_mmc'
1067and 'brppt1_spi', removing a trailing semicolon. 'brppt1_nand' gained an a
1068value for 'altbootcmd', but lost one for ' altbootcmd'.
1069
1070The -U option uses the u-boot.env files which are produced by a build.
1071
Simon Glassf77ca5b2019-01-07 16:44:20 -07001072
1073Building with clang
1074===================
1075
1076To build with clang (sandbox only), use the -O option to override the
1077toolchain. For example:
1078
1079 buildman -O clang-7 --board sandbox
1080
1081
Simon Glassb6eb8cf2020-03-18 09:42:42 -06001082Doing a simple build
1083====================
1084
1085In some cases you just want to build a single board and get the full output, use
1086the -w option, for example:
1087
1088 buildman -o /tmp/build --board sandbox -w
1089
Simon Glassd9c98632020-04-17 17:51:32 -06001090This will write the full build into /tmp/build including object files. You must
1091specify the output directory with -o when using -w.
Simon Glassb6eb8cf2020-03-18 09:42:42 -06001092
1093
Simon Glass6c435622022-07-11 19:03:56 -06001094Support for IDEs (Integrated Development Environments)
1095======================================================
1096
1097Normally buildman summarises the output and shows information indicating the
1098meaning of each line of output. For example a '+' symbol appears at the start of
1099each error line. Also, buildman prints information about what it is about to do,
1100along with a summary at the end.
1101
1102When using buildman from an IDE, it is helpful to drop this behaviour. Use the
1103-I/--ide option for that. You might find -W helpful also so that warnings do
1104not cause the build to fail:
1105
1106 buildman -o /tmp/build --board sandbox -wWI
1107
1108
Simon Glasse5650a82022-01-22 05:07:33 -07001109Changing the configuration
1110==========================
1111
1112Sometimes it is useful to change the CONFIG options for a build on the fly. This
1113can be used to build a board (or multiple) with a few changes to see the impact.
1114The -a option supports this:
1115
1116 -a <cfg>
1117
1118where <cfg> is a CONFIG option (with or without the CONFIG_ prefix) to enable.
1119For example:
1120
1121 buildman -a CMD_SETEXPR_FMT
1122
1123will build with CONFIG_CMD_SETEXPR_FMT enabled.
1124
1125You can disable options by preceding them with tilde (~). You can specify the
1126-a option multiple times:
1127
1128 buildman -a CMD_SETEXPR_FMT -a ~CMDLINE
1129
1130Some options have values, in which case you can change them:
1131
1132 buildman -a 'BOOTCOMMAND="echo hello"' CONFIG_SYS_LOAD_ADDR=0x1000
1133
1134Note that you must put quotes around string options and the whole thing must be
1135in single quotes, to make sure the shell leave it alone.
1136
1137If you try to set an option that does not exist, or that cannot be changed for
1138some other reason (e.g. it is 'selected' by another option), then buildman
1139shows an error:
1140
1141 buildman --board sandbox -a FRED
1142 Building current source for 1 boards (1 thread, 32 jobs per thread)
1143 0 0 0 /1 -1 (starting)errs
1144 Some CONFIG adjustments did not take effect. This may be because
1145 the request CONFIGs do not exist or conflict with others.
1146
1147 Failed adjustments:
1148
1149 FRED Missing expected line: CONFIG_FRED=y
1150
1151
1152One major caveat with this feature with branches (-b) is that buildman does not
1153name the output directories differently when you change the configuration, so
1154doing the same build again with different configuration will not trigger a
1155rebuild. You can use -f to work around that.
1156
1157
Simon Glassc05694f2013-04-03 11:07:16 +00001158Other options
1159=============
1160
Simon Glass35e7d382020-03-18 09:42:44 -06001161Buildman has various other command-line options. Try --help to see them.
Simon Glassc05694f2013-04-03 11:07:16 +00001162
Simon Glass2df44be2020-03-18 09:42:47 -06001163To find out what toolchain prefix buildman will use for a build, use the -A
1164option.
Simon Glass48ac42e2019-12-05 15:59:14 -07001165
Simon Glass35e7d382020-03-18 09:42:44 -06001166To request that compiler warnings be promoted to errors, use -E. This passes the
1167-Werror flag to the compiler. Note that the build can still produce warnings
1168with -E, e.g. the migration warnings:
1169
1170 ===================== WARNING ======================
1171 This board does not use CONFIG_DM_MMC. Please update
1172 ...
1173 ====================================================
1174
Simon Glassc2f91072014-08-28 09:43:39 -06001175When doing builds, Buildman's return code will reflect the overall result:
1176
1177 0 (success) No errors or warnings found
Simon Glasse4cd5062020-04-09 10:49:45 -06001178 100 Errors found
1179 101 Warnings found (only if no -W)
Simon Glass35e7d382020-03-18 09:42:44 -06001180
Simon Glasse4cd5062020-04-09 10:49:45 -06001181You can use -W to tell Buildman to return 0 (success) instead of 101 when
Simon Glass35e7d382020-03-18 09:42:44 -06001182warnings are found. Note that it can be useful to combine -E and -W. This means
Simon Glasse4cd5062020-04-09 10:49:45 -06001183that all compiler warnings will produce failures (code 100) and all other
1184warnings will produce success (since 101 is changed to 0).
Simon Glass35e7d382020-03-18 09:42:44 -06001185
Simon Glasse4cd5062020-04-09 10:49:45 -06001186If there are both warnings and errors, errors win, so buildman returns 100.
Simon Glassc2f91072014-08-28 09:43:39 -06001187
Simon Glass9ea93812020-04-09 15:08:52 -06001188The -y option is provided (for use with -s) to ignore the bountiful device-tree
Simon Glassf4ebfba2020-04-09 15:08:53 -06001189warnings. Similarly, -Y tells buildman to ignore the migration warnings.
Simon Glass9ea93812020-04-09 15:08:52 -06001190
Simon Glassc635d892021-01-30 22:17:46 -07001191Sometimes you might get an error in a thread that is not handled by buildman,
1192perhaps due to a failure of a tool that it calls. You might see the output, but
1193then buildman hangs. Failing to handle any eventuality is a bug in buildman and
1194should be reported. But you can use -T0 to disable threading and hopefully
1195figure out the root cause of the build failure.
Simon Glassc05694f2013-04-03 11:07:16 +00001196
Simon Glassa6793662020-07-19 12:40:26 -06001197Build summary
1198=============
1199
1200When buildman finishes it shows a summary, something like this:
1201
1202 Completed: 5 total built, duration 0:00:21, rate 0.24
1203
1204This shows that a total of 5 builds were done across all selected boards, it
1205took 21 seconds and the builds happened at the rate of 0.24 per second. The
1206latter number depends on the speed of your machine and the efficiency of the
1207U-Boot build.
1208
1209
Simon Glass3ec03d42014-08-09 15:32:58 -06001210How to change from MAKEALL
1211==========================
1212
1213Buildman includes most of the features of MAKEALL and is generally faster
1214and easier to use. In particular it builds entire branches: if a particular
1215commit introduces an error in a particular board, buildman can easily show
1216you this, even if a later commit fixes that error.
1217
1218The reasons to deprecate MAKEALL are:
1219- We don't want to maintain two build systems
1220- Buildman is typically faster
1221- Buildman has a lot more features
1222
1223But still, many people will be sad to lose MAKEALL. If you are used to
1224MAKEALL, here are a few pointers.
1225
1226First you need to set up your tool chains - see the 'Setting up' section
1227for details. Once you have your required toolchain(s) detected then you are
1228ready to go.
1229
Simon Glass78e418e2014-08-09 15:33:03 -06001230To build the current source tree, run buildman without a -b flag:
1231
1232 ./tools/buildman/buildman <list of things to build>
1233
1234This will build the current source tree for the given boards and display
1235the results and errors.
1236
1237However buildman usually works on entire branches, and for that you must
1238specify a board flag:
Simon Glass3ec03d42014-08-09 15:32:58 -06001239
1240 ./tools/buildman/buildman -b <branch_name> <list of things to build>
1241
1242followed by (afterwards, or perhaps concurrently in another terminal):
1243
1244 ./tools/buildman/buildman -b <branch_name> -s <list of things to build>
1245
1246to see the results of the build. Rather than showing you all the output,
1247buildman just shows a summary, with red indicating that a commit introduced
1248an error and green indicating that a commit fixed an error. Use the -e
Simon Glass3394c9f2014-08-28 09:43:43 -06001249flag to see the full errors and -l to see which boards caused which errors.
Simon Glass3ec03d42014-08-09 15:32:58 -06001250
Simon Glass78e418e2014-08-09 15:33:03 -06001251If you really want to see build results as they happen, use -v when doing a
Simon Glassd8158f92014-10-16 01:05:56 -06001252build (and -e to see the errors/warnings too).
Simon Glass78e418e2014-08-09 15:33:03 -06001253
Simon Glass3ec03d42014-08-09 15:32:58 -06001254You don't need to stick around on that branch while buildman is running. It
1255checks out its own copy of the source code, so you can change branches,
1256add commits, etc. without affecting the build in progress.
1257
1258The <list of things to build> can include board names, architectures or the
1259like. There are no flags to disambiguate since ambiguities are rare. Using
1260the examples from MAKEALL:
1261
1262Examples:
1263 - build all Power Architecture boards:
1264 MAKEALL -a powerpc
1265 MAKEALL --arch powerpc
1266 MAKEALL powerpc
1267 ** buildman -b <branch> powerpc
1268 - build all PowerPC boards manufactured by vendor "esd":
1269 MAKEALL -a powerpc -v esd
1270 ** buildman -b <branch> esd
1271 - build all PowerPC boards manufactured either by "keymile" or "siemens":
1272 MAKEALL -a powerpc -v keymile -v siemens
1273 ** buildman -b <branch> keymile siemens
1274 - build all Freescale boards with MPC83xx CPUs, plus all 4xx boards:
1275 MAKEALL -c mpc83xx -v freescale 4xx
1276 ** buildman -b <branch> mpc83xx freescale 4xx
1277
1278Buildman automatically tries to use all the CPUs in your machine. If you
1279are building a lot of boards it will use one thread for every CPU core
1280it detects in your machine. This is like MAKEALL's BUILD_NBUILDS option.
1281You can use the -T flag to change the number of threads. If you are only
1282building a few boards, buildman will automatically run make with the -j
1283flag to increase the number of concurrent make tasks. It isn't normally
1284that helpful to fiddle with this option, but if you use the BUILD_NCPUS
1285option in MAKEALL then -j is the equivalent in buildman.
1286
1287Buildman puts its output in ../<branch_name> by default but you can change
1288this with the -o option. Buildman normally does out-of-tree builds: use -i
1289to disable that if you really want to. But be careful that once you have
1290used -i you pollute buildman's copies of the source tree, and you will need
1291to remove the build directory (normally ../<branch_name>) to run buildman
1292in normal mode (without -i).
1293
1294Buildman doesn't keep the output result normally, but use the -k option to
1295do this.
1296
1297Please read 'Theory of Operation' a few times as it will make a lot of
1298things clearer.
1299
1300Some options you might like are:
1301
1302 -B shows which functions are growing/shrinking in which commit - great
1303 for finding code bloat.
1304 -S shows image sizes for each commit (just an overall summary)
1305 -u shows boards that you haven't built yet
1306 --step 0 will build just the upstream commit and the last commit of your
1307 branch. This is often a quick sanity check that your branch doesn't
1308 break anything. But note this does not check bisectability!
1309
1310
Simon Glass0c477b72022-07-11 19:04:04 -06001311Using boards.cfg
1312================
1313
1314This file is no-longer needed by buildman but it is still generated in the
1315working directory. This helps avoid a delay on every build, since scanning all
1316the Kconfig files takes a few seconds. Use the -R flag to force regeneration
Simon Glassafbd2132022-07-11 19:04:08 -06001317of the file - in that case buildman exits after writing the file. with exit code
13182 if there was an error in the maintainer files.
Simon Glass0c477b72022-07-11 19:04:04 -06001319
1320You should use 'buildman -nv <criteria>' instead of greoing the boards.cfg file,
1321since it may be dropped altogether in future.
1322
1323
Simon Glassc05694f2013-04-03 11:07:16 +00001324TODO
1325====
1326
Simon Glassa6286312020-04-09 15:08:54 -06001327Many improvements have been made over the years. There is still quite a bit of
1328scope for more though, e.g.:
Simon Glassc05694f2013-04-03 11:07:16 +00001329
Simon Glassa6286312020-04-09 15:08:54 -06001330- easier access to log files
1331- 'hunting' for problems, perhaps by building a few boards for each arch, or
1332 checking commits for changed files and building only boards which use those
1333 files
1334- using the same git repo for all threads instead of cloning it. Currently
1335 it uses about 500MB per thread, so on a 64-thread machine this is 32GB for
1336 the build.
1337
Simon Glassc05694f2013-04-03 11:07:16 +00001338
1339Credits
1340=======
1341
1342Thanks to Grant Grundler <grundler@chromium.org> for his ideas for improving
1343the build speed by building all commits for a board instead of the other
1344way around.
1345
1346
Simon Glassc05694f2013-04-03 11:07:16 +00001347Simon Glass
1348sjg@chromium.org
1349Halloween 2012
1350Updated 12-12-12
1351Updated 23-02-13
Simon Glassa6286312020-04-09 15:08:54 -06001352Updated 09-04-20