A few posts ago, UNDI vs PXE drivers was discussed.
Here below a nice explanations (take from here).
What are the differences between the different PXE files?
Filenames
- ipxe has drivers native to the ipxe project. Those drivers are handled from the iPXE developers.
- undionly uses the "undi" stack made by the manufacturer of the NIC.
Universal Network Device Interface (UNDI) is an application programming interface (API) for network interface cards (NIC) used by the Preboot Execution Environment (PXE) protocol.
When chainloading iPXE from PXE, iPXE can use this API (instead of loading a hardware driver). This way, you're getting support for network controllers that are not natively supported by iPXE. Some network controllers have improved performance when using the UNDI driver over the vendor specific iPXE driver.
To use the UNDI driver, select the UNDI driver (undionly) when generating the iPXE ROM. (e.g. make bin/undionly.kpxe EMBED=embedscriptname)
Extensions
More info can be referenced here:
- .pxe is an image designed to be chain loaded, unloading both the underlying PXE and UNDI code sections. This is ultimately the goal, but there's not enough information to allow this to actually work flawlessly every time. It uses, purely, the drivers from the iPXE information. One of the benefits is the codebase for the drivers are handled by the iPXE developers. So, in theory and given enough time, all NICs could potentially be supported.
- .pxe is an image designed to be chain loaded, unloading both the underlying PXE and UNDI code sections.
- .kpxe unloads just the pxe stack and is the normal file we want in use as it seems to be the best between pxe/chaining I can find without flashing roms.
- .kpxe is a PXE image that keeps UNDI loaded and unloads PXE
- .kkpxe keeps both undi and pxe stacks in place. kkpxe works best for buggy hardware. Only recommended if you're having weird issues with the undionly.kpxe
- .kkpxe is a PXE image that keeps PXE+UNDI loaded and return to PXE (instead of int 18h).
- .kkkpxe is only used to generate the ipxelinux.0 file. This is only used in conjunction with the syslinux project. When gpxe was the developed software of this type the file was called gpxelinux.0 which can usually be built with modern syslinux.
More information on this can be found on the ipxe forum thread located
Undi and iPXE Stack
The UNDI driver is a generic driver that works on network cards that have a vendor UNDI ROM. The ROM contains driver code that is supposed to conform to the PXE/UNDI specification. iPXE can load the UNDI driver and use it instead of a native driver.
Depending on the iPXE image type, UNDI support works as follows:
- undionly.kpxe is loaded from a vendor PXE stack and uses UNDI on the network card that it was booted from.
- All-driver (ipxe) or undi images can load the UNDI for PCI network cards. The network boot ROM must be enabled in the BIOS in order for the UNDI ROM to be visible to iPXE. Note that only the first network card is supported with UNDI since multiple instances of UNDI is unreliable and cannot be supported.
Why write native drivers if UNDI works with every network card?
- iPXE is an open source PXE stack and provides UNDI services. iPXE cannot be used as an option ROM without a native driver.
- UNDI is slow because iPXE must switch CPU modes when calling it.
- UNDI ROMs can be buggy or violate the PXE specification. Native drivers are known to work with iPXE and can be fixed if there is a bug since they are part of the iPXE codebase.
- Enabling the network boot ROM in the BIOS is not always possible or desirable.