diff options
author | Leah Rowe <leah@libreboot.org> | 2023-10-06 03:32:38 +0100 |
---|---|---|
committer | Leah Rowe <leah@libreboot.org> | 2023-10-06 03:32:38 +0100 |
commit | 965b6a7ed73f1dbd78a353c83b99a88b50c86f38 (patch) | |
tree | 8df72616290921a2b56715f9020cbb021cb0a39c /script/build/fw/serprog | |
parent | 5494ffb3d10b66de8723d1c841a25e404d4885bd (diff) |
rename build/firmware/ to build/fw/
Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'script/build/fw/serprog')
-rwxr-xr-x | script/build/fw/serprog | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/script/build/fw/serprog b/script/build/fw/serprog new file mode 100755 index 00000000..0966af77 --- /dev/null +++ b/script/build/fw/serprog @@ -0,0 +1,80 @@ +#!/usr/bin/env sh +# SPDX-License-Identifier: GPL-3.0-or-later +# SPDX-FileCopyrightText: 2023 Riku Viitanen <riku.viitanen@protonmail.com> + +[ "x${DEBUG+set}" = 'xset' ] && set -v +set -u -e + +. "include/err.sh" + +pico_src_dir=util-fw/rp2040/pico-serprog +pico_sdk_dir=util-fw/rp2040/pico-sdk + +stm32_src_dir=util-fw/stm32-vserprog + +usage="usage: ./build firmware serprog <rp2040|stm32> [board]" + +main() +{ + [ -z "${1+x}" ] && err "${usage}" + if [ "${1}" = "rp2040" ]; then + platform="rp2040" + boards_dir=${pico_sdk_dir}/src/boards/include/boards + [ -d "${pico_src_dir}/" ] || \ + x_ ./update project repo "rpi-pico-serprog" + elif [ "${1}" = "stm32" ]; then + platform="stm32" + boards_dir=${stm32_src_dir}/boards + [ -d "${stm32_src_dir}/" ] || \ + x_ ./update project repo "stm32-vserprog" + else + err "${usage}" + fi + x_ mkdir -p "bin/serprog_${platform}" + + if [ $# -gt 1 ] ; then + [ "${2}" = "list" ] && print_boards ${boards_dir} && return 0 + build_${platform}_rom "${2}" + else + printf "Building all serprog targets\n" + list_boards "${boards_dir}" | while read board; do + build_${platform}_rom "${board}" + done + fi +} + +build_rp2040_rom() +{ + board=${1} + printf "Building pico-serprog for ${board}\n" + x_ cmake -DPICO_BOARD="${board}" -DPICO_SDK_PATH="${pico_sdk_dir}" \ + -B "${pico_src_dir}/build" "${pico_src_dir}" + x_ cmake --build "${pico_src_dir}/build" + x_ mv ${pico_src_dir}/build/pico_serprog.uf2 \ + bin/serprog_rp2040/serprog_${board}.uf2 + printf "output to bin/serprog_rp2040/serprog_${board}.uf2\n" +} + +build_stm32_rom() +{ + board=${1} + printf "Building stm32-vserprog for ${board}\n" + x_ make -C ${stm32_src_dir} libopencm3-just-make BOARD=${board} + x_ make -C ${stm32_src_dir} BOARD=${board} + x_ mv ${stm32_src_dir}/stm32-vserprog.hex \ + bin/serprog_stm32/serprog_${board}.hex + printf "output to bin/serprog_stm32/serprog_${board}.hex\n" +} + +print_boards() +{ + printf "Available boards:\n" + list_boards "${1}" +} + +list_boards() +{ + basename -a -s .h ${1}/*.h +} + +main $@ |