]> git.proxmox.com Git - mirror_edk2.git/commitdiff
OvmfPkg: enable building VirtioNetDxe
authorLaszlo Ersek <lersek@redhat.com>
Fri, 14 Jun 2013 07:41:13 +0000 (07:41 +0000)
committerjljusten <jljusten@6f19259b-4bc3-4df7-8a09-765794883524>
Fri, 14 Jun 2013 07:41:13 +0000 (07:41 +0000)
Also summarize the resultant NIC driver options in the README file.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
Reviewed-by: Jordan Justen <jordan.l.justen@intel.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@14421 6f19259b-4bc3-4df7-8a09-765794883524

OvmfPkg/OvmfPkgIa32.dsc
OvmfPkg/OvmfPkgIa32.fdf
OvmfPkg/OvmfPkgIa32X64.dsc
OvmfPkg/OvmfPkgIa32X64.fdf
OvmfPkg/OvmfPkgX64.dsc
OvmfPkg/OvmfPkgX64.fdf
OvmfPkg/README

index 0e6d1879b5e19384f248f7be83c54aaa787b24c3..fbb70980211df9b47cee61dea700f724f145102c 100644 (file)
   MdeModulePkg/Universal/Network/Udp4Dxe/Udp4Dxe.inf\r
   MdeModulePkg/Universal/Network/UefiPxeBcDxe/UefiPxeBcDxe.inf\r
   MdeModulePkg/Universal/Network/IScsiDxe/IScsiDxe.inf\r
+  OvmfPkg/VirtioNetDxe/VirtioNet.inf\r
 \r
   #\r
   # Usb Support\r
index 4665b9e1bd36e012486017635f335bf518ea030f..be6ca885b947c4e1a302a7ec2121364f631ab43e 100644 (file)
@@ -267,6 +267,7 @@ FILE FREEFORM = PCD(gEfiIntelFrameworkModulePkgTokenSpaceGuid.PcdLogoFile) {
   INF  MdeModulePkg/Universal/Network/Udp4Dxe/Udp4Dxe.inf\r
   INF  MdeModulePkg/Universal/Network/UefiPxeBcDxe/UefiPxeBcDxe.inf\r
   INF  MdeModulePkg/Universal/Network/IScsiDxe/IScsiDxe.inf\r
+  INF  OvmfPkg/VirtioNetDxe/VirtioNet.inf\r
 \r
 #\r
 # Usb Support\r
index 48da5328e0385d7462460f3949b6f3d84079c781..ace575a0a2d602de196d68bc67dafbb6d125009c 100644 (file)
   MdeModulePkg/Universal/Network/Udp4Dxe/Udp4Dxe.inf\r
   MdeModulePkg/Universal/Network/UefiPxeBcDxe/UefiPxeBcDxe.inf\r
   MdeModulePkg/Universal/Network/IScsiDxe/IScsiDxe.inf\r
+  OvmfPkg/VirtioNetDxe/VirtioNet.inf\r
 \r
   #\r
   # Usb Support\r
index 177c880d4b2a1ce7ae33d31cdd6f661f9c7baca4..89e86e6804212a9dcfed49bf9622e1478790022d 100644 (file)
@@ -267,6 +267,7 @@ FILE FREEFORM = PCD(gEfiIntelFrameworkModulePkgTokenSpaceGuid.PcdLogoFile) {
   INF  MdeModulePkg/Universal/Network/Udp4Dxe/Udp4Dxe.inf\r
   INF  MdeModulePkg/Universal/Network/UefiPxeBcDxe/UefiPxeBcDxe.inf\r
   INF  MdeModulePkg/Universal/Network/IScsiDxe/IScsiDxe.inf\r
+  INF  OvmfPkg/VirtioNetDxe/VirtioNet.inf\r
 \r
 #\r
 # Usb Support\r
index 7f138ce48d9aed70a380a22f79f732390ae0a2e8..001393e32418e687a9af55e991e4569eed00966b 100644 (file)
   MdeModulePkg/Universal/Network/Udp4Dxe/Udp4Dxe.inf\r
   MdeModulePkg/Universal/Network/UefiPxeBcDxe/UefiPxeBcDxe.inf\r
   MdeModulePkg/Universal/Network/IScsiDxe/IScsiDxe.inf\r
+  OvmfPkg/VirtioNetDxe/VirtioNet.inf\r
 \r
   #\r
   # Usb Support\r
index 1d3ba8e52fed63b3ed0c3bae209897c9592d72ee..abeedefd85552b65ace57cd077c5411bb18fbc6e 100644 (file)
@@ -267,6 +267,7 @@ FILE FREEFORM = PCD(gEfiIntelFrameworkModulePkgTokenSpaceGuid.PcdLogoFile) {
   INF  MdeModulePkg/Universal/Network/Udp4Dxe/Udp4Dxe.inf\r
   INF  MdeModulePkg/Universal/Network/UefiPxeBcDxe/UefiPxeBcDxe.inf\r
   INF  MdeModulePkg/Universal/Network/IScsiDxe/IScsiDxe.inf\r
+  INF  OvmfPkg/VirtioNetDxe/VirtioNet.inf\r
 \r
 #\r
 # Usb Support\r
index 13058eae47a89c4abcf34ce2be62de829e8da17a..213d8648d6bd9f4e6ade68cb832c7563662c0121 100644 (file)
@@ -108,11 +108,11 @@ $ OvmfPkg/build.sh -a IA32 -b RELEASE -t GCC45
 \r
 === Network Support ===\r
 \r
-OVMF provides a generic UEFI network stack by default, with the lowest level\r
-driver (the NIC driver) missing in the default build. In order to complete the\r
-stack and make eg. DHCP, PXE Boot, and socket test utilities from the StdLib\r
-edk2 package work, (1) qemu has to be configured to emulate a NIC, (2) a\r
-matching UEFI NIC driver must be available when OVMF boots.\r
+OVMF provides a UEFI network stack by default. Its lowest level driver is the\r
+NIC driver, higher levels are generic. In order to make DHCP, PXE Boot, and eg.\r
+socket test utilities from the StdLib edk2 package work, (1) qemu has to be\r
+configured to emulate a NIC, (2) a matching UEFI NIC driver must be available\r
+when OVMF boots.\r
 \r
 (If a NIC is configured for the virtual machine, and -- dependent on boot order\r
 -- PXE booting is attempted, but no DHCP server responds to OVMF's DHCP\r
@@ -122,23 +122,23 @@ longer.)
 * For each NIC emulated by qemu, a GPLv2 licensed UEFI driver is available from\r
   the iPXE project. The qemu source distribution, starting with version 1.5,\r
   contains prebuilt binaries of these drivers (and of course allows one to\r
-  rebuild them from source as well).\r
+  rebuild them from source as well). This is the recommended set of drivers.\r
 \r
 * Use the qemu -netdev and -device options, or the legacy -net option, to\r
   enable NIC support: <http://wiki.qemu.org/Documentation/Networking>.\r
 \r
 * For a qemu >= 1.5 binary running *without* any "-M machine" option where\r
   "machine" would identify a < qemu-1.5 configuration (for example: "-M\r
-  pc-i440fx-1.4" or "-M pc-0.13"), the drivers are available from the default\r
-  qemu installation to OVMF without further settings.\r
+  pc-i440fx-1.4" or "-M pc-0.13"), the iPXE drivers are automatically available\r
+  to and configured for OVMF in the default qemu installation.\r
 \r
 * For a qemu binary in [0.13, 1.5), or a qemu >= 1.5 binary with an "-M\r
   machine" option where "machine" selects a < qemu-1.5 configuration:\r
 \r
   - download a >= 1.5.0-rc1 source tarball from <http://wiki.qemu.org/Download>,\r
 \r
-  - extract the following files from the tarball and install them in a\r
-    location that is accessible to qemu processes (this may depend on your\r
+  - extract the following iPXE driver files from the tarball and install them\r
+    in a location that is accessible to qemu processes (this may depend on your\r
     SELinux configuration, for example):\r
 \r
     qemu-VERSION/pc-bios/efi-e1000.rom\r
@@ -156,9 +156,11 @@ longer.)
     -device rtl8139,...,romfile=/full/path/to/efi-rtl8139.rom\r
     -device virtio-net-pci,...,romfile=/full/path/to/efi-virtio.rom\r
 \r
-* Independently of the iPXE NIC drivers, Intel's proprietary E1000 NIC driver\r
-  can be embedded in the OVMF image at build time, as an alternative guest\r
-  driver for "-device e1000":\r
+* Independently of the iPXE NIC drivers, the default OVMF build provides a\r
+  basic virtio-net driver, located in OvmfPkg/VirtioNetDxe.\r
+\r
+* Also independently of the iPXE NIC drivers, Intel's proprietary E1000 NIC\r
+  driver (PROEFI) can be embedded in the OVMF image at build time:\r
 \r
   - Download UEFI drivers for the e1000 NIC\r
     - http://downloadcenter.intel.com/Detail_Desc.aspx?agr=Y&DwnldID=17515&lang=eng\r
@@ -168,6 +170,15 @@ longer.)
     - Add "-D E1000_ENABLE -D FD_SIZE_2MB" to your build command,\r
     - For example: "build -D E1000_ENABLE -D FD_SIZE_2MB".\r
 \r
+* When a matching iPXE driver is configured for a NIC as described above, it\r
+  takes priority over other drivers that could possibly drive the card too:\r
+\r
+                 | e1000  ne2k_pci  pcnet  rtl8139  virtio-net-pci\r
+    -------------+------------------------------------------------\r
+    iPXE         |   x       x        x       x           x\r
+    VirtioNetDxe |                                        x\r
+    Intel PROEFI |   x\r
+\r
 === UNIXGCC Debug ===\r
 \r
 If you build with the UNIXGCC toolchain, then debugging will be disabled\r