> This was caused by installing Debian, then restoring a full backup from the old laptop, which didn't use EFI yet, over the root filesystem.
This really isn't guaranteed to work. I'm surprised nothing else broke! This is why my laptop migration process looks something more like this:
1. Restore home directory 2. Restore /etc (taking care not to overwrite anything hardware-specific) 3. Install the same list of packages that were installed on old machine
I've done it recently on my work laptop. Some notes for whoever walks this path.
I'd add /opt to that list, where I install non-apt software .e.g. Jetbrains, Joplin, eclipse, ...
Some stuff under $HOME breaks even if it shouldn't. firefox got an upgrade from LTS to mozilla, and refused to pickup or even import its profile and passwords. libreoffice never got past the splash screen . The corporate VPN tool just completely broke for no apparant reason. Deleting and rewriting all their .config 'fixed' it. Also, .cache was not copied over.
I started maintaining an ansible script to manage my laptop, but that was more to learn ansible. Even so, it did well rebuilding /etc. I have a copy but don't seem to need it..
I look at utmp to book my work hours, so I had to guestimate failover day. A next upgrade will copy it too.
Renaming the home directory due to sssd broke a lot of paths that really should have been relative to ~. I made a symlink from my old home as lazy workaround.
All in all, I was back running fast, but mainly because everything was scripted or in a decent location. My days of perfectly tuning every nook and cranny are long past.
Also I should clarify that I'm not trying to say this is your fault. But I also understand why the maintainers acted the way they did. I think it's not unreasonable to expect that a configuration change distributed as part of a new version of a program won't be installed by itself.
These days any changes going into /etc or really anywhere which is not my home directory are done via an Ansible playbook for me. If it's too complicated to script like that (which is not complicated at all) then it is absolutely too complicated to remember I did it or why.
Nothing's guaranteed, but it is good when an OS which is properly installed to be bootable by BIOS, behaves like it should and will naturally also be bootable by UEFI according to what the firmware finds in an accessible EFI folder somewhere.
Or if nothing else what you can type in on the UEFI shell.
One of the inconsistencies I see between different distributions is the location of the full set of Grub boot files.
Sometimes the EFI (Fat32) partition will only contain the minimal handful of files barely needed to boot, with the remaining bulk of the files still needed to follow through, plus service & update Grub, residing on the EXTx volume. This is descended from the legacy way of having Grub2's "barely needed" boot code reside in a small number of traditional boot sectors (back before UEFI displaced MBR), while the remaining bulk of Grub was similarly in files & folders in the main Linux EXTx volume. In these cases a grub.cfg file may exist in both the fat32 EFI as well as within the EXTx fileset. And they will often, if not usually, be different.
Experience has shown this to be nonideal compared to the established alternative:
Other distros will have the full config and service files & folders, including initrd & vmlinuz, right there on the EFI volume in the distro's own designated folder.
This is really the way it should be going forward. With UEFI now standardized at having a required fat32 boot volume, the more complete boot files finally have the perfect place they have been needing since the BIOS days.
Now the distros that already have this are actually compatible with what they had in the past because once booted they find Grub on the EFI partitiion and mount the working Grub folders virtually on the EXTx filesystem into their previously expected locations.
That way either alternative for the physical location of Grub support files in common use today is intended to be handled by the same grub service & update scripts.
So it is no longer as sensible to have any of the Grub support files on the EXTx volume at all, or the performance is poorer than Windows.
Since today's Windows NT6 takes full advantage of the dedicated EFI partition, so its boot files in \EFI\Microsoft are more-than-complete as needed. That way you can change everything on the NTFS volume alone and it changes nothing about NT6 booting whatsoever.
IOW with Windows you can format and recover your NTFS volume alone, choosing from any number of backup dates, without touching the EFI volume at all. This quite reliably boots the Windows that it finds on your main NTFS volume, regardless if is actually the same version or year as the NT6 bootfiles.
The possibility of equivalent Linux backup/recovery workflow is broken when Grub is not physically stored on the EFI partition, which is the kind of thing that particular partition is there for to begin with.
Recovery may never be fast, but even with some bloat it's not so slow any more either.
What's really good is having better confidence than ever that Windows will immediately boot the first time after full recovery, with no further ado, delays, or grub-installs. And no further Windows "installs" either. Yikes, let's be honest. The Windows installation process writes an appropriate EFI folder when there's nothing on your SSD at all. It may or may not be your friend at other times. Especially if you dual boot, the UEFI default-generically-named \EFI\boot\bootx64.efi file is actually OS-specific so whatever OS you install the most recently is the one that puts its own version of this file into the \EFI\boot folder, overwriting whatever the previous one was.
Once you've got a reliable EFI whether you are multibooting or not, it's nice not to need any more attention over the long run. The \EFI\ folder is made to be shared by \EFI\Microsoft, \EFI\fedora, \EFI\debian, etc.
Those OS's that have enough of their bootloader files physically located on the EFI volume can have those files updated independently from any respective OS or OS updates.
This can increase the chances that it will go well, and definitely make it easier to recover in case there is a breaking change like the author had.
Edit: Also forgot to add, without much trouble you can back up the full EFI folder from either Linux or Windows, but not very helpful if parts of Grub are also on EXTx. The distros having Grub on EXTx are also scattered in more than one folder. Which is one reason I don't think many people have gotten in the habit of backing them up.
There is rarely a need for GRUB on EFI systems. Create a unified kernel image, create a fat fs gpt partition, mount on /boot/efi and put the image there, then add it to efibootmgr. Sign and use systemd-stub and Shim for Secure Boot. No GRUB, no systemd-boot, just EFI firmware -> initrd -> kernel. Tried and tested on Debian 12 and Trixie. Can also dual boot Windows if the machine has a way to select an OS on boot, something most systems have these days.
I think the work required to do the above vs just using the standard installer is what holds people back, but it's hard to mess up once it's done.
Wasn't the 500 mile email [1] caused by something similar, i.e. software loading a config file made for a newer version loading it and behaving in an undesirable fashion?
> One of the settings that was set to zero was the timeout to connect to the
remote SMTP server. Some experimentation established that on this
particular machine with its typical load, a zero timeout would abort a
connect call in slightly over three milliseconds.
In the early days of UEFI being on PCs, I had to coach a TON of IT admins on the changes that were happening. Lots of them assumed that if you just dunked a drive image onto a machine, it would Just Work:tm: without having to add anything into the boot menu or other such things.
Watching Norton Ghost from 2002 run on a brand new Skylake laptop was something else. Ghost still doesn't support EFI systems properly, but EFI systems became a lot less hardass about their boot menus after a while.
I hit something similar recently, after installing Debian 12.8 (I think it was 12.8) on my wife's computer, where another Linux version was already installed.
I didn't find the root cause. I know it's a system on which SecureBoot used to be on and was working fine (with an older Debian version). Anyway after installing Debian 12.8, somehow I ended up at that infamous GRUB boot prompt, unable to boot the system.
I "fixed" it by disabling SecureBoot from the UEFI: not my proudest fix but I didn't feel like troubleshooting what had gone wrong (which was certainly simple and dumb). So Kudos to TFA's author for spending the time to troubleshoot and solve a much more complicated issue.
This reminds me of why Firefox now refuses to load profiles previously used on newer versions of itself: it's generally unreasonable for older versions of programs to correctly support configuration data from newer versions of them.
I had a different GRUB2 upgrade breakage a couple years ago. Mine related to a hybrid ISO/MBR disk (extremely common for distro install disks); previously grub had silently just used the obvious partition table, but the new grub insisted on erroring out due to ambiguity. I had to do some really hairy "dd to back up the MBR; wipefs; dd to restore the MBR" to get a working system again; luckily I didn't lose power.
(note that many distros normally don't upgrade grub after the first install to avoid exactly this kind of breakage, but there was some "important security crap" at the time)
I don't use UEFI often. Last night after installing a new kernel, I noticed that updating-grub failed to add that kernel to (either of 2) GRUB bootlists. After consulting a Boot-Repair report, I found that deleting a partition on another drive flagged as 'boot,esp' resolved that problem. Moral: 1) don't leave skeletons in closets.
This really isn't guaranteed to work. I'm surprised nothing else broke! This is why my laptop migration process looks something more like this:
1. Restore home directory 2. Restore /etc (taking care not to overwrite anything hardware-specific) 3. Install the same list of packages that were installed on old machine