Merge pull request #3203 from WarriorOfWire/speed_up_builds
Use 2 cores per build task in github CI build
This commit is contained in:
commit
fbc78972eb
@ -5,6 +5,7 @@
|
|||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
import multiprocessing
|
||||||
import sys
|
import sys
|
||||||
import subprocess
|
import subprocess
|
||||||
import shutil
|
import shutil
|
||||||
@ -27,6 +28,8 @@ sha, version = build_info.get_version_info()
|
|||||||
|
|
||||||
languages = build_info.get_languages()
|
languages = build_info.get_languages()
|
||||||
exit_status = 0
|
exit_status = 0
|
||||||
|
cores = multiprocessing.cpu_count()
|
||||||
|
print('building boards with parallelism {}'.format(cores))
|
||||||
for board in build_boards:
|
for board in build_boards:
|
||||||
bin_directory = "../bin/{}/".format(board)
|
bin_directory = "../bin/{}/".format(board)
|
||||||
os.makedirs(bin_directory, exist_ok=True)
|
os.makedirs(bin_directory, exist_ok=True)
|
||||||
@ -41,8 +44,8 @@ for board in build_boards:
|
|||||||
# But sometimes a particular language needs to be built from scratch, if, for instance,
|
# But sometimes a particular language needs to be built from scratch, if, for instance,
|
||||||
# CFLAGS_INLINE_LIMIT is set for a particular language to make it fit.
|
# CFLAGS_INLINE_LIMIT is set for a particular language to make it fit.
|
||||||
clean_build_check_result = subprocess.run(
|
clean_build_check_result = subprocess.run(
|
||||||
"make -C ../ports/{port} TRANSLATION={language} BOARD={board} check-release-needs-clean-build | fgrep 'RELEASE_NEEDS_CLEAN_BUILD = 1'".format(
|
"make -C ../ports/{port} TRANSLATION={language} BOARD={board} check-release-needs-clean-build -j {cores} | fgrep 'RELEASE_NEEDS_CLEAN_BUILD = 1'".format(
|
||||||
port = board_info["port"], language=language, board=board),
|
port = board_info["port"], language=language, board=board, cores=cores),
|
||||||
shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
|
shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
|
||||||
clean_build = clean_build_check_result.returncode == 0
|
clean_build = clean_build_check_result.returncode == 0
|
||||||
|
|
||||||
@ -51,8 +54,8 @@ for board in build_boards:
|
|||||||
build_dir += "-{language}".format(language=language)
|
build_dir += "-{language}".format(language=language)
|
||||||
|
|
||||||
make_result = subprocess.run(
|
make_result = subprocess.run(
|
||||||
"make -C ../ports/{port} TRANSLATION={language} BOARD={board} BUILD={build}".format(
|
"make -C ../ports/{port} TRANSLATION={language} BOARD={board} BUILD={build} -j {cores}".format(
|
||||||
port = board_info["port"], language=language, board=board, build=build_dir),
|
port = board_info["port"], language=language, board=board, build=build_dir, cores=cores),
|
||||||
shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
|
shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
|
||||||
|
|
||||||
build_duration = time.monotonic() - start_time
|
build_duration = time.monotonic() - start_time
|
||||||
|
Loading…
Reference in New Issue
Block a user