add option to pass symbol defines to ci build.py

add build.args option for hil json
add MAX3421_HOST=1 for metro m4 express
This commit is contained in:
hathach
2025-07-09 17:58:11 +07:00
parent 227b22de02
commit b5694fd40a
5 changed files with 34 additions and 21 deletions

View File

@@ -3,9 +3,6 @@ set(SAM_FAMILY samd51)
set(JLINK_DEVICE ATSAMD51J19) set(JLINK_DEVICE ATSAMD51J19)
set(LD_FILE_GNU ${CMAKE_CURRENT_LIST_DIR}/${BOARD}.ld) set(LD_FILE_GNU ${CMAKE_CURRENT_LIST_DIR}/${BOARD}.ld)
# force max3421e for testing with hardware-in-the-loop
set(MAX3421_HOST 1)
function(update_board TARGET) function(update_board TARGET)
target_compile_definitions(${TARGET} PUBLIC target_compile_definitions(${TARGET} PUBLIC
__SAMD51J19A__ __SAMD51J19A__

View File

@@ -28,14 +28,20 @@ def main():
else: else:
toolchain = 'arm-gcc' toolchain = 'arm-gcc'
if 'build' in board and 'flags_on' in board['build']: build_board = f'-b {name}'
for f in board['build']['flags_on']: if 'build' in board:
if f == '': if 'args' in board['build']:
matrix[toolchain].append(f'-b {name}') build_board += ' ' + ' '.join(f'-D{a}' for a in board['build']['args'])
else: if 'flags_on' in board['build']:
matrix[toolchain].append(f'-b {name} -f1 {f.replace(" ", " -f1 ")}') for f in board['build']['flags_on']:
if f == '':
matrix[toolchain].append(build_board)
else:
matrix[toolchain].append(f'{build_board} -f1 {f.replace(" ", " -f1 ")}')
else:
matrix[toolchain].append(build_board)
else: else:
matrix[toolchain].append(f'-b {name}') matrix[toolchain].append(build_board)
print(json.dumps(matrix)) print(json.dumps(matrix))

View File

@@ -61,6 +61,9 @@
{ {
"name": "metro_m4_express", "name": "metro_m4_express",
"uid": "9995AD485337433231202020FF100A34", "uid": "9995AD485337433231202020FF100A34",
"build" : {
"args": ["MAX3421_HOST=1"]
},
"tests": { "tests": {
"device": true, "host": false, "dual": true, "device": true, "host": false, "dual": true,
"dev_attached": [{"vid_pid": "1a86_55d4", "serial": "52D2002130"}] "dev_attached": [{"vid_pid": "1a86_55d4", "serial": "52D2002130"}]

View File

@@ -82,7 +82,7 @@ def print_build_result(board, example, status, duration):
# ----------------------------- # -----------------------------
# CMake # CMake
# ----------------------------- # -----------------------------
def cmake_board(board, toolchain, build_flags_on): def cmake_board(board, build_args, build_flags_on):
ret = [0, 0, 0] ret = [0, 0, 0]
start_time = time.monotonic() start_time = time.monotonic()
@@ -106,7 +106,7 @@ def cmake_board(board, toolchain, build_flags_on):
ret[0 if rcmd.returncode == 0 else 1] += 1 ret[0 if rcmd.returncode == 0 else 1] += 1
else: else:
rcmd = run_cmd(f'cmake examples -B {build_dir} -G Ninja -DBOARD={board} -DCMAKE_BUILD_TYPE=MinSizeRel ' rcmd = run_cmd(f'cmake examples -B {build_dir} -G Ninja -DBOARD={board} -DCMAKE_BUILD_TYPE=MinSizeRel '
f'-DTOOLCHAIN={toolchain} {build_flags}') f'{build_args} {build_flags}')
if rcmd.returncode == 0: if rcmd.returncode == 0:
cmd = f"cmake --build {build_dir}" cmd = f"cmake --build {build_dir}"
njobs = parallel_jobs njobs = parallel_jobs
@@ -152,7 +152,7 @@ def make_one_example(example, board, make_option):
return ret return ret
def make_board(board, toolchain): def make_board(board, build_args):
print(build_separator) print(build_separator)
family = find_family(board); family = find_family(board);
all_examples = get_examples(family) all_examples = get_examples(family)
@@ -163,7 +163,7 @@ def make_board(board, toolchain):
final_status = 2 final_status = 2
else: else:
with Pool(processes=os.cpu_count()) as pool: with Pool(processes=os.cpu_count()) as pool:
pool_args = list((map(lambda e, b=board, o=f"TOOLCHAIN={toolchain}": [e, b, o], all_examples))) pool_args = list((map(lambda e, b=board, o=f"{build_args}": [e, b, o], all_examples)))
r = pool.starmap(make_one_example, pool_args) r = pool.starmap(make_one_example, pool_args)
# sum all element of same index (column sum) # sum all element of same index (column sum)
ret = list(map(sum, list(zip(*r)))) ret = list(map(sum, list(zip(*r))))
@@ -175,21 +175,23 @@ def make_board(board, toolchain):
# ----------------------------- # -----------------------------
# Build Family # Build Family
# ----------------------------- # -----------------------------
def build_boards_list(boards, toolchain, build_system, build_flags_on): def build_boards_list(boards, build_defines, build_system, build_flags_on):
ret = [0, 0, 0] ret = [0, 0, 0]
for b in boards: for b in boards:
r = [0, 0, 0] r = [0, 0, 0]
if build_system == 'cmake': if build_system == 'cmake':
r = cmake_board(b, toolchain, build_flags_on) build_args = ' '.join(f'-D{d}' for d in build_defines)
r = cmake_board(b, build_args, build_flags_on)
elif build_system == 'make': elif build_system == 'make':
r = make_board(b, toolchain) build_args = ' '.join(f'{d}' for d in build_defines)
r = make_board(b, build_args)
ret[0] += r[0] ret[0] += r[0]
ret[1] += r[1] ret[1] += r[1]
ret[2] += r[2] ret[2] += r[2]
return ret return ret
def build_family(family, toolchain, build_system, build_flags_on, one_per_family, boards): def build_family(family, build_defines, build_system, build_flags_on, one_per_family, boards):
skip_ci = ['pico_sdk'] skip_ci = ['pico_sdk']
if os.getenv('GITHUB_ACTIONS') or os.getenv('CIRCLECI'): if os.getenv('GITHUB_ACTIONS') or os.getenv('CIRCLECI'):
skip_ci_file = Path(f"hw/bsp/{family}/skip_ci.txt") skip_ci_file = Path(f"hw/bsp/{family}/skip_ci.txt")
@@ -210,7 +212,7 @@ def build_family(family, toolchain, build_system, build_flags_on, one_per_family
return ret return ret
all_boards = [random.choice(all_boards)] all_boards = [random.choice(all_boards)]
ret = build_boards_list(all_boards, toolchain, build_system, build_flags_on) ret = build_boards_list(all_boards, build_defines, build_system, build_flags_on)
return ret return ret
@@ -226,6 +228,7 @@ def main():
parser.add_argument('-b', '--board', action='append', default=[], help='Boards to build') parser.add_argument('-b', '--board', action='append', default=[], help='Boards to build')
parser.add_argument('-t', '--toolchain', default='gcc', help='Toolchain to use, default is gcc') parser.add_argument('-t', '--toolchain', default='gcc', help='Toolchain to use, default is gcc')
parser.add_argument('-s', '--build-system', default='cmake', help='Build system to use, default is cmake') parser.add_argument('-s', '--build-system', default='cmake', help='Build system to use, default is cmake')
parser.add_argument('-D', '--define-symbol', action='append', default=[], help='Define to pass to build system')
parser.add_argument('-f1', '--build-flags-on', action='append', default=[], help='Build flag to pass to build system') parser.add_argument('-f1', '--build-flags-on', action='append', default=[], help='Build flag to pass to build system')
parser.add_argument('-1', '--one-per-family', action='store_true', default=False, help='Build only one random board inside a family') parser.add_argument('-1', '--one-per-family', action='store_true', default=False, help='Build only one random board inside a family')
parser.add_argument('-j', '--jobs', type=int, default=os.cpu_count(), help='Number of jobs to run in parallel') parser.add_argument('-j', '--jobs', type=int, default=os.cpu_count(), help='Number of jobs to run in parallel')
@@ -236,11 +239,14 @@ def main():
boards = args.board boards = args.board
toolchain = args.toolchain toolchain = args.toolchain
build_system = args.build_system build_system = args.build_system
build_defines = args.define_symbol
build_flags_on = args.build_flags_on build_flags_on = args.build_flags_on
one_per_family = args.one_per_family one_per_family = args.one_per_family
verbose = args.verbose verbose = args.verbose
parallel_jobs = args.jobs parallel_jobs = args.jobs
build_defines.append(f'TOOLCHAIN={toolchain}')
if len(families) == 0 and len(boards) == 0: if len(families) == 0 and len(boards) == 0:
print("Please specify families or board to build") print("Please specify families or board to build")
return 1 return 1
@@ -262,13 +268,13 @@ def main():
# succeeded, failed, skipped # succeeded, failed, skipped
for f in all_families: for f in all_families:
r = build_family(f, toolchain, build_system, build_flags_on, one_per_family, boards) r = build_family(f, build_defines, build_system, build_flags_on, one_per_family, boards)
result[0] += r[0] result[0] += r[0]
result[1] += r[1] result[1] += r[1]
result[2] += r[2] result[2] += r[2]
# build boards # build boards
r = build_boards_list(boards, toolchain, build_system, build_flags_on) r = build_boards_list(boards, build_defines, build_system, build_flags_on)
result[0] += r[0] result[0] += r[0]
result[1] += r[1] result[1] += r[1]
result[2] += r[2] result[2] += r[2]

View File

@@ -286,6 +286,7 @@ def main():
parser = argparse.ArgumentParser() parser = argparse.ArgumentParser()
parser.add_argument('families', nargs='*', default=[], help='Families to fetch') parser.add_argument('families', nargs='*', default=[], help='Families to fetch')
parser.add_argument('-b', '--board', action='append', default=[], help='Boards to fetch') parser.add_argument('-b', '--board', action='append', default=[], help='Boards to fetch')
parser.add_argument('-D', '--define', action='append', default=[], help='Have no effect')
parser.add_argument('-f1', '--build-flags-on', action='append', default=[], help='Have no effect') parser.add_argument('-f1', '--build-flags-on', action='append', default=[], help='Have no effect')
parser.add_argument('--print', action='store_true', help='Print commit hash only') parser.add_argument('--print', action='store_true', help='Print commit hash only')
args = parser.parse_args() args = parser.parse_args()