summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2024-05-14 23:17:22 +0100
committerLeah Rowe <leah@libreboot.org>2024-05-14 23:44:28 +0100
commit1ce7e339769c4fd38ce5a3818e5b5835a867422a (patch)
tree7a1840ba9d1be48675711eee01544793923aaad5
parent190495d2e51e8fac710e53e6b3bc7afc3de74277 (diff)
move rom tarball creation to script/roms
export LBMK_RELEASE="y" if this is done, the tarball is created instead of a directory, and the rom images are nuked using ./vendor inject with the nuke option, inserting the correct version files; the rom directory is deleted now the release script logic simple renames existing tarballs. the benefit of this change is fewer lines of code, and now lbmk doesn't use an insane amount of disk space when building a *lot* of release images (the uncompressed directories are deleted after each build) Signed-off-by: Leah Rowe <leah@libreboot.org>
-rwxr-xr-xbuild123
-rwxr-xr-xinclude/option.sh38
-rwxr-xr-xscript/roms25
3 files changed, 63 insertions, 123 deletions
diff --git a/build b/build
index 9917cd03..41154704 100755
--- a/build
+++ b/build
@@ -223,130 +223,15 @@ mkrom_images()
./build roms serprog rp2040 || $err "${_xm}: rp2040"
./build roms serprog stm32 || $err "${_xm}: stm32"
- for rombuild in bin/*; do
- [ -d "${rombuild}" ] || continue
- handle_rom_archive "${rombuild}"
+ for rombuild in bin/*.tar.xz; do
+ [ -f "${rombuild}" ] || continue
+ tarball="release/$version/roms/${relname}_${rombuild##*/}"
+ mv "$rombuild" "$tarball" || $err "Cannot create $tarball"
done
mv "release/${version}/roms/" ../roms || $err "${_xm}: copy roms/"
}
-handle_rom_archive()
-{
- builddir="${1}"
- romdir="tmp/romdir"
- rm -Rf "${romdir}" || $err "!rm romdir, handle_rom_archive"
- target="${builddir##*/}"
-
- if [ ! -f "config/coreboot/${target}/target.cfg" ]; then
- # No config, just make a tarball
- tarball="release/${version}/roms/${relname}_${target}.tar.xz"
- insert_copying_files "${builddir}" || \
- $err "!insert copy, handle, ${builddir}"
- mktarball "${builddir}" "${tarball}"
- return 0
- fi
-
- romdir="${romdir}/bin/${target}"
- mkdir -p "${romdir}" || $err "!mkdir -p romdir, handle_rom_archive"
- cp "$builddir/"* "$romdir" || $err "!cp romdir, handle_rom_archive"
-
- nukerom
-
- printf "Generating release/%s/roms/%s-%s_%s.tar.xz\n" \
- "${version}" "${projectname}" "${version}" "${target##*/}"
- insert_version_files "${romdir}" || \
- $err "mkrom_tarball ${romdir}: versionfile"
-
- insert_copying_files "$romdir" || $err "!insert copy, handle 2, $romdir"
- mkrom_tarball
-}
-
-nukerom()
-{
- . "config/coreboot/${target}/target.cfg"
-
- # Hash the images before removing vendor files
- # which "./vendor inject" uses for verification
- rm -f "${romdir}/vendorhashes" || $err "!rm ${romdir}/vendorhashes"
- touch "${romdir}/vendorhashes" || $err "!touch ${romdir}/vendorhashes"
- (
- cd "${romdir}" || $err "!cd romdir ${romdir}, nukerom"
- sha512sum ./*.rom >> vendorhashes || \
- $err "!create vendorhashes, nukerom"
- ) || $err "can't create vendor hashes"
-
- for romfile in "${romdir}"/*.rom; do
- [ -f "${romfile}" ] || continue
- ./vendor inject -r "$romfile" -b "$target" -n nuke || \
- $err "!vendor inject (nuke) ${romfile}, nukerom"
- done
-}
-
-insert_copying_files()
-{
- remkdir "${1}/licenses"
- l="${1}/licenses"
- # copy licenses to rom image archive, for completion
- cp "src/grub/COPYING" "${l}/COPYING.grub" || return 1
- cp "src/coreboot/default/COPYING" "${l}/COPYING.coreboot" || return 1
- cp -R "src/coreboot/default/LICENSES" "${l}/LICENSES.coreboot" || \
- return 1
- cp "src/seabios/default/COPYING" "${l}/COPYING.coreboot" || return 1
- cp "src/seabios/default/COPYING.LESSER" "$l/COPYING.LESSER.seabios" \
- || return 1
- cp -R "src/u-boot/default/Licenses" "${l}/COPYING.u-boot" || return 1
- printf "Multiple licenses. Check corresponding %s source archive\n" \
- "${projectname}" > "${1}/COPYING" || return 1
- rm -f src/u-boot/*/test/lib/strlcat.c || return 1
-}
-
-mkrom_tarball()
-{
- archivename="${relname}_${target##*/}"
- f="release/${version}/roms/${archivename}"
- mkdir -p "${f%/*}" || $err "mkrom_tarball: !mkdir -p ${f%/*}"
- (
- cd "${romdir%"/bin/$target"}" || $err "!cd ${romdir%"/bin/$target"}"
- mktarball "bin/${target}" "${archivename}.tar.xz"
- ) || $err "can't create rom tarball"
- mv "${romdir%"/bin/${target}"}/${archivename}.tar.xz"* "${f%/*}" || \
- $err "mktar ${f%/*}/${romdir%"/bin/$target"}/$archivename.tar.xz"
-
- printf "Created ROM archive: %s" "${f%/*}/${archivename}.tar.xz"
-}
-
-insert_version_files()
-{
- printf "%s\n" "${version}" > "${1}/version" || return 1
- printf "%s\n" "${versiondate}" > "${1}/versiondate" || return 1
- printf "%s\n" "${projectname}" > "${1}/projectname" || return 1
-}
-
-mktarball()
-{
- # preserve timestamps for reproducible tarballs
- tar_implementation=$(tar --version | head -n1) || :
-
- [ "${2%/*}" = "${2}" ] || \
- mkdir -p "${2%/*}" || $err "mk, !mkdir -p \"${2%/*}\""
- printf "\nCreating archive: %s\n\n" "$2"
- if [ "${tar_implementation% *}" = "tar (GNU tar)" ]; then
- tar --sort=name --owner=root:0 --group=root:0 \
- --mtime="UTC 2024-05-04" -c "$1" | xz -T$threads -9e \
- > "$2" || $err "mktarball 1, ${1}"
- else
- # TODO: reproducible tarballs on non-GNU systems
- tar -c "$1" | xz -T$threads -9e > "$2" || \
- $err "mktarball 2, $1"
- fi
- (
- [ "${2%/*}" != "${2}" ] && x_ cd "${2%/*}"
- sha512sum "${2##*/}" > "${2##*/}.sha512" || \
- $err "!sha512sum \"${2##*/}\" > \"${2##*/}.sha512\""
- ) || $err "failed to create tarball checksum"
-}
-
mkversion()
{
printf "revision: %s %s\n" "$projectname" "$version"
diff --git a/include/option.sh b/include/option.sh
index b79c34f4..b974c630 100755
--- a/include/option.sh
+++ b/include/option.sh
@@ -171,3 +171,41 @@ check_project()
done
export LOCALVERSION="-${projectname}-${version%%-*}"
}
+
+mktar_release()
+{
+ x_ insert_version_files "$1"
+ mktarball "$1" "${1}.tar.xz"
+ x_ rm -Rf "$1"
+}
+
+mktarball()
+{
+ # preserve timestamps for reproducible tarballs
+ tar_implementation=$(tar --version | head -n1) || :
+
+ [ "${2%/*}" = "${2}" ] || \
+ mkdir -p "${2%/*}" || $err "mk, !mkdir -p \"${2%/*}\""
+ printf "\nCreating archive: %s\n\n" "$2"
+ if [ "${tar_implementation% *}" = "tar (GNU tar)" ]; then
+ tar --sort=name --owner=root:0 --group=root:0 \
+ --mtime="UTC 2024-05-04" -c "$1" | xz -T$threads -9e \
+ > "$2" || $err "mktarball 1, ${1}"
+ else
+ # TODO: reproducible tarballs on non-GNU systems
+ tar -c "$1" | xz -T$threads -9e > "$2" || \
+ $err "mktarball 2, $1"
+ fi
+ (
+ [ "${2%/*}" != "${2}" ] && x_ cd "${2%/*}"
+ sha512sum "${2##*/}" > "${2##*/}.sha512" || \
+ $err "!sha512sum \"${2##*/}\" > \"${2##*/}.sha512\""
+ ) || $err "failed to create tarball checksum"
+}
+
+insert_version_files()
+{
+ printf "%s\n" "${version}" > "${1}/version" || return 1
+ printf "%s\n" "${versiondate}" > "${1}/versiondate" || return 1
+ printf "%s\n" "${projectname}" > "${1}/projectname" || return 1
+}
diff --git a/script/roms b/script/roms
index ce7e52f2..b48bb7a0 100755
--- a/script/roms
+++ b/script/roms
@@ -66,11 +66,16 @@ main()
done
fi
+ bstr="directories"
+ [ "$lbmk_release" = "y" ] && bstr="tarballs"
+
[ -z "${targets}" ] && $err "No ROM images were compiled"
- printf "\nROM images available in these directories:\n"
+ printf "\nROM images available in these %s:\n" "$bstr"
eval "printf \"${targets}\""
- printf "^^ ROM images available in these directories.\n\n"
+ printf "^^ ROM images available in these %s.\n\n" "$bstr"
+ [ "$lbmk_release" = "y" ] && \
+ printf "Always run the inject command on release images!\n"
printf "DO NOT flash images from elf/ - please use bin/ instead.\n"
}
@@ -89,6 +94,7 @@ handle_serprog()
if [ $# -gt 1 ] && [ "${2}" = "list" ]; then
print_serprog_boards ${serprog_boards_dir}
+ return 0
elif [ $# -gt 1 ]; then
build_${1}_rom "${2}"
else
@@ -98,6 +104,8 @@ handle_serprog()
build_${1}_rom "${board}"
done
fi
+
+ [ "$lbmk_release" = "y" ] && mktar_release "bin/serprog_$1"; return 0
}
build_rp2040_rom()
@@ -151,7 +159,9 @@ handle_coreboot_target()
build_target_mainboard
[ -d "bin/${board}" ] || return 0
- targets="* bin/${board}\n${targets}"
+ [ "$lbmk_release" = "y" ] || targets="* bin/${board}\n${targets}"
+ [ "$lbmk_release" = "y" ] && targets="* bin/$board.tar.xz\n$targets"
+ [ "$lbmk_release" = "y" ] && mktar_release "bin/$board"; return 0
}
configure_target()
@@ -264,7 +274,7 @@ build_uboot_payload()
build_target_mainboard()
{
- rm -f "${romdir}/"* || $err "!prepare, rm files, ${romdir}"
+ x_ rm -Rf "${romdir}"
for x in "normal" "vgarom" "libgfxinit"; do
initmode="${x}"
@@ -460,6 +470,13 @@ moverom()
x_ mkdir -p "${2%/*}"
x_ cp "$1" "$2"
+ [ "$lbmk_release" = "y" ] || return 0
+
+ (
+ cd "${2%/*}" || $err "moverom, !cd \"${2%/*}\""
+ sha512sum ./"${2##*/}" >> vendorhashes || $err "!$2 vendorhashes"
+ ) || $err "Cannot create checksum for '$2'"
+ x_ ./vendor inject -r "${2}" -b "$board" -n nuke
}
usage()