Commit ba770ce3 authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Eliminate the intel_dp dependency from DRRS

The DRRS code has no use for the intel_dp, replace it with
just a crtc pointer. This is just an intermediate step towards
making DRRS truly per-crtc.
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220311172428.14685-12-ville.syrjala@linux.intel.comReviewed-by: default avatarJani Nikula <jani.nikula@intel.com>
parent a1b952d4
...@@ -2820,7 +2820,7 @@ static void intel_enable_ddi_dp(struct intel_atomic_state *state, ...@@ -2820,7 +2820,7 @@ static void intel_enable_ddi_dp(struct intel_atomic_state *state,
if (!dig_port->lspcon.active || dig_port->dp.has_hdmi_sink) if (!dig_port->lspcon.active || dig_port->dp.has_hdmi_sink)
intel_dp_set_infoframes(encoder, true, crtc_state, conn_state); intel_dp_set_infoframes(encoder, true, crtc_state, conn_state);
intel_drrs_enable(intel_dp, crtc_state); intel_drrs_enable(crtc_state);
if (crtc_state->has_audio) if (crtc_state->has_audio)
intel_audio_codec_enable(encoder, crtc_state, conn_state); intel_audio_codec_enable(encoder, crtc_state, conn_state);
...@@ -2963,7 +2963,7 @@ static void intel_disable_ddi_dp(struct intel_atomic_state *state, ...@@ -2963,7 +2963,7 @@ static void intel_disable_ddi_dp(struct intel_atomic_state *state,
intel_audio_codec_disable(encoder, intel_audio_codec_disable(encoder,
old_crtc_state, old_conn_state); old_crtc_state, old_conn_state);
intel_drrs_disable(intel_dp, old_crtc_state); intel_drrs_disable(old_crtc_state);
intel_psr_disable(intel_dp, old_crtc_state); intel_psr_disable(intel_dp, old_crtc_state);
intel_edp_backlight_off(old_conn_state); intel_edp_backlight_off(old_conn_state);
/* Disable the decompression in DP Sink */ /* Disable the decompression in DP Sink */
...@@ -3013,12 +3013,10 @@ static void intel_ddi_update_pipe_dp(struct intel_atomic_state *state, ...@@ -3013,12 +3013,10 @@ static void intel_ddi_update_pipe_dp(struct intel_atomic_state *state,
const struct intel_crtc_state *crtc_state, const struct intel_crtc_state *crtc_state,
const struct drm_connector_state *conn_state) const struct drm_connector_state *conn_state)
{ {
struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
intel_ddi_set_dp_msa(crtc_state, conn_state); intel_ddi_set_dp_msa(crtc_state, conn_state);
intel_dp_set_infoframes(encoder, true, crtc_state, conn_state); intel_dp_set_infoframes(encoder, true, crtc_state, conn_state);
intel_drrs_update(intel_dp, crtc_state); intel_drrs_update(crtc_state);
intel_backlight_update(state, encoder, crtc_state, conn_state); intel_backlight_update(state, encoder, crtc_state, conn_state);
drm_connector_update_privacy_screen(conn_state); drm_connector_update_privacy_screen(conn_state);
......
...@@ -1161,20 +1161,17 @@ static void drrs_status_per_crtc(struct seq_file *m, ...@@ -1161,20 +1161,17 @@ static void drrs_status_per_crtc(struct seq_file *m,
seq_puts(m, "\n"); seq_puts(m, "\n");
if (to_intel_crtc_state(crtc->base.state)->has_drrs) { if (to_intel_crtc_state(crtc->base.state)->has_drrs) {
struct intel_panel *panel;
mutex_lock(&drrs->mutex); mutex_lock(&drrs->mutex);
/* DRRS Supported */ /* DRRS Supported */
seq_puts(m, "\tDRRS Enabled: Yes\n"); seq_puts(m, "\tDRRS Enabled: Yes\n");
/* disable_drrs() will make drrs->dp NULL */ /* disable_drrs() will make drrs->dp NULL */
if (!drrs->dp) { if (!drrs->crtc) {
seq_puts(m, "Idleness DRRS: Disabled\n"); seq_puts(m, "Idleness DRRS: Disabled\n");
mutex_unlock(&drrs->mutex); mutex_unlock(&drrs->mutex);
return; return;
} }
panel = &drrs->dp->attached_connector->panel;
seq_printf(m, "\t\tBusy_frontbuffer_bits: 0x%X", seq_printf(m, "\t\tBusy_frontbuffer_bits: 0x%X",
drrs->busy_frontbuffer_bits); drrs->busy_frontbuffer_bits);
...@@ -1881,9 +1878,7 @@ static int i915_drrs_ctl_set(void *data, u64 val) ...@@ -1881,9 +1878,7 @@ static int i915_drrs_ctl_set(void *data, u64 val)
return -ENODEV; return -ENODEV;
for_each_intel_crtc(dev, crtc) { for_each_intel_crtc(dev, crtc) {
struct drm_connector_list_iter conn_iter;
struct intel_crtc_state *crtc_state; struct intel_crtc_state *crtc_state;
struct drm_connector *connector;
struct drm_crtc_commit *commit; struct drm_crtc_commit *commit;
int ret; int ret;
...@@ -1904,30 +1899,14 @@ static int i915_drrs_ctl_set(void *data, u64 val) ...@@ -1904,30 +1899,14 @@ static int i915_drrs_ctl_set(void *data, u64 val)
goto out; goto out;
} }
drm_connector_list_iter_begin(dev, &conn_iter); drm_dbg(&dev_priv->drm,
drm_for_each_connector_iter(connector, &conn_iter) { "Manually %sabling DRRS. %llu\n",
struct intel_encoder *encoder; val ? "en" : "dis", val);
struct intel_dp *intel_dp;
if (!(crtc_state->uapi.connector_mask &
drm_connector_mask(connector)))
continue;
encoder = intel_attached_encoder(to_intel_connector(connector));
if (encoder->type != INTEL_OUTPUT_EDP)
continue;
drm_dbg(&dev_priv->drm,
"Manually %sabling DRRS. %llu\n",
val ? "en" : "dis", val);
intel_dp = enc_to_intel_dp(encoder); if (val)
if (val) intel_drrs_enable(crtc_state);
intel_drrs_enable(intel_dp, crtc_state); else
else intel_drrs_disable(crtc_state);
intel_drrs_disable(intel_dp, crtc_state);
}
drm_connector_list_iter_end(&conn_iter);
out: out:
drm_modeset_unlock(&crtc->base.mutex); drm_modeset_unlock(&crtc->base.mutex);
......
...@@ -1899,8 +1899,8 @@ intel_dp_compute_config(struct intel_encoder *encoder, ...@@ -1899,8 +1899,8 @@ intel_dp_compute_config(struct intel_encoder *encoder,
intel_vrr_compute_config(pipe_config, conn_state); intel_vrr_compute_config(pipe_config, conn_state);
intel_psr_compute_config(intel_dp, pipe_config, conn_state); intel_psr_compute_config(intel_dp, pipe_config, conn_state);
intel_drrs_compute_config(intel_dp, pipe_config, output_bpp, intel_drrs_compute_config(intel_connector, pipe_config,
constant_n); output_bpp, constant_n);
intel_dp_compute_vsc_sdp(intel_dp, pipe_config, conn_state); intel_dp_compute_vsc_sdp(intel_dp, pipe_config, conn_state);
intel_dp_compute_hdr_metadata_infoframe_sdp(intel_dp, pipe_config, conn_state); intel_dp_compute_hdr_metadata_infoframe_sdp(intel_dp, pipe_config, conn_state);
......
...@@ -80,11 +80,10 @@ static bool can_enable_drrs(struct intel_connector *connector, ...@@ -80,11 +80,10 @@ static bool can_enable_drrs(struct intel_connector *connector,
} }
void void
intel_drrs_compute_config(struct intel_dp *intel_dp, intel_drrs_compute_config(struct intel_connector *connector,
struct intel_crtc_state *pipe_config, struct intel_crtc_state *pipe_config,
int output_bpp, bool constant_n) int output_bpp, bool constant_n)
{ {
struct intel_connector *connector = intel_dp->attached_connector;
struct drm_i915_private *i915 = to_i915(connector->base.dev); struct drm_i915_private *i915 = to_i915(connector->base.dev);
const struct drm_display_mode *downclock_mode = const struct drm_display_mode *downclock_mode =
intel_panel_downclock_mode(connector, &pipe_config->hw.adjusted_mode); intel_panel_downclock_mode(connector, &pipe_config->hw.adjusted_mode);
...@@ -153,10 +152,9 @@ static void intel_drrs_set_state(struct drm_i915_private *dev_priv, ...@@ -153,10 +152,9 @@ static void intel_drrs_set_state(struct drm_i915_private *dev_priv,
const struct intel_crtc_state *crtc_state, const struct intel_crtc_state *crtc_state,
enum drrs_refresh_rate refresh_rate) enum drrs_refresh_rate refresh_rate)
{ {
struct intel_dp *intel_dp = dev_priv->drrs.dp;
struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc); struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
if (!intel_dp) { if (!dev_priv->drrs.crtc) {
drm_dbg_kms(&dev_priv->drm, "DRRS not supported.\n"); drm_dbg_kms(&dev_priv->drm, "DRRS not supported.\n");
return; return;
} }
...@@ -193,25 +191,24 @@ static void intel_drrs_set_state(struct drm_i915_private *dev_priv, ...@@ -193,25 +191,24 @@ static void intel_drrs_set_state(struct drm_i915_private *dev_priv,
} }
static void static void
intel_drrs_enable_locked(struct intel_dp *intel_dp) intel_drrs_enable_locked(struct intel_crtc *crtc)
{ {
struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
dev_priv->drrs.busy_frontbuffer_bits = 0; dev_priv->drrs.busy_frontbuffer_bits = 0;
dev_priv->drrs.dp = intel_dp; dev_priv->drrs.crtc = crtc;
} }
/** /**
* intel_drrs_enable - init drrs struct if supported * intel_drrs_enable - init drrs struct if supported
* @intel_dp: DP struct
* @crtc_state: A pointer to the active crtc state. * @crtc_state: A pointer to the active crtc state.
* *
* Initializes frontbuffer_bits and drrs.dp * Initializes frontbuffer_bits and drrs.dp
*/ */
void intel_drrs_enable(struct intel_dp *intel_dp, void intel_drrs_enable(const struct intel_crtc_state *crtc_state)
const struct intel_crtc_state *crtc_state)
{ {
struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
if (!crtc_state->has_drrs) if (!crtc_state->has_drrs)
return; return;
...@@ -220,48 +217,45 @@ void intel_drrs_enable(struct intel_dp *intel_dp, ...@@ -220,48 +217,45 @@ void intel_drrs_enable(struct intel_dp *intel_dp,
mutex_lock(&dev_priv->drrs.mutex); mutex_lock(&dev_priv->drrs.mutex);
if (dev_priv->drrs.dp) { if (dev_priv->drrs.crtc) {
drm_warn(&dev_priv->drm, "DRRS already enabled\n"); drm_warn(&dev_priv->drm, "DRRS already enabled\n");
goto unlock; goto unlock;
} }
intel_drrs_enable_locked(intel_dp); intel_drrs_enable_locked(crtc);
unlock: unlock:
mutex_unlock(&dev_priv->drrs.mutex); mutex_unlock(&dev_priv->drrs.mutex);
} }
static void static void
intel_drrs_disable_locked(struct intel_dp *intel_dp, intel_drrs_disable_locked(const struct intel_crtc_state *crtc_state)
const struct intel_crtc_state *crtc_state)
{ {
struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); struct drm_i915_private *dev_priv = to_i915(crtc_state->uapi.crtc->dev);
intel_drrs_set_state(dev_priv, crtc_state, DRRS_REFRESH_RATE_HIGH); intel_drrs_set_state(dev_priv, crtc_state, DRRS_REFRESH_RATE_HIGH);
dev_priv->drrs.dp = NULL; dev_priv->drrs.crtc = NULL;
} }
/** /**
* intel_drrs_disable - Disable DRRS * intel_drrs_disable - Disable DRRS
* @intel_dp: DP struct
* @old_crtc_state: Pointer to old crtc_state. * @old_crtc_state: Pointer to old crtc_state.
*
*/ */
void intel_drrs_disable(struct intel_dp *intel_dp, void intel_drrs_disable(const struct intel_crtc_state *old_crtc_state)
const struct intel_crtc_state *old_crtc_state)
{ {
struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); struct intel_crtc *crtc = to_intel_crtc(old_crtc_state->uapi.crtc);
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
if (!old_crtc_state->has_drrs) if (!old_crtc_state->has_drrs)
return; return;
mutex_lock(&dev_priv->drrs.mutex); mutex_lock(&dev_priv->drrs.mutex);
if (!dev_priv->drrs.dp) { if (dev_priv->drrs.crtc != crtc) {
mutex_unlock(&dev_priv->drrs.mutex); mutex_unlock(&dev_priv->drrs.mutex);
return; return;
} }
intel_drrs_disable_locked(intel_dp, old_crtc_state); intel_drrs_disable_locked(old_crtc_state);
mutex_unlock(&dev_priv->drrs.mutex); mutex_unlock(&dev_priv->drrs.mutex);
cancel_delayed_work_sync(&dev_priv->drrs.work); cancel_delayed_work_sync(&dev_priv->drrs.work);
...@@ -269,7 +263,6 @@ void intel_drrs_disable(struct intel_dp *intel_dp, ...@@ -269,7 +263,6 @@ void intel_drrs_disable(struct intel_dp *intel_dp,
/** /**
* intel_drrs_update - Update DRRS state * intel_drrs_update - Update DRRS state
* @intel_dp: Intel DP
* @crtc_state: new CRTC state * @crtc_state: new CRTC state
* *
* This function will update DRRS states, disabling or enabling DRRS when * This function will update DRRS states, disabling or enabling DRRS when
...@@ -277,10 +270,10 @@ void intel_drrs_disable(struct intel_dp *intel_dp, ...@@ -277,10 +270,10 @@ void intel_drrs_disable(struct intel_dp *intel_dp,
* intel_drrs_enable() should be called instead. * intel_drrs_enable() should be called instead.
*/ */
void void
intel_drrs_update(struct intel_dp *intel_dp, intel_drrs_update(const struct intel_crtc_state *crtc_state)
const struct intel_crtc_state *crtc_state)
{ {
struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
if (dev_priv->vbt.drrs_type != DRRS_TYPE_SEAMLESS) if (dev_priv->vbt.drrs_type != DRRS_TYPE_SEAMLESS)
return; return;
...@@ -288,13 +281,13 @@ intel_drrs_update(struct intel_dp *intel_dp, ...@@ -288,13 +281,13 @@ intel_drrs_update(struct intel_dp *intel_dp,
mutex_lock(&dev_priv->drrs.mutex); mutex_lock(&dev_priv->drrs.mutex);
/* New state matches current one? */ /* New state matches current one? */
if (crtc_state->has_drrs == !!dev_priv->drrs.dp) if (crtc_state->has_drrs == !!dev_priv->drrs.crtc)
goto unlock; goto unlock;
if (crtc_state->has_drrs) if (crtc_state->has_drrs)
intel_drrs_enable_locked(intel_dp); intel_drrs_enable_locked(crtc);
else else
intel_drrs_disable_locked(intel_dp, crtc_state); intel_drrs_disable_locked(crtc_state);
unlock: unlock:
mutex_unlock(&dev_priv->drrs.mutex); mutex_unlock(&dev_priv->drrs.mutex);
...@@ -304,13 +297,12 @@ static void intel_drrs_downclock_work(struct work_struct *work) ...@@ -304,13 +297,12 @@ static void intel_drrs_downclock_work(struct work_struct *work)
{ {
struct drm_i915_private *dev_priv = struct drm_i915_private *dev_priv =
container_of(work, typeof(*dev_priv), drrs.work.work); container_of(work, typeof(*dev_priv), drrs.work.work);
struct intel_dp *intel_dp; struct intel_crtc *crtc;
mutex_lock(&dev_priv->drrs.mutex); mutex_lock(&dev_priv->drrs.mutex);
intel_dp = dev_priv->drrs.dp; crtc = dev_priv->drrs.crtc;
if (!crtc)
if (!intel_dp)
goto unlock; goto unlock;
/* /*
...@@ -319,9 +311,6 @@ static void intel_drrs_downclock_work(struct work_struct *work) ...@@ -319,9 +311,6 @@ static void intel_drrs_downclock_work(struct work_struct *work)
*/ */
if (!dev_priv->drrs.busy_frontbuffer_bits) { if (!dev_priv->drrs.busy_frontbuffer_bits) {
struct intel_crtc *crtc =
to_intel_crtc(dp_to_dig_port(intel_dp)->base.base.crtc);
intel_drrs_set_state(dev_priv, crtc->config, intel_drrs_set_state(dev_priv, crtc->config,
DRRS_REFRESH_RATE_LOW); DRRS_REFRESH_RATE_LOW);
} }
...@@ -334,9 +323,7 @@ static void intel_drrs_frontbuffer_update(struct drm_i915_private *dev_priv, ...@@ -334,9 +323,7 @@ static void intel_drrs_frontbuffer_update(struct drm_i915_private *dev_priv,
unsigned int frontbuffer_bits, unsigned int frontbuffer_bits,
bool invalidate) bool invalidate)
{ {
struct intel_dp *intel_dp; struct intel_crtc *crtc;
struct drm_crtc *crtc;
enum pipe pipe;
if (dev_priv->vbt.drrs_type != DRRS_TYPE_SEAMLESS) if (dev_priv->vbt.drrs_type != DRRS_TYPE_SEAMLESS)
return; return;
...@@ -345,16 +332,13 @@ static void intel_drrs_frontbuffer_update(struct drm_i915_private *dev_priv, ...@@ -345,16 +332,13 @@ static void intel_drrs_frontbuffer_update(struct drm_i915_private *dev_priv,
mutex_lock(&dev_priv->drrs.mutex); mutex_lock(&dev_priv->drrs.mutex);
intel_dp = dev_priv->drrs.dp; crtc = dev_priv->drrs.crtc;
if (!intel_dp) { if (!crtc) {
mutex_unlock(&dev_priv->drrs.mutex); mutex_unlock(&dev_priv->drrs.mutex);
return; return;
} }
crtc = dp_to_dig_port(intel_dp)->base.base.crtc; frontbuffer_bits &= INTEL_FRONTBUFFER_ALL_MASK(crtc->pipe);
pipe = to_intel_crtc(crtc)->pipe;
frontbuffer_bits &= INTEL_FRONTBUFFER_ALL_MASK(pipe);
if (invalidate) if (invalidate)
dev_priv->drrs.busy_frontbuffer_bits |= frontbuffer_bits; dev_priv->drrs.busy_frontbuffer_bits |= frontbuffer_bits;
else else
...@@ -362,7 +346,7 @@ static void intel_drrs_frontbuffer_update(struct drm_i915_private *dev_priv, ...@@ -362,7 +346,7 @@ static void intel_drrs_frontbuffer_update(struct drm_i915_private *dev_priv,
/* flush/invalidate means busy screen hence upclock */ /* flush/invalidate means busy screen hence upclock */
if (frontbuffer_bits) if (frontbuffer_bits)
intel_drrs_set_state(dev_priv, to_intel_crtc(crtc)->config, intel_drrs_set_state(dev_priv, crtc->config,
DRRS_REFRESH_RATE_HIGH); DRRS_REFRESH_RATE_HIGH);
/* /*
......
...@@ -14,22 +14,18 @@ struct intel_atomic_state; ...@@ -14,22 +14,18 @@ struct intel_atomic_state;
struct intel_crtc; struct intel_crtc;
struct intel_crtc_state; struct intel_crtc_state;
struct intel_connector; struct intel_connector;
struct intel_dp;
const char *intel_drrs_type_str(enum drrs_type drrs_type); const char *intel_drrs_type_str(enum drrs_type drrs_type);
void intel_drrs_enable(struct intel_dp *intel_dp, void intel_drrs_enable(const struct intel_crtc_state *crtc_state);
const struct intel_crtc_state *crtc_state); void intel_drrs_disable(const struct intel_crtc_state *crtc_state);
void intel_drrs_disable(struct intel_dp *intel_dp, void intel_drrs_update(const struct intel_crtc_state *crtc_state);
const struct intel_crtc_state *crtc_state);
void intel_drrs_update(struct intel_dp *intel_dp,
const struct intel_crtc_state *crtc_state);
void intel_drrs_invalidate(struct drm_i915_private *dev_priv, void intel_drrs_invalidate(struct drm_i915_private *dev_priv,
unsigned int frontbuffer_bits); unsigned int frontbuffer_bits);
void intel_drrs_flush(struct drm_i915_private *dev_priv, void intel_drrs_flush(struct drm_i915_private *dev_priv,
unsigned int frontbuffer_bits); unsigned int frontbuffer_bits);
void intel_drrs_page_flip(struct intel_atomic_state *state, void intel_drrs_page_flip(struct intel_atomic_state *state,
struct intel_crtc *crtc); struct intel_crtc *crtc);
void intel_drrs_compute_config(struct intel_dp *intel_dp, void intel_drrs_compute_config(struct intel_connector *connector,
struct intel_crtc_state *pipe_config, struct intel_crtc_state *pipe_config,
int output_bpp, bool constant_n); int output_bpp, bool constant_n);
struct drm_display_mode *intel_drrs_init(struct intel_connector *connector, struct drm_display_mode *intel_drrs_init(struct intel_connector *connector,
......
...@@ -210,7 +210,7 @@ enum drrs_type { ...@@ -210,7 +210,7 @@ enum drrs_type {
struct i915_drrs { struct i915_drrs {
struct mutex mutex; struct mutex mutex;
struct delayed_work work; struct delayed_work work;
struct intel_dp *dp; struct intel_crtc *crtc;
unsigned busy_frontbuffer_bits; unsigned busy_frontbuffer_bits;
enum drrs_refresh_rate refresh_rate; enum drrs_refresh_rate refresh_rate;
}; };
......
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