vendor.sh: Safer exit when vendorfiles not needed
When vendor files were not needed on a given board, the script would directly exit. This is bad, because the inject functions are called directly from the main script, which means the parent instance of lbmk. This means that the lock file and temporary files were not being removed on exit. On a subsequent run, this would cause the error stating that a lock file is present, which would cause further error, making the user believe something is broken in lbmk. Modify the behaviour accordingly; exits are now returns, and these are handled in the calling functions, in such a way that a proper exit occurs, whereby temporary files and the lock file are deleted. For context, please read the main "build" script where it calls vendor_inject and vendor_download. At the end of that script, it calls tmp_cleanup, which removes the TMPDIR that was created, and the lock file. In lbmk, the TMPDIR is not /tmp, but rather a subdirectory under /tmp, so that further calls to mktemp create everything under one single temporary directory, which lbmk automatically removes on exit. Therefore, this patch also avoids leaving temporary files laying around on the disk. Signed-off-by: Leah Rowe <leah@libreboot.org>master
parent
a18175a5df
commit
5d1f182306
|
@ -259,7 +259,7 @@ extract_tbfw()
|
|||
vendor_inject()
|
||||
{
|
||||
set +u +e; [ $# -lt 1 ] && $err "No options specified."
|
||||
[ "$1" = "listboards" ] && eval "ls -1 config/coreboot || :; exit 0"
|
||||
[ "$1" = "listboards" ] && eval "ls -1 config/coreboot || :; return 0"
|
||||
|
||||
archive="$1"; while getopts n:r:b:m: option; do
|
||||
case "$option" in
|
||||
|
@ -273,8 +273,11 @@ vendor_inject()
|
|||
|
||||
check_board || return 0
|
||||
[ "$nukemode" = "nuke" ] || x_ ./vendor download $board
|
||||
[ "$vrelease" != "y" ] && patch_rom "$rom"
|
||||
[ "$vrelease" = "y" ] && patch_release_roms; :
|
||||
if [ "$vrelease" = "y" ]; then
|
||||
patch_release_roms
|
||||
else
|
||||
patch_rom "$rom" || :
|
||||
fi; :
|
||||
}
|
||||
|
||||
check_board()
|
||||
|
@ -338,7 +341,7 @@ patch_release_roms()
|
|||
$err "patch_release_roms: !tar -xf \"$archive\" -C \"tmp/romdir\""
|
||||
|
||||
for x in "tmp/romdir/bin/"*/*.rom ; do
|
||||
patch_rom "$x"
|
||||
patch_rom "$x" || return 0
|
||||
done
|
||||
|
||||
(
|
||||
|
@ -363,7 +366,7 @@ patch_release_roms()
|
|||
patch_rom()
|
||||
{
|
||||
rom="$1"
|
||||
readkconfig || exit 0
|
||||
readkconfig || return 1
|
||||
|
||||
[ "$CONFIG_HAVE_MRC" = "y" ] && inject "mrc.bin" "$CONFIG_MRC_FILE" \
|
||||
"mrc" "0xfffa0000"
|
||||
|
|
Loading…
Reference in New Issue