Blame view

MAKEALL 22.7 KB
f2352877c   Peter Tyser   MAKEALL: Fix retu...
1
  #!/bin/bash
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
2
3
4
  # Tool mainly for U-Boot Quality Assurance: build one or more board
  # configurations with minimal verbosity, showing only warnings and
  # errors.
eca3aeb35   Wolfgang Denk   Licenses: introdu...
5
6
  #
  # SPDX-License-Identifier:	GPL-2.0+
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
7

d8e392d95   Mike Frysinger   MAKEALL: add -h/-...
8
9
10
11
12
13
14
15
16
17
18
19
20
  usage()
  {
  	# if exiting with 0, write to stdout, else write to stderr
  	local ret=${1:-0}
  	[ "${ret}" -eq 1 ] && exec 1>&2
  	cat <<-EOF
  	Usage: MAKEALL [options] [--] [boards-to-build]
  
  	Options:
  	  -a ARCH,   --arch ARCH       Build all boards with arch ARCH
  	  -c CPU,    --cpu CPU         Build all boards with cpu CPU
  	  -v VENDOR, --vendor VENDOR   Build all boards with vendor VENDOR
  	  -s SOC,    --soc SOC         Build all boards with soc SOC
4d1584bd0   Masahiro Yamada   MAKEALL: add -b (...
21
  	  -b BOARD,  --board BOARD     Build all boards with board name BOARD
7f79c6f2f   Marek Vasut   MAKEALL: Add -l o...
22
  	  -l,        --list            List all targets to be built
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
23
24
  	  -m,        --maintainers     List all targets and maintainer email
  	  -M,        --mails           List all targets and all affilated emails
33f336d52   Kim Phillips   MAKEALL: add a -C...
25
  	  -C,        --check           Enable build checking
085102047   Joe Hershberger   MAKEALL: Add opti...
26
27
  	  -n,        --continue        Continue (skip boards already built)
  	  -r,        --rebuild-errors  Rebuild any boards that errored
d8e392d95   Mike Frysinger   MAKEALL: add -h/-...
28
29
30
31
32
33
34
35
36
37
38
39
40
  	  -h,        --help            This help output
  
  	Selections by these options are logically ANDed; if the same option
  	is used repeatedly, such selections are ORed.  So "-v FOO -v BAR"
  	will select all configurations where the vendor is either FOO or
  	BAR.  Any additional arguments specified on the command line are
  	always build additionally.  See the boards.cfg file for more info.
  
  	If no boards are specified, then the default is "powerpc".
  
  	Environment variables:
  	  BUILD_NCPUS      number of parallel make jobs (default: auto)
  	  CROSS_COMPILE    cross-compiler toolchain prefix (default: "")
47104c37d   Allen Martin   MAKEALL: add supp...
41
  	  CROSS_COMPILE_<ARCH> cross-compiler toolchain prefix for
93e145964   Wolfgang Denk   Coding Style clea...
42
43
  			   architecture "ARCH".  Substitute "ARCH" for any
  			   supported architecture (default: "")
d8e392d95   Mike Frysinger   MAKEALL: add -h/-...
44
45
  	  MAKEALL_LOGDIR   output all logs to here (default: ./LOG/)
  	  BUILD_DIR        output build directory (default: ./)
f588bb034   Andy Fleming   Allow for paralle...
46
  	  BUILD_NBUILDS	   number of parallel targets (default: 1)
d8e392d95   Mike Frysinger   MAKEALL: add -h/-...
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
  
  	Examples:
  	  - build all Power Architecture boards:
  	      MAKEALL -a powerpc
  	      MAKEALL --arch powerpc
  	      MAKEALL powerpc
  	  - build all PowerPC boards manufactured by vendor "esd":
  	      MAKEALL -a powerpc -v esd
  	  - build all PowerPC boards manufactured either by "keymile" or "siemens":
  	      MAKEALL -a powerpc -v keymile -v siemens
  	  - build all Freescale boards with MPC83xx CPUs, plus all 4xx boards:
  	      MAKEALL -c mpc83xx -v freescale 4xx
  	EOF
  	exit ${ret}
  }
f4815763b   Simon Glass   RFC: Deprecate MA...
62
63
64
65
66
67
68
  deprecation() {
  	echo "** Note: MAKEALL is deprecated - please use buildman instead"
  	echo "** See tools/buildman/README for details"
  	echo
  }
  
  deprecation
4d1584bd0   Masahiro Yamada   MAKEALL: add -b (...
69
70
  SHORT_OPTS="ha:c:v:s:b:lmMCnr"
  LONG_OPTS="help,arch:,cpu:,vendor:,soc:,board:,list,maintainers,mails,check,continue,rebuild-errors"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
71
72
  
  # Option processing based on util-linux-2.13/getopt-parse.bash
071bc9233   Wolfgang Denk   Coding Style cleanup
73
  # Note that we use `"$@"' to let each command-line parameter expand to a
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
74
75
76
77
78
  # separate word. The quotes around `$@' are essential!
  # We need TEMP as the `eval set --' would nuke the return value of
  # getopt.
  TEMP=`getopt -o ${SHORT_OPTS} --long ${LONG_OPTS} \
       -n 'MAKEALL' -- "$@"`
d8e392d95   Mike Frysinger   MAKEALL: add -h/-...
79
  [ $? != 0 ] && usage 1
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
80
81
82
83
84
  
  # Note the quotes around `$TEMP': they are essential!
  eval set -- "$TEMP"
  
  SELECTED=''
7f79c6f2f   Marek Vasut   MAKEALL: Add -l o...
85
  ONLY_LIST=''
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
86
87
  PRINT_MAINTS=''
  MAINTAINERS_ONLY=''
085102047   Joe Hershberger   MAKEALL: Add opti...
88
89
  CONTINUE=''
  REBUILD_ERRORS=''
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
  
  while true ; do
  	case "$1" in
  	-a|--arch)
  		# echo "Option ARCH: argument \`$2'"
  		if [ "$opt_a" ] ; then
  			opt_a="${opt_a%)} || \$2 == \"$2\")"
  		else
  			opt_a="(\$2 == \"$2\")"
  		fi
  		SELECTED='y'
  		shift 2 ;;
  	-c|--cpu)
  		# echo "Option CPU: argument \`$2'"
  		if [ "$opt_c" ] ; then
