* repair broken boot record
@ 2021-09-30 7:43 Thomas Danckaert
2021-10-01 6:53 ` pelzflorian (Florian Pelz)
0 siblings, 1 reply; 8+ messages in thread
From: Thomas Danckaert @ 2021-09-30 7:43 UTC (permalink / raw)
To: help-guix
Hello guix-help,
my system does not boot anymore after a guix pull and system reconfigure
(which did show a warning, see below). It does not even enter the GRUB
stage, I get a "Reboot and Select proper Boot device" instead. I think
the MBR might not have been written correctly (just a hunch, I'm no
expert...).
During reconfigure, I did get a warning that my bootloader configuration
used 'target', which is apparently deprecated in favor of 'targets'. I
wasn't paying too much attention, and ignored the warning.... I don't
know if that could be the cause of a missing or incorrect boot record?
(In that case, I suggest this warning should be an ERROR ;-) )
I checked using a live USB, and it seems the whole system is still there
on the hard drive. Is there a way to restore my system, keeping the
existing /gnu/store? Or do I have to reinstall from scratch, remove the
existing /gnu/store and rebuild everything (shouldn't be too much work
using Guix, but way less elegant :) )
Thank you!
Thomas
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: repair broken boot record
2021-09-30 7:43 repair broken boot record Thomas Danckaert
@ 2021-10-01 6:53 ` pelzflorian (Florian Pelz)
2021-10-05 9:28 ` Thomas Danckaert
0 siblings, 1 reply; 8+ messages in thread
From: pelzflorian (Florian Pelz) @ 2021-10-01 6:53 UTC (permalink / raw)
To: Thomas Danckaert; +Cc: help-guix
On Thu, Sep 30, 2021 at 09:43:18AM +0200, Thomas Danckaert wrote:
> Hello guix-help,
>
> my system does not boot anymore after a guix pull and system reconfigure
> (which did show a warning, see below). It does not even enter the GRUB
> stage, I get a "Reboot and Select proper Boot device" instead. I think the
> MBR might not have been written correctly (just a hunch, I'm no expert...).
If this system uses no old grub-bootloader but instead EFI
(grub-efi-bootloader), maybe writing the bootloader to the mainboard
failed (it is not only written to disk), perhaps because the mainboard
NVRAM is full and needs to be cleaned with efibootmgr/efivar/such
utilities.
> During reconfigure, I did get a warning that my bootloader configuration
> used 'target', which is apparently deprecated in favor of 'targets'. I
> wasn't paying too much attention, and ignored the warning.... I don't know
> if that could be the cause of a missing or incorrect boot record? (In that
> case, I suggest this warning should be an ERROR ;-) )
No, the old target would fall back to targets. The warning is only a
warning that you should switch to (targets (list "…")).
> I checked using a live USB, and it seems the whole system is still there on
> the hard drive. Is there a way to restore my system, keeping the existing
> /gnu/store? Or do I have to reinstall from scratch, remove the existing
> /gnu/store and rebuild everything (shouldn't be too much work using Guix,
> but way less elegant :) )
>
> Thank you!
>
> Thomas
I search on Duckduckgo for “site:lists.gnu.org guix chroot”, you
should read there how to chroot into your system so you can
reconfigure.
Regards,
Florian
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: repair broken boot record
2021-10-01 6:53 ` pelzflorian (Florian Pelz)
@ 2021-10-05 9:28 ` Thomas Danckaert
2021-10-05 11:04 ` pelzflorian (Florian Pelz)
0 siblings, 1 reply; 8+ messages in thread
From: Thomas Danckaert @ 2021-10-05 9:28 UTC (permalink / raw)
To: pelzflorian (Florian Pelz); +Cc: help-guix
Hello Florian,
thank you for your help. I managed to chroot into my system, and re-run
'guix system reconfigure' (very useful mailing list discussion on
chrooting, I also vote for including it in documentation :) ). In one
of the final steps, where guix tries to install the bootloader, I get
the error:
/gnu/store/.../grub/i386-pc/modinfo.sh doesn't exist. Please specify
--target or --directory.
Indeed my system uses grub-efi. Could that be related? Can you point
me to some specific instructions on how to check/solve efivar issues?
Not sure if I need grub-efi, or if it might also work using grub-pc.
Until now I've always used grub-efi.
(Another thing I noticed (maybe a side effect of chroot?): when I re-run
'guix system reconfigure' it tries to rebuild derivations that are
already there in the store from last time, I think.)
thank you!
Thomas
On 2021-10-01 08:53, pelzflorian (Florian Pelz) wrote:
> On Thu, Sep 30, 2021 at 09:43:18AM +0200, Thomas Danckaert wrote:
>> Hello guix-help,
>>
>> my system does not boot anymore after a guix pull and system
>> reconfigure
>> (which did show a warning, see below). It does not even enter the
>> GRUB
>> stage, I get a "Reboot and Select proper Boot device" instead. I
>> think the
>> MBR might not have been written correctly (just a hunch, I'm no
>> expert...).
>
> If this system uses no old grub-bootloader but instead EFI
> (grub-efi-bootloader), maybe writing the bootloader to the mainboard
> failed (it is not only written to disk), perhaps because the mainboard
> NVRAM is full and needs to be cleaned with efibootmgr/efivar/such
> utilities.
>
>
>> During reconfigure, I did get a warning that my bootloader
>> configuration
>> used 'target', which is apparently deprecated in favor of 'targets'.
>> I
>> wasn't paying too much attention, and ignored the warning.... I don't
>> know
>> if that could be the cause of a missing or incorrect boot record? (In
>> that
>> case, I suggest this warning should be an ERROR ;-) )
>
> No, the old target would fall back to targets. The warning is only a
> warning that you should switch to (targets (list "…")).
>
>
>
>> I checked using a live USB, and it seems the whole system is still
>> there on
>> the hard drive. Is there a way to restore my system, keeping the
>> existing
>> /gnu/store? Or do I have to reinstall from scratch, remove the
>> existing
>> /gnu/store and rebuild everything (shouldn't be too much work using
>> Guix,
>> but way less elegant :) )
>>
>> Thank you!
>>
>> Thomas
>
> I search on Duckduckgo for “site:lists.gnu.org guix chroot”, you
> should read there how to chroot into your system so you can
> reconfigure.
>
> Regards,
> Florian
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: repair broken boot record
2021-10-05 9:28 ` Thomas Danckaert
@ 2021-10-05 11:04 ` pelzflorian (Florian Pelz)
2021-10-06 8:23 ` Thomas Danckaert
0 siblings, 1 reply; 8+ messages in thread
From: pelzflorian (Florian Pelz) @ 2021-10-05 11:04 UTC (permalink / raw)
To: Thomas Danckaert; +Cc: help-guix
On Tue, Oct 05, 2021 at 11:28:50AM +0200, Thomas Danckaert wrote:
> Hello Florian,
>
> thank you for your help. I managed to chroot into my system, and re-run
> 'guix system reconfigure' (very useful mailing list discussion on chrooting,
> I also vote for including it in documentation :) ).
I’m glad it helped so far, although I don’t know all the details about
chroot nor EFI. (For example which directories from the live system
should be mounted in the chroot and why.) So I won’t attempt to write
documentation.
> In one of the final
> steps, where guix tries to install the bootloader, I get the error:
>
> /gnu/store/.../grub/i386-pc/modinfo.sh doesn't exist. Please specify
> --target or --directory.
This is strange. When you reconfigure, Guix should print the
grub-install command that was used, which should include both --target
and --directory.
However, perhaps the chroot is at fault: Before chrooting to, let’s
say, /mnt with chroot /mnt, you need to have mounted the /dev/sdXy
file system with EFI on it (that which is declared in your config.scm)
to /mnt/boot/efi.
What I write below you will probably not need; you can ignore it if
the above works:
> Indeed my system uses grub-efi. Could that be related? Can you point me to
> some specific instructions on how to check/solve efivar issues?
If you have made available efivar (by installing it or by `guix
environment --ad-hoc efivar` or similar), and if you have booted from
an EFI bootloader, then you can run `efivar -l` to see all variables
stored on your motherboard/mainboard. The motherboard NVRAM can
become full. However I’m not sure how to delete such variables; I
think the program efibootmgr can do it. Hopefully and likely it will
not be necessary.
> Not sure if I need grub-efi, or if it might also work using grub-pc. Until
> now I've always used grub-efi.
Some systems need EFI (and others don’t work with EFI). It is
probably better to stick with EFI.
> (Another thing I noticed (maybe a side effect of chroot?): when I re-run
> 'guix system reconfigure' it tries to rebuild derivations that are already
> there in the store from last time, I think.)
Maybe they just have the same package name but are different versions,
so a rebuild is necessary. But maybe also the running guix-daemon is
the one from the live USB and not from the installed system.
guix-daemon stores information about what is installed in a sqlite
database. Now I wonder if the chroot can make changes to the wrong
database and interfere with the already installed guix-daemon, making
the store inconsistent. Anyway, this should not cause trouble with
reconfiguring and if some inconsistency in the installed system causes
trouble later on, guix gc --verify can fix it. It is not important now.
Hope it helps.
Regards,
Florian
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: repair broken boot record
2021-10-05 11:04 ` pelzflorian (Florian Pelz)
@ 2021-10-06 8:23 ` Thomas Danckaert
2021-10-06 9:28 ` pelzflorian (Florian Pelz)
0 siblings, 1 reply; 8+ messages in thread
From: Thomas Danckaert @ 2021-10-06 8:23 UTC (permalink / raw)
To: pelzflorian (Florian Pelz); +Cc: help-guix
On 2021-10-05 13:04, pelzflorian (Florian Pelz) wrote:
> On Tue, Oct 05, 2021 at 11:28:50AM +0200, Thomas Danckaert wrote:
>> In one of the final
>> steps, where guix tries to install the bootloader, I get the error:
>>
>> /gnu/store/.../grub/i386-pc/modinfo.sh doesn't exist. Please specify
>> --target or --directory.
>
> This is strange. When you reconfigure, Guix should print the
> grub-install command that was used, which should include both --target
> and --directory.
The full message is:
guix system: error:
'/gnu/store/v77n5m....grub-efi-2.06/sbin/grub-install --boot-directory
//boot --bootloader-id=Guix --efi-directory=/boot/efi' exited with
status 1; output follows:
/gnu/store/.../grub-install: error:
/gnu/store/.../lib/grub/i386-pc/modinfo.sh doesn't exist. Please
specify --target or --directory'
Note that the grub-install command doens't contain '--target' or
'--directory'. (Also: my system is x64, and this seems to be for i386.
Should there be a --target=x64_86-efi somewhere?)
> However, perhaps the chroot is at fault: Before chrooting to, let’s
> say, /mnt with chroot /mnt, you need to have mounted the /dev/sdXy
> file system with EFI on it (that which is declared in your config.scm)
> to /mnt/boot/efi.
I have in my config 'target /boot/efi'. My EFI partition is /dev/sda1.
If I mount it like
# mount /dev/sda1 /mnt2
(/mnt2 because I already have my /dev/sda3 partition with guix at /mnt)
I find the following layout:
/mnt2/EFI/
EFI
grub
Guix
what would be the correct bind mount? I tried
# mount --bind /mnt2/EFI /boot/efi
so I now have
/boot/efi/
EFI
grub
Guix
Any idea if that is the desired layout?
thanks!
Thomas
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: repair broken boot record
2021-10-06 8:23 ` Thomas Danckaert
@ 2021-10-06 9:28 ` pelzflorian (Florian Pelz)
2021-12-13 14:16 ` Thomas Danckaert
0 siblings, 1 reply; 8+ messages in thread
From: pelzflorian (Florian Pelz) @ 2021-10-06 9:28 UTC (permalink / raw)
To: Thomas Danckaert; +Cc: help-guix
On Wed, Oct 06, 2021 at 10:23:38AM +0200, Thomas Danckaert wrote:
> On 2021-10-05 13:04, pelzflorian (Florian Pelz) wrote:
> > On Tue, Oct 05, 2021 at 11:28:50AM +0200, Thomas Danckaert wrote:
> > > In one of the final
> > > steps, where guix tries to install the bootloader, I get the error:
> > >
> > > /gnu/store/.../grub/i386-pc/modinfo.sh doesn't exist. Please specify
> > > --target or --directory.
> >
> > This is strange. When you reconfigure, Guix should print the
> > grub-install command that was used, which should include both --target
> > and --directory.
>
> The full message is:
>
> guix system: error: '/gnu/store/v77n5m....grub-efi-2.06/sbin/grub-install
> --boot-directory //boot --bootloader-id=Guix --efi-directory=/boot/efi'
> exited with status 1; output follows:
>
> /gnu/store/.../grub-install: error:
> /gnu/store/.../lib/grub/i386-pc/modinfo.sh doesn't exist. Please specify
> --target or --directory'
>
> Note that the grub-install command doens't contain '--target' or
> '--directory'. (Also: my system is x64, and this seems to be for i386.
> Should there be a --target=x64_86-efi somewhere?)
Sorry, I was wrong about --target being used; looking in the Guix
source at gnu/bootloader/grub.scm
<https://git.savannah.gnu.org/cgit/guix.git/tree/gnu/bootloader/grub.scm>,
--target is only for traditional BIOS boot and not EFI boot.
Your command is correct. I checked and have used exactly the same
command successfully (I checked the install-bootloader.scm file after
reconfigure on an EFI PC), and it should install, but for you it does
not. It is good to see the full message though.
Note that you can run exactly the same command manually, but the
result would likely be the same.
> > However, perhaps the chroot is at fault: Before chrooting to, let’s
> > say, /mnt with chroot /mnt, you need to have mounted the /dev/sdXy
> > file system with EFI on it (that which is declared in your config.scm)
> > to /mnt/boot/efi.
>
> I have in my config 'target /boot/efi'. My EFI partition is /dev/sda1. If
> I mount it like
> # mount /dev/sda1 /mnt2
> (/mnt2 because I already have my /dev/sda3 partition with guix at /mnt)
> I find the following layout:
>
> /mnt2/EFI/
> EFI
> grub
> Guix
>
> what would be the correct bind mount? I tried
> # mount --bind /mnt2/EFI /boot/efi
> so I now have
> /boot/efi/
> EFI
> grub
> Guix
>
> Any idea if that is the desired layout?
From outside the chroot, you should
# mount /dev/sda3 /mnt
# mount /dev/sda1 /mnt/boot/efi
Regards,
Florian
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: repair broken boot record
2021-10-06 9:28 ` pelzflorian (Florian Pelz)
@ 2021-12-13 14:16 ` Thomas Danckaert
2021-12-13 16:12 ` pelzflorian (Florian Pelz)
0 siblings, 1 reply; 8+ messages in thread
From: Thomas Danckaert @ 2021-12-13 14:16 UTC (permalink / raw)
To: pelzflorian; +Cc: help-guix
Hi Florian,
I think I still owed a final response in this thread, especially
after all your effort to help out.
In the end, I reinstallled Guix from scratch (luckily, I had a full
backup of my /home, and Guix makes it easy to restore your system
exactly as it was...), and switched to '(bootloader
grub-bootloader)'. That did the trick. I couldn't get the chroot
approach to work properly (maybe with more time, ...).
Looking back at the history of my system config, I used to have
(bootloader (grub-configuration (target "/dev/sda")))
for a long time. I don't actually remember how I ever ended up with
grub-efi-bootloader (little Guix time lately, I mostly just update
and check my e-mail these days), maybe I just copied from the manual
without thinking/ reading properly...
Thanks for your help, I still learned a few things, even though I
couldn't get it to work properly...
Thomas
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: repair broken boot record
2021-12-13 14:16 ` Thomas Danckaert
@ 2021-12-13 16:12 ` pelzflorian (Florian Pelz)
0 siblings, 0 replies; 8+ messages in thread
From: pelzflorian (Florian Pelz) @ 2021-12-13 16:12 UTC (permalink / raw)
To: Thomas Danckaert; +Cc: help-guix
Thank you Thomas for the post-mortem.
> In the end, I reinstallled Guix from scratch […] I couldn't get the
> chroot approach to work properly (maybe with more time, ...).
Though there is little difference betweem reconfigure and reinstall if
the chroot is set up properly, I should better have adviced to avoid
the trouble and reinstall. Imitating a booted system with chroot has
too individual requirements. Anyway.
Good your system is working again now. :)
Regards,
Florian
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2021-12-13 16:13 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-09-30 7:43 repair broken boot record Thomas Danckaert
2021-10-01 6:53 ` pelzflorian (Florian Pelz)
2021-10-05 9:28 ` Thomas Danckaert
2021-10-05 11:04 ` pelzflorian (Florian Pelz)
2021-10-06 8:23 ` Thomas Danckaert
2021-10-06 9:28 ` pelzflorian (Florian Pelz)
2021-12-13 14:16 ` Thomas Danckaert
2021-12-13 16:12 ` pelzflorian (Florian Pelz)
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/guix.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.