Blame view

MAKEALL 22.5 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}
  }
4d1584bd0   Masahiro Yamada   MAKEALL: add -b (...
62
63
  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...
64
65
  
  # Option processing based on util-linux-2.13/getopt-parse.bash
071bc9233   Wolfgang Denk   Coding Style cleanup
66
  # Note that we use `"$@"' to let each command-line parameter expand to a
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
67
68
69
70
71
  # 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/-...
72
  [ $? != 0 ] && usage 1
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
73
74
75
76
77
  
  # Note the quotes around `$TEMP': they are essential!
  eval set -- "$TEMP"
  
  SELECTED=''
7f79c6f2f   Marek Vasut   MAKEALL: Add -l o...
78
  ONLY_LIST=''
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
79
80
  PRINT_MAINTS=''
  MAINTAINERS_ONLY=''
085102047   Joe Hershberger   MAKEALL: Add opti...
81
82
  CONTINUE=''
  REBUILD_ERRORS=''
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
  
  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...
98
  			opt_c="${opt_c%)} || \$3 == \"$2\" || \$3 ~ /$2:/)"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
99
  		else
aa2e279d2   Allen Martin   MAKEALL: update t...
100
  			opt_c="(\$3 == \"$2\" || \$3 ~ /$2:/)"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
101
102
103
104
105
106
  		fi
  		SELECTED='y'
  		shift 2 ;;
  	-s|--soc)
  		# echo "Option SoC: argument \`$2'"
  		if [ "$opt_s" ] ; then
27af930e9   Albert ARIBAUD   Merge and reforma...
107
  			opt_s="${opt_s%)} || \$4 == \"$2\" || \$4 ~ /$2/)"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
108
  		else
27af930e9   Albert ARIBAUD   Merge and reforma...
109
  			opt_s="(\$4 == \"$2\" || \$4 ~ /$2/)"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
110
111
112
113
114
115
116
117
118
119
120
121
  		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 (...
122
123
124
125
126
127
128
129
130
131
132
  	-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...
133
134
135
  	-C|--check)
  		CHECK='C=1'
  		shift ;;
085102047   Joe Hershberger   MAKEALL: Add opti...
136
137
138
139
140
141
  	-n|--continue)
  		CONTINUE='y'
  		shift ;;
  	-r|--rebuild-errors)
  		REBUILD_ERRORS='y'
  		shift ;;
7f79c6f2f   Marek Vasut   MAKEALL: Add -l o...
142
143
144
  	-l|--list)
  		ONLY_LIST='y'
  		shift ;;
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
145
146
147
148
149
150
151
152
153
  	-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/-...
154
155
  	-h|--help)
  		usage ;;
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
156
157
158
159
160
161
  	--)
  		shift ; break ;;
  	*)
  		echo "Internal error!" >&2 ; exit 1 ;;
  	esac
  done
e18fd9405   Masahiro Yamada   MAKEALL: make sur...
162
163
164
165
166
  
  GNU_MAKE=$(scripts/show-gnu-make) || {
  	echo "GNU Make not found" >&2
  	exit 1
  }
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
167
168
  # echo "Remaining arguments:"
  # for arg do echo '--> '"\`$arg'" ; done
94ab8f411   Masahiro Yamada   MAKEALL: run genb...
169
170
171
172
  tools/genboardscfg.py || {
  	echo "Failed to generate boards.cfg" >&2
  	exit 1
  }
bb6da87d7   Masahiro Yamada   MAKEALL: adjust f...
173

