Blame view

MAKEALL 22.8 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
162
163
164
165
166
167
168
169
  	--)
  		shift ; break ;;
  	*)
  		echo "Internal error!" >&2 ; exit 1 ;;
  	esac
  done
  # echo "Remaining arguments:"
  # for arg do echo '--> '"\`$arg'" ; done
  
  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 (...
170
  [ "$opt_b" ] && FILTER="${FILTER} && $opt_b"
0777eafb3   Wolfgang Denk   MAKEALL: allow ad...
171
172
  
  if [ "$SELECTED" ] ; then
27af930e9   Albert ARIBAUD   Merge and reforma...
173
  	SELECTED=$(awk '('"$FILTER"') { print $7 }' boards.cfg)
cd57b0bb8   Peter Tyser   MAKEALL: Do a san...
174
175
176
177
178
179
  
  	# 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...
180
181
182
  fi
  
  #########################################################################
40a28f088   Peter Tyser   MAKEALL: Add summ...
183
184
185
  # Print statistics when we exit
  trap exit 1 2 3 15
  trap print_stats 0
7fa6a2f3b   Wolfgang Denk   MAKEALL: Automati...
186
187
188
189
190
  # 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...
191
  	JOBS="-j $((BUILD_NCPUS + 1))"
7fa6a2f3b   Wolfgang Denk   MAKEALL: Automati...
192
193
194
  else
  	JOBS=""
  fi
f93286397   Marian Balakowicz   Add support for a...
195
196
197
198
199
  if [ "${MAKEALL_LOGDIR}" ] ; then
  	LOG_DIR=${MAKEALL_LOGDIR}
  else
  	LOG_DIR="LOG"
  fi
887e2ec9e   Stefan Roese   Add support for A...
200

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

9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
231
  # Helper funcs for parsing boards.cfg
8948794a2   Masahiro Yamada   MAKEALL: rename b...
232
  targets_by_field()
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
233
  {
8e5a2d425   Masahiro Yamada   MAKEALL: fix boar...
234
235
236
237
238
  	field=$1
  	regexp=$2
  
  	awk '($1 !~ /^#/ && $'"$field"' ~ /^'"$regexp"'$/) { print $7 }' \
  								boards.cfg
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
239
  }
8e5a2d425   Masahiro Yamada   MAKEALL: fix boar...
240

8948794a2   Masahiro Yamada   MAKEALL: rename b...
241
242
243
  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...
244

7ebf7443a   wdenk   Initial revision
245
  #########################################################################
0db5bca80   wdenk   * Patch by Martin...
246
247
  ## MPC5xx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
248
  LIST_5xx="$(targets_by_cpu mpc5xx)"
0db5bca80   wdenk   * Patch by Martin...
249
250
  
  #########################################################################
945af8d72   wdenk   * Add support for...
251
252
  ## MPC5xxx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
253
  LIST_5xxx="$(targets_by_cpu mpc5xxx)"
945af8d72   wdenk   * Add support for...
254
255
  
  #########################################################################
8993e54b6   Rafal Jaworowski   [ADS5121] Support...
256
257
  ## MPC512x Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
258
  LIST_512x="$(targets_by_cpu mpc512x)"
945af8d72   wdenk   * Add support for...
259
260
  
  #########################################################################
7ebf7443a   wdenk   Initial revision
261
262
  ## MPC8xx Systems
  #########################################################################
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
263

8948794a2   Masahiro Yamada   MAKEALL: rename b...
264
  LIST_8xx="$(targets_by_cpu mpc8xx)"
7ebf7443a   wdenk   Initial revision
265
266
267
268
  
  #########################################################################
  ## PPC4xx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
269
  LIST_4xx="$(targets_by_cpu ppc4xx)"
7ebf7443a   wdenk   Initial revision
270
271
272
273
  
  #########################################################################
  ## MPC824x Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
274
  LIST_824x="$(targets_by_cpu mpc824x)"
592c5cabe   wdenk   Patch by Murray J...
275

7ebf7443a   wdenk   Initial revision
276
  #########################################################################
7aa786147   wdenk   * Add support for...
277
  ## MPC8260 Systems (includes 8250, 8255 etc.)
7ebf7443a   wdenk   Initial revision
278
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
279
  LIST_8260="$(targets_by_cpu mpc8260)"
7ebf7443a   wdenk   Initial revision
280
281
  
  #########################################################################
f046ccd15   Eran Liberty   * Patch by Eran L...
282
283
  ## MPC83xx Systems (includes 8349, etc.)
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
284
  LIST_83xx="$(targets_by_cpu mpc83xx)"
f046ccd15   Eran Liberty   * Patch by Eran L...
285
286
  
  #########################################################################
42d1f0394   wdenk   * Patches by Xian...
287
288
  ## MPC85xx Systems (includes 8540, 8560 etc.)
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
289
  LIST_85xx="$(targets_by_cpu mpc85xx)"
42d1f0394   wdenk   * Patches by Xian...
290
291
  
  #########################################################################
822d55365   Jon Loeliger   Add LIST_86xx MAK...
292
293
  ## MPC86xx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
294
  LIST_86xx="$(targets_by_cpu mpc86xx)"
822d55365   Jon Loeliger   Add LIST_86xx MAK...
295
296
  
  #########################################################################
7ebf7443a   wdenk   Initial revision
297
298
  ## 74xx/7xx Systems
  #########################################################################
8948794a2   Masahiro Yamada   MAKEALL: rename b...
299
  LIST_74xx_7xx="$(targets_by_cpu 74xx_7xx)"
7ebf7443a   wdenk   Initial revision
300

d9a42c0ac   Wolfgang Denk   MAKEALL: sort ent...
301
302
303
304
305
306
307
308
309
  #########################################################################
  ## PowerPC groups
  #########################################################################
  
  LIST_TSEC="		\
  	${LIST_83xx}	\
  	${LIST_85xx}	\
  	${LIST_86xx}	\
  "
a47a12bec   Stefan Roese   Move arch/ppc to ...
310
  LIST_powerpc="		\
fb56579ff   Kim Phillips   make MAKEALL more...
311
  	${LIST_5xx}	\
3deca9d44   Jean-Christophe PLAGNIOL-VILLARD   MAKEALL: add miss...
312
  	${LIST_512x}	\
fb56579ff   Kim Phillips   make MAKEALL more...
313
314
  	${LIST_5xxx}	\
  	${LIST_8xx}	\
fb56579ff   Kim Phillips   make MAKEALL more...
315
316
317
318
319
320
  	${LIST_824x}	\
  	${LIST_8260}	\
  	${LIST_83xx}	\
  	${LIST_85xx}	\
  	${LIST_86xx}	\
  	${LIST_4xx}	\
2ae182419   Wolfgang Denk   Makefile: move al...
321
  	${LIST_74xx_7xx}\
fb56579ff   Kim Phillips   make MAKEALL more...
322
  "
7ebf7443a   wdenk   Initial revision
323

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

27af930e9   Albert ARIBAUD   Merge and reforma...
471
  	[ "${BOARD_NAME}" ] || BOARD_NAME="${7%_config}"
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
472

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

23d6410c2   Masahiro Yamada   MAKEALL: fix awk ...
501
  	local line=`awk '\$7 == "'"$target"'" { print \$0 }' boards.cfg`
27af930e9   Albert ARIBAUD   Merge and reforma...
502
  	if [ -z "${line}" ]; then
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
503
504
505
  		echo ""
  		return ;
  	fi
27af930e9   Albert ARIBAUD   Merge and reforma...
506
507
508
  	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/-...
509
  }
