update/release: make src tarball first, then roms

this way, the src tarball is guaranteed to be clean.

the downside is that lbmk itself does not currently
handle crossgcc downloads, and there may be some
stragglers such as third party modules automatically
downloaded by certain codebases that libreboot uses.

this will have to be audited later (and it will be).

Signed-off-by: Leah Rowe <leah@libreboot.org>
btrfsvols
Leah Rowe 2023-10-13 23:11:40 +01:00
parent 653a8571f4
commit 268fd6ce71
1 changed files with 6 additions and 38 deletions

View File

@ -72,15 +72,16 @@ build_release()
_xm="build_release ${vdir}" _xm="build_release ${vdir}"
( (
cd "${srcdir}" || err "${_xm}: !cd \"${srcdir}\"" cd "${srcdir}" || err "${_xm}: !cd \"${srcdir}\""
fetch_trees fetch_trees
mkrom_images
clean_release
) )
( (
cd "${srcdir%/*}" || err "${_xm}: mktarball \"${srcdir}\"" cd "${srcdir%/*}" || err "${_xm}: mktarball \"${srcdir}\""
mktarball "${srcdir##*/}" "${srcdir##*/}.tar.xz" || err "${_xm}: mksrc" mktarball "${srcdir##*/}" "${srcdir##*/}.tar.xz" || err "${_xm}: mksrc"
) )
(
cd "${srcdir}" || err "${_xm}: 2 !cd \"${srcdir}\""
mkrom_images
)
rm -Rf "${srcdir}" || err "${_xm}: !rm -Rf \"${srcdir}\"" rm -Rf "${srcdir}" || err "${_xm}: !rm -Rf \"${srcdir}\""
} }
@ -89,16 +90,9 @@ fetch_trees()
for x in ${_f}; do for x in ${_f}; do
./update project trees -f "${x}" || err "${_xm}: fetch ${x}" ./update project trees -f "${x}" || err "${_xm}: fetch ${x}"
done done
x_ rm -Rf src/coreboot/coreboot src/u-boot/u-boot src/seabios/seabios
# by doing this first, we build-test under the same conditions as
# the user, when they extract and build from the src tarball. this
# saves time on build-testing, because we build once, not twice. thus:
rm -Rf */.git* */*/.git* */*/*/.git* */*/*/*/.git* */*/*/*/*/.git* \ rm -Rf */.git* */*/.git* */*/*/.git* */*/*/*/.git* */*/*/*/*/.git* \
*/*/*/*/*/*/.git* */*/*/*/*/*/*/.git* */*/*/*/*/*/*/*/.git* || \ */*/*/*/*/*/.git* */*/*/*/*/*/*/.git* */*/*/*/*/*/*/*/.git* \
err "${_xm}: rm-dotgit" .git || err "${_xm}: rm-dotgit"
} }
mkrom_images() mkrom_images()
@ -253,32 +247,6 @@ mkrom_tarball()
printf "Created ROM archive: ${f%/*}/${archivename}.tar.xz" printf "Created ROM archive: ${f%/*}/${archivename}.tar.xz"
} }
clean_release()
{
for x in "src/coreboot/default/util/kbc1126" util/*; do
[ ! -f "${x}/Makefile" ] && continue
x_ make clean -C "${x}"
done
for x in ${_f}; do
./update project trees -c "${x}" || err "${_xm}: pclean ${x}"
done
./update project trees -x coreboot || err "${_xm}: clean-crossgcc"
./update project trees -c "stm32-vserprog/libopencm3"
# make absolutely sure crossgcc was purged. for some reason,
# crossgcc-clean isn't always reliable on every coreboot tree
for xgcc in "build-" "binutils-" "gcc-" "gmp-" "mpc-" "mpfr-" \
"llvm-" "clang-tools-" "cfe-" "compiler-rt-" "acpica-" \
"getopt" "xgcc"; do
x_ rm -Rf src/coreboot/*/util/crossgcc/${xgcc}*
done
rm -Rf vendor mrc ec pciroms || err "${_xm}: vendor files"
rm -Rf elf tmp cbutils src/pico-serprog/build release bin || \
err "${_xm}: elf, tmp, cbutils, pico-serprog/build"
}
insert_version_files() insert_version_files()
{ {
printf "%s\n" "${version}" > "${1}/version" || return 1 printf "%s\n" "${version}" > "${1}/version" || return 1