drm/i915/hwmon: Enable PL1 limit when writing limit value to HW
authorAshutosh Dixit <ashutosh.dixit@intel.com>
Thu, 16 Feb 2023 16:49:44 +0000 (08:49 -0800)
committerRodrigo Vivi <rodrigo.vivi@intel.com>
Thu, 16 Feb 2023 21:53:51 +0000 (16:53 -0500)
Previous documentation suggested that the PL1 power limit is always enabled
in HW. However we now find this not to be the case on some platforms (such
as ATSM). Therefore enable the PL1 power limit (by setting the enable bit)
when writing the PL1 limit value to HW.

Bspec: 51864

Signed-off-by: Ashutosh Dixit <ashutosh.dixit@intel.com>
Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230216164944.2366150-3-ashutosh.dixit@intel.com
drivers/gpu/drm/i915/i915_hwmon.c

index 85195d61f89c735d0f9758ab2b707da901098dff..7c20a6f47b92edbea0f4386221366c981f18082f 100644 (file)
@@ -385,10 +385,11 @@ hwm_power_max_write(struct hwm_drvdata *ddat, long val)
 
        /* Computation in 64-bits to avoid overflow. Round to nearest. */
        nval = DIV_ROUND_CLOSEST_ULL((u64)val << hwmon->scl_shift_power, SF_POWER);
+       nval = PKG_PWR_LIM_1_EN | REG_FIELD_PREP(PKG_PWR_LIM_1, nval);
 
        hwm_locked_with_pm_intel_uncore_rmw(ddat, hwmon->rg.pkg_rapl_limit,
-                                           PKG_PWR_LIM_1,
-                                           REG_FIELD_PREP(PKG_PWR_LIM_1, nval));
+                                           PKG_PWR_LIM_1_EN | PKG_PWR_LIM_1,
+                                           nval);
        return 0;
 }