blob: 1d6f2abe1c1137bb6edfac9d1907234ba5df3777 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Mark Brown9e6e96a2010-01-29 17:47:12 +00002/*
3 * wm8994.h -- WM8994 Soc Audio driver
Mark Brown9e6e96a2010-01-29 17:47:12 +00004 */
5
6#ifndef _WM8994_H
7#define _WM8994_H
8
9#include <sound/soc.h>
Mark Brownfbbf5922011-03-11 18:09:04 +000010#include <linux/firmware.h>
Mark Brownc7ebf932011-07-12 19:47:59 +090011#include <linux/completion.h>
Mark Browne9b54de42012-05-09 19:20:59 +010012#include <linux/workqueue.h>
Lars-Peter Clausenfabfad22014-11-09 17:01:02 +010013#include <linux/mutex.h>
Mark Brown9e6e96a2010-01-29 17:47:12 +000014
Mark Brownf701a2e2011-03-09 19:31:01 +000015#include "wm_hubs.h"
16
Mark Brown9e6e96a2010-01-29 17:47:12 +000017/* Sources for AIF1/2 SYSCLK - use with set_dai_sysclk() */
18#define WM8994_SYSCLK_MCLK1 1
19#define WM8994_SYSCLK_MCLK2 2
20#define WM8994_SYSCLK_FLL1 3
21#define WM8994_SYSCLK_FLL2 4
22
Mark Brown66b47fd2010-07-08 11:25:43 +090023/* OPCLK is also configured with set_dai_sysclk, specify division*10 as rate. */
24#define WM8994_SYSCLK_OPCLK 5
25
Mark Brown9e6e96a2010-01-29 17:47:12 +000026#define WM8994_FLL1 1
27#define WM8994_FLL2 2
28
Mark Brownfbfe6982012-07-23 20:14:43 +010029#define WM8994_FLL_SRC_MCLK1 1
30#define WM8994_FLL_SRC_MCLK2 2
31#define WM8994_FLL_SRC_LRCLK 3
32#define WM8994_FLL_SRC_BCLK 4
33#define WM8994_FLL_SRC_INTERNAL 5
Mark Brown136ff2a2010-04-20 12:56:18 +090034
Mark Brown22f8d052012-03-19 17:32:06 +000035enum wm8994_vmid_mode {
36 WM8994_VMID_NORMAL,
37 WM8994_VMID_FORCE,
38};
39
Mark Brown63dd5452012-11-22 20:44:32 +090040typedef void (*wm1811_micdet_cb)(void *data);
Mark Brown98869f62012-12-03 16:14:37 +090041typedef void (*wm1811_mic_id_cb)(void *data, u16 status);
Mark Brown821edd22010-11-26 15:21:09 +000042
Kuninori Morimoto00a69412018-01-29 03:12:21 +000043int wm8994_mic_detect(struct snd_soc_component *component, struct snd_soc_jack *jack,
Mark Brown87092e32012-02-06 18:50:39 +000044 int micbias);
Kuninori Morimoto00a69412018-01-29 03:12:21 +000045int wm8958_mic_detect(struct snd_soc_component *component, struct snd_soc_jack *jack,
Mark Brown98869f62012-12-03 16:14:37 +090046 wm1811_micdet_cb cb, void *det_cb_data,
47 wm1811_mic_id_cb id_cb, void *id_cb_data);
Mark Brown88766982010-03-29 20:57:12 +010048
Kuninori Morimoto00a69412018-01-29 03:12:21 +000049int wm8994_vmid_mode(struct snd_soc_component *component, enum wm8994_vmid_mode mode);
Mark Brown22f8d052012-03-19 17:32:06 +000050
Mark Brownf701a2e2011-03-09 19:31:01 +000051int wm8958_aif_ev(struct snd_soc_dapm_widget *w,
52 struct snd_kcontrol *kcontrol, int event);
53
Kuninori Morimoto00a69412018-01-29 03:12:21 +000054void wm8958_dsp2_init(struct snd_soc_component *component);
Mark Brownf701a2e2011-03-09 19:31:01 +000055
56struct wm8994_micdet {
57 struct snd_soc_jack *jack;
Mark Brown87092e32012-02-06 18:50:39 +000058 bool detecting;
Mark Brownf701a2e2011-03-09 19:31:01 +000059};
60
61/* codec private data */
62struct wm8994_fll_config {
63 int src;
64 int in;
65 int out;
66};
67
68#define WM8994_NUM_DRC 3
69#define WM8994_NUM_EQ 3
70
Mark Brown2a8a8562011-07-24 12:20:41 +010071struct wm8994;
72
Mark Brownf701a2e2011-03-09 19:31:01 +000073struct wm8994_priv {
74 struct wm_hubs_data hubs;
Mark Brown2a8a8562011-07-24 12:20:41 +010075 struct wm8994 *wm8994;
Mark Brownf701a2e2011-03-09 19:31:01 +000076 int sysclk[2];
77 int sysclk_rate[2];
78 int mclk[2];
79 int aifclk[2];
Mark Brownd3725762013-01-29 23:17:12 +080080 int aifdiv[2];
Mark Brown79748cd2012-10-01 15:28:30 +010081 int channels[2];
Mark Brownf701a2e2011-03-09 19:31:01 +000082 struct wm8994_fll_config fll[2], fll_suspend[2];
Mark Brownc7ebf932011-07-12 19:47:59 +090083 struct completion fll_locked[2];
84 bool fll_locked_irq;
Mark Brown20dc24a2012-04-05 12:55:20 +010085 bool fll_byp;
Mark Brown99af79d2012-07-25 23:03:36 +010086 bool clk_has_run;
Mark Brownf701a2e2011-03-09 19:31:01 +000087
Mark Brown4b7ed832011-08-10 17:47:33 +090088 int vmid_refcount;
Mark Brownaf6b6fe2011-11-30 20:32:05 +000089 int active_refcount;
Mark Brown22f8d052012-03-19 17:32:06 +000090 enum wm8994_vmid_mode vmid_mode;
Mark Brown4b7ed832011-08-10 17:47:33 +090091
Mark Brownf701a2e2011-03-09 19:31:01 +000092 int dac_rates[2];
93 int lrclk_shared[2];
94
95 int mbc_ena[3];
Mark Brown09e10d72011-03-16 22:57:47 +000096 int hpf1_ena[3];
97 int hpf2_ena[3];
98 int vss_ena[3];
Mark Brown31215872011-03-17 20:23:43 +000099 int enh_eq_ena[3];
Mark Brownf701a2e2011-03-09 19:31:01 +0000100
101 /* Platform dependant DRC configuration */
102 const char **drc_texts;
103 int drc_cfg[WM8994_NUM_DRC];
104 struct soc_enum drc_enum;
105
106 /* Platform dependant ReTune mobile configuration */
107 int num_retune_mobile_texts;
108 const char **retune_mobile_texts;
109 int retune_mobile_cfg[WM8994_NUM_EQ];
110 struct soc_enum retune_mobile_enum;
111
112 /* Platform dependant MBC configuration */
113 int mbc_cfg;
114 const char **mbc_texts;
115 struct soc_enum mbc_enum;
116
Mark Brown09e10d72011-03-16 22:57:47 +0000117 /* Platform dependant VSS configuration */
118 int vss_cfg;
119 const char **vss_texts;
120 struct soc_enum vss_enum;
121
122 /* Platform dependant VSS HPF configuration */
123 int vss_hpf_cfg;
124 const char **vss_hpf_texts;
125 struct soc_enum vss_hpf_enum;
126
Mark Brown31215872011-03-17 20:23:43 +0000127 /* Platform dependant enhanced EQ configuration */
128 int enh_eq_cfg;
129 const char **enh_eq_texts;
130 struct soc_enum enh_eq_enum;
131
Mark Brownaf6b6fe2011-11-30 20:32:05 +0000132 struct mutex accdet_lock;
Mark Brownf701a2e2011-03-09 19:31:01 +0000133 struct wm8994_micdet micdet[2];
Mark Browne9b54de42012-05-09 19:20:59 +0100134 struct delayed_work mic_work;
Mark Brown70bd3b22013-05-29 20:28:16 +0100135 struct delayed_work open_circuit_work;
Mark Brown2da1c4b2013-05-30 13:42:29 +0100136 struct delayed_work mic_complete_work;
137 u16 mic_status;
Mark Brown157a75e2011-11-30 13:43:51 +0000138 bool mic_detecting;
Mark Brownb00adf72011-08-13 11:57:18 +0900139 bool jack_mic;
Mark Brown4585790d2011-11-30 10:55:14 +0000140 int btn_mask;
Mark Brownaf6b6fe2011-11-30 20:32:05 +0000141 bool jackdet;
Mark Brown4752a882012-03-04 02:16:01 +0000142 int jackdet_mode;
Mark Brown99af79d2012-07-25 23:03:36 +0100143 struct delayed_work jackdet_bootstrap;
Mark Brownf701a2e2011-03-09 19:31:01 +0000144
Mark Brownf701a2e2011-03-09 19:31:01 +0000145 int micdet_irq;
Mark Brown63dd5452012-11-22 20:44:32 +0900146 wm1811_micdet_cb micd_cb;
147 void *micd_cb_data;
Mark Brown98869f62012-12-03 16:14:37 +0900148 wm1811_mic_id_cb mic_id_cb;
149 void *mic_id_cb_data;
Mark Brownf701a2e2011-03-09 19:31:01 +0000150
Mark Brownf701a2e2011-03-09 19:31:01 +0000151 unsigned int aif1clk_enable:1;
152 unsigned int aif2clk_enable:1;
153
154 unsigned int aif1clk_disable:1;
155 unsigned int aif2clk_disable:1;
Mark Brownfbbf5922011-03-11 18:09:04 +0000156
Lars-Peter Clausenfabfad22014-11-09 17:01:02 +0100157 struct mutex fw_lock;
Mark Brownf20d77c2011-03-16 20:55:37 +0000158 int dsp_active;
Mark Brownfbbf5922011-03-11 18:09:04 +0000159 const struct firmware *cur_fw;
160 const struct firmware *mbc;
Mark Brown09e10d72011-03-16 22:57:47 +0000161 const struct firmware *mbc_vss;
Mark Brown31215872011-03-17 20:23:43 +0000162 const struct firmware *enh_eq;
Mark Brownf701a2e2011-03-09 19:31:01 +0000163};
164
Mark Brown9e6e96a2010-01-29 17:47:12 +0000165#endif