xref: /linux/sound/soc/codecs/aw88081.h (revision 7f4f3b14e8079ecde096bd734af10e30d40c27b7)
1 // SPDX-License-Identifier: GPL-2.0-only
2 //
3 // aw88081.h  --  AW88081 ALSA SoC Audio driver
4 //
5 // Copyright (c) 2024 awinic Technology CO., LTD
6 //
7 // Author: Weidong Wang <wangweidong.a@awinic.com>
8 //
9 
10 #ifndef __AW88081_H__
11 #define __AW88081_H__
12 
13 #define AW88081_ID_REG			(0x00)
14 #define AW88081_SYSST_REG		(0x01)
15 #define AW88081_SYSINT_REG		(0x02)
16 #define AW88081_SYSINTM_REG		(0x03)
17 #define AW88081_SYSCTRL_REG		(0x04)
18 #define AW88081_SYSCTRL2_REG		(0x05)
19 #define AW88081_I2SCTRL1_REG		(0x06)
20 #define AW88081_I2SCTRL2_REG		(0x07)
21 #define AW88081_I2SCTRL3_REG		(0x08)
22 #define AW88081_DACCFG1_REG		(0x09)
23 #define AW88081_DACCFG2_REG		(0x0A)
24 #define AW88081_DACCFG3_REG		(0x0B)
25 #define AW88081_DACCFG4_REG		(0x0C)
26 #define AW88081_DACCFG5_REG		(0x0D)
27 #define AW88081_DACCFG6_REG		(0x0E)
28 #define AW88081_DACCFG7_REG		(0x11)
29 #define AW88081_PWMCTRL1_REG		(0x13)
30 #define AW88081_PWMCTRL2_REG		(0x14)
31 #define AW88081_PWMCTRL3_REG		(0x15)
32 #define AW88081_PWMCTRL4_REG		(0x16)
33 #define AW88081_I2SCFG1_REG		(0x17)
34 #define AW88081_DBGCTRL_REG		(0x18)
35 #define AW88081_PDMCTRL_REG		(0x19)
36 #define AW88081_DACST_REG		(0x20)
37 #define AW88081_PATTERNST_REG		(0x21)
38 #define AW88081_I2SINT_REG		(0x26)
39 #define AW88081_I2SCAPCNT_REG		(0x27)
40 #define AW88081_ANASTA1_REG		(0x28)
41 #define AW88081_ANASTA2_REG		(0x29)
42 #define AW88081_ANASTA3_REG		(0x2A)
43 #define AW88081_VBAT_REG		(0x21)
44 #define AW88081_TEMP_REG		(0x22)
45 #define AW88081_PVDD_REG		(0x23)
46 #define AW88081_ISNDAT_REG		(0x24)
47 #define AW88081_VSNDAT_REG		(0x25)
48 #define AW88081_DSMCFG1_REG		(0x30)
49 #define AW88081_DSMCFG2_REG		(0x31)
50 #define AW88081_DSMCFG3_REG		(0x32)
51 #define AW88081_DSMCFG4_REG		(0x33)
52 #define AW88081_DSMCFG5_REG		(0x34)
53 #define AW88081_DSMCFG6_REG		(0x35)
54 #define AW88081_DSMCFG7_REG		(0x36)
55 #define AW88081_DSMCFG8_REG		(0x37)
56 #define AW88081_TESTIN_REG		(0x38)
57 #define AW88081_TESTOUT_REG		(0x39)
58 #define AW88081_BOPCTRL1_REG		(0x40)
59 #define AW88081_BOPCTRL2_REG		(0x41)
60 #define AW88081_BOPCTRL3_REG		(0x42)
61 #define AW88081_BOPSTA_REG		(0x43)
62 #define AW88081_PLLCTRL1_REG		(0x54)
63 #define AW88081_PLLCTRL2_REG		(0x55)
64 #define AW88081_PLLCTRL3_REG		(0x56)
65 #define AW88081_CDACTRL1_REG		(0x57)
66 #define AW88081_CDACTRL2_REG		(0x58)
67 #define AW88081_CDACTRL3_REG		(0x59)
68 #define AW88081_DITHERCFG1_REG		(0x5A)
69 #define AW88081_DITHERCFG2_REG		(0x5B)
70 #define AW88081_DITHERCFG3_REG		(0x5C)
71 #define AW88081_TM_REG			(0x6E)
72 #define AW88081_TM2_REG		(0x6F)
73 #define AW88081_TESTCTRL1_REG		(0x70)
74 #define AW88081_TESTCTRL2_REG		(0x71)
75 
76 #define AW88081_REG_MAX		(0x72)
77 
78 #define AW88081_UVLS_START_BIT		(14)
79 #define AW88081_UVLS_UVLO		(1)
80 #define AW88081_UVLS_UVLO_VALUE	\
81 	(AW88081_UVLS_UVLO << AW88081_UVLS_START_BIT)
82 
83 #define AW88081_SWS_START_BIT		(8)
84 #define AW88081_SWS_SWITCHING		(1)
85 #define AW88081_SWS_SWITCHING_VALUE	\
86 	(AW88081_SWS_SWITCHING << AW88081_SWS_START_BIT)
87 
88 #define AW88081_NOCLKS_START_BIT	(5)
89 #define AW88081_NOCLKS_NO_CLOCK	(1)
90 #define AW88081_NOCLKS_NO_CLOCK_VALUE	\
91 	(AW88081_NOCLKS_NO_CLOCK << AW88081_NOCLKS_START_BIT)
92 
93 #define AW88081_CLKS_START_BIT		(4)
94 #define AW88081_CLKS_STABLE		(1)
95 #define AW88081_CLKS_STABLE_VALUE	\
96 	(AW88081_CLKS_STABLE << AW88081_CLKS_START_BIT)
97 
98 #define AW88081_OCDS_START_BIT		(3)
99 #define AW88081_OCDS_OC		(1)
100 #define AW88081_OCDS_OC_VALUE		\
101 	(AW88081_OCDS_OC << AW88081_OCDS_START_BIT)
102 
103 #define AW88081_OTHS_START_BIT		(1)
104 #define AW88081_OTHS_OT		(1)
105 #define AW88081_OTHS_OT_VALUE		\
106 	(AW88081_OTHS_OT << AW88081_OTHS_START_BIT)
107 
108 #define AW88081_PLLS_START_BIT		(0)
109 #define AW88081_PLLS_LOCKED		(1)
110 #define AW88081_PLLS_LOCKED_VALUE	\
111 	(AW88081_PLLS_LOCKED << AW88081_PLLS_START_BIT)
112 
113 #define AW88081_BIT_PLL_CHECK \
114 		(AW88081_CLKS_STABLE_VALUE | \
115 		AW88081_PLLS_LOCKED_VALUE)
116 
117 #define AW88081_BIT_SYSST_CHECK_MASK \
118 		(~(AW88081_UVLS_UVLO_VALUE | \
119 		AW88081_SWS_SWITCHING_VALUE | \
120 		AW88081_NOCLKS_NO_CLOCK_VALUE | \
121 		AW88081_CLKS_STABLE_VALUE | \
122 		AW88081_OCDS_OC_VALUE | \
123 		AW88081_OTHS_OT_VALUE | \
124 		AW88081_PLLS_LOCKED_VALUE))
125 
126 #define AW88081_NO_SWS_SYSST_CHECK \
127 		(AW88081_CLKS_STABLE_VALUE | \
128 		AW88081_PLLS_LOCKED_VALUE)
129 
130 #define AW88081_SWS_SYSST_CHECK \
131 	(AW88081_SWS_SWITCHING_VALUE | \
132 	AW88081_CLKS_STABLE_VALUE | \
133 	AW88081_PLLS_LOCKED_VALUE)
134 
135 #define AW88081_ULS_HMUTE_START_BIT	(14)
136 #define AW88081_ULS_HMUTE_BITS_LEN	(1)
137 #define AW88081_ULS_HMUTE_MASK		\
138 	(~(((1<<AW88081_ULS_HMUTE_BITS_LEN)-1) << AW88081_ULS_HMUTE_START_BIT))
139 
140 #define AW88081_ULS_HMUTE_DISABLE	(0)
141 #define AW88081_ULS_HMUTE_DISABLE_VALUE	\
142 	(AW88081_ULS_HMUTE_DISABLE << AW88081_ULS_HMUTE_START_BIT)
143 
144 #define AW88081_ULS_HMUTE_ENABLE	(1)
145 #define AW88081_ULS_HMUTE_ENABLE_VALUE	\
146 	(AW88081_ULS_HMUTE_ENABLE << AW88081_ULS_HMUTE_START_BIT)
147 
148 #define AW88081_HMUTE_START_BIT	(8)
149 #define AW88081_HMUTE_BITS_LEN		(1)
150 #define AW88081_HMUTE_MASK		\
151 	(~(((1<<AW88081_HMUTE_BITS_LEN)-1) << AW88081_HMUTE_START_BIT))
152 
153 #define AW88081_HMUTE_DISABLE		(0)
154 #define AW88081_HMUTE_DISABLE_VALUE	\
155 	(AW88081_HMUTE_DISABLE << AW88081_HMUTE_START_BIT)
156 
157 #define AW88081_HMUTE_ENABLE		(1)
158 #define AW88081_HMUTE_ENABLE_VALUE	\
159 	(AW88081_HMUTE_ENABLE << AW88081_HMUTE_START_BIT)
160 
161 #define AW88081_EN_PA_START_BIT	(1)
162 #define AW88081_EN_PA_BITS_LEN		(1)
163 #define AW88081_EN_PA_MASK		\
164 	(~(((1<<AW88081_EN_PA_BITS_LEN)-1) << AW88081_EN_PA_START_BIT))
165 
166 #define AW88081_EN_PA_WORKING		(1)
167 #define AW88081_EN_PA_WORKING_VALUE	\
168 	(AW88081_EN_PA_WORKING << AW88081_EN_PA_START_BIT)
169 
170 #define AW88081_EN_PA_POWER_DOWN	(0)
171 #define AW88081_EN_PA_POWER_DOWN_VALUE	\
172 	(AW88081_EN_PA_POWER_DOWN << AW88081_EN_PA_START_BIT)
173 
174 #define AW88081_PWDN_START_BIT		(0)
175 #define AW88081_PWDN_BITS_LEN		(1)
176 #define AW88081_PWDN_MASK		\
177 	(~(((1<<AW88081_PWDN_BITS_LEN)-1) << AW88081_PWDN_START_BIT))
178 
179 #define AW88081_PWDN_WORKING		(0)
180 #define AW88081_PWDN_WORKING_VALUE	\
181 	(AW88081_PWDN_WORKING << AW88081_PWDN_START_BIT)
182 
183 #define AW88081_PWDN_POWER_DOWN	(1)
184 #define AW88081_PWDN_POWER_DOWN_VALUE	\
185 	(AW88081_PWDN_POWER_DOWN << AW88081_PWDN_START_BIT)
186 
187 #define AW88081_VOL_START_BIT		(0)
188 #define AW88081_VOL_BITS_LEN		(10)
189 #define AW88081_VOL_MASK		\
190 	(~(((1<<AW88081_VOL_BITS_LEN)-1) << AW88081_VOL_START_BIT))
191 
192 #define AW88081_VOLUME_STEP_DB		(64)
193 #define AW88081_MUTE_VOL		(1023)
194 
195 #define AW88081_I2STXEN_START_BIT	(6)
196 #define AW88081_I2STXEN_BITS_LEN	(1)
197 #define AW88081_I2STXEN_MASK		\
198 	(~(((1<<AW88081_I2STXEN_BITS_LEN)-1) << AW88081_I2STXEN_START_BIT))
199 
200 #define AW88081_I2STXEN_DISABLE	(0)
201 #define AW88081_I2STXEN_DISABLE_VALUE	\
202 	(AW88081_I2STXEN_DISABLE << AW88081_I2STXEN_START_BIT)
203 
204 #define AW88081_I2STXEN_ENABLE		(1)
205 #define AW88081_I2STXEN_ENABLE_VALUE	\
206 	(AW88081_I2STXEN_ENABLE << AW88081_I2STXEN_START_BIT)
207 
208 #define AW88081_NOISE_GATE_EN_START_BIT	(13)
209 #define AW88081_NOISE_GATE_EN_BITS_LEN	(1)
210 #define AW88081_NOISE_GATE_EN_MASK	\
211 		(~(((1<<AW88081_NOISE_GATE_EN_BITS_LEN)-1) << AW88081_NOISE_GATE_EN_START_BIT))
212 
213 #define AW88081_NOISE_GATE_EN_DISABLE	(0)
214 #define AW88081_NOISE_GATE_EN_DISABLE_VALUE	\
215 		(AW88081_NOISE_GATE_EN_DISABLE << AW88081_NOISE_GATE_EN_START_BIT)
216 
217 #define AW88081_NOISE_GATE_EN_ENABLE	(1)
218 #define AW88081_NOISE_GATE_EN_ENABLE_VALUE	\
219 		(AW88081_NOISE_GATE_EN_ENABLE << AW88081_NOISE_GATE_EN_START_BIT)
220 
221 #define AW88081_CCO_MUX_START_BIT	(13)
222 #define AW88081_CCO_MUX_BITS_LEN	(1)
223 #define AW88081_CCO_MUX_MASK		\
224 	(~(((1<<AW88081_CCO_MUX_BITS_LEN)-1) << AW88081_CCO_MUX_START_BIT))
225 
226 #define AW88081_CCO_MUX_DIVIDED	(0)
227 #define AW88081_CCO_MUX_DIVIDED_VALUE	\
228 	(AW88081_CCO_MUX_DIVIDED << AW88081_CCO_MUX_START_BIT)
229 
230 #define AW88081_CCO_MUX_BYPASS		(1)
231 #define AW88081_CCO_MUX_BYPASS_VALUE	\
232 	(AW88081_CCO_MUX_BYPASS << AW88081_CCO_MUX_START_BIT)
233 
234 #define AW88081_START_RETRIES		(5)
235 #define AW88081_START_WORK_DELAY_MS	(0)
236 
237 #define AW88081_I2C_NAME		"aw88081"
238 #define AW88081_CHIP_ID		0x2116
239 
240 #define AW88081_RATES (SNDRV_PCM_RATE_8000_48000 | \
241 			SNDRV_PCM_RATE_96000)
242 #define AW88081_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | \
243 			SNDRV_PCM_FMTBIT_S24_LE | \
244 			SNDRV_PCM_FMTBIT_S32_LE)
245 
246 #define FADE_TIME_MAX			100000
247 
248 #define AW88081_DEV_DEFAULT_CH		(0)
249 #define AW88081_ACF_FILE		"aw88081_acf.bin"
250 #define AW88081_DEV_SYSST_CHECK_MAX	(10)
251 #define AW88081_SOFT_RESET_VALUE	(0x55aa)
252 
253 #define AW88081_INIT_PROFILE		(0)
254 
255 #define AW88081_PROFILE_EXT(xname, profile_info, profile_get, profile_set) \
256 { \
257 	.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
258 	.name = xname, \
259 	.info = profile_info, \
260 	.get = profile_get, \
261 	.put = profile_set, \
262 }
263 
264 enum {
265 	AW88081_SYNC_START = 0,
266 	AW88081_ASYNC_START,
267 };
268 
269 enum {
270 	AW88081_500_US = 500,
271 	AW88081_1000_US = 1000,
272 	AW88081_2000_US = 2000,
273 	AW88081_5000_US = 5000,
274 };
275 
276 enum {
277 	AW88081_DEV_PW_OFF = 0,
278 	AW88081_DEV_PW_ON,
279 };
280 
281 enum {
282 	AW88081_DEV_FW_FAILED = 0,
283 	AW88081_DEV_FW_OK,
284 };
285 
286 #endif
287