add boot params archisoflags= and cow_flags= for mount options

Having files on btrfs subvolumes requires to give mount options. Add
boot params archisoflags= and cow_flags= for this purpose. Boot
parameters could look like this:

... archisodevice=/dev/sdaX archisoflags=subvolume=isos
cow_device=/dev/sdaX cow_flags=subvolume=persist ...

Signed-off-by: Christian Hesse <mail@eworm.de>
This commit is contained in:
Christian Hesse 2015-12-13 15:18:39 +01:00 committed by Gerardo Exequiel Pozzi
parent d1e95f8581
commit 03c296cb4f
2 changed files with 8 additions and 2 deletions

View File

@ -110,6 +110,7 @@ run_hook() {
[[ -z "${archisobasedir}" ]] && archisobasedir="arch" [[ -z "${archisobasedir}" ]] && archisobasedir="arch"
[[ -z "${dm_snap_prefix}" ]] && dm_snap_prefix="arch" [[ -z "${dm_snap_prefix}" ]] && dm_snap_prefix="arch"
[[ -z "${archisodevice}" ]] && archisodevice="/dev/disk/by-label/${archisolabel}" [[ -z "${archisodevice}" ]] && archisodevice="/dev/disk/by-label/${archisolabel}"
[[ -z "${archisoflags}" ]] && archisoflags="defaults"
[[ -z "${cow_spacesize}" ]] && cow_spacesize="256M" [[ -z "${cow_spacesize}" ]] && cow_spacesize="256M"
if [[ -n "${cow_label}" ]]; then if [[ -n "${cow_label}" ]]; then
@ -121,6 +122,7 @@ run_hook() {
cow_persistent="N" cow_persistent="N"
fi fi
[[ -z "${cow_flags}" ]] && cow_flags="defaults"
[[ -z "${cow_directory}" ]] && cow_directory="persistent_${archisolabel}/${arch}" [[ -z "${cow_directory}" ]] && cow_directory="persistent_${archisolabel}/${arch}"
[[ -z "${cow_chunksize}" ]] && cow_chunksize="8" [[ -z "${cow_chunksize}" ]] && cow_chunksize="8"
@ -135,7 +137,7 @@ archiso_mount_handler() {
local newroot="${1}" local newroot="${1}"
if ! mountpoint -q "/run/archiso/bootmnt"; then if ! mountpoint -q "/run/archiso/bootmnt"; then
_mnt_dev "${archisodevice}" "/run/archiso/bootmnt" "-r" _mnt_dev -o "${archisoflags}" "${archisodevice}" "/run/archiso/bootmnt" "-r"
if [[ "${copytoram}" != "y" ]]; then if [[ "${copytoram}" != "y" ]]; then
echo $(readlink -f ${archisodevice}) >> /run/archiso/used_block_devices echo $(readlink -f ${archisodevice}) >> /run/archiso/used_block_devices
fi fi
@ -164,7 +166,7 @@ archiso_mount_handler() {
fi fi
if [[ -n "${cow_device}" ]]; then if [[ -n "${cow_device}" ]]; then
_mnt_dev "${cow_device}" "/run/archiso/cowspace" "-r" _mnt_dev -o "${cow_flags}" "${cow_device}" "/run/archiso/cowspace" "-r"
echo $(readlink -f ${cow_device}) >> /run/archiso/used_block_devices echo $(readlink -f ${cow_device}) >> /run/archiso/used_block_devices
mount -o remount,rw "/run/archiso/cowspace" mount -o remount,rw "/run/archiso/cowspace"
else else

View File

@ -21,6 +21,8 @@ INDEX
Default: (unset) Default: (unset)
* archisodevice= Set the device node where archiso medium is located. * archisodevice= Set the device node where archiso medium is located.
Default: "/dev/disk/by-label/${archisolabel}" Default: "/dev/disk/by-label/${archisolabel}"
* archisoflags= Set extra mount options, e.g. for btrfs subvolumes.
Default: defaults
* archisobasedir= Set the base directory where all files reside. * archisobasedir= Set the base directory where all files reside.
Default: "arch" Default: "arch"
* copytoram= If set to "y" or just "copytoram" without arguments, * copytoram= If set to "y" or just "copytoram" without arguments,
@ -35,6 +37,8 @@ INDEX
Default: (unset) Default: (unset)
* cow_device= Like cow_label= but using device node. * cow_device= Like cow_label= but using device node.
Default: (unset) or "/dev/disk/by-label/${cow_label}" Default: (unset) or "/dev/disk/by-label/${cow_label}"
* cow_flags= Set extra mount options, e.g. for btrfs subvolumes.
Default: defaults
* cow_directory= Set a directory inside ${cow_device}. * cow_directory= Set a directory inside ${cow_device}.
Default: "/persistent_${archisolabel}/${arch}" Default: "/persistent_${archisolabel}/${arch}"
* cow_persistent= Set if snapshot is persistent "P" or non-persistent "N". * cow_persistent= Set if snapshot is persistent "P" or non-persistent "N".