**This is an old revision of the document!** ----

A PCRE internal error occured. This might be caused by a faulty plugin

===== Driver FAQ ===== === How do I check if a network card is supported? === When a PCI network card is detected, its PCI ID is used to identify it and choose an appropriate driver. Each network card driver has a list of PCI IDs it supports. The format of a PCI ID is ''VVVV:DDDD'', where the ''VVVV'' field is called the Vendor ID and the ''DDDD'' field is called the Device ID. - Find out the PCI ID of the network card: * On Linux using ''lspci -nn''. Look for ''Ethernet controller''. * In gPXE using ''show net0/busid''. Ignore for first byte, e.g. busid ''01:10:ec:81:39'' -> PCI ID ''10ec:8139''. - Check if there is a gPXE driver for this PCI ID: * Ask ''gpxebot'' on #etherboot IRC like this: ''gpxebot: lspci 10ec:8139''. * Search the gPXE source code for the Device ID, looking for lines of code like this: PCI_ROM(0x10ec, 0x8139, "rtl8139", "Realtek 8139", 0), === What if there is no driver for my network card? === If there is no native gPXE driver for a network card, there are two choices: - Develop a driver or extend an existing driver to support the network card. - Use the generic UNDI driver, which works for many use cases but is not equivalent to a native driver. Before falling back to the UNDI driver, speak with the developers about the effort required to add native driver support for the network card. Sometimes there is already a native driver and it simply needs a line added with the PCI ID of the network card. There are developers in the community who do paid driver development work and can help you add support for new network cards. Ask on the mailing list. === Can open source Linux or BSD drivers be used with gPXE? === No. Although the gPXE driver API is similar to the Linux API, drivers are not compatible at the source or binary level. Open source drivers can be ported to gPXE or used as a starting point for developing gPXE drivers. This is especially useful for network cards where no datasheet is available from the vendor. === How can I use the UNDI driver if there is no native driver? === 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. gPXE can load the UNDI driver and use it instead of a native driver. Depending on the gPXE 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 (''gpxe'') 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 gPXE. 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? === - gPXE is an open source PXE stack and provides UNDI services. If a vendor chooses to use gPXE as their PXE/UNDI stack then they need a native driver. - UNDI is slow because gPXE must switch CPU modes when calling it. - UNDI ROMs can be buggy or violate the PXE specification. Native drivers are known to work with gPXE and can be fixed if there is a bug. - Enabling the network boot ROM in the BIOS is not always possible or desirable.


QR Code
QR Code faq:drivers (generated for current page)