Commit a617b304 authored by Matt Atwood's avatar Matt Atwood Committed by Rodrigo Vivi

drm/xe: Add infrastructure for per engine tuning

Add the infrastructure for per engine tuning in preparation for disable
indirect state.

v3: Rebase
v4: Fix rebasing issues
Reviewed-by: default avatarMatt Roper <matthew.d.roper@intel.com>
Signed-off-by: default avatarMatt Atwood <matthew.s.atwood@intel.com>
Signed-off-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
parent 3a13c2de
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
#include "xe_reg_sr.h" #include "xe_reg_sr.h"
#include "xe_rtp.h" #include "xe_rtp.h"
#include "xe_sched_job.h" #include "xe_sched_job.h"
#include "xe_tuning.h"
#include "xe_wa.h" #include "xe_wa.h"
#define MAX_MMIO_BASES 3 #define MAX_MMIO_BASES 3
...@@ -405,6 +406,7 @@ static void hw_engine_init_early(struct xe_gt *gt, struct xe_hw_engine *hwe, ...@@ -405,6 +406,7 @@ static void hw_engine_init_early(struct xe_gt *gt, struct xe_hw_engine *hwe,
} }
xe_reg_sr_init(&hwe->reg_sr, hwe->name, gt_to_xe(gt)); xe_reg_sr_init(&hwe->reg_sr, hwe->name, gt_to_xe(gt));
xe_tuning_process_engine(hwe);
xe_wa_process_engine(hwe); xe_wa_process_engine(hwe);
hw_engine_setup_default_state(hwe); hw_engine_setup_default_state(hwe);
......
...@@ -27,6 +27,10 @@ static const struct xe_rtp_entry_sr gt_tunings[] = { ...@@ -27,6 +27,10 @@ static const struct xe_rtp_entry_sr gt_tunings[] = {
{} {}
}; };
static const struct xe_rtp_entry_sr engine_tunings[] = {
{}
};
static const struct xe_rtp_entry_sr lrc_tunings[] = { static const struct xe_rtp_entry_sr lrc_tunings[] = {
{ XE_RTP_NAME("Tuning: ganged timer, also known as 16011163337"), { XE_RTP_NAME("Tuning: ganged timer, also known as 16011163337"),
XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210), ENGINE_CLASS(RENDER)), XE_RTP_RULES(GRAPHICS_VERSION_RANGE(1200, 1210), ENGINE_CLASS(RENDER)),
...@@ -65,6 +69,14 @@ void xe_tuning_process_gt(struct xe_gt *gt) ...@@ -65,6 +69,14 @@ void xe_tuning_process_gt(struct xe_gt *gt)
} }
EXPORT_SYMBOL_IF_KUNIT(xe_tuning_process_gt); EXPORT_SYMBOL_IF_KUNIT(xe_tuning_process_gt);
void xe_tuning_process_engine(struct xe_hw_engine *hwe)
{
struct xe_rtp_process_ctx ctx = XE_RTP_PROCESS_CTX_INITIALIZER(hwe);
xe_rtp_process_to_sr(&ctx, engine_tunings, &hwe->reg_sr);
}
EXPORT_SYMBOL_IF_KUNIT(xe_tuning_process_engine);
/** /**
* xe_tuning_process_lrc - process lrc tunings * xe_tuning_process_lrc - process lrc tunings
* @hwe: engine instance to process tunings for * @hwe: engine instance to process tunings for
......
...@@ -10,6 +10,7 @@ struct xe_gt; ...@@ -10,6 +10,7 @@ struct xe_gt;
struct xe_hw_engine; struct xe_hw_engine;
void xe_tuning_process_gt(struct xe_gt *gt); void xe_tuning_process_gt(struct xe_gt *gt);
void xe_tuning_process_engine(struct xe_hw_engine *hwe);
void xe_tuning_process_lrc(struct xe_hw_engine *hwe); void xe_tuning_process_lrc(struct xe_hw_engine *hwe);
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment