• Recent
    • Unsolved
    • Tags
    • Popular
    • Users
    • Groups
    • Search
    • Register
    • Login

    FOG doesn’t copy NVRAM from cloned machine to the new machine

    Scheduled Pinned Locked Moved Solved FOG Problems
    21 Posts 3 Posters 5.0k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      Sebastian Roth Moderator
      last edited by

      @marted Ahhh, now I see. Well done, seems like you have come up with a great process to make sure both your Windows and Linux installation are setup nicely after the image deploy and changing OS on reboot works as well!

      While I haven’t tried grub2win myself I would expect you need to adjust /var/www/html/fog/service/ipxe/refind.conf to make it find your grub2win binary in the EFI partition. The information about adding an entry to NVRAM using efibootmgr tool probably doesn’t help in your case I’d think.

      So I would assume the easiest way right now is adding a menu entry at the end of this file like this:

      menuentry grub2win {
          loader /EFI/grub2win/grub2win.boot64.efi
      }
      

      As well you want to adjust line 441 in refind.conf and set to default_selection grub2win - all untested… see what you get.

      Note: This change will reflect on all systems booting to the iPXE menu and chainload to disk. Just be aware this might have an impact on all your clients at once.

      One thing that came to my mind when reading your post is that you might be able to achieve the same thing by adding specific Host EFI Exit Types (host settings in the web UI) and switch between those for individual clients or groups of clients. BUT the issue is this part of FOG is not customizable as of now. So it would need manual code adjustments in bootmenu.class.php unfortunately. I can’t give you a ready-set-go solution for this right away as I haven’t done it for UEFI machines myself yet. Some years ago I used the old grub4dos binary we ship with FOG since a long time to switch default boot between Windows and Linux on MBR/legacy BIOS based machines when those chainload back to boot from disk as a default from the iPXE menu when there is no task scheduled. Sorry this sentence is a nightmare but I still hope you get what I mean.

      So I could see you using rEFind or even grub2win (if it’s PXE capable) to boot the two different OSes without having to modify the grub2win config on the clients at all. Probably don’t even need to install grub2win on the computers. Not saying this is the most reasonable way to go. As you already have it working the way you have, you might just stick to it. Just thought I throw this in for something else to look at.

      Web GUI issue? Please check apache error (debian/ubuntu: /var/log/apache2/error.log, centos/fedora/rhel: /var/log/httpd/error_log) and php-fpm log (/var/log/php*-fpm.log)

      Please support FOG if you like it: https://wiki.fogproject.org/wiki/index.php/Support_FOG

      M 1 Reply Last reply Reply Quote 0
      • M
        marted
        last edited by

        Thank yo so much @Sebastian-Roth . I’ll try tomorrow the config you suggested and will give you feedback.

        1 Reply Last reply Reply Quote 0
        • M
          marted @Sebastian Roth
          last edited by

          @Sebastian-Roth sorry for my late response but I wanted to test everything before asking you again for help.
          Now the problem is that I see the rEfind menu in some model UEFI (HP 800 G2 UEFI) and on other HP 800 G4 UEFI), the boot stays on the message rEFInd initializing and does nothing.
          Furthermore, on the first one model where I see the menu, I still don’t understand something - I added the menuentry for grub2win you suggested and I cannot see it. After I deactivated ALL entries and still see the same menu on boot! Do I have to run some command to apply the changes in refind.conf file or it applies the changes every time it boots?
          Just to mention we compare the BIOS of both two computers G2 and G4 and they are equal, secure boot disable and legacy disable.

          1 Reply Last reply Reply Quote 0
          • S
            Sebastian Roth Moderator
            last edited by

            @marted Try the latest rEFInd version you find here: http://sourceforge.net/projects/refind/files/0.11.4/refind-bin-0.11.4.zip/download

            See if those work better than the ones we have as default.

            After I deactivated ALL entries and still see the same menu on boot! Do I have to run some command to apply the changes in refind.conf file or it applies the changes every time it boots?

            Changes should be active on the next boot as soon as you save the file. Though I haven’t played much with the config lately. Maybe there is some option that I have forgotten about that you need to enable/add/change/remove to make those boot entries work. @george1421 would you have an idea?

            Web GUI issue? Please check apache error (debian/ubuntu: /var/log/apache2/error.log, centos/fedora/rhel: /var/log/httpd/error_log) and php-fpm log (/var/log/php*-fpm.log)

            Please support FOG if you like it: https://wiki.fogproject.org/wiki/index.php/Support_FOG

            1 Reply Last reply Reply Quote 0
            • M
              marted
              last edited by

              @Sebastian, from the downloaded zip file, do I need just to find the .efi file x64 and replace the old one on the server with it? what about the .conf example in the zip? Do I have to copy it also to the server replacing the old one?

              1 Reply Last reply Reply Quote 0
              • S
                Sebastian Roth Moderator
                last edited by

                @marted I would say use the .efi file should do. If you are keen you can copy the .conf over as well but using a different name and diff the two files.

                Web GUI issue? Please check apache error (debian/ubuntu: /var/log/apache2/error.log, centos/fedora/rhel: /var/log/httpd/error_log) and php-fpm log (/var/log/php*-fpm.log)

                Please support FOG if you like it: https://wiki.fogproject.org/wiki/index.php/Support_FOG

                M 1 Reply Last reply Reply Quote 0
                • M
                  marted
                  last edited by

                  @Sebastian I tried your other suggestion for executing a postscript and I came with this command I executed in debug session on a client and it works 🙂
                  For me, it will be a better solution instead to mess up with rEFInd boot.
                  Now I need just to figure out how to add the script and where

                  efibootmgr --create --disk /dev/sda --part 1 --loader ‘\EFI\grub2win\g2bootmgr\gnugrub.kernel64.efi’ --label “Grub2Win”

                  1 Reply Last reply Reply Quote 0
                  • M
                    marted @Sebastian Roth
                    last edited by

                    @Sebastian to run this command with efibootmgr, do I need just to create a bash script, make it executable and put it in /images/postdownloadscripts. ?

                    george1421G 1 Reply Last reply Reply Quote 0
                    • george1421G
                      george1421 Moderator @marted
                      last edited by

                      @marted The proper way is to create a bash script and place it in /images/postdownload directory and then link (call) it into the fog.postdownload script. If you have different hardware or images, you can also create a conditional if statement so that it only calls this command if the image name matches a certain image name.

                      I have examples of post download scripts in the tutorial forum. Some are windows focused but the concepts are the same.

                      https://forums.fogproject.org/topic/7740/the-magical-mystical-fog-post-download-script

                      https://forums.fogproject.org/topic/8889/fog-post-install-script-for-win-driver-injection

                      Please help us build the FOG community with everyone involved. It's not just about coding - way more we need people to test things, update documentation and most importantly work on uniting the community of people enjoying and working on FOG!

                      M 2 Replies Last reply Reply Quote 0
                      • M
                        marted @george1421
                        last edited by Sebastian Roth

                        @george1421 Thank you so much!

                        1 Reply Last reply Reply Quote 0
                        • S
                          Sebastian Roth Moderator
                          last edited by

                          @marted said in FOG doesn’t copy NVRAM from cloned machine to the new machine:

                          I tried your other suggestion for executing a postscript and I came with this command I executed in debug session on a client and it works

                          Nice. Well you might go with that for now and come back to other solutions when you feel like it.

                          Web GUI issue? Please check apache error (debian/ubuntu: /var/log/apache2/error.log, centos/fedora/rhel: /var/log/httpd/error_log) and php-fpm log (/var/log/php*-fpm.log)

                          Please support FOG if you like it: https://wiki.fogproject.org/wiki/index.php/Support_FOG

                          1 Reply Last reply Reply Quote 0
                          • M
                            marted @george1421
                            last edited by

                            @george1421 @Sebastian-Roth I did the changes, just please confirm that everything I did is correct :

                            1. I created a file with permission 775 on the server FOG in /images/postdownloadscripts called fog.grub2win
                            #!/bin/bash
                            /bin/efibootmgr --create --disk /dev/sda --part 1 --loader ‘\EFI\grub2win\g2bootmgr\gnugrub.kernel64.efi’ --label “Grub2Win”
                            
                            1. I added the script in fog.postdownload
                            #!/bin/bash
                            ## This file serves as a starting point to call your custom postimaging scripts.
                            ## <SCRIPTNAME> should be changed to the script you're planning to use.
                            ## Syntax of post download scripts are
                            . ${postdownpath}fog.grub2win
                            

                            is everything OK?

                            george1421G 1 Reply Last reply Reply Quote 0
                            • george1421G
                              george1421 Moderator @marted
                              last edited by george1421

                              @marted Yes, I would make a comment and add a debugPause in your script so you can see it run something like this.

                              #!/bin/bash
                              echo Updating the Grub boot manager
                              debugPause
                              
                              /bin/efibootmgr --create --disk /dev/sda --part 1 --loader ‘\EFI\grub2win\g2bootmgr\gnugrub.kernel64.efi’ --label “Grub2Win”
                              
                              echo Grub configuration has been updated
                              debugPause
                              
                              

                              The echo statement will allow you to see while the post install script is running that your efibootmgr code is running. The debugPause will pause the code while running in debug mode.

                              Please help us build the FOG community with everyone involved. It's not just about coding - way more we need people to test things, update documentation and most importantly work on uniting the community of people enjoying and working on FOG!

                              1 Reply Last reply Reply Quote 0
                              • M
                                marted
                                last edited by marted

                                @george1421 thank you !

                                1 Reply Last reply Reply Quote 0
                                • S
                                  Sebastian Roth Moderator
                                  last edited by

                                  @marted Looking good.

                                  Web GUI issue? Please check apache error (debian/ubuntu: /var/log/apache2/error.log, centos/fedora/rhel: /var/log/httpd/error_log) and php-fpm log (/var/log/php*-fpm.log)

                                  Please support FOG if you like it: https://wiki.fogproject.org/wiki/index.php/Support_FOG

                                  1 Reply Last reply Reply Quote 0
                                  • 1
                                  • 2
                                  • 1 / 2
                                  • First post
                                    Last post

                                  177

                                  Online

                                  12.3k

                                  Users

                                  17.4k

                                  Topics

                                  155.8k

                                  Posts
                                  Copyright © 2012-2025 FOG Project