pico-sdk: Import picotool as a dependency

We were previously not handling picotool at all, and
pico-sdk would download picotool itself, at build time.

This means that the source archive, if created, would
not contain picotool. While not strictly required, for
complete corresponding source, since it's a toolchain
and not the actual pico-serprog firmware, it is my policy
that releases must include full corresponding source code,
when it is feasible to do so.

I must say, I intensely dislike cmake, with such burning
passion; I am thoroughly displeased by how hacky this is,
but it works and now nothing is in my way for a Libreboot
20241206 rev8 release!

Signed-off-by: Leah Rowe <leah@libreboot.org>
master
Leah Rowe 2025-01-06 16:53:12 +00:00
parent adf1a2e1a4
commit 62d655b8dd
5 changed files with 23 additions and 2 deletions

View File

@ -7,3 +7,4 @@ serx="$sersrc/build/pico_serprog.uf2"
picosdk="src/pico-sdk" picosdk="src/pico-sdk"
serdir="$picosdk/src/boards/include/boards" serdir="$picosdk/src/boards/include/boards"
premake="mkserprog pico" premake="mkserprog pico"
picotool="$PWD/src/picotool/xbmkbin"

View File

@ -3,4 +3,4 @@
rev="e75e3a20e63269a5e3189bc2e49a6a81d45a636a" rev="e75e3a20e63269a5e3189bc2e49a6a81d45a636a"
url="https://codeberg.org/libreboot/pico-serprog" url="https://codeberg.org/libreboot/pico-serprog"
bkup_url="https://git.disroot.org/libreboot/pico-serprog" bkup_url="https://git.disroot.org/libreboot/pico-serprog"
depend="pico-sdk" depend="pico-sdk picotool"

View File

@ -1 +0,0 @@
config/git/rp2040-serprog

View File

@ -0,0 +1,5 @@
# SPDX-License-Identifier: GPL-3.0-or-later
rev="df21059f7ca6f1babc7f1f3b92122cacffc85951"
url="https://github.com/raspberrypi/picotool"
bkup_url="https://codeberg.org/libreboot/picotool"

View File

@ -7,6 +7,9 @@
mkserprog() mkserprog()
{ {
[ $# -lt 1 ] && $err "mkserprog: no arguments provided"
[ "$1" = "pico" ] && mkpicotool
[ "$_f" = "-d" ] && return 0 # dry run [ "$_f" = "-d" ] && return 0 # dry run
basename -as .h "$serdir/"*.h > "$TMPDIR/ser" || $err "!mk $1 $TMPDIR" basename -as .h "$serdir/"*.h > "$TMPDIR/ser" || $err "!mk $1 $TMPDIR"
@ -20,6 +23,7 @@ mkserprog()
ln -srf "$sersrc/build_$pt/" "$sersrc/build") \ ln -srf "$sersrc/build_$pt/" "$sersrc/build") \
&& x_ cmake -DPICO_BOARD="$sertarget" \ && x_ cmake -DPICO_BOARD="$sertarget" \
-DPICO_SDK_PATH="$picosdk" -B "$sersrc/build" "$sersrc" \ -DPICO_SDK_PATH="$picosdk" -B "$sersrc/build" "$sersrc" \
-Dpicotool_DIR="$picotool/picotool" \
&& x_ cmake --build "$sersrc/build" && x_ cmake --build "$sersrc/build"
[ "$1" = "stm32" ] && x_ make -C "$sersrc" \ [ "$1" = "stm32" ] && x_ make -C "$sersrc" \
libopencm3-just-make BOARD=$sertarget && x_ make -C \ libopencm3-just-make BOARD=$sertarget && x_ make -C \
@ -30,6 +34,18 @@ mkserprog()
[ "$XBMK_RELEASE" = "y" ] && mkrom_tarball "bin/serprog_$1"; return 0 [ "$XBMK_RELEASE" = "y" ] && mkrom_tarball "bin/serprog_$1"; return 0
} }
mkpicotool()
{
rm -Rf "$picotool" || $err "Can't remove picotool builddir"
(
x_ cd src/picotool
cmake -DCMAKE_INSTALL_PREFIX=xbmkbin -DPICOTOOL_FLAT_INSTALL=1 \
-DPICO_SDK_PATH=../pico-sdk || \
$err "Can't prep picotool"
make install || $err "Can't build picotool"; :
) || $err "Can't build picotool"; :
}
copyps1bios() copyps1bios()
{ {
x_ rm -Rf bin/playstation x_ rm -Rf bin/playstation