From: Kalesh AP <kalesh-anakkur.pura...@broadcom.com>

This patch supports proactive error handling mode.

Signed-off-by: Kalesh AP <kalesh-anakkur.pura...@broadcom.com>
Signed-off-by: Somnath Kotur <somnath.ko...@broadcom.com>
Reviewed-by: Ajit Khaparde <ajit.khapa...@broadcom.com>
Reviewed-by: Chengwen Feng <fengcheng...@huawei.com>
---
 drivers/net/bnxt/bnxt_cpr.c    |  4 ++++
 drivers/net/bnxt/bnxt_ethdev.c | 13 ++++++++++++-
 2 files changed, 16 insertions(+), 1 deletion(-)

diff --git a/drivers/net/bnxt/bnxt_cpr.c b/drivers/net/bnxt/bnxt_cpr.c
index 99af0f9e87..5bb376d4d5 100644
--- a/drivers/net/bnxt/bnxt_cpr.c
+++ b/drivers/net/bnxt/bnxt_cpr.c
@@ -180,6 +180,10 @@ void bnxt_handle_async_event(struct bnxt *bp,
                        return;
                }
 
+               rte_eth_dev_callback_process(bp->eth_dev,
+                                            RTE_ETH_EVENT_ERR_RECOVERING,
+                                            NULL);
+
                pthread_mutex_lock(&bp->err_recovery_lock);
                event_data = data1;
                /* timestamp_lo/hi values are in units of 100ms */
diff --git a/drivers/net/bnxt/bnxt_ethdev.c b/drivers/net/bnxt/bnxt_ethdev.c
index 3dfe9efc09..b3de490d36 100644
--- a/drivers/net/bnxt/bnxt_ethdev.c
+++ b/drivers/net/bnxt/bnxt_ethdev.c
@@ -1063,6 +1063,8 @@ static int bnxt_dev_info_get_op(struct rte_eth_dev 
*eth_dev,
        dev_info->vmdq_pool_base = 0;
        dev_info->vmdq_queue_base = 0;
 
+       dev_info->err_handle_mode = RTE_ETH_ERROR_HANDLE_MODE_PROACTIVE;
+
        return 0;
 }
 
@@ -4382,13 +4384,18 @@ static void bnxt_dev_recover(void *arg)
        PMD_DRV_LOG(INFO, "Port: %u Recovered from FW reset\n",
                    bp->eth_dev->data->port_id);
        pthread_mutex_unlock(&bp->err_recovery_lock);
-
+       rte_eth_dev_callback_process(bp->eth_dev,
+                                    RTE_ETH_EVENT_RECOVERY_SUCCESS,
+                                    NULL);
        return;
 err_start:
        bnxt_dev_stop(bp->eth_dev);
 err:
        bp->flags |= BNXT_FLAG_FATAL_ERROR;
        bnxt_uninit_resources(bp, false);
+       rte_eth_dev_callback_process(bp->eth_dev,
+                                    RTE_ETH_EVENT_RECOVERY_FAILED,
+                                    NULL);
        if (bp->eth_dev->data->dev_conf.intr_conf.rmv)
                rte_eth_dev_callback_process(bp->eth_dev,
                                             RTE_ETH_EVENT_INTR_RMV,
@@ -4560,6 +4567,10 @@ static void bnxt_check_fw_health(void *arg)
 
        PMD_DRV_LOG(ERR, "Detected FW dead condition\n");
 
+       rte_eth_dev_callback_process(bp->eth_dev,
+                                    RTE_ETH_EVENT_ERR_RECOVERING,
+                                    NULL);
+
        if (bnxt_is_primary_func(bp))
                wait_msec = info->primary_func_wait_period;
        else
-- 
2.17.1

Reply via email to