Commit bb7aae55 authored by Damien George's avatar Damien George

tools/autobuild: Automatically build all stm32 boards.

Any board with a board.json file will be built.  Additional variants for
certain pyboards will also be built by the explicit build-stm32-extra.sh
script.  Both .dfu and .hex files will be made available.

Also build boards in a sorted order, and don't stop building if a single
board fails.
Signed-off-by: default avatarDamien George <damien@micropython.org>
parent 90554d03
...@@ -65,9 +65,7 @@ FW_GIT="$(git describe --dirty || echo unknown)" ...@@ -65,9 +65,7 @@ FW_GIT="$(git describe --dirty || echo unknown)"
FW_TAG="-$FW_DATE-unstable-$FW_GIT" FW_TAG="-$FW_DATE-unstable-$FW_GIT"
# build new firmware # build new firmware
cd ports/stm32 cd ports/cc3200
${AUTODIR}/build-stm32-latest.sh ${FW_TAG} ${LOCAL_FIRMWARE}
cd ../cc3200
${AUTODIR}/build-cc3200-latest.sh ${FW_TAG} ${LOCAL_FIRMWARE} ${AUTODIR}/build-cc3200-latest.sh ${FW_TAG} ${LOCAL_FIRMWARE}
cd ../esp8266 cd ../esp8266
${AUTODIR}/build-esp8266-latest.sh ${FW_TAG} ${LOCAL_FIRMWARE} ${AUTODIR}/build-esp8266-latest.sh ${FW_TAG} ${LOCAL_FIRMWARE}
...@@ -81,6 +79,9 @@ cd ../rp2 ...@@ -81,6 +79,9 @@ cd ../rp2
build_rp2_boards ${FW_TAG} ${LOCAL_FIRMWARE} build_rp2_boards ${FW_TAG} ${LOCAL_FIRMWARE}
cd ../samd cd ../samd
build_samd_boards ${FW_TAG} ${LOCAL_FIRMWARE} build_samd_boards ${FW_TAG} ${LOCAL_FIRMWARE}
cd ../stm32
build_stm32_boards ${FW_TAG} ${LOCAL_FIRMWARE}
${AUTODIR}/build-stm32-extra.sh ${FW_TAG} ${LOCAL_FIRMWARE}
popd popd
......
...@@ -26,16 +26,17 @@ function build_boards { ...@@ -26,16 +26,17 @@ function build_boards {
return 1 return 1
fi fi
for board_json in $(find boards/ -name board.json); do for board_json in $(find boards/ -name board.json | sort); do
board=$(echo $board_json | awk -F '/' '{ print $2 }') board=$(echo $board_json | awk -F '/' '{ print $2 }')
descr=$(cat $board_json | python3 -c "import json,sys; print(json.load(sys.stdin).get('id', '$board'))") descr=$(cat $board_json | python3 -c "import json,sys; print(json.load(sys.stdin).get('id', '$board'))")
build_dir=/tmp/micropython-build-$board build_dir=/tmp/micropython-build-$board
echo "building $descr $board" echo "building $descr $board"
$MICROPY_AUTOBUILD_MAKE BOARD=$board BUILD=$build_dir || return 1 $MICROPY_AUTOBUILD_MAKE BOARD=$board BUILD=$build_dir && (
for ext in $@; do for ext in $@; do
mv $build_dir/firmware.$ext $dest_dir/$descr$fw_tag.$ext mv $build_dir/firmware.$ext $dest_dir/$descr$fw_tag.$ext
done done
)
rm -rf $build_dir rm -rf $build_dir
done done
} }
...@@ -51,3 +52,7 @@ function build_rp2_boards { ...@@ -51,3 +52,7 @@ function build_rp2_boards {
function build_samd_boards { function build_samd_boards {
build_boards $1 $2 samd_soc.c uf2 build_boards $1 $2 samd_soc.c uf2
} }
function build_stm32_boards {
build_boards $1 $2 modpyb.c dfu hex
}
#!/bin/bash #!/bin/bash
# Build additional variants of pyboard firmware (base variants are built by build-boards.sh).
# function for building firmware # function for building firmware
function do_build() { function do_build() {
...@@ -10,6 +11,7 @@ function do_build() { ...@@ -10,6 +11,7 @@ function do_build() {
build_dir=/tmp/stm-build-$board build_dir=/tmp/stm-build-$board
$MICROPY_AUTOBUILD_MAKE $@ BOARD=$board BUILD=$build_dir || exit 1 $MICROPY_AUTOBUILD_MAKE $@ BOARD=$board BUILD=$build_dir || exit 1
mv $build_dir/firmware.dfu $dest_dir/$descr$fw_tag.dfu mv $build_dir/firmware.dfu $dest_dir/$descr$fw_tag.dfu
mv $build_dir/firmware.hex $dest_dir/$descr$fw_tag.hex
rm -rf $build_dir rm -rf $build_dir
} }
...@@ -31,26 +33,15 @@ fi ...@@ -31,26 +33,15 @@ fi
# build the versions # build the versions
do_build pybv3 PYBV3 do_build pybv3 PYBV3
do_build pybv3-network PYBV3 MICROPY_PY_WIZNET5K=5200 MICROPY_PY_CC3K=1 do_build pybv3-network PYBV3 MICROPY_PY_WIZNET5K=5200 MICROPY_PY_CC3K=1
do_build pybv10 PYBV10
do_build pybv10-dp PYBV10 MICROPY_FLOAT_IMPL=double do_build pybv10-dp PYBV10 MICROPY_FLOAT_IMPL=double
do_build pybv10-thread PYBV10 CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1' do_build pybv10-thread PYBV10 CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1'
do_build pybv10-dp-thread PYBV10 MICROPY_FLOAT_IMPL=double CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1' do_build pybv10-dp-thread PYBV10 MICROPY_FLOAT_IMPL=double CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1'
do_build pybv10-network PYBV10 MICROPY_PY_WIZNET5K=5200 MICROPY_PY_CC3K=1 do_build pybv10-network PYBV10 MICROPY_PY_WIZNET5K=5200 MICROPY_PY_CC3K=1
do_build pybv11 PYBV11
do_build pybv11-dp PYBV11 MICROPY_FLOAT_IMPL=double do_build pybv11-dp PYBV11 MICROPY_FLOAT_IMPL=double
do_build pybv11-thread PYBV11 CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1' do_build pybv11-thread PYBV11 CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1'
do_build pybv11-dp-thread PYBV11 MICROPY_FLOAT_IMPL=double CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1' do_build pybv11-dp-thread PYBV11 MICROPY_FLOAT_IMPL=double CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1'
do_build pybv11-network PYBV11 MICROPY_PY_WIZNET5K=5200 MICROPY_PY_CC3K=1 do_build pybv11-network PYBV11 MICROPY_PY_WIZNET5K=5200 MICROPY_PY_CC3K=1
do_build pyblitev10 PYBLITEV10
do_build pyblitev10-dp PYBLITEV10 MICROPY_FLOAT_IMPL=double do_build pyblitev10-dp PYBLITEV10 MICROPY_FLOAT_IMPL=double
do_build pyblitev10-thread PYBLITEV10 CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1' do_build pyblitev10-thread PYBLITEV10 CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1'
do_build pyblitev10-dp-thread PYBLITEV10 MICROPY_FLOAT_IMPL=double CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1' do_build pyblitev10-dp-thread PYBLITEV10 MICROPY_FLOAT_IMPL=double CFLAGS_EXTRA='-DMICROPY_PY_THREAD=1'
do_build pyblitev10-network PYBLITEV10 MICROPY_PY_WIZNET5K=5200 MICROPY_PY_CC3K=1 do_build pyblitev10-network PYBLITEV10 MICROPY_PY_WIZNET5K=5200 MICROPY_PY_CC3K=1
do_build PYBD-SF2 PYBD_SF2
do_build PYBD-SF3 PYBD_SF3
do_build PYBD-SF6 PYBD_SF6
for board in boards/{NUCLEO_*,STM32F*DISC,B_L*,USBDONGLE_WB55,ESPRUINO_PICO} ; do
bd=$(basename $board)
do_build $bd $bd USE_MBOOT=0 MBOOT_ENABLE_PACKING=0
done
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment