[Intel-gfx] [PATCH 1/3] drm/i915/irq: relocate gmbus and dp aux irq handlers

Rodrigo Vivi rodrigo.vivi at kernel.org
Fri May 5 14:34:05 UTC 2023


On Thu, May 04, 2023 at 07:57:29PM +0300, Jani Nikula wrote:
> Move gmbus and dp aux irq handlers to their respective files. It should
> be up to them what to do with the irq, not the generic irq code.

I wonder if we shouldn't merge these 2 functions since they are identical
and leave only the gmbus version since the wake_up is there anyway.

But anyway, this is a good clean up regardless,

Reviewed-by: Rodrigo Vivi <rodrigo.vivi at intel.com>

> 
> Signed-off-by: Jani Nikula <jani.nikula at intel.com>
> ---
>  drivers/gpu/drm/i915/display/intel_dp_aux.c |  5 +++
>  drivers/gpu/drm/i915/display/intel_dp_aux.h |  3 ++
>  drivers/gpu/drm/i915/display/intel_gmbus.c  |  5 +++
>  drivers/gpu/drm/i915/display/intel_gmbus.h  |  2 ++
>  drivers/gpu/drm/i915/i915_irq.c             | 40 +++++++++------------
>  5 files changed, 31 insertions(+), 24 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_dp_aux.c b/drivers/gpu/drm/i915/display/intel_dp_aux.c
> index abf77ba76972..20226764757b 100644
> --- a/drivers/gpu/drm/i915/display/intel_dp_aux.c
> +++ b/drivers/gpu/drm/i915/display/intel_dp_aux.c
> @@ -815,3 +815,8 @@ enum aux_ch intel_dp_aux_ch(struct intel_encoder *encoder)
>  
>  	return aux_ch;
>  }
> +
> +void intel_dp_aux_irq_handler(struct drm_i915_private *i915)
> +{
> +	wake_up_all(&i915->display.gmbus.wait_queue);
> +}
> diff --git a/drivers/gpu/drm/i915/display/intel_dp_aux.h b/drivers/gpu/drm/i915/display/intel_dp_aux.h
> index 138e340f94ee..5b608f9d3499 100644
> --- a/drivers/gpu/drm/i915/display/intel_dp_aux.h
> +++ b/drivers/gpu/drm/i915/display/intel_dp_aux.h
> @@ -7,6 +7,7 @@
>  #define __INTEL_DP_AUX_H__
>  
>  enum aux_ch;
> +struct drm_i915_private;
>  struct intel_dp;
>  struct intel_encoder;
>  
> @@ -15,4 +16,6 @@ void intel_dp_aux_init(struct intel_dp *intel_dp);
>  
>  enum aux_ch intel_dp_aux_ch(struct intel_encoder *encoder);
>  
> +void intel_dp_aux_irq_handler(struct drm_i915_private *i915);
> +
>  #endif /* __INTEL_DP_AUX_H__ */
> diff --git a/drivers/gpu/drm/i915/display/intel_gmbus.c b/drivers/gpu/drm/i915/display/intel_gmbus.c
> index 3ddfc8080ee8..e95ddb580ef6 100644
> --- a/drivers/gpu/drm/i915/display/intel_gmbus.c
> +++ b/drivers/gpu/drm/i915/display/intel_gmbus.c
> @@ -991,3 +991,8 @@ void intel_gmbus_teardown(struct drm_i915_private *i915)
>  		i915->display.gmbus.bus[pin] = NULL;
>  	}
>  }
> +
> +void intel_gmbus_irq_handler(struct drm_i915_private *i915)
> +{
> +	wake_up_all(&i915->display.gmbus.wait_queue);
> +}
> diff --git a/drivers/gpu/drm/i915/display/intel_gmbus.h b/drivers/gpu/drm/i915/display/intel_gmbus.h
> index 20f704bd4e70..8111eb23e2af 100644
> --- a/drivers/gpu/drm/i915/display/intel_gmbus.h
> +++ b/drivers/gpu/drm/i915/display/intel_gmbus.h
> @@ -46,4 +46,6 @@ void intel_gmbus_force_bit(struct i2c_adapter *adapter, bool force_bit);
>  bool intel_gmbus_is_forced_bit(struct i2c_adapter *adapter);
>  void intel_gmbus_reset(struct drm_i915_private *dev_priv);
>  
> +void intel_gmbus_irq_handler(struct drm_i915_private *i915);
> +
>  #endif /* __INTEL_GMBUS_H__ */
> diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
> index e5f12aa141f6..02b6cbb832e9 100644
> --- a/drivers/gpu/drm/i915/i915_irq.c
> +++ b/drivers/gpu/drm/i915/i915_irq.c
> @@ -37,8 +37,10 @@
>  #include "display/intel_de.h"
>  #include "display/intel_display_trace.h"
>  #include "display/intel_display_types.h"
> +#include "display/intel_dp_aux.h"
>  #include "display/intel_fdi_regs.h"
>  #include "display/intel_fifo_underrun.h"
> +#include "display/intel_gmbus.h"
>  #include "display/intel_hotplug.h"
>  #include "display/intel_lpe_audio.h"
>  #include "display/intel_psr.h"
> @@ -925,16 +927,6 @@ static u32 intel_hpd_hotplug_enables(struct drm_i915_private *i915,
>  	return hotplug;
>  }
>  
> -static void gmbus_irq_handler(struct drm_i915_private *dev_priv)
> -{
> -	wake_up_all(&dev_priv->display.gmbus.wait_queue);
> -}
> -
> -static void dp_aux_irq_handler(struct drm_i915_private *dev_priv)
> -{
> -	wake_up_all(&dev_priv->display.gmbus.wait_queue);
> -}
> -
>  #if defined(CONFIG_DEBUG_FS)
>  static void display_pipe_crc_irq_handler(struct drm_i915_private *dev_priv,
>  					 enum pipe pipe,
> @@ -1181,7 +1173,7 @@ static void i965_pipestat_irq_handler(struct drm_i915_private *dev_priv,
>  		intel_opregion_asle_intr(dev_priv);
>  
>  	if (pipe_stats[0] & PIPE_GMBUS_INTERRUPT_STATUS)
> -		gmbus_irq_handler(dev_priv);
> +		intel_gmbus_irq_handler(dev_priv);
>  }
>  
>  static void valleyview_pipestat_irq_handler(struct drm_i915_private *dev_priv,
> @@ -1204,7 +1196,7 @@ static void valleyview_pipestat_irq_handler(struct drm_i915_private *dev_priv,
>  	}
>  
>  	if (pipe_stats[0] & PIPE_GMBUS_INTERRUPT_STATUS)
> -		gmbus_irq_handler(dev_priv);
> +		intel_gmbus_irq_handler(dev_priv);
>  }
>  
>  static u32 i9xx_hpd_irq_ack(struct drm_i915_private *dev_priv)
> @@ -1269,7 +1261,7 @@ static void i9xx_hpd_irq_handler(struct drm_i915_private *dev_priv,
>  	if ((IS_G4X(dev_priv) ||
>  	     IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)) &&
>  	    hotplug_status & DP_AUX_CHANNEL_MASK_INT_STATUS_G4X)
> -		dp_aux_irq_handler(dev_priv);
> +		intel_dp_aux_irq_handler(dev_priv);
>  }
>  
>  static irqreturn_t valleyview_irq_handler(int irq, void *arg)
> @@ -1483,10 +1475,10 @@ static void ibx_irq_handler(struct drm_i915_private *dev_priv, u32 pch_iir)
>  	}
>  
>  	if (pch_iir & SDE_AUX_MASK)
> -		dp_aux_irq_handler(dev_priv);
> +		intel_dp_aux_irq_handler(dev_priv);
>  
>  	if (pch_iir & SDE_GMBUS)
> -		gmbus_irq_handler(dev_priv);
> +		intel_gmbus_irq_handler(dev_priv);
>  
>  	if (pch_iir & SDE_AUDIO_HDCP_MASK)
>  		drm_dbg(&dev_priv->drm, "PCH HDCP audio interrupt\n");
> @@ -1571,10 +1563,10 @@ static void cpt_irq_handler(struct drm_i915_private *dev_priv, u32 pch_iir)
>  	}
>  
>  	if (pch_iir & SDE_AUX_MASK_CPT)
> -		dp_aux_irq_handler(dev_priv);
> +		intel_dp_aux_irq_handler(dev_priv);
>  
>  	if (pch_iir & SDE_GMBUS_CPT)
> -		gmbus_irq_handler(dev_priv);
> +		intel_gmbus_irq_handler(dev_priv);
>  
>  	if (pch_iir & SDE_AUDIO_CP_REQ_CPT)
>  		drm_dbg(&dev_priv->drm, "Audio CP request interrupt\n");
> @@ -1624,7 +1616,7 @@ static void xelpdp_pica_irq_handler(struct drm_i915_private *i915, u32 iir)
>  	}
>  
>  	if (trigger_aux)
> -		dp_aux_irq_handler(i915);
> +		intel_dp_aux_irq_handler(i915);
>  
>  	if (!pin_mask && !trigger_aux)
>  		drm_err(&i915->drm,
> @@ -1666,7 +1658,7 @@ static void icp_irq_handler(struct drm_i915_private *dev_priv, u32 pch_iir)
>  		intel_hpd_irq_handler(dev_priv, pin_mask, long_mask);
>  
>  	if (pch_iir & SDE_GMBUS_ICP)
> -		gmbus_irq_handler(dev_priv);
> +		intel_gmbus_irq_handler(dev_priv);
>  }
>  
>  static void spt_irq_handler(struct drm_i915_private *dev_priv, u32 pch_iir)
> @@ -1702,7 +1694,7 @@ static void spt_irq_handler(struct drm_i915_private *dev_priv, u32 pch_iir)
>  		intel_hpd_irq_handler(dev_priv, pin_mask, long_mask);
>  
>  	if (pch_iir & SDE_GMBUS_CPT)
> -		gmbus_irq_handler(dev_priv);
> +		intel_gmbus_irq_handler(dev_priv);
>  }
>  
>  static void ilk_hpd_irq_handler(struct drm_i915_private *dev_priv,
> @@ -1730,7 +1722,7 @@ static void ilk_display_irq_handler(struct drm_i915_private *dev_priv,
>  		ilk_hpd_irq_handler(dev_priv, hotplug_trigger);
>  
>  	if (de_iir & DE_AUX_CHANNEL_A)
> -		dp_aux_irq_handler(dev_priv);
> +		intel_dp_aux_irq_handler(dev_priv);
>  
>  	if (de_iir & DE_GSE)
>  		intel_opregion_asle_intr(dev_priv);
> @@ -1782,7 +1774,7 @@ static void ivb_display_irq_handler(struct drm_i915_private *dev_priv,
>  		ivb_err_int_handler(dev_priv);
>  
>  	if (de_iir & DE_AUX_CHANNEL_A_IVB)
> -		dp_aux_irq_handler(dev_priv);
> +		intel_dp_aux_irq_handler(dev_priv);
>  
>  	if (de_iir & DE_GSE_IVB)
>  		intel_opregion_asle_intr(dev_priv);
> @@ -2174,7 +2166,7 @@ gen8_de_irq_handler(struct drm_i915_private *dev_priv, u32 master_ctl)
>  			ret = IRQ_HANDLED;
>  
>  			if (iir & gen8_de_port_aux_mask(dev_priv)) {
> -				dp_aux_irq_handler(dev_priv);
> +				intel_dp_aux_irq_handler(dev_priv);
>  				found = true;
>  			}
>  
> @@ -2196,7 +2188,7 @@ gen8_de_irq_handler(struct drm_i915_private *dev_priv, u32 master_ctl)
>  
>  			if ((IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv)) &&
>  			    (iir & BXT_DE_PORT_GMBUS)) {
> -				gmbus_irq_handler(dev_priv);
> +				intel_gmbus_irq_handler(dev_priv);
>  				found = true;
>  			}
>  
> -- 
> 2.39.2
> 


More information about the Intel-gfx mailing list