On 7/21/2021 10:25 AM, Michal Wajdeczko wrote:
On 21.07.2021 18:11, Vinay Belgaumkar wrote:
Add constants and params that are needed to configure SLPC.
v2: Add a new abi header for SLPC. Replace bitfields with genmasks. Address other comments from Michal W.
Signed-off-by: Vinay Belgaumkar vinay.belgaumkar@intel.com Signed-off-by: Sundaresan Sujaritha sujaritha.sundaresan@intel.com
.../drm/i915/gt/uc/abi/guc_actions_slpc_abi.h | 201 ++++++++++++++++++ drivers/gpu/drm/i915/gt/uc/intel_guc.c | 4 + drivers/gpu/drm/i915/gt/uc/intel_guc_fwif.h | 1 + 3 files changed, 206 insertions(+) create mode 100644 drivers/gpu/drm/i915/gt/uc/abi/guc_actions_slpc_abi.h
diff --git a/drivers/gpu/drm/i915/gt/uc/abi/guc_actions_slpc_abi.h b/drivers/gpu/drm/i915/gt/uc/abi/guc_actions_slpc_abi.h new file mode 100644 index 000000000000..05d809746b32 --- /dev/null +++ b/drivers/gpu/drm/i915/gt/uc/abi/guc_actions_slpc_abi.h @@ -0,0 +1,201 @@ +/* SPDX-License-Identifier: MIT */ +/*
- Copyright © 2021 Intel Corporation
- */
+#ifndef _GUC_ACTIONS_SLPC_ABI_H_ +#define _GUC_ACTIONS_SLPC_ABI_H_
+#include <linux/types.h>
+/**
- SLPC SHARED DATA STRUCTURE
if you want to use kernel-doc, then add DOC: tag
ok.
- +---+-------+--------------------------------------------------------------+
- | CL| Bytes | Description |
- +===+=======+==============================================================+
- | 1 | 0-3 | SHARED DATA SIZE |
- | +-------+--------------------------------------------------------------+
- | | 4-7 | GLOBAL STATE |
- | +-------+--------------------------------------------------------------+
- | | 8-11 | DISPLAY DATA ADDRESS |
- | +-------+--------------------------------------------------------------+
- | | 12:63 | PADDING |
- +---+-------+--------------------------------------------------------------+
- | | 0:63 | PADDING(PLATFORM INFO) |
- +---+-------+--------------------------------------------------------------+
- | 3 | 0-3 | TASK STATE DATA |
- +-------+--------------------------------------------------------------+
- | | 4:63 | PADDING |
- +---+-------+--------------------------------------------------------------+
- |4-21 0:1087| OVERRIDE PARAMS AND BIT FIELDS |
^^^^^
something didn't work here
Fixed.
- +---+-------+--------------------------------------------------------------+
- | | | PADDING + EXTRA RESERVED PAGE |
- +---+-------+--------------------------------------------------------------+
- */
+/*
- SLPC exposes certain parameters for global configuration by the host.
- These are referred to as override parameters, because in most cases
- the host will not need to modify the default values used by SLPC.
- SLPC remembers the default values which allows the host to easily restore
- them by simply unsetting the override. The host can set or unset override
- parameters during SLPC (re-)initialization using the SLPC Reset event.
- The host can also set or unset override parameters on the fly using the
- Parameter Set and Parameter Unset events
- */
+#define SLPC_MAX_OVERRIDE_PARAMETERS 256 +#define SLPC_OVERRIDE_BITFIELD_SIZE \
(SLPC_MAX_OVERRIDE_PARAMETERS / 32)
+#define SLPC_PAGE_SIZE_BYTES 4096 +#define SLPC_CACHELINE_SIZE_BYTES 64 +#define SLPC_SHARED_DATA_SIZE_BYTE_HEADER SLPC_CACHELINE_SIZE_BYTES +#define SLPC_SHARED_DATA_SIZE_BYTE_PLATFORM_INFO SLPC_CACHELINE_SIZE_BYTES +#define SLPC_SHARED_DATA_SIZE_BYTE_TASK_STATE SLPC_CACHELINE_SIZE_BYTES +#define SLPC_SHARED_DATA_MODE_DEFN_TABLE_SIZE SLPC_PAGE_SIZE_BYTES +#define SLPC_SHARED_DATA_SIZE_BYTE_MAX (2 * SLPC_PAGE_SIZE_BYTES) +#define SLPC_EVENT(id, argc) ((u32)(id) << 8 | (argc)) +#define SLPC_EVENT_MAX_INPUT_ARGS 9
above two are likely used in H2G SLPC message that is not fully defined, maybe at the end of this file add separate section with H2G format, using plain C #defines, and move SLPC_EVENT helper macro to fwif.h
ok.
+/*
- Cacheline size aligned (Total size needed for
- SLPM_KMD_MAX_OVERRIDE_PARAMETERS=256 is 1088 bytes)
- */
+#define SLPC_OVERRIDE_PARAMS_TOTAL_BYTES (((((SLPC_MAX_OVERRIDE_PARAMETERS * 4) \
+ ((SLPC_MAX_OVERRIDE_PARAMETERS / 32) * 4)) \
+ (SLPC_CACHELINE_SIZE_BYTES-1)) / SLPC_CACHELINE_SIZE_BYTES)*SLPC_CACHELINE_SIZE_BYTES)
+#define SLPC_SHARED_DATA_SIZE_BYTE_OTHER (SLPC_SHARED_DATA_SIZE_BYTE_MAX - \
(SLPC_SHARED_DATA_SIZE_BYTE_HEADER \
+ SLPC_SHARED_DATA_SIZE_BYTE_PLATFORM_INFO \
+ SLPC_SHARED_DATA_SIZE_BYTE_TASK_STATE \
+ SLPC_OVERRIDE_PARAMS_TOTAL_BYTES \
+ SLPC_SHARED_DATA_MODE_DEFN_TABLE_SIZE))
+enum slpc_task_enable {
- SLPC_PARAM_TASK_DEFAULT = 0,
- SLPC_PARAM_TASK_ENABLED,
- SLPC_PARAM_TASK_DISABLED,
- SLPC_PARAM_TASK_UNKNOWN
+};
+enum slpc_global_state {
- SLPC_GLOBAL_STATE_NOT_RUNNING = 0,
- SLPC_GLOBAL_STATE_INITIALIZING = 1,
- SLPC_GLOBAL_STATE_RESETTING = 2,
- SLPC_GLOBAL_STATE_RUNNING = 3,
- SLPC_GLOBAL_STATE_SHUTTING_DOWN = 4,
- SLPC_GLOBAL_STATE_ERROR = 5
+};
+enum slpc_param_id {
- SLPC_PARAM_TASK_ENABLE_GTPERF = 0,
- SLPC_PARAM_TASK_DISABLE_GTPERF = 1,
- SLPC_PARAM_TASK_ENABLE_BALANCER = 2,
- SLPC_PARAM_TASK_DISABLE_BALANCER = 3,
- SLPC_PARAM_TASK_ENABLE_DCC = 4,
- SLPC_PARAM_TASK_DISABLE_DCC = 5,
- SLPC_PARAM_GLOBAL_MIN_GT_UNSLICE_FREQ_MHZ = 6,
- SLPC_PARAM_GLOBAL_MAX_GT_UNSLICE_FREQ_MHZ = 7,
- SLPC_PARAM_GLOBAL_MIN_GT_SLICE_FREQ_MHZ = 8,
- SLPC_PARAM_GLOBAL_MAX_GT_SLICE_FREQ_MHZ = 9,
- SLPC_PARAM_GTPERF_THRESHOLD_MAX_FPS = 10,
- SLPC_PARAM_GLOBAL_DISABLE_GT_FREQ_MANAGEMENT = 11,
- SLPC_PARAM_GTPERF_ENABLE_FRAMERATE_STALLING = 12,
- SLPC_PARAM_GLOBAL_DISABLE_RC6_MODE_CHANGE = 13,
- SLPC_PARAM_GLOBAL_OC_UNSLICE_FREQ_MHZ = 14,
- SLPC_PARAM_GLOBAL_OC_SLICE_FREQ_MHZ = 15,
- SLPC_PARAM_GLOBAL_ENABLE_IA_GT_BALANCING = 16,
- SLPC_PARAM_GLOBAL_ENABLE_ADAPTIVE_BURST_TURBO = 17,
- SLPC_PARAM_GLOBAL_ENABLE_EVAL_MODE = 18,
- SLPC_PARAM_GLOBAL_ENABLE_BALANCER_IN_NON_GAMING_MODE = 19,
- SLPC_PARAM_GLOBAL_RT_MODE_TURBO_FREQ_DELTA_MHZ = 20,
- SLPC_PARAM_PWRGATE_RC_MODE = 21,
- SLPC_PARAM_EDR_MODE_COMPUTE_TIMEOUT_MS = 22,
- SLPC_PARAM_EDR_QOS_FREQ_MHZ = 23,
- SLPC_PARAM_MEDIA_FF_RATIO_MODE = 24,
- SLPC_PARAM_ENABLE_IA_FREQ_LIMITING = 25,
- SLPC_PARAM_STRATEGIES = 26,
- SLPC_PARAM_POWER_PROFILE = 27,
- SLPC_PARAM_IGNORE_EFFICIENT_FREQUENCY = 28,
- SLPC_MAX_PARAM = 32,
+};
+enum slpc_event_id {
- SLPC_EVENT_RESET = 0,
- SLPC_EVENT_SHUTDOWN = 1,
- SLPC_EVENT_PLATFORM_INFO_CHANGE = 2,
- SLPC_EVENT_DISPLAY_MODE_CHANGE = 3,
- SLPC_EVENT_FLIP_COMPLETE = 4,
- SLPC_EVENT_QUERY_TASK_STATE = 5,
- SLPC_EVENT_PARAMETER_SET = 6,
- SLPC_EVENT_PARAMETER_UNSET = 7,
+};
+struct slpc_task_state_data {
- union {
u32 task_status_padding;
struct {
u32 status;
+#define SLPC_GTPERF_TASK_ACTIVE BIT(0) +#define SLPC_GTPERF_STALL_POSSIBLE BIT(1) +#define SLPC_GTPERF_GAMING_MODE BIT(2) +#define SLPC_GTPERF_TARGET_FPS BIT(3) +#define SLPC_DCC_TASK_ACTIVE BIT(4) +#define SLPC_IN_DCC BIT(5) +#define SLPC_IN_DCT BIT(6) +#define SLPC_FREQ_SWITCH_ACTIVE BIT(7) +#define SLPC_IBC_ENABLED BIT(8) +#define SLPC_IBC_ACTIVE BIT(9) +#define SLPC_PG1_ENABLED BIT(10) +#define SLPC_PG1_ACTIVE BIT(11)
};
- };
- union {
u32 freq_padding;
struct {
+#define SLPC_MAX_UNSLICE_FREQ_MASK REG_GENMASK(7, 0) +#define SLPC_MIN_UNSLICE_FREQ_MASK REG_GENMASK(15, 8) +#define SLPC_MAX_SLICE_FREQ_MASK REG_GENMASK(23, 16) +#define SLPC_MIN_SLICE_FREQ_MASK REG_GENMASK(31, 24)
u32 freq;
};
- };
+} __packed;
Added.
+struct slpc_shared_data_header {
- /* Total size in bytes of this shared buffer. */
- u32 size;
- u32 global_state;
- u32 display_data_addr;
+};
__packed ?
added.
+struct slpc_override_params {
- u32 bits[SLPC_OVERRIDE_BITFIELD_SIZE];
- u32 values[SLPC_MAX_OVERRIDE_PARAMETERS];
+};
__packed ?
Added.
+struct slpc_shared_data {
- struct slpc_shared_data_header header;
- u8 shared_data_header_pad[SLPC_SHARED_DATA_SIZE_BYTE_HEADER -
sizeof(struct slpc_shared_data_header)];
- u8 platform_info_pad[SLPC_SHARED_DATA_SIZE_BYTE_PLATFORM_INFO];
- struct slpc_task_state_data task_state_data;
- u8 task_state_data_pad[SLPC_SHARED_DATA_SIZE_BYTE_TASK_STATE -
sizeof(struct slpc_task_state_data)];
- struct slpc_override_params override_params ;
- u8 override_params_pad[SLPC_OVERRIDE_PARAMS_TOTAL_BYTES -
sizeof(struct slpc_override_params)];
- u8 shared_data_pad[SLPC_SHARED_DATA_SIZE_BYTE_OTHER];
- /* PAGE 2 (4096 bytes), mode based parameter will be removed soon */
- u8 reserved_mode_definition[4096];
+} __packed;
+#endif diff --git a/drivers/gpu/drm/i915/gt/uc/intel_guc.c b/drivers/gpu/drm/i915/gt/uc/intel_guc.c index 39bc3c16057b..fcccb103a21a 100644 --- a/drivers/gpu/drm/i915/gt/uc/intel_guc.c +++ b/drivers/gpu/drm/i915/gt/uc/intel_guc.c @@ -203,11 +203,15 @@ static u32 guc_ctl_debug_flags(struct intel_guc *guc)
static u32 guc_ctl_feature_flags(struct intel_guc *guc) {
struct intel_gt *gt = guc_to_gt(guc); u32 flags = 0;
if (!intel_guc_submission_is_used(guc)) flags |= GUC_CTL_DISABLE_SCHEDULER;
if (intel_uc_uses_guc_slpc(>->uc))
we should have intel_guc_uses_slpc()
Done.
Thanks, Vinay.
Thanks, Michal
flags |= GUC_CTL_ENABLE_SLPC;
- return flags; }
diff --git a/drivers/gpu/drm/i915/gt/uc/intel_guc_fwif.h b/drivers/gpu/drm/i915/gt/uc/intel_guc_fwif.h index 82534259b7ad..c3122ca5407b 100644 --- a/drivers/gpu/drm/i915/gt/uc/intel_guc_fwif.h +++ b/drivers/gpu/drm/i915/gt/uc/intel_guc_fwif.h @@ -95,6 +95,7 @@ #define GUC_CTL_WA 1 #define GUC_CTL_FEATURE 2 #define GUC_CTL_DISABLE_SCHEDULER (1 << 14) +#define GUC_CTL_ENABLE_SLPC BIT(2)
#define GUC_CTL_DEBUG 3 #define GUC_LOG_VERBOSITY_SHIFT 0