fix boot parameters for mount options

Fixes: 03c296cb4f
Signed-off-by: Christian Hesse <mail@eworm.de>
This commit is contained in:
Christian Hesse 2016-02-02 15:45:48 +01:00 committed by Gerardo Exequiel Pozzi
parent 03c296cb4f
commit 5725183716
3 changed files with 11 additions and 10 deletions

View File

@ -33,7 +33,7 @@ _mnt_dmsnapshot() {
dmsetup create ${dm_snap_name} --table "0 ${ro_dev_size} snapshot ${ro_dev} ${rw_dev} ${cow_persistent} ${cow_chunksize}" dmsetup create ${dm_snap_name} --table "0 ${ro_dev_size} snapshot ${ro_dev} ${rw_dev} ${cow_persistent} ${cow_chunksize}"
_mnt_dev "/dev/mapper/${dm_snap_name}" "${newroot}${mnt}" "-w" _mnt_dev "/dev/mapper/${dm_snap_name}" "${newroot}${mnt}" "-w" "defaults"
echo $(readlink -f /dev/mapper/${dm_snap_name}) >> /run/archiso/used_block_devices echo $(readlink -f /dev/mapper/${dm_snap_name}) >> /run/archiso/used_block_devices
} }
@ -65,14 +65,15 @@ _mnt_sfs() {
fi fi
sfs_dev=$(losetup --find --show --read-only "${img}") sfs_dev=$(losetup --find --show --read-only "${img}")
echo ${sfs_dev} >> /run/archiso/used_block_devices echo ${sfs_dev} >> /run/archiso/used_block_devices
_mnt_dev "${sfs_dev}" "${mnt}" "-r" _mnt_dev "${sfs_dev}" "${mnt}" "-r" "defaults"
} }
# args: device, mountpoint, flags # args: device, mountpoint, flags, opts
_mnt_dev() { _mnt_dev() {
local dev="${1}" local dev="${1}"
local mnt="${2}" local mnt="${2}"
local flg="${3}" local flg="${3}"
local opts="${4}"
mkdir -p "${mnt}" mkdir -p "${mnt}"
@ -85,7 +86,7 @@ _mnt_dev() {
launch_interactive_shell launch_interactive_shell
done done
if mount "${flg}" "${dev}" "${mnt}"; then if mount -o "${opts}" "${flg}" "${dev}" "${mnt}"; then
msg ":: Device '${dev}' mounted successfully." msg ":: Device '${dev}' mounted successfully."
else else
echo "ERROR; Failed to mount '${dev}'" echo "ERROR; Failed to mount '${dev}'"
@ -110,7 +111,6 @@ 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
@ -137,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 -o "${archisoflags}" "${archisodevice}" "/run/archiso/bootmnt" "-r" _mnt_dev "${archisodevice}" "/run/archiso/bootmnt" "-r" "defaults"
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
@ -166,7 +166,7 @@ archiso_mount_handler() {
fi fi
if [[ -n "${cow_device}" ]]; then if [[ -n "${cow_device}" ]]; then
_mnt_dev -o "${cow_flags}" "${cow_device}" "/run/archiso/cowspace" "-r" _mnt_dev "${cow_device}" "/run/archiso/cowspace" "-r" "${cow_flags}"
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

@ -2,6 +2,7 @@
run_hook () { run_hook () {
[[ -n "${img_label}" ]] && img_dev="/dev/disk/by-label/${img_label}" [[ -n "${img_label}" ]] && img_dev="/dev/disk/by-label/${img_label}"
[[ -z "${img_flags}" ]] && img_flags="defaults"
if [[ -n "${img_dev}" && -n "${img_loop}" ]]; then if [[ -n "${img_dev}" && -n "${img_loop}" ]]; then
mount_handler="archiso_loop_mount_handler" mount_handler="archiso_loop_mount_handler"
fi fi
@ -13,7 +14,7 @@ archiso_loop_mount_handler () {
local _dev_loop local _dev_loop
msg ":: Setup a loop device from ${img_loop} located at device ${img_dev}" msg ":: Setup a loop device from ${img_loop} located at device ${img_dev}"
_mnt_dev "${img_dev}" "/run/archiso/img_dev" "-r" _mnt_dev "${img_dev}" "/run/archiso/img_dev" "-r" "${img_flags}"
if [[ "${copytoram}" != "y" ]]; then if [[ "${copytoram}" != "y" ]]; then
echo $(readlink -f ${img_dev}) >> /run/archiso/used_block_devices echo $(readlink -f ${img_dev}) >> /run/archiso/used_block_devices
fi fi

View File

@ -21,8 +21,6 @@ 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,
@ -125,6 +123,8 @@ INDEX
Default: (unset) Default: (unset)
* img_dev= Device where archiso-image.iso reside. * img_dev= Device where archiso-image.iso reside.
Default: (unset) or "/dev/disk/by-label/${img_label}" Default: (unset) or "/dev/disk/by-label/${img_label}"
* img_flags= Set extra mount options, e.g. for btrfs subvolumes.
Default: defaults
* img_loop= Full path where archiso-image.iso is located on ${img_dev} * img_loop= Full path where archiso-image.iso is located on ${img_dev}
Default: (unset) Default: (unset)