[PATCH] drm/i915: Add debug print about hw config table size

Daniele Ceraolo Spurio daniele.ceraolospurio at intel.com
Tue Dec 24 19:10:04 UTC 2024




On 12/24/2024 10:13 AM, John Harrison wrote:
> On 12/23/2024 15:20, Daniele Ceraolo Spurio wrote:
>> On 12/20/2024 5:19 PM, John.C.Harrison at Intel.com wrote:
>>> From: John Harrison<John.C.Harrison at Intel.com>
>>>
>>> Add debug info to help investigate a very rare bug:
>>>    https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/13385
>>>
>>> Signed-off-by: John Harrison<John.C.Harrison at Intel.com>
>>> ---
>>>   drivers/gpu/drm/i915/gt/uc/intel_guc_hwconfig.c | 3 +++
>>>   1 file changed, 3 insertions(+)
>>>
>>> diff --git a/drivers/gpu/drm/i915/gt/uc/intel_guc_hwconfig.c b/drivers/gpu/drm/i915/gt/uc/intel_guc_hwconfig.c
>>> index b67a15f742762..868195c33f5b3 100644
>>> --- a/drivers/gpu/drm/i915/gt/uc/intel_guc_hwconfig.c
>>> +++ b/drivers/gpu/drm/i915/gt/uc/intel_guc_hwconfig.c
>>> @@ -7,6 +7,7 @@
>>>   #include "gt/intel_hwconfig.h"
>>>   #include "i915_drv.h"
>>>   #include "i915_memcpy.h"
>>> +#include "intel_guc_print.h"
>>>   
>>>   /*
>>>    * GuC has a blob containing hardware configuration information (HWConfig).
>>> @@ -42,6 +43,8 @@ static int __guc_action_get_hwconfig(struct intel_guc *guc,
>>>   	};
>>>   	int ret;
>>>   
>>> +	guc_dbg(guc, "Querying HW config table: size = %d, offset = 0x%08X\n",
>>> +		ggtt_size, ggtt_offset);
>>
>> This seems to result in a double-log where the first print has no 
>> useful information, e.g.:
>>
>> [drm:__guc_action_get_hwconfig [i915]] GT0: GUC: Querying HW config 
>> table: size = 0, offset = 0x00000000
>> [drm:__guc_action_get_hwconfig [i915]] GT0: GUC: Querying HW config 
>> table: size = 752, offset = 0x00D05000
>>
>> Given that only the second log is useful, IMO better to move the 
>> guc_dbg to guc_hwconfig_fill_buffer(), because the info needed for 
>> the second print is available there and it is only called once.
> I disagree that the first print has no useful information. It tells us 
> that a call is being made and these are the parameters. We do not know 
> what the failure is. It seems highly unlikely that the size changes 
> from query to the next given that the table is a fixed entity. It is 
> much more likely to be a caching type issue with GuC reading data the 
> KMD did not write. If so, GuC could potentially read non-zero data for 
> the initial size query and complain that data is invalid.
>
> The intention is to report all calls with their parameters to try to 
> narrow down exactly what calls are not working.

But we don't need both prints to know which of the 2 calls has failed, 
if the error comes before we get the second print then we know the 
failure was in the first call, otherwise it was in the second.

Daniele

>
> John.
>
>
>>
>> Daniele
>>
>>>   	ret = intel_guc_send_mmio(guc, action, ARRAY_SIZE(action), NULL, 0);
>>>   	if (ret == -ENXIO)
>>>   		return -ENOENT;
>>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/dri-devel/attachments/20241224/a3284960/attachment-0001.htm>


More information about the dri-devel mailing list