From: Ian Stokes <ian.sto...@intel.com>

QV tools are affected by two issues:
- Diagnostic tests do not end and cannot be aborted
- Celo hangs after tests start
Reason is that huge timeout dedicated to FPGA was applied. This patch is
adjusting the code to QV compilation flags and use correct timeout.

Signed-off-by: Fabio Pricoco <fabio.pric...@intel.com>
Signed-off-by: Ian Stokes <ian.sto...@intel.com>
---
 drivers/net/ice/base/ice_common.c | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)

diff --git a/drivers/net/ice/base/ice_common.c 
b/drivers/net/ice/base/ice_common.c
index df827c26e4..cc84b8a6ec 100644
--- a/drivers/net/ice/base/ice_common.c
+++ b/drivers/net/ice/base/ice_common.c
@@ -1139,7 +1139,7 @@ void ice_deinit_hw(struct ice_hw *hw)
  */
 int ice_check_reset(struct ice_hw *hw)
 {
-       u32 cnt, reg = 0, grst_timeout, uld_mask;
+       u32 cnt, reg = 0, grst_timeout, uld_mask, reset_wait_cnt;
 
        /* Poll for Device Active state in case a recent CORER, GLOBR,
         * or EMPR has occurred. The grst delay value is in 100ms units.
@@ -1170,8 +1170,10 @@ int ice_check_reset(struct ice_hw *hw)
 
        uld_mask = ICE_RESET_DONE_MASK;
 
+       reset_wait_cnt = ICE_PF_RESET_WAIT_COUNT;
+
        /* Device is Active; check Global Reset processes are done */
-       for (cnt = 0; cnt < ICE_PF_RESET_WAIT_COUNT; cnt++) {
+       for (cnt = 0; cnt < reset_wait_cnt; cnt++) {
                reg = rd32(hw, GLNVM_ULD) & uld_mask;
                if (reg == uld_mask) {
                        ice_debug(hw, ICE_DBG_INIT, "Global reset processes 
done. %d\n", cnt);
@@ -1180,7 +1182,7 @@ int ice_check_reset(struct ice_hw *hw)
                ice_msec_delay(10, true);
        }
 
-       if (cnt == ICE_PF_RESET_WAIT_COUNT) {
+       if (cnt == reset_wait_cnt) {
                ice_debug(hw, ICE_DBG_INIT, "Wait for Reset Done timed out. 
GLNVM_ULD = 0x%x\n",
                          reg);
                return ICE_ERR_RESET_FAILED;
-- 
2.43.0

Reply via email to