this post was submitted on 22 Aug 2024
548 points (98.8% liked)

Linux

48655 readers
647 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 5 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 56 points 4 months ago (3 children)

This is a regular occurrence and honestly we need to stop recommending dual boot. Use separate drives if you need to, but sharing the same drive is destined to brick something

[–] [email protected] 23 points 4 months ago (2 children)

I literally got this error using a bootable SSD with Ubuntu Mate on it. Separate drives aren't immune to the issue.

[–] [email protected] 14 points 4 months ago (2 children)

I think I've managed to avoid this by making the Linux drive my boot drive and by leaving the Windows drive untouched. (i.e. grub bootloader on the Linux drive, with option to boot to Windows as the second choice)

[–] [email protected] 4 points 4 months ago

I've got the same setup 😎

[–] [email protected] 1 points 4 months ago

same setup, havent had issues so far.

[–] [email protected] 1 points 3 months ago

This isn't true if you have a bootloader on each drive, which, I think, is what the we're talking about.

[–] [email protected] 13 points 4 months ago (3 children)

But having 2 drives does not solve the boot loading issue, I mean, even if you have two drives, you still have only one bootloader, not?

[–] [email protected] 20 points 4 months ago* (last edited 4 months ago) (1 children)

No. You can have more than one EFI system partition with separate bootloaders on each drive and set their boot order in the BIOS, just like booting from USB or anything else.

This is also possible with just one drive. The efi boot entries for each OS are stored separately in the efi system partition.

[–] [email protected] 8 points 4 months ago (1 children)

EFI can also live in firmware memory.

You can pull the linux drive, boot from the windows drive, and if one of the firmware updates was for efi, windows will trash the entry for your Linux disk.

This has happened for me many times, I had to use a grub rescue disk to rebuild the efi table.

[–] [email protected] 1 points 3 months ago* (last edited 3 months ago) (1 children)

The boot entries live in firmware yes, efibootmgr can create and remove them. The are pointers to the bootloader. Many systems can boot from the disk itself without the entry, the entry just makes it pretty (“Fedora” instead of NVME1).

[–] [email protected] 1 points 3 months ago (1 children)

I'm not exactly sure what you're suggesting. Isn't that more or less what I just said?

[–] [email protected] 0 points 3 months ago* (last edited 3 months ago)

Somewhat. One, a system can be bootable without the entries because they are just pointers to the actual bootloader, so even if windows does the stupid and deletes them it isn’t the end of the world. It does depend on your specific firmware though.

Also two, you can write them again with a single line in efibootmgr, they’re just saying “if I click Fedora load the shim from the EFI system partition on disk 1”.

This is very different than the old world where windows would delete your bootloader entirely and the MBR couldn’t be easily explored. They live in the efi system partition instead - or at least the shim does- and typically every OS leaves the other ones alone (even Windows, except in this case, although it didn’t touch the shim itself).

The initial comment was about the bootloader and really only applies to MBR partitions.

[–] [email protected] 10 points 4 months ago (3 children)

even if you have two drives, you still have only one bootloader, not?

The idea is to have completely separate boot and OS drives. You select which one you want to boot through the BIOS boot selection (ie. pressing F10 or F11 at the BIOS screen).

This functionally makes each OS "unaware" of the other one.

[–] [email protected] 5 points 4 months ago (1 children)

Oh you sweet sweet summer boy....

We're talking Microsoft here, they'll make sure they're aware and they'll make sure to f you over because Microsoft

[–] [email protected] 2 points 4 months ago

While I generally agree with that, that's not what seems to be happening here. What seems to be happening is that anyone who boots Windows via grub is getting grub itself overwritten.

When you install Linux, boot loaders like grub generally are smart and try to be helpful by scanning all available OSes and provide a boot menu entry for those. This is generally to help new users who install a dual-boot system and help them not think that "Linux erased Windows" when they see the new grub boot loader.

When you boot Windows from grub, Windows treats the drive with grub (where it booted from) as the boot drive. But if you tell your BIOS to boot the Windows drive, then grub won't be invoked and Windows will boot seeing it's own drive as the boot drive.

This is mostly an assumption as this hasn't happened to me and details are still a bit scarce.

[–] [email protected] 5 points 4 months ago (2 children)

Unfortunately it really doesn’t. And it’s actually Linux that’s the bigger problem: whenever it decides to updates GRUB it looks for OSes on all of your drives to make grub entries for them. It also doesn’t necessarily modify the version of grub on the booted drive.

Yes I’m sure there’s a way to manually configure everything perfectly but my goal is a setup where I don’t have to constantly manually fix things.

[–] [email protected] 2 points 4 months ago

If you install each OS with it's own drive as the boot device, then you won't see this issue.

Unless you boot Windows via the grub boot menu. If you do that then Windows will see that drive as the boot device.

If you select the OS by using the BIOS boot selection then you won't see this issue.

I was bitten by Windows doing exactly this almost 15 years ago. Since that day if I ever had a need for dual-boot (even if running different distros) each OS will get it's own dedicated drive, and I select what I want to boot through the BBS (BIOS Boot Selection). It's usually invoked with F10 or F11 (but could be a different key combo.

[–] [email protected] 2 points 4 months ago

My install does not seem to do this. I removed the windows drive when installing Linux on a new drive. Put both drives in and select which one to boot in the bios. Its been that way for about a year and, so far, grub updates have never noticed the windows install nor added to grub.

That's with bazzite, can't speak for any other distro as that is the only dual-boot machine I own. Bazzite does mention they do not recommend traditional dual boot with the boot loader and recommend the bios method so maybe they have something changed to avoid that?

[–] [email protected] 2 points 4 months ago

I did that and a Windows update nuked Linux from the BIOS boot loader a few weeks ago.

The only safe option is to have completely separate machines. Thankfully with the rise of ridiculously powerful minipcs that's easier than ever.

[–] [email protected] 4 points 4 months ago* (last edited 4 months ago) (1 children)

You can have a own EFI partition per Drive (and on it whatever bootloader you want). You then need to use the UEFI boot menu if you want e.g. boot the Windows one. If you have 2 different OS on different drives they should never interfere with each other.

Well, i mean you could of course use the Linux Bootmanager to then forward to the Windows boot manager on the other disk. but i never experimented with that.

[–] [email protected] 2 points 4 months ago

I just learned that you can do this setup even on one drive alone (having two bootloader on one drive in two partition and choosing in UEFI/Legacy BIOS)

[–] [email protected] 6 points 4 months ago (1 children)

I don't think dual boot has ever been a good solution (unless you also run one or both of the OS's under the other in a VM).

Like, if you are unsure about linux, trying it out, learning, whatever, you can just boot a live"cd", or maybe install it on an external (flash) drive.

If you are kinda sure you want to switch, just nuke Windows; it's easier to switch that way than to have everything on two systems, having to switch.

[–] [email protected] 0 points 4 months ago (1 children)

That is until you want to switch and use mostly linux, but you have friends who want to play one of those few games that only works on windows

[–] [email protected] 2 points 4 months ago (1 children)

The second windows isnt the only option for "all games without any effort", it will be dead.

[–] [email protected] 3 points 4 months ago (2 children)

Well i believe it already is for the majority of games, though I don't game anymore so I don't know, proton wasnt 100% a year or two back

[–] [email protected] 3 points 4 months ago

I've been on Steam+Proton for more than 3 years now. So many many games are now supported. It is usually the DRM kernel anti-cheats that are Windoxez only tend to be the broken ones. I dont buy or care about games that run anti-cheat in Windoze kernel.