git.sh: support downloading *files* as submodules

when we download coreboot, we currently don't have a way to
download crossgcc tarballs, so we rely on coreboot to do it,
which means running the coreboot build system to do it; which
means we don't get them in release archives, unless we add
very hacky logic (which did exist and was removed).

the problem with coreboot's build system is that it does not
define backup links for each given tarball, instead relying
on gnu.org exclusively, which seems OK at first because the
gnu.org links actually return an HTTP 302 response leading
to a random mirror, HOWEVER:

the gnu.org 302 redirect often fails, and the download fails,
causing an error. a mitigation for this has been to patch the
coreboot build system to download directly from a single mirror
that is reliable (in our case mirrorservice.org).

while this mitigation mostly works, it's not redundant; the
kent mirror is occasionally down too, and again we still have
the problem of not being able to cleanly provide crossgcc
tarballs inside release archives.

do it in config/submodules, like so:

module.list shall say the relative path of a given file,
once downloaded, relative to the given source tree.

module.cfg shall be re-used, in the same way as for git
submodules, but:

subfile="url"
subfile_bkup="backup url"

do this, instead of:

subrepo="url"
subrepo_bkup="backup url"

example entries in module.list:

util/crossgcc/tarballs/binutils-2.41.tar.xz
util/crossgcc/tarballs/gcc-13.2.0.tar.xz
util/crossgcc/tarballs/gmp-6.3.0.tar.xz
util/crossgcc/tarballs/mpc-1.3.1.tar.gz
util/crossgcc/tarballs/mpfr-4.2.1.tar.xz
util/crossgcc/tarballs/nasm-2.16.01.tar.bz2
util/crossgcc/tarballs/R06_28_23.tar.gz

the "subrev" variable (in module.cfg) has been renamed
to "subhash", so that this makes sense, and that name is
common to both subfile/subrepo.

the download logic from the vendor scripts has been re-used
for this purpose, and it verifies files using sha512sum.
therefore:

when specifying subrepo(git submodule), subhash will still
be a sha1 checksum, but:

when specifying subfile(file, e.g. tarball), subhash will
be a sha512 checksum

the logic for both (subrepo and subfile) is unified, and
has this rule:

subrepo* and subfile* must never *both* be declared.

the actual configuration of coreboot crossgcc tarballs
will be done in a follow-up commit. this commit simply
modifies the code to accomodate this.

over time, this feature could be used for many other files
within source trees, and could perhaps be expanded to allow
extracting source tarballs in leiu of git repositories, but
the latter is not yet required and thus not implemented.

