mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-03 23:09:35 +03:00
420b44488f
Basenames that remain, in cmd/zed/zed.d/statechange-led.sh: dev=$(basename "$(echo "$therest" | awk '{print $(NF-1)}')") vdev=$(basename "$ZEVENT_VDEV_PATH") I don't wanna interfere with #11988 scripts/zfs-tests.sh: SINGLETESTFILE=$(basename "$SINGLETEST") tests/zfs-tests/tests/functional/cli_user/zfs_list/zfs_list.kshlib: ACTUAL=$(basename $dataset) ACTUAL=$(basename $dataset) tests/zfs-tests/tests/functional/cli_user/zpool_iostat/ zpool_iostat_-c_homedir.ksh: typeset USER_SCRIPT=$(basename "$USER_SCRIPT_FULL") tests/zfs-tests/tests/functional/cli_user/zpool_iostat/ zpool_iostat_-c_searchpath.ksh: typeset CMD_1=$(basename "$SCRIPT_1") typeset CMD_2=$(basename "$SCRIPT_2") tests/zfs-tests/tests/functional/cli_user/zpool_status/ zpool_status_-c_homedir.ksh: typeset USER_SCRIPT=$(basename "$USER_SCRIPT_FULL") tests/zfs-tests/tests/functional/cli_user/zpool_status/ zpool_status_-c_searchpath.ksh typeset CMD_1=$(basename "$SCRIPT_1") typeset CMD_2=$(basename "$SCRIPT_2") tests/zfs-tests/tests/functional/migration/migration.cfg: export BNAME=`basename $TESTFILE` tests/zfs-tests/tests/perf/perf.shlib: typeset logbase="$(get_perf_output_dir)/$(basename \ tests/zfs-tests/tests/perf/perf.shlib: typeset logbase="$(get_perf_output_dir)/$(basename \ These are potentially Of Directories, where basename is actually useful Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: John Kennedy <john.kennedy@delphix.com> Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Closes #12652
64 lines
1.8 KiB
Bash
Executable File
64 lines
1.8 KiB
Bash
Executable File
#!/bin/sh
|
|
# shellcheck disable=SC2034,SC2154
|
|
|
|
. /lib/dracut-lib.sh
|
|
|
|
# Let the command line override our host id.
|
|
spl_hostid=$(getarg spl_hostid=)
|
|
if [ -n "${spl_hostid}" ] ; then
|
|
info "ZFS: Using hostid from command line: ${spl_hostid}"
|
|
zgenhostid -f "${spl_hostid}"
|
|
elif [ -f "/etc/hostid" ] ; then
|
|
info "ZFS: Using hostid from /etc/hostid: $(hostid)"
|
|
else
|
|
warn "ZFS: No hostid found on kernel command line or /etc/hostid."
|
|
warn "ZFS: Pools may not import correctly."
|
|
fi
|
|
|
|
wait_for_zfs=0
|
|
case "${root}" in
|
|
""|zfs|zfs:)
|
|
# We'll take root unset, root=zfs, or root=zfs:
|
|
# No root set, so we want to read the bootfs attribute. We
|
|
# can't do that until udev settles so we'll set dummy values
|
|
# and hope for the best later on.
|
|
root="zfs:AUTO"
|
|
rootok=1
|
|
wait_for_zfs=1
|
|
|
|
info "ZFS: Enabling autodetection of bootfs after udev settles."
|
|
;;
|
|
|
|
ZFS=*|zfs:*|FILESYSTEM=*)
|
|
# root is explicit ZFS root. Parse it now. We can handle
|
|
# a root=... param in any of the following formats:
|
|
# root=ZFS=rpool/ROOT
|
|
# root=zfs:rpool/ROOT
|
|
# root=zfs:FILESYSTEM=rpool/ROOT
|
|
# root=FILESYSTEM=rpool/ROOT
|
|
# root=ZFS=pool+with+space/ROOT+WITH+SPACE (translates to root=ZFS=pool with space/ROOT WITH SPACE)
|
|
|
|
# Strip down to just the pool/fs
|
|
root="${root#zfs:}"
|
|
root="${root#FILESYSTEM=}"
|
|
root="zfs:${root#ZFS=}"
|
|
# switch + with spaces because kernel cmdline does not allow us to quote parameters
|
|
root=$(echo "$root" | tr '+' ' ')
|
|
rootok=1
|
|
wait_for_zfs=1
|
|
|
|
info "ZFS: Set ${root} as bootfs."
|
|
;;
|
|
esac
|
|
|
|
# Make sure Dracut is happy that we have a root and will wait for ZFS
|
|
# modules to settle before mounting.
|
|
if [ ${wait_for_zfs} -eq 1 ]; then
|
|
ln -s /dev/null /dev/root 2>/dev/null
|
|
initqueuedir="${hookdir}/initqueue/finished"
|
|
test -d "${initqueuedir}" || {
|
|
initqueuedir="${hookdir}/initqueue-finished"
|
|
}
|
|
echo '[ -e /dev/zfs ]' > "${initqueuedir}/zfs.sh"
|
|
fi
|