Commit 1b5f5d38 authored by Marcin Formela's avatar Marcin Formela Committed by Jeff Kirsher

i40e: fix retrying in i40e_aq_get_phy_capabilities

Fixed a bug where driver was breaking out of the loop and
reporting an error without retrying first.
Signed-off-by: default avatarMarcin Formela <marcin.formela@intel.com>
Tested-by: default avatarAndrew Bowers <andrewx.bowers@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
parent 65c275e4
...@@ -1577,19 +1577,22 @@ i40e_status i40e_aq_get_phy_capabilities(struct i40e_hw *hw, ...@@ -1577,19 +1577,22 @@ i40e_status i40e_aq_get_phy_capabilities(struct i40e_hw *hw,
status = i40e_asq_send_command(hw, &desc, abilities, status = i40e_asq_send_command(hw, &desc, abilities,
abilities_size, cmd_details); abilities_size, cmd_details);
if (status) switch (hw->aq.asq_last_status) {
break; case I40E_AQ_RC_EIO:
if (hw->aq.asq_last_status == I40E_AQ_RC_EIO) {
status = I40E_ERR_UNKNOWN_PHY; status = I40E_ERR_UNKNOWN_PHY;
break; break;
} else if (hw->aq.asq_last_status == I40E_AQ_RC_EAGAIN) { case I40E_AQ_RC_EAGAIN:
usleep_range(1000, 2000); usleep_range(1000, 2000);
total_delay++; total_delay++;
status = I40E_ERR_TIMEOUT; status = I40E_ERR_TIMEOUT;
break;
/* also covers I40E_AQ_RC_OK */
default:
break;
} }
} while ((hw->aq.asq_last_status != I40E_AQ_RC_OK) &&
(total_delay < max_delay)); } while ((hw->aq.asq_last_status == I40E_AQ_RC_EAGAIN) &&
(total_delay < max_delay));
if (status) if (status)
return status; return status;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment