Commit 98869f68 authored by Mark Brown's avatar Mark Brown
Browse files

ASoC: wm8994: Allow microphone identification callback to be overridden



Allow custom accessory identification mechanisms to make use of the MICDET
support in the device.

Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
parent e874de43
Loading
Loading
Loading
Loading
+16 −6
Original line number Original line Diff line number Diff line
@@ -3432,8 +3432,9 @@ static void wm8958_button_det(struct snd_soc_codec *codec, u16 status)
			    wm8994->btn_mask);
			    wm8994->btn_mask);
}
}


static void wm8958_mic_id(struct snd_soc_codec *codec, u16 status)
static void wm8958_mic_id(void *data, u16 status)
{
{
	struct snd_soc_codec *codec = data;
	struct wm8994_priv *wm8994 = snd_soc_codec_get_drvdata(codec);
	struct wm8994_priv *wm8994 = snd_soc_codec_get_drvdata(codec);


	/* Either nothing present or just starting detection */
	/* Either nothing present or just starting detection */
@@ -3629,7 +3630,8 @@ static void wm1811_jackdet_bootstrap(struct work_struct *work)
 * detection algorithm.
 * detection algorithm.
 */
 */
int wm8958_mic_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack,
int wm8958_mic_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack,
		      wm1811_micdet_cb cb, void *cb_data)
		      wm1811_micdet_cb det_cb, void *det_cb_data,
		      wm1811_mic_id_cb id_cb, void *id_cb_data)
{
{
	struct wm8994_priv *wm8994 = snd_soc_codec_get_drvdata(codec);
	struct wm8994_priv *wm8994 = snd_soc_codec_get_drvdata(codec);
	struct wm8994 *control = wm8994->wm8994;
	struct wm8994 *control = wm8994->wm8994;
@@ -3649,14 +3651,22 @@ int wm8958_mic_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack,


		wm8994->micdet[0].jack = jack;
		wm8994->micdet[0].jack = jack;


		if (cb) {
		if (det_cb) {
			wm8994->micd_cb = cb;
			wm8994->micd_cb = det_cb;
			wm8994->micd_cb_data = cb_data;
			wm8994->micd_cb_data = det_cb_data;
		} else {
		} else {
			wm8994->mic_detecting = true;
			wm8994->mic_detecting = true;
			wm8994->jack_mic = false;
			wm8994->jack_mic = false;
		}
		}


		if (id_cb) {
			wm8994->mic_id_cb = id_cb;
			wm8994->mic_id_cb_data = id_cb_data;
		} else {
			wm8994->mic_id_cb = wm8958_mic_id;
			wm8994->mic_id_cb_data = codec;
		}

		wm8958_micd_set_rate(codec);
		wm8958_micd_set_rate(codec);


		/* Detect microphones and short circuits by default */
		/* Detect microphones and short circuits by default */
@@ -3768,7 +3778,7 @@ static irqreturn_t wm8958_mic_irq(int irq, void *data)
	}
	}


	if (wm8994->mic_detecting)
	if (wm8994->mic_detecting)
		wm8958_mic_id(codec, reg);
		wm8994->mic_id_cb(wm8994->mic_id_cb_data, reg);
	else
	else
		wm8958_button_det(codec, reg);
		wm8958_button_det(codec, reg);


+5 −1
Original line number Original line Diff line number Diff line
@@ -40,11 +40,13 @@ enum wm8994_vmid_mode {
};
};


typedef void (*wm1811_micdet_cb)(void *data);
typedef void (*wm1811_micdet_cb)(void *data);
typedef void (*wm1811_mic_id_cb)(void *data, u16 status);


int wm8994_mic_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack,
int wm8994_mic_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack,
		      int micbias);
		      int micbias);
int wm8958_mic_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack,
int wm8958_mic_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack,
		      wm1811_micdet_cb cb, void *cb_data);
		      wm1811_micdet_cb cb, void *det_cb_data,
		      wm1811_mic_id_cb id_cb, void *id_cb_data);


int wm8994_vmid_mode(struct snd_soc_codec *codec, enum wm8994_vmid_mode mode);
int wm8994_vmid_mode(struct snd_soc_codec *codec, enum wm8994_vmid_mode mode);


@@ -140,6 +142,8 @@ struct wm8994_priv {
	int micdet_irq;
	int micdet_irq;
	wm1811_micdet_cb micd_cb;
	wm1811_micdet_cb micd_cb;
	void *micd_cb_data;
	void *micd_cb_data;
	wm1811_mic_id_cb mic_id_cb;
	void *mic_id_cb_data;


	int revision;
	int revision;


+1 −1
Original line number Original line Diff line number Diff line
@@ -270,7 +270,7 @@ static int littlemill_late_probe(struct snd_soc_card *card)
		return ret;
		return ret;


	/* This will check device compatibility itself */
	/* This will check device compatibility itself */
	wm8958_mic_detect(codec, &littlemill_headset, NULL, NULL);
	wm8958_mic_detect(codec, &littlemill_headset, NULL, NULL, NULL, NULL);


	/* As will this */
	/* As will this */
	wm8994_mic_detect(codec, &littlemill_headset, 1);
	wm8994_mic_detect(codec, &littlemill_headset, 1);