ardupilot/Tools/scripts/configure_all.py

99 lines
3.5 KiB
Python
Raw Normal View History

#!/usr/bin/env python
"""
script to run configre for all hwdef.dat, to check for syntax errors
"""
import os
import subprocess
import sys
import fnmatch
import argparse
parser = argparse.ArgumentParser(description='configure all ChibiOS boards')
parser.add_argument('--build', action='store_true', default=False, help='build as well as configure')
parser.add_argument('--build-target', default='copter', help='build target')
parser.add_argument('--stop', action='store_true', default=False, help='stop on build fail')
parser.add_argument('--no-bl', action='store_true', default=False, help="don't check bootloader builds")
2020-05-11 02:56:54 -03:00
parser.add_argument('--Werror', action='store_true', default=False, help="build with -Werror")
parser.add_argument('--pattern', default='*')
2020-05-11 02:56:54 -03:00
parser.add_argument('--start', default=None, type=int, help='continue from specified build number')
parser.add_argument('--python', default='python')
args = parser.parse_args()
os.environ['PYTHONUNBUFFERED'] = '1'
failures = []
2020-05-11 02:56:54 -03:00
done = []
board_list = []
def get_board_list():
'''add boards based on existance of hwdef-bl.dat in subdirectories for ChibiOS'''
board_list = []
2020-05-11 02:56:54 -03:00
# these are base builds, and don't build directly
omit = ['f103-periph', 'f303-periph']
dirname, dirlist, filenames = next(os.walk('libraries/AP_HAL_ChibiOS/hwdef'))
for d in dirlist:
hwdef = os.path.join(dirname, d, 'hwdef.dat')
2020-05-11 02:56:54 -03:00
if os.path.exists(hwdef) and not d in omit:
board_list.append(d)
return board_list
def run_program(cmd_list, build):
print("Running (%s)" % " ".join(cmd_list))
retcode = subprocess.call(cmd_list)
if retcode != 0:
2020-05-11 02:56:54 -03:00
print("FAILED BUILD: %s %s" % (build, ' '.join(cmd_list)))
global failures
failures.append(build)
if args.stop:
sys.exit(1)
2020-05-11 02:56:54 -03:00
for board in sorted(get_board_list()):
if not fnmatch.fnmatch(board, args.pattern):
continue
2020-05-11 02:56:54 -03:00
board_list.append(board)
if args.start is not None:
if args.start < 1 or args.start >= len(board_list):
print("Invalid start %u for %u boards" % (args.start, len(board_list)))
sys.exit(1)
board_list = board_list[args.start-1:]
for board in board_list:
done.append(board)
print("Configuring for %s [%u/%u failed=%u]" % (board, len(done), len(board_list), len(failures)))
config_opts = ["--board", board]
if args.Werror:
config_opts += ["--Werror"]
run_program([args.python, "waf", "configure"] + config_opts, "configure: " + board)
if args.build:
if board == "iomcu":
target = "iofirmware"
elif board in ['CUAV_GPS', 'ZubaxGNSS'] or board.startswith('f103') or board.startswith('f303'):
target = "AP_Periph"
else:
target = args.build_target
2020-05-11 02:56:54 -03:00
if target.find('/') != -1:
run_program([args.python, "waf", "--target", target], "build: " + board)
else:
run_program([args.python, "waf", target], "build: " + board)
if args.no_bl:
continue
# check for bootloader def
hwdef_bl = os.path.join('libraries/AP_HAL_ChibiOS/hwdef/%s/hwdef-bl.dat' % board)
if os.path.exists(hwdef_bl):
print("Configuring bootloader for %s" % board)
run_program([args.python, "waf", "configure", "--board", board, "--bootloader"], "configure: " + board + "-bl")
if args.build:
run_program([args.python, "waf", "bootloader"], "build: " + board + "-bl")
if len(failures) > 0:
print("Failed builds:")
for f in failures:
print(' ' + f)
sys.exit(1)
sys.exit(0)