Description of problem: After an update from 2.06-42 to 2.06-45 I can no longer boot to Windows 11 from grub menu, only the black screen and nothing else. Fedora boots fine. Reverting to 2.06-42 solves the problem. Hardware: Dell G15 5510 laptop, efi. Version-Release number of selected component (if applicable): grub2-efi-x64-2.06-45.fc36.x86_64 How reproducible: always Steps to Reproduce: 1. 2. 3. Actual results: Expected results: Additional info:
Sounds like a Windows bug? What's going wrong?
I have a chainloader in my grub menu: windows boot manager to boot windows 11. Grub.conf is created by grub2-mkconfig. In 2.06-42 selecting windows boot manager boots windows 11 just fine. But in 2.06-45 selecting that entry leads to black screen. The only escape from there is to reset or poweroff. Windows boots normally if selected from bios boot menu or like I said from grub menu with grub2 2.06-42. Only grub2 2.06-45 has trouble with it.
I experience the same thing: Since grub2-common-1:2.06-45.fc36.noarch, Windows doesn't start anymore. Workaround: Use UEFI to directly start Windows instead of Linux/GRUB. (On my laptop: press F9 early on during boot to choose start medium.) The workaround strongly suggests to me that it's a GRUB problem, not a Windows problem. I tried reconfiguring GRUB with `grub2-mkconfig -o /boot/grub2/grub.cfg`: ``` [root]# grub2-mkconfig -o /boot/grub2/grub.cfg Generating grub configuration file ... Found Windows Boot Manager on /dev/nvme0n1p1@/EFI/Microsoft/Boot/bootmgfw.efi Adding boot menu entry for UEFI Firmware Settings ... done ``` Please tell me how I could generate useful information, I have no idea what else to do.
I'm having the same problem after an update from a few days ago. I've had to resort to booting my OS of choice from the UEFI boot menu.
I'm experiencing the same thing on my IdeaPad 330s-15IKB 81F5. I tried reconfiguring GRUB and disabling Secure Boot, but it didn't work. Selecting from UEFI boot menu works. Selecting Windows Boot Manager from GRUB leads to the Lenovo logo without loading anything. Only way to get out is rebooting. Really looks like a bug from the latest GRUB update. Dual booting Windows 11 and Fedora 36 Workstation.
I also have this exact same problem on an HP Elitedesk 800 G3 Desktop Mini dual booting Fedora 36 and Windows 11 since this package was updated. This needs to be addressed ASAP. It is not a Windows problem or an issue with my computer. Booting Windows from GRUB works perfectly fine with the older package version.
I should add that the console command /EndEntire is displayed on the top left corner of a black screen and the boot process is never initiated. Windows cannot boot from GRUB using the newer package.
Same problem here on a Lenovo P1 Gen3. I solved this issue by downgrading GRUB2 to version 2.06-42.
Related comment. I'm running GRUB2 version 2.06-46.fc37. When booting Wndows 10 from the GRUB menu, I see the black screen with /EndEntire, but that screen disappears after a few seconds and Windows 10 boots normally. HP EliteDesk 800 G2 Mini
I ran into the issue yesterday on my ThinkPad P50. It totally broke my Windows install. Even if I booted from my UEFI menu instead of GRUB, Windows would just load to its Automatic Repair option and fail to boot. Ended up having to reinstall both Fedora and Windows to get both OS's to boot again.
Windows goes to automatic repair because of previous failed boot. My system does that too, but just cancel repair, press additional options and select to continue to boot windows. Your system will restart, remember to boot from UEFI menu after that.
Not entirely sure it's related to this BZ specifically, but since this one is about regressions from the new grub; it's entirely broken Fedora CoreOS: https://github.com/coreos/fedora-coreos-tracker/issues/1271
Fedora CoreOS tests runs in VMs with 512MB RAM I recall. I can reproduce that issue with a qemu VM with 512MB RAM. It fails when "Trying to allocate kernel mem" (I can't be certain it's related to this BZ either)
The CI for Fedora CoreOS defaults to VMs with 1G of RAM.
oh really. I have a rawhide VM that upgraded just fine, however if I reduce the memory of the VM it fails (reducing to 800MiB it still works, reducing to 700MiB or below it fails, reproducing the same error seen in the CoreOS build).
out of curiosity, I made a build https://koji.fedoraproject.org/koji/taskinfo?taskID=90523690 without the 0271-efi-make-the-default-arena-most-of-ram.patch and this fixes the issue on my VM (it works fine again with 512MB memory). Also this could be related https://bugs.launchpad.net/snapd/+bug/1897533
It fixes the problem on my system! The command to update to your build was: sudo dnf update https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-2.06-46.fc37.src.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-common-2.06-46.fc37.noarch.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-debuginfo-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-debugsource-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-efi-ia32-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-efi-ia32-cdboot-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-efi-ia32-modules-2.06-46.fc37.noarch.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-efi-x64-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-efi-x64-cdboot-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-efi-x64-modules-2.06-46.fc37.noarch.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-emu-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-emu-debuginfo-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-emu-modules-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-pc-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-pc-modules-2.06-46.fc37.noarch.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-tools-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-tools-debuginfo-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-tools-efi-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-tools-efi-debuginfo-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-tools-extra-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-tools-extra-debuginfo-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-tools-minimal-2.06-46.fc37.x86_64.rpm https://kojipkgs.fedoraproject.org//work/tasks/3690/90523690/grub2-tools-minimal-debuginfo-2.06-46.fc37.x86_64.rpm Is there a better way of applying koji patches?
We seem to be deviating from the original report here. The problem has nothing to do with VMs. The problem that GRUB won't boot Windows anymore.
I can confirm a similar behaviour as comment https://bugzilla.redhat.com/show_bug.cgi?id=2115202#c5 on my Lenovo Ideapad S740-15IRH (16 GB of RAM). After updating to GRUB 2.06-45 I can no longer boot Windows 10 through GRUB. I get stuck on Lenovo boot logo without any loading animation. The only to boot into Windows it to use the UEFI boot menu using F12 key when turning on my laptop. Downgrading to grub2-2.06-42.fc36 or grub2-2.06-43.fc37 ( https://koji.fedoraproject.org/koji/buildinfo?buildID=2004809 ) fixes the problem. Also, I can confirm that the build without the 0271-efi-make-the-default-arena-most-of-ram.patch ( https://koji.fedoraproject.org/koji/taskinfo?taskID=90523690 ) fixes the problem too.
Just in case it helps, the GRUB menu entry looks like this: menuentry 'Windows Boot Manager (on /dev/nvme0n1p1)' --class windows --class os $menuentry_id_option 'osprober-efi-1234-5678' { savedefault insmod part_gpt insmod fat search --no-floppy --fs-uuid --set=root 1234-5678 chainloader /EFI/Microsoft/Boot/bootmgfw.efi }
I hit this issue too via regular F36 updates, using chainload to another grub EFI binary. The chainloaded grub instance fails to then boot Linux, with error message: error: can't allocate kernel. Version 2.06-43 is OK Version 2.06-44 fails Looking at grub-core/kern/efi/mm.c code affected by 0271-efi-make-the-default-arena-most-of-ram.patch, the 3/4 RAM memory allocation is created with b->allocate_pages, and there is no corresponding call to b->free_pages that I can see. Or is that intentional because we'd be freeing the allocation used for the kernel (or chainloaded binary) that we're going to execute?
François' koji packages work perfectly. Thank you! And, thanks to fattony4 for the copy/paste command. I had to disable secure boot checking. I'm assuming the mainstream Fedora stuffs are signed and these may not be. I'll reenable in the fullness of time. Our 2 different Dell G5 laptops suffered from the problem, but our Dell G3 3579 did not, for whatever reason. All firmware should be up to date on them, if that is of any importance.
Proposing as a Prioritized bug and a CommonBug.
Also a blocker for F37: https://fedoraproject.org/wiki/Fedora_37_Final_Release_Criteria#Windows_dual_boot
FEDORA-2022-d0c322d15a has been submitted as an update to Fedora 36. https://bodhi.fedoraproject.org/updates/FEDORA-2022-d0c322d15a
*** Bug 2116032 has been marked as a duplicate of this bug. ***
FEDORA-2022-d0c322d15a has been pushed to the Fedora 36 testing repository. Soon you'll be able to install the update with the following command: `sudo dnf upgrade --enablerepo=updates-testing --refresh --advisory=FEDORA-2022-d0c322d15a` You can provide feedback for this update here: https://bodhi.fedoraproject.org/updates/FEDORA-2022-d0c322d15a See also https://fedoraproject.org/wiki/QA:Updates_Testing for more information on how to test updates.
(In reply to Fedora Update System from comment #27) > FEDORA-2022-d0c322d15a has been pushed to the Fedora 36 testing repository. > Soon you'll be able to install the update with the following command: > `sudo dnf upgrade --enablerepo=updates-testing --refresh > --advisory=FEDORA-2022-d0c322d15a` > You can provide feedback for this update here: > https://bodhi.fedoraproject.org/updates/FEDORA-2022-d0c322d15a > > See also https://fedoraproject.org/wiki/QA:Updates_Testing for more > information on how to test updates. And I just updated. And it indeed fixed the bug! Yay! Thank you, @rharwood!
Update works. Both Fedora 36 and Windows 11 boot fine.
FEDORA-2022-d0c322d15a has been pushed to the Fedora 36 stable repository. If problem still persists, please make note of it in this bug report.
FEDORA-2022-be17145ba6 has been submitted as an update to Fedora 38. https://bodhi.fedoraproject.org/updates/FEDORA-2022-be17145ba6
FEDORA-2022-be17145ba6 has been pushed to the Fedora 38 stable repository. If problem still persists, please make note of it in this bug report.
Sorry, messed up the bug number. Please ignore the above comments.
@
Patch looks good to me, but the code comment is now out of date and still refers to reserving "3/4ths" of available RAM: https://src.fedoraproject.org/rpms/grub2/c/ac27fd45d7a7c718dea64db8ec5e0d9626dda55c?branch=f36 ``` + /* By default, request three quarters of the available memory. */ + total_pages = get_total_pages (filtered_memory_map, desc_size, + filtered_memory_map_end); + - required_pages = (total_pages >> 1) + (total_pages >> 2); + + required_pages = (total_pages >> 1); ```
I upgraded to version 2.06-47.fc36 and it did not fix the problem for me. I wonder what could be the difference with my system. Since this problem is connected with memory allocation, I guess it may be caused by the fact that I have 16 GB of RAM. Does anyone else have 16 GB (or more) RAM and did this fix solved the problem for you? Note that the Koji build without the 0271-efi-make-the-default-arena-most-of-ram.patch ( https://koji.fedoraproject.org/koji/taskinfo?taskID=90523690 ) worked on my system.
Reopening per comment 36. Miroslav, I have 24 GB RAM and grub2-efi-x64-2.06-47.fc36.x86_64 works fine for me, I can boot into Windows when running in UEFI-only mode. (However, I don't know if the previous version was broken on this particular system, I didn't try it at that time).
>I upgraded to version 2.06-47.fc36 and it did not fix the problem for me. I have 16G RAM and grub2-efi-x64-2.06-47.fc36.x86_64, and it's booting Windows 10 OK. Unless Robbie Harwood has another suggestion - I suggest enabling debugging on the chainloader module, it might help him figure out what's going wrong. Edit /boot/grub2/grub.cfg, find the Windows section, add this line after 'insmod fat' and before the chainloader line. debug=chainloader You'll probably get many pages of verbose debug info, since pager=1 by default you'll get a pause, press space bar to get to the next page, you can either take video or photos with a cell phone, but it's... tedious.
Discussed during the 2022-08-22 blocker review meeting: [0] The decision to classify this bug as an "AcceptedBlocker (Final)" was made as it violates the following criterion: "The installer must be able to install into free space alongside an existing clean Windows installation and install a bootloader which can boot into both Windows and Fedora." [0] https://meetbot.fedoraproject.org/fedora-blocker-review/2022-08-22/f37-blocker-review.2022-08-22-16.01.txt
Removing the Prioritized Bugs flag as this is an accepted F37 Final blocker: https://meetbot.fedoraproject.org/fedora-meeting-1/2022-08-24/fedora_prioritized_bugs_and_issues.2022-08-24-14.00.log.html#l-32
grub2-2.06-47.fc36 didn’t fix the problem for me either. I’m running Fedora 36 / Win 11 on a Dell XPS 13 9300 8GB Ram ran “dnf downgrade grub2” and I was downgraded to grub2-2.06-29.fc36. I was able to dual-boot again.
So same question for you then.
Specifically the task in comment 38 (I'm guessing?)
I use Windows mainly for playing games for which I did not have time lately. Sorry for not responding earlier. I used `debug=chain` (`debug=chainloader` did not work) and captured the output. I do not see much difference except of the addresses.
Created attachment 1908410 [details] screenshot of working debug=chain
Created attachment 1908411 [details] screenshot of not working debug=chain
When the chainloader to Windows works the entrypoint address is: 0x24b1bcb0 (ie. ~587 MiB) and when it does not work the entrypoint address is: 0x1b8e8cb0 (ie. ~441 MiB). It's interesting that there is so little difference in the addresses when once it allocates 1/4 of the memory and the other time 3/4. It's only a wild guess but I wonder whether there can be a problem when the chainloader uses addresses under 512 MiB.
I also tried to enable this memory map printing: https://github.com/alexmurray/grub2/blob/4e75b2ae313b13b5bfb54cc5e5c53368d6eb2a08/grub-core/kern/efi/mm.c#L531 if it helps anyhow.
Created attachment 1908426 [details] memory map when working
Created attachment 1908428 [details] memory map when not working
To clarify: - "screenshot of working debug=chain" is done with GRUB v2.06-42 (ie. 1/4 allocation) - "screenshot of not working debug=chain" is done with GRUB v2.06-47 (ie. 1/2 allocation) - "memory map when working" is done with v2.06-47 patched to allocate 1/4 of memory - "memory map when not working" is done with v2.06-47 allocating 1/2 of memory
I still have the same problem with the current version grub2 v2.06-52. Due to holiday, I skipped the previous -45 or -47 packages mentioned above. The solution with 'dnf downgrade grub2-efi' worked for me too, bringing the version to 2.06-29. The laptop (Dell XPS 13 7390 with 16GB RAM and latest BIOS 1.17) runs Fedora 36 and Windows 10.
This is also still a problem on my Lenovo Ideapad S740 15-IRH with 16GB of RAM and latest BIOS. I cannot boot Windows 10 from the GRUB boot menu after updating Fedora 36 (I haven't used this machine in a while, so only caught this bug now.) Downgrading the package fixes the problem, but this is only a temporary failsafe at this point. I don't really understand why the bug is still happening after the supposed fix. I suggest simply reverting whatever behavior code broke the Windows chainloader in the first place. This problem is serious, urgent, and frankly unacceptable, as it affects a variety of machines from different manufacturers and prevents critical booting functionality.
FEDORA-2022-c96e000a12 has been submitted as an update to Fedora 36. https://bodhi.fedoraproject.org/updates/FEDORA-2022-c96e000a12
FEDORA-2022-c96e000a12 has been pushed to the Fedora 36 testing repository. Soon you'll be able to install the update with the following command: `sudo dnf upgrade --enablerepo=updates-testing --refresh --advisory=FEDORA-2022-c96e000a12` You can provide feedback for this update here: https://bodhi.fedoraproject.org/updates/FEDORA-2022-c96e000a12 See also https://fedoraproject.org/wiki/QA:Updates_Testing for more information on how to test updates.
FEDORA-2022-c96e000a12 has been pushed to the Fedora 36 stable repository. If problem still persists, please make note of it in this bug report.
Since this was an accepted blocker, we'll want verification before we close this. Nicholas, Bogdan, Miroslav, David - Can you please tell us whether grub2-2.06-53.fc36 fixes the windows bootloader issue for you? Thanks!
I can confirm that 2.06-53 fixes the problem on F36 for booting Windows 10 with my setup (as in comment #52). I'm not checking 'clear all needinfo requests' as there seemed to be several differences in the other reports. Thanks everybody for your work on this!
I can confirm that 2.06.53 now allows F36 and Windows 11 to boot on my setup (see comment #41). Thanks.
OK, we have confirmation, closing again.
I can also confirm that 2.06-53 fixes the boot problem and allows GRUB to boot Windows 10/11 on my Lenovo laptop with Fedora 36 installed. Thank you for fixing this problem.
The needinfo request[s] on this closed bug have been removed as they have been unresolved for 365 days