aa2e279d2   Allen Martin   MAKEALL: update t...
105
  			opt_c="${opt_c%)} || \$3 == \"$2\" || \$3 ~ /$2:/)"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
106
  		else
aa2e279d2   Allen Martin   MAKEALL: update t...
107
  			opt_c="(\$3 == \"$2\" || \$3 ~ /$2:/)"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
108
109
110
111
112
113
  		fi
  		SELECTED='y'
  		shift 2 ;;
  	-s|--soc)
  		# echo "Option SoC: argument \`$2'"
  		if [ "$opt_s" ] ; then
27af930e9   Albert ARIBAUD   Merge and reforma...
114
  			opt_s="${opt_s%)} || \$4 == \"$2\" || \$4 ~ /$2/)"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
115
  		else
27af930e9   Albert ARIBAUD   Merge and reforma...
116
  			opt_s="(\$4 == \"$2\" || \$4 ~ /$2/)"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
117
118
119
120
121
122
123
124
125
126
127
128
  		fi
  		SELECTED='y'
  		shift 2 ;;
  	-v|--vendor)
  		# echo "Option VENDOR: argument \`$2'"
  		if [ "$opt_v" ] ; then
  			opt_v="${opt_v%)} || \$5 == \"$2\")"
  		else
  			opt_v="(\$5 == \"$2\")"
  		fi
  		SELECTED='y'
  		shift 2 ;;
4d1584bd0   Masahiro Yamada   MAKEALL: add -b (...
129
130
131
132
133
134
135
136
137
138
139
  	-b|--board)
  		# echo "Option BOARD: argument \`$2'"
  		if [ "$opt_b" ] ; then
  			opt_b="${opt_b%)} || \$6 == \"$2\" || \$7 == \"$2\")"
  		else
  			# We need to check the 7th field too
  			# for boards whose 6th field is "-"
  			opt_b="(\$6 == \"$2\" || \$7 == \"$2\")"
  		fi
  		SELECTED='y'
  		shift 2 ;;
33f336d52   Kim Phillips   MAKEALL: add a -C...
140
141
142
  	-C|--check)
  		CHECK='C=1'
  		shift ;;
085102047   Joe Hershberger   MAKEALL: Add opti...
143
144
145
146
147
148
  	-n|--continue)
  		CONTINUE='y'
  		shift ;;
  	-r|--rebuild-errors)
  		REBUILD_ERRORS='y'
  		shift ;;
7f79c6f2f   Marek Vasut   MAKEALL: Add -l o...
149
150
151
  	-l|--list)
  		ONLY_LIST='y'
  		shift ;;
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
152
153
154
155
156
157
158
159
160
  	-m|--maintainers)
  		ONLY_LIST='y'
  		PRINT_MAINTS='y'
  		MAINTAINERS_ONLY='y'
  		shift ;;
  	-M|--mails)
  		ONLY_LIST='y'
  		PRINT_MAINTS='y'
  		shift ;;
d8e392d95   Mike Frysinger   MAKEALL: add -h/-...
161
162
  	-h|--help)
  		usage ;;
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
163
164
165
166
167
168
  	--)
  		shift ; break ;;
  	*)
  		echo "Internal error!" >&2 ; exit 1 ;;
  	esac
  done
e18fd9405   Masahiro Yamada   MAKEALL: make sur...
169
170
171
172
173
  
  GNU_MAKE=$(scripts/show-gnu-make) || {
  	echo "GNU Make not found" >&2
  	exit 1
  }
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
174
175
  # echo "Remaining arguments:"
  # for arg do echo '--> '"\`$arg'" ; done
94ab8f411   Masahiro Yamada   MAKEALL: run genb...
176
177
178
179
  tools/genboardscfg.py || {
  	echo "Failed to generate boards.cfg" >&2
  	exit 1
  }
bb6da87d7   Masahiro Yamada   MAKEALL: adjust f...
180

0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
181
182
183
184
185
  FILTER="\$1 !~ /^#/"
  [ "$opt_a" ] && FILTER="${FILTER} && $opt_a"
  [ "$opt_c" ] && FILTER="${FILTER} && $opt_c"
  [ "$opt_s" ] && FILTER="${FILTER} && $opt_s"
  [ "$opt_v" ] && FILTER="${FILTER} && $opt_v"