47104c37d   Allen Martin   MAKEALL: add supp...
510
511
512
513
  get_target_arch() {
  	local target=$1
  
  	# Automatic mode
54d1f5048   Masahiro Yamada   MAKEALL: fix a bu...
514
  	local line=`awk '\$7 == "'"$target"'" { print \$0 }' boards.cfg`
47104c37d   Allen Martin   MAKEALL: add supp...
515
516
517
518
519
520
  
  	if [ -z "${line}" ] ; then echo "" ; return ; fi
  
  	set ${line}
  	echo "$2"
  }
9b96c6b11   Marek Vasut   MAKEALL: Add -m/-...
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
561
562
  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...
563
564
565
566
567
568
569
  # 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...
570
571
572
573
574
575
  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
576
577
  build_target() {
  	target=$1
f588bb034   Andy Fleming   Allow for paralle...
578
  	build_idx=$2
f50bf50d7   Andy Fleming   Improve MAKEALL p...
579
580
581
582
  	if [ "$ONLY_LIST" == 'y' ] ; then
  		list_target ${target}
  		return
  	fi
f588bb034   Andy Fleming   Allow for paralle...
583
584
585
  	if [ $BUILD_MANY == 1 ] ; then
  		output_dir="${OUTPUT_PREFIX}/${target}"
  		mkdir -p "${output_dir}"
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
586
  		trap build_target_killed TERM
f588bb034   Andy Fleming   Allow for paralle...
587
588
589
  	else
  		output_dir="${OUTPUT_PREFIX}"
  	fi
47104c37d   Allen Martin   MAKEALL: add supp...
590
  	target_arch=$(get_target_arch ${target})
c17b94ec5   York Sun   MAKEALL: Fix case...
591
  	eval cross_toolchain=\$CROSS_COMPILE_`echo $target_arch | tr '[:lower:]' '[:upper:]'`
47104c37d   Allen Martin   MAKEALL: add supp...
592
593
594
595
596
597
598
  	if [ "${cross_toolchain}" ] ; then
  	    MAKE="make CROSS_COMPILE=${cross_toolchain}"
  	elif [ "${CROSS_COMPILE}" ] ; then
  	    MAKE="make CROSS_COMPILE=${CROSS_COMPILE}"
  	else
  	    MAKE=make
  	fi
9e4140329   Masahiro Yamada   kbuild: change ou...
599
600
601
  	if [  "${output_dir}" != "." ] ; then
  		MAKE="${MAKE} O=${output_dir}"
  	fi
7ebf7443a   wdenk   Initial revision
602
  	${MAKE} distclean >/dev/null
d70d8ccc2   Kim Phillips   silence config st...
603
  	${MAKE} -s ${target}_config
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
f588bb034   Andy Fleming   Allow for paralle...
612
  	if [ $BUILD_MANY == 1 ] ; then
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
613
  		trap - TERM
7390643f7   Masahiro Yamada   Makefile: remove ...
614
  		${MAKE} -s clean
f588bb034   Andy Fleming   Allow for paralle...
615
616
  
  		if [ -s ${LOG_DIR}/${target}.ERR ] ; then
b86a475c1   Joe Hershberger   MAKEALL: Report b...
617
  			cp ${LOG_DIR}/${target}.ERR ${OUTPUT_PREFIX}/ERR/${target}
f588bb034   Andy Fleming   Allow for paralle...
618
619
620
  		else
  			rm ${LOG_DIR}/${target}.ERR
  		fi
40a28f088   Peter Tyser   MAKEALL: Add summ...
621
  	else
f588bb034   Andy Fleming   Allow for paralle...
622
  		if [ -s ${LOG_DIR}/${target}.ERR ] ; then
b86a475c1   Joe Hershberger   MAKEALL: Report b...
623
624
625
626
627
628
629
  			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...
630
631
632
  		else
  			rm ${LOG_DIR}/${target}.ERR
  		fi
40a28f088   Peter Tyser   MAKEALL: Add summ...
633
  	fi
f588bb034   Andy Fleming   Allow for paralle...
634
635
636
  	OBJS=${output_dir}/u-boot
  	if [ -e ${output_dir}/spl/u-boot-spl ]; then
  		OBJS="${OBJS} ${output_dir}/spl/u-boot-spl"
0c1856960   Scott Wood   MAKEALL: display ...
637
638
639
  	fi
  
  	${CROSS_COMPILE}size ${OBJS} | tee -a ${LOG_DIR}/$target.MAKELOG
f588bb034   Andy Fleming   Allow for paralle...
640
641
  
  	[ -e "${LOG_DIR}/${target}.ERR" ] && cat "${LOG_DIR}/${target}.ERR"
f588bb034   Andy Fleming   Allow for paralle...
642
  	touch "${donep}${build_idx}"
7ebf7443a   wdenk   Initial revision
643
  }
