|
|
|
@@ -11,19 +11,13 @@ _mnt_fs() {
|
|
|
|
ro_dev=$(losetup --find --show --read-only "${img}")
|
|
|
|
ro_dev=$(losetup --find --show --read-only "${img}")
|
|
|
|
echo ${ro_dev} >> /run/archiso/used_block_devices
|
|
|
|
echo ${ro_dev} >> /run/archiso/used_block_devices
|
|
|
|
ro_dev_size=$(blockdev --getsz ${ro_dev})
|
|
|
|
ro_dev_size=$(blockdev --getsz ${ro_dev})
|
|
|
|
if [[ "${cowfile_size}" == "100" ]]; then
|
|
|
|
|
|
|
|
rw_dev_size=${ro_dev_size}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
# size calculation done in this way to avoid integer overflow when ro_dev_size is > 10.2G
|
|
|
|
|
|
|
|
rw_dev_size=$((ro_dev_size/100*cowfile_size))
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ "${cow_persistent}" == "P" ]]; then
|
|
|
|
if [[ "${cow_persistent}" == "P" ]]; then
|
|
|
|
if [[ -f "/run/archiso/cowspace/${cow_directory}/${img_name}.cow" ]]; then
|
|
|
|
if [[ -f "/run/archiso/cowspace/${cow_directory}/${img_name}.cow" ]]; then
|
|
|
|
msg ":: Found '/run/archiso/cowspace/${cow_directory}/${img_name}.cow', using as persistent."
|
|
|
|
msg ":: Found '/run/archiso/cowspace/${cow_directory}/${img_name}.cow', using as persistent."
|
|
|
|
else
|
|
|
|
else
|
|
|
|
msg ":: Creating '/run/archiso/cowspace/${cow_directory}/${img_name}.cow' as persistent."
|
|
|
|
msg ":: Creating '/run/archiso/cowspace/${cow_directory}/${img_name}.cow' as persistent."
|
|
|
|
dd of="/run/archiso/cowspace/${cow_directory}/${img_name}.cow" count=0 seek=${rw_dev_size} &> /dev/null
|
|
|
|
truncate -s "${cowfile_size}" "/run/archiso/cowspace/${cow_directory}/${img_name}.cow"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
else
|
|
|
|
if [[ -f "/run/archiso/cowspace/${cow_directory}/${img_name}.cow" ]]; then
|
|
|
|
if [[ -f "/run/archiso/cowspace/${cow_directory}/${img_name}.cow" ]]; then
|
|
|
|
@@ -31,13 +25,13 @@ _mnt_fs() {
|
|
|
|
rm -f "/run/archiso/cowspace/${cow_directory}/${img_name}.cow"
|
|
|
|
rm -f "/run/archiso/cowspace/${cow_directory}/${img_name}.cow"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
msg ":: Creating '/run/archiso/cowspace/${cow_directory}/${img_name}.cow' as non-persistent."
|
|
|
|
msg ":: Creating '/run/archiso/cowspace/${cow_directory}/${img_name}.cow' as non-persistent."
|
|
|
|
dd of="/run/archiso/cowspace/${cow_directory}/${img_name}.cow" count=0 seek=${rw_dev_size} &> /dev/null
|
|
|
|
truncate -s "${cowfile_size}" "/run/archiso/cowspace/${cow_directory}/${img_name}.cow"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
rw_dev=$(losetup --find --show "/run/archiso/cowspace/${cow_directory}/${img_name}.cow")
|
|
|
|
rw_dev=$(losetup --find --show "/run/archiso/cowspace/${cow_directory}/${img_name}.cow")
|
|
|
|
echo ${rw_dev} >> /run/archiso/used_block_devices
|
|
|
|
echo ${rw_dev} >> /run/archiso/used_block_devices
|
|
|
|
|
|
|
|
|
|
|
|
echo "0 ${ro_dev_size} snapshot ${ro_dev} ${rw_dev} ${cow_persistent} 8" | dmsetup create ${dm_snap_name}
|
|
|
|
dmsetup create ${dm_snap_name} --table "0 ${ro_dev_size} snapshot ${ro_dev} ${rw_dev} ${cow_persistent} 8"
|
|
|
|
|
|
|
|
|
|
|
|
_mnt_dev "/dev/mapper/${dm_snap_name}" "${newroot}${mnt}" "-w"
|
|
|
|
_mnt_dev "/dev/mapper/${dm_snap_name}" "${newroot}${mnt}" "-w"
|
|
|
|
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
|
|
|
|
@@ -108,9 +102,7 @@ run_hook() {
|
|
|
|
[[ -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}"
|
|
|
|
if [[ -z "${cowfile_size}" ]]; then
|
|
|
|
if [[ -z "${cowfile_size}" ]]; then
|
|
|
|
cowfile_size="100"
|
|
|
|
cowfile_size="256M"
|
|
|
|
else
|
|
|
|
|
|
|
|
cowfile_size=${cowfile_size/%}
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -n "${cow_label}" ]]; then
|
|
|
|
if [[ -n "${cow_label}" ]]; then
|
|
|
|
@@ -176,7 +168,7 @@ archiso_mount_handler() {
|
|
|
|
|
|
|
|
|
|
|
|
_mnt_sfs "/run/archiso/bootmnt/${archisobasedir}/${arch}/airootfs.sfs" "/run/archiso/sfs/airootfs"
|
|
|
|
_mnt_sfs "/run/archiso/bootmnt/${archisobasedir}/${arch}/airootfs.sfs" "/run/archiso/sfs/airootfs"
|
|
|
|
#_mnt_fs "/run/archiso/sfs/airootfs/airootfs.img" "${newroot}" "/"
|
|
|
|
#_mnt_fs "/run/archiso/sfs/airootfs/airootfs.img" "${newroot}" "/"
|
|
|
|
mount --bind "run/archiso/sfs/airootfs" "/new_root"
|
|
|
|
mount --bind "/run/archiso/sfs/airootfs" "/new_root"
|
|
|
|
|
|
|
|
|
|
|
|
if [[ "${copytoram}" == "y" ]]; then
|
|
|
|
if [[ "${copytoram}" == "y" ]]; then
|
|
|
|
umount /run/archiso/bootmnt
|
|
|
|
umount /run/archiso/bootmnt
|
|
|
|
|