#define VPGEN_VFRTRIG_VFSWR_M                  BIT(0)
 #define PFHMC_ERRORDATA                                0x00520500
 #define PFHMC_ERRORINFO                                0x00520400
+#define GLINT_CTL                              0x0016CC54
+#define GLINT_CTL_DIS_AUTOMASK_M               BIT(0)
+#define GLINT_CTL_ITR_GRAN_200_S               16
+#define GLINT_CTL_ITR_GRAN_200_M               ICE_M(0xF, 16)
+#define GLINT_CTL_ITR_GRAN_100_S               20
+#define GLINT_CTL_ITR_GRAN_100_M               ICE_M(0xF, 20)
+#define GLINT_CTL_ITR_GRAN_50_S                        24
+#define GLINT_CTL_ITR_GRAN_50_M                        ICE_M(0xF, 24)
+#define GLINT_CTL_ITR_GRAN_25_S                        28
+#define GLINT_CTL_ITR_GRAN_25_M                        ICE_M(0xF, 28)
 #define GLINT_DYN_CTL(_INT)                    (0x00160000 + ((_INT) * 4))
 #define GLINT_DYN_CTL_INTENA_M                 BIT(0)
 #define GLINT_DYN_CTL_CLEARPBA_M               BIT(1)
 
        return 0;
 }
 
+/**
+ * ice_cfg_itr_gran - set the ITR granularity to 2 usecs if not already set
+ * @hw: board specific structure
+ */
+static void ice_cfg_itr_gran(struct ice_hw *hw)
+{
+       u32 regval = rd32(hw, GLINT_CTL);
+
+       /* no need to update global register if ITR gran is already set */
+       if (!(regval & GLINT_CTL_DIS_AUTOMASK_M) &&
+           (((regval & GLINT_CTL_ITR_GRAN_200_M) >>
+            GLINT_CTL_ITR_GRAN_200_S) == ICE_ITR_GRAN_US) &&
+           (((regval & GLINT_CTL_ITR_GRAN_100_M) >>
+            GLINT_CTL_ITR_GRAN_100_S) == ICE_ITR_GRAN_US) &&
+           (((regval & GLINT_CTL_ITR_GRAN_50_M) >>
+            GLINT_CTL_ITR_GRAN_50_S) == ICE_ITR_GRAN_US) &&
+           (((regval & GLINT_CTL_ITR_GRAN_25_M) >>
+             GLINT_CTL_ITR_GRAN_25_S) == ICE_ITR_GRAN_US))
+               return;
+
+       regval = ((ICE_ITR_GRAN_US << GLINT_CTL_ITR_GRAN_200_S) &
+                 GLINT_CTL_ITR_GRAN_200_M) |
+                ((ICE_ITR_GRAN_US << GLINT_CTL_ITR_GRAN_100_S) &
+                 GLINT_CTL_ITR_GRAN_100_M) |
+                ((ICE_ITR_GRAN_US << GLINT_CTL_ITR_GRAN_50_S) &
+                 GLINT_CTL_ITR_GRAN_50_M) |
+                ((ICE_ITR_GRAN_US << GLINT_CTL_ITR_GRAN_25_S) &
+                 GLINT_CTL_ITR_GRAN_25_M);
+       wr32(hw, GLINT_CTL, regval);
+}
+
 /**
  * ice_cfg_itr - configure the initial interrupt throttle values
  * @hw: pointer to the HW structure
 static void
 ice_cfg_itr(struct ice_hw *hw, struct ice_q_vector *q_vector, u16 vector)
 {
+       ice_cfg_itr_gran(hw);
+
        if (q_vector->num_ring_rx) {
                struct ice_ring_container *rc = &q_vector->rx;
 
 
        return 0;
 }
 
-/**
- * ice_verify_itr_gran - verify driver's assumption of ITR granularity
- * @pf: pointer to the PF structure
- *
- * There is no error returned here because the driver will be able to handle a
- * different ITR granularity, but interrupt moderation will not be accurate if
- * the driver's assumptions are not verified. This assumption is made so we can
- * use constants in the hot path instead of accessing structure members.
- */
-static void ice_verify_itr_gran(struct ice_pf *pf)
-{
-       if (pf->hw.itr_gran != (ICE_ITR_GRAN_S << 1))
-               dev_warn(&pf->pdev->dev,
-                        "%d ITR granularity assumption is invalid, actual ITR granularity is %d. Interrupt moderation will be inaccurate!\n",
-                        (ICE_ITR_GRAN_S << 1), pf->hw.itr_gran);
-}
-
 /**
  * ice_verify_cacheline_size - verify driver's assumption of 64 Byte cache lines
  * @pf: pointer to the PF structure
        mod_timer(&pf->serv_tmr, round_jiffies(jiffies + pf->serv_tmr_period));
 
        ice_verify_cacheline_size(pf);
-       ice_verify_itr_gran(pf);
 
        return 0;
 
 
 #define ITR_IS_DYNAMIC(setting) (!!((setting) & ICE_ITR_DYNAMIC))
 #define ITR_TO_REG(setting)    ((setting) & ~ICE_ITR_DYNAMIC)
 #define ICE_ITR_GRAN_S         1       /* Assume ITR granularity is 2us */
+#define ICE_ITR_GRAN_US                BIT(ICE_ITR_GRAN_S)
 #define ICE_ITR_MASK           0x1FFE  /* ITR register value alignment mask */
 #define ITR_REG_ALIGN(setting) __ALIGN_MASK(setting, ~ICE_ITR_MASK)