提交 b70709a6 编写于 作者: M Maarten Lankhorst 提交者: Daniel Vetter

drm/i915: get rid of primary_enabled and use atomic state

This was an optimization from way back before we had primary plane
support to be able to disable the primary plane. But with primary
plane support userspace can tell the kernel this directly, so there's
no big need for this any more. And it's getting in the way of the
atomic conversion.

If need be we can resurrect this later on properly again.
Signed-off-by: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Reviewed-by: NAnder Conselvan de Oliveira <ander.conselvan.de.oliveira@intel.com>
[danvet: Explain why removing this is ok.]
Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
上级 27321ae8
...@@ -2236,11 +2236,7 @@ static void intel_enable_primary_hw_plane(struct drm_plane *plane, ...@@ -2236,11 +2236,7 @@ static void intel_enable_primary_hw_plane(struct drm_plane *plane,
/* If the pipe isn't enabled, we can't pump pixels and may hang */ /* If the pipe isn't enabled, we can't pump pixels and may hang */
assert_pipe_enabled(dev_priv, intel_crtc->pipe); assert_pipe_enabled(dev_priv, intel_crtc->pipe);
to_intel_plane_state(plane->state)->visible = true;
if (intel_crtc->primary_enabled)
return;
intel_crtc->primary_enabled = true;
dev_priv->display.update_primary_plane(crtc, plane->fb, dev_priv->display.update_primary_plane(crtc, plane->fb,
crtc->x, crtc->y); crtc->x, crtc->y);
...@@ -2661,6 +2657,8 @@ static void i9xx_update_primary_plane(struct drm_crtc *crtc, ...@@ -2661,6 +2657,8 @@ static void i9xx_update_primary_plane(struct drm_crtc *crtc,
struct drm_device *dev = crtc->dev; struct drm_device *dev = crtc->dev;
struct drm_i915_private *dev_priv = dev->dev_private; struct drm_i915_private *dev_priv = dev->dev_private;
struct intel_crtc *intel_crtc = to_intel_crtc(crtc); struct intel_crtc *intel_crtc = to_intel_crtc(crtc);
struct drm_plane *primary = crtc->primary;
bool visible = to_intel_plane_state(primary->state)->visible;
struct drm_i915_gem_object *obj; struct drm_i915_gem_object *obj;
int plane = intel_crtc->plane; int plane = intel_crtc->plane;
unsigned long linear_offset; unsigned long linear_offset;
...@@ -2668,7 +2666,7 @@ static void i9xx_update_primary_plane(struct drm_crtc *crtc, ...@@ -2668,7 +2666,7 @@ static void i9xx_update_primary_plane(struct drm_crtc *crtc,
u32 reg = DSPCNTR(plane); u32 reg = DSPCNTR(plane);
int pixel_size; int pixel_size;
if (!intel_crtc->primary_enabled || !fb) { if (!visible || !fb) {
I915_WRITE(reg, 0); I915_WRITE(reg, 0);
if (INTEL_INFO(dev)->gen >= 4) if (INTEL_INFO(dev)->gen >= 4)
I915_WRITE(DSPSURF(plane), 0); I915_WRITE(DSPSURF(plane), 0);
...@@ -2790,6 +2788,8 @@ static void ironlake_update_primary_plane(struct drm_crtc *crtc, ...@@ -2790,6 +2788,8 @@ static void ironlake_update_primary_plane(struct drm_crtc *crtc,
struct drm_device *dev = crtc->dev; struct drm_device *dev = crtc->dev;
struct drm_i915_private *dev_priv = dev->dev_private; struct drm_i915_private *dev_priv = dev->dev_private;
struct intel_crtc *intel_crtc = to_intel_crtc(crtc); struct intel_crtc *intel_crtc = to_intel_crtc(crtc);
struct drm_plane *primary = crtc->primary;
bool visible = to_intel_plane_state(primary->state)->visible;
struct drm_i915_gem_object *obj; struct drm_i915_gem_object *obj;
int plane = intel_crtc->plane; int plane = intel_crtc->plane;
unsigned long linear_offset; unsigned long linear_offset;
...@@ -2797,7 +2797,7 @@ static void ironlake_update_primary_plane(struct drm_crtc *crtc, ...@@ -2797,7 +2797,7 @@ static void ironlake_update_primary_plane(struct drm_crtc *crtc,
u32 reg = DSPCNTR(plane); u32 reg = DSPCNTR(plane);
int pixel_size; int pixel_size;
if (!intel_crtc->primary_enabled || !fb) { if (!visible || !fb) {
I915_WRITE(reg, 0); I915_WRITE(reg, 0);
I915_WRITE(DSPSURF(plane), 0); I915_WRITE(DSPSURF(plane), 0);
POSTING_READ(reg); POSTING_READ(reg);
...@@ -3059,6 +3059,8 @@ static void skylake_update_primary_plane(struct drm_crtc *crtc, ...@@ -3059,6 +3059,8 @@ static void skylake_update_primary_plane(struct drm_crtc *crtc,
struct drm_device *dev = crtc->dev; struct drm_device *dev = crtc->dev;
struct drm_i915_private *dev_priv = dev->dev_private; struct drm_i915_private *dev_priv = dev->dev_private;
struct intel_crtc *intel_crtc = to_intel_crtc(crtc); struct intel_crtc *intel_crtc = to_intel_crtc(crtc);
struct drm_plane *plane = crtc->primary;
bool visible = to_intel_plane_state(plane->state)->visible;
struct drm_i915_gem_object *obj; struct drm_i915_gem_object *obj;
int pipe = intel_crtc->pipe; int pipe = intel_crtc->pipe;
u32 plane_ctl, stride_div, stride; u32 plane_ctl, stride_div, stride;
...@@ -3066,17 +3068,15 @@ static void skylake_update_primary_plane(struct drm_crtc *crtc, ...@@ -3066,17 +3068,15 @@ static void skylake_update_primary_plane(struct drm_crtc *crtc,
unsigned int rotation; unsigned int rotation;
int x_offset, y_offset; int x_offset, y_offset;
unsigned long surf_addr; unsigned long surf_addr;
struct drm_plane *plane;
struct intel_crtc_state *crtc_state = intel_crtc->config; struct intel_crtc_state *crtc_state = intel_crtc->config;
struct intel_plane_state *plane_state; struct intel_plane_state *plane_state;
int src_x = 0, src_y = 0, src_w = 0, src_h = 0; int src_x = 0, src_y = 0, src_w = 0, src_h = 0;
int dst_x = 0, dst_y = 0, dst_w = 0, dst_h = 0; int dst_x = 0, dst_y = 0, dst_w = 0, dst_h = 0;
int scaler_id = -1; int scaler_id = -1;
plane = crtc->primary;
plane_state = to_intel_plane_state(plane->state); plane_state = to_intel_plane_state(plane->state);
if (!intel_crtc->primary_enabled || !fb) { if (!visible || !fb) {
I915_WRITE(PLANE_CTL(pipe, 0), 0); I915_WRITE(PLANE_CTL(pipe, 0), 0);
I915_WRITE(PLANE_SURF(pipe, 0), 0); I915_WRITE(PLANE_SURF(pipe, 0), 0);
POSTING_READ(PLANE_CTL(pipe, 0)); POSTING_READ(PLANE_CTL(pipe, 0));
...@@ -4783,7 +4783,6 @@ static void intel_crtc_disable_planes(struct drm_crtc *crtc) ...@@ -4783,7 +4783,6 @@ static void intel_crtc_disable_planes(struct drm_crtc *crtc)
hsw_disable_ips(intel_crtc); hsw_disable_ips(intel_crtc);
intel_crtc_dpms_overlay(intel_crtc, false); intel_crtc_dpms_overlay(intel_crtc, false);
intel_crtc->primary_enabled = false;
for_each_intel_plane(dev, intel_plane) { for_each_intel_plane(dev, intel_plane) {
if (intel_plane->pipe == pipe) { if (intel_plane->pipe == pipe) {
struct drm_crtc *from = intel_plane->base.crtc; struct drm_crtc *from = intel_plane->base.crtc;
...@@ -12891,6 +12890,9 @@ static int intel_crtc_set_config(struct drm_mode_set *set) ...@@ -12891,6 +12890,9 @@ static int intel_crtc_set_config(struct drm_mode_set *set)
} else if (config->fb_changed) { } else if (config->fb_changed) {
struct intel_crtc *intel_crtc = to_intel_crtc(set->crtc); struct intel_crtc *intel_crtc = to_intel_crtc(set->crtc);
struct drm_plane *primary = set->crtc->primary; struct drm_plane *primary = set->crtc->primary;
struct intel_plane_state *plane_state =
to_intel_plane_state(primary->state);
bool was_visible = plane_state->visible;
int vdisplay, hdisplay; int vdisplay, hdisplay;
drm_crtc_get_hv_timing(set->mode, &hdisplay, &vdisplay); drm_crtc_get_hv_timing(set->mode, &hdisplay, &vdisplay);
...@@ -12903,7 +12905,8 @@ static int intel_crtc_set_config(struct drm_mode_set *set) ...@@ -12903,7 +12905,8 @@ static int intel_crtc_set_config(struct drm_mode_set *set)
* We need to make sure the primary plane is re-enabled if it * We need to make sure the primary plane is re-enabled if it
* has previously been turned off. * has previously been turned off.
*/ */
if (!intel_crtc->primary_enabled && ret == 0) { plane_state = to_intel_plane_state(primary->state);
if (ret == 0 && !was_visible && plane_state->visible) {
WARN_ON(!intel_crtc->active); WARN_ON(!intel_crtc->active);
intel_enable_primary_hw_plane(set->crtc->primary, set->crtc); intel_enable_primary_hw_plane(set->crtc->primary, set->crtc);
} }
...@@ -13239,6 +13242,9 @@ intel_check_primary_plane(struct drm_plane *plane, ...@@ -13239,6 +13242,9 @@ intel_check_primary_plane(struct drm_plane *plane,
return ret; return ret;
if (intel_crtc->active) { if (intel_crtc->active) {
struct intel_plane_state *old_state =
to_intel_plane_state(plane->state);
intel_crtc->atomic.wait_for_flips = true; intel_crtc->atomic.wait_for_flips = true;
/* /*
...@@ -13251,20 +13257,20 @@ intel_check_primary_plane(struct drm_plane *plane, ...@@ -13251,20 +13257,20 @@ intel_check_primary_plane(struct drm_plane *plane,
* one is done too late. We eventually need to unify * one is done too late. We eventually need to unify
* this. * this.
*/ */
if (intel_crtc->primary_enabled && if (state->visible &&
INTEL_INFO(dev)->gen <= 4 && !IS_G4X(dev) && INTEL_INFO(dev)->gen <= 4 && !IS_G4X(dev) &&
dev_priv->fbc.crtc == intel_crtc && dev_priv->fbc.crtc == intel_crtc &&
state->base.rotation != BIT(DRM_ROTATE_0)) { state->base.rotation != BIT(DRM_ROTATE_0)) {
intel_crtc->atomic.disable_fbc = true; intel_crtc->atomic.disable_fbc = true;
} }
if (state->visible) { if (state->visible && !old_state->visible) {
/* /*
* BDW signals flip done immediately if the plane * BDW signals flip done immediately if the plane
* is disabled, even if the plane enable is already * is disabled, even if the plane enable is already
* armed to occur at the next vblank :( * armed to occur at the next vblank :(
*/ */
if (IS_BROADWELL(dev) && !intel_crtc->primary_enabled) if (IS_BROADWELL(dev))
intel_crtc->atomic.wait_vblank = true; intel_crtc->atomic.wait_vblank = true;
} }
...@@ -13306,8 +13312,6 @@ intel_commit_primary_plane(struct drm_plane *plane, ...@@ -13306,8 +13312,6 @@ intel_commit_primary_plane(struct drm_plane *plane,
crtc->y = src->y1 >> 16; crtc->y = src->y1 >> 16;
if (intel_crtc->active) { if (intel_crtc->active) {
intel_crtc->primary_enabled = state->visible;
if (state->visible) if (state->visible)
/* FIXME: kill this fastboot hack */ /* FIXME: kill this fastboot hack */
intel_update_pipe_size(intel_crtc); intel_update_pipe_size(intel_crtc);
...@@ -13325,9 +13329,6 @@ intel_disable_primary_plane(struct drm_plane *plane, ...@@ -13325,9 +13329,6 @@ intel_disable_primary_plane(struct drm_plane *plane,
struct drm_device *dev = plane->dev; struct drm_device *dev = plane->dev;
struct drm_i915_private *dev_priv = dev->dev_private; struct drm_i915_private *dev_priv = dev->dev_private;
if (!force)
to_intel_crtc(crtc)->primary_enabled = false;
dev_priv->display.update_primary_plane(crtc, NULL, 0, 0); dev_priv->display.update_primary_plane(crtc, NULL, 0, 0);
} }
...@@ -14791,8 +14792,8 @@ static void intel_sanitize_crtc(struct intel_crtc *crtc) ...@@ -14791,8 +14792,8 @@ static void intel_sanitize_crtc(struct intel_crtc *crtc)
* Temporarily change the plane mapping and disable everything * Temporarily change the plane mapping and disable everything
* ... */ * ... */
plane = crtc->plane; plane = crtc->plane;
to_intel_plane_state(crtc->base.primary->state)->visible = true;
crtc->plane = !plane; crtc->plane = !plane;
crtc->primary_enabled = true;
dev_priv->display.crtc_disable(&crtc->base); dev_priv->display.crtc_disable(&crtc->base);
crtc->plane = plane; crtc->plane = plane;
...@@ -14969,6 +14970,9 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev) ...@@ -14969,6 +14970,9 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev)
int i; int i;
for_each_intel_crtc(dev, crtc) { for_each_intel_crtc(dev, crtc) {
struct drm_plane *primary = crtc->base.primary;
struct intel_plane_state *plane_state;
memset(crtc->config, 0, sizeof(*crtc->config)); memset(crtc->config, 0, sizeof(*crtc->config));
crtc->config->quirks |= PIPE_CONFIG_QUIRK_INHERITED_MODE; crtc->config->quirks |= PIPE_CONFIG_QUIRK_INHERITED_MODE;
...@@ -14978,7 +14982,9 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev) ...@@ -14978,7 +14982,9 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev)
crtc->base.state->enable = crtc->active; crtc->base.state->enable = crtc->active;
crtc->base.enabled = crtc->active; crtc->base.enabled = crtc->active;
crtc->primary_enabled = primary_get_hw_state(crtc);
plane_state = to_intel_plane_state(primary->state);
plane_state->visible = primary_get_hw_state(crtc);
DRM_DEBUG_KMS("[CRTC:%d] hw state readout: %s\n", DRM_DEBUG_KMS("[CRTC:%d] hw state readout: %s\n",
crtc->base.base.id, crtc->base.base.id,
......
...@@ -507,7 +507,6 @@ struct intel_crtc { ...@@ -507,7 +507,6 @@ struct intel_crtc {
*/ */
bool active; bool active;
unsigned long enabled_power_domains; unsigned long enabled_power_domains;
bool primary_enabled; /* is the primary plane (partially) visible? */
bool lowfreq_avail; bool lowfreq_avail;
struct intel_overlay *overlay; struct intel_overlay *overlay;
struct intel_unpin_work *unpin_work; struct intel_unpin_work *unpin_work;
......
...@@ -457,7 +457,7 @@ static struct drm_crtc *intel_fbc_find_crtc(struct drm_i915_private *dev_priv) ...@@ -457,7 +457,7 @@ static struct drm_crtc *intel_fbc_find_crtc(struct drm_i915_private *dev_priv)
tmp_crtc = dev_priv->pipe_to_crtc_mapping[pipe]; tmp_crtc = dev_priv->pipe_to_crtc_mapping[pipe];
if (intel_crtc_active(tmp_crtc) && if (intel_crtc_active(tmp_crtc) &&
to_intel_crtc(tmp_crtc)->primary_enabled) { to_intel_plane_state(tmp_crtc->primary->state)->visible) {
if (one_pipe_only && crtc) { if (one_pipe_only && crtc) {
if (set_no_fbc_reason(dev_priv, FBC_MULTIPLE_PIPES)) if (set_no_fbc_reason(dev_priv, FBC_MULTIPLE_PIPES))
DRM_DEBUG_KMS("more than one pipe active, disabling compression\n"); DRM_DEBUG_KMS("more than one pipe active, disabling compression\n");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册