xref: /openbmc/u-boot/tools/buildman/README (revision c81d0d215ea38d3b8cf3684a57f4ecaca3c01b03)
1fc3fe1c2SSimon Glass# Copyright (c) 2013 The Chromium OS Authors.
2fc3fe1c2SSimon Glass#
31a459660SWolfgang Denk# SPDX-License-Identifier:	GPL-2.0+
4fc3fe1c2SSimon Glass#
5fc3fe1c2SSimon Glass
66eede34cSSimon Glass(Please read 'How to change from MAKEALL' if you are used to that tool)
76eede34cSSimon Glass
8fc3fe1c2SSimon GlassWhat is this?
9fc3fe1c2SSimon Glass=============
10fc3fe1c2SSimon Glass
11fc3fe1c2SSimon GlassThis tool handles building U-Boot to check that you have not broken it
12fc3fe1c2SSimon Glasswith your patch series. It can build each individual commit and report
13fc3fe1c2SSimon Glasswhich boards fail on which commits, and which errors come up. It aims
14fc3fe1c2SSimon Glassto make full use of multi-processor machines.
15fc3fe1c2SSimon Glass
16fc3fe1c2SSimon GlassA key feature of buildman is its output summary, which allows warnings,
17fc3fe1c2SSimon Glasserrors or image size increases in a particular commit or board to be
18fc3fe1c2SSimon Glassquickly identified and the offending commit pinpointed. This can be a big
19fc3fe1c2SSimon Glasshelp for anyone working with >10 patches at a time.
20fc3fe1c2SSimon Glass
21fc3fe1c2SSimon Glass
22fc3fe1c2SSimon GlassCaveats
23fc3fe1c2SSimon Glass=======
24fc3fe1c2SSimon Glass
25fc3fe1c2SSimon GlassBuildman is still in its infancy. It is already a very useful tool, but
26fc3fe1c2SSimon Glassexpect to find problems and send patches.
27fc3fe1c2SSimon Glass
28fc3fe1c2SSimon GlassBuildman can be stopped and restarted, in which case it will continue
29fc3fe1c2SSimon Glasswhere it left off. This should happen cleanly and without side-effects.
30fc3fe1c2SSimon GlassIf not, it is a bug, for which a patch would be welcome.
31fc3fe1c2SSimon Glass
32fc3fe1c2SSimon GlassBuildman gets so tied up in its work that it can ignore the outside world.
33fc3fe1c2SSimon GlassYou may need to press Ctrl-C several times to quit it. Also it will print
34fc3fe1c2SSimon Glassout various exceptions when stopped.
35fc3fe1c2SSimon Glass
36fc3fe1c2SSimon Glass
37fc3fe1c2SSimon GlassTheory of Operation
38fc3fe1c2SSimon Glass===================
39fc3fe1c2SSimon Glass
40fc3fe1c2SSimon Glass(please read this section in full twice or you will be perpetually confused)
41fc3fe1c2SSimon Glass
42fc3fe1c2SSimon GlassBuildman is a builder. It is not make, although it runs make. It does not
43fc3fe1c2SSimon Glassproduce any useful output on the terminal while building, except for
44e5a0e5d8SSimon Glassprogress information (except with -v, see below). All the output (errors,
453e1ded1fSDirk Behmewarnings and binaries if you ask for them) is stored in output
46e5a0e5d8SSimon Glassdirectories, which you can look at while the build is progressing, or when
47e5a0e5d8SSimon Glassit is finished.
48fc3fe1c2SSimon Glass
49fc3fe1c2SSimon GlassBuildman produces a concise summary of which boards succeeded and failed.
50fc3fe1c2SSimon GlassIt shows which commit introduced which board failure using a simple
51fc3fe1c2SSimon Glassred/green colour coding. Full error information can be requested, in which
52fc3fe1c2SSimon Glasscase it is de-duped and displayed against the commit that introduced the
53fc3fe1c2SSimon Glasserror. An example workflow is below.
54fc3fe1c2SSimon Glass
55fc3fe1c2SSimon GlassBuildman stores image size information and can report changes in image size
56fc3fe1c2SSimon Glassfrom commit to commit. An example of this is below.
57fc3fe1c2SSimon Glass
58fc3fe1c2SSimon GlassBuildman starts multiple threads, and each thread builds for one board at
59fc3fe1c2SSimon Glassa time. A thread starts at the first commit, configures the source for your
60fc3fe1c2SSimon Glassboard and builds it. Then it checks out the next commit and does an
61fc3fe1c2SSimon Glassincremental build. Eventually the thread reaches the last commit and stops.
62fc3fe1c2SSimon GlassIf errors or warnings are found along the way, the thread will reconfigure
63fc3fe1c2SSimon Glassafter every commit, and your build will be very slow. This is because a
64fc3fe1c2SSimon Glassfile that produces just a warning would not normally be rebuilt in an
65fc3fe1c2SSimon Glassincremental build.
66fc3fe1c2SSimon Glass
67fc3fe1c2SSimon GlassBuildman works in an entirely separate place from your U-Boot repository.
68fc3fe1c2SSimon GlassIt creates a separate working directory for each thread, and puts the
69fc3fe1c2SSimon Glassoutput files in the working directory, organised by commit name and board
70fc3fe1c2SSimon Glassname, in a two-level hierarchy.
71fc3fe1c2SSimon Glass
72fc3fe1c2SSimon GlassBuildman is invoked in your U-Boot directory, the one with the .git
73fc3fe1c2SSimon Glassdirectory. It clones this repository into a copy for each thread, and the
74fc3fe1c2SSimon Glassthreads do not affect the state of your git repository. Any checkouts done
75fc3fe1c2SSimon Glassby the thread affect only the working directory for that thread.
76fc3fe1c2SSimon Glass
77fc3fe1c2SSimon GlassBuildman automatically selects the correct tool chain for each board. You
78fc3fe1c2SSimon Glassmust supply suitable tool chains, but buildman takes care of selecting the
79fc3fe1c2SSimon Glassright one.
80fc3fe1c2SSimon Glass
81e5a0e5d8SSimon GlassBuildman generally builds a branch (with the -b flag), and in this case
82e5a0e5d8SSimon Glassbuilds the upstream commit as well, for comparison. It cannot build
83e5a0e5d8SSimon Glassindividual commits at present, unless (maybe) you point it at an empty
84e5a0e5d8SSimon Glassbranch. Put all your commits in a branch, set the branch's upstream to a
85e5a0e5d8SSimon Glassvalid value, and all will be well. Otherwise buildman will perform random
86e5a0e5d8SSimon Glassactions. Use -n to check what the random actions might be.
87e5a0e5d8SSimon Glass
881d8104feSSimon GlassIf you just want to build the current source tree, leave off the -b flag
891d8104feSSimon Glassand add -e. This will display results and errors as they happen. You can
901d8104feSSimon Glassstill look at them later using -se. Note that buildman will assume that the
911d8104feSSimon Glasssource has changed, and will build all specified boards in this case.
92fc3fe1c2SSimon Glass
93fc3fe1c2SSimon GlassBuildman is optimised for building many commits at once, for many boards.
94fc3fe1c2SSimon GlassOn multi-core machines, Buildman is fast because it uses most of the
95fc3fe1c2SSimon Glassavailable CPU power. When it gets to the end, or if you are building just
96fc3fe1c2SSimon Glassa few commits or boards, it will be pretty slow. As a tip, if you don't
97fc3fe1c2SSimon Glassplan to use your machine for anything else, you can use -T to increase the
98fc3fe1c2SSimon Glassnumber of threads beyond the default.
99fc3fe1c2SSimon Glass
1008426d8b0SStephen WarrenBuildman lets you build all boards, or a subset. Specify the subset by passing
1018426d8b0SStephen Warrencommand-line arguments that list the desired board name, architecture name,
1028426d8b0SStephen WarrenSOC name, or anything else in the boards.cfg file. Multiple arguments are
1038426d8b0SStephen Warrenallowed. Each argument will be interpreted as a regular expression, so
1048426d8b0SStephen Warrenbehaviour is a superset of exact or substring matching. Examples are:
1058426d8b0SStephen Warren
1068426d8b0SStephen Warren* 'tegra20'      All boards with a Tegra20 SoC
1078426d8b0SStephen Warren* 'tegra'        All boards with any Tegra Soc (Tegra20, Tegra30, Tegra114...)
1088426d8b0SStephen Warren* '^tegra[23]0$' All boards with either Tegra20 or Tegra30 SoC
1098426d8b0SStephen Warren* 'powerpc'      All PowerPC boards
110fc3fe1c2SSimon Glass
1116131beabSSimon GlassWhile the default is to OR the terms together, you can also make use of
1126131beabSSimon Glassthe '&' operator to limit the selection:
1136131beabSSimon Glass
1146131beabSSimon Glass* 'freescale & arm sandbox'  All Freescale boards with ARM architecture,
1156131beabSSimon Glass                             plus sandbox
1166131beabSSimon Glass
1173cf4ae6fSSimon GlassYou can also use -x to specifically exclude some boards. For example:
1183cf4ae6fSSimon Glass
1193cf4ae6fSSimon Glass buildmand arm -x nvidia,freescale,.*ball$
1203cf4ae6fSSimon Glass
1213cf4ae6fSSimon Glassmeans to build all arm boards except nvidia, freescale and anything ending
1223cf4ae6fSSimon Glasswith 'ball'.
1233cf4ae6fSSimon Glass
1243e1ded1fSDirk BehmeIt is convenient to use the -n option to see what will be built based on
1256131beabSSimon Glassthe subset given.
1266131beabSSimon Glass
127fc3fe1c2SSimon GlassBuildman does not store intermediate object files. It optionally copies
128fc3fe1c2SSimon Glassthe binary output into a directory when a build is successful. Size
129fc3fe1c2SSimon Glassinformation is always recorded. It needs a fair bit of disk space to work,
130fc3fe1c2SSimon Glasstypically 250MB per thread.
131fc3fe1c2SSimon Glass
132fc3fe1c2SSimon Glass
133fc3fe1c2SSimon GlassSetting up
134fc3fe1c2SSimon Glass==========
135fc3fe1c2SSimon Glass
136fc3fe1c2SSimon Glass1. Get the U-Boot source. You probably already have it, but if not these
137fc3fe1c2SSimon Glasssteps should get you started with a repo and some commits for testing.
138fc3fe1c2SSimon Glass
139fc3fe1c2SSimon Glass$ cd /path/to/u-boot
140fc3fe1c2SSimon Glass$ git clone git://git.denx.de/u-boot.git .
141fc3fe1c2SSimon Glass$ git checkout -b my-branch origin/master
142fc3fe1c2SSimon Glass$ # Add some commits to the branch, reading for testing
143fc3fe1c2SSimon Glass
14462005342SSimon Glass2. Create ~/.buildman to tell buildman where to find tool chains (see 'The
14562005342SSimon Glass.buildman file' later for details). As an example:
146fc3fe1c2SSimon Glass
147fc3fe1c2SSimon Glass# Buildman settings file
148fc3fe1c2SSimon Glass
149fc3fe1c2SSimon Glass[toolchain]
150fc3fe1c2SSimon Glassroot: /
151fc3fe1c2SSimon Glassrest: /toolchains/*
152fc3fe1c2SSimon Glasseldk: /opt/eldk-4.2
153e9569478SSimon Glassarm: /opt/linaro/gcc-linaro-arm-linux-gnueabihf-4.8-2013.08_linux
154e9569478SSimon Glassaarch64: /opt/linaro/gcc-linaro-aarch64-none-elf-4.8-2013.10_linux
155fc3fe1c2SSimon Glass
156fc3fe1c2SSimon Glass[toolchain-alias]
157fc3fe1c2SSimon Glassx86: i386
158fc3fe1c2SSimon Glassblackfin: bfin
159fc3fe1c2SSimon Glassnds32: nds32le
160e8aebc47SBin Mengopenrisc: or1k
161fc3fe1c2SSimon Glass
162fc3fe1c2SSimon Glass
163fc3fe1c2SSimon GlassThis selects the available toolchain paths. Add the base directory for
164fc3fe1c2SSimon Glasseach of your toolchains here. Buildman will search inside these directories
165fc3fe1c2SSimon Glassand also in any '/usr' and '/usr/bin' subdirectories.
166fc3fe1c2SSimon Glass
167fc3fe1c2SSimon GlassMake sure the tags (here root: rest: and eldk:) are unique.
168fc3fe1c2SSimon Glass
169fc3fe1c2SSimon GlassThe toolchain-alias section indicates that the i386 toolchain should be used
170fc3fe1c2SSimon Glassto build x86 commits.
171fc3fe1c2SSimon Glass
17217bce66cSSimon GlassNote that you can also specific exactly toolchain prefixes if you like:
17317bce66cSSimon Glass
17417bce66cSSimon Glass[toolchain-prefix]
17517bce66cSSimon Glassarm: /opt/arm-eabi-4.6/bin/arm-eabi-
17617bce66cSSimon Glass
17717bce66cSSimon Glassor even:
17817bce66cSSimon Glass
17917bce66cSSimon Glass[toolchain-prefix]
18017bce66cSSimon Glassarm: /opt/arm-eabi-4.6/bin/arm-eabi-gcc
18117bce66cSSimon Glass
18217bce66cSSimon GlassThis tells buildman that you want to use this exact toolchain for the arm
18317bce66cSSimon Glassarchitecture. This will override any toolchains found by searching using the
18417bce66cSSimon Glass[toolchain] settings.
18517bce66cSSimon Glass
18617bce66cSSimon GlassSince the toolchain prefix is an explicit request, buildman will report an
18717bce66cSSimon Glasserror if a toolchain is not found with that prefix. The current PATH will be
18817bce66cSSimon Glasssearched, so it is possible to use:
18917bce66cSSimon Glass
19017bce66cSSimon Glass[toolchain-prefix]
19117bce66cSSimon Glassarm: arm-none-eabi-
19217bce66cSSimon Glass
19317bce66cSSimon Glassand buildman will find arm-none-eabi-gcc in /usr/bin if you have it installed.
194fc3fe1c2SSimon Glass
19534699696SSimon Glass3. Make sure you have the require Python pre-requisites
19634699696SSimon Glass
197827e37b5SSimon GlassBuildman uses multiprocessing, Queue, shutil, StringIO, ConfigParser and
198827e37b5SSimon Glassurllib2. These should normally be available, but if you get an error like
199827e37b5SSimon Glassthis then you will need to obtain those modules:
20034699696SSimon Glass
20134699696SSimon Glass    ImportError: No module named multiprocessing
20234699696SSimon Glass
20334699696SSimon Glass
20434699696SSimon Glass4. Check the available toolchains
205fc3fe1c2SSimon Glass
206fc3fe1c2SSimon GlassRun this check to make sure that you have a toolchain for every architecture.
207fc3fe1c2SSimon Glass
208fc3fe1c2SSimon Glass$ ./tools/buildman/buildman --list-tool-chains
209fc3fe1c2SSimon GlassScanning for tool chains
21017bce66cSSimon Glass   - scanning prefix '/opt/gcc-4.6.3-nolibc/x86_64-linux/bin/x86_64-linux-'
21117bce66cSSimon GlassTool chain test:  OK, arch='x86', priority 1
21217bce66cSSimon Glass   - scanning prefix '/opt/arm-eabi-4.6/bin/arm-eabi-'
21317bce66cSSimon GlassTool chain test:  OK, arch='arm', priority 1
21417bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/i386-linux'
21517bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/i386-linux/.'
21617bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/i386-linux/bin'
21717bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/i386-linux/bin/i386-linux-gcc'
21817bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/i386-linux/usr/bin'
21917bce66cSSimon GlassTool chain test:  OK, arch='i386', priority 4
22017bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/aarch64-linux'
22117bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/aarch64-linux/.'
22217bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/aarch64-linux/bin'
22317bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/aarch64-linux/bin/aarch64-linux-gcc'
22417bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/aarch64-linux/usr/bin'
22517bce66cSSimon GlassTool chain test:  OK, arch='aarch64', priority 4
22617bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/microblaze-linux'
22717bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/microblaze-linux/.'
22817bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/microblaze-linux/bin'
22917bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/microblaze-linux/bin/microblaze-linux-gcc'
23017bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/microblaze-linux/usr/bin'
23117bce66cSSimon GlassTool chain test:  OK, arch='microblaze', priority 4
23217bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/mips64-linux'
23317bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/mips64-linux/.'
23417bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/mips64-linux/bin'
23517bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/mips64-linux/bin/mips64-linux-gcc'
23617bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/mips64-linux/usr/bin'
23717bce66cSSimon GlassTool chain test:  OK, arch='mips64', priority 4
23817bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/sparc64-linux'
23917bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/sparc64-linux/.'
24017bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/sparc64-linux/bin'
24117bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/sparc64-linux/bin/sparc64-linux-gcc'
24217bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/sparc64-linux/usr/bin'
24317bce66cSSimon GlassTool chain test:  OK, arch='sparc64', priority 4
24417bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi'
24517bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/.'
24617bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/bin'
24717bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/bin/arm-unknown-linux-gnueabi-gcc'
24817bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/arm-unknown-linux-gnueabi/usr/bin'
24917bce66cSSimon GlassTool chain test:  OK, arch='arm', priority 3
25017bce66cSSimon GlassToolchain '/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
25117bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/sparc-linux'
25217bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/sparc-linux/.'
25317bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/sparc-linux/bin'
25417bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/sparc-linux/bin/sparc-linux-gcc'
25517bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/sparc-linux/usr/bin'
25617bce66cSSimon GlassTool chain test:  OK, arch='sparc', priority 4
25717bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/mips-linux'
25817bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/mips-linux/.'
25917bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/mips-linux/bin'
26017bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/mips-linux/bin/mips-linux-gcc'
26117bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/mips-linux/usr/bin'
26217bce66cSSimon GlassTool chain test:  OK, arch='mips', priority 4
26317bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/x86_64-linux'
26417bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/.'
26517bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin'
26617bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-gcc'
26717bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-x86_64-linux-gcc'
26817bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/x86_64-linux/usr/bin'
26917bce66cSSimon GlassTool chain test:  OK, arch='x86_64', priority 4
27017bce66cSSimon GlassTool chain test:  OK, arch='x86_64', priority 4
27117bce66cSSimon GlassToolchain '/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
27217bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/m68k-linux'
27317bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/m68k-linux/.'
27417bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/m68k-linux/bin'
27517bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/m68k-linux/bin/m68k-linux-gcc'
27617bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/m68k-linux/usr/bin'
27717bce66cSSimon GlassTool chain test:  OK, arch='m68k', priority 4
27817bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.9.0-nolibc/powerpc-linux'
27917bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/powerpc-linux/.'
28017bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/powerpc-linux/bin'
28117bce66cSSimon Glass         - found '/toolchains/gcc-4.9.0-nolibc/powerpc-linux/bin/powerpc-linux-gcc'
28217bce66cSSimon Glass      - looking in '/toolchains/gcc-4.9.0-nolibc/powerpc-linux/usr/bin'
28317bce66cSSimon GlassTool chain test:  OK, arch='powerpc', priority 4
28417bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux'
28517bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux/.'
28617bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux/bin'
28717bce66cSSimon Glass         - found '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux/bin/bfin-uclinux-gcc'
28817bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/bfin-uclinux/usr/bin'
28917bce66cSSimon GlassTool chain test:  OK, arch='bfin', priority 6
29017bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.6.3-nolibc/sparc-linux'
29117bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/sparc-linux/.'
29217bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/sparc-linux/bin'
29317bce66cSSimon Glass         - found '/toolchains/gcc-4.6.3-nolibc/sparc-linux/bin/sparc-linux-gcc'
29417bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/sparc-linux/usr/bin'
29517bce66cSSimon GlassTool chain test:  OK, arch='sparc', priority 4
29617bce66cSSimon GlassToolchain '/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
29717bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.6.3-nolibc/mips-linux'
29817bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/mips-linux/.'
29917bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/mips-linux/bin'
30017bce66cSSimon Glass         - found '/toolchains/gcc-4.6.3-nolibc/mips-linux/bin/mips-linux-gcc'
30117bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/mips-linux/usr/bin'
30217bce66cSSimon GlassTool chain test:  OK, arch='mips', priority 4
30317bce66cSSimon GlassToolchain '/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
30417bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.6.3-nolibc/m68k-linux'
30517bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/m68k-linux/.'
30617bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/m68k-linux/bin'
30717bce66cSSimon Glass         - found '/toolchains/gcc-4.6.3-nolibc/m68k-linux/bin/m68k-linux-gcc'
30817bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/m68k-linux/usr/bin'
30917bce66cSSimon GlassTool chain test:  OK, arch='m68k', priority 4
31017bce66cSSimon GlassToolchain '/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
31117bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.6.3-nolibc/powerpc-linux'
31217bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/powerpc-linux/.'
31317bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/powerpc-linux/bin'
31417bce66cSSimon Glass         - found '/toolchains/gcc-4.6.3-nolibc/powerpc-linux/bin/powerpc-linux-gcc'
31517bce66cSSimon Glass      - looking in '/toolchains/gcc-4.6.3-nolibc/powerpc-linux/usr/bin'
31617bce66cSSimon GlassTool chain test:  OK, arch='powerpc', priority 4
31717bce66cSSimon GlassTool chain test:  OK, arch='or32', priority 4
31817bce66cSSimon Glass   - scanning path '/toolchains/gcc-4.2.4-nolibc/avr32-linux'
31917bce66cSSimon Glass      - looking in '/toolchains/gcc-4.2.4-nolibc/avr32-linux/.'
32017bce66cSSimon Glass      - looking in '/toolchains/gcc-4.2.4-nolibc/avr32-linux/bin'
32117bce66cSSimon Glass         - found '/toolchains/gcc-4.2.4-nolibc/avr32-linux/bin/avr32-linux-gcc'
32217bce66cSSimon Glass      - looking in '/toolchains/gcc-4.2.4-nolibc/avr32-linux/usr/bin'
32317bce66cSSimon GlassTool chain test:  OK, arch='avr32', priority 4
324fc3fe1c2SSimon Glass   - scanning path '/'
325fc3fe1c2SSimon Glass      - looking in '/.'
326fc3fe1c2SSimon Glass      - looking in '/bin'
327fc3fe1c2SSimon Glass      - looking in '/usr/bin'
32817bce66cSSimon Glass         - found '/usr/bin/i586-mingw32msvc-gcc'
329fc3fe1c2SSimon Glass         - found '/usr/bin/c89-gcc'
330fc3fe1c2SSimon Glass         - found '/usr/bin/x86_64-linux-gnu-gcc'
33117bce66cSSimon Glass         - found '/usr/bin/gcc'
33217bce66cSSimon Glass         - found '/usr/bin/c99-gcc'
33317bce66cSSimon Glass         - found '/usr/bin/arm-linux-gnueabi-gcc'
33417bce66cSSimon Glass         - found '/usr/bin/aarch64-linux-gnu-gcc'
33517bce66cSSimon Glass         - found '/usr/bin/winegcc'
33617bce66cSSimon Glass         - found '/usr/bin/arm-linux-gnueabihf-gcc'
33717bce66cSSimon GlassTool chain test:  OK, arch='i586', priority 11
33817bce66cSSimon GlassTool chain test:  OK, arch='c89', priority 11
33917bce66cSSimon GlassTool chain test:  OK, arch='x86_64', priority 4
34017bce66cSSimon GlassToolchain '/usr/bin/x86_64-linux-gnu-gcc' at priority 4 will be ignored because another toolchain for arch 'x86_64' has priority 4
34117bce66cSSimon GlassTool chain test:  OK, arch='sandbox', priority 11
34217bce66cSSimon GlassTool chain test:  OK, arch='c99', priority 11
34317bce66cSSimon GlassTool chain test:  OK, arch='arm', priority 4
34417bce66cSSimon GlassToolchain '/usr/bin/arm-linux-gnueabi-gcc' at priority 4 will be ignored because another toolchain for arch 'arm' has priority 1
34517bce66cSSimon GlassTool chain test:  OK, arch='aarch64', priority 4
34617bce66cSSimon GlassToolchain '/usr/bin/aarch64-linux-gnu-gcc' at priority 4 will be ignored because another toolchain for arch 'aarch64' has priority 4
34717bce66cSSimon GlassTool chain test:  OK, arch='sandbox', priority 11
34817bce66cSSimon GlassToolchain '/usr/bin/winegcc' at priority 11 will be ignored because another toolchain for arch 'sandbox' has priority 11
34917bce66cSSimon GlassTool chain test:  OK, arch='arm', priority 4
35017bce66cSSimon GlassToolchain '/usr/bin/arm-linux-gnueabihf-gcc' at priority 4 will be ignored because another toolchain for arch 'arm' has priority 1
35117bce66cSSimon GlassList of available toolchains (34):
35217bce66cSSimon Glassaarch64   : /toolchains/gcc-4.9.0-nolibc/aarch64-linux/bin/aarch64-linux-gcc
35317bce66cSSimon Glassalpha     : /toolchains/gcc-4.9.0-nolibc/alpha-linux/bin/alpha-linux-gcc
35417bce66cSSimon Glassam33_2.0  : /toolchains/gcc-4.9.0-nolibc/am33_2.0-linux/bin/am33_2.0-linux-gcc
35517bce66cSSimon Glassarm       : /opt/arm-eabi-4.6/bin/arm-eabi-gcc
35617bce66cSSimon Glassavr32     : /toolchains/gcc-4.2.4-nolibc/avr32-linux/bin/avr32-linux-gcc
35717bce66cSSimon Glassbfin      : /toolchains/gcc-4.6.3-nolibc/bfin-uclinux/bin/bfin-uclinux-gcc
358fc3fe1c2SSimon Glassc89       : /usr/bin/c89-gcc
359fc3fe1c2SSimon Glassc99       : /usr/bin/c99-gcc
36017bce66cSSimon Glassfrv       : /toolchains/gcc-4.9.0-nolibc/frv-linux/bin/frv-linux-gcc
36117bce66cSSimon Glassh8300     : /toolchains/gcc-4.9.0-nolibc/h8300-elf/bin/h8300-elf-gcc
36217bce66cSSimon Glasshppa      : /toolchains/gcc-4.9.0-nolibc/hppa-linux/bin/hppa-linux-gcc
36317bce66cSSimon Glasshppa64    : /toolchains/gcc-4.9.0-nolibc/hppa64-linux/bin/hppa64-linux-gcc
36417bce66cSSimon Glassi386      : /toolchains/gcc-4.9.0-nolibc/i386-linux/bin/i386-linux-gcc
36517bce66cSSimon Glassi586      : /usr/bin/i586-mingw32msvc-gcc
36617bce66cSSimon Glassia64      : /toolchains/gcc-4.9.0-nolibc/ia64-linux/bin/ia64-linux-gcc
36717bce66cSSimon Glassm32r      : /toolchains/gcc-4.9.0-nolibc/m32r-linux/bin/m32r-linux-gcc
36817bce66cSSimon Glassm68k      : /toolchains/gcc-4.9.0-nolibc/m68k-linux/bin/m68k-linux-gcc
36917bce66cSSimon Glassmicroblaze: /toolchains/gcc-4.9.0-nolibc/microblaze-linux/bin/microblaze-linux-gcc
37017bce66cSSimon Glassmips      : /toolchains/gcc-4.9.0-nolibc/mips-linux/bin/mips-linux-gcc
37117bce66cSSimon Glassmips64    : /toolchains/gcc-4.9.0-nolibc/mips64-linux/bin/mips64-linux-gcc
37217bce66cSSimon Glassor32      : /toolchains/gcc-4.5.1-nolibc/or32-linux/bin/or32-linux-gcc
37317bce66cSSimon Glasspowerpc   : /toolchains/gcc-4.9.0-nolibc/powerpc-linux/bin/powerpc-linux-gcc
37417bce66cSSimon Glasspowerpc64 : /toolchains/gcc-4.9.0-nolibc/powerpc64-linux/bin/powerpc64-linux-gcc
37517bce66cSSimon Glassppc64le   : /toolchains/gcc-4.9.0-nolibc/ppc64le-linux/bin/ppc64le-linux-gcc
37617bce66cSSimon Glasss390x     : /toolchains/gcc-4.9.0-nolibc/s390x-linux/bin/s390x-linux-gcc
377fc3fe1c2SSimon Glasssandbox   : /usr/bin/gcc
37817bce66cSSimon Glasssh4       : /toolchains/gcc-4.6.3-nolibc/sh4-linux/bin/sh4-linux-gcc
37917bce66cSSimon Glasssparc     : /toolchains/gcc-4.9.0-nolibc/sparc-linux/bin/sparc-linux-gcc
38017bce66cSSimon Glasssparc64   : /toolchains/gcc-4.9.0-nolibc/sparc64-linux/bin/sparc64-linux-gcc
38117bce66cSSimon Glasstilegx    : /toolchains/gcc-4.6.2-nolibc/tilegx-linux/bin/tilegx-linux-gcc
38217bce66cSSimon Glassx86       : /opt/gcc-4.6.3-nolibc/x86_64-linux/bin/x86_64-linux-gcc
38317bce66cSSimon Glassx86_64    : /toolchains/gcc-4.9.0-nolibc/x86_64-linux/bin/x86_64-linux-gcc
384fc3fe1c2SSimon Glass
385fc3fe1c2SSimon Glass
386fc3fe1c2SSimon GlassYou can see that everything is covered, even some strange ones that won't
387fc3fe1c2SSimon Glassbe used (c88 and c99). This is a feature.
388fc3fe1c2SSimon Glass
389fc3fe1c2SSimon Glass
390827e37b5SSimon Glass5. Install new toolchains if needed
391827e37b5SSimon Glass
392827e37b5SSimon GlassYou can download toolchains and update the [toolchain] section of the
393827e37b5SSimon Glasssettings file to find them.
394827e37b5SSimon Glass
395827e37b5SSimon GlassTo make this easier, buildman can automatically download and install
396827e37b5SSimon Glasstoolchains from kernel.org. First list the available architectures:
397827e37b5SSimon Glass
3989f244b27SBin Meng$ ./tools/buildman/buildman --fetch-arch list
399827e37b5SSimon GlassChecking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.6.3/
400827e37b5SSimon GlassChecking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.6.2/
401827e37b5SSimon GlassChecking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.5.1/
402827e37b5SSimon GlassChecking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.2.4/
403827e37b5SSimon GlassAvailable architectures: alpha am33_2.0 arm avr32 bfin cris crisv32 frv h8300
404827e37b5SSimon Glasshppa hppa64 i386 ia64 m32r m68k mips mips64 or32 powerpc powerpc64 s390x sh4
405827e37b5SSimon Glasssparc sparc64 tilegx x86_64 xtensa
406827e37b5SSimon Glass
407827e37b5SSimon GlassThen pick one and download it:
408827e37b5SSimon Glass
4099f244b27SBin Meng$ ./tools/buildman/buildman --fetch-arch or32
410827e37b5SSimon GlassChecking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.6.3/
411827e37b5SSimon GlassChecking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.6.2/
412827e37b5SSimon GlassChecking: https://www.kernel.org/pub/tools/crosstool/files/bin/x86_64/4.5.1/
413827e37b5SSimon GlassDownloading: 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
414827e37b5SSimon GlassUnpacking to: /home/sjg/.buildman-toolchains
415827e37b5SSimon GlassTesting
416827e37b5SSimon Glass      - looking in '/home/sjg/.buildman-toolchains/gcc-4.5.1-nolibc/or32-linux/.'
417827e37b5SSimon Glass      - looking in '/home/sjg/.buildman-toolchains/gcc-4.5.1-nolibc/or32-linux/bin'
418827e37b5SSimon Glass         - found '/home/sjg/.buildman-toolchains/gcc-4.5.1-nolibc/or32-linux/bin/or32-linux-gcc'
419827e37b5SSimon GlassTool chain test:  OK
420827e37b5SSimon Glass
4218951523cSThomas ChouOr download them all from kernel.org and move them to /toolchains directory,
4228951523cSThomas Chou
4238951523cSThomas Chou$ for i in aarch64 arm avr32 i386 m68k microblaze mips or32 powerpc sparc
4248951523cSThomas Chou  do
4258951523cSThomas Chou  ./tools/buildman/buildman --fetch-arch $i
4268951523cSThomas Chou  done
4278951523cSThomas Chou$ sudo mkdir -p /toolchains
4288951523cSThomas Chou$ sudo mv ~/.buildman-toolchains/*/* /toolchains/
4298951523cSThomas Chou
4308951523cSThomas ChouFor those not available from kernel.org, download from the following links.
4318951523cSThomas Chou
4328951523cSThomas Chouarc: https://github.com/foss-for-synopsys-dwc-arc-processors/toolchain/releases/
4338951523cSThomas Chou    arc_gnu_2015.06_prebuilt_uclibc_le_archs_linux_install.tar.gz
4348951523cSThomas Choublackfin: http://sourceforge.net/projects/adi-toolchain/files/
4358951523cSThomas Chou    blackfin-toolchain-elf-gcc-4.5-2014R1_45-RC2.x86_64.tar.bz2
4368951523cSThomas Chounds32: http://osdk.andestech.com/packages/
4378951523cSThomas Chou    nds32le-linux-glibc-v1.tgz
4388951523cSThomas Chounios2: http://sourcery.mentor.com/public/gnu_toolchain/nios2-linux-gnu/
4398951523cSThomas Chou    sourceryg++-2015.11-27-nios2-linux-gnu-i686-pc-linux-gnu.tar.bz2
4408951523cSThomas Choush: http://sourcery.mentor.com/public/gnu_toolchain/sh-linux-gnu/
4418951523cSThomas Chou    renesas-4.4-200-sh-linux-gnu-i686-pc-linux-gnu.tar.bz2
4428951523cSThomas Chou
443e8aebc47SBin MengNote openrisc kernel.org toolchain is out of date, download latest one from
444e8aebc47SBin Menghttp://opencores.org/or1k/OpenRISC_GNU_tool_chain#Prebuilt_versions, eg:
445e8aebc47SBin Mengftp://ocuser:ocuser@openrisc.opencores.org/toolchain/gcc-or1k-elf-4.8.1-x86.tar.bz2.
446e8aebc47SBin Meng
447827e37b5SSimon GlassBuildman should now be set up to use your new toolchain.
448827e37b5SSimon Glass
449827e37b5SSimon GlassAt the time of writing, U-Boot has these architectures:
450827e37b5SSimon Glass
451827e37b5SSimon Glass   arc, arm, avr32, blackfin, m68k, microblaze, mips, nds32, nios2, openrisc
452827e37b5SSimon Glass   powerpc, sandbox, sh, sparc, x86
453827e37b5SSimon Glass
4541246231cSMichal SimekOf these, only arc and nds32 are not available at kernel.org..
455827e37b5SSimon Glass
456827e37b5SSimon Glass
457fc3fe1c2SSimon GlassHow to run it
458fc3fe1c2SSimon Glass=============
459fc3fe1c2SSimon Glass
460fc3fe1c2SSimon GlassFirst do a dry run using the -n flag: (replace <branch> with a real, local
461fc3fe1c2SSimon Glassbranch with a valid upstream)
462fc3fe1c2SSimon Glass
463fc3fe1c2SSimon Glass$ ./tools/buildman/buildman -b <branch> -n
464fc3fe1c2SSimon Glass
465fc3fe1c2SSimon GlassIf it can't detect the upstream branch, try checking out the branch, and
4662a9e2c6aSSimon Glassdoing something like 'git branch --set-upstream-to upstream/master'
4672a9e2c6aSSimon Glassor something similar. Buildman will try to guess a suitable upstream branch
4682a9e2c6aSSimon Glassif it can't find one (you will see a message like" Guessing upstream as ...).
469fc3fe1c2SSimon Glass
470cec83c3eSSimon GlassAs an example:
471fc3fe1c2SSimon Glass
472fc3fe1c2SSimon GlassDry run, so not doing much. But I would do this:
473fc3fe1c2SSimon Glass
474fc3fe1c2SSimon GlassBuilding 18 commits for 1059 boards (4 threads, 1 job per thread)
475fc3fe1c2SSimon GlassBuild directory: ../lcd9b
476fc3fe1c2SSimon Glass    5bb3505 Merge branch 'master' of git://git.denx.de/u-boot-arm
477fc3fe1c2SSimon Glass    c18f1b4 tegra: Use const for pinmux_config_pingroup/table()
478fc3fe1c2SSimon Glass    2f043ae tegra: Add display support to funcmux
479fc3fe1c2SSimon Glass    e349900 tegra: fdt: Add pwm binding and node
480fc3fe1c2SSimon Glass    424a5f0 tegra: fdt: Add LCD definitions for Tegra
481fc3fe1c2SSimon Glass    0636ccf tegra: Add support for PWM
482fc3fe1c2SSimon Glass    a994fe7 tegra: Add SOC support for display/lcd
483fc3fe1c2SSimon Glass    fcd7350 tegra: Add LCD driver
484fc3fe1c2SSimon Glass    4d46e9d tegra: Add LCD support to Nvidia boards
485fc3fe1c2SSimon Glass    991bd48 arm: Add control over cachability of memory regions
486fc3fe1c2SSimon Glass    54e8019 lcd: Add CONFIG_LCD_ALIGNMENT to select frame buffer alignment
487fc3fe1c2SSimon Glass    d92aff7 lcd: Add support for flushing LCD fb from dcache after update
488fc3fe1c2SSimon Glass    dbd0677 tegra: Align LCD frame buffer to section boundary
489fc3fe1c2SSimon Glass    0cff9b8 tegra: Support control of cache settings for LCD
490fc3fe1c2SSimon Glass    9c56900 tegra: fdt: Add LCD definitions for Seaboard
491fc3fe1c2SSimon Glass    5cc29db lcd: Add CONFIG_CONSOLE_SCROLL_LINES option to speed console
492fc3fe1c2SSimon Glass    cac5a23 tegra: Enable display/lcd support on Seaboard
493fc3fe1c2SSimon Glass    49ff541 wip
494fc3fe1c2SSimon Glass
495fc3fe1c2SSimon GlassTotal boards to build for each commit: 1059
496fc3fe1c2SSimon Glass
497fc3fe1c2SSimon GlassThis shows that it will build all 1059 boards, using 4 threads (because
498fc3fe1c2SSimon Glasswe have a 4-core CPU). Each thread will run with -j1, meaning that each
499fc3fe1c2SSimon Glassmake job will use a single CPU. The list of commits to be built helps you
500fc3fe1c2SSimon Glassconfirm that things look about right. Notice that buildman has chosen a
501fc3fe1c2SSimon Glass'base' directory for you, immediately above your source tree.
502fc3fe1c2SSimon Glass
503fc3fe1c2SSimon GlassBuildman works entirely inside the base directory, here ../lcd9b,
504fc3fe1c2SSimon Glasscreating a working directory for each thread, and creating output
505fc3fe1c2SSimon Glassdirectories for each commit and board.
506fc3fe1c2SSimon Glass
507fc3fe1c2SSimon Glass
508fc3fe1c2SSimon GlassSuggested Workflow
509fc3fe1c2SSimon Glass==================
510fc3fe1c2SSimon Glass
511fc3fe1c2SSimon GlassTo run the build for real, take off the -n:
512fc3fe1c2SSimon Glass
513fc3fe1c2SSimon Glass$ ./tools/buildman/buildman -b <branch>
514fc3fe1c2SSimon Glass
515fc3fe1c2SSimon GlassBuildman will set up some working directories, and get started. After a
516fc3fe1c2SSimon Glassminute or so it will settle down to a steady pace, with a display like this:
517fc3fe1c2SSimon Glass
518fc3fe1c2SSimon GlassBuilding 18 commits for 1059 boards (4 threads, 1 job per thread)
519fc3fe1c2SSimon Glass  528   36  124 /19062  1:13:30  : SIMPC8313_SP
520fc3fe1c2SSimon Glass
521fc3fe1c2SSimon GlassThis means that it is building 19062 board/commit combinations. So far it
522cec83c3eSSimon Glasshas managed to successfully build 528. Another 36 have built with warnings,
523fc3fe1c2SSimon Glassand 124 more didn't build at all. Buildman expects to complete the process
524fc3fe1c2SSimon Glassin an hour and 15 minutes. Use this time to buy a faster computer.
525fc3fe1c2SSimon Glass
526fc3fe1c2SSimon Glass
527fc3fe1c2SSimon GlassTo find out how the build went, ask for a summary with -s. You can do this
5283e1ded1fSDirk Behmeeither before the build completes (presumably in another terminal) or
529fc3fe1c2SSimon Glassafterwards. Let's work through an example of how this is used:
530fc3fe1c2SSimon Glass
531fc3fe1c2SSimon Glass$ ./tools/buildman/buildman -b lcd9b -s
532fc3fe1c2SSimon Glass...
533fc3fe1c2SSimon Glass01: Merge branch 'master' of git://git.denx.de/u-boot-arm
534fc3fe1c2SSimon Glass   powerpc:   + galaxy5200_LOWBOOT
535fc3fe1c2SSimon Glass02: tegra: Use const for pinmux_config_pingroup/table()
536fc3fe1c2SSimon Glass03: tegra: Add display support to funcmux
537fc3fe1c2SSimon Glass04: tegra: fdt: Add pwm binding and node
538fc3fe1c2SSimon Glass05: tegra: fdt: Add LCD definitions for Tegra
539fc3fe1c2SSimon Glass06: tegra: Add support for PWM
540fc3fe1c2SSimon Glass07: tegra: Add SOC support for display/lcd
541fc3fe1c2SSimon Glass08: tegra: Add LCD driver
542fc3fe1c2SSimon Glass09: tegra: Add LCD support to Nvidia boards
543fc3fe1c2SSimon Glass10: arm: Add control over cachability of memory regions
544fc3fe1c2SSimon Glass11: lcd: Add CONFIG_LCD_ALIGNMENT to select frame buffer alignment
545fc3fe1c2SSimon Glass12: lcd: Add support for flushing LCD fb from dcache after update
546fc3fe1c2SSimon Glass       arm:   + lubbock
547fc3fe1c2SSimon Glass13: tegra: Align LCD frame buffer to section boundary
548fc3fe1c2SSimon Glass14: tegra: Support control of cache settings for LCD
549fc3fe1c2SSimon Glass15: tegra: fdt: Add LCD definitions for Seaboard
550fc3fe1c2SSimon Glass16: lcd: Add CONFIG_CONSOLE_SCROLL_LINES option to speed console
551fc3fe1c2SSimon Glass17: tegra: Enable display/lcd support on Seaboard
552fc3fe1c2SSimon Glass18: wip
553fc3fe1c2SSimon Glass
554fc3fe1c2SSimon GlassThis shows which commits have succeeded and which have failed. In this case
555fc3fe1c2SSimon Glassthe build is still in progress so many boards are not built yet (use -u to
556fc3fe1c2SSimon Glasssee which ones). But still we can see a few failures. The galaxy5200_LOWBOOT
557fc3fe1c2SSimon Glassnever builds correctly. This could be a problem with our toolchain, or it
558fc3fe1c2SSimon Glasscould be a bug in the upstream. The good news is that we probably don't need
559fc3fe1c2SSimon Glassto blame our commits. The bad news is it isn't tested on that board.
560fc3fe1c2SSimon Glass
561fc3fe1c2SSimon GlassCommit 12 broke lubbock. That's what the '+ lubbock' means. The failure
562fc3fe1c2SSimon Glassis never fixed by a later commit, or you would see lubbock again, in green,
563fc3fe1c2SSimon Glasswithout the +.
564fc3fe1c2SSimon Glass
565fc3fe1c2SSimon GlassTo see the actual error:
566fc3fe1c2SSimon Glass
567fc3fe1c2SSimon Glass$ ./tools/buildman/buildman -b <branch> -se lubbock
568fc3fe1c2SSimon Glass...
569fc3fe1c2SSimon Glass12: lcd: Add support for flushing LCD fb from dcache after update
570fc3fe1c2SSimon Glass       arm:   + lubbock
571fc3fe1c2SSimon Glass+common/libcommon.o: In function `lcd_sync':
572fc3fe1c2SSimon Glass+/u-boot/lcd9b/.bm-work/00/common/lcd.c:120: undefined reference to `flush_dcache_range'
573fc3fe1c2SSimon Glass+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
574fc3fe1c2SSimon Glass+make: *** [/u-boot/lcd9b/.bm-work/00/build/u-boot] Error 139
575fc3fe1c2SSimon Glass13: tegra: Align LCD frame buffer to section boundary
576fc3fe1c2SSimon Glass14: tegra: Support control of cache settings for LCD
577fc3fe1c2SSimon Glass15: tegra: fdt: Add LCD definitions for Seaboard
578fc3fe1c2SSimon Glass16: lcd: Add CONFIG_CONSOLE_SCROLL_LINES option to speed console
579fc3fe1c2SSimon Glass-/u-boot/lcd9b/.bm-work/00/common/lcd.c:120: undefined reference to `flush_dcache_range'
580fc3fe1c2SSimon Glass+/u-boot/lcd9b/.bm-work/00/common/lcd.c:125: undefined reference to `flush_dcache_range'
581fc3fe1c2SSimon Glass17: tegra: Enable display/lcd support on Seaboard
582fc3fe1c2SSimon Glass18: wip
583fc3fe1c2SSimon Glass
584fc3fe1c2SSimon GlassSo the problem is in lcd.c, due to missing cache operations. This information
585fc3fe1c2SSimon Glassshould be enough to work out what that commit is doing to break these
586fc3fe1c2SSimon Glassboards. (In this case pxa did not have cache operations defined).
587fc3fe1c2SSimon Glass
588fc3fe1c2SSimon GlassIf you see error lines marked with - that means that the errors were fixed
589fc3fe1c2SSimon Glassby that commit. Sometimes commits can be in the wrong order, so that a
590fc3fe1c2SSimon Glassbreakage is introduced for a few commits and fixed by later commits. This
591fc3fe1c2SSimon Glassshows up clearly with buildman. You can then reorder the commits and try
592fc3fe1c2SSimon Glassagain.
593fc3fe1c2SSimon Glass
594fc3fe1c2SSimon GlassAt commit 16, the error moves - you can see that the old error at line 120
595fc3fe1c2SSimon Glassis fixed, but there is a new one at line 126. This is probably only because
5963e1ded1fSDirk Behmewe added some code and moved the broken line further down the file.
597fc3fe1c2SSimon Glass
598fc3fe1c2SSimon GlassIf many boards have the same error, then -e will display the error only
599ed966657SSimon Glassonce. This makes the output as concise as possible. To see which boards have
600ed966657SSimon Glasseach error, use -l.
601fc3fe1c2SSimon Glass
602e30965dbSSimon GlassBuildman tries to distinguish warnings from errors, and shows warning lines
603e30965dbSSimon Glassseparately with a 'w' prefix.
604e30965dbSSimon Glass
605fc3fe1c2SSimon GlassThe full build output in this case is available in:
606fc3fe1c2SSimon Glass
607fc3fe1c2SSimon Glass../lcd9b/12_of_18_gd92aff7_lcd--Add-support-for/lubbock/
608fc3fe1c2SSimon Glass
609fc3fe1c2SSimon Glass   done: Indicates the build was done, and holds the return code from make.
610fc3fe1c2SSimon Glass         This is 0 for a good build, typically 2 for a failure.
611fc3fe1c2SSimon Glass
612fc3fe1c2SSimon Glass   err:  Output from stderr, if any. Errors and warnings appear here.
613fc3fe1c2SSimon Glass
614fc3fe1c2SSimon Glass   log:  Output from stdout. Normally there isn't any since buildman runs
615*c81d0d21SSimon Glass         in silent mode. Use -V to force a verbose build (this passes V=1
616*c81d0d21SSimon Glass         to 'make')
617fc3fe1c2SSimon Glass
618fc3fe1c2SSimon Glass   toolchain: Shows information about the toolchain used for the build.
619fc3fe1c2SSimon Glass
620fc3fe1c2SSimon Glass   sizes: Shows image size information.
621fc3fe1c2SSimon Glass
622fc3fe1c2SSimon GlassIt is possible to get the build output there also. Use the -k option for
623fc3fe1c2SSimon Glassthis. In that case you will also see some output files, like:
624fc3fe1c2SSimon Glass
625fc3fe1c2SSimon Glass   System.map  toolchain  u-boot  u-boot.bin  u-boot.map  autoconf.mk
626fc3fe1c2SSimon Glass   (also SPL versions u-boot-spl and u-boot-spl.bin if available)
627fc3fe1c2SSimon Glass
628fc3fe1c2SSimon Glass
629fc3fe1c2SSimon GlassChecking Image Sizes
630fc3fe1c2SSimon Glass====================
631fc3fe1c2SSimon Glass
632fc3fe1c2SSimon GlassA key requirement for U-Boot is that you keep code/data size to a minimum.
633fc3fe1c2SSimon GlassWhere a new feature increases this noticeably it should normally be put
634fc3fe1c2SSimon Glassbehind a CONFIG flag so that boards can leave it off and keep the image
635fc3fe1c2SSimon Glasssize more or less the same with each new release.
636fc3fe1c2SSimon Glass
637fc3fe1c2SSimon GlassTo check the impact of your commits on image size, use -S. For example:
638fc3fe1c2SSimon Glass
639fc3fe1c2SSimon Glass$ ./tools/buildman/buildman -b us-x86 -sS
640fc3fe1c2SSimon GlassSummary of 10 commits for 1066 boards (4 threads, 1 job per thread)
641fc3fe1c2SSimon Glass01: MAKEALL: add support for per architecture toolchains
642fc3fe1c2SSimon Glass02: x86: Add function to get top of usable ram
643fc3fe1c2SSimon Glass       x86: (for 1/3 boards)  text -272.0  rodata +41.0
644fc3fe1c2SSimon Glass03: x86: Add basic cache operations
645fc3fe1c2SSimon Glass04: x86: Permit bootstage and timer data to be used prior to relocation
646fc3fe1c2SSimon Glass       x86: (for 1/3 boards)  data +16.0
647fc3fe1c2SSimon Glass05: x86: Add an __end symbol to signal the end of the U-Boot binary
648fc3fe1c2SSimon Glass       x86: (for 1/3 boards)  text +76.0
649fc3fe1c2SSimon Glass06: x86: Rearrange the output input to remove BSS
650fc3fe1c2SSimon Glass       x86: (for 1/3 boards)  bss -2140.0
651fc3fe1c2SSimon Glass07: x86: Support relocation of FDT on start-up
652fc3fe1c2SSimon Glass       x86: +   coreboot-x86
653fc3fe1c2SSimon Glass08: x86: Add error checking to x86 relocation code
654fc3fe1c2SSimon Glass09: x86: Adjust link device tree include file
655fc3fe1c2SSimon Glass10: x86: Enable CONFIG_OF_CONTROL on coreboot
656fc3fe1c2SSimon Glass
657fc3fe1c2SSimon Glass
658fc3fe1c2SSimon GlassYou can see that image size only changed on x86, which is good because this
659fc3fe1c2SSimon Glassseries is not supposed to change any other board. From commit 7 onwards the
660fc3fe1c2SSimon Glassbuild fails so we don't get code size numbers. The numbers are fractional
661fc3fe1c2SSimon Glassbecause they are an average of all boards for that architecture. The
662fc3fe1c2SSimon Glassintention is to allow you to quickly find image size problems introduced by
663fc3fe1c2SSimon Glassyour commits.
664fc3fe1c2SSimon Glass
665fc3fe1c2SSimon GlassNote that the 'text' region and 'rodata' are split out. You should add the
666fc3fe1c2SSimon Glasstwo together to get the total read-only size (reported as the first column
667fc3fe1c2SSimon Glassin the output from binutil's 'size' utility).
668fc3fe1c2SSimon Glass
669fc3fe1c2SSimon GlassA useful option is --step which lets you skip some commits. For example
670fc3fe1c2SSimon Glass--step 2 will show the image sizes for only every 2nd commit (so it will
671fc3fe1c2SSimon Glasscompare the image sizes of the 1st, 3rd, 5th... commits). You can also use
672fc3fe1c2SSimon Glass--step 0 which will compare only the first and last commits. This is useful
673fc3fe1c2SSimon Glassfor an overview of how your entire series affects code size.
674fc3fe1c2SSimon Glass
675fc3fe1c2SSimon GlassYou can also use -d to see a detailed size breakdown for each board. This
676fc3fe1c2SSimon Glasslist is sorted in order from largest growth to largest reduction.
677fc3fe1c2SSimon Glass
678fc3fe1c2SSimon GlassIt is possible to go a little further with the -B option (--bloat). This
679cec83c3eSSimon Glassshows where U-Boot has bloated, breaking the size change down to the function
680fc3fe1c2SSimon Glasslevel. Example output is below:
681fc3fe1c2SSimon Glass
682fc3fe1c2SSimon Glass$ ./tools/buildman/buildman -b us-mem4 -sSdB
683fc3fe1c2SSimon Glass...
684fc3fe1c2SSimon Glass19: Roll crc32 into hash infrastructure
685fc3fe1c2SSimon Glass       arm: (for 10/10 boards)  all -143.4  bss +1.2  data -4.8  rodata -48.2 text -91.6
686fc3fe1c2SSimon Glass            paz00          :  all +23  bss -4  rodata -29  text +56
687fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 3/-2 bytes: 168/-104 (64)
688fc3fe1c2SSimon Glass                 function                                   old     new   delta
689fc3fe1c2SSimon Glass                 hash_command                                80     160     +80
690fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
691fc3fe1c2SSimon Glass                 ext4fs_read_file                           540     568     +28
692fc3fe1c2SSimon Glass                 insert_var_value_sub                       688     692      +4
693fc3fe1c2SSimon Glass                 run_list_real                             1996    1992      -4
694fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
695fc3fe1c2SSimon Glass            trimslice      :  all -9  bss +16  rodata -29  text +4
696fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 1/-3 bytes: 136/-124 (12)
697fc3fe1c2SSimon Glass                 function                                   old     new   delta
698fc3fe1c2SSimon Glass                 hash_command                                80     160     +80
699fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
700fc3fe1c2SSimon Glass                 ext4fs_iterate_dir                         672     668      -4
701fc3fe1c2SSimon Glass                 ext4fs_read_file                           568     548     -20
702fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
703fc3fe1c2SSimon Glass            whistler       :  all -9  bss +16  rodata -29  text +4
704fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 1/-3 bytes: 136/-124 (12)
705fc3fe1c2SSimon Glass                 function                                   old     new   delta
706fc3fe1c2SSimon Glass                 hash_command                                80     160     +80
707fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
708fc3fe1c2SSimon Glass                 ext4fs_iterate_dir                         672     668      -4
709fc3fe1c2SSimon Glass                 ext4fs_read_file                           568     548     -20
710fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
711fc3fe1c2SSimon Glass            seaboard       :  all -9  bss -28  rodata -29  text +48
712fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 3/-2 bytes: 160/-104 (56)
713fc3fe1c2SSimon Glass                 function                                   old     new   delta
714fc3fe1c2SSimon Glass                 hash_command                                80     160     +80
715fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
716fc3fe1c2SSimon Glass                 ext4fs_read_file                           548     568     +20
717fc3fe1c2SSimon Glass                 run_list_real                             1996    2000      +4
718fc3fe1c2SSimon Glass                 do_nandboot                                760     756      -4
719fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
720e57c6e5bSMarcel Ziswiler            colibri_t20    :  all -9  rodata -29  text +20
721fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 2/-3 bytes: 140/-112 (28)
722fc3fe1c2SSimon Glass                 function                                   old     new   delta
723fc3fe1c2SSimon Glass                 hash_command                                80     160     +80
724fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
725fc3fe1c2SSimon Glass                 read_abs_bbt                               204     208      +4
726fc3fe1c2SSimon Glass                 do_nandboot                                760     756      -4
727fc3fe1c2SSimon Glass                 ext4fs_read_file                           576     568      -8
728fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
729fc3fe1c2SSimon Glass            ventana        :  all -37  bss -12  rodata -29  text +4
730fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 1/-3 bytes: 136/-124 (12)
731fc3fe1c2SSimon Glass                 function                                   old     new   delta
732fc3fe1c2SSimon Glass                 hash_command                                80     160     +80
733fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
734fc3fe1c2SSimon Glass                 ext4fs_iterate_dir                         672     668      -4
735fc3fe1c2SSimon Glass                 ext4fs_read_file                           568     548     -20
736fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
737fc3fe1c2SSimon Glass            harmony        :  all -37  bss -16  rodata -29  text +8
738fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 2/-3 bytes: 140/-124 (16)
739fc3fe1c2SSimon Glass                 function                                   old     new   delta
740fc3fe1c2SSimon Glass                 hash_command                                80     160     +80
741fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
742fc3fe1c2SSimon Glass                 nand_write_oob_syndrome                    428     432      +4
743fc3fe1c2SSimon Glass                 ext4fs_iterate_dir                         672     668      -4
744fc3fe1c2SSimon Glass                 ext4fs_read_file                           568     548     -20
745fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
746fc3fe1c2SSimon Glass            medcom-wide    :  all -417  bss +28  data -16  rodata -93  text -336
747fc3fe1c2SSimon Glass               u-boot: add: 1/-1, grow: 1/-2 bytes: 88/-376 (-288)
748fc3fe1c2SSimon Glass                 function                                   old     new   delta
749fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
750fc3fe1c2SSimon Glass                 do_fat_read_at                            2872    2904     +32
751fc3fe1c2SSimon Glass                 hash_algo                                   16       -     -16
752fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
753fc3fe1c2SSimon Glass                 hash_command                               420     160    -260
754fc3fe1c2SSimon Glass            tec            :  all -449  bss -4  data -16  rodata -93  text -336
755fc3fe1c2SSimon Glass               u-boot: add: 1/-1, grow: 1/-2 bytes: 88/-376 (-288)
756fc3fe1c2SSimon Glass                 function                                   old     new   delta
757fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
758fc3fe1c2SSimon Glass                 do_fat_read_at                            2872    2904     +32
759fc3fe1c2SSimon Glass                 hash_algo                                   16       -     -16
760fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
761fc3fe1c2SSimon Glass                 hash_command                               420     160    -260
762fc3fe1c2SSimon Glass            plutux         :  all -481  bss +16  data -16  rodata -93  text -388
763fc3fe1c2SSimon Glass               u-boot: add: 1/-1, grow: 1/-3 bytes: 68/-408 (-340)
764fc3fe1c2SSimon Glass                 function                                   old     new   delta
765fc3fe1c2SSimon Glass                 crc32_wd_buf                                 -      56     +56
766fc3fe1c2SSimon Glass                 do_load_serial_bin                        1688    1700     +12
767fc3fe1c2SSimon Glass                 hash_algo                                   16       -     -16
768fc3fe1c2SSimon Glass                 do_fat_read_at                            2904    2872     -32
769fc3fe1c2SSimon Glass                 do_mem_crc                                 168      68    -100
770fc3fe1c2SSimon Glass                 hash_command                               420     160    -260
771fc3fe1c2SSimon Glass   powerpc: (for 5/5 boards)  all +37.4  data -3.2  rodata -41.8  text +82.4
772fc3fe1c2SSimon Glass            MPC8610HPCD    :  all +55  rodata -29  text +84
773fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 0/-1 bytes: 176/-96 (80)
774fc3fe1c2SSimon Glass                 function                                   old     new   delta
775fc3fe1c2SSimon Glass                 hash_command                                 -     176    +176
776fc3fe1c2SSimon Glass                 do_mem_crc                                 184      88     -96
777fc3fe1c2SSimon Glass            MPC8641HPCN    :  all +55  rodata -29  text +84
778fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 0/-1 bytes: 176/-96 (80)
779fc3fe1c2SSimon Glass                 function                                   old     new   delta
780fc3fe1c2SSimon Glass                 hash_command                                 -     176    +176
781fc3fe1c2SSimon Glass                 do_mem_crc                                 184      88     -96
782fc3fe1c2SSimon Glass            MPC8641HPCN_36BIT:  all +55  rodata -29  text +84
783fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 0/-1 bytes: 176/-96 (80)
784fc3fe1c2SSimon Glass                 function                                   old     new   delta
785fc3fe1c2SSimon Glass                 hash_command                                 -     176    +176
786fc3fe1c2SSimon Glass                 do_mem_crc                                 184      88     -96
787fc3fe1c2SSimon Glass            sbc8641d       :  all +55  rodata -29  text +84
788fc3fe1c2SSimon Glass               u-boot: add: 1/0, grow: 0/-1 bytes: 176/-96 (80)
789fc3fe1c2SSimon Glass                 function                                   old     new   delta
790fc3fe1c2SSimon Glass                 hash_command                                 -     176    +176
791fc3fe1c2SSimon Glass                 do_mem_crc                                 184      88     -96
792fc3fe1c2SSimon Glass            xpedite517x    :  all -33  data -16  rodata -93  text +76
793fc3fe1c2SSimon Glass               u-boot: add: 1/-1, grow: 0/-1 bytes: 176/-112 (64)
794fc3fe1c2SSimon Glass                 function                                   old     new   delta
795fc3fe1c2SSimon Glass                 hash_command                                 -     176    +176
796fc3fe1c2SSimon Glass                 hash_algo                                   16       -     -16
797fc3fe1c2SSimon Glass                 do_mem_crc                                 184      88     -96
798fc3fe1c2SSimon Glass...
799fc3fe1c2SSimon Glass
800fc3fe1c2SSimon Glass
801fc3fe1c2SSimon GlassThis shows that commit 19 has increased text size for arm (although only one
802fc3fe1c2SSimon Glassboard was built) and by 96 bytes for powerpc. This increase was offset in both
803fc3fe1c2SSimon Glasscases by reductions in rodata and data/bss.
804fc3fe1c2SSimon Glass
8053e1ded1fSDirk BehmeShown below the summary lines are the sizes for each board. Below each board
8063e1ded1fSDirk Behmeare the sizes for each function. This information starts with:
807fc3fe1c2SSimon Glass
808fc3fe1c2SSimon Glass   add - number of functions added / removed
809fc3fe1c2SSimon Glass   grow - number of functions which grew / shrunk
810fc3fe1c2SSimon Glass   bytes - number of bytes of code added to / removed from all functions,
811fc3fe1c2SSimon Glass            plus the total byte change in brackets
812fc3fe1c2SSimon Glass
813fc3fe1c2SSimon GlassThe change seems to be that hash_command() has increased by more than the
814fc3fe1c2SSimon Glassdo_mem_crc() function has decreased. The function sizes typically add up to
815fc3fe1c2SSimon Glassroughly the text area size, but note that every read-only section except
816fc3fe1c2SSimon Glassrodata is included in 'text', so the function total does not exactly
817fc3fe1c2SSimon Glasscorrespond.
818fc3fe1c2SSimon Glass
819fc3fe1c2SSimon GlassIt is common when refactoring code for the rodata to decrease as the text size
820fc3fe1c2SSimon Glassincreases, and vice versa.
821fc3fe1c2SSimon Glass
822fc3fe1c2SSimon Glass
82362005342SSimon GlassThe .buildman file
82462005342SSimon Glass==================
8254281ad8eSSimon Glass
82662005342SSimon GlassThe .buildman file provides information about the available toolchains and
82762005342SSimon Glassalso allows build flags to be passed to 'make'. It consists of several
82862005342SSimon Glasssections, with the section name in square brackets. Within each section are
82962005342SSimon Glassa set of (tag, value) pairs.
83062005342SSimon Glass
83162005342SSimon Glass'[toolchain]' section
83262005342SSimon Glass
83362005342SSimon Glass    This lists the available toolchains. The tag here doesn't matter, but
83462005342SSimon Glass    make sure it is unique. The value is the path to the toolchain. Buildman
83562005342SSimon Glass    will look in that path for a file ending in 'gcc'. It will then execute
83662005342SSimon Glass    it to check that it is a C compiler, passing only the --version flag to
83762005342SSimon Glass    it. If the return code is 0, buildman assumes that it is a valid C
83862005342SSimon Glass    compiler. It uses the first part of the name as the architecture and
83962005342SSimon Glass    strips off the last part when setting the CROSS_COMPILE environment
84062005342SSimon Glass    variable (parts are delimited with a hyphen).
84162005342SSimon Glass
84262005342SSimon Glass    For example powerpc-linux-gcc will be noted as a toolchain for 'powerpc'
84362005342SSimon Glass    and CROSS_COMPILE will be set to powerpc-linux- when using it.
84462005342SSimon Glass
84562005342SSimon Glass'[toolchain-alias]' section
84662005342SSimon Glass
84762005342SSimon Glass    This converts toolchain architecture names to U-Boot names. For example,
84862005342SSimon Glass    if an x86 toolchains is called i386-linux-gcc it will not normally be
8499b83bfdcSSimon Glass    used for architecture 'x86'. Adding 'x86: i386 x86_64' to this section
8509b83bfdcSSimon Glass    will tell buildman that the i386 and x86_64 toolchains can be used for
8519b83bfdcSSimon Glass    the x86 architecture.
85262005342SSimon Glass
85362005342SSimon Glass'[make-flags]' section
85462005342SSimon Glass
85562005342SSimon Glass    U-Boot's build system supports a few flags (such as BUILD_TAG) which
85662005342SSimon Glass    affect the build product. These flags can be specified in the buildman
85762005342SSimon Glass    settings file. They can also be useful when building U-Boot against other
85862005342SSimon Glass    open source software.
8594281ad8eSSimon Glass
8604281ad8eSSimon Glass    [make-flags]
8614281ad8eSSimon Glass    at91-boards=ENABLE_AT91_TEST=1
8624281ad8eSSimon Glass    snapper9260=${at91-boards} BUILD_TAG=442
8634281ad8eSSimon Glass    snapper9g45=${at91-boards} BUILD_TAG=443
8644281ad8eSSimon Glass
8654281ad8eSSimon Glass    This will use 'make ENABLE_AT91_TEST=1 BUILD_TAG=442' for snapper9260
86661242ac5SAndreas Bießmann    and 'make ENABLE_AT91_TEST=1 BUILD_TAG=443' for snapper9g45. A special
86762005342SSimon Glass    variable ${target} is available to access the target name (snapper9260
86862005342SSimon Glass    and snapper9g20 in this case). Variables are resolved recursively. Note
86962005342SSimon Glass    that variables can only contain the characters A-Z, a-z, 0-9, hyphen (-)
87062005342SSimon Glass    and underscore (_).
8714281ad8eSSimon Glass
8724281ad8eSSimon Glass    It is expected that any variables added are dealt with in U-Boot's
8734281ad8eSSimon Glass    config.mk file and documented in the README.
8744281ad8eSSimon Glass
87562005342SSimon Glass    Note that you can pass ad-hoc options to the build using environment
87662005342SSimon Glass    variables, for example:
87762005342SSimon Glass
87862005342SSimon Glass       SOME_OPTION=1234 ./tools/buildman/buildman my_board
87962005342SSimon Glass
8804281ad8eSSimon Glass
881e5a0e5d8SSimon GlassQuick Sanity Check
882e5a0e5d8SSimon Glass==================
883e5a0e5d8SSimon Glass
884e5a0e5d8SSimon GlassIf you have made changes and want to do a quick sanity check of the
8851d8104feSSimon Glasscurrently checked-out source, run buildman without the -b flag. This will
8861d8104feSSimon Glassbuild the selected boards and display build status as it runs (i.e. -v is
8871d8104feSSimon Glassenabled automatically). Use -e to see errors/warnings as well.
888e5a0e5d8SSimon Glass
889e5a0e5d8SSimon Glass
8905abab20dSSimon GlassBuilding Ranges
8915abab20dSSimon Glass===============
8925abab20dSSimon Glass
8935abab20dSSimon GlassYou can build a range of commits by specifying a range instead of a branch
8945abab20dSSimon Glasswhen using the -b flag. For example:
8955abab20dSSimon Glass
8965abab20dSSimon Glass    upstream/master..us-buildman
8975abab20dSSimon Glass
8985abab20dSSimon Glasswill build commits in us-buildman that are not in upstream/master.
8995abab20dSSimon Glass
9005abab20dSSimon Glass
901fc3fe1c2SSimon GlassOther options
902fc3fe1c2SSimon Glass=============
903fc3fe1c2SSimon Glass
904fc3fe1c2SSimon GlassBuildman has various other command line options. Try --help to see them.
905fc3fe1c2SSimon Glass
9062c3deb97SSimon GlassWhen doing builds, Buildman's return code will reflect the overall result:
9072c3deb97SSimon Glass
9082c3deb97SSimon Glass    0 (success)     No errors or warnings found
9092c3deb97SSimon Glass    128             Errors found
9102c3deb97SSimon Glass    129             Warnings found
9112c3deb97SSimon Glass
912fc3fe1c2SSimon Glass
9136eede34cSSimon GlassHow to change from MAKEALL
9146eede34cSSimon Glass==========================
9156eede34cSSimon Glass
9166eede34cSSimon GlassBuildman includes most of the features of MAKEALL and is generally faster
9176eede34cSSimon Glassand easier to use. In particular it builds entire branches: if a particular
9186eede34cSSimon Glasscommit introduces an error in a particular board, buildman can easily show
9196eede34cSSimon Glassyou this, even if a later commit fixes that error.
9206eede34cSSimon Glass
9216eede34cSSimon GlassThe reasons to deprecate MAKEALL are:
9226eede34cSSimon Glass- We don't want to maintain two build systems
9236eede34cSSimon Glass- Buildman is typically faster
9246eede34cSSimon Glass- Buildman has a lot more features
9256eede34cSSimon Glass
9266eede34cSSimon GlassBut still, many people will be sad to lose MAKEALL. If you are used to
9276eede34cSSimon GlassMAKEALL, here are a few pointers.
9286eede34cSSimon Glass
9296eede34cSSimon GlassFirst you need to set up your tool chains - see the 'Setting up' section
9306eede34cSSimon Glassfor details. Once you have your required toolchain(s) detected then you are
9316eede34cSSimon Glassready to go.
9326eede34cSSimon Glass
933e5a0e5d8SSimon GlassTo build the current source tree, run buildman without a -b flag:
934e5a0e5d8SSimon Glass
935e5a0e5d8SSimon Glass   ./tools/buildman/buildman <list of things to build>
936e5a0e5d8SSimon Glass
937e5a0e5d8SSimon GlassThis will build the current source tree for the given boards and display
938e5a0e5d8SSimon Glassthe results and errors.
939e5a0e5d8SSimon Glass
940e5a0e5d8SSimon GlassHowever buildman usually works on entire branches, and for that you must
941e5a0e5d8SSimon Glassspecify a board flag:
9426eede34cSSimon Glass
9436eede34cSSimon Glass   ./tools/buildman/buildman -b <branch_name> <list of things to build>
9446eede34cSSimon Glass
9456eede34cSSimon Glassfollowed by (afterwards, or perhaps concurrently in another terminal):
9466eede34cSSimon Glass
9476eede34cSSimon Glass   ./tools/buildman/buildman -b <branch_name> -s <list of things to build>
9486eede34cSSimon Glass
9496eede34cSSimon Glassto see the results of the build. Rather than showing you all the output,
9506eede34cSSimon Glassbuildman just shows a summary, with red indicating that a commit introduced
9516eede34cSSimon Glassan error and green indicating that a commit fixed an error. Use the -e
952ed966657SSimon Glassflag to see the full errors and -l to see which boards caused which errors.
9536eede34cSSimon Glass
954e5a0e5d8SSimon GlassIf you really want to see build results as they happen, use -v when doing a
9551d8104feSSimon Glassbuild (and -e to see the errors/warnings too).
956e5a0e5d8SSimon Glass
9576eede34cSSimon GlassYou don't need to stick around on that branch while buildman is running. It
9586eede34cSSimon Glasschecks out its own copy of the source code, so you can change branches,
9596eede34cSSimon Glassadd commits, etc. without affecting the build in progress.
9606eede34cSSimon Glass
9616eede34cSSimon GlassThe <list of things to build> can include board names, architectures or the
9626eede34cSSimon Glasslike. There are no flags to disambiguate since ambiguities are rare. Using
9636eede34cSSimon Glassthe examples from MAKEALL:
9646eede34cSSimon Glass
9656eede34cSSimon GlassExamples:
9666eede34cSSimon Glass  - build all Power Architecture boards:
9676eede34cSSimon Glass      MAKEALL -a powerpc
9686eede34cSSimon Glass      MAKEALL --arch powerpc
9696eede34cSSimon Glass      MAKEALL powerpc
9706eede34cSSimon Glass          ** buildman -b <branch> powerpc
9716eede34cSSimon Glass  - build all PowerPC boards manufactured by vendor "esd":
9726eede34cSSimon Glass      MAKEALL -a powerpc -v esd
9736eede34cSSimon Glass          ** buildman -b <branch> esd
9746eede34cSSimon Glass  - build all PowerPC boards manufactured either by "keymile" or "siemens":
9756eede34cSSimon Glass      MAKEALL -a powerpc -v keymile -v siemens
9766eede34cSSimon Glass          ** buildman -b <branch> keymile siemens
9776eede34cSSimon Glass  - build all Freescale boards with MPC83xx CPUs, plus all 4xx boards:
9786eede34cSSimon Glass      MAKEALL -c mpc83xx -v freescale 4xx
9796eede34cSSimon Glass          ** buildman -b <branch> mpc83xx freescale 4xx
9806eede34cSSimon Glass
9816eede34cSSimon GlassBuildman automatically tries to use all the CPUs in your machine. If you
9826eede34cSSimon Glassare building a lot of boards it will use one thread for every CPU core
9836eede34cSSimon Glassit detects in your machine. This is like MAKEALL's BUILD_NBUILDS option.
9846eede34cSSimon GlassYou can use the -T flag to change the number of threads. If you are only
9856eede34cSSimon Glassbuilding a few boards, buildman will automatically run make with the -j
9866eede34cSSimon Glassflag to increase the number of concurrent make tasks. It isn't normally
9876eede34cSSimon Glassthat helpful to fiddle with this option, but if you use the BUILD_NCPUS
9886eede34cSSimon Glassoption in MAKEALL then -j is the equivalent in buildman.
9896eede34cSSimon Glass
9906eede34cSSimon GlassBuildman puts its output in ../<branch_name> by default but you can change
9916eede34cSSimon Glassthis with the -o option. Buildman normally does out-of-tree builds: use -i
9926eede34cSSimon Glassto disable that if you really want to. But be careful that once you have
9936eede34cSSimon Glassused -i you pollute buildman's copies of the source tree, and you will need
9946eede34cSSimon Glassto remove the build directory (normally ../<branch_name>) to run buildman
9956eede34cSSimon Glassin normal mode (without -i).
9966eede34cSSimon Glass
9976eede34cSSimon GlassBuildman doesn't keep the output result normally, but use the -k option to
9986eede34cSSimon Glassdo this.
9996eede34cSSimon Glass
10006eede34cSSimon GlassPlease read 'Theory of Operation' a few times as it will make a lot of
10016eede34cSSimon Glassthings clearer.
10026eede34cSSimon Glass
10036eede34cSSimon GlassSome options you might like are:
10046eede34cSSimon Glass
10056eede34cSSimon Glass   -B shows which functions are growing/shrinking in which commit - great
10066eede34cSSimon Glass        for finding code bloat.
10076eede34cSSimon Glass   -S shows image sizes for each commit (just an overall summary)
10086eede34cSSimon Glass   -u shows boards that you haven't built yet
10096eede34cSSimon Glass   --step 0 will build just the upstream commit and the last commit of your
10106eede34cSSimon Glass        branch. This is often a quick sanity check that your branch doesn't
10116eede34cSSimon Glass        break anything. But note this does not check bisectability!
10126eede34cSSimon Glass
10136eede34cSSimon Glass
1014fc3fe1c2SSimon GlassTODO
1015fc3fe1c2SSimon Glass====
1016fc3fe1c2SSimon Glass
1017fc3fe1c2SSimon GlassThis has mostly be written in my spare time as a response to my difficulties
1018fc3fe1c2SSimon Glassin testing large series of patches. Apart from tidying up there is quite a
10191d8104feSSimon Glassbit of scope for improvement. Things like better error diffs and easier
10203e1ded1fSDirk Behmeaccess to log files. Also it would be nice if buildman could 'hunt' for
10211d8104feSSimon Glassproblems, perhaps by building a few boards for each arch, or checking
10221d8104feSSimon Glasscommits for changed files and building only boards which use those files.
1023fc3fe1c2SSimon Glass
1024fc3fe1c2SSimon Glass
1025fc3fe1c2SSimon GlassCredits
1026fc3fe1c2SSimon Glass=======
1027fc3fe1c2SSimon Glass
1028fc3fe1c2SSimon GlassThanks to Grant Grundler <grundler@chromium.org> for his ideas for improving
1029fc3fe1c2SSimon Glassthe build speed by building all commits for a board instead of the other
1030fc3fe1c2SSimon Glassway around.
1031fc3fe1c2SSimon Glass
1032fc3fe1c2SSimon Glass
1033fc3fe1c2SSimon GlassSimon Glass
1034fc3fe1c2SSimon Glasssjg@chromium.org
1035fc3fe1c2SSimon GlassHalloween 2012
1036fc3fe1c2SSimon GlassUpdated 12-12-12
1037fc3fe1c2SSimon GlassUpdated 23-02-13
1038