95nvmf: rework parameter handling

Always add the nvmf.discover parameters to /etc/nvme/discovery
when parsing the dracut commandline, and rely on NVMe autodiscovery
when no parameters are given.
And modify the syntax to use a comma ',' as a separator for nvmf.discover
as the semicolon ':' is already used for the FC-NVMe transport address format.

Signed-off-by: Hannes Reinecke <hare@suse.de>
master
Hannes Reinecke 2020-09-28 11:25:53 +02:00 committed by Daniel Molkentin
parent ee9b9b1241
commit 4087fd4d1a
2 changed files with 50 additions and 21 deletions

View File

@ -57,6 +57,31 @@ installkernel() {
cmdline() { cmdline() {
local _hostnqn local _hostnqn
local _hostid local _hostid

gen_nvmf_cmdline() {
local _dev=$1
local trtype

[[ -L "/sys/dev/block/$_dev" ]] || return 0
cd -P "/sys/dev/block/$_dev" || return 0
if [ -f partition ] ; then
cd ..
fi
for d in device/nvme* ; do
[ -L "$d" ] || continue
if readlink "$d" | grep -q nvme-fabrics ; then
trtype=$(cat "$d"/transport)
break
fi
done

[ -z "$trtype" ] && return 0
nvme list-subsys ${PWD##*/} | while read x dev trtype traddr host_traddr state ana; do
[ "$trtype" != "${trtype#NQN}" ] && continue
echo -n " nvmf.discover=$trtype,${traddr#traddr=},${host_traddr#host_traddr=}"
done
}

if [ -f /etc/nvme/hostnqn ] ; then if [ -f /etc/nvme/hostnqn ] ; then
_hostnqn=$(cat /etc/nvme/hostnqn) _hostnqn=$(cat /etc/nvme/hostnqn)
echo -n " nvmf.hostnqn=${_hostnqn}" echo -n " nvmf.hostnqn=${_hostnqn}"
@ -65,7 +90,12 @@ cmdline() {
_hostid=$(cat /etc/nvme/hostid) _hostid=$(cat /etc/nvme/hostid)
echo -n " nvmf.hostid=${_hostid}" echo -n " nvmf.hostid=${_hostid}"
fi fi
echo ""
[[ $hostonly ]] || [[ $mount_needs ]] && {
pushd . >/dev/null
for_each_host_dev_and_slaves gen_nvmf_cmdline
popd >/dev/null
}
} }


# called by dracut # called by dracut

View File

@ -3,14 +3,14 @@
# Supported formats: # Supported formats:
# nvmf.hostnqn=<hostnqn> # nvmf.hostnqn=<hostnqn>
# nvmf.hostid=<hostid> # nvmf.hostid=<hostid>
# nvmf.discover=<transport>:<traddr>:<host-traddr>:<trsvcid> # nvmf.discover=<transport>,<traddr>,<host-traddr>,<trsvcid>
# #
# Examples: # Examples:
# nvmf.hostnqn=nqn.2014-08.org.nvmexpress:uuid:37303738-3034-584d-5137-333230423843 # nvmf.hostnqn=nqn.2014-08.org.nvmexpress:uuid:37303738-3034-584d-5137-333230423843
# nvmf.discover=rdma:192.168.1.3::4420 # nvmf.discover=rdma,192.168.1.3,,4420
# nvmf.discover=tcp:192.168.1.3::4420 # nvmf.discover=tcp,192.168.1.3,,4420
# nvmf.discover=tcp:192.168.1.3 # nvmf.discover=tcp,192.168.1.3
# nvmf.discover=fc:auto # nvmf.discover=fc,nn-0x200400a098d85236:pn-0x201400a098d85236,nn-0x200000109b7db455:pn-0x100000109b7db455
# #
# Note: FC does autodiscovery, so typically there is no need to # Note: FC does autodiscovery, so typically there is no need to
# specify any discover parameters for FC. # specify any discover parameters for FC.
@ -25,11 +25,6 @@ fi


initqueue --onetime modprobe --all -b -q nvme nvme_tcp nvme_core nvme_fabrics initqueue --onetime modprobe --all -b -q nvme nvme_tcp nvme_core nvme_fabrics


traddr="none"
trtype="none"
hosttraddr="none"
trsvcid=4420

validate_ip_conn() { validate_ip_conn() {
if ! getargbool 0 rd.neednet ; then if ! getargbool 0 rd.neednet ; then
warn "$trtype transport requires rd.neednet=1" warn "$trtype transport requires rd.neednet=1"
@ -59,8 +54,12 @@ validate_ip_conn() {
} }


parse_nvmf_discover() { parse_nvmf_discover() {
traddr="none"
trtype="none"
hosttraddr="none"
trsvcid=4420
OLDIFS="$IFS" OLDIFS="$IFS"
IFS=: IFS=,
set $1 set $1
IFS="$OLDIFS" IFS="$OLDIFS"


@ -101,7 +100,11 @@ parse_nvmf_discover() {
if [ "$trtype" = "tcp" ]; then if [ "$trtype" = "tcp" ]; then
validate_ip_conn validate_ip_conn
fi fi
if [ "$trtype" = "fc" ] ; then
echo "--transport=$trtype --traddr=$traddr --host-traddr=$hosttraddr" >> /etc/nvme/discovery.conf
else
echo "--transport=$trtype --traddr=$traddr --host-traddr=$hosttraddr --trsvcid=$trsvcid" >> /etc/nvme/discovery.conf echo "--transport=$trtype --traddr=$traddr --host-traddr=$hosttraddr --trsvcid=$trsvcid" >> /etc/nvme/discovery.conf
fi
} }


nvmf_hostnqn=$(getarg nvmf.hostnqn=) nvmf_hostnqn=$(getarg nvmf.hostnqn=)
@ -122,17 +125,13 @@ done
[ -f "/etc/nvme/hostid" ] || exit 0 [ -f "/etc/nvme/hostid" ] || exit 0


if [ -f "/etc/nvme/discovery.conf" ] ; then if [ -f "/etc/nvme/discovery.conf" ] ; then
if [ "$trtype" = "tcp" ] ; then
/sbin/initqueue --settled --onetime --unique --name nvme-discover /usr/sbin/nvme connect-all /sbin/initqueue --settled --onetime --unique --name nvme-discover /usr/sbin/nvme connect-all
if [ "$trtype" = "tcp" ] ; then
> /tmp/net.$ifname.did-setup > /tmp/net.$ifname.did-setup
else
/sbin/initqueue --onetime --unique --name nvme-discover /usr/sbin/nvme connect-all
fi fi
else else
if [ "$trtype" = "tcp" ] ; then # No nvme command line arguments present, try autodiscovery
/sbin/initqueue --settled --onetime --unique /usr/sbin/nvme connect-all -t tcp -a $traddr -s $trsvcid if [ "$trtype" = "fc" ] ; then
> /tmp/net.$ifname.did-setup /sbin/initqueue --finished --onetime --unique --name nvme-fc-autoconnect echo 1 > /sys/class/fc/fc_udev_device/nvme_discovery
else
/sbin/initqueue --finished --unique --name nvme-fc-autoconnect echo 1 > /sys/class/fc/fc_udev_device/nvme_discovery
fi fi
fi fi