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

    Build iPXE from source

    Scheduled Pinned Locked Moved
    Tutorials
    3
    4
    7.2k
    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.
    • Tom ElliottT
      Tom Elliott
      last edited by

      This document just proves as a method to help with building your own undionly.kpxe and/or snponly.kpxe file at it’s current state.

      I will try to keep this updated, but it will probably be lost in the mix later on.

      There are no guarantee’s that this will work for you, but it is assumed that you have the proper packages installed to build the system. There is plenty of documentation on what’s needed and google will be your friend in this regard as well.

      1.) Download the source from iPXE’s git repository:
      [code]git clone git://git.ipxe.org/ipxe.git[/code]

      2.) Change to the ipxe src directory
      [code]cd ipxe/src[/code]

      3.) Edit the files to allow for Console, bzImage, nfs, https, and image_png
      [code]vi config/general.h[/code]

      Change the appropriate lines so they appear as such: [B]THIS IS FOR UNDIONLY.KPXE[/B]
      [code]#define PXE_STACK
      #define PXE_MENU
      #define DOWNLOAD_PROTO_HTTPS
      #define DOWNLOAD_PROTO_NFS
      #define IMAGE_PXE
      #define IMAGE_BZIMAGE
      #define IMAGE_PNG
      #define AUTOBOOT_CMD
      #define NVO_CMD
      #define CONFIG_CMD
      #define IFMGMT_CMD
      #define IWMGMT_CMD
      #define FCMGMT_CMD
      #define ROUTE_CMD
      #define IMAGE_CMD
      #define DHCP_CMD
      #define SANBOOT_CMD
      #define MENU_CMD
      #define LOGIN_CMD
      #define SYNC_CMD
      #define NSLOOKUP_CMD
      #define TIME_CMD
      #define DIGEST_CMD
      #define LOTEST_CMD
      #define VLAN_CMD
      #define PXE_CMD
      #define REBOOT_CMD
      #define POWEROFF_CMD
      #define IMAGE_TRUST_CMD
      #define PCI_CMD
      #define PARAM_CMD
      #define NEIGHBOUR_CMD
      #define PING_CMD
      #define CONSOLE_CMD
      #define IPSTAT_CMD[/code]

      4.) Edit the file to allow for vesafb (display’s picture behind menu).
      [code]vi config/console.h[/code]

      Change the appropriate lines so they appear as such: [B]THIS IS FOR THE UNDIONLY.KPXE FILE[/B]
      [code]#define CONSOLE_VESAFB[/code]

      5.) Make the embed script:
      [code]cat << EOF > ipxescriptfile
      #!ipxe
      :retry
      dhcp || goto retry
      chain default.ipxe || exit
      EOF[/code]

      6.) Build the undionly file.
      [code]make bin/undionly.kpxe EMBED=ipxescriptfile[/code]

      Once completed with the build, you have created the undionly.kpxe file the same as I have done for FOG 0.33.

      Copy the ipxe/src/bin/undionly.kpxe file to your tftpboot folder on your fog server and you’ll be using it. It’s that simple. For the snponly.kpxe follow these steps.

      1.) Edit the config/general.h file so the appropriate lines read:
      [code]//#define PXE_STACK
      //#define PXE_MENU
      #define DOWNLOAD_PROTO_HTTPS
      #define DOWNLOAD_PROTO_NFS
      //#define IMAGE_PXE
      //#define IMAGE_BZIMAGE
      #define IMAGE_EFI
      #define IMAGE_PNG
      #define AUTOBOOT_CMD
      #define NVO_CMD
      #define CONFIG_CMD
      #define IFMGMT_CMD
      #define IWMGMT_CMD
      #define FCMGMT_CMD
      #define ROUTE_CMD
      #define IMAGE_CMD
      #define DHCP_CMD
      #define SANBOOT_CMD
      #define MENU_CMD
      #define LOGIN_CMD
      #define SYNC_CMD
      #define NSLOOKUP_CMD
      #define TIME_CMD
      #define DIGEST_CMD
      #define LOTEST_CMD
      #define VLAN_CMD
      //#define PXE_CMD
      #define REBOOT_CMD
      #define POWEROFF_CMD
      #define IMAGE_TRUST_CMD
      #define PCI_CMD
      #define PARAM_CMD
      #define NEIGHBOUR_CMD
      #define PING_CMD
      #define CONSOLE_CMD
      #define IPSTAT_CMD[/code]

      2.) Edit the config/console.h file so the vesafb is commented as such:
      [code]//#define CONSOLE_VESAFB[/code]

      3.) Make the snponly.efi
      [code]make bin-x86_64-efi/snponly.efi EMBED=ipxescriptfile[/code]

      Then you’ve created the efi file. While it isn’t working with menu and such yet, hopefully we’ll achieve this in the near future.

      Hopefully this helps everybody.

      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! Get in contact with me (chat bubble in the top right corner) if you want to join in.

      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
      • Wayne WorkmanW
        Wayne Workman
        last edited by

        This post is deleted!
        1 Reply Last reply Reply Quote 0
        • Wayne WorkmanW
          Wayne Workman
          last edited by

          For Fedora 21, this is required:
          [CODE]yum install binutils-devel[/CODE]
          Reference:
          [url]http://forum.ipxe.org/showthread.php?tid=7508[/url]

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

            For Debian/Ubuntu:
            [CODE] sudo apt-get install binutils-dev[/CODE]

            [B]Would you please edit the post and remove the “on RH” in the code box… I am sure a lot of people don’t understand that this is not part of the command![/B]

            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 / 1
            • First post
              Last post

            147

            Online

            12.0k

            Users

            17.3k

            Topics

            155.2k

            Posts
            Copyright © 2012-2024 FOG Project