0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
174
175
176
177
178
  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 (...
179
  [ "$opt_b" ] && FILTER="${FILTER} && $opt_b"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
180
181
  
  if [ "$SELECTED" ] ; then
27af930e9   Albert ARIBAUD   Merge and reforma...
182
  	SELECTED=$(awk '('"$FILTER"') { print $7 }' boards.cfg)
cd57b0bb8   Peter Tyser   MAKEALL: Do a san...
183
184
185
186
187
188
  
  	# 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...
189
190
191
  fi
  
  #########################################################################
40a28f088   Peter Tyser   MAKEALL: Add summ...
192
193
194
  # Print statistics when we exit
  trap exit 1 2 3 15
  trap print_stats 0
7fa6a2f3b   Wolfgang Denk   MAKEALL: Automati...
195
196
197
198
199
  # 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...
200
  	JOBS="-j $((BUILD_NCPUS + 1))"
7fa6a2f3b   Wolfgang Denk   MAKEALL: Automati...
201
202
203
  else
  	JOBS=""
  fi
f93286397   Marian Balakowicz   Add support for a...
204
205
206
207
208
  if [ "${MAKEALL_LOGDIR}" ] ; then
  	LOG_DIR=${MAKEALL_LOGDIR}
  else
  	LOG_DIR="LOG"
  fi
887e2ec9e   Stefan Roese   Add support for A...
209

f588bb034   Andy Fleming   Allow for paralle...
210
211
212
213
214
215
216
217
  : ${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...
218
  fi
f588bb034   Andy Fleming   Allow for paralle...
219
220
221
222
223
  : ${BUILD_DIR:=.}
  
  OUTPUT_PREFIX="${BUILD_DIR}"
  
  [ -d ${LOG_DIR} ] || mkdir "${LOG_DIR}" || exit 1
085102047   Joe Hershberger   MAKEALL: Add opti...
224
225
226
  if [ "$CONTINUE" != 'y' -a "$REBUILD_ERRORS" != 'y' ] ; then
  	find "${LOG_DIR}/" -type f -exec rm -f {} +
  fi
7ebf7443a   wdenk   Initial revision
227
228
  
  LIST=""
40a28f088   Peter Tyser   MAKEALL: Add summ...
229
230
231
  # Keep track of the number of builds and errors
  ERR_CNT=0
  ERR_LIST=""
b86a475c1   Joe Hershberger   MAKEALL: Report b...
232
233
  WRN_CNT=0
  WRN_LIST=""
40a28f088   Peter Tyser   MAKEALL: Add summ...
234
  TOTAL_CNT=0
085102047   Joe Hershberger   MAKEALL: Add opti...
235
  SKIP_CNT=0
f588bb034   Andy Fleming   Allow for paralle...
236
237
  CURRENT_CNT=0
  OLDEST_IDX=1
f2352877c   Peter Tyser   MAKEALL: Fix retu...
238
  RC=0
40a28f088   Peter Tyser   MAKEALL: Add summ...
239

9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
240
  # Helper funcs for parsing boards.cfg
8948794a2   Masahiro Yamada   MAKEALL: rename b...
241
  targets_by_field()
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
242
  {
8e5a2d425   Masahiro Yamada   MAKEALL: fix boar...
243
244
245
246
247
  	field=$1
  	regexp=$2
  
  	awk '($1 !~ /^#/ && $'"$field"' ~ /^'"$regexp"'$/) { print $7 }' \
  								boards.cfg
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
248
  }
8e5a2d425   Masahiro Yamada   MAKEALL: fix boar...
249

8948794a2   Masahiro Yamada   MAKEALL: rename b...
250
251
252
  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...
253

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

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

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

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

d9a42c0ac   Wolfgang Denk   MAKEALL: sort ent...
374
  #########################################################################
24dede480   Stefan Roese   MAKEALL: Add spea...
375
376
  ## SPEAr Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
377
  LIST_spear="$(targets_by_soc spear)"
24dede480   Stefan Roese   MAKEALL: Add spea...
378
379
  
  #########################################################################
d9a42c0ac   Wolfgang Denk   MAKEALL: sort ent...
380
381
  ## ARM groups
  #########################################################################
2d5b561e2   wdenk   * Make sure HUSH ...
382

2475e6347   David Feng   arm64: MAKEALL, f...
383
384
385
386
387
  LIST_arm="$(targets_by_arch arm |		\
  	for ARMV8_TARGET in $LIST_ARMV8;	\
  		do sed "/$ARMV8_TARGET/d";	\
  	done)					\
  "
7ebf7443a   wdenk   Initial revision
388

c021880ac   wdenk   * Add support for...
389
  #########################################################################
b62bdffb7   Wolfgang Denk   Adjust MAKEALL sc...
390
  ## MIPS Systems		(default = big endian)
c021880ac   wdenk   * Add support for...
391
  #########################################################################
ed638b6af   Daniel Schwierzeck   MAKEALL: remove h...
392
  LIST_mips="$(targets_by_arch mips)"
c021880ac   wdenk   * Add support for...
393

7a8e9bed1   wdenk   * Patch by Marc S...
394
  #########################################################################
deddf5d2e   Stefan Kristiansson   openrisc: Add arc...
395
396
  ## OpenRISC Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
397
  LIST_openrisc="$(targets_by_arch openrisc)"
b62bdffb7   Wolfgang Denk   Adjust MAKEALL sc...
398
399
  
  #########################################################################
fea257200   Graeme Russ   x86: Rename i386 ...
400
  ## x86 Systems
7a8e9bed1   wdenk   * Patch by Marc S...
401
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
402
  LIST_x86="$(targets_by_arch x86)"
7a8e9bed1   wdenk   * Patch by Marc S...
403

c935d3bd8   wdenk   Patches by Stepha...
404
  #########################################################################
5c952cf02   wdenk   Patches by Scott ...
405
406
  ## Nios-II Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
407
  LIST_nios2="$(targets_by_arch nios2)"
5c952cf02   wdenk   Patches by Scott ...
408
409
  
  #########################################################################
857cad37a   wdenk   Patches by Yasush...
410
411
  ## MicroBlaze Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
412
  LIST_microblaze="$(targets_by_arch microblaze)"
857cad37a   wdenk   Patches by Yasush...
413

f8c3b4f31   Zachary P. Landau   Add ColdFire targ...
414
415
416
  #########################################################################
  ## ColdFire Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
417
  LIST_m68k="$(targets_by_arch m68k)"
c13f47b0d   Mike Frysinger   MAKEALL: rename c...
418
  LIST_coldfire=${LIST_m68k}
f8c3b4f31   Zachary P. Landau   Add ColdFire targ...
419

6ccec4492   Wolfgang Denk   Add ATSTK1000 and...
420
421
422
  #########################################################################
  ## AVR32 Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
423
  LIST_avr32="$(targets_by_arch avr32)"
6ccec4492   Wolfgang Denk   Add ATSTK1000 and...
424

ef26a08fe   Aubrey.Li   [Blackfin][PATCH-...
425
426
427
  #########################################################################
  ## Blackfin Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
428
  LIST_blackfin="$(targets_by_arch blackfin)"
ef26a08fe   Aubrey.Li   [Blackfin][PATCH-...
429

c71443734   Jean-Christophe PLAGNIOL-VILLARD   sh: Add sh3 and s...
430
431
432
  #########################################################################
  ## SH Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
433
434
435
  LIST_sh2="$(targets_by_cpu sh2)"
  LIST_sh3="$(targets_by_cpu sh3)"
  LIST_sh4="$(targets_by_cpu sh4)"
d9a42c0ac   Wolfgang Denk   MAKEALL: sort ent...
436

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

c2f02da21   Daniel Hellstrom   SPARC: Added gene...
439
440
441
  #########################################################################
  ## SPARC Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
442
  LIST_sparc="$(targets_by_arch sparc)"
7ebf7443a   wdenk   Initial revision
443

5f1719c10   Macpaul Lin   adp-ag101: add bo...
444
445
446
  #########################################################################
  ## NDS32 Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
447
  LIST_nds32="$(targets_by_arch nds32)"
5f1719c10   Macpaul Lin   adp-ag101: add bo...
448

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

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

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

23d6410c2   Masahiro Yamada   MAKEALL: fix awk ...
499
  	local line=`awk '\$7 == "'"$target"'" { print \$0 }' boards.cfg`
27af930e9   Albert ARIBAUD   Merge and reforma...
500
  	if [ -z "${line}" ]; then
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
501
502
503
  		echo ""
  		return ;
  	fi
27af930e9   Albert ARIBAUD   Merge and reforma...
504
505
506
  	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/-...
507
  }
47104c37d   Allen Martin   MAKEALL: add supp...
508
509
  get_target_arch() {
  	local target=$1
bf678dfd4   Masahiro Yamada   MAKEALL: fix get_...
510
  	awk '$7 == "'$target'" { print $2 }' boards.cfg
47104c37d   Allen Martin   MAKEALL: add supp...
511
  }
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
512
513
514
515
516
517
518
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
  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...
554
555
556
557
558
559
560
  # 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...
561
562
563
564
565
566
  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
567
568
  build_target() {
  	target=$1
f588bb034   Andy Fleming   Allow for paralle...
569
  	build_idx=$2
f50bf50d7   Andy Fleming   Improve MAKEALL p...
570
571
572
573
  	if [ "$ONLY_LIST" == 'y' ] ; then
  		list_target ${target}
  		return
  	fi
f588bb034   Andy Fleming   Allow for paralle...
574
575
576
  	if [ $BUILD_MANY == 1 ] ; then
  		output_dir="${OUTPUT_PREFIX}/${target}"
  		mkdir -p "${output_dir}"
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
577
  		trap build_target_killed TERM
f588bb034   Andy Fleming   Allow for paralle...
578
579
580
  	else
  		output_dir="${OUTPUT_PREFIX}"
  	fi
47104c37d   Allen Martin   MAKEALL: add supp...
581
  	target_arch=$(get_target_arch ${target})
c17b94ec5   York Sun   MAKEALL: Fix case...
582
  	eval cross_toolchain=\$CROSS_COMPILE_`echo $target_arch | tr '[:lower:]' '[:upper:]'`
47104c37d   Allen Martin   MAKEALL: add supp...
583
  	if [ "${cross_toolchain}" ] ; then
e18fd9405   Masahiro Yamada   MAKEALL: make sur...
584
  	    MAKE="$GNU_MAKE CROSS_COMPILE=${cross_toolchain}"
47104c37d   Allen Martin   MAKEALL: add supp...
585
  	elif [ "${CROSS_COMPILE}" ] ; then
e18fd9405   Masahiro Yamada   MAKEALL: make sur...
586
  	    MAKE="$GNU_MAKE CROSS_COMPILE=${CROSS_COMPILE}"
47104c37d   Allen Martin   MAKEALL: add supp...
587
  	else
e18fd9405   Masahiro Yamada   MAKEALL: make sur...
588
  	    MAKE=$GNU_MAKE
47104c37d   Allen Martin   MAKEALL: add supp...
589
  	fi
9e4140329   Masahiro Yamada   kbuild: change ou...
590
591
592
  	if [  "${output_dir}" != "." ] ; then
  		MAKE="${MAKE} O=${output_dir}"
  	fi
fd18a89e7   Roger Meier   Makefile: remove ...
593
  	${MAKE} mrproper >/dev/null
bb6da87d7   Masahiro Yamada   MAKEALL: adjust f...
594
595
596
  
  	echo "Building ${target} board..."
  	${MAKE} -s ${target}_defconfig >/dev/null
f93286397   Marian Balakowicz   Add support for a...
597

33f336d52   Kim Phillips   MAKEALL: add a -C...
598
  	${MAKE} ${JOBS} ${CHECK} all \
f588bb034   Andy Fleming   Allow for paralle...
599
  		>${LOG_DIR}/$target.MAKELOG 2> ${LOG_DIR}/$target.ERR
f2352877c   Peter Tyser   MAKEALL: Fix retu...
600
601
602
603
604
  
  	# Check for 'make' errors
  	if [ ${PIPESTATUS[0]} -ne 0 ] ; then
  		RC=1
  	fi
e71796a70   Joe Hershberger   MAKEALL: Don't tr...
605
606
607
608
609
610
  	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...
611
  	if [ $BUILD_MANY == 1 ] ; then
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
612
  		trap - TERM
7390643f7   Masahiro Yamada   Makefile: remove ...
613
  		${MAKE} -s clean
f588bb034   Andy Fleming   Allow for paralle...
614
615
  
  		if [ -s ${LOG_DIR}/${target}.ERR ] ; then
b86a475c1   Joe Hershberger   MAKEALL: Report b...
616
  			cp ${LOG_DIR}/${target}.ERR ${OUTPUT_PREFIX}/ERR/${target}
f588bb034   Andy Fleming   Allow for paralle...
617
618
619
  		else
  			rm ${LOG_DIR}/${target}.ERR
  		fi
40a28f088   Peter Tyser   MAKEALL: Add summ...
620
  	else
f588bb034   Andy Fleming   Allow for paralle...
621
  		if [ -s ${LOG_DIR}/${target}.ERR ] ; then
b86a475c1   Joe Hershberger   MAKEALL: Report b...
622
623
624
625
626
627
628
  			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...
629
630
631
  		else
  			rm ${LOG_DIR}/${target}.ERR
  		fi
40a28f088   Peter Tyser   MAKEALL: Add summ...
632
  	fi
f588bb034   Andy Fleming   Allow for paralle...
633
  	[ -e "${LOG_DIR}/${target}.ERR" ] && cat "${LOG_DIR}/${target}.ERR"
f588bb034   Andy Fleming   Allow for paralle...
634
  	touch "${donep}${build_idx}"
7ebf7443a   wdenk   Initial revision
635
  }
f588bb034   Andy Fleming   Allow for paralle...
636
637
638
  
  manage_builds() {
  	search_idx=${OLDEST_IDX}
f50bf50d7   Andy Fleming   Improve MAKEALL p...
639
  	if [ "$ONLY_LIST" == 'y' ] ; then return ; fi
f588bb034   Andy Fleming   Allow for paralle...
640
641
  	while true; do
  		if [ -e "${donep}${search_idx}" ] ; then
f588bb034   Andy Fleming   Allow for paralle...
642
643
644
645
646
647
648
649
650
651
652
  			: $(( 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...
653
654
  		: $(( search_idx++ ))
  		if [ ${search_idx} -gt ${TOTAL_CNT} ] ; then
f588bb034   Andy Fleming   Allow for paralle...
655
656
657
658
659
660
661
662
663
  			if [ ${CURRENT_CNT} -ge ${BUILD_NBUILDS} ] ; then
  				search_idx=${OLDEST_IDX}
  				sleep 1
  			else
  				break
  			fi
  		fi
  	done
  }
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
664
665
666
667
668
669
670
671
672
673
674
675
  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...
676
677
678
679
  			: $((TOTAL_CNT += 1))
  			: $((CURRENT_CNT += 1))
  			rm -f "${donep}${TOTAL_CNT}"
  			rm -f "${skipp}${TOTAL_CNT}"
085102047   Joe Hershberger   MAKEALL: Add opti...
680
681
682
683
684
685
  			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...
686
  			else
085102047   Joe Hershberger   MAKEALL: Add opti...
687
688
689
690
691
692
693
  				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...
694
  			fi
f588bb034   Andy Fleming   Allow for paralle...
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
  		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...
710
711
712
  		fi
  	done
  }
7ebf7443a   wdenk   Initial revision
713
714
  
  #-----------------------------------------------------------------------
f50bf50d7   Andy Fleming   Improve MAKEALL p...
715
  kill_children() {
6bdd9f896   Andreas Bießmann   MAKEALL: fix kill...
716
717
718
719
720
721
722
723
724
725
726
727
728
729
  	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...
730
731
732
  
  	kill $children 2> /dev/null
  	wait $children 2> /dev/null
f50bf50d7   Andy Fleming   Improve MAKEALL p...
733
734
735
  
  	exit
  }
40a28f088   Peter Tyser   MAKEALL: Add summ...
736
  print_stats() {
7f79c6f2f   Marek Vasut   MAKEALL: Add -l o...
737
  	if [ "$ONLY_LIST" == 'y' ] ; then return ; fi
f588bb034   Andy Fleming   Allow for paralle...
738

c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
739
740
  	# Only count boards that completed
  	: $((TOTAL_CNT = `find ${skipp}* 2> /dev/null | wc -l`))
f588bb034   Andy Fleming   Allow for paralle...
741
742
743
  	rm -f ${donep}* ${skipp}*
  
  	if [ $BUILD_MANY == 1 ] && [ -e "${OUTPUT_PREFIX}/ERR" ] ; then
033220e7a   Andy Fleming   MAKEALL: Allow em...
744
  		ERR_LIST=`grep -riwl error ${OUTPUT_PREFIX}/ERR/`
b86a475c1   Joe Hershberger   MAKEALL: Report b...
745
746
  		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...
747
  		WRN_LIST=`grep -riwL error ${OUTPUT_PREFIX}/ERR/`
b86a475c1   Joe Hershberger   MAKEALL: Report b...
748
749
  		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...
750
751
752
  	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...
753
  	fi
085102047   Joe Hershberger   MAKEALL: Add opti...
754
  	: $((TOTAL_CNT -= ${SKIP_CNT}))
40a28f088   Peter Tyser   MAKEALL: Add summ...
755
756
  	echo ""
  	echo "--------------------- SUMMARY ----------------------------"
085102047   Joe Hershberger   MAKEALL: Add opti...
757
758
759
  	if [ "$CONTINUE" = 'y' -o "$REBUILD_ERRORS" = 'y' ] ; then
  		echo "Boards skipped: ${SKIP_CNT}"
  	fi
40a28f088   Peter Tyser   MAKEALL: Add summ...
760
761
  	echo "Boards compiled: ${TOTAL_CNT}"
  	if [ ${ERR_CNT} -gt 0 ] ; then
b86a475c1   Joe Hershberger   MAKEALL: Report b...
762
763
764
765
  		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...
766
767
  	fi
  	echo "----------------------------------------------------------"
f2352877c   Peter Tyser   MAKEALL: Fix retu...
768

f50bf50d7   Andy Fleming   Improve MAKEALL p...
769
  	if [ $BUILD_MANY == 1 ] ; then
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
770
  		kill_children
f50bf50d7   Andy Fleming   Improve MAKEALL p...
771
  	fi
f2352877c   Peter Tyser   MAKEALL: Fix retu...
772
  	exit $RC
40a28f088   Peter Tyser   MAKEALL: Add summ...
773
  }
7ebf7443a   wdenk   Initial revision
774

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

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