From patchwork Tue Feb 24 16:27:40 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Bruce Richardson X-Patchwork-Id: 3678 Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [IPv6:::1]) by dpdk.org (Postfix) with ESMTP id 875DFAD80; Tue, 24 Feb 2015 17:28:14 +0100 (CET) Received: from mga02.intel.com (mga02.intel.com [134.134.136.20]) by dpdk.org (Postfix) with ESMTP id 906DA9AF3 for ; Tue, 24 Feb 2015 17:28:12 +0100 (CET) Received: from orsmga001.jf.intel.com ([10.7.209.18]) by orsmga101.jf.intel.com with ESMTP; 24 Feb 2015 08:27:45 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.09,639,1418112000"; d="scan'208";a="656520852" Received: from irvmail001.ir.intel.com ([163.33.26.43]) by orsmga001.jf.intel.com with ESMTP; 24 Feb 2015 08:27:44 -0800 Received: from sivswdev01.ir.intel.com (sivswdev01.ir.intel.com [10.237.217.45]) by irvmail001.ir.intel.com (8.14.3/8.13.6/MailSET/Hub) with ESMTP id t1OGRfSj019095; Tue, 24 Feb 2015 16:27:41 GMT Received: from sivswdev01.ir.intel.com (localhost [127.0.0.1]) by sivswdev01.ir.intel.com with ESMTP id t1OGRfr5013844; Tue, 24 Feb 2015 16:27:41 GMT Received: (from bricha3@localhost) by sivswdev01.ir.intel.com with id t1OGRfBN013839; Tue, 24 Feb 2015 16:27:41 GMT From: Bruce Richardson To: dev@dpdk.org Date: Tue, 24 Feb 2015 16:27:40 +0000 Message-Id: <1424795260-13793-3-git-send-email-bruce.richardson@intel.com> X-Mailer: git-send-email 1.7.4.1 In-Reply-To: <1424795260-13793-1-git-send-email-bruce.richardson@intel.com> References: <1424795260-13793-1-git-send-email-bruce.richardson@intel.com> Subject: [dpdk-dev] [PATCH 2/2] doc: update programmers guide for uio_pci_generic X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: patches and discussions about DPDK List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" Since DPDK now has support for the in-tree uio_pci_generic driver, update the programmers guide document to reference this module, and to use it in preference to the igb_uio driver, which is DPDK-specific. Signed-off-by: Bruce Richardson --- doc/guides/prog_guide/env_abstraction_layer.rst | 8 ++++---- doc/guides/prog_guide/intel_dpdk_xen_based_packet_switch_sol.rst | 6 +++--- doc/guides/prog_guide/kernel_nic_interface.rst | 2 +- doc/guides/prog_guide/poll_mode_drv_emulated_virtio_nic.rst | 8 ++++---- doc/guides/prog_guide/poll_mode_drv_paravirtual_vmxnets_nic.rst | 2 +- 5 files changed, 13 insertions(+), 13 deletions(-) diff --git a/doc/guides/prog_guide/env_abstraction_layer.rst b/doc/guides/prog_guide/env_abstraction_layer.rst index 231e266..b5321c3 100644 --- a/doc/guides/prog_guide/env_abstraction_layer.rst +++ b/doc/guides/prog_guide/env_abstraction_layer.rst @@ -66,7 +66,7 @@ EAL in a Linux-userland Execution Environment --------------------------------------------- In a Linux user space environment, the DPDK application runs as a user-space application using the pthread library. -PCI information about devices and address space is discovered through the /sys kernel interface and through a module called igb_uio. +PCI information about devices and address space is discovered through the /sys kernel interface and through kernel modules such as uio_pci_generic, or igb_uio. Refer to the UIO: User-space drivers documentation in the Linux kernel. This memory is mmap'd in the application. The EAL performs physical memory allocation using mmap() in hugetlbfs (using huge page sizes to increase performance). @@ -134,10 +134,10 @@ PCI Access ~~~~~~~~~~ The EAL uses the /sys/bus/pci utilities provided by the kernel to scan the content on the PCI bus. - -To access PCI memory, a kernel module called igb_uio provides a /dev/uioX device file +To access PCI memory, a kernel module called uio_pci_generic provides a /dev/uioX device file +and resource files in /sys that can be mmap'd to obtain access to PCI address space from the application. -It uses the uio kernel feature (userland driver). +The DPDK-specific igb_uio module can also be used for this. Both drivers use the uio kernel feature (userland driver). Per-lcore and Shared Variables ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ diff --git a/doc/guides/prog_guide/intel_dpdk_xen_based_packet_switch_sol.rst b/doc/guides/prog_guide/intel_dpdk_xen_based_packet_switch_sol.rst index 1f1e04f..a0dd959 100644 --- a/doc/guides/prog_guide/intel_dpdk_xen_based_packet_switch_sol.rst +++ b/doc/guides/prog_guide/intel_dpdk_xen_based_packet_switch_sol.rst @@ -306,12 +306,12 @@ Building and Running the Switching Backend Refer to the *DPDK Getting Started Guide* for more information on memory management in the DPDK. In the above command, 4 GB memory is reserved (2048 of 2 MB pages) for DPDK. -#. Load igb_uio and bind one Intel NIC controller to igb_uio: +#. Load uio_pci_generic and bind one Intel NIC controller to it: .. code-block:: console - insmod x86_64-native-linuxapp-gcc/kmod/igb_uio.ko - python tools/dpdk_nic_bind.py -b igb_uio 0000:09:00:00.0 + modprobe uio_pci_generic + python tools/dpdk_nic_bind.py -b uio_pci_generic 0000:09:00:00.0 In this case, 0000:09:00.0 is the PCI address for the NIC controller. diff --git a/doc/guides/prog_guide/kernel_nic_interface.rst b/doc/guides/prog_guide/kernel_nic_interface.rst index 0276019..9ed7688 100644 --- a/doc/guides/prog_guide/kernel_nic_interface.rst +++ b/doc/guides/prog_guide/kernel_nic_interface.rst @@ -224,7 +224,7 @@ Otherwise, by default, KNI will not enable its backend support capability. Of course, as a prerequisite, the vhost/vhost-net kernel CONFIG should be chosen before compiling the kernel. -#. Compile the DPDK and insert igb_uio as normal. +#. Compile the DPDK and insert uio_pci_generic/igb_uio kernel modules as normal. #. Insert the KNI kernel module: diff --git a/doc/guides/prog_guide/poll_mode_drv_emulated_virtio_nic.rst b/doc/guides/prog_guide/poll_mode_drv_emulated_virtio_nic.rst index 86f4f60..b0a6250 100644 --- a/doc/guides/prog_guide/poll_mode_drv_emulated_virtio_nic.rst +++ b/doc/guides/prog_guide/poll_mode_drv_emulated_virtio_nic.rst @@ -113,7 +113,7 @@ Host2VM communication example insmod rte_kni.ko - Other basic DPDK preparations like hugepage enabling, igb_uio port binding are not listed here. + Other basic DPDK preparations like hugepage enabling, uio port binding are not listed here. Please refer to the *DPDK Getting Started Guide* for detailed instructions. #. Launch the kni user application: @@ -154,7 +154,7 @@ Host2VM communication example In the above example, virtio port 0 in the guest VM will be associated with vEth0, which in turns corresponds to a physical port, which means received packets come from vEth0, and transmitted packets is sent to vEth0. -#. In the guest, bind the virtio device to the igb_uio kernel module and start the forwarding application. +#. In the guest, bind the virtio device to the uio_pci_generic kernel module and start the forwarding application. When the virtio port in guest bursts rx, it is getting packets from the raw socket's receive queue. When the virtio port bursts tx, it is sending packet to the tx_q. @@ -162,8 +162,8 @@ Host2VM communication example modprobe uio echo 512 > /sys/devices/system/node/node0/hugepages/hugepages-2048kB/nr_hugepages - insmod x86_64-native-linuxapp-gcc/kmod/igb_uio.ko - python tools/dpdk_nic_bind.py -b igb_uio 00:03.0 + modprobe uio_pci_generic + python tools/dpdk_nic_bind.py -b uio_pci_generic 00:03.0 We use testpmd as the forwarding application in this example. diff --git a/doc/guides/prog_guide/poll_mode_drv_paravirtual_vmxnets_nic.rst b/doc/guides/prog_guide/poll_mode_drv_paravirtual_vmxnets_nic.rst index e48bc13..769723e 100644 --- a/doc/guides/prog_guide/poll_mode_drv_paravirtual_vmxnets_nic.rst +++ b/doc/guides/prog_guide/poll_mode_drv_paravirtual_vmxnets_nic.rst @@ -150,7 +150,7 @@ This section describes an example setup for Phy-vSwitch-VM-Phy communication. .. note:: - Other instructions on preparing to use DPDK such as, hugepage enabling, igb_uio port binding are not listed here. + Other instructions on preparing to use DPDK such as, hugepage enabling, uio port binding are not listed here. Please refer to *DPDK Getting Started Guide and DPDK Sample Application's User Guide* for detailed instructions. The packet reception and transmission flow path is: