I used solution 1: And succeeded. Now, the dracut based imager from Systemimager can install a client and direct boot it without rebooting: http://olivier.lahaye1.free.fr/SystemImager/Videos/20180403_SystemImager_directboot.webm (The disk is initialiser and the OS is installed before swaproot, the a give control back to system which does the swaproot and finishes boot. Requirement: the Systeimager initramfs kernel must have its matching modules on imaged system otherwise it reboots instead of directboot). The magic is in the dracut systemimager module: https://github.com/finley/SystemImager/tree/initrd-from-imageserver-and-dont-package-initrd/lib/dracut/modules.d/51systemimager (it works of all rhel based distro based on dracut including RHEL-6 and SuSE with wicked DHCP instead of ISC and should work on all debian like provided dracut doesn't conflict with initramfstools and provided I rewrite packaging): https://github.com/finley/SystemImager/tree/initrd-from-imageserver-and-dont-package-initrd/initrd_source/skel/etc Source: https://github.com/finley/SystemImager/tree/initrd-from-imageserver-and-dont-package-initrd Packages: http://svn.oscar.openclustergroup.org/repos/unstable/ -- Olivier LAHAYE ________________________________________ De : initramfs-owner@xxxxxxxxxxxxxxx [initramfs-owner@xxxxxxxxxxxxxxx] de la part de LAHAYE Olivier Envoyé : mercredi 28 mars 2018 10:18 À : initramfs@xxxxxxxxxxxxxxx Objet : [PROVENANCE INTERNET] RE: systemimager-dracut: devel help needed (root= known only in initqueue) After digging, I've discovered that systemd-fstab-generator that should generate /run/systemd/generator/sysroot.mount only reads /proc/cmdline (and /etc/fstab and /sysroot/etc/fstab). It seems to ignore env($root) or /etc/cmdline.d/whatever_that_defines_root.conf Thus, I assume that: 1/ /dracut-state.conf is USELESS in that matter 2/ /etc/cmdline.d/<whatever_defines_root=>.conf is USELESS in that matter => Then what is the propper way to have filesystem correctly mounted? solution 1: mount /sysroot only in pre-mount hook? (and have the fstab generator read /sysroot/etc/fstab? solution 2: write a systemimager-sysroot-generator and trigger it with systemctl daemon-reload? solution 3: something I'm missing? Thanks for any advise on how to behave cleanely in having /sysroot correctly mounted . -- Olivier LAHAYE ________________________________________ De : initramfs-owner@xxxxxxxxxxxxxxx [initramfs-owner@xxxxxxxxxxxxxxx] de la part de LAHAYE Olivier Envoyé : mardi 27 mars 2018 11:40 À : initramfs@xxxxxxxxxxxxxxx Objet : [PROVENANCE INTERNET] systemimager-dracut: devel help needed (root= known only in initqueue) Sorry for initial long post, but this is worth reading :) Hi, I'm main active developper for systemimager (http://www.systemimager.org), a software that automates image deployments on cluster nodes that was initially developped by Brian Elliott Finley. The imager consist of an initramf that initialise the disk, download the image and runs post installs. The historic initramfs was build from scratch including kernel and was extremely hard to maintain. I rewrote the whole stuff using dracut which is the perfect tool for that. (https://github.com/finley/SystemImager/tree/initrd-from-imageserver-and-dont-package-initrd) For that I wrote a somewhat complex (but easy to maintain) dracut module: https://github.com/finley/SystemImager/tree/initrd-from-imageserver-and-dont-package-initrd/lib/dracut/modules.d/51systemimager This works perfectly, but I want to go BEYOND a reboot after imaging. I want, after imaging, to finish booting as normal boot (imaging is finnished in initqueue hook) if imager kernel has matching modules in imaged system. My PROBLEM IS: /sysroot is not automatically mounted and I'm trying to have it mounted without doing ugly hacks. How I proceed: (CentOS7, fedora-27, Open SuSE 42.3 (and in another form CentOS-6)) 1/ in cmdline, I set root='UNSET' and rootok=1 => It ends in /dracut-state.sh and cmdline hook is happy 2/ in initqueue/online, I retrieve disk layout, image name, ... and using that I initialise the disk(s), raid if any, lvm if any and I install the image, configure bootloader, and runs some chrooted postinstall 3/ in initqueue/online (at the end, I umount all filesystems) and update /dracut-state.sh with root=block:/the/correct/root/device => is overridden with "none" between initqueue and pre-mount hooks ???? WHY? WHERE? => So I save it in /etc/cmdline.d/systemimager-rootfs.conf (rootfs-generator ignores /dracut-state.sh and uses getarg) 4/ in initqueue/finished (/sysroot is empty), I run systemctl daemon-reload to triggger dracut-rootfs-generator. => devexists-\x2fdev\x2fsystemvg\x2frootlv.sh is generated correctly BUT, sysroot.mount is not generated anywhere (neither in /etc/systemd/system, nor in /lib/systemd/system) QUESTION 1: what am I missing to have sysroot.mount be created AND mounted. QUESTION 2: why /dracut-state.sh is overwritten between initqueue/finished and pre-mount hooks and why is it not used by dracut-rootfs-generator? QUESTION 3: On CentOS-6 I use /tmp/root.info, how to I get the rootfs mounted without systemd? should I only settle udev? Many thanks for any tips. -- Olivier LAHAYE -- To unsubscribe from this list: send the line "unsubscribe initramfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe initramfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html