diff options
Diffstat (limited to 'script/build')
-rwxr-xr-x | script/build/serprog/rp2040 | 21 | ||||
-rwxr-xr-x | script/build/serprog/stm32 | 19 |
2 files changed, 29 insertions, 11 deletions
diff --git a/script/build/serprog/rp2040 b/script/build/serprog/rp2040 index 3b4fbf14..83c8af69 100755 --- a/script/build/serprog/rp2040 +++ b/script/build/serprog/rp2040 @@ -24,23 +24,25 @@ set -u -e . "include/err.sh" serprog_release_dir=$(pwd)/bin/serprog_rp2040 -sdk_dir=$(pwd)/util-fw/rp2040/pico-sdk src_dir=$(pwd)/util-fw/rp2040/pico-serprog +sdk_dir=$(pwd)/util-fw/rp2040/pico-sdk +boards_dir=${sdk_dir}/src/boards/include/boards main() { - printf "Compiling serprog firmware for Raspberry Pi Pico\n" - [ -d "${src_dir}/" ] || ./update project repo rpi-pico-serprog \ || err "fetch rpi-pico-serprog failed!\n" mkdir -p "${serprog_release_dir}" || \ err "can't create dir: ${serprog_release_dir}" - boards_dir=${sdk_dir}/src/boards/include/boards - if [ $# -gt 0 ] ; then - buildrom "${1}" + if [ "${1}" = "list" ] ; then + list_boards + else + buildrom "${1}" + fi else + printf "Building pico-serprog for all boards\n" basename -a -s .h ${boards_dir}/*.h | while read board ; do [ "${board}" = "none" ] || buildrom ${board} done @@ -51,6 +53,7 @@ main() buildrom() { board=${1} + printf "Building pico-serprog for ${board}\n" cmake -DPICO_BOARD="${board}" -DPICO_SDK_PATH="${sdk_dir}" \ -B "${src_dir}/build" "${src_dir}" \ || err "can't cmake ${src_dir}" @@ -61,4 +64,10 @@ buildrom() printf "output to ${serprog_release_dir}/serprog_${board}.uf2\n" } +list_boards() +{ + printf "Available boards for pico-serprog:\n" + basename -a -s .h ${boards_dir}/*.h +} + main $@ diff --git a/script/build/serprog/stm32 b/script/build/serprog/stm32 index 41412957..94c45bc8 100755 --- a/script/build/serprog/stm32 +++ b/script/build/serprog/stm32 @@ -25,21 +25,23 @@ set -u -e serprog_release_dir=$(pwd)/bin/serprog_stm32 src_dir=$(pwd)/util-fw/stm32-vserprog +boards_dir=${src_dir}/boards main() { - printf "Compiling serprog firmware for STM32\n" - [ -d "${src_dir}/" ] || ./update project repo stm32-vserprog \ || err "fetch stm32-vserprog failed!\n" mkdir -p "${serprog_release_dir}" || \ err "can't create dir: ${serprog_release_dir}" - boards_dir=${src_dir}/boards - if [ $# -gt 0 ] ; then - buildrom "${1}" + if [ "${1}" = "list" ] ; then + list_boards + else + buildrom "${1}" + fi else + printf "Building stm32-vserprog for all boards\n" basename -a -s .h ${boards_dir}/*.h | while read board ; do buildrom ${board} done @@ -50,6 +52,7 @@ main() buildrom() { board=${1} + printf "Building stm32-vserprog for ${board}\n" make -C ${src_dir} libopencm3-just-make BOARD=${board} make -C ${src_dir} BOARD=${board} mv ${src_dir}/stm32-vserprog.hex \ @@ -58,4 +61,10 @@ buildrom() printf "output to ${serprog_release_dir}/serprog_${board}.hex\n" } +list_boards() +{ + printf "Available boards for stm32-vserprog:\n" + basename -a -s .h ${boards_dir}/*.h +} + main $@ |