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 394