提交 e72cb7d6 编写于 作者: M Michael Chan 提交者: David S. Miller

bnxt_en: Fix compile error regression with CONFIG_BNXT_SRIOV not set.

Add a new function bnxt_get_registered_vfs() to handle the work
of getting the number of registered VFs under #ifdef CONFIG_BNXT_SRIOV.
The main code will call this function and will always work correctly
whether CONFIG_BNXT_SRIOV is set or not.

Fixes: 230d1f0d ("bnxt_en: Handle firmware reset.")
Reported-by: Nkbuild test robot <lkp@intel.com>
Signed-off-by: NMichael Chan <michael.chan@broadcom.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 fd0f75d2
...@@ -10107,34 +10107,56 @@ void bnxt_fw_exception(struct bnxt *bp) ...@@ -10107,34 +10107,56 @@ void bnxt_fw_exception(struct bnxt *bp)
bnxt_rtnl_unlock_sp(bp); bnxt_rtnl_unlock_sp(bp);
} }
void bnxt_fw_reset(struct bnxt *bp) /* Returns the number of registered VFs, or 1 if VF configuration is pending, or
* < 0 on error.
*/
static int bnxt_get_registered_vfs(struct bnxt *bp)
{ {
#ifdef CONFIG_BNXT_SRIOV
int rc; int rc;
if (!BNXT_PF(bp))
return 0;
rc = bnxt_hwrm_func_qcfg(bp);
if (rc) {
netdev_err(bp->dev, "func_qcfg cmd failed, rc = %d\n", rc);
return rc;
}
if (bp->pf.registered_vfs)
return bp->pf.registered_vfs;
if (bp->sriov_cfg)
return 1;
#endif
return 0;
}
void bnxt_fw_reset(struct bnxt *bp)
{
bnxt_rtnl_lock_sp(bp); bnxt_rtnl_lock_sp(bp);
if (test_bit(BNXT_STATE_OPEN, &bp->state) && if (test_bit(BNXT_STATE_OPEN, &bp->state) &&
!test_bit(BNXT_STATE_IN_FW_RESET, &bp->state)) { !test_bit(BNXT_STATE_IN_FW_RESET, &bp->state)) {
int n = 0;
set_bit(BNXT_STATE_IN_FW_RESET, &bp->state); set_bit(BNXT_STATE_IN_FW_RESET, &bp->state);
if (BNXT_PF(bp) && bp->pf.active_vfs && if (bp->pf.active_vfs &&
!test_bit(BNXT_STATE_FW_FATAL_COND, &bp->state)) { !test_bit(BNXT_STATE_FW_FATAL_COND, &bp->state))
rc = bnxt_hwrm_func_qcfg(bp); n = bnxt_get_registered_vfs(bp);
if (rc) { if (n < 0) {
netdev_err(bp->dev, "Firmware reset aborted, first func_qcfg cmd failed, rc = %d\n", netdev_err(bp->dev, "Firmware reset aborted, rc = %d\n",
rc); n);
clear_bit(BNXT_STATE_IN_FW_RESET, &bp->state); clear_bit(BNXT_STATE_IN_FW_RESET, &bp->state);
dev_close(bp->dev); dev_close(bp->dev);
goto fw_reset_exit; goto fw_reset_exit;
} } else if (n > 0) {
if (bp->pf.registered_vfs || bp->sriov_cfg) { u16 vf_tmo_dsecs = n * 10;
u16 vf_tmo_dsecs = bp->pf.registered_vfs * 10;
if (bp->fw_reset_max_dsecs < vf_tmo_dsecs)
if (bp->fw_reset_max_dsecs < vf_tmo_dsecs) bp->fw_reset_max_dsecs = vf_tmo_dsecs;
bp->fw_reset_max_dsecs = vf_tmo_dsecs; bp->fw_reset_state =
bp->fw_reset_state = BNXT_FW_RESET_STATE_POLL_VF;
BNXT_FW_RESET_STATE_POLL_VF; bnxt_queue_fw_reset_work(bp, HZ / 10);
bnxt_queue_fw_reset_work(bp, HZ / 10); goto fw_reset_exit;
goto fw_reset_exit;
}
} }
bnxt_fw_reset_close(bp); bnxt_fw_reset_close(bp);
bp->fw_reset_state = BNXT_FW_RESET_STATE_ENABLE_DEV; bp->fw_reset_state = BNXT_FW_RESET_STATE_ENABLE_DEV;
...@@ -10579,22 +10601,21 @@ static void bnxt_fw_reset_task(struct work_struct *work) ...@@ -10579,22 +10601,21 @@ static void bnxt_fw_reset_task(struct work_struct *work)
} }
switch (bp->fw_reset_state) { switch (bp->fw_reset_state) {
case BNXT_FW_RESET_STATE_POLL_VF: case BNXT_FW_RESET_STATE_POLL_VF: {
rc = bnxt_hwrm_func_qcfg(bp); int n = bnxt_get_registered_vfs(bp);
if (rc) {
if (n < 0) {
netdev_err(bp->dev, "Firmware reset aborted, subsequent func_qcfg cmd failed, rc = %d, %d msecs since reset timestamp\n", netdev_err(bp->dev, "Firmware reset aborted, subsequent func_qcfg cmd failed, rc = %d, %d msecs since reset timestamp\n",
rc, jiffies_to_msecs(jiffies - n, jiffies_to_msecs(jiffies -
bp->fw_reset_timestamp)); bp->fw_reset_timestamp));
goto fw_reset_abort; goto fw_reset_abort;
} } else if (n > 0) {
if (bp->pf.registered_vfs || bp->sriov_cfg) {
if (time_after(jiffies, bp->fw_reset_timestamp + if (time_after(jiffies, bp->fw_reset_timestamp +
(bp->fw_reset_max_dsecs * HZ / 10))) { (bp->fw_reset_max_dsecs * HZ / 10))) {
clear_bit(BNXT_STATE_IN_FW_RESET, &bp->state); clear_bit(BNXT_STATE_IN_FW_RESET, &bp->state);
bp->fw_reset_state = 0; bp->fw_reset_state = 0;
netdev_err(bp->dev, "Firmware reset aborted, %d VFs still registered, sriov_cfg %d\n", netdev_err(bp->dev, "Firmware reset aborted, bnxt_get_registered_vfs() returns %d\n",
bp->pf.registered_vfs, n);
bp->sriov_cfg);
return; return;
} }
bnxt_queue_fw_reset_work(bp, HZ / 10); bnxt_queue_fw_reset_work(bp, HZ / 10);
...@@ -10607,6 +10628,7 @@ static void bnxt_fw_reset_task(struct work_struct *work) ...@@ -10607,6 +10628,7 @@ static void bnxt_fw_reset_task(struct work_struct *work)
rtnl_unlock(); rtnl_unlock();
bnxt_queue_fw_reset_work(bp, bp->fw_reset_min_dsecs * HZ / 10); bnxt_queue_fw_reset_work(bp, bp->fw_reset_min_dsecs * HZ / 10);
return; return;
}
case BNXT_FW_RESET_STATE_RESET_FW: { case BNXT_FW_RESET_STATE_RESET_FW: {
u32 wait_dsecs = bp->fw_health->post_reset_wait_dsecs; u32 wait_dsecs = bp->fw_health->post_reset_wait_dsecs;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册