Signed-off-by: Leah Rowe <leah@libreboot.org>
audit2-merge1
Leah Rowe 2024-06-08 03:01:05 +01:00 committed by Leah Rowe
parent 0730513709
commit 8a34a0d338
20 changed files with 39 additions and 26 deletions

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/arm-trusted-firmware.git" subrepo="https://review.coreboot.org/arm-trusted-firmware.git"
subrepo_bkup="https://github.com/coreboot/arm-trusted-firmware" subrepo_bkup="https://github.com/coreboot/arm-trusted-firmware"
subrev="23d6774ab53ded09d8065a184b4763504e9c8d9e" subhash="23d6774ab53ded09d8065a184b4763504e9c8d9e"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/libgfxinit.git" subrepo="https://review.coreboot.org/libgfxinit.git"
subrepo_bkup="https://github.com/coreboot/libgfxinit" subrepo_bkup="https://github.com/coreboot/libgfxinit"
subrev="a4be8a21b0e2c752da0042c79aae5942418f53e2" subhash="a4be8a21b0e2c752da0042c79aae5942418f53e2"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/libhwbase.git" subrepo="https://review.coreboot.org/libhwbase.git"
subrepo_bkup="https://github.com/coreboot/libhwbase" subrepo_bkup="https://github.com/coreboot/libhwbase"
subrev="584629b9f4771b7618951cec57df2ca3af9c6981" subhash="584629b9f4771b7618951cec57df2ca3af9c6981"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/vboot.git" subrepo="https://review.coreboot.org/vboot.git"
subrepo_bkup="https://github.com/coreboot/vboot" subrepo_bkup="https://github.com/coreboot/vboot"
subrev="3d37d2aafe1f941c532def2a1fbbb58c8dd84182" subhash="3d37d2aafe1f941c532def2a1fbbb58c8dd84182"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/libgfxinit.git" subrepo="https://review.coreboot.org/libgfxinit.git"
subrepo_bkup="https://github.com/coreboot/libgfxinit" subrepo_bkup="https://github.com/coreboot/libgfxinit"
subrev="a4be8a21b0e2c752da0042c79aae5942418f53e2" subhash="a4be8a21b0e2c752da0042c79aae5942418f53e2"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/libhwbase.git" subrepo="https://review.coreboot.org/libhwbase.git"
subrepo_bkup="https://github.com/coreboot/libhwbase" subrepo_bkup="https://github.com/coreboot/libhwbase"
subrev="584629b9f4771b7618951cec57df2ca3af9c6981" subhash="584629b9f4771b7618951cec57df2ca3af9c6981"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/vboot.git" subrepo="https://review.coreboot.org/vboot.git"
subrepo_bkup="https://github.com/coreboot/vboot" subrepo_bkup="https://github.com/coreboot/vboot"
subrev="3d37d2aafe1f941c532def2a1fbbb58c8dd84182" subhash="3d37d2aafe1f941c532def2a1fbbb58c8dd84182"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/vboot.git" subrepo="https://review.coreboot.org/vboot.git"
subrepo_bkup="https://github.com/coreboot/vboot" subrepo_bkup="https://github.com/coreboot/vboot"
subrev="ecdca931ae0637d1a9498f64862939bd5bb99e0b" subhash="ecdca931ae0637d1a9498f64862939bd5bb99e0b"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/vboot.git" subrepo="https://review.coreboot.org/vboot.git"
subrepo_bkup="https://github.com/coreboot/vboot" subrepo_bkup="https://github.com/coreboot/vboot"
subrev="ecdca931ae0637d1a9498f64862939bd5bb99e0b" subhash="ecdca931ae0637d1a9498f64862939bd5bb99e0b"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/libgfxinit.git" subrepo="https://review.coreboot.org/libgfxinit.git"
subrepo_bkup="https://github.com/coreboot/libgfxinit" subrepo_bkup="https://github.com/coreboot/libgfxinit"
subrev="066e52eeaa329d782ccee96265a6a351fc395bf1" subhash="066e52eeaa329d782ccee96265a6a351fc395bf1"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/libhwbase.git" subrepo="https://review.coreboot.org/libhwbase.git"
subrepo_bkup="https://github.com/coreboot/libhwbase" subrepo_bkup="https://github.com/coreboot/libhwbase"
subrev="8be5a82b85ceb3ee8a1c4fbf36c75a4bfbda8900" subhash="8be5a82b85ceb3ee8a1c4fbf36c75a4bfbda8900"

View File

@ -1,3 +1,3 @@
subrepo="https://review.coreboot.org/vboot.git" subrepo="https://review.coreboot.org/vboot.git"
subrepo_bkup="https://github.com/coreboot/vboot" subrepo_bkup="https://github.com/coreboot/vboot"
subrev="5b8596cefd1a61252501943f2534323708338732" subhash="5b8596cefd1a61252501943f2534323708338732"

View File

@ -1,3 +1,3 @@
subrev="bed60ad131fd90c9e48fcda475e21e353466db1c" subhash="bed60ad131fd90c9e48fcda475e21e353466db1c"
subrepo="https://codeberg.org/canoeboot/cbwww" subrepo="https://codeberg.org/canoeboot/cbwww"
subrepo_bkup="https://git.disroot.org/canoeboot/cbwww" subrepo_bkup="https://git.disroot.org/canoeboot/cbwww"

View File

@ -1,3 +1,3 @@
subrev="12fd6c46c9de7161c85fa497824467ea035a721b" subhash="12fd6c46c9de7161c85fa497824467ea035a721b"
subrepo="https://codeberg.org/canoeboot/cbwww-img" subrepo="https://codeberg.org/canoeboot/cbwww-img"
subrepo_bkup="https://git.disroot.org/canoeboot/cbwww-img" subrepo_bkup="https://git.disroot.org/canoeboot/cbwww-img"

View File

@ -1,3 +1,3 @@
subrev="78cdadea40143a7e55b8eae48f4239d31ebb5c16" subhash="78cdadea40143a7e55b8eae48f4239d31ebb5c16"
subrepo="https://codeberg.org/vimuser/untitled-website" subrepo="https://codeberg.org/vimuser/untitled-website"
subrepo_bkup="https://notabug.org/untitled/untitled-website" subrepo_bkup="https://notabug.org/untitled/untitled-website"

View File

