X-Git-Url: https://iankelling.org/git/?p=automated-distro-installer;a=blobdiff_plain;f=myfai-chboot-local;h=4fc6f06bd56183162800004ce3750ab867ab0cfc;hp=3ecc7d13f83d5b3beb8af69327faca4c875f56ad;hb=6ca069946c8ff88d79d1ae421e0eda60ae1c514c;hpb=ee37d990c89bb3bab1b54e3b3fb43e9f79ed039b diff --git a/myfai-chboot-local b/myfai-chboot-local index 3ecc7d1..4fc6f06 100755 --- a/myfai-chboot-local +++ b/myfai-chboot-local @@ -32,13 +32,10 @@ while [[ $1 == -* ]]; do esac done -e() { - echo "$*" - if ! "$@"; then - echo "$0: error: exit code $? from: $*" - exit 1 - fi -} +pre="${0##*/}:" +m() { printf "$pre %s\n" "$*"; "$@"; } +e() { printf "$pre %s\n" "$*"; } +err() { echo "[$(date +'%Y-%m-%d %H:%M:%S%z')]: $pre: $*" >&2; } host=$1 @@ -68,6 +65,7 @@ else exit 1 fi ip=$ip/32 + echo "$0: found ip of $host: $ip" fi if modprobe nfsd &>/dev/null; then @@ -105,14 +103,17 @@ fi # man page doesn't explain this, but this deletes & thus disables # all chboot systems. -e fai-chboot -iv $std_arg default # set it to default to get a val out of it next +m fai-chboot -iv $std_arg default # set it to default to get a val out of it next kernel=$(fai-chboot -L '^default$' | awk '{print $3}') default_k_args=$(fai-chboot -L '^default$' | \ sed -r "s/^(\S+\s+){3}(.*)/\2/") # example of default_k_args -# initrd=initrd.img-3.16.0-4-amd64 ip=dhcp root=192.168.1.3:/srv/fai/nfsroot aufs FAI_CONFIG_SRC=nfs://faiserver/srv/fai/config FAI_ACTION=install +# initrd=initrd.img-3.16.0-4-amd64 ip=dhcp root=192.168.1.3:/srv/fai/nfsroot FAI_CONFIG_SRC=nfs://faiserver/srv/fai/config FAI_ACTION=install -k_args=(FAI_ACTION=$fai_action) +# https://wiki.archlinux.org/index.php/Solid_state_drive#Resolving_NCQ_errors +# currently on needed on d16 samsung 870 qvo, but better to have this +# and not wait for more conditions where its needed. +k_args=(FAI_ACTION=$fai_action libata.force=noncq) if $kgped16; then k_args+=(console=tty0 console=ttyS0,115200) fi @@ -125,7 +126,7 @@ for arg in $default_k_args; do esac done rm -f /srv/tftp/fai/pxelinux.cfg/* -e fai-chboot -k "${k_args[*]}" -v -f verbose,sshd,createvt$fai_reboot_arg $std_arg $kernel "$host" +m fai-chboot -k "${k_args[*]}" -v -f verbose,sshd,createvt$fai_reboot_arg $std_arg $kernel "$host" # this is needed for autodiscover iso. i'm not sure, it might override # the fai-chboot method of setting this, i'm not sure.