mirror of
https://github.com/torvalds/linux.git
synced 2026-05-25 23:52:08 +02:00
drm/i915: Define and compute Transcoder CMRR registers
Add register definitions for Transcoder Fixed Average Vtotal mode/CMRR function, with the necessary bitfields. Compute these registers when CMRR is enabled, extending Adaptive refresh rate capabilities. --v2: - Use intel_de_read64_2x32 in intel_vrr_get_config. [Jani] - Fix indent and order based on register offset. [Jani] --v3: - Removing RFC tag. --v4: - Update place holder for CMRR register definition. (Jani) --v5: - Add CMRR register definitions to a separate file intel_vrr_reg.h. --v6: - Fixed indentation. (Jani) - Add dependency header intel_display_reg_defs.h. (Jani) - Rename file name to intel_vrr_regs.h instead of reg.h (Jani) --v7: - Remove adding CMRR flag to vrr_ctl register during set_transcoder_timing, as it is already being done during intel_vrr_enable. (Ankit) Signed-off-by: Mitul Golani <mitulkumar.ajitkumar.golani@intel.com> Reviewed-by: Ankit Nautiyal <ankit.k.nautiyal@intel.com> Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20240610072203.24956-4-mitulkumar.ajitkumar.golani@intel.com
This commit is contained in:
parent
6eb8276188
commit
0617334033
|
|
@ -1006,6 +1006,13 @@ static bool vrr_params_changed(const struct intel_crtc_state *old_crtc_state,
|
|||
old_crtc_state->vrr.pipeline_full != new_crtc_state->vrr.pipeline_full;
|
||||
}
|
||||
|
||||
static bool cmrr_params_changed(const struct intel_crtc_state *old_crtc_state,
|
||||
const struct intel_crtc_state *new_crtc_state)
|
||||
{
|
||||
return old_crtc_state->cmrr.cmrr_m != new_crtc_state->cmrr.cmrr_m ||
|
||||
old_crtc_state->cmrr.cmrr_n != new_crtc_state->cmrr.cmrr_n;
|
||||
}
|
||||
|
||||
static bool vrr_enabling(const struct intel_crtc_state *old_crtc_state,
|
||||
const struct intel_crtc_state *new_crtc_state)
|
||||
{
|
||||
|
|
@ -5078,6 +5085,16 @@ intel_pipe_config_compare(const struct intel_crtc_state *current_config,
|
|||
} \
|
||||
} while (0)
|
||||
|
||||
#define PIPE_CONF_CHECK_LLI(name) do { \
|
||||
if (current_config->name != pipe_config->name) { \
|
||||
pipe_config_mismatch(&p, fastset, crtc, __stringify(name), \
|
||||
"(expected %lli, found %lli)", \
|
||||
current_config->name, \
|
||||
pipe_config->name); \
|
||||
ret = false; \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define PIPE_CONF_CHECK_BOOL(name) do { \
|
||||
if (current_config->name != pipe_config->name) { \
|
||||
BUILD_BUG_ON_MSG(!__same_type(current_config->name, bool), \
|
||||
|
|
@ -5456,10 +5473,13 @@ intel_pipe_config_compare(const struct intel_crtc_state *current_config,
|
|||
PIPE_CONF_CHECK_I(vrr.guardband);
|
||||
PIPE_CONF_CHECK_I(vrr.vsync_start);
|
||||
PIPE_CONF_CHECK_I(vrr.vsync_end);
|
||||
PIPE_CONF_CHECK_LLI(cmrr.cmrr_m);
|
||||
PIPE_CONF_CHECK_LLI(cmrr.cmrr_n);
|
||||
}
|
||||
|
||||
#undef PIPE_CONF_CHECK_X
|
||||
#undef PIPE_CONF_CHECK_I
|
||||
#undef PIPE_CONF_CHECK_LLI
|
||||
#undef PIPE_CONF_CHECK_BOOL
|
||||
#undef PIPE_CONF_CHECK_P
|
||||
#undef PIPE_CONF_CHECK_FLAGS
|
||||
|
|
@ -6848,7 +6868,8 @@ static void intel_pre_update_crtc(struct intel_atomic_state *state,
|
|||
intel_crtc_needs_fastset(new_crtc_state))
|
||||
icl_set_pipe_chicken(new_crtc_state);
|
||||
|
||||
if (vrr_params_changed(old_crtc_state, new_crtc_state))
|
||||
if (vrr_params_changed(old_crtc_state, new_crtc_state) ||
|
||||
cmrr_params_changed(old_crtc_state, new_crtc_state))
|
||||
intel_vrr_set_transcoder_timings(new_crtc_state);
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -1402,6 +1402,12 @@ struct intel_crtc_state {
|
|||
u32 vsync_end, vsync_start;
|
||||
} vrr;
|
||||
|
||||
/* Content Match Refresh Rate state */
|
||||
struct {
|
||||
bool enable;
|
||||
u64 cmrr_n, cmrr_m;
|
||||
} cmrr;
|
||||
|
||||
/* Stream Splitter for eDP MSO */
|
||||
struct {
|
||||
bool enable;
|
||||
|
|
|
|||
|
|
@ -219,6 +219,17 @@ void intel_vrr_set_transcoder_timings(const struct intel_crtc_state *crtc_state)
|
|||
return;
|
||||
}
|
||||
|
||||
if (crtc_state->cmrr.enable) {
|
||||
intel_de_write(dev_priv, TRANS_CMRR_M_HI(dev_priv, cpu_transcoder),
|
||||
upper_32_bits(crtc_state->cmrr.cmrr_m));
|
||||
intel_de_write(dev_priv, TRANS_CMRR_M_LO(dev_priv, cpu_transcoder),
|
||||
lower_32_bits(crtc_state->cmrr.cmrr_m));
|
||||
intel_de_write(dev_priv, TRANS_CMRR_N_HI(dev_priv, cpu_transcoder),
|
||||
upper_32_bits(crtc_state->cmrr.cmrr_n));
|
||||
intel_de_write(dev_priv, TRANS_CMRR_N_LO(dev_priv, cpu_transcoder),
|
||||
lower_32_bits(crtc_state->cmrr.cmrr_n));
|
||||
}
|
||||
|
||||
intel_de_write(dev_priv, TRANS_VRR_VMIN(dev_priv, cpu_transcoder),
|
||||
crtc_state->vrr.vmin - 1);
|
||||
intel_de_write(dev_priv, TRANS_VRR_VMAX(dev_priv, cpu_transcoder),
|
||||
|
|
@ -307,6 +318,15 @@ void intel_vrr_get_config(struct intel_crtc_state *crtc_state)
|
|||
|
||||
crtc_state->vrr.enable = trans_vrr_ctl & VRR_CTL_VRR_ENABLE;
|
||||
|
||||
if (crtc_state->cmrr.enable) {
|
||||
crtc_state->cmrr.cmrr_n =
|
||||
intel_de_read64_2x32(dev_priv, TRANS_CMRR_N_LO(dev_priv, cpu_transcoder),
|
||||
TRANS_CMRR_N_HI(dev_priv, cpu_transcoder));
|
||||
crtc_state->cmrr.cmrr_m =
|
||||
intel_de_read64_2x32(dev_priv, TRANS_CMRR_M_LO(dev_priv, cpu_transcoder),
|
||||
TRANS_CMRR_M_HI(dev_priv, cpu_transcoder));
|
||||
}
|
||||
|
||||
if (DISPLAY_VER(dev_priv) >= 13)
|
||||
crtc_state->vrr.guardband =
|
||||
REG_FIELD_GET(XELPD_VRR_CTL_VRR_GUARDBAND_MASK, trans_vrr_ctl);
|
||||
|
|
|
|||
|
|
@ -108,4 +108,18 @@
|
|||
#define VRR_VSYNC_START_MASK REG_GENMASK(12, 0)
|
||||
#define VRR_VSYNC_START(vsync_start) REG_FIELD_PREP(VRR_VSYNC_START_MASK, (vsync_start))
|
||||
|
||||
/*CMRR Registers*/
|
||||
|
||||
#define _TRANS_CMRR_M_LO_A 0x604F0
|
||||
#define TRANS_CMRR_M_LO(dev_priv, trans) _MMIO_TRANS2(dev_priv, trans, _TRANS_CMRR_M_LO_A)
|
||||
|
||||
#define _TRANS_CMRR_M_HI_A 0x604F4
|
||||
#define TRANS_CMRR_M_HI(dev_priv, trans) _MMIO_TRANS2(dev_priv, trans, _TRANS_CMRR_M_HI_A)
|
||||
|
||||
#define _TRANS_CMRR_N_LO_A 0x604F8
|
||||
#define TRANS_CMRR_N_LO(dev_priv, trans) _MMIO_TRANS2(dev_priv, trans, _TRANS_CMRR_N_LO_A)
|
||||
|
||||
#define _TRANS_CMRR_N_HI_A 0x604FC
|
||||
#define TRANS_CMRR_N_HI(dev_priv, trans) _MMIO_TRANS2(dev_priv, trans, _TRANS_CMRR_N_HI_A)
|
||||
|
||||
#endif /* __INTEL_VRR_REGS__ */
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user