docs: Update vmxnet3 usecase 06/18306/4
authorSteven Luong <sluong@cisco.com>
Thu, 14 Mar 2019 19:07:29 +0000 (12:07 -0700)
committerDamjan Marion <dmarion@me.com>
Tue, 19 Mar 2019 07:39:51 +0000 (07:39 +0000)
Update vmxnet3 usecase to reflect the current supported features.

Change-Id: I4558eb422d5b2641b3acfc7c0a3734bf31a8fb0f
Signed-off-by: Steven Luong <sluong@cisco.com>
docs/usecases/vmxnet3.rst

index e556207..b87885f 100644 (file)
@@ -21,8 +21,6 @@ Does not support
 
 This driver does yet support the following features.
 
--  NUMA support
--  RSS/multiple queues
 -  VLAN filter
 
 Prerequisites
@@ -31,8 +29,8 @@ Prerequisites
 -  This code is tested with vfio-pci driver installed with Ubuntu 18.04
    which has kernel version 4.15.0-33-generic.
 
--  This code is tested with ESXi vSwitch version 6.0, release build
-   3620759.
+-  This code is tested with ESXi vSwitch version 6.5/6.7 for LRO/TSO support,
+   VMware Workstation 15 Pro (no LRO/TSO), and VMware Fusion 11 Pro (no LRO/TSO).
 
 -  Driver requires MSI-X interrupt support, which is not supported by
    uio_pci_generic driver, so vfio-pci needs to be used. On systems
@@ -45,7 +43,7 @@ VMware Fusion for Mac
 VMware fusion does not have a menu option to change the default driver (e1000)
 to the **vmxnet3** driver. VPP supports the **vmxnet3** driver.
 
-These instructions describe how to change the e100 driver for VMware fusion.
+These instructions describe how to change the e1000 driver for VMware fusion.
 
 * From the VMware Fusion menu bar select **Window** then **Virtual Machine Library**.
 * From the Virtual Machine menu right click on the Virtual Machine you are using and select **Show in Finder**
@@ -56,9 +54,25 @@ These instructions describe how to change the e100 driver for VMware fusion.
 If you are concerned more with configuration not performance the vmxnet3 driver can be set to
 **interrupt** mode in VPP. This will save a great deal on battery usage. Do this with the following
 
+VMware Workstatiom PRO 15 for Linux
+-----------------------------------
+
+VMware Workstation does not have a menu option to change the default driver (e1000)
+to the **vmxnet3** driver. VPP supports the **vmxnet3** driver.
+
+These instructions describe how to change the e1000 driver for VMware Workstation PRO 15 Linux. You may need to be a superuser for performing these steps.
+
+* Shut down the VM you are about to change.
+* From the vmware folder where vmware creates and stores the VM's, change the directory to the specific VM which you want to modify, and use your favorite text editor to open the corresponding VM's .vmx file. By default, it is $HOME/vmware/<vm-name>/<vm-name>.vmx
+* Locate the line for the interface which you want to modify. For example, if it is ethernet1, then change the line **ethernet1.virtualDev = "e1000"** to **ethernet1.virtualDev = "vmxnet3"**
+* Save the file and power on the VM.
+
+If you are concerned more with configuration not performance the vmxnet3 driver can be set to
+**interrupt** mode in VPP. This will save a great deal on battery usage. Do this with the following
+
 .. code-block:: console
 
-    # vppctl set interface rx-mode <interface> interrupt
+    $ sudo vppctl set interface rx-mode <interface> interrupt
 
 
 System setup
@@ -72,6 +86,15 @@ Load VFIO driver
 
     $ sudo modprobe vfio-pci
 
+Make sure the interface is down
+
+.. code-block:: console
+
+    $ sudo ifconfig <if-name> down
+
+The next 2 steps are optional and may be accomplished by specifying the optional "bind" keyword
+when creating the vmxnet3 interface.
+
 For systems without IOMMU only, enable unsafe NOIOMMU mode
 
 .. code-block:: console
@@ -80,7 +103,7 @@ For systems without IOMMU only, enable unsafe NOIOMMU mode
 
 To bind interface to vfio-pci first install the :ref:`configutil`. This will download
 the dpdk_devbind.py script. It is located in */usr/vpp/vpp-config/scripts* with Centos
-and */usr/local/vpp/vpp-config/scripts* with Ubuntu. 
+and */usr/local/vpp/vpp-config/scripts* with Ubuntu.
 
 Bind the driver with the following commands:
 
@@ -105,12 +128,13 @@ Bind the driver with the following commands:
 Interface Creation
 ~~~~~~~~~~~~~~~~~~
 
-Now create the interface dynamically with following:
+Now create the interface dynamically with following. The bind option must be specified if pci is
+not already bound manually by above steps.
 
 .. code-block:: console
 
-    $ sudo vppctl create interface vmxnet3 0000:0b:00.0
-    $ sudo set int state vmxnet3-0/b/0/0 up
+    $ sudo vppctl create interface vmxnet3 0000:0b:00.0 bind
+    $ sudo vppctl set interface state vmxnet3-0/b/0/0 up
 
 Interface Deletion
 ~~~~~~~~~~~~~~~~~~
@@ -119,7 +143,7 @@ If the interface needs to be deleted:
 
 .. code-block:: console
 
-    $ sudo delete interface vmxnet3 <if-name>
+    $ sudo vppctl delete interface vmxnet3 <if-name>
 
 Show vmxnet3
 ~~~~~~~~~~~~
@@ -131,7 +155,7 @@ For example:
 
 .. code-block:: console
 
-    $ sudo vppctl show vmxnet
+    $ sudo vppctl show vmxnet3
     Interface: vmxnet3-0/b/0/0 (ifindex 1)
       Version: 1
       PCI Address: 0000:0b:00.0