summaryrefslogtreecommitdiff
path: root/script/build/firmware/serprog
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2023-10-06 02:19:57 +0100
committerLeah Rowe <leah@libreboot.org>2023-10-06 02:26:18 +0100
commit315d0c4572d79282fd9190510234496169bdbdaa (patch)
treeaf6dc0237e4c54d04014733d102f3cbb56533ed2 /script/build/firmware/serprog
parent863081c369c60fb485a95188d06f0090787dafad (diff)
mv build/fw/serprog,build/boot/roms build/firmware
./build boot roms is now: ./build firmware coreboot ./build fw serprog is now: ./build firmware serprog Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'script/build/firmware/serprog')
-rwxr-xr-xscript/build/firmware/serprog80
1 files changed, 80 insertions, 0 deletions
diff --git a/script/build/firmware/serprog b/script/build/firmware/serprog
new file mode 100755
index 00000000..0966af77
--- /dev/null
+++ b/script/build/firmware/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 $@