Add NBD support
This adds basic support for root on a network block device to the netroot framework.master
parent
5103130352
commit
2b117123ec
|
@ -0,0 +1,11 @@
|
|||
#!/bin/sh
|
||||
# We depend on network modules being loaded
|
||||
[ "$1" = "-d" ] && echo network
|
||||
|
||||
# If hostonly was requested, fail the check if we are not actually
|
||||
# booting from root.
|
||||
[ "$1" = "-h" ] && ! egrep -q '/ /dev/nbd[0-9]*' /proc/mounts && exit 1
|
||||
|
||||
# If our prerequisites are not met, fail anyways.
|
||||
which nbd-client >/dev/null 2>&1 || exit 1
|
||||
exit 0
|
|
@ -0,0 +1,7 @@
|
|||
#!/bin/bash
|
||||
|
||||
inst nbd-client
|
||||
inst_hook cmdline 90 "$moddir/parse-nbdroot.sh"
|
||||
inst_hook netroot 90 "$moddir/nbd-netroot.sh"
|
||||
inst "$moddir/nbdroot" "/sbin/nbdroot"
|
||||
instmods nbd
|
|
@ -0,0 +1,11 @@
|
|||
#!/bin/sh # for highlighting
|
||||
|
||||
if [ "$root" = "dhcp" ]; then
|
||||
if [ -n "$new_root_path" -a -z "${new_root_path%%nbd:*}" ]; then
|
||||
root="$new_root_path"
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ -z "${root%nbd:*}" ]; then
|
||||
handler=/sbin/nbdroot
|
||||
fi
|
|
@ -0,0 +1,96 @@
|
|||
#!/bin/sh
|
||||
|
||||
. /lib/dracut-lib
|
||||
|
||||
PATH=$PATH:/sbin:/usr/sbin
|
||||
|
||||
# XXX needs error handling like ifup/dhclient-script
|
||||
|
||||
if getarg rdnetdebug; then
|
||||
exec > /tmp/nbdroot.$1.$$.out
|
||||
exec 2>> /tmp/nbdroot.$1.$$.out
|
||||
set -x
|
||||
fi
|
||||
|
||||
# root is in the form root=nbd:server:port:fstype:fsopts:nbdopts
|
||||
netif="$1"
|
||||
root="$2"
|
||||
|
||||
root=${root#nbd:}
|
||||
nbdserver=${root%%:*}; root=${root#*:}
|
||||
nbdport=${root%%:*}; root=${root#*:}
|
||||
nbdfstype=${root%%:*}; root=${root#*:}
|
||||
nbdflags=${root%%:*}
|
||||
nbdopts=${root#*:}
|
||||
|
||||
if [ "$nbdopts" = "$nbdflags" ]; then
|
||||
unset nbdopts
|
||||
fi
|
||||
if [ "$nbdflags" = "$nbdfstype" ]; then
|
||||
unset nbdflags
|
||||
fi
|
||||
if [ "$nbdfstype" = "$nbdport" ]; then
|
||||
unset nbdfstype
|
||||
fi
|
||||
if [ -z "$nbdfstype" ]; then
|
||||
nbdfstype=auto
|
||||
fi
|
||||
|
||||
# look through the NBD options and pull out the ones that need to
|
||||
# go before the host etc. Append a ',' so we know we terminate the loop
|
||||
nbdopts=${nbdopts},
|
||||
while [ -n "$nbdopts" ]; do
|
||||
f=${nbdopts%%,*}
|
||||
nbdopts=${nbdopts#*,}
|
||||
if [ -z "$f" ]; then
|
||||
break
|
||||
fi
|
||||
if [ -z "${f%bs=*}" -o -z "${f%timeout=*}" ]; then
|
||||
preopts="$preopts $f"
|
||||
continue
|
||||
fi
|
||||
opts="$opts $f"
|
||||
done
|
||||
|
||||
# look through the flags and see if any are overridden by the command line
|
||||
nbdflags=${nbdflags},
|
||||
while [ -n "$nbdflags" ]; do
|
||||
f=${nbdflags%%,*}
|
||||
nbdflags=${nbdflags#*,}
|
||||
if [ -z "$f" ]; then
|
||||
break
|
||||
fi
|
||||
if [ "$f" = "ro" -o "$f" = "rw" ]; then
|
||||
nbdrw=$f
|
||||
continue
|
||||
fi
|
||||
fsopts=${fsopts+$fsopts,}$f
|
||||
done
|
||||
|
||||
getarg ro && nbdrw=ro
|
||||
getarg rw && nbdrw=rw
|
||||
fsopts=${fsopts+$fsopts,}${nbdrw}
|
||||
|
||||
modprobe nbd || exit 1
|
||||
|
||||
# XXX better way to wait for the device to be made?
|
||||
i=0
|
||||
while [ ! -b /dev/nbd0 ]; do
|
||||
[ $i -ge 20 ] && exit 1
|
||||
sleep 0.1
|
||||
i=$(( $i + 1))
|
||||
done
|
||||
|
||||
# XXX netroot expects to have the handler mount things, but we should
|
||||
# XXX allow LVM, LUKS, etc over nbd
|
||||
|
||||
nbd-client $preopts "$nbdserver" "$nbdport" /dev/nbd0 $opts || exit 1
|
||||
|
||||
if ! mount -t $nbdfstype -o$fsopts /dev/nbd0 $NEWROOT; then
|
||||
# Mount failed, clean up after ourselves so if we try a different
|
||||
# interface it can succeed
|
||||
nbd-client -d /dev/nbd0
|
||||
exit 1
|
||||
fi
|
||||
|
||||
exit 0
|
|
@ -0,0 +1,49 @@
|
|||
#!/bin/dash
|
||||
|
||||
# It'd be nice if this could share rules with 99-block.sh, but since
|
||||
# the kernel side adds nbd{1..16} when the module is loaded -- before
|
||||
# they are associated with a server -- we cannot use the udev add rule
|
||||
# to find it
|
||||
#
|
||||
# XXX actually we could, if we move to root=XXX and netroot=XXX, then
|
||||
# you could do root=LABEL=/ nbdroot=XXX, or netroot=nbd:XXX
|
||||
#
|
||||
# However, we need to be 90-nbd.sh to catch root=/dev/nbd*
|
||||
#
|
||||
# Preferred format:
|
||||
# root=nbd:srv:port[:fstype[:rootflags[:nbdopts]]]
|
||||
#
|
||||
# nbdopts is a comma seperated list of options to give to nbd-client
|
||||
#
|
||||
#
|
||||
# Legacy formats:
|
||||
# nbdroot=srv,port
|
||||
# nbdroot=srv:port[:fstype[:rootflags[:nbdopts]]]
|
||||
# root=dhcp nbdroot=srv:port[:fstype[:rootflags[:nbdopts]]]
|
||||
# root=nbd nbdroot=srv:port[:fstype[:rootflags[:nbdopts]]]
|
||||
#
|
||||
|
||||
case "$root" in
|
||||
nbd|dhcp|'')
|
||||
if getarg nbdroot= > /dev/null; then
|
||||
root=nbd:$(getarg nbdroot=)
|
||||
fi
|
||||
;;
|
||||
esac
|
||||
|
||||
# Convert the Debian style to our syntax, but avoid matches on fs arguments
|
||||
case "$root" in
|
||||
nbd:*,*)
|
||||
if check_occurances "$root" ',' 1 && check_occurances "$root" ':' 1;
|
||||
then
|
||||
root=${root%*,}:${root#*,}
|
||||
fi
|
||||
;;
|
||||
esac
|
||||
|
||||
if [ "${root%%:*}" = "nbd" ]; then
|
||||
# XXX validate options here?
|
||||
# XXX generate udev rules?
|
||||
rootok=1
|
||||
netroot=nbd
|
||||
fi
|
Loading…
Reference in New Issue