summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRiku Viitanen <riku.viitanen@protonmail.com>2023-09-12 02:51:32 +0300
committerRiku Viitanen <riku.viitanen@protonmail.com>2023-09-12 02:53:23 +0300
commitc3ac62b1734341777591376f08bd2ca5ed339990 (patch)
treef0d43cfc94269723781d1100890dfa0482cd38a7
parent24185bca429bf4334bdc99bd9054bf864044ccab (diff)
serprog: list available boards
Signed-off-by: Riku Viitanen <riku.viitanen@protonmail.com>
-rwxr-xr-xscript/build/serprog/rp204021
-rwxr-xr-xscript/build/serprog/stm3219
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 $@