aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/intel/ice/ice_main.c
diff options
context:
space:
mode:
authorDave Ertman <david.m.ertman@intel.com>2019-02-13 13:51:08 -0500
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>2019-03-25 13:12:21 -0400
commit2ebd4428d93a2f6ce0c813b10a1a43b6a8241fe5 (patch)
tree9dba3b17190f0d6772c8e8baca61824f91082ddd /drivers/net/ethernet/intel/ice/ice_main.c
parenta65f71fed5add2ec5713fcc605842f5f2dff22a3 (diff)
ice: Prevent unintended multiple chain resets
In the current implementation of ice_reset_subtask, if multiple reset types are set in the pf->state, the most intrusive one is meant to be performed only, but the bits requesting the other types are not being cleared. This would lead to another reset being performed the next time the service task is scheduled. Change the flow of ice_reset_subtask so that all reset request bits in pf->state are cleared, and we still perform the most intrusive of the resets requested. Signed-off-by: Dave Ertman <david.m.ertman@intel.com> Signed-off-by: Anirudh Venkataramanan <anirudh.venkataramanan@intel.com> Tested-by: Andrew Bowers <andrewx.bowers@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Diffstat (limited to 'drivers/net/ethernet/intel/ice/ice_main.c')
-rw-r--r--drivers/net/ethernet/intel/ice/ice_main.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/drivers/net/ethernet/intel/ice/ice_main.c b/drivers/net/ethernet/intel/ice/ice_main.c
index d0ea4d059a05..3588cbb8ccd2 100644
--- a/drivers/net/ethernet/intel/ice/ice_main.c
+++ b/drivers/net/ethernet/intel/ice/ice_main.c
@@ -478,8 +478,14 @@ static void ice_reset_subtask(struct ice_pf *pf)
478 * for the reset now), poll for reset done, rebuild and return. 478 * for the reset now), poll for reset done, rebuild and return.
479 */ 479 */
480 if (test_bit(__ICE_RESET_OICR_RECV, pf->state)) { 480 if (test_bit(__ICE_RESET_OICR_RECV, pf->state)) {
481 clear_bit(__ICE_GLOBR_RECV, pf->state); 481 /* Perform the largest reset requested */
482 clear_bit(__ICE_CORER_RECV, pf->state); 482 if (test_and_clear_bit(__ICE_CORER_RECV, pf->state))
483 reset_type = ICE_RESET_CORER;
484 if (test_and_clear_bit(__ICE_GLOBR_RECV, pf->state))
485 reset_type = ICE_RESET_GLOBR;
486 /* return if no valid reset type requested */
487 if (reset_type == ICE_RESET_INVAL)
488 return;
483 if (!test_bit(__ICE_PREPARED_FOR_RESET, pf->state)) 489 if (!test_bit(__ICE_PREPARED_FOR_RESET, pf->state))
484 ice_prepare_for_reset(pf); 490 ice_prepare_for_reset(pf);
485 491