If you are not familiar with this kind of setup, it basically works with:
- a non-encrypted /boot with kernel and initramfs
- initramfs contains required modules (aes, lvm, etc.) and a few scripts to mount the filesystem: in this case, a script to ask for the password, decrypt the LVM and mount the root filesystem
The failure comes from the new (11.04) initramfs. Hopefully the upgrade left the previous kernel and initramfs intact, so I could boot on the older one to fix it.
To investigate why it fails to boot with the new initramfs, just compare it with the old one.
Extract initrd images (initramfs format) to current directory:
1 | gzip -d < initrd.img | cpio -i -- make -directories |
1 | find . | cpio -H newc -o | gzip -c -9 > initrd.img |
Recurse diff showed - among other things - a different scripts/local-top/cryptroot. This is an initramfs-tools script from package cryptsetup. Weird, no bug report yet.
A quick solution is to extract new initramfs, replace the new cryptroot script with the old one - extracted from the old initramfs - and repack. A more permanent solution is to copy the old cryptroot script (extracted from the old initramfs or from the old package) to /usr/share/initramfs-tools/scripts/local-top/cryptroot, and generate it again with:
1 | update-initramfs -tuck <target kernel version> |
Anyway, it is always good to know how to work with initramfs images. And they can be fun use, for instance see how SliTaz use it to have a fully featured desktop running in RAM and in less than 30MB (disk, not RAM).
Also, I am sure you know that the kernel can drop you to /bin/sh at the root filesystem init with parameter "init=/bin/sh" (it is a convenient way to reset a root password), but did you know it can do the same with the initrd? "rdinit=/bin/sh" drops you to /bin/sh inside your initramfs.
Thanks google I think I found a solution in your post!
ReplyDeleteI have an encrypted LVM PV and I want to restore an older version of /. I'm sure the system won't boot since the /boot has newer kernel now.
Can you suggest please the steps to fix /boot so that the system would work with older /? I think it is grub-install --boot-directory.... && update-initramfs -tuck ?
Or can I use dpkg-reconfigure ? Do I need to chroot? Thanks!