net/bnxt: invoke device removal event on recovery failure
When the driver receives RESET_NOTIFY async event from FW or detects a FW fatal error condition, it tries to recover from the error. When the driver fails to recover from the error condition, fixed to send device removal event to the application. Fixes: df6cd7c1f73a ("net/bnxt: handle reset notify async event from FW") Cc: stable@dpdk.org Signed-off-by: Kalesh AP <kalesh-anakkur.purayil@broadcom.com> Reviewed-by: Somnath Kotur <somnath.kotur@broadcom.com> Reviewed-by: Ajit Khaparde <ajit.khaparde@broadcom.com>
This commit is contained in:
parent
70c7d4184c
commit
8ac3cbba62
@ -4347,6 +4347,10 @@ err_start:
|
||||
err:
|
||||
bp->flags |= BNXT_FLAG_FATAL_ERROR;
|
||||
bnxt_uninit_resources(bp, false);
|
||||
if (bp->eth_dev->data->dev_conf.intr_conf.rmv)
|
||||
rte_eth_dev_callback_process(bp->eth_dev,
|
||||
RTE_ETH_EVENT_INTR_RMV,
|
||||
NULL);
|
||||
pthread_mutex_unlock(&bp->err_recovery_lock);
|
||||
PMD_DRV_LOG(ERR, "Failed to recover from FW reset\n");
|
||||
}
|
||||
@ -6501,6 +6505,7 @@ static int bnxt_pci_remove(struct rte_pci_device *pci_dev)
|
||||
static struct rte_pci_driver bnxt_rte_pmd = {
|
||||
.id_table = bnxt_pci_id_map,
|
||||
.drv_flags = RTE_PCI_DRV_NEED_MAPPING | RTE_PCI_DRV_INTR_LSC |
|
||||
RTE_PCI_DRV_INTR_RMV |
|
||||
RTE_PCI_DRV_PROBE_AGAIN, /* Needed in case of VF-REPs
|
||||
* and OVS-DPDK
|
||||
*/
|
||||
|
Loading…
x
Reference in New Issue
Block a user