Commit e6946ea8 authored by Michal Wajdeczko's avatar Michal Wajdeczko
Browse files

drm/xe/guc: Add more KLV helper macros



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.

Reviewed-by: default avatarPiotr Piórkowski <piotr.piorkowski@intel.com>
Signed-off-by: default avatarMichal Wajdeczko <michal.wajdeczko@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240514190015.2172-2-michal.wajdeczko@intel.com
parent 9aa85860
Loading
Loading
Loading
Loading
+14 −1
Original line number Diff line number Diff line
@@ -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