[Intel-gfx] [RFC] drm/i915/rc6: Access RC6 regs with forcewake
Nilawar, Badal
badal.nilawar at intel.com
Mon Apr 25 04:25:57 UTC 2022
On 22-04-2022 21:04, Matt Roper wrote:
> On Fri, Apr 22, 2022 at 07:07:52PM +0530, Badal Nilawar wrote:
>> To access RC6 related MMIO regs use intel_uncore_write(), which grabs
>> forcewake if reg requires a forcewake.
>>
>> Signed-off-by: Badal Nilawar <badal.nilawar at intel.com>
>> ---
>> drivers/gpu/drm/i915/gt/intel_rc6.c | 2 +-
>> 1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/drivers/gpu/drm/i915/gt/intel_rc6.c b/drivers/gpu/drm/i915/gt/intel_rc6.c
>> index b4770690e794..9edaad3f19b5 100644
>> --- a/drivers/gpu/drm/i915/gt/intel_rc6.c
>> +++ b/drivers/gpu/drm/i915/gt/intel_rc6.c
>> @@ -55,7 +55,7 @@ static struct drm_i915_private *rc6_to_i915(struct intel_rc6 *rc)
>>
>> static void set(struct intel_uncore *uncore, i915_reg_t reg, u32 val)
>> {
>> - intel_uncore_write_fw(uncore, reg, val);
>> + intel_uncore_write(uncore, reg, val);
>
> The set() function is primarily used within the *_rc6_enable() functions.
> Those are all called via intel_rc6_enable() which has already
> grabbed explicit forcewake before calling them:
>
> intel_uncore_forcewake_get(uncore, FORCEWAKE_ALL);
>
> so there's no need to grab an additional reference on every register
> access. Likewise, the call in vlv_residency_raw() doesn't need
> forcewake because its own caller (intel_rc6_residency_ns) has already
> acquired it.
>
> I think the call in intel_rc6_unpark() is the only one that might be
> questionable from a very quick skim of the code. So rather than
> needlessly grabbing forcewake in all the other spots, it's probably
> better to just replace that single call with a direct call to
> intel_uncore_write() if it actually is problematic.
>
> Even better, we might just want to drop the set() wrapper completely and
> replace all instances with the appropriate intel_uncore_write[_fw]
> calls; I don't really see the slightly shorter lines the wrapper gives
> us as being worth the deviation from the rest of the driver's code
> (especially if it's causing us confusion about what the intendended
> forcewake semantics are).
>
Thanks for clarification.
The change in set() function was done for inte_rc6_unpark/park() only
since 0xA090 RC6_CTRL is getting written without forcewake. For now as
you suggested in inte_rc6_unpark/park() I will replace set() with
intel_uncore_write().
Regards,
Badal
>
> Matt
>
>> }
>>
>> static void gen11_rc6_enable(struct intel_rc6 *rc6)
>> --
>> 2.25.1
>>
>
More information about the Intel-gfx
mailing list