GNU Linux-libre 6.9.1-gnu
[releases.git] / sound / soc / codecs / es83xx-dsm-common.h
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Copyright (c) Intel Corporation, 2022
4  * Copyright Everest Semiconductor Co.,Ltd
5  */
6
7 /* Definitions extracted from ASL file provided at
8  * https://github.com/thesofproject/linux/files/9398723/ESSX8326.zip
9  */
10
11 #ifndef _ES83XX_DSM_COMMON_H
12 #define _ES83XX_DSM_COMMON_H
13
14 /***************************************************
15  *  DSM arguments                                  *
16  ***************************************************/
17
18 #define PLATFORM_MAINMIC_TYPE_ARG               0x00
19 #define PLATFORM_HPMIC_TYPE_ARG                 0x01
20 #define PLATFORM_SPK_TYPE_ARG                   0x02
21 #define PLATFORM_HPDET_INV_ARG                  0x03
22 #define PLATFORM_PCM_TYPE_ARG                   0x04
23
24 #define PLATFORM_MIC_DE_POP_ARG                 0x06
25 #define PLATFORM_CODEC_TYPE_ARG                 0x0E
26 #define PLATFORM_BUS_SLOT_ARG                   0x0F
27
28 #define HP_CODEC_LINEIN_PGA_GAIN_ARG            0x10
29 #define MAIN_CODEC_LINEIN_PGA_GAIN_ARG          0x20
30
31 #define HP_CODEC_D2SEPGA_GAIN_ARG               0x11
32 #define MAIN_CODEC_D2SEPGA_GAIN_ARG             0x21
33
34 #define HP_CODEC_ADC_VOLUME_ARG                 0x12
35 #define MAIN_CODEC_ADC_VOLUME_ARG               0x22
36
37 #define HP_CODEC_ADC_ALC_ENABLE_ARG             0x13
38 #define MAIN_CODEC_ADC_ALC_ENABLE_ARG           0x23
39
40 #define HP_CODEC_ADC_ALC_TARGET_LEVEL_ARG       0x14
41 #define MAIN_CODEC_ADC_ALC_TARGET_LEVEL_ARG     0x24
42
43 #define HP_CODEC_ADC_ALC_MAXGAIN_ARG            0x15
44 #define MAIN_CODEC_ADC_ALC_MAXGAIN_ARG          0x25
45
46 #define HP_CODEC_ADC_ALC_MINGAIN_ARG            0x16
47 #define MAIN_CODEC_ADC_ALC_MINGAIN_ARG          0x26
48
49 #define HP_CODEC_ADC_ALC_HLDTIME_ARG            0x17
50 #define MAIN_CODEC_ADC_ALC_HLDTIME_ARG          0x27
51
52 #define HP_CODEC_ADC_ALC_DCYTIME_ARG            0x18
53 #define MAIN_CODEC_ADC_ALC_DCYTIME_ARG          0x28
54
55 #define HP_CODEC_ADC_ALC_ATKTIME_ARG            0x19
56 #define MAIN_CODEC_ADC_ALC_ATKTIME_ARG          0x29
57
58 #define HP_CODEC_ADC_ALC_NGTYPE_ARG             0x1a
59 #define MAIN_CODEC_ADC_ALC_NGTYPE_ARG           0x2a
60
61 #define HP_CODEC_ADC_ALC_NGTHLD_ARG             0x1b
62 #define MAIN_CODEC_ADC_ALC_NGTHLD_ARG           0x2b
63
64 #define MAIN_CODEC_ADC_GUI_STEP_ARG             0x2c
65 #define MAIN_CODEC_ADC_GUI_GAIN_RANGE_ARG       0x2c
66
67 #define HEADPHONE_DUMMY_REMOVE_ENABLE_ARG       0x2e
68
69 #define HP_CODEC_DAC_HPMIX_HIGAIN_ARG           0x40
70 #define SPK_CODEC_DAC_HPMIX_HIGAIN_ARG          0x50
71
72 #define HP_CODEC_DAC_HPMIX_VOLUME_ARG           0x41
73 #define SPK_CODEC_DAC_HPMIX_VOLUME_ARG          0x51
74
75 #define HP_CODEC_DAC_HPOUT_VOLUME_ARG           0x42
76 #define SPK_CODEC_DAC_HPOUT_VOLUME_ARG          0x52
77
78 #define HP_CODEC_LDAC_VOLUME_ARG                0x44
79 #define HP_CODEC_RDAC_VOLUME_ARG                0x54
80
81 #define SPK_CODEC_LDAC_VOLUME_ARG               0x45
82 #define SPK_CODEC_RDAC_VOLUME_ARG               0x55
83
84 #define HP_CODEC_DAC_AUTOMUTE_ARG               0x46
85 #define SPK_CODEC_DAC_AUTOMUTE_ARG              0x56
86
87 #define HP_CODEC_DAC_MONO_ARG                   0x4A
88 #define SPK_CODEC_DAC_MONO_ARG                  0x5A
89
90 #define HP_CTL_IO_LEVEL_ARG                     0x4B
91 #define SPK_CTL_IO_LEVEL_ARG                    0x5B
92
93 #define CODEC_GPIO0_FUNC_ARG                    0x80
94 #define CODEC_GPIO1_FUNC_ARG                    0x81
95 #define CODEC_GPIO2_FUNC_ARG                    0x82
96 #define CODEC_GPIO3_FUNC_ARG                    0x83
97 #define CODEC_GPIO4_FUNC_ARG                    0x84
98
99 #define PLATFORM_MCLK_LRCK_FREQ_ARG             0x85
100
101 /***************************************************
102  *  Values for arguments                           *
103  ***************************************************/
104
105 /* Main and HP Mic */
106 #define PLATFORM_MIC_DMIC_HIGH_LEVEL            0xAA
107 #define PLATFORM_MIC_DMIC_LOW_LEVEL             0x55
108 #define PLATFORM_MIC_AMIC_LIN1RIN1              0xBB
109 #define PLATFORM_MIC_AMIC_LIN2RIN2              0xCC
110
111 /* Speaker */
112 #define PLATFORM_SPK_NONE                       0x00
113 #define PLATFORM_SPK_MONO                       0x01
114 #define PLATFORM_SPK_STEREO                     0x02
115
116 /* Jack Detection */
117 #define PLATFORM_HPDET_NORMAL                   0x00
118 #define PLATFORM_HPDET_INVERTED                 0x01
119
120 /* PCM type (Port number + protocol) */
121 /*
122  * RETURNED VALUE = 0x00,   PCM PORT0, I2S
123  *       0x01,   PCM PORT0, LJ
124  *       0x02,   PCM PORT0, RJ
125  *       0x03,   PCM PORT0, DSP-A
126  *       0x04,   PCM PORT0, DSP-B
127  *       0x10,   PCM PORT1, I2S
128  *       0x11,   PCM PORT1, LJ
129  *       0x12,   PCM PORT1, RJ
130  *       0x13,   PCM PORT1, DSP-A
131  *       0x14,   PCM PORT1, DSP-B
132  *       0xFF,   Use default
133  *
134  * This is not used in Linux (defined by topology) and in
135  * Windows it's always DSP-A
136  */
137
138 /* Depop */
139 #define PLATFORM_MIC_DE_POP_OFF                 0x00
140 #define PLATFORM_MIC_DE_POP_ON                  0x01
141
142 /* Codec type */
143 #define PLATFORM_CODEC_8316                     16
144 #define PLATFORM_CODEC_8326                     26
145 #define PLATFORM_CODEC_8336                     36
146 #define PLATFORM_CODEC_8395                     95
147 #define PLATFORM_CODEC_8396                     96
148
149 /* Bus slot (on the host) */
150 /* BIT[3:0] FOR BUS NUMBER, BIT[7:4] FOR SLOT NUMBER
151  * BIT[3:0] 0 for I2S0, 1 for IS21, 2 for I2S2.
152  *
153  * On Intel platforms this refers to SSP0..2. This information
154  * is not really useful for Linux, the information is already
155  * inferred from NHLT but can be used to double-check NHLT
156  */
157
158 /* Volume - Gain */
159 #define LINEIN_GAIN_0db                         0x00 /* gain =  0db */
160 #define LINEIN_GAIN_3db                         0x01 /* gain = +3db */
161 #define LINEIN_GAIN_6db                         0x02 /* gain = +6db */
162 #define LINEIN_GAIN_9db                         0x03 /* gain = +9db */
163 #define LINEIN_GAIN_12db                        0x04 /* gain = +12db */
164 #define LINEIN_GAIN_15db                        0x05 /* gain = +15db */
165 #define LINEIN_GAIN_18db                        0x06 /* gain = +18db */
166 #define LINEIN_GAIN_21db                        0x07 /* gain = +21db */
167 #define LINEIN_GAIN_24db                        0x08 /* gain = +24db */
168 #define LINEIN_GAIN_27db                        0x09 /* gain = +27db */
169 #define LINEIN_GAIN_30db                        0x0a /* gain = +30db */
170
171 #define ADC_GUI_STEP_3db                        0x03 /* gain = +3db */
172 #define ADC_GUI_STEP_6db                        0x06 /* gain = +6db */
173 #define ADC_GUI_STEP_10db                       0x0a /* gain = +10db */
174
175 #define D2SEPGA_GAIN_0db                        0x00 /* gain =   0db */
176 #define D2SEPGA_GAIN_15db                       0x01 /* gain = +15db */
177
178 /* ADC volume: base = 0db, -0.5db/setp, 0xc0 <-> -96db */
179
180 #define ADC_ALC_DISABLE                         0x00
181 #define ADC_ALC_ENABLE                          0x01
182
183 #define ADC_ALC_TARGET_LEVEL_m16_5db            0x00 /* gain = -16.5db */
184 #define ADC_ALC_TARGET_LEVEL_m15db              0x01 /* gain = -15db */
185 #define ADC_ALC_TARGET_LEVEL_m13_5db            0x02 /* gain = -13.5db */
186 #define ADC_ALC_TARGET_LEVEL_m12db              0x03 /* gain = -12db */
187 #define ADC_ALC_TARGET_LEVEL_m10_5db            0x04 /* gain = -10.5db */
188 #define ADC_ALC_TARGET_LEVEL_m9db               0x05 /* gain = -9db */
189 #define ADC_ALC_TARGET_LEVEL_m7_5db             0x06 /* gain = -7.5db */
190 #define ADC_ALC_TARGET_LEVEL_m6db               0x07 /* gain = -6db */
191 #define ADC_ALC_TARGET_LEVEL_m4_5db             0x08 /* gain = -4.5db */
192 #define ADC_ALC_TARGET_LEVEL_m_3db              0x09 /* gain = -3db */
193 #define ADC_ALC_TARGET_LEVEL_m1_5db             0x0a /* gain = -1.5db */
194
195 #define ADC_ALC_MAXGAIN_m6_5db                  0x00  /* gain = -6.5db */
196 #define ADC_ALC_MAXGAIN_m5db                    0x01  /* gain = -5db */
197 #define ADC_ALC_MAXGAIN_m3_5db                  0x02  /* gain = -3.5db */
198 #define ADC_ALC_MAXGAIN_m2db                    0x03  /* gain = -2db */
199 #define ADC_ALC_MAXGAIN_m0_5db                  0x04  /* gain = -0.5db */
200 #define ADC_ALC_MAXGAIN_1db                     0x05  /* gain = +1db */
201 #define ADC_ALC_MAXGAIN_2_5db                   0x06  /* gain = +2.5db */
202 #define ADC_ALC_MAXGAIN_4db                     0x07  /* gain = +4db */
203 #define ADC_ALC_MAXGAIN_5_5db                   0x08  /* gain = +5.5db */
204 #define ADC_ALC_MAXGAIN_7db                     0x09  /* gain = +7db */
205 #define ADC_ALC_MAXGAIN_8_5db                   0x0a  /* gain = +8.5db */
206 #define ADC_ALC_MAXGAIN_10db                    0x0b  /* gain = +10db */
207 #define ADC_ALC_MAXGAIN_11_5db                  0x0c  /* gain = +11.5db */
208 #define ADC_ALC_MAXGAIN_13db                    0x0d  /* gain = +13db */
209 #define ADC_ALC_MAXGAIN_14_5db                  0x0e  /* gain = +14.5db */
210 #define ADC_ALC_MAXGAIN_16db                    0x0f  /* gain = +16db */
211 #define ADC_ALC_MAXGAIN_17_5db                  0x10  /* gain = +17.5db */
212 #define ADC_ALC_MAXGAIN_19db                    0x11  /* gain = +19db */
213 #define ADC_ALC_MAXGAIN_20_5db                  0x12  /* gain = +20.5db */
214 #define ADC_ALC_MAXGAIN_22db                    0x13  /* gain = +22db */
215 #define ADC_ALC_MAXGAIN_23_5db                  0x14  /* gain = +23.5db */
216 #define ADC_ALC_MAXGAIN_25db                    0x15  /* gain = +25db */
217 #define ADC_ALC_MAXGAIN_26_5db                  0x16  /* gain = +26.5db */
218 #define ADC_ALC_MAXGAIN_28db                    0x17  /* gain = +28db */
219 #define ADC_ALC_MAXGAIN_29_5db                  0x18  /* gain = +29.5db */
220 #define ADC_ALC_MAXGAIN_31db                    0x19  /* gain = +31db */
221 #define ADC_ALC_MAXGAIN_32_5db                  0x1a  /* gain = +32.5db */
222 #define ADC_ALC_MAXGAIN_34db                    0x1b  /* gain = +34db */
223 #define ADC_ALC_MAXGAIN_35_5db                  0x1c  /* gain = +35.5db */
224
225 #define ADC_ALC_MINGAIN_m12db                   0x00 /* gain = -12db */
226 #define ADC_ALC_MINGAIN_m10_5db                 0x01 /* gain = -10.5db */
227 #define ADC_ALC_MINGAIN_m9db                    0x02 /* gain = -9db */
228 #define ADC_ALC_MINGAIN_m7_5db                  0x03 /* gain = -7.5db */
229 #define ADC_ALC_MINGAIN_m6db                    0x04 /* gain = -6db */
230 #define ADC_ALC_MINGAIN_m4_51db                 0x05 /* gain = -4.51db */
231 #define ADC_ALC_MINGAIN_m3db                    0x06 /* gain = -3db */
232 #define ADC_ALC_MINGAIN_m1_5db                  0x07 /* gain = -1.5db */
233 #define ADC_ALC_MINGAIN_0db                     0x08 /* gain = 0db */
234 #define ADC_ALC_MINGAIN_1_5db                   0x09 /* gain = +1.5db */
235 #define ADC_ALC_MINGAIN_3db                     0x0a /* gain = +3db */
236 #define ADC_ALC_MINGAIN_4_5db                   0x0b /* gain = +4.5db */
237 #define ADC_ALC_MINGAIN_6db                     0x0c /* gain = +6db */
238 #define ADC_ALC_MINGAIN_7_5db                   0x0d /* gain = +7.5db */
239 #define ADC_ALC_MINGAIN_9db                     0x0e /* gain = +9db */
240 #define ADC_ALC_MINGAIN_10_5db                  0x0f /* gain = +10.5db */
241 #define ADC_ALC_MINGAIN_12db                    0x10 /* gain = +12db */
242 #define ADC_ALC_MINGAIN_13_5db                  0x11 /* gain = +13.5db */
243 #define ADC_ALC_MINGAIN_15db                    0x12 /* gain = +15db */
244 #define ADC_ALC_MINGAIN_16_5db                  0x13 /* gain = +16.5db */
245 #define ADC_ALC_MINGAIN_18db                    0x14 /* gain = +18db */
246 #define ADC_ALC_MINGAIN_19_5db                  0x15 /* gain = +19.5db */
247 #define ADC_ALC_MINGAIN_21db                    0x16 /* gain = +21db */
248 #define ADC_ALC_MINGAIN_22_5db                  0x17 /* gain = +22.5db */
249 #define ADC_ALC_MINGAIN_24db                    0x18 /* gain = +24db */
250 #define ADC_ALC_MINGAIN_25_5db                  0x19 /* gain = +25.5db */
251 #define ADC_ALC_MINGAIN_27db                    0x1a /* gain = +27db */
252 #define ADC_ALC_MINGAIN_28_5db                  0x1b /* gain = +28.5db */
253 #define ADC_ALC_MINGAIN_30db                    0x1c /* gain = +30db */
254
255 /* ADC volume: step 1dB */
256
257 /* ALC Hold, Decay, Attack */
258 #define ADC_ALC_HLDTIME_0_US                    0x00
259 #define ADC_ALC_HLDTIME_0000266_US              0x01 //time = 2.67ms
260 #define ADC_ALC_HLDTIME_0000533_US              0x02 //time = 5.33ms
261 #define ADC_ALC_HLDTIME_0001066_US              0x03 //time = 10.66ms
262 #define ADC_ALC_HLDTIME_0002132_US              0x04 //time = 21.32ms
263 #define ADC_ALC_HLDTIME_0004264_US              0x05 //time = 42.64ms
264 #define ADC_ALC_HLDTIME_0008538_US              0x06 //time = 85.38ms
265 #define ADC_ALC_HLDTIME_0017076_US              0x07 //time = 170.76ms
266 #define ADC_ALC_HLDTIME_0034152_US              0x08 //time = 341.52ms
267 #define ADC_ALC_HLDTIME_0680000_US              0x09 //time = 0.68s
268 #define ADC_ALC_HLDTIME_1360000_US              0x0a //time = 1.36s
269
270 #define ADC_ALC_DCYTIME_000410_US               0x00 //time = 410us
271 #define ADC_ALC_DCYTIME_000820_US               0x01 //time = 820us
272 #define ADC_ALC_DCYTIME_001640_US               0x02 //time = 1.64ms
273 #define ADC_ALC_DCYTIME_003280_US               0x03 //time = 3.28ms
274 #define ADC_ALC_DCYTIME_006560_US               0x04 //time = 6.56ms
275 #define ADC_ALC_DCYTIME_013120_US               0x05 //time = 13.12ms
276 #define ADC_ALC_DCYTIME_026240_US               0x06 //time = 26.24ms
277 #define ADC_ALC_DCYTIME_058480_US               0x07 //time = 52.48ms
278 #define ADC_ALC_DCYTIME_104960_US               0x08 //time = 104.96ms
279 #define ADC_ALC_DCYTIME_209920_US               0x09 //time = 209.92ms
280 #define ADC_ALC_DCYTIME_420000_US               0x0a //time = 420ms
281
282 #define ADC_ALC_ATKTIME_000104_US               0x00 //time = 104us
283 #define ADC_ALC_ATKTIME_000208_US               0x01 //time = 208us
284 #define ADC_ALC_ATKTIME_000416_US               0x02 //time = 416ms
285 #define ADC_ALC_ATKTIME_003832_US               0x03 //time = 832ms
286 #define ADC_ALC_ATKTIME_001664_US               0x04 //time = 1.664ms
287 #define ADC_ALC_ATKTIME_003328_US               0x05 //time = 3.328ms
288 #define ADC_ALC_ATKTIME_006656_US               0x06 //time = 6.656ms
289 #define ADC_ALC_ATKTIME_013312_US               0x07 //time = 13.312ms
290 #define ADC_ALC_ATKTIME_026624_US               0x08 //time = 26.624ms
291 #define ADC_ALC_ATKTIME_053248_US               0x09 //time = 53.248ms
292 #define ADC_ALC_ATKTIME_106496_US               0x0a //time = 106.496ms
293
294 /* ALC Noise Gate */
295 #define ADC_ALC_NGTYPE_DISABLE                  0x00 //noise gate disable
296 #define ADC_ALC_NGTYPE_ENABLE_HOLD              0x01 //noise gate enable, hold gain type
297 #define ADC_ALC_NGTYPE_ENABLE_MUTE              0x03 //noise gate enable, mute type
298
299 #define ADC_ALC_NGTHLD_m76_5db                  0x00 /* Threshold = -76.5db */
300 #define ADC_ALC_NGTHLD_m75db                    0x01 /* Threshold = -75db   */
301 #define ADC_ALC_NGTHLD_m73_5db                  0x02 /* Threshold = -73.5db */
302 #define ADC_ALC_NGTHLD_m72db                    0x03 /* Threshold = -72db   */
303 #define ADC_ALC_NGTHLD_m70_5db                  0x04 /* Threshold = -70.5db */
304 #define ADC_ALC_NGTHLD_m69db                    0x05 /* Threshold = -69db   */
305 #define ADC_ALC_NGTHLD_m67_5db                  0x06 /* Threshold = -67.5db */
306 #define ADC_ALC_NGTHLD_m66db                    0x07 /* Threshold = -66db   */
307 #define ADC_ALC_NGTHLD_m64_5db                  0x08 /* Threshold = -64.5db */
308 #define ADC_ALC_NGTHLD_m63db                    0x09 /* Threshold = -63db   */
309 #define ADC_ALC_NGTHLD_m61_5db                  0x0a /* Threshold = -61.5db */
310 #define ADC_ALC_NGTHLD_m60db                    0x0b /* Threshold = -60db   */
311 #define ADC_ALC_NGTHLD_m58_5db                  0x0c /* Threshold = -58.5db */
312 #define ADC_ALC_NGTHLD_m57db                    0x0d /* Threshold = -57db   */
313 #define ADC_ALC_NGTHLD_m55_5db                  0x0e /* Threshold = -55.5db */
314 #define ADC_ALC_NGTHLD_m54db                    0x0f /* Threshold = -54db   */
315 #define ADC_ALC_NGTHLD_m52_5db                  0x10 /* Threshold = -52.5db */
316 #define ADC_ALC_NGTHLD_m51db                    0x11 /* Threshold = -51db   */
317 #define ADC_ALC_NGTHLD_m49_5db                  0x12 /* Threshold = -49.5db */
318 #define ADC_ALC_NGTHLD_m48db                    0x13 /* Threshold = -48db   */
319 #define ADC_ALC_NGTHLD_m46_5db                  0x14 /* Threshold = -46.5db */
320 #define ADC_ALC_NGTHLD_m45db                    0x15 /* Threshold = -45db   */
321 #define ADC_ALC_NGTHLD_m43_5db                  0x16 /* Threshold = -43.5db */
322 #define ADC_ALC_NGTHLD_m42db                    0x17 /* Threshold = -42db   */
323 #define ADC_ALC_NGTHLD_m40_5db                  0x18 /* Threshold = -40.5db */
324 #define ADC_ALC_NGTHLD_m39db                    0x19 /* Threshold = -39db   */
325 #define ADC_ALC_NGTHLD_m37_5db                  0x1a /* Threshold = -37.5db */
326 #define ADC_ALC_NGTHLD_m36db                    0x1b /* Threshold = -36db   */
327 #define ADC_ALC_NGTHLD_m34_5db                  0x1c /* Threshold = -34.5db */
328 #define ADC_ALC_NGTHLD_m33db                    0x1d /* Threshold = -33db   */
329 #define ADC_ALC_NGTHLD_m31_5db                  0x1e /* Threshold = -31.5db */
330 #define ADC_ALC_NGTHLD_m30db                    0x1f /* Threshold = -30db   */
331
332 /* Headphone dummy - Windows Specific flag, not needed for Linux */
333
334 /* HPMIX HIGAIN and VOLUME */
335 #define DAC_HPMIX_HIGAIN_0db                    0x00 /* gain =  0db      */
336 #define DAC_HPMIX_HIGAIN_m6db                   0x88 /* gain = -6db      */
337
338 #define DAC_HPMIX_VOLUME_m12db                  0x00 /* volume = -12db   */
339 #define DAC_HPMIX_VOLUME_m10_5db                0x11 /* volume = -10.5db */
340 #define DAC_HPMIX_VOLUME_m9db                   0x22 /* volume = -9db    */
341 #define DAC_HPMIX_VOLUME_m7_5db                 0x33 /* volume = -7.5db  */
342 #define DAC_HPMIX_VOLUME_m6db                   0x44 /* volume = -6db    */
343 #define DAC_HPMIX_VOLUME_m4_5db                 0x88 /* volume = -4.5db  */
344 #define DAC_HPMIX_VOLUME_m3db                   0x99 /* volume = -3db    */
345 #define DAC_HPMIX_VOLUME_m1_5db                 0xaa /* volume = -1.5db  */
346 #define DAC_HPMIX_VOLUME_0db                    0xbb /* volume =  0db    */
347
348 /* HPOUT VOLUME */
349 #define DAC_HPOUT_VOLUME_0db                    0x00 /* volume =   0db   */
350 #define DAC_HPOUT_VOLUME_m12db                  0x11 /* volume = -12db   */
351 #define DAC_HPOUT_VOLUME_m24db                  0x22 /* volume = -24db   */
352 #define DAC_HPOUT_VOLUME_m48db                  0x33 /* volume = -48db   */
353
354 /* LDAC/RDAC volume = 0db, -0.5db/setp, 0xc0 <-> -96db */
355
356 /* Automute */
357 #define DAC_AUTOMUTE_NONE                       0x00 /* no automute  */
358 #define DAC_AUTOMUTE_DIGITAL                    0x01 /* digital mute */
359 #define DAC_AUTOMUTE_ANALOG                     0x02 /* analog mute  */
360
361 /* Mono - Windows specific, on Linux the information comes from DAI/topology */
362 #define HEADPHONE_MONO                          0x01 /* on channel */
363 #define HEADPHONE_STEREO                        0x00 /* stereo */
364
365 /* Speaker and headphone GPIO control */
366 #define GPIO_CTL_IO_LEVEL_LOW                   0x00 /* low level enable */
367 #define GPIO_CTL_IO_LEVEL_HIGH                  0x01 /* high level enable */
368
369 /* GPIO */
370 /* FIXME: for ES8396, no need to use */
371
372 /* Platform clocks */
373 /*
374  * BCLK AND MCLK FREQ
375  * BIT[7:4] MCLK FREQ
376  * 0 - 19.2MHz
377  * 1 - 24MHz
378  * 2 - 12.288MHz
379  * F - Default for 19.2MHz
380  *
381  * BIT[3:0] BCLK FREQ
382  * 0 - 4.8MHz
383  * 1 - 2.4MHz
384  * 2 - 2.304MHz
385  * 3 - 3.072MHz
386  * 4 - 4.096MHz
387  * F - Default for 4.8MHz
388  */
389
390 int es83xx_dsm(struct device *dev, int arg, int *value);
391 int es83xx_dsm_dump(struct device *dev);
392
393 #endif