Skip to content

Commit df7415b

Browse files
committed
drm/i915: Do not unmask PSR interruption in IRQ postinstall
No need to unmask PSR interrutpion if PSR is not enabled, better move the call to intel_psr_enable_source(). v2: Renamed intel_psr_irq_control() to psr_irq_control() (Lucas) Cc: Rodrigo Vivi <rodrigo.vivi@intel.com> Cc: Dhinakaran Pandiyan <dhinakaran.pandiyan@intel.com> Signed-off-by: José Roberto de Souza <jose.souza@intel.com> Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com> Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190820223325.27490-3-jose.souza@intel.com
1 parent 99fc38b commit df7415b

File tree

3 files changed

+4
-5
lines changed

3 files changed

+4
-5
lines changed

drivers/gpu/drm/i915/display/intel_psr.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -105,7 +105,7 @@ static int edp_psr_shift(enum transcoder cpu_transcoder)
105105
}
106106
}
107107

108-
void intel_psr_irq_control(struct drm_i915_private *dev_priv, u32 debug)
108+
static void psr_irq_control(struct drm_i915_private *dev_priv, u32 debug)
109109
{
110110
u32 debug_mask, mask;
111111
enum transcoder cpu_transcoder;
@@ -736,6 +736,8 @@ static void intel_psr_enable_source(struct intel_dp *intel_dp,
736736
mask |= EDP_PSR_DEBUG_MASK_DISP_REG_WRITE;
737737

738738
I915_WRITE(EDP_PSR_DEBUG(dev_priv->psr.transcoder), mask);
739+
740+
psr_irq_control(dev_priv, dev_priv->psr.debug);
739741
}
740742

741743
static void intel_psr_enable_locked(struct drm_i915_private *dev_priv,
@@ -1108,7 +1110,7 @@ int intel_psr_debug_set(struct drm_i915_private *dev_priv, u64 val)
11081110

11091111
old_mode = dev_priv->psr.debug & I915_PSR_DEBUG_MODE_MASK;
11101112
dev_priv->psr.debug = val;
1111-
intel_psr_irq_control(dev_priv, dev_priv->psr.debug);
1113+
psr_irq_control(dev_priv, dev_priv->psr.debug);
11121114

11131115
mutex_unlock(&dev_priv->psr.lock);
11141116

drivers/gpu/drm/i915/display/intel_psr.h

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,6 @@ void intel_psr_flush(struct drm_i915_private *dev_priv,
3030
void intel_psr_init(struct drm_i915_private *dev_priv);
3131
void intel_psr_compute_config(struct intel_dp *intel_dp,
3232
struct intel_crtc_state *crtc_state);
33-
void intel_psr_irq_control(struct drm_i915_private *dev_priv, u32 debug);
3433
void intel_psr_irq_handler(struct drm_i915_private *dev_priv, u32 psr_iir);
3534
void intel_psr_short_pulse(struct intel_dp *intel_dp);
3635
int intel_psr_wait_for_idle(const struct intel_crtc_state *new_crtc_state,

drivers/gpu/drm/i915/i915_irq.c

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -3684,7 +3684,6 @@ static void ironlake_irq_postinstall(struct drm_i915_private *dev_priv)
36843684

36853685
if (IS_HASWELL(dev_priv)) {
36863686
gen3_assert_iir_is_zero(uncore, EDP_PSR_IIR);
3687-
intel_psr_irq_control(dev_priv, dev_priv->psr.debug);
36883687
display_mask |= DE_EDP_PSR_INT_HSW;
36893688
}
36903689

@@ -3795,7 +3794,6 @@ static void gen8_de_irq_postinstall(struct drm_i915_private *dev_priv)
37953794
de_port_enables |= GEN8_PORT_DP_A_HOTPLUG;
37963795

37973796
gen3_assert_iir_is_zero(uncore, EDP_PSR_IIR);
3798-
intel_psr_irq_control(dev_priv, dev_priv->psr.debug);
37993797

38003798
for_each_pipe(dev_priv, pipe) {
38013799
dev_priv->de_irq_mask[pipe] = ~de_pipe_masked;

0 commit comments

Comments
 (0)