[PATCH] drm/xe/guc: Make creation of SLPC debugfs files conditional
Upadhyay, Tejas
tejas.upadhyay at intel.com
Thu May 15 13:16:25 UTC 2025
> -----Original Message-----
> From: Bhatia, Aradhya <aradhya.bhatia at intel.com>
> Sent: 15 May 2025 15:19
> To: Roper, Matthew D <matthew.d.roper at intel.com>
> Cc: Intel XE List <intel-xe at lists.freedesktop.org>; Upadhyay, Tejas
> <tejas.upadhyay at intel.com>; Ghimiray, Himal Prasad
> <himal.prasad.ghimiray at intel.com>; Bhatia, Aradhya
> <aradhya.bhatia at intel.com>
> Subject: [PATCH] drm/xe/guc: Make creation of SLPC debugfs files conditional
>
> Platforms that do not support SLPC are exempted from the GuC PC support.
> The GuC PC does not get initialized, and neither do its BOs get created.
>
> This causes a problem because the GuC PC debugfs file is still being created.
> Whenever the file is attempted to read, it causes a NULL pointer dereference
> on the supposed BO of the GuC PC.
>
> So, make the creation of SLPC debugfs files conditional to when SLPC features
> are supported.
>
> Suggested-by: Matt Roper <matthew.d.roper at intel.com>
> Signed-off-by: Aradhya Bhatia <aradhya.bhatia at intel.com>
> ---
> drivers/gpu/drm/xe/xe_guc_debugfs.c | 17 ++++++++++++++---
> 1 file changed, 14 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/gpu/drm/xe/xe_guc_debugfs.c
> b/drivers/gpu/drm/xe/xe_guc_debugfs.c
> index f33013f8a0f3..0b102ab46c4d 100644
> --- a/drivers/gpu/drm/xe/xe_guc_debugfs.c
> +++ b/drivers/gpu/drm/xe/xe_guc_debugfs.c
> @@ -113,23 +113,34 @@ static const struct drm_info_list
> vf_safe_debugfs_list[] = {
> { "guc_ctb", .show = guc_debugfs_show, .data = guc_ctb }, };
>
> +/* For GuC debugfs files that require the SLPC support */ static const
> +struct drm_info_list slpc_debugfs_list[] = {
> + { "guc_pc", .show = guc_debugfs_show, .data = guc_pc }, };
> +
> /* everything else should be added here */ static const struct drm_info_list
> pf_only_debugfs_list[] = {
> { "guc_log", .show = guc_debugfs_show, .data = guc_log },
> { "guc_log_dmesg", .show = guc_debugfs_show, .data =
> guc_log_dmesg },
> - { "guc_pc", .show = guc_debugfs_show, .data = guc_pc },
You need fixes tag here it seems. With that,
Reviewed-by: Tejas Upadhyay <tejas.upadhyay at intel.com>
Tejas
> };
>
> void xe_guc_debugfs_register(struct xe_guc *guc, struct dentry *parent) {
> - struct drm_minor *minor = guc_to_xe(guc)->drm.primary;
> + struct xe_device *xe = guc_to_xe(guc);
> + struct drm_minor *minor = xe->drm.primary;
>
> drm_debugfs_create_files(vf_safe_debugfs_list,
> ARRAY_SIZE(vf_safe_debugfs_list),
> parent, minor);
>
> - if (!IS_SRIOV_VF(guc_to_xe(guc)))
> + if (!IS_SRIOV_VF(xe)) {
> drm_debugfs_create_files(pf_only_debugfs_list,
> ARRAY_SIZE(pf_only_debugfs_list),
> parent, minor);
> +
> + if (!xe->info.skip_guc_pc)
> + drm_debugfs_create_files(slpc_debugfs_list,
> +
> ARRAY_SIZE(slpc_debugfs_list),
> + parent, minor);
> + }
> }
>
> base-commit: 3d6670fab64cb00b5e6ed80d2517147db533faf1
> --
> 2.43.0
More information about the Intel-xe
mailing list