Commit 7cfd1a18 authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Remove remaining locks from i9xx plane udpates

Now that fbc no longer nukes while a flip is pending we can
remove the last uncore.lock from the i9xx plane code.
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220315140001.1172-5-ville.syrjala@linux.intel.comReviewed-by: default avatarMika Kahola <mika.kahola@intel.com>
parent de5bd083
...@@ -449,7 +449,6 @@ static void i9xx_plane_update_arm(struct intel_plane *plane, ...@@ -449,7 +449,6 @@ static void i9xx_plane_update_arm(struct intel_plane *plane,
int x = plane_state->view.color_plane[0].x; int x = plane_state->view.color_plane[0].x;
int y = plane_state->view.color_plane[0].y; int y = plane_state->view.color_plane[0].y;
u32 dspcntr, dspaddr_offset, linear_offset; u32 dspcntr, dspaddr_offset, linear_offset;
unsigned long irqflags;
dspcntr = plane_state->ctl | i9xx_plane_ctl_crtc(crtc_state); dspcntr = plane_state->ctl | i9xx_plane_ctl_crtc(crtc_state);
...@@ -490,15 +489,12 @@ static void i9xx_plane_update_arm(struct intel_plane *plane, ...@@ -490,15 +489,12 @@ static void i9xx_plane_update_arm(struct intel_plane *plane,
*/ */
intel_de_write_fw(dev_priv, DSPCNTR(i9xx_plane), dspcntr); intel_de_write_fw(dev_priv, DSPCNTR(i9xx_plane), dspcntr);
/* lock to protect against rmw in fbc nuke */
spin_lock_irqsave(&dev_priv->uncore.lock, irqflags);
if (DISPLAY_VER(dev_priv) >= 4) if (DISPLAY_VER(dev_priv) >= 4)
intel_de_write_fw(dev_priv, DSPSURF(i9xx_plane), intel_de_write_fw(dev_priv, DSPSURF(i9xx_plane),
intel_plane_ggtt_offset(plane_state) + dspaddr_offset); intel_plane_ggtt_offset(plane_state) + dspaddr_offset);
else else
intel_de_write_fw(dev_priv, DSPADDR(i9xx_plane), intel_de_write_fw(dev_priv, DSPADDR(i9xx_plane),
intel_plane_ggtt_offset(plane_state) + dspaddr_offset); intel_plane_ggtt_offset(plane_state) + dspaddr_offset);
spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
} }
static void i830_plane_update_arm(struct intel_plane *plane, static void i830_plane_update_arm(struct intel_plane *plane,
...@@ -520,7 +516,6 @@ static void i9xx_plane_disable_arm(struct intel_plane *plane, ...@@ -520,7 +516,6 @@ static void i9xx_plane_disable_arm(struct intel_plane *plane,
{ {
struct drm_i915_private *dev_priv = to_i915(plane->base.dev); struct drm_i915_private *dev_priv = to_i915(plane->base.dev);
enum i9xx_plane_id i9xx_plane = plane->i9xx_plane; enum i9xx_plane_id i9xx_plane = plane->i9xx_plane;
unsigned long irqflags;
u32 dspcntr; u32 dspcntr;
/* /*
...@@ -537,13 +532,10 @@ static void i9xx_plane_disable_arm(struct intel_plane *plane, ...@@ -537,13 +532,10 @@ static void i9xx_plane_disable_arm(struct intel_plane *plane,
intel_de_write_fw(dev_priv, DSPCNTR(i9xx_plane), dspcntr); intel_de_write_fw(dev_priv, DSPCNTR(i9xx_plane), dspcntr);
/* lock to protect against rmw in fbc nuke */
spin_lock_irqsave(&dev_priv->uncore.lock, irqflags);
if (DISPLAY_VER(dev_priv) >= 4) if (DISPLAY_VER(dev_priv) >= 4)
intel_de_write_fw(dev_priv, DSPSURF(i9xx_plane), 0); intel_de_write_fw(dev_priv, DSPSURF(i9xx_plane), 0);
else else
intel_de_write_fw(dev_priv, DSPADDR(i9xx_plane), 0); intel_de_write_fw(dev_priv, DSPADDR(i9xx_plane), 0);
spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
} }
static void static void
...@@ -556,18 +548,14 @@ g4x_primary_async_flip(struct intel_plane *plane, ...@@ -556,18 +548,14 @@ g4x_primary_async_flip(struct intel_plane *plane,
u32 dspcntr = plane_state->ctl | i9xx_plane_ctl_crtc(crtc_state); u32 dspcntr = plane_state->ctl | i9xx_plane_ctl_crtc(crtc_state);
u32 dspaddr_offset = plane_state->view.color_plane[0].offset; u32 dspaddr_offset = plane_state->view.color_plane[0].offset;
enum i9xx_plane_id i9xx_plane = plane->i9xx_plane; enum i9xx_plane_id i9xx_plane = plane->i9xx_plane;
unsigned long irqflags;
if (async_flip) if (async_flip)
dspcntr |= DISP_ASYNC_FLIP; dspcntr |= DISP_ASYNC_FLIP;
intel_de_write_fw(dev_priv, DSPCNTR(i9xx_plane), dspcntr); intel_de_write_fw(dev_priv, DSPCNTR(i9xx_plane), dspcntr);
/* lock to protect against rmw in fbc nuke */
spin_lock_irqsave(&dev_priv->uncore.lock, irqflags);
intel_de_write_fw(dev_priv, DSPSURF(i9xx_plane), intel_de_write_fw(dev_priv, DSPSURF(i9xx_plane),
intel_plane_ggtt_offset(plane_state) + dspaddr_offset); intel_plane_ggtt_offset(plane_state) + dspaddr_offset);
spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
} }
static void static void
......
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