[PATCH 1/8] drm/xe/guc: Add more KLV helper macros

Piotr Piórkowski piotr.piorkowski at intel.com
Tue May 14 06:57:28 UTC 2024


Michal Wajdeczko <michal.wajdeczko at intel.com> wrote on pon [2024-maj-06 15:38:07 +0200]:
> In upcoming patches we will want to generate some of the KLV keys
> from other macros. Add MAKE_GUC_KLV_{KEY|LEN} macros for that and
> make sure they will correctly expand provided TAG parameter. Also
> fix PREP_GUC_KLV_TAG to also work correctly within other macros.
> 
> Signed-off-by: Michal Wajdeczko <michal.wajdeczko at intel.com>
> ---
>  drivers/gpu/drm/xe/xe_guc_klv_helpers.h | 15 ++++++++++++++-
>  1 file changed, 14 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/gpu/drm/xe/xe_guc_klv_helpers.h b/drivers/gpu/drm/xe/xe_guc_klv_helpers.h
> index b835e0ebe6db..c676d21c173b 100644
> --- a/drivers/gpu/drm/xe/xe_guc_klv_helpers.h
> +++ b/drivers/gpu/drm/xe/xe_guc_klv_helpers.h
> @@ -6,6 +6,7 @@
>  #ifndef _XE_GUC_KLV_HELPERS_H_
>  #define _XE_GUC_KLV_HELPERS_H_
>  
> +#include <linux/args.h>
>  #include <linux/types.h>
>  
>  struct drm_printer;
> @@ -37,6 +38,18 @@ int xe_guc_klv_count(const u32 *klvs, u32 num_dwords);
>  	(FIELD_PREP_CONST(GUC_KLV_0_KEY, (key)) | \
>  	 FIELD_PREP_CONST(GUC_KLV_0_LEN, (len)))
>  
> +/**
> + * MAKE_GUC_KLV_KEY - Prepare KLV KEY name based on unique KLV definition tag.
> + * @TAG: unique tag of the KLV definition
> + */
> +#define MAKE_GUC_KLV_KEY(TAG) CONCATENATE(CONCATENATE(GUC_KLV_, TAG), _KEY)
> +
> +/**
> + * MAKE_GUC_KLV_LEN - Prepare KLV LEN name based on unique KLV definition tag.
> + * @TAG: unique tag of the KLV definition
> + */
> +#define MAKE_GUC_KLV_LEN(TAG) CONCATENATE(CONCATENATE(GUC_KLV_, TAG), _LEN)
> +
>  /**
>   * PREP_GUC_KLV_TAG - Prepare KLV header value based on unique KLV definition tag.
>   * @TAG: unique tag of the KLV definition
> @@ -46,6 +59,6 @@ int xe_guc_klv_count(const u32 *klvs, u32 num_dwords);
>   * Return: value of the KLV header (u32).
>   */
>  #define PREP_GUC_KLV_TAG(TAG) \
> -	PREP_GUC_KLV_CONST(GUC_KLV_##TAG##_KEY, GUC_KLV_##TAG##_LEN)
> +	PREP_GUC_KLV_CONST(MAKE_GUC_KLV_KEY(TAG), MAKE_GUC_KLV_LEN(TAG))
>  
>  #endif

LGTM:
Reviewed-by: Piotr Piórkowski <piotr.piorkowski at intel.com>


> -- 
> 2.43.0
> 

-- 


More information about the Intel-xe mailing list