@ -1,3 +1,3 @@
subrepo="git://git.sv.gnu.org/gnulib" subrepo="git://git.sv.gnu.org/gnulib"
subrepo_bkup="https://codeberg.org/libreboot/gnulib" subrepo_bkup="https://codeberg.org/libreboot/gnulib"
subrev="9f48fb992a3d7e96610c4ce8be969cff2d61a01b" subhash="9f48fb992a3d7e96610c4ce8be969cff2d61a01b"

View File

@ -1,3 +1,3 @@
subrepo="git://git.sv.gnu.org/gnulib" subrepo="git://git.sv.gnu.org/gnulib"
subrepo_bkup="https://codeberg.org/libreboot/gnulib" subrepo_bkup="https://codeberg.org/libreboot/gnulib"
subrev="9f48fb992a3d7e96610c4ce8be969cff2d61a01b" subhash="9f48fb992a3d7e96610c4ce8be969cff2d61a01b"

View File

@ -1,3 +1,3 @@
subrev="86c416d4c0fb38432460b3e11b08b9de76941bf5" subhash="86c416d4c0fb38432460b3e11b08b9de76941bf5"
subrepo="https://codeberg.org/libreboot/tinyusb" subrepo="https://codeberg.org/libreboot/tinyusb"
subrepo_bkup="https://github.com/hathach/tinyusb.git" subrepo_bkup="https://github.com/hathach/tinyusb.git"

View File

@ -1,3 +1,3 @@
subrev="458250dc6147dc807eec9e4d5a6caf38a699ecb1" subhash="458250dc6147dc807eec9e4d5a6caf38a699ecb1"
subrepo="https://codeberg.org/libreboot/libopencm3" subrepo="https://codeberg.org/libreboot/libopencm3"
subrepo_bkup="https://github.com/libopencm3/libopencm3" subrepo_bkup="https://github.com/libopencm3/libopencm3"

View File

@ -3,7 +3,7 @@
# Copyright (c) 2022 Caleb La Grange <thonkpeasant@protonmail.com> # Copyright (c) 2022 Caleb La Grange <thonkpeasant@protonmail.com>
eval "$(setvars "" _target rev _xm loc url bkup_url depend tree_depend xtree \ eval "$(setvars "" _target rev _xm loc url bkup_url depend tree_depend xtree \
mdir subrev subrepo subrepo_bkup)" mdir subhash subrepo subrepo_bkup subfile subfile_bkup)"
fetch_project_trees() fetch_project_trees()
{ {
@ -114,18 +114,31 @@ prep_submodules()
fetch_submodule() fetch_submodule()
{ {
mcfgdir="$mdir/${1##*/}" mcfgdir="$mdir/${1##*/}"
eval "$(setvars "" subrev subrepo subrepo_bkup)" eval "$(setvars "" subhash subrepo subrepo_bkup subfile subfile_bkup)"
[ ! -f "$mcfgdir/module.cfg" ] || . "$mcfgdir/module.cfg" || \ [ ! -f "$mcfgdir/module.cfg" ] || . "$mcfgdir/module.cfg" || \
$err "! . $mcfgdir/module.cfg" $err "! . $mcfgdir/module.cfg"
[ -z "$subrepo" ] && [ -z "$subrepo_bkup" ] && return 0 st=""
for mvar in subrepo subrepo_bkup subrev; do for _st in repo file; do
_seval="if [ -n \"\$sub$_st\" ] || [ -n \"\$sub${_st}_bkup\" ]"
eval "$_seval; then st=\"\$st \$_st\"; fi"
done
st="${st# }"
[ "$st" = "repo file" ] && $err "$mdir: repo/file both defined"
[ -z "$st" ] && return 0 # subrepo/subfile not defined
for mvar in "sub${st}" "sub${st}_bkup" "subhash"; do
eval "[ -n \"\$$mvar\" ] || $err \"$1, $mdir: $mvar unset\"" eval "[ -n \"\$$mvar\" ] || $err \"$1, $mdir: $mvar unset\""
done done
rm -Rf "$tmpgit/$1" || $err "!rm '$mdir' '$1'" if [ "$st" = "repo" ]; then
tmpclone "$subrepo" "$subrepo_bkup" "$tmpgit/$1" "$subrev" \ rm -Rf "$tmpgit/$1" || $err "!rm '$mdir' '$1'"
"$mdir/${1##*/}/patches" tmpclone "$subrepo" "$subrepo_bkup" "$tmpgit/$1" "$subhash" \
"$mdir/${1##*/}/patches"
else
download "$subfile" "$subfile_bkup" "$tmpgit/$1" "$subhash"
fi
} }
tmpclone() tmpclone()