[alsa-devel] [PATCH 1/2] ALSA: hda - make a generic unsol event handler

Takashi Iwai tiwai at suse.de
Mon Oct 8 09:53:57 CEST 2012


At Tue, 25 Sep 2012 11:30:59 +0200,
David Henningsson wrote:
> 
> Moving towards less duplication of code between codecs - this patch
> takes some of the common code of unsol event handling and makes it
> generic.
> 
> Signed-off-by: David Henningsson <david.henningsson at canonical.com>

Applied both patches for 3.7 queue.  Thanks.


Takashi

> ---
>  sound/pci/hda/hda_jack.c |   32 ++++++++++++++++++++++++++++++--
>  sound/pci/hda/hda_jack.h |    9 +++++++++
>  2 files changed, 39 insertions(+), 2 deletions(-)
> 
> diff --git a/sound/pci/hda/hda_jack.c b/sound/pci/hda/hda_jack.c
> index c9333c9..5c690cb 100644
> --- a/sound/pci/hda/hda_jack.c
> +++ b/sound/pci/hda/hda_jack.c
> @@ -192,8 +192,9 @@ EXPORT_SYMBOL_HDA(snd_hda_jack_detect);
>  /**
>   * snd_hda_jack_detect_enable - enable the jack-detection
>   */
> -int snd_hda_jack_detect_enable(struct hda_codec *codec, hda_nid_t nid,
> -			       unsigned char action)
> +int snd_hda_jack_detect_enable_callback(struct hda_codec *codec, hda_nid_t nid,
> +					unsigned char action,
> +					hda_jack_callback cb)
>  {
>  	struct hda_jack_tbl *jack = snd_hda_jack_tbl_new(codec, nid);
>  	if (!jack)
> @@ -203,10 +204,19 @@ int snd_hda_jack_detect_enable(struct hda_codec *codec, hda_nid_t nid,
>  	jack->jack_detect = 1;
>  	if (action)
>  		jack->action = action;
> +	if (cb)
> +		jack->callback = cb;
>  	return snd_hda_codec_write_cache(codec, nid, 0,
>  					 AC_VERB_SET_UNSOLICITED_ENABLE,
>  					 AC_USRSP_EN | jack->tag);
>  }
> +EXPORT_SYMBOL_HDA(snd_hda_jack_detect_enable_callback);
> +
> +int snd_hda_jack_detect_enable(struct hda_codec *codec, hda_nid_t nid,
> +			       unsigned char action)
> +{
> +	return snd_hda_jack_detect_enable_callback(codec, nid, action, NULL);
> +}
>  EXPORT_SYMBOL_HDA(snd_hda_jack_detect_enable);
>  
>  /**
> @@ -411,3 +421,21 @@ int snd_hda_jack_add_kctls(struct hda_codec *codec,
>  	return 0;
>  }
>  EXPORT_SYMBOL_HDA(snd_hda_jack_add_kctls);
> +
> +void snd_hda_jack_unsol_event(struct hda_codec *codec, unsigned int res)
> +{
> +	struct hda_jack_tbl *event;
> +	int tag = (res >> AC_UNSOL_RES_TAG_SHIFT) & 0x7f;
> +
> +	event = snd_hda_jack_tbl_get_from_tag(codec, tag);
> +	if (!event)
> +		return;
> +	event->jack_dirty = 1;
> +
> +	if (event->callback)
> +		event->callback(codec, event);
> +
> +	snd_hda_jack_report_sync(codec);
> +}
> +EXPORT_SYMBOL_HDA(snd_hda_jack_unsol_event);
> +
> diff --git a/sound/pci/hda/hda_jack.h b/sound/pci/hda/hda_jack.h
> index a9803da..af8dd47 100644
> --- a/sound/pci/hda/hda_jack.h
> +++ b/sound/pci/hda/hda_jack.h
> @@ -13,12 +13,16 @@
>  #define __SOUND_HDA_JACK_H
>  
>  struct auto_pin_cfg;
> +struct hda_jack_tbl;
> +
> +typedef void (*hda_jack_callback) (struct hda_codec *, struct hda_jack_tbl *);
>  
>  struct hda_jack_tbl {
>  	hda_nid_t nid;
>  	unsigned char action;		/* event action (0 = none) */
>  	unsigned char tag;		/* unsol event tag */
>  	unsigned int private_data;	/* arbitrary data */
> +	hda_jack_callback callback;
>  	/* jack-detection stuff */
>  	unsigned int pin_sense;		/* cached pin-sense value */
>  	unsigned int jack_detect:1;	/* capable of jack-detection? */
> @@ -61,6 +65,10 @@ void snd_hda_jack_set_dirty_all(struct hda_codec *codec);
>  
>  int snd_hda_jack_detect_enable(struct hda_codec *codec, hda_nid_t nid,
>  			       unsigned char action);
> +int snd_hda_jack_detect_enable_callback(struct hda_codec *codec, hda_nid_t nid,
> +					unsigned char action,
> +					hda_jack_callback cb);
> +
>  
>  u32 snd_hda_pin_sense(struct hda_codec *codec, hda_nid_t nid);
>  int snd_hda_jack_detect(struct hda_codec *codec, hda_nid_t nid);
> @@ -74,5 +82,6 @@ int snd_hda_jack_add_kctls(struct hda_codec *codec,
>  
>  void snd_hda_jack_report_sync(struct hda_codec *codec);
>  
> +void snd_hda_jack_unsol_event(struct hda_codec *codec, unsigned int res);
>  
>  #endif /* __SOUND_HDA_JACK_H */
> -- 
> 1.7.9.5
> 


More information about the Alsa-devel mailing list