提交 a227569d 编写于 作者: V Ville Syrjälä

drm/i915: Replace I915_MODE_FLAG_INHERITED with a boolean

There's no reason for I915_MODE_FLAG_INHERITED to exist as a flag
anymore. Just make it a boolean.

v2: Deal with sanitize_watermarks()

CC: Sam Ravnborg <sam@ravnborg.org>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
Cc: Emil Velikov <emil.l.velikov@gmail.com>
Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200429103936.11850-1-ville.syrjala@linux.intel.com
上级 af157b76
...@@ -249,11 +249,11 @@ intel_crtc_duplicate_state(struct drm_crtc *crtc) ...@@ -249,11 +249,11 @@ intel_crtc_duplicate_state(struct drm_crtc *crtc)
crtc_state->update_wm_post = false; crtc_state->update_wm_post = false;
crtc_state->fifo_changed = false; crtc_state->fifo_changed = false;
crtc_state->preload_luts = false; crtc_state->preload_luts = false;
crtc_state->inherited = false;
crtc_state->wm.need_postvbl_update = false; crtc_state->wm.need_postvbl_update = false;
crtc_state->fb_bits = 0; crtc_state->fb_bits = 0;
crtc_state->update_planes = 0; crtc_state->update_planes = 0;
crtc_state->dsb = NULL; crtc_state->dsb = NULL;
crtc_state->mode_flags &= ~I915_MODE_FLAG_INHERITED;
return &crtc_state->uapi; return &crtc_state->uapi;
} }
......
...@@ -6424,8 +6424,7 @@ static bool hsw_post_update_enable_ips(const struct intel_crtc_state *old_crtc_s ...@@ -6424,8 +6424,7 @@ static bool hsw_post_update_enable_ips(const struct intel_crtc_state *old_crtc_s
* We can't read out IPS on broadwell, assume the worst and * We can't read out IPS on broadwell, assume the worst and
* forcibly enable IPS on the first fastset. * forcibly enable IPS on the first fastset.
*/ */
if (new_crtc_state->update_pipe && if (new_crtc_state->update_pipe && old_crtc_state->inherited)
old_crtc_state->mode_flags & I915_MODE_FLAG_INHERITED)
return true; return true;
return !old_crtc_state->ips_enabled; return !old_crtc_state->ips_enabled;
...@@ -13605,8 +13604,7 @@ intel_pipe_config_compare(const struct intel_crtc_state *current_config, ...@@ -13605,8 +13604,7 @@ intel_pipe_config_compare(const struct intel_crtc_state *current_config,
bool ret = true; bool ret = true;
u32 bp_gamma = 0; u32 bp_gamma = 0;
bool fixup_inherited = fastset && bool fixup_inherited = fastset &&
(current_config->mode_flags & I915_MODE_FLAG_INHERITED) && current_config->inherited && !pipe_config->inherited;
!(pipe_config->mode_flags & I915_MODE_FLAG_INHERITED);
if (fixup_inherited && !fastboot_enabled(dev_priv)) { if (fixup_inherited && !fastboot_enabled(dev_priv)) {
drm_dbg_kms(&dev_priv->drm, drm_dbg_kms(&dev_priv->drm,
...@@ -14813,10 +14811,9 @@ static int intel_atomic_check(struct drm_device *dev, ...@@ -14813,10 +14811,9 @@ static int intel_atomic_check(struct drm_device *dev,
int ret, i; int ret, i;
bool any_ms = false; bool any_ms = false;
/* Catch I915_MODE_FLAG_INHERITED */
for_each_oldnew_intel_crtc_in_state(state, crtc, old_crtc_state, for_each_oldnew_intel_crtc_in_state(state, crtc, old_crtc_state,
new_crtc_state, i) { new_crtc_state, i) {
if (new_crtc_state->mode_flags != old_crtc_state->mode_flags) if (new_crtc_state->inherited != old_crtc_state->inherited)
new_crtc_state->uapi.mode_changed = true; new_crtc_state->uapi.mode_changed = true;
} }
...@@ -15186,7 +15183,7 @@ static void intel_update_crtc(struct intel_atomic_state *state, ...@@ -15186,7 +15183,7 @@ static void intel_update_crtc(struct intel_atomic_state *state,
* of enabling them on the CRTC's first fastset. * of enabling them on the CRTC's first fastset.
*/ */
if (new_crtc_state->update_pipe && !modeset && if (new_crtc_state->update_pipe && !modeset &&
old_crtc_state->mode_flags & I915_MODE_FLAG_INHERITED) old_crtc_state->inherited)
intel_crtc_arm_fifo_underrun(crtc, new_crtc_state); intel_crtc_arm_fifo_underrun(crtc, new_crtc_state);
} }
...@@ -17520,7 +17517,7 @@ static int sanitize_watermarks_add_affected(struct drm_atomic_state *state) ...@@ -17520,7 +17517,7 @@ static int sanitize_watermarks_add_affected(struct drm_atomic_state *state)
* Preserve the inherited flag to avoid * Preserve the inherited flag to avoid
* taking the full modeset path. * taking the full modeset path.
*/ */
crtc_state->mode_flags |= I915_MODE_FLAG_INHERITED; crtc_state->inherited = true;
} }
} }
...@@ -17670,7 +17667,7 @@ static int intel_initial_commit(struct drm_device *dev) ...@@ -17670,7 +17667,7 @@ static int intel_initial_commit(struct drm_device *dev)
* happen only for the first real commit from userspace. * happen only for the first real commit from userspace.
* So preserve the inherited flag for the time being. * So preserve the inherited flag for the time being.
*/ */
crtc_state->mode_flags |= I915_MODE_FLAG_INHERITED; crtc_state->inherited = true;
ret = drm_atomic_add_affected_planes(state, &crtc->base); ret = drm_atomic_add_affected_planes(state, &crtc->base);
if (ret) if (ret)
...@@ -18450,7 +18447,7 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev) ...@@ -18450,7 +18447,7 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev)
* set a flag to indicate that a full recalculation is * set a flag to indicate that a full recalculation is
* needed on the next commit. * needed on the next commit.
*/ */
crtc_state->mode_flags |= I915_MODE_FLAG_INHERITED; crtc_state->inherited = true;
intel_crtc_compute_pixel_rate(crtc_state); intel_crtc_compute_pixel_rate(crtc_state);
......
...@@ -631,7 +631,6 @@ struct intel_crtc_scaler_state { ...@@ -631,7 +631,6 @@ struct intel_crtc_scaler_state {
}; };
/* {crtc,crtc_state}->mode_flags */ /* {crtc,crtc_state}->mode_flags */
#define I915_MODE_FLAG_INHERITED (1<<0)
/* Flag to get scanline using frame time stamps */ /* Flag to get scanline using frame time stamps */
#define I915_MODE_FLAG_GET_SCANLINE_FROM_TIMESTAMP (1<<1) #define I915_MODE_FLAG_GET_SCANLINE_FROM_TIMESTAMP (1<<1)
/* Flag to use the scanline counter instead of the pixel counter */ /* Flag to use the scanline counter instead of the pixel counter */
...@@ -828,6 +827,7 @@ struct intel_crtc_state { ...@@ -828,6 +827,7 @@ struct intel_crtc_state {
bool update_wm_pre, update_wm_post; /* watermarks are updated */ bool update_wm_pre, update_wm_post; /* watermarks are updated */
bool fifo_changed; /* FIFO split is changed */ bool fifo_changed; /* FIFO split is changed */
bool preload_luts; bool preload_luts;
bool inherited; /* state inherited from BIOS? */
/* Pipe source size (ie. panel fitter input size) /* Pipe source size (ie. panel fitter input size)
* All planes will be positioned inside this space, * All planes will be positioned inside this space,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册