* [dts] [PATCH V1] test_plans/vf_interrupt_pmd_test_plan:Modify test plan
@ 2019-08-05 8:34 zhang,yan
2019-08-05 8:45 ` Zhu, WenhuiX
0 siblings, 1 reply; 3+ messages in thread
From: zhang,yan @ 2019-08-05 8:34 UTC (permalink / raw)
To: dts; +Cc: yuwei1.zhang, zhang,yan
Modify test_plan.
Signed-off-by: zhang,yan <yanx.a.zhang@intel.com>
---
test_plans/vf_interrupt_pmd_test_plan.rst | 131 +++++++++-------------
1 file changed, 51 insertions(+), 80 deletions(-)
diff --git a/test_plans/vf_interrupt_pmd_test_plan.rst b/test_plans/vf_interrupt_pmd_test_plan.rst
index 1c4bb7d..6464ebc 100644
--- a/test_plans/vf_interrupt_pmd_test_plan.rst
+++ b/test_plans/vf_interrupt_pmd_test_plan.rst
@@ -1,4 +1,4 @@
-.. Copyright (c) <2017>, Intel Corporation
+.. Copyright (c) <2017-2019>, Intel Corporation
All rights reserved.
Redistribution and use in source and binary forms, with or without
@@ -49,123 +49,94 @@ Prerequisites
Each of the 10Gb Ethernet* ports of the DUT is directly connected in
full-duplex to a different port of the peer traffic generator.
-Assume PF port PCI addresses are 0000:04:00.0 and 0000:04:00.1, their
-Interfaces name are p786p1 and p786p2. Assume generated VF PCI address will
-be 0000:04:10.0, 0000:04:10.1.
+Assume PF port PCI addresses is 0000:04:00.0, their
+Interfaces name is p786p0. Assume generated VF PCI address will
+be 0000:04:10.0.
Iommu pass through feature has been enabled in kernel::
- intel_iommu=on iommu=pt
+ intel_iommu=on iommu=pt
-Support igb_uio and vfio driver, if used vfio, kernel need 3.6+ and enable vt-d
-in bios. When used vfio, requested to insmod two drivers vfio and vfio-pci.
-
-Test Case1: VF interrupt pmd in VM with uio
-===========================================
-
-Create one VF per Port in host and add these two VFs into VM::
-
-
- usertools/dpdk-devbind.py --force --bind=vfio-pci 0000:04:00.0 0000:04:00.1
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.0/max_vfs
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/max_vfs
- usertools/dpdk-devbind.py --force --bind=pci-stub 0000:04:10.0 0000:04:10.1
-
-Start VM and start l3fwd-power with one queue per port in VM::
+Modify the DPDK-l3fwd-power source code and recompile the l3fwd-power::
+ sed -i -e '/DEV_RX_OFFLOAD_CHECKSUM,/d' ./examples/l3fwd-power/main.c
- l3fwd-power -c 7 -n 4 -- -p 0x3 -P --config="(0,0,1),(1,0,2)"
+ export RTE_TARGET=x86_64-native-linuxapp-gcc
+ export RTE_SDK=`/root/DPDK`
+ make -C examples/l3fwd-power
-Send one packet to VF0 and VF1, check that thread on core1 and core2 waked up::
-
-
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq0
-
-Check the packet has been normally forwarded.
-
-After the packet forwarded, thread on core1 and core 2 will return to sleep::
-
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq0 triggers
+Support igb_uio and vfio driver, if used vfio, kernel need 3.6+ and enable vt-d
+in bios. When used vfio, requested to insmod two drivers vfio and vfio-pci.
-Send packet flows to VF0 and VF1, check that thread on core1 and core2 will
-keep up awake.
+Test Case1: Check Interrupt for PF with vfio driver on ixgbe and i40e
+=====================================================================
-Test Case2: VF interrupt pmd in Host with uio
-=============================================
+1. Bind NIC PF to igb_uio drvier::
-Create one VF per Port in host and make sure PF interface up
-uses kernel driver to create vf::
+ modprobe vfio-pci;
+ usertools/dpdk-devbind.py --bind=igb-uio 0000:04:00.0
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
+2. start l3fwd-power with PF::
-Bind VF device to igb_uio::
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
- ./usertools/dpdk-devbind.py --bind=igb_uio 0000:04:10.0 0000:04:10.1
+ sendp([Ether(dst='pf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')], iface="tester_intf")
-Start host and start l3fwd-power with one queue per port in host::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue 0
+4. Check if threads on core 2 have returned to sleep mode::
- l3fwd-power -c 7 -n 4 -- -p 0x3 -P --config="(0,0,1),(1,0,2)"
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
-Send one packet to VF0 and VF1, check that thread on core1 and core2 waked up::
+Test Case2: Check Interrupt for PF with igb_uio driver on ixgbe and i40e
+========================================================================
+1. Bind NIC PF to igb_uio drvier::
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq0
+ modprobe uio;
+ insmod x86_64-native-linuxapp-gcc/kmod/igb_uio.ko;
-Check the packet has been normally forwarded.
+ usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:00.0
-After the packet forwarded, thread on core1 and core 2 will return to sleep::
+2. start l3fwd-power with PF::
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq0 triggers
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
-Send packet flows to VF0 and VF1, check that thread on core1 and core2 will
-keep up awake.
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
-Test Case3: VF interrupt pmd in Host with vfio
-==============================================
+ sendp([Ether(dst='pf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')], iface="tester_intf")
-Create one VF per Port in host and make sure PF interface up
-uses kernel driver to create vf::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue 0
+4. Check if threads on core 2 have returned to sleep mode::
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
-Bind VF device to host igb_uio::
+Test Case3: Check Interrupt for VF with vfio driver on ixgbe and i40e
+=====================================================================
+1. Generate NIC VF, then bind it to vfio drvier::
- ./usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:10.0 0000:04:10.1
+ echo 1 > /sys/bus/pci/devices/0000\:04\:00.0/sriov_numvfs
-Start VM and start l3fwd-power with two queues per port in VM::
+ modprobe vfio-pci
+ usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:10.0(vf_pci)
+ Notice: If your PF is kernel driver, make sure PF link is up when your start testpmd on VF.
- l3fwd-power -c 1f -n 4 -- -p 0x3 -P \
- --config="(0,0,1),(0,1,2)(1,0,3),(1,1,4)"
+2. Start l3fwd-power with VF::
-Send packets with increased dest IP to Port0 and Port1, check that thread on
-core1,core2,core3,core4 waked up::
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq1
- L3FWD_POWER: lcore 3 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 4 is waked up from rx interrupt on port1,rxq1
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
-Check the packet has been normally forwarded.
+ sendp([Ether(dst='vf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')], iface="tester_intf")
-After the packet forwarded, thread on core1,core2,core3,core4 will return to
-sleep::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue 0
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq1 triggers
- L3FWD_POWER: lcore 3 sleeps until interrupt on port1,rxq0 triggers
- L3FWD_POWER: lcore 4 sleeps until interrupt on port1,rxq1 triggers
+4. Check if threads on core 2 have returned to sleep mode::
-Send packet flows to Port0 and Port1, check that thread on core1,core2,core3,
-core4 will keep up awake.
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
--
2.17.2
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [dts] [PATCH V1] test_plans/vf_interrupt_pmd_test_plan:Modify test plan
2019-08-05 8:34 [dts] [PATCH V1] test_plans/vf_interrupt_pmd_test_plan:Modify test plan zhang,yan
@ 2019-08-05 8:45 ` Zhu, WenhuiX
2019-08-06 1:58 ` Zhang, Yuwei1
0 siblings, 1 reply; 3+ messages in thread
From: Zhu, WenhuiX @ 2019-08-05 8:45 UTC (permalink / raw)
To: Zhang, YanX A, dts; +Cc: Zhang, Yuwei1, Zhang, YanX A
Tested-by: Zhu, WenhuiX <wenhuix.zhu@intel.com>
-----Original Message-----
From: dts [mailto:dts-bounces@dpdk.org] On Behalf Of zhang,yan
Sent: Monday, August 5, 2019 4:34 PM
To: dts@dpdk.org
Cc: Zhang, Yuwei1 <yuwei1.zhang@intel.com>; Zhang, YanX A <yanx.a.zhang@intel.com>
Subject: [dts] [PATCH V1] test_plans/vf_interrupt_pmd_test_plan:Modify test plan
Modify test_plan.
Signed-off-by: zhang,yan <yanx.a.zhang@intel.com>
---
test_plans/vf_interrupt_pmd_test_plan.rst | 131 +++++++++-------------
1 file changed, 51 insertions(+), 80 deletions(-)
diff --git a/test_plans/vf_interrupt_pmd_test_plan.rst b/test_plans/vf_interrupt_pmd_test_plan.rst
index 1c4bb7d..6464ebc 100644
--- a/test_plans/vf_interrupt_pmd_test_plan.rst
+++ b/test_plans/vf_interrupt_pmd_test_plan.rst
@@ -1,4 +1,4 @@
-.. Copyright (c) <2017>, Intel Corporation
+.. Copyright (c) <2017-2019>, Intel Corporation
All rights reserved.
Redistribution and use in source and binary forms, with or without @@ -49,123 +49,94 @@ Prerequisites Each of the 10Gb Ethernet* ports of the DUT is directly connected in full-duplex to a different port of the peer traffic generator.
-Assume PF port PCI addresses are 0000:04:00.0 and 0000:04:00.1, their -Interfaces name are p786p1 and p786p2. Assume generated VF PCI address will -be 0000:04:10.0, 0000:04:10.1.
+Assume PF port PCI addresses is 0000:04:00.0, their Interfaces name is
+p786p0. Assume generated VF PCI address will be 0000:04:10.0.
Iommu pass through feature has been enabled in kernel::
- intel_iommu=on iommu=pt
+ intel_iommu=on iommu=pt
-Support igb_uio and vfio driver, if used vfio, kernel need 3.6+ and enable vt-d -in bios. When used vfio, requested to insmod two drivers vfio and vfio-pci.
-
-Test Case1: VF interrupt pmd in VM with uio -===========================================
-
-Create one VF per Port in host and add these two VFs into VM::
-
-
- usertools/dpdk-devbind.py --force --bind=vfio-pci 0000:04:00.0 0000:04:00.1
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.0/max_vfs
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/max_vfs
- usertools/dpdk-devbind.py --force --bind=pci-stub 0000:04:10.0 0000:04:10.1
-
-Start VM and start l3fwd-power with one queue per port in VM::
+Modify the DPDK-l3fwd-power source code and recompile the l3fwd-power::
+ sed -i -e '/DEV_RX_OFFLOAD_CHECKSUM,/d'
+ ./examples/l3fwd-power/main.c
- l3fwd-power -c 7 -n 4 -- -p 0x3 -P --config="(0,0,1),(1,0,2)"
+ export RTE_TARGET=x86_64-native-linuxapp-gcc
+ export RTE_SDK=`/root/DPDK`
+ make -C examples/l3fwd-power
-Send one packet to VF0 and VF1, check that thread on core1 and core2 waked up::
-
-
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq0
-
-Check the packet has been normally forwarded.
-
-After the packet forwarded, thread on core1 and core 2 will return to sleep::
-
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq0 triggers
+Support igb_uio and vfio driver, if used vfio, kernel need 3.6+ and
+enable vt-d in bios. When used vfio, requested to insmod two drivers vfio and vfio-pci.
-Send packet flows to VF0 and VF1, check that thread on core1 and core2 will -keep up awake.
+Test Case1: Check Interrupt for PF with vfio driver on ixgbe and i40e
+=====================================================================
-Test Case2: VF interrupt pmd in Host with uio -=============================================
+1. Bind NIC PF to igb_uio drvier::
-Create one VF per Port in host and make sure PF interface up -uses kernel driver to create vf::
+ modprobe vfio-pci;
+ usertools/dpdk-devbind.py --bind=igb-uio 0000:04:00.0
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
+2. start l3fwd-power with PF::
-Bind VF device to igb_uio::
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
- ./usertools/dpdk-devbind.py --bind=igb_uio 0000:04:10.0 0000:04:10.1
+
+ sendp([Ether(dst='pf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')],
+ iface="tester_intf")
-Start host and start l3fwd-power with one queue per port in host::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue
+ 0
+4. Check if threads on core 2 have returned to sleep mode::
- l3fwd-power -c 7 -n 4 -- -p 0x3 -P --config="(0,0,1),(1,0,2)"
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
-Send one packet to VF0 and VF1, check that thread on core1 and core2 waked up::
+Test Case2: Check Interrupt for PF with igb_uio driver on ixgbe and
+i40e
+=======================================================================
+=
+1. Bind NIC PF to igb_uio drvier::
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq0
+ modprobe uio;
+ insmod x86_64-native-linuxapp-gcc/kmod/igb_uio.ko;
-Check the packet has been normally forwarded.
+ usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:00.0
-After the packet forwarded, thread on core1 and core 2 will return to sleep::
+2. start l3fwd-power with PF::
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq0 triggers
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
-Send packet flows to VF0 and VF1, check that thread on core1 and core2 will -keep up awake.
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
-Test Case3: VF interrupt pmd in Host with vfio -==============================================
+
+ sendp([Ether(dst='pf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')],
+ iface="tester_intf")
-Create one VF per Port in host and make sure PF interface up -uses kernel driver to create vf::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue
+ 0
+4. Check if threads on core 2 have returned to sleep mode::
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
-Bind VF device to host igb_uio::
+Test Case3: Check Interrupt for VF with vfio driver on ixgbe and i40e
+=====================================================================
+1. Generate NIC VF, then bind it to vfio drvier::
- ./usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:10.0 0000:04:10.1
+ echo 1 > /sys/bus/pci/devices/0000\:04\:00.0/sriov_numvfs
-Start VM and start l3fwd-power with two queues per port in VM::
+ modprobe vfio-pci
+ usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:10.0(vf_pci)
+ Notice: If your PF is kernel driver, make sure PF link is up when your start testpmd on VF.
- l3fwd-power -c 1f -n 4 -- -p 0x3 -P \
- --config="(0,0,1),(0,1,2)(1,0,3),(1,1,4)"
+2. Start l3fwd-power with VF::
-Send packets with increased dest IP to Port0 and Port1, check that thread on
-core1,core2,core3,core4 waked up::
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq1
- L3FWD_POWER: lcore 3 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 4 is waked up from rx interrupt on port1,rxq1
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
-Check the packet has been normally forwarded.
+
+ sendp([Ether(dst='vf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')],
+ iface="tester_intf")
-After the packet forwarded, thread on core1,core2,core3,core4 will return to
-sleep::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue
+ 0
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq1 triggers
- L3FWD_POWER: lcore 3 sleeps until interrupt on port1,rxq0 triggers
- L3FWD_POWER: lcore 4 sleeps until interrupt on port1,rxq1 triggers
+4. Check if threads on core 2 have returned to sleep mode::
-Send packet flows to Port0 and Port1, check that thread on core1,core2,core3,
-core4 will keep up awake.
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
--
2.17.2
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [dts] [PATCH V1] test_plans/vf_interrupt_pmd_test_plan:Modify test plan
2019-08-05 8:45 ` Zhu, WenhuiX
@ 2019-08-06 1:58 ` Zhang, Yuwei1
0 siblings, 0 replies; 3+ messages in thread
From: Zhang, Yuwei1 @ 2019-08-06 1:58 UTC (permalink / raw)
To: Zhu, WenhuiX, Zhang, YanX A, dts; +Cc: Zhang, YanX A
Acked-by: Zhang, Yuwei
-----Original Message-----
From: Zhu, WenhuiX
Sent: Monday, August 5, 2019 4:46 PM
To: Zhang, YanX A <yanx.a.zhang@intel.com>; dts@dpdk.org
Cc: Zhang, Yuwei1 <yuwei1.zhang@intel.com>; Zhang, YanX A <yanx.a.zhang@intel.com>
Subject: RE: [dts] [PATCH V1] test_plans/vf_interrupt_pmd_test_plan:Modify test plan
Tested-by: Zhu, WenhuiX <wenhuix.zhu@intel.com>
-----Original Message-----
From: dts [mailto:dts-bounces@dpdk.org] On Behalf Of zhang,yan
Sent: Monday, August 5, 2019 4:34 PM
To: dts@dpdk.org
Cc: Zhang, Yuwei1 <yuwei1.zhang@intel.com>; Zhang, YanX A <yanx.a.zhang@intel.com>
Subject: [dts] [PATCH V1] test_plans/vf_interrupt_pmd_test_plan:Modify test plan
Modify test_plan.
Signed-off-by: zhang,yan <yanx.a.zhang@intel.com>
---
test_plans/vf_interrupt_pmd_test_plan.rst | 131 +++++++++-------------
1 file changed, 51 insertions(+), 80 deletions(-)
diff --git a/test_plans/vf_interrupt_pmd_test_plan.rst b/test_plans/vf_interrupt_pmd_test_plan.rst
index 1c4bb7d..6464ebc 100644
--- a/test_plans/vf_interrupt_pmd_test_plan.rst
+++ b/test_plans/vf_interrupt_pmd_test_plan.rst
@@ -1,4 +1,4 @@
-.. Copyright (c) <2017>, Intel Corporation
+.. Copyright (c) <2017-2019>, Intel Corporation
All rights reserved.
Redistribution and use in source and binary forms, with or without @@ -49,123 +49,94 @@ Prerequisites Each of the 10Gb Ethernet* ports of the DUT is directly connected in full-duplex to a different port of the peer traffic generator.
-Assume PF port PCI addresses are 0000:04:00.0 and 0000:04:00.1, their -Interfaces name are p786p1 and p786p2. Assume generated VF PCI address will -be 0000:04:10.0, 0000:04:10.1.
+Assume PF port PCI addresses is 0000:04:00.0, their Interfaces name is
+p786p0. Assume generated VF PCI address will be 0000:04:10.0.
Iommu pass through feature has been enabled in kernel::
- intel_iommu=on iommu=pt
+ intel_iommu=on iommu=pt
-Support igb_uio and vfio driver, if used vfio, kernel need 3.6+ and enable vt-d -in bios. When used vfio, requested to insmod two drivers vfio and vfio-pci.
-
-Test Case1: VF interrupt pmd in VM with uio -===========================================
-
-Create one VF per Port in host and add these two VFs into VM::
-
-
- usertools/dpdk-devbind.py --force --bind=vfio-pci 0000:04:00.0 0000:04:00.1
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.0/max_vfs
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/max_vfs
- usertools/dpdk-devbind.py --force --bind=pci-stub 0000:04:10.0 0000:04:10.1
-
-Start VM and start l3fwd-power with one queue per port in VM::
+Modify the DPDK-l3fwd-power source code and recompile the l3fwd-power::
+ sed -i -e '/DEV_RX_OFFLOAD_CHECKSUM,/d'
+ ./examples/l3fwd-power/main.c
- l3fwd-power -c 7 -n 4 -- -p 0x3 -P --config="(0,0,1),(1,0,2)"
+ export RTE_TARGET=x86_64-native-linuxapp-gcc
+ export RTE_SDK=`/root/DPDK`
+ make -C examples/l3fwd-power
-Send one packet to VF0 and VF1, check that thread on core1 and core2 waked up::
-
-
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq0
-
-Check the packet has been normally forwarded.
-
-After the packet forwarded, thread on core1 and core 2 will return to sleep::
-
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq0 triggers
+Support igb_uio and vfio driver, if used vfio, kernel need 3.6+ and
+enable vt-d in bios. When used vfio, requested to insmod two drivers vfio and vfio-pci.
-Send packet flows to VF0 and VF1, check that thread on core1 and core2 will -keep up awake.
+Test Case1: Check Interrupt for PF with vfio driver on ixgbe and i40e
+=====================================================================
-Test Case2: VF interrupt pmd in Host with uio -=============================================
+1. Bind NIC PF to igb_uio drvier::
-Create one VF per Port in host and make sure PF interface up -uses kernel driver to create vf::
+ modprobe vfio-pci;
+ usertools/dpdk-devbind.py --bind=igb-uio 0000:04:00.0
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
+2. start l3fwd-power with PF::
-Bind VF device to igb_uio::
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
- ./usertools/dpdk-devbind.py --bind=igb_uio 0000:04:10.0 0000:04:10.1
+
+ sendp([Ether(dst='pf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')],
+ iface="tester_intf")
-Start host and start l3fwd-power with one queue per port in host::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue
+ 0
+4. Check if threads on core 2 have returned to sleep mode::
- l3fwd-power -c 7 -n 4 -- -p 0x3 -P --config="(0,0,1),(1,0,2)"
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
-Send one packet to VF0 and VF1, check that thread on core1 and core2 waked up::
+Test Case2: Check Interrupt for PF with igb_uio driver on ixgbe and
+i40e
+=======================================================================
+=
+1. Bind NIC PF to igb_uio drvier::
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq0
+ modprobe uio;
+ insmod x86_64-native-linuxapp-gcc/kmod/igb_uio.ko;
-Check the packet has been normally forwarded.
+ usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:00.0
-After the packet forwarded, thread on core1 and core 2 will return to sleep::
+2. start l3fwd-power with PF::
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq0 triggers
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
-Send packet flows to VF0 and VF1, check that thread on core1 and core2 will -keep up awake.
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
-Test Case3: VF interrupt pmd in Host with vfio -==============================================
+
+ sendp([Ether(dst='pf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')],
+ iface="tester_intf")
-Create one VF per Port in host and make sure PF interface up -uses kernel driver to create vf::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue
+ 0
+4. Check if threads on core 2 have returned to sleep mode::
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
- echo 1 >/sys/bus/pci/devices/0000\:04\:00.1/sriov_numvf
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
-Bind VF device to host igb_uio::
+Test Case3: Check Interrupt for VF with vfio driver on ixgbe and i40e
+=====================================================================
+1. Generate NIC VF, then bind it to vfio drvier::
- ./usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:10.0 0000:04:10.1
+ echo 1 > /sys/bus/pci/devices/0000\:04\:00.0/sriov_numvfs
-Start VM and start l3fwd-power with two queues per port in VM::
+ modprobe vfio-pci
+ usertools/dpdk-devbind.py --bind=vfio-pci 0000:04:10.0(vf_pci)
+ Notice: If your PF is kernel driver, make sure PF link is up when your start testpmd on VF.
- l3fwd-power -c 1f -n 4 -- -p 0x3 -P \
- --config="(0,0,1),(0,1,2)(1,0,3),(1,1,4)"
+2. Start l3fwd-power with VF::
-Send packets with increased dest IP to Port0 and Port1, check that thread on
-core1,core2,core3,core4 waked up::
+ examples/l3fwd-power/build/l3fwd-power -l 1-3 -n 4 -- -P -p 0x01 --config '(0,0,2)'
- L3FWD_POWER: lcore 1 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 2 is waked up from rx interrupt on port1,rxq1
- L3FWD_POWER: lcore 3 is waked up from rx interrupt on port1,rxq0
- L3FWD_POWER: lcore 4 is waked up from rx interrupt on port1,rxq1
+3. Send packet with packet generator to the pf NIC, check that thread core2 waked up::
-Check the packet has been normally forwarded.
+
+ sendp([Ether(dst='vf_mac')/IP()/UDP()/Raw(load='XXXXXXXXXXXXXXXXXX')],
+ iface="tester_intf")
-After the packet forwarded, thread on core1,core2,core3,core4 will return to
-sleep::
+ L3FWD_POWER: lcore 2 is waked up from rx interrupt on port 0 queue
+ 0
- L3FWD_POWER: lcore 1 sleeps until interrupt on port0,rxq0 triggers
- L3FWD_POWER: lcore 2 sleeps until interrupt on port0,rxq1 triggers
- L3FWD_POWER: lcore 3 sleeps until interrupt on port1,rxq0 triggers
- L3FWD_POWER: lcore 4 sleeps until interrupt on port1,rxq1 triggers
+4. Check if threads on core 2 have returned to sleep mode::
-Send packet flows to Port0 and Port1, check that thread on core1,core2,core3,
-core4 will keep up awake.
+ L3FWD_POWER: lcore 2 sleeps until interrupt triggers
--
2.17.2
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2019-08-06 1:58 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-08-05 8:34 [dts] [PATCH V1] test_plans/vf_interrupt_pmd_test_plan:Modify test plan zhang,yan
2019-08-05 8:45 ` Zhu, WenhuiX
2019-08-06 1:58 ` Zhang, Yuwei1
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).