casper toram forgets to disconnect loop device

Bug #684280 reported by komputes
134
This bug affects 31 people
Affects Status Importance Assigned to Milestone
Baltix
Invalid
Undecided
Unassigned
casper (Ubuntu)
Triaged
Medium
Unassigned

Bug Description

Binary package hint: ubiquity

Ubiquity cannot install if you are booting LiveCD directly from ISO.

Booting directly from GRUB to the ISO, mounts the ISO to /isodevice.

Ubiquity will not install (even if on separate disk) if this is not unmounted.

The result being that one cannot install Ubuntu in this method.

This method can be used to create a recovery partition or a multi-usb bootable drive. For more explanation on how to do this:

========== START ==========

    * Run the following commands which will create the directory /boot/iso and download the iso file to that directory.

$ sudo -s
# mkdir /boot/iso
# cd /boot/iso
# wget http://releases.ubuntu.com/maverick/ubuntu-10.10-desktop-i386.iso

    * Add a custom menu entry in GRUB2 configuration file. Edit /etc/grub.d/40_custom as root to look like this:

#!/bin/sh
echo "Adding 40_custom." >&2
exec tail -n +3 $0

menuentry "Maverick CD Image ISO" {
set isofile=/boot/iso/ubuntu-10.10-desktop-i386.iso
loopback loop (hd0,1)$isofile
linux (loop)/casper/vmlinuz boot=casper iso-scan/filename=$isofile noprompt noeject
initrd (loop)/casper/initrd.lz
}

    * Afterwards, run update-grub for the changes to be propagated to /boot/grub/grub.cfg

# update-grub
Generating grub.cfg ...
Found linux image: /boot/vmlinuz-...
Found initrd image: /boot/initrd.img-...

========== STOP ==========

================== Workaround =================

After casper copy to ram , it need to disconnect the loop device and unmount

losetup -d /dev/loop0
umount /isodevice

===========================================

The result of booting from the ISO directly from GRUB, is that the CD is that the partition where the ISO is located is mounted to /isodevice.

Ubiquity seems to want to have control of all disks and unmount all disks before it starts installing. In the images here you see the example is sda2 for / and sda for the MBR. I have also tried this with a secondary disk where sdb1 was to be used for / and sdb for the MBR and ubiquity still complained that it had to to unmount /isodevice, even though it is on sda1. Doesn't make much sense to unmount a disk if you will not be editing any part of it.

ProblemType: Bug
DistroRelease: Ubuntu 10.10
Package: ubiquity 2.4.8
ProcVersionSignature: Ubuntu 2.6.35-22.33-generic 2.6.35.4
Uname: Linux 2.6.35-22-generic i686
NonfreeKernelModules: wl
Architecture: i386
Date: Thu Dec 2 16:34:42 2010
LiveMediaBuild: Ubuntu 10.10 "Maverick Meerkat" - Release i386 (20101007)
ProcEnviron:
 LANG=en_US.UTF-8
 SHELL=/bin/bash
SourcePackage: ubiquity

Related branches

Revision history for this message
komputes (komputes) wrote :
Revision history for this message
komputes (komputes) wrote :
Revision history for this message
komputes (komputes) wrote :
Revision history for this message
komputes (komputes) wrote :
Revision history for this message
komputes (komputes) wrote :
Revision history for this message
komputes (komputes) wrote :
Revision history for this message
komputes (komputes) wrote :
komputes (komputes)
description: updated
description: updated
Revision history for this message
Evan (ev) wrote :

You need to preseed the following:

d-i partman/filter_mounted boolean false
d-i ubiquity/partman-skip-unmount boolean true

Changed in ubiquity (Ubuntu):
status: New → Invalid
Revision history for this message
komputes (komputes) wrote :

How can one preseed d-i values on a LiveCD with ubiquity? Can you please provide instructions and I will test and get back to you.

Changed in ubiquity (Ubuntu):
status: Invalid → New
tags: added: ubiquity-2.4.8
Revision history for this message
komputes (komputes) wrote :

This no longer affects me with the latest version.

Changed in baltix:
status: New → Invalid
Changed in ubiquity (Ubuntu):
status: New → Invalid
Revision history for this message
Krainov Lev (lev-krainov) wrote :

reproduced in kubuntu-11.10-desktop-amd64.iso , workaround with exit 0 in /lib/partman/commit.d/01unmount_busy solved the problem

Revision history for this message
user (meta1729-deactivatedaccount) wrote :

Present in xubuntu-14.04-desktop-i386.iso. The installer says it needs to unmount /isodevice even if NO partition changes (create/delete/resize) are requested. All that is requested is formatting of other partition as ext4.

Please reopen this bug.

Revision history for this message
experimancer (experimancer) wrote :

Still present in ubuntu-14.04-desktop iso, booted from grub2.

No way to continue with installation cause "/isodevice cannot be unmounted" (the operation of which is not even needed).

Not "invalid" or "fixed" not even in any of this bugs duplicates.

Wonder why this has ever been closed, even if it has been around for atleast 4 years in each and every Ubunut installatiion .iso image.?

The quality of Ubuntu distributions is getting worse and worse every year.. And seems that rven this severe installation bugs are not fixed :(

tags: added: installer ubuntu-14.04
Revision history for this message
experimancer (experimancer) wrote :

Fix is actully here: https://help.ubuntu.com/community/Grub2/ISOBoot (i.e add "toram" to relevant Grub2 menuentry or manually umount the /isodevice with "sudo umount -lrf /isodevice" and re-start the installation.

Changed in ubiquity (Ubuntu):
status: Invalid → New
no longer affects: ubiquity
Revision history for this message
Launchpad Janitor (janitor) wrote :

Status changed to 'Confirmed' because the bug affects multiple users.

Changed in ubiquity (Ubuntu):
status: New → Confirmed
Revision history for this message
gregrwm (gregrwm) wrote :

confirmed that the 'umount -lrf /isodevice' workaround works on the bionic iso of 2018/2/8. i didn't even use 'toram'.

everyone expects they need either burn a cd, use a thumb or external drive, or use another installer, eg mini.iso. with this workaround, or better yet if this bug gets fixed, none of those are necessary.

Revision history for this message
Phillip Susi (psusi) wrote :

Looks like after casper copies the squashfs to ram, it forgets to disconnect the loop device. The workaround is to run losetup -d /dev/loop0 and umount /isodevice.

affects: ubiquity (Ubuntu) → casper (Ubuntu)
Changed in casper (Ubuntu):
importance: Undecided → Medium
status: Confirmed → Triaged
summary: - Ubiquity cannot install if you are booting LiveCD directly from ISO
+ casper toram forgets to disconnect loop device
Revision history for this message
Daniel Richard G. (skunk) wrote :

Philip Susi: Confirmed with the Bionic live CD:

root@xubuntu:~# cat /proc/cmdline
BOOT_IMAGE=(loop)/casper/vmlinuz boot=casper iso-scan/filename=/linux/xubuntu-18.04-desktop-amd64.iso toram

root@xubuntu:~# umount /isodevice
umount: /isodevice: target is busy.

root@xubuntu:~# losetup -d /dev/loop0

root@xubuntu:~# umount /isodevice
(succeeds)

However, I did not observe the issue as originally reported; Ubiquity was able to install the system even with /isodevice mounted and unable to be unmounted. (In my case, the ISO file was on a USB thumbdrive, and I installed to a hard drive.)

Revision history for this message
Phillip Susi (psusi) wrote :

Yes; the install only fails if the iso file is on your hard disk.

Revision history for this message
Filip (fspacek) wrote :

Here's a patch for casper to delete the loopback after copying:

diff --git a/scripts/casper b/scripts/casper
index 5861ced..fa06c0d 100644
--- a/scripts/casper
+++ b/scripts/casper
@@ -191,7 +191,7 @@ copy_live_to() {
     if [ -e ${copyfrom}/.disk ]; then
         cp -a ${copyfrom}/.disk ${copyto}
     fi
- umount ${copyfrom}
+ umount -d ${copyfrom}
     mount -r -o move ${copyto} ${copyfrom}
     rmdir ${copyto}
     return 0

Revision history for this message
Charles Wilkins (cg-chas) wrote :

Regarding comment #20, 2019-10-03,

I tried this patch and umount -d ${copyfrom} seems like it should unmount the loopback device, but it does not.

Yet this works:

root@xubuntu:~# losetup -d /dev/loop0
root@xubuntu:~# umount /isodevice

I am still looking that this, but was curious if anybody else is experiencing the same issue when booting a recent live iso from disk.

Revision history for this message
Charles Wilkins (cg-chas) wrote :

I tried explicitly using losetup -d /dev/loop0 right before umount ${copyfrom} in the casper script and it did not work. losetup -d /dev/loop0 and umount /isodevice does work out of rc.local just fyi.

tags: added: bionic focal
removed: maverick
description: updated
Revision history for this message
Michel-Ekimia (michel.ekimia) wrote :
Revision history for this message
Michel-Ekimia (michel.ekimia) wrote :

Even better option of umount : -d ( detach loop devices )

So sudo umount -lfd /isodevice

should be the way.

description: updated
Revision history for this message
Michel-Ekimia (michel.ekimia) wrote :

Any update on this small but big win fix ?

Revision history for this message
Michel-Ekimia (michel.ekimia) wrote :

Still on 20.04.1 ...

Revision history for this message
Michel-Ekimia (michel.ekimia) wrote :

Just an Update : umount -lfd was not enough

So I'm trying to embed a startup script in a Live custom ISO :

losetup -d /dev/loop0
umount -lfd /isodevice

And it works

description: updated
description: updated
Revision history for this message
Jerzy Luszawski (dr-agon) wrote :

When booting Kubuntu 20.04.1 (LTS) iso the workaround of detaching /dev/loop0 device and then unmounting /isodevice was required, as in comment #27. Then setup finished.

Revision history for this message
Paul W (ponggone) wrote (last edit ):

Issue is still occurring on ubuntu-20.04.3-live-server-amd64.

Unfortunately having difficulty unmounting the iso file with the following two commands,

losetup -d /dev/loop0
umount /isodevice

UPDATE: Specific issue related to the Dell Optiplex 5080 unit I was using
https://askubuntu.com/questions/1377159/ubuntu-server-20-04-3-setup-stuck-at-block-probing-did-not-discover-any-disks/1377260#1377260

Revision history for this message
Martin Laclaustra (martin-laclaustra) wrote :

This issue got worse because casper-lupin functionality was incompletely ported into casper itself.

I wrote a patch that ubuntu developers will need to add in order to get back at the point that this issue describes. The patch is here:
https://bugs.launchpad.net/ubuntu/+source/lupin/+bug/1960457/comments/34

Revision history for this message
Martin Laclaustra (martin-laclaustra) wrote :

Disconnecting the loop device may not always be desired after using "toram": See https://bugs.launchpad.net/ubuntu/+source/lupin/+bug/1960457/comments/33

Thus, it may be advisable to ask for that explicitly. I propose using "detach". So the system should be booted with "toram detach".

Solving this problem requires less than 10 lines. I hope that developers can add the patch below.

For this patch to work it is necessary to fix the issue mentioned previously beforehand: https://bugs.launchpad.net/ubuntu/+source/lupin/+bug/1960457/comments/34 first (4 lines)

Here is the patch:

--- scripts/casper_1477
+++ scripts/casper
@@ -75,6 +75,8 @@
                 export TORAM="Yes" ;;
             todisk=*)
                 export TODISK="${x#todisk=}" ;;
+ detach)
+ export DETACH="Yes" ;;
             hostname=*)
                 export CMD_HOST="${x#hostname=}" ;;
             userfullname=*)
@@ -1042,6 +1044,13 @@
     run_scripts /scripts/casper-bottom
     [ "$quiet" != "y" ] && log_end_msg

+ if [ "${live_dest}" ] && [ -z "$PERSISTENT" ] && [ "$DETACH" ]; then
+ if grep -q '^[^ ]* /root/isodevice ' /proc/mounts; then
+ losetup -d /dev/loop0
+ umount /root/isodevice
+ fi
+ fi
+
     # Close the fd's associated with debconf-communicate.
     exec 3>&- 4<&-
     rm -f /tmp/debconf-in.fifo

There are other options for implementing this, for example:
a) detaching as the default behavior and allowing for a "nodetach" argument in cmdline
b) removing "/root" from the patch (in the 2 lines where it appears), will make this work without fixing https://bugs.launchpad.net/ubuntu/+source/lupin/+bug/1960457/comments/34 first.

Revision history for this message
Glenn Washburn (crass) wrote :

> Disconnecting the loop device may not always be desired after using "toram": See https://bugs.launchpad.net/ubuntu/+source/lupin/+bug/1960457/comments/33

That comment was very likely not in the context of "toram" usage. That users requirements appear to be iso loopback loading access to /isodevice from the overlay root.

I prefer a nodetach option as I think the expected use case (or maybe just mine) for toram is to remove the usb device on which resides the loopback loaded iso so that the device can be used elsewhere while the live cd is running.

Revision history for this message
scmarko (scmarko) wrote (last edit ):

This should be fixed, because when you boot an ISO file from your hard drive and load Ubuntu to RAM, you are not able to do any repartitioning, installing etc to the hard drive from where the ISO was loaded from when it stays mounted. I have tested this on a Ubuntu installation with LVM hard drive and once I applied the changes to the initrd file of the Ubuntu ISO, then I was able to successfully run the following commands:

losetup -d /dev/loop0
umount /isodevice

After that I was able to repartition the hard drive and install Ubuntu from RAM to hard drive. But this adds too much complexity to the end user if needing to unpack the ISO file and then modify initrd if needing to use Ubuntu like this.

To post a comment you must log in.
This report contains Public information  
Everyone can see this information.

Other bug subscribers

Remote bug watches

Bug watches keep track of this bug in other bug trackers.