[dpdk-dev] [PATCH v6 0/4] support reset of VF link
Luca Boccassi
lboccass at Brocade.com
Mon Jul 4 17:48:08 CEST 2016
On Mon, 2016-06-20 at 14:24 +0800, Wenzhuo Lu wrote:
> If the PF link is down and up, VF link will not work accordingly.
> This patch set addes the support of VF link reset. So, when VF
> receices the messges of physical link down/up. APP can reset the
> VF link and let it recover.
>
> PS: This patch set is splitted from a previous patch set,
> *automatic link recovery on ixgbe/igb VF*, and it's base on the
> patch set *support mailbox interruption on ixgbe/igb VF*.
>
> Wenzhuo Lu (3):
> lib/librte_ether: support device reset
> ixgbe: implement device reset on VF
> igb: implement device reset on VF
>
> Zhe Tao (1):
> i40e: implement device reset on VF
>
> v1:
> - Added the implementation for the VF reset functionality.
> v2:
> - Changed the i40e related operations during VF reset.
> v3:
> - Resent the patches because of the mail sent issue.
> v4:
> - Removed some VF reset emulation code.
> v5:
> - Removed all the code related with lock.
> v6:
> - Updated the NIC feature overview matrix.
> - Added more explanation in the doxygen comment of reset API.
>
> doc/guides/nics/overview.rst | 1 +
> doc/guides/rel_notes/release_16_07.rst | 13 ++++++
> drivers/net/e1000/igb_ethdev.c | 59 ++++++++++++++++++++++++
> drivers/net/i40e/i40e_ethdev.h | 4 ++
> drivers/net/i40e/i40e_ethdev_vf.c | 83 ++++++++++++++++++++++++++++++++++
> drivers/net/i40e/i40e_rxtx.c | 10 ++++
> drivers/net/i40e/i40e_rxtx.h | 4 ++
> drivers/net/ixgbe/ixgbe_ethdev.c | 64 +++++++++++++++++++++++++-
> drivers/net/ixgbe/ixgbe_ethdev.h | 2 +-
> drivers/net/ixgbe/ixgbe_rxtx.c | 12 +++--
> lib/librte_ether/rte_ethdev.c | 17 +++++++
> lib/librte_ether/rte_ethdev.h | 24 ++++++++++
> lib/librte_ether/rte_ether_version.map | 7 +++
> 13 files changed, 295 insertions(+), 5 deletions(-)
Hello Wenzhuo,
I'm testing this patchset, but I am sporadically running into an issue
where the VFs reset fails after the PF flaps.
I have a VM running on a KVM box with a X540-AT2, passing 2 VFs in.
I am using calling rte_eth_dev_reset in response to a
RTE_ETH_EVENT_INTR_RESET callback, and the following errors appear in
the log:
PMD: ixgbevf_dev_reset(): Ixgbe VF reset: Failed to update link.
PMD: ixgbe_alloc_rx_queue_mbufs(): RX mbuf alloc failed queue_id=0
PMD: ixgbevf_dev_start(): Unable to initialize RX hardware (-12)
PMD: ixgbevf_dev_reset(): Ixgbe VF reset: Failed to start device.
Jumping in with GDB, it seems that the rte_rxmbuf_alloc call in
ixgbe_alloc_rx_queue_mbufs returns NULL at iteration 64 out of 2048.
The application has ~500 2MB hugepages, and there's 2GB of free memory
available on top of that.
Have you seen this before? Any pointer or suggestion for debugging?
Thanks!
--
Kind regards,
Luca Boccassi
More information about the dev
mailing list