4d1584bd0   Masahiro Yamada   MAKEALL: add -b (...
186
  [ "$opt_b" ] && FILTER="${FILTER} && $opt_b"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
187
188
  
  if [ "$SELECTED" ] ; then
27af930e9   Albert ARIBAUD   Merge and reforma...
189
  	SELECTED=$(awk '('"$FILTER"') { print $7 }' boards.cfg)
cd57b0bb8   Peter Tyser   MAKEALL: Do a san...
190
191
192
193
194
195
  
  	# Make sure some boards from boards.cfg are actually found
  	if [ -z "$SELECTED" ] ; then
  		echo "Error: No boards selected, invalid arguments"
  		exit 1
  	fi
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
196
197
198
  fi
  
  #########################################################################
40a28f088   Peter Tyser   MAKEALL: Add summ...
199
200
201
  # Print statistics when we exit
  trap exit 1 2 3 15
  trap print_stats 0
7fa6a2f3b   Wolfgang Denk   MAKEALL: Automati...
202
203
204
205
206
  # Determine number of CPU cores if no default was set
  : ${BUILD_NCPUS:="`getconf _NPROCESSORS_ONLN`"}
  
  if [ "$BUILD_NCPUS" -gt 1 ]
  then
55f786d8b   Peter Tyser   MAKEALL: Use POSI...
207
  	JOBS="-j $((BUILD_NCPUS + 1))"
7fa6a2f3b   Wolfgang Denk   MAKEALL: Automati...
208
209
210
  else
  	JOBS=""
  fi
f93286397   Marian Balakowicz   Add support for a...
211
212
213
214
215
  if [ "${MAKEALL_LOGDIR}" ] ; then
  	LOG_DIR=${MAKEALL_LOGDIR}
  else
  	LOG_DIR="LOG"
  fi
887e2ec9e   Stefan Roese   Add support for A...
216

f588bb034   Andy Fleming   Allow for paralle...
217
218
219
220
221
222
223
224
  : ${BUILD_NBUILDS:=1}
  BUILD_MANY=0
  
  if [ "${BUILD_NBUILDS}" -gt 1 ] ; then
  	BUILD_MANY=1
  	: ${BUILD_DIR:=./build}
  	mkdir -p "${BUILD_DIR}/ERR"
  	find "${BUILD_DIR}/ERR/" -type f -exec rm -f {} +
f93286397   Marian Balakowicz   Add support for a...
225
  fi
f588bb034   Andy Fleming   Allow for paralle...
226
227
228
229
230
  : ${BUILD_DIR:=.}
  
  OUTPUT_PREFIX="${BUILD_DIR}"
  
  [ -d ${LOG_DIR} ] || mkdir "${LOG_DIR}" || exit 1
085102047   Joe Hershberger   MAKEALL: Add opti...
231
232
233
  if [ "$CONTINUE" != 'y' -a "$REBUILD_ERRORS" != 'y' ] ; then
  	find "${LOG_DIR}/" -type f -exec rm -f {} +
  fi
7ebf7443a   wdenk   Initial revision
234
235
  
  LIST=""
40a28f088   Peter Tyser   MAKEALL: Add summ...
236
237
238
  # Keep track of the number of builds and errors
  ERR_CNT=0
  ERR_LIST=""
b86a475c1   Joe Hershberger   MAKEALL: Report b...
239
240
  WRN_CNT=0
  WRN_LIST=""
40a28f088   Peter Tyser   MAKEALL: Add summ...
241
  TOTAL_CNT=0
085102047   Joe Hershberger   MAKEALL: Add opti...
242
  SKIP_CNT=0
f588bb034   Andy Fleming   Allow for paralle...
243
244
  CURRENT_CNT=0
  OLDEST_IDX=1
f2352877c   Peter Tyser   MAKEALL: Fix retu...
245
  RC=0
40a28f088   Peter Tyser   MAKEALL: Add summ...
246

9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
247
  # Helper funcs for parsing boards.cfg
8948794a2   Masahiro Yamada   MAKEALL: rename b...
248
  targets_by_field()
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
249
  {
8e5a2d425   Masahiro Yamada   MAKEALL: fix boar...
250
251
252
253
254
  	field=$1
  	regexp=$2
  
  	awk '($1 !~ /^#/ && $'"$field"' ~ /^'"$regexp"'$/) { print $7 }' \
  								boards.cfg
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
255
  }
8e5a2d425   Masahiro Yamada   MAKEALL: fix boar...
256

8948794a2   Masahiro Yamada   MAKEALL: rename b...
257
258
259
  targets_by_arch() { targets_by_field 2 "$@" ; }
  targets_by_cpu()  { targets_by_field 3 "$@" ; targets_by_field 3 "$@:.*" ; }
  targets_by_soc()  { targets_by_field 4 "$@" ; }
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
260

7ebf7443a   wdenk   Initial revision
261
  #########################################################################
0db5bca80   wdenk   * Patch by Martin...
262
263
  ## MPC5xx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
264
  LIST_5xx="$(targets_by_cpu mpc5xx)"
0db5bca80   wdenk   * Patch by Martin...
265
266
  
  #########################################################################
945af8d72   wdenk   * Add support for...
267
268
  ## MPC5xxx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
269
  LIST_5xxx="$(targets_by_cpu mpc5xxx)"
945af8d72   wdenk   * Add support for...
270
271
  
  #########################################################################
8993e54b6   Rafal Jaworowski   [ADS5121] Support...
272
273
  ## MPC512x Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
274
  LIST_512x="$(targets_by_cpu mpc512x)"
945af8d72   wdenk   * Add support for...
275
276
  
  #########################################################################
7ebf7443a   wdenk   Initial revision
277
278
  ## MPC8xx Systems
  #########################################################################
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
279

8948794a2   Masahiro Yamada   MAKEALL: rename b...
280
  LIST_8xx="$(targets_by_cpu mpc8xx)"
7ebf7443a   wdenk   Initial revision
281
282
283
284
  
  #########################################################################
  ## PPC4xx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
285
  LIST_4xx="$(targets_by_cpu ppc4xx)"
7ebf7443a   wdenk   Initial revision
286
287
  
  #########################################################################
7aa786147   wdenk   * Add support for...
288
  ## MPC8260 Systems (includes 8250, 8255 etc.)
7ebf7443a   wdenk   Initial revision
289
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
290
  LIST_8260="$(targets_by_cpu mpc8260)"
7ebf7443a   wdenk   Initial revision
291
292
  
  #########################################################################
f046ccd15   Eran Liberty   * Patch by Eran L...
293
294
  ## MPC83xx Systems (includes 8349, etc.)
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
295
  LIST_83xx="$(targets_by_cpu mpc83xx)"
f046ccd15   Eran Liberty   * Patch by Eran L...
296
297
  
  #########################################################################
42d1f0394   wdenk   * Patches by Xian...
298
299
  ## MPC85xx Systems (includes 8540, 8560 etc.)
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
300
  LIST_85xx="$(targets_by_cpu mpc85xx)"
42d1f0394   wdenk   * Patches by Xian...
301
302
  
  #########################################################################
822d55365   Jon Loeliger   Add LIST_86xx MAK...
303
304
  ## MPC86xx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
305
  LIST_86xx="$(targets_by_cpu mpc86xx)"
822d55365   Jon Loeliger   Add LIST_86xx MAK...
306
307
  
  #########################################################################
d9a42c0ac   Wolfgang Denk   MAKEALL: sort ent...
308
309
310
311
312
313
314
315
  ## PowerPC groups
  #########################################################################
  
  LIST_TSEC="		\
  	${LIST_83xx}	\
  	${LIST_85xx}	\
  	${LIST_86xx}	\
  "
a47a12bec   Stefan Roese   Move arch/ppc to ...
316
  LIST_powerpc="		\
fb56579ff   Kim Phillips   make MAKEALL more...
317
  	${LIST_5xx}	\
3deca9d44   Jean-Christophe PLAGNIOL-VILLARD   MAKEALL: add miss...
318
  	${LIST_512x}	\
fb56579ff   Kim Phillips   make MAKEALL more...
319
320
  	${LIST_5xxx}	\
  	${LIST_8xx}	\
fb56579ff   Kim Phillips   make MAKEALL more...
321
322
323
324
325
326
  	${LIST_824x}	\
  	${LIST_8260}	\
  	${LIST_83xx}	\
  	${LIST_85xx}	\
  	${LIST_86xx}	\
  	${LIST_4xx}	\
fb56579ff   Kim Phillips   make MAKEALL more...
327
  "
7ebf7443a   wdenk   Initial revision
328

a47a12bec   Stefan Roese   Move arch/ppc to ...
329
330
331
332
333
  # Alias "ppc" -> "powerpc" to not break compatibility with older scripts
  # still using "ppc" instead of "powerpc"
  LIST_ppc="		\
  	${LIST_powerpc}	\
  "
7ebf7443a   wdenk   Initial revision
334
335
336
  #########################################################################
  ## StrongARM Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
337
  LIST_SA="$(targets_by_cpu sa1100)"
7ebf7443a   wdenk   Initial revision
338
339
  
  #########################################################################
cce5d210e   Allen Martin   MAKEALL: fix per ...
340
341
  ## ARM7 Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
342
  LIST_ARM7="$(targets_by_cpu arm720t)"
cce5d210e   Allen Martin   MAKEALL: fix per ...
343
344
  
  #########################################################################
7ebf7443a   wdenk   Initial revision
345
346
  ## ARM9 Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
347
348
349
  LIST_ARM9="$(targets_by_cpu arm920t)	\
  	$(targets_by_cpu arm926ejs)	\
  	$(targets_by_cpu arm946es)	\
6f21347d4   wdenk   * Patch by George...
350
  "
7ebf7443a   wdenk   Initial revision
351
352
  
  #########################################################################
8ed960461   wdenk   * Patches by Rich...
353
354
  ## ARM11 Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
355
356
  LIST_ARM11="$(targets_by_cpu arm1136)	\
  	$(targets_by_cpu arm1176)	\
cce5d210e   Allen Martin   MAKEALL: fix per ...
357
  "
8ed960461   wdenk   * Patches by Rich...
358
359
  
  #########################################################################
f56348af5   Steve Sakoman   ARM: Rename arch/...
360
  ## ARMV7 Systems
f904cdbb6   Dirk Behme   OMAP3: Add common...
361
  #########################################################################
f37586bb1   Dirk Behme   MAKEALL ARMv7: Us...
362

8948794a2   Masahiro Yamada   MAKEALL: rename b...
363
  LIST_ARMV7="$(targets_by_cpu armv7)"
f904cdbb6   Dirk Behme   OMAP3: Add common...
364
365
  
  #########################################################################
2475e6347   David Feng   arm64: MAKEALL, f...
366
367
368
369
370
371
  ## ARMV8 Systems
  #########################################################################
  
  LIST_ARMV8="$(targets_by_cpu armv8)"
  
  #########################################################################
602cac138   Jean-Christophe PLAGNIOL-VILLARD   MAKEALL: add at91...
372
373
  ## AT91 Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
374
  LIST_at91="$(targets_by_soc at91)"
602cac138   Jean-Christophe PLAGNIOL-VILLARD   MAKEALL: add at91...
375
376
  
  #########################################################################
7ebf7443a   wdenk   Initial revision
377
378
  ## Xscale Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
379
  LIST_pxa="$(targets_by_cpu pxa)"
7ebf7443a   wdenk   Initial revision
380

d9a42c0ac   Wolfgang Denk   MAKEALL: sort ent...
381
  #########################################################################
24dede480   Stefan Roese   MAKEALL: Add spea...
382
383
  ## SPEAr Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
384
  LIST_spear="$(targets_by_soc spear)"
24dede480   Stefan Roese   MAKEALL: Add spea...
385
386
  
  #########################################################################
d9a42c0ac   Wolfgang Denk   MAKEALL: sort ent...
387
388
  ## ARM groups
  #########################################################################
2d5b561e2   wdenk   * Make sure HUSH ...
389

2475e6347   David Feng   arm64: MAKEALL, f...
390
391
392
393
394
  LIST_arm="$(targets_by_arch arm |		\
  	for ARMV8_TARGET in $LIST_ARMV8;	\
  		do sed "/$ARMV8_TARGET/d";	\
  	done)					\
  "
7ebf7443a   wdenk   Initial revision
395

c021880ac   wdenk   * Add support for...
396
  #########################################################################
b62bdffb7   Wolfgang Denk   Adjust MAKEALL sc...
397
  ## MIPS Systems		(default = big endian)
c021880ac   wdenk   * Add support for...
398
  #########################################################################
ed638b6af   Daniel Schwierzeck   MAKEALL: remove h...
399
  LIST_mips="$(targets_by_arch mips)"
c021880ac   wdenk   * Add support for...
400

7a8e9bed1   wdenk   * Patch by Marc S...
401
  #########################################################################
deddf5d2e   Stefan Kristiansson   openrisc: Add arc...
402
403
  ## OpenRISC Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
404
  LIST_openrisc="$(targets_by_arch openrisc)"
b62bdffb7   Wolfgang Denk   Adjust MAKEALL sc...
405
406
  
  #########################################################################
fea257200   Graeme Russ   x86: Rename i386 ...
407
  ## x86 Systems
7a8e9bed1   wdenk   * Patch by Marc S...
408
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
409
  LIST_x86="$(targets_by_arch x86)"
7a8e9bed1   wdenk   * Patch by Marc S...
410

c935d3bd8   wdenk   Patches by Stepha...
411
  #########################################################################
5c952cf02   wdenk   Patches by Scott ...
412
413
  ## Nios-II Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
414
  LIST_nios2="$(targets_by_arch nios2)"
5c952cf02   wdenk   Patches by Scott ...
415
416
  
  #########################################################################
857cad37a   wdenk   Patches by Yasush...
417
418
  ## MicroBlaze Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
419
  LIST_microblaze="$(targets_by_arch microblaze)"
857cad37a   wdenk   Patches by Yasush...
420

f8c3b4f31   Zachary P. Landau   Add ColdFire targ...
421
422
423
  #########################################################################
  ## ColdFire Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
424
  LIST_m68k="$(targets_by_arch m68k)"
c13f47b0d   Mike Frysinger   MAKEALL: rename c...
425
  LIST_coldfire=${LIST_m68k}
f8c3b4f31   Zachary P. Landau   Add ColdFire targ...
426

6ccec4492   Wolfgang Denk   Add ATSTK1000 and...
427
428
429
  #########################################################################
  ## AVR32 Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
430
  LIST_avr32="$(targets_by_arch avr32)"
6ccec4492   Wolfgang Denk   Add ATSTK1000 and...
431

ef26a08fe   Aubrey.Li   [Blackfin][PATCH-...
432
433
434
  #########################################################################
  ## Blackfin Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
435
  LIST_blackfin="$(targets_by_arch blackfin)"
ef26a08fe   Aubrey.Li   [Blackfin][PATCH-...
436

c71443734   Jean-Christophe PLAGNIOL-VILLARD   sh: Add sh3 and s...
437
438
439
  #########################################################################
  ## SH Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
440
441
442
  LIST_sh2="$(targets_by_cpu sh2)"
  LIST_sh3="$(targets_by_cpu sh3)"
  LIST_sh4="$(targets_by_cpu sh4)"
d9a42c0ac   Wolfgang Denk   MAKEALL: sort ent...
443

8948794a2   Masahiro Yamada   MAKEALL: rename b...
444
  LIST_sh="$(targets_by_arch sh)"
c71443734   Jean-Christophe PLAGNIOL-VILLARD   sh: Add sh3 and s...
445

c2f02da21   Daniel Hellstrom   SPARC: Added gene...
446
447
448
  #########################################################################
  ## SPARC Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
449
  LIST_sparc="$(targets_by_arch sparc)"
7ebf7443a   wdenk   Initial revision
450

5f1719c10   Macpaul Lin   adp-ag101: add bo...
451
452
453
  #########################################################################
  ## NDS32 Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
454
  LIST_nds32="$(targets_by_arch nds32)"
5f1719c10   Macpaul Lin   adp-ag101: add bo...
455

568c1fade   Alexey Brodkin   arc: add architec...
456
457
458
459
460
  #########################################################################
  ## ARC Systems
  #########################################################################
  
  LIST_arc="$(targets_by_arch arc)"
7ebf7443a   wdenk   Initial revision
461
  #-----------------------------------------------------------------------
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
462
463
464
465
466
467
468
469
  get_target_location() {
  	local target=$1
  	local BOARD_NAME=""
  	local CONFIG_NAME=""
  	local board=""
  	local vendor=""
  
  	# Automatic mode
23d6410c2   Masahiro Yamada   MAKEALL: fix awk ...
470
  	local line=`awk '\$7 == "'"$target"'" { print \$0 }' boards.cfg`
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
471
472
473
  	if [ -z "${line}" ] ; then echo "" ; return ; fi
  
  	set ${line}
bb6da87d7   Masahiro Yamada   MAKEALL: adjust f...
474
  	CONFIG_NAME="${7%_defconfig}"
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
475

bb6da87d7   Masahiro Yamada   MAKEALL: adjust f...
476
  	[ "${BOARD_NAME}" ] || BOARD_NAME="${7%_defconfig}"
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
477

27af930e9   Albert ARIBAUD   Merge and reforma...
478
479
480
481
482
483
  	if [ $# -gt 5 ]; then
  		if [ "$6" = "-" ] ; then
  			board=${BOARD_NAME}
  		else
  			board="$6"
  		fi
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
484
485
486
  	fi
  
  	[ $# -gt 4 ] && [ "$5" != "-" ] && vendor="$5"
27af930e9   Albert ARIBAUD   Merge and reforma...
487
488
  	[ $# -gt 6 ] && [ "$8" != "-" ] && {
  		tmp="${8%:*}"
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
489
490
491
492
493
494
  		if [ "$tmp" ] ; then
  			CONFIG_NAME="$tmp"
  		fi
  	}
  
  	# Assign board directory to BOARDIR variable
27af930e9   Albert ARIBAUD   Merge and reforma...
495
  	if [ "${vendor}" == "-" ] ; then
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
496
497
498
499
  	    BOARDDIR=${board}
  	else
  	    BOARDDIR=${vendor}/${board}
  	fi
27af930e9   Albert ARIBAUD   Merge and reforma...
500
  	echo "${CONFIG_NAME}:${BOARDDIR}:${BOARD_NAME}"
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
501
502
503
  }
  
  get_target_maintainers() {
27af930e9   Albert ARIBAUD   Merge and reforma...
504
  	local name=`echo $1 | cut -d : -f 3`
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
505

23d6410c2   Masahiro Yamada   MAKEALL: fix awk ...
506
  	local line=`awk '\$7 == "'"$target"'" { print \$0 }' boards.cfg`
27af930e9   Albert ARIBAUD   Merge and reforma...
507
  	if [ -z "${line}" ]; then
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
508
509
510
  		echo ""
  		return ;
  	fi
27af930e9   Albert ARIBAUD   Merge and reforma...
511
512
513
  	local mails=`echo ${line} | cut -d ' ' -f 9- | sed -e 's/[^<]*<//' -e 's/>.*</ /' -e 's/>[^>]*$//'`
  	[ "$mails" == "-" ] && mails=""
  	echo "$mails"
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
514
  }
47104c37d   Allen Martin   MAKEALL: add supp...
515
516
  get_target_arch() {
  	local target=$1
bf678dfd4   Masahiro Yamada   MAKEALL: fix get_...
517
  	awk '$7 == "'$target'" { print $2 }' boards.cfg
47104c37d   Allen Martin   MAKEALL: add supp...
518
  }
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
  list_target() {
  	if [ "$PRINT_MAINTS" != 'y' ] ; then
  		echo "$1"
  		return
  	fi
  
  	echo -n "$1:"
  
  	local loc=`get_target_location $1`
  
  	if [ -z "${loc}" ] ; then echo "ERROR" ; return ; fi
  
  	local maintainers_result=`get_target_maintainers ${loc} | tr " " "
  "`
  
  	if [ "$MAINTAINERS_ONLY" != 'y' ] ; then
  
  		local dir=`echo ${loc} | cut -d ":" -f 2`
  		local cfg=`echo ${loc} | cut -d ":" -f 1`
  		local git_result=`git log --format=%aE board/${dir} \
  				include/configs/${cfg}.h | grep "@"`
  		local git_result_recent=`echo ${git_result} | tr " " "
  " | \
  						head -n 3`
  		local git_result_top=`echo ${git_result} | tr " " "
  " | \
  			sort | uniq -c | sort -nr | head -n 3 | \
  			sed "s/^ \+[0-9]\+ \+//"`
  
  		echo -e "$git_result_recent
  $git_result_top
  $maintainers_result" | \
  			sort -u | tr "
  " " " | sed "s/ $//" ;
  	else
  		echo -e "$maintainers_result" | sort -u | tr "
  " " " | \
  						sed "s/ $//" ;
  	fi
  
  	echo ""
  }
f588bb034   Andy Fleming   Allow for paralle...
561
562
563
564
565
566
567
  # Each finished build will have a file called ${donep}${n},
  # where n is the index of the build. Each build
  # we've already noted as finished will have ${skipp}${n}.
  # The code managing the build process will use this information
  # to ensure that only BUILD_NBUILDS builds are in flight at once
  donep="${LOG_DIR}/._done_"
  skipp="${LOG_DIR}/._skip_"
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
568
569
570
571
572
573
  build_target_killed() {
  	echo "Aborted $target build."
  	# Remove the logs for this board since it was aborted
  	rm -f ${LOG_DIR}/$target.MAKELOG ${LOG_DIR}/$target.ERR
  	exit
  }
7ebf7443a   wdenk   Initial revision
574
575
  build_target() {
  	target=$1
f588bb034   Andy Fleming   Allow for paralle...
576
  	build_idx=$2
f50bf50d7   Andy Fleming   Improve MAKEALL p...
577
578
579
580
  	if [ "$ONLY_LIST" == 'y' ] ; then
  		list_target ${target}
  		return
  	fi
f588bb034   Andy Fleming   Allow for paralle...
581
582
583
  	if [ $BUILD_MANY == 1 ] ; then
  		output_dir="${OUTPUT_PREFIX}/${target}"
  		mkdir -p "${output_dir}"
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
584
  		trap build_target_killed TERM
f588bb034   Andy Fleming   Allow for paralle...
585
586
587
  	else
  		output_dir="${OUTPUT_PREFIX}"
  	fi
47104c37d   Allen Martin   MAKEALL: add supp...
588
  	target_arch=$(get_target_arch ${target})
c17b94ec5   York Sun   MAKEALL: Fix case...
589
  	eval cross_toolchain=\$CROSS_COMPILE_`echo $target_arch | tr '[:lower:]' '[:upper:]'`
47104c37d   Allen Martin   MAKEALL: add supp...
590
  	if [ "${cross_toolchain}" ] ; then
e18fd9405   Masahiro Yamada   MAKEALL: make sur...
591
  	    MAKE="$GNU_MAKE CROSS_COMPILE=${cross_toolchain}"
47104c37d   Allen Martin   MAKEALL: add supp...
592
  	elif [ "${CROSS_COMPILE}" ] ; then
e18fd9405   Masahiro Yamada   MAKEALL: make sur...
593
  	    MAKE="$GNU_MAKE CROSS_COMPILE=${CROSS_COMPILE}"
47104c37d   Allen Martin   MAKEALL: add supp...
594
  	else
e18fd9405   Masahiro Yamada   MAKEALL: make sur...
595
  	    MAKE=$GNU_MAKE
47104c37d   Allen Martin   MAKEALL: add supp...
596
  	fi
9e4140329   Masahiro Yamada   kbuild: change ou...
597
598
599
  	if [  "${output_dir}" != "." ] ; then
  		MAKE="${MAKE} O=${output_dir}"
  	fi
fd18a89e7   Roger Meier   Makefile: remove ...
600
  	${MAKE} mrproper >/dev/null
bb6da87d7   Masahiro Yamada   MAKEALL: adjust f...
601
602
603
  
  	echo "Building ${target} board..."
  	${MAKE} -s ${target}_defconfig >/dev/null
f93286397   Marian Balakowicz   Add support for a...
604

33f336d52   Kim Phillips   MAKEALL: add a -C...
605
  	${MAKE} ${JOBS} ${CHECK} all \
f588bb034   Andy Fleming   Allow for paralle...
606
  		>${LOG_DIR}/$target.MAKELOG 2> ${LOG_DIR}/$target.ERR
f2352877c   Peter Tyser   MAKEALL: Fix retu...
607
608
609
610
611
  
  	# Check for 'make' errors
  	if [ ${PIPESTATUS[0]} -ne 0 ] ; then
  		RC=1
  	fi
e71796a70   Joe Hershberger   MAKEALL: Don't tr...
612
613
614
615
616
617
  	OBJS=${output_dir}/u-boot
  	if [ -e ${output_dir}/spl/u-boot-spl ]; then
  		OBJS="${OBJS} ${output_dir}/spl/u-boot-spl"
  	fi
  
  	${CROSS_COMPILE}size ${OBJS} | tee -a ${LOG_DIR}/$target.MAKELOG
f588bb034   Andy Fleming   Allow for paralle...
618
  	if [ $BUILD_MANY == 1 ] ; then
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
619
  		trap - TERM
7390643f7   Masahiro Yamada   Makefile: remove ...
620
  		${MAKE} -s clean
f588bb034   Andy Fleming   Allow for paralle...
621
622
  
  		if [ -s ${LOG_DIR}/${target}.ERR ] ; then
b86a475c1   Joe Hershberger   MAKEALL: Report b...
623
  			cp ${LOG_DIR}/${target}.ERR ${OUTPUT_PREFIX}/ERR/${target}
f588bb034   Andy Fleming   Allow for paralle...
624
625
626
  		else
  			rm ${LOG_DIR}/${target}.ERR
  		fi
40a28f088   Peter Tyser   MAKEALL: Add summ...
627
  	else
f588bb034   Andy Fleming   Allow for paralle...
628
  		if [ -s ${LOG_DIR}/${target}.ERR ] ; then
b86a475c1   Joe Hershberger   MAKEALL: Report b...
629
630
631
632
633
634
635
  			if grep -iw error ${LOG_DIR}/${target}.ERR ; then
  				: $(( ERR_CNT += 1 ))
  				ERR_LIST="${ERR_LIST} $target"
  			else
  				: $(( WRN_CNT += 1 ))
  				WRN_LIST="${WRN_LIST} $target"
  			fi
f588bb034   Andy Fleming   Allow for paralle...
636
637
638
  		else
  			rm ${LOG_DIR}/${target}.ERR
  		fi
40a28f088   Peter Tyser   MAKEALL: Add summ...
639
  	fi
f588bb034   Andy Fleming   Allow for paralle...
640
  	[ -e "${LOG_DIR}/${target}.ERR" ] && cat "${LOG_DIR}/${target}.ERR"
f588bb034   Andy Fleming   Allow for paralle...
641
  	touch "${donep}${build_idx}"
7ebf7443a   wdenk   Initial revision
642
  }
f588bb034   Andy Fleming   Allow for paralle...
643
644
645
  
  manage_builds() {
  	search_idx=${OLDEST_IDX}
f50bf50d7   Andy Fleming   Improve MAKEALL p...
646
  	if [ "$ONLY_LIST" == 'y' ] ; then return ; fi
f588bb034   Andy Fleming   Allow for paralle...
647
648
  	while true; do
  		if [ -e "${donep}${search_idx}" ] ; then
f588bb034   Andy Fleming   Allow for paralle...
649
650
651
652
653
654
655
656
657
658
659
  			: $(( CURRENT_CNT-- ))
  			[ ${OLDEST_IDX} -eq ${search_idx} ] &&
  				: $(( OLDEST_IDX++ ))
  
  			# Only want to count it once
  			rm -f "${donep}${search_idx}"
  			touch "${skipp}${search_idx}"
  		elif [ -e "${skipp}${search_idx}" ] ; then
  			[ ${OLDEST_IDX} -eq ${search_idx} ] &&
  				: $(( OLDEST_IDX++ ))
  		fi
f588bb034   Andy Fleming   Allow for paralle...
660
661
  		: $(( search_idx++ ))
  		if [ ${search_idx} -gt ${TOTAL_CNT} ] ; then
f588bb034   Andy Fleming   Allow for paralle...
662
663
664
665
666
667
668
669
670
  			if [ ${CURRENT_CNT} -ge ${BUILD_NBUILDS} ] ; then
  				search_idx=${OLDEST_IDX}
  				sleep 1
  			else
  				break
  			fi
  		fi
  	done
  }
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
671
672
673
674
675
676
677
678
679
680
681
682
  build_targets() {
  	for t in "$@" ; do
  		# If a LIST_xxx var exists, use it.  But avoid variable
  		# expansion in the eval when a board name contains certain
  		# characters that the shell interprets.
  		case ${t} in
  			*[-+=]*) list= ;;
  			*)       list=$(eval echo '${LIST_'$t'}') ;;
  		esac
  		if [ -n "${list}" ] ; then
  			build_targets ${list}
  		else
f588bb034   Andy Fleming   Allow for paralle...
683
684
685
686
  			: $((TOTAL_CNT += 1))
  			: $((CURRENT_CNT += 1))
  			rm -f "${donep}${TOTAL_CNT}"
  			rm -f "${skipp}${TOTAL_CNT}"
085102047   Joe Hershberger   MAKEALL: Add opti...
687
688
689
690
691
692
  			if [ "$CONTINUE" = 'y' -a -e ${LOG_DIR}/$t.MAKELOG ] ; then
  				: $((SKIP_CNT += 1))
  				touch "${donep}${TOTAL_CNT}"
  			elif [ "$REBUILD_ERRORS" = 'y' -a ! -e ${LOG_DIR}/$t.ERR ] ; then
  				: $((SKIP_CNT += 1))
  				touch "${donep}${TOTAL_CNT}"
b594bd6ab   Joe Hershberger   MAKEALL: Fix erro...
693
  			else
085102047   Joe Hershberger   MAKEALL: Add opti...
694
695
696
697
698
699
700
  				if [ $BUILD_MANY == 1 ] ; then
  					build_target ${t} ${TOTAL_CNT} &
  				else
  					CUR_TGT="${t}"
  					build_target ${t} ${TOTAL_CNT}
  					CUR_TGT=''
  				fi
b594bd6ab   Joe Hershberger   MAKEALL: Fix erro...
701
  			fi
f588bb034   Andy Fleming   Allow for paralle...
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
  		fi
  
  		# We maintain a running count of all the builds we have done.
  		# Each finished build will have a file called ${donep}${n},
  		# where n is the index of the build. Each build
  		# we've already noted as finished will have ${skipp}${n}.
  		# We track the current index via TOTAL_CNT, and the oldest
  		# index. When we exceed the maximum number of parallel builds,
  		# We look from oldest to current for builds that have completed,
  		# and update the current count and oldest index as appropriate.
  		# If we've gone through the entire list, wait a second, and
  		# reprocess the entire list until we find a build that has
  		# completed
  		if [ ${CURRENT_CNT} -ge ${BUILD_NBUILDS} ] ; then
  			manage_builds
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
717
718
719
  		fi
  	done
  }
7ebf7443a   wdenk   Initial revision
720
721
  
  #-----------------------------------------------------------------------
f50bf50d7   Andy Fleming   Improve MAKEALL p...
722
  kill_children() {
6bdd9f896   Andreas Bießmann   MAKEALL: fix kill...
723
724
725
726
727
728
729
730
731
732
733
734
735
736
  	local OS=$(uname -s)
  	local children=""
  	case "${OS}" in
  		"Darwin")
  			# Mac OS X is known to have BSD style ps
  			local pgid=$(ps -p $$ -o pgid | sed -e "/PGID/d")
  			children=$(ps -g $pgid -o pid | sed -e "/PID\|$$\|$pgid/d")
  			;;
  		*)
  			# everything else tries the GNU style
  			local pgid=$(ps -p $$ --no-headers -o "%r" | tr -d ' ')
  			children=$(pgrep -g $pgid | sed -e "/$$\|$pgid/d")
  			;;
  	esac
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
737
738
739
  
  	kill $children 2> /dev/null
  	wait $children 2> /dev/null
f50bf50d7   Andy Fleming   Improve MAKEALL p...
740
741
742
  
  	exit
  }
40a28f088   Peter Tyser   MAKEALL: Add summ...
743
  print_stats() {
7f79c6f2f   Marek Vasut   MAKEALL: Add -l o...
744
  	if [ "$ONLY_LIST" == 'y' ] ; then return ; fi
f588bb034   Andy Fleming   Allow for paralle...
745

c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
746
747
  	# Only count boards that completed
  	: $((TOTAL_CNT = `find ${skipp}* 2> /dev/null | wc -l`))
f588bb034   Andy Fleming   Allow for paralle...
748
749
750
  	rm -f ${donep}* ${skipp}*
  
  	if [ $BUILD_MANY == 1 ] && [ -e "${OUTPUT_PREFIX}/ERR" ] ; then
033220e7a   Andy Fleming   MAKEALL: Allow em...
751
  		ERR_LIST=`grep -riwl error ${OUTPUT_PREFIX}/ERR/`
b86a475c1   Joe Hershberger   MAKEALL: Report b...
752
753
  		ERR_LIST=`for f in $ERR_LIST ; do echo -n " $(basename $f)" ; done`
  		ERR_CNT=`echo $ERR_LIST | wc -w | awk '{print $1}'`
033220e7a   Andy Fleming   MAKEALL: Allow em...
754
  		WRN_LIST=`grep -riwL error ${OUTPUT_PREFIX}/ERR/`
b86a475c1   Joe Hershberger   MAKEALL: Report b...
755
756
  		WRN_LIST=`for f in $WRN_LIST ; do echo -n " $(basename $f)" ; done`
  		WRN_CNT=`echo $WRN_LIST | wc -w | awk '{print $1}'`
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
757
758
759
  	else
  		# Remove the logs for any board that was interrupted
  		rm -f ${LOG_DIR}/${CUR_TGT}.MAKELOG ${LOG_DIR}/${CUR_TGT}.ERR
f588bb034   Andy Fleming   Allow for paralle...
760
  	fi
085102047   Joe Hershberger   MAKEALL: Add opti...
761
  	: $((TOTAL_CNT -= ${SKIP_CNT}))
40a28f088   Peter Tyser   MAKEALL: Add summ...
762
763
  	echo ""
  	echo "--------------------- SUMMARY ----------------------------"
085102047   Joe Hershberger   MAKEALL: Add opti...
764
765
766
  	if [ "$CONTINUE" = 'y' -o "$REBUILD_ERRORS" = 'y' ] ; then
  		echo "Boards skipped: ${SKIP_CNT}"
  	fi
40a28f088   Peter Tyser   MAKEALL: Add summ...
767
768
  	echo "Boards compiled: ${TOTAL_CNT}"
  	if [ ${ERR_CNT} -gt 0 ] ; then
b86a475c1   Joe Hershberger   MAKEALL: Report b...
769
770
771
772
  		echo "Boards with errors: ${ERR_CNT} (${ERR_LIST} )"
  	fi
  	if [ ${WRN_CNT} -gt 0 ] ; then
  		echo "Boards with warnings but no errors: ${WRN_CNT} (${WRN_LIST} )"
40a28f088   Peter Tyser   MAKEALL: Add summ...
773
774
  	fi
  	echo "----------------------------------------------------------"
f2352877c   Peter Tyser   MAKEALL: Fix retu...
775

f50bf50d7   Andy Fleming   Improve MAKEALL p...
776
  	if [ $BUILD_MANY == 1 ] ; then
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
777
  		kill_children
f50bf50d7   Andy Fleming   Improve MAKEALL p...
778
  	fi
f4815763b   Simon Glass   RFC: Deprecate MA...
779
  	deprecation
f2352877c   Peter Tyser   MAKEALL: Fix retu...
780
  	exit $RC
40a28f088   Peter Tyser   MAKEALL: Add summ...
781
  }
7ebf7443a   wdenk   Initial revision
782

40a28f088   Peter Tyser   MAKEALL: Add summ...
783
  #-----------------------------------------------------------------------
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
784

0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
785
786
787
  # Build target groups selected by options, plus any command line args
  set -- ${SELECTED} "$@"
  # run PowerPC by default
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
788
  [ $# = 0 ] && set -- powerpc
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
789
  build_targets "$@"
f588bb034   Andy Fleming   Allow for paralle...
790
  wait