mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-19 19:14:01 +08:00
i40e: Handle admin Q timeout when releasing NVM
There are some rare cases where the release resource call will return an admin Q timeout. In these cases the code needs to try to release the resource again until it succeeds or it times out. Signed-off-by: Paul M Stillwell Jr <paul.m.stillwell.jr@intel.com> Tested-by: Andrew Bowers <andrewx.bowers@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
parent
4d5957cbde
commit
981e25c32b
@ -134,8 +134,25 @@ i40e_i40e_acquire_nvm_exit:
|
||||
**/
|
||||
void i40e_release_nvm(struct i40e_hw *hw)
|
||||
{
|
||||
if (!hw->nvm.blank_nvm_mode)
|
||||
i40e_aq_release_resource(hw, I40E_NVM_RESOURCE_ID, 0, NULL);
|
||||
i40e_status ret_code = I40E_SUCCESS;
|
||||
u32 total_delay = 0;
|
||||
|
||||
if (hw->nvm.blank_nvm_mode)
|
||||
return;
|
||||
|
||||
ret_code = i40e_aq_release_resource(hw, I40E_NVM_RESOURCE_ID, 0, NULL);
|
||||
|
||||
/* there are some rare cases when trying to release the resource
|
||||
* results in an admin Q timeout, so handle them correctly
|
||||
*/
|
||||
while ((ret_code == I40E_ERR_ADMIN_QUEUE_TIMEOUT) &&
|
||||
(total_delay < hw->aq.asq_cmd_timeout)) {
|
||||
usleep_range(1000, 2000);
|
||||
ret_code = i40e_aq_release_resource(hw,
|
||||
I40E_NVM_RESOURCE_ID,
|
||||
0, NULL);
|
||||
total_delay++;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user