f588bb034   Andy Fleming   Allow for paralle...
644
645
646
  
  manage_builds() {
  	search_idx=${OLDEST_IDX}
f50bf50d7   Andy Fleming   Improve MAKEALL p...
647
  	if [ "$ONLY_LIST" == 'y' ] ; then return ; fi
f588bb034   Andy Fleming   Allow for paralle...
648
649
  	while true; do
  		if [ -e "${donep}${search_idx}" ] ; then
f588bb034   Andy Fleming   Allow for paralle...
650
651
652
653
654
655
656
657
658
659
660
  			: $(( 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...
661
662
  		: $(( search_idx++ ))
  		if [ ${search_idx} -gt ${TOTAL_CNT} ] ; then
f588bb034   Andy Fleming   Allow for paralle...
663
664
665
666
667
668
669
670
671
  			if [ ${CURRENT_CNT} -ge ${BUILD_NBUILDS} ] ; then
  				search_idx=${OLDEST_IDX}
  				sleep 1
  			else
  				break
  			fi
  		fi
  	done
  }
9ec49f8f8   Mike Frysinger   MAKEALL: cut down...
672
673
674
675
676
677
678
679
680
681
682
683
  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...
684
685
686
687
  			: $((TOTAL_CNT += 1))
  			: $((CURRENT_CNT += 1))
  			rm -f "${donep}${TOTAL_CNT}"
  			rm -f "${skipp}${TOTAL_CNT}"
085102047   Joe Hershberger   MAKEALL: Add opti...
688
689
690
691
692
693
  			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...
694
  			else
085102047   Joe Hershberger   MAKEALL: Add opti...
695
696
697
698
699
700
701
  				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...
702
  			fi
f588bb034   Andy Fleming   Allow for paralle...
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
  		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...
718
719
720
  		fi
  	done
  }
7ebf7443a   wdenk   Initial revision
721
722
  
  #-----------------------------------------------------------------------
f50bf50d7   Andy Fleming   Improve MAKEALL p...
723
  kill_children() {
6bdd9f896   Andreas Bießmann   MAKEALL: fix kill...
724
725
726
727
728
729
730
731
732
733
734
735
736
737
  	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...
738
739
740
  
  	kill $children 2> /dev/null
  	wait $children 2> /dev/null
f50bf50d7   Andy Fleming   Improve MAKEALL p...
741
742
743
  
  	exit
  }
40a28f088   Peter Tyser   MAKEALL: Add summ...
744
  print_stats() {
7f79c6f2f   Marek Vasut   MAKEALL: Add -l o...
745
  	if [ "$ONLY_LIST" == 'y' ] ; then return ; fi
f588bb034   Andy Fleming   Allow for paralle...
746

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

f50bf50d7   Andy Fleming   Improve MAKEALL p...
777
  	if [ $BUILD_MANY == 1 ] ; then
c97d59cbd   Joe Hershberger   MAKEALL: Fix kill...
778
  		kill_children
f50bf50d7   Andy Fleming   Improve MAKEALL p...
779
  	fi
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