=================================================================== RCS file: /cvs/openbsd/fw_update/fw_install.sh,v retrieving revision 1.63 retrieving revision 1.66 diff -u -r1.63 -r1.66 --- openbsd/fw_update/fw_install.sh 2021/12/09 02:23:15 1.63 +++ openbsd/fw_update/fw_install.sh 2021/12/11 03:12:21 1.66 @@ -1,5 +1,5 @@ #!/bin/ksh -# $OpenBSD: fw_install.sh,v 1.63 2021/12/09 02:23:15 afresh1 Exp $ +# $OpenBSD: fw_install.sh,v 1.66 2021/12/11 03:12:21 afresh1 Exp $ # # Copyright (c) 2021 Andrew Hewus Fresh # @@ -182,26 +182,33 @@ } usage() { - echo "Usage: fw_install [ -d dir ] [ driver | file [ ... ] ]" + echo "usage: fw_install [-d dir | -L dir] [driver | file [...]]" exit 2 } DOWNLOADDIR= -while getopts d: name +LOCALDIR= +while getopts d:L: name do case "$name" in d) DOWNLOADDIR=$OPTARG ;; + L) LOCALDIR=$OPTARG ;; ?) usage 2 ;; esac done shift $((OPTIND - 1)) +if [[ -n "$DOWNLOADDIR" && -n "$LOCALDIR" ]]; then + echo "Cannot use -d and -L" >&2 + usage 2 +fi + set -A devices -- "$@" [ "${devices[*]:-}" ] || set -A devices -- $( devices_needing_firmware ) -if [ ! "${devices:-}" ]; then +if [ ! "${devices[*]:-}" ]; then echo "No devices found which need firmware files to be downloaded." exit fi @@ -214,7 +221,7 @@ d=$( firmware_devicename "$f" ) [ "$f" = "$d" ] && f="$( echo "$f"-firmware-*.tgz | sed '$!d' )" if [ -e "$f" ]; then - if [ "${DOWNLOADDIR:-}" ]; then + if [ "$DOWNLOADDIR" ]; then echo "Cannot download local file $f" >&2 exit 2 fi @@ -228,14 +235,21 @@ echo "Unable to use $DOWNLOADDIR, make sure it is a directory" exit 2 fi +elif [ "$LOCALDIR" ]; then + if ! cd "$LOCALDIR"; then + echo "Unable to use $LOCALDIR, make sure it is a directory" + exit 2 + fi else TMPDIR=$( tmpdir "${DESTDIR}/tmp/fw_install" ) cd "$TMPDIR" fi -fetch "$CFILE" -! signify -qVep "$FWPUB_KEY" -x "$CFILE" -m "$CFILE" && - echo "Signature check of SHA256.sig failed" >&2 && exit 1 +if ! [[ -n "$LOCALDIR" && -e "$CFILE" ]]; then + fetch "$CFILE" + ! signify -qVep "$FWPUB_KEY" -x "$CFILE" -m "$CFILE" && + echo "Signature check of SHA256.sig failed" >&2 && exit 1 +fi for d in "${devices[@]}"; do f="${d##*:}" @@ -248,8 +262,8 @@ set -A installed -- $( installed_firmware "$d" ) - if [ ! "${DOWNLOADDIR:-}" ] && [ "${installed:-}" ]; then - for i in "${installed[@]:-}"; do + if [ ! "$DOWNLOADDIR" ] && [ "${installed[*]:-}" ]; then + for i in "${installed[@]}"; do if [ "${f##*/}" = "$i.tgz" ]; then echo "$i already installed" continue 2 @@ -258,16 +272,17 @@ fi if [ ! -e "$f" ]; then + [ "$LOCALDIR" ] && echo "Cannot install $f, not found" >&2 && continue fetch "$f" || continue verify "$f" || continue - elif [ "${DOWNLOADDIR:-}" ]; then + elif [ "$DOWNLOADDIR" ]; then echo "Already have $f" verify "$f" || continue fi - [ "${DOWNLOADDIR:-}" ] && continue + [ "$DOWNLOADDIR" ] && continue - if [ "${installed:-}" ]; then + if [ "${installed[*]:-}" ]; then for i in "${installed[@]}"; do delete_firmware "$i" done