1 // SPDX-License-Identifier: GPL-2.0-only 1 2 // Copyright (c) 2018-2020, The Linux Foundati 3 4 #include <linux/clk.h> 5 #include <linux/clk-provider.h> 6 #include <linux/init.h> 7 #include <linux/io.h> 8 #include <linux/module.h> 9 #include <linux/of_clk.h> 10 #include <linux/of_platform.h> 11 #include <linux/platform_device.h> 12 #include <linux/pm_runtime.h> 13 #include <linux/regmap.h> 14 #include <linux/regulator/consumer.h> 15 #include <sound/soc.h> 16 #include <sound/soc-dapm.h> 17 #include <sound/tlv.h> 18 19 #include "lpass-macro-common.h" 20 21 /* VA macro registers */ 22 #define CDC_VA_CLK_RST_CTRL_MCLK_CONTROL 23 #define CDC_VA_MCLK_CONTROL_EN 24 #define CDC_VA_CLK_RST_CTRL_FS_CNT_CONTROL 25 #define CDC_VA_FS_CONTROL_EN 26 #define CDC_VA_FS_COUNTER_CLR 27 #define CDC_VA_CLK_RST_CTRL_SWR_CONTROL 28 #define CDC_VA_SWR_RESET_MASK BIT(1) 29 #define CDC_VA_SWR_RESET_ENABLE BIT(1) 30 #define CDC_VA_SWR_CLK_EN_MASK BIT(0) 31 #define CDC_VA_SWR_CLK_ENABLE BIT(0) 32 #define CDC_VA_TOP_CSR_TOP_CFG0 33 #define CDC_VA_FS_BROADCAST_EN 34 #define CDC_VA_TOP_CSR_DMIC0_CTL 35 #define CDC_VA_TOP_CSR_DMIC1_CTL 36 #define CDC_VA_TOP_CSR_DMIC2_CTL 37 #define CDC_VA_TOP_CSR_DMIC3_CTL 38 #define CDC_VA_DMIC_EN_MASK 39 #define CDC_VA_DMIC_ENABLE 40 #define CDC_VA_DMIC_CLK_SEL_MASK 41 #define CDC_VA_DMIC_CLK_SEL_SHFT 42 #define CDC_VA_DMIC_CLK_SEL_DIV0 43 #define CDC_VA_DMIC_CLK_SEL_DIV1 44 #define CDC_VA_DMIC_CLK_SEL_DIV2 45 #define CDC_VA_DMIC_CLK_SEL_DIV3 46 #define CDC_VA_DMIC_CLK_SEL_DIV4 47 #define CDC_VA_DMIC_CLK_SEL_DIV5 48 #define CDC_VA_TOP_CSR_DMIC_CFG 49 #define CDC_VA_RESET_ALL_DMICS_MASK 50 #define CDC_VA_RESET_ALL_DMICS_RESET 51 #define CDC_VA_RESET_ALL_DMICS_DISABLE 52 #define CDC_VA_DMIC3_FREQ_CHANGE_MASK 53 #define CDC_VA_DMIC3_FREQ_CHANGE_EN 54 #define CDC_VA_DMIC2_FREQ_CHANGE_MASK 55 #define CDC_VA_DMIC2_FREQ_CHANGE_EN 56 #define CDC_VA_DMIC1_FREQ_CHANGE_MASK 57 #define CDC_VA_DMIC1_FREQ_CHANGE_EN 58 #define CDC_VA_DMIC0_FREQ_CHANGE_MASK 59 #define CDC_VA_DMIC0_FREQ_CHANGE_EN 60 #define CDC_VA_DMIC_FREQ_CHANGE_DISABLE 61 #define CDC_VA_TOP_CSR_DEBUG_BUS 62 #define CDC_VA_TOP_CSR_DEBUG_EN 63 #define CDC_VA_TOP_CSR_TX_I2S_CTL 64 #define CDC_VA_TOP_CSR_I2S_CLK 65 #define CDC_VA_TOP_CSR_I2S_RESET 66 #define CDC_VA_TOP_CSR_CORE_ID_0 67 #define CDC_VA_TOP_CSR_CORE_ID_1 68 #define CDC_VA_TOP_CSR_CORE_ID_2 69 #define CDC_VA_TOP_CSR_CORE_ID_3 70 #define CDC_VA_TOP_CSR_SWR_MIC_CTL0 71 #define CDC_VA_TOP_CSR_SWR_MIC_CTL1 72 #define CDC_VA_TOP_CSR_SWR_MIC_CTL2 73 #define CDC_VA_SWR_MIC_CLK_SEL_0_1_MASK 74 #define CDC_VA_SWR_MIC_CLK_SEL_0_1_DIV1 75 #define CDC_VA_TOP_CSR_SWR_CTRL 76 #define CDC_VA_INP_MUX_ADC_MUX0_CFG0 77 #define CDC_VA_INP_MUX_ADC_MUX0_CFG1 78 #define CDC_VA_INP_MUX_ADC_MUX1_CFG0 79 #define CDC_VA_INP_MUX_ADC_MUX1_CFG1 80 #define CDC_VA_INP_MUX_ADC_MUX2_CFG0 81 #define CDC_VA_INP_MUX_ADC_MUX2_CFG1 82 #define CDC_VA_INP_MUX_ADC_MUX3_CFG0 83 #define CDC_VA_INP_MUX_ADC_MUX3_CFG1 84 #define CDC_VA_TX0_TX_PATH_CTL 85 #define CDC_VA_TX_PATH_CLK_EN_MASK 86 #define CDC_VA_TX_PATH_CLK_EN 87 #define CDC_VA_TX_PATH_CLK_DISABLE 88 #define CDC_VA_TX_PATH_PGA_MUTE_EN_MASK 89 #define CDC_VA_TX_PATH_PGA_MUTE_EN 90 #define CDC_VA_TX_PATH_PGA_MUTE_DISABLE 91 #define CDC_VA_TX0_TX_PATH_CFG0 92 #define CDC_VA_ADC_MODE_MASK 93 #define CDC_VA_ADC_MODE_SHIFT 94 #define TX_HPF_CUT_OFF_FREQ_MASK 95 #define CF_MIN_3DB_4HZ 0x0 96 #define CF_MIN_3DB_75HZ 0x1 97 #define CF_MIN_3DB_150HZ 0x2 98 #define CDC_VA_TX0_TX_PATH_CFG1 99 #define CDC_VA_TX0_TX_VOL_CTL 100 #define CDC_VA_TX0_TX_PATH_SEC0 101 #define CDC_VA_TX0_TX_PATH_SEC1 102 #define CDC_VA_TX0_TX_PATH_SEC2 103 #define CDC_VA_TX_HPF_CUTOFF_FREQ_CHANGE_MASK 104 #define CDC_VA_TX_HPF_CUTOFF_FREQ_CHANGE_REQ 105 #define CDC_VA_TX_HPF_ZERO_GATE_MASK 106 #define CDC_VA_TX_HPF_ZERO_NO_GATE 107 #define CDC_VA_TX_HPF_ZERO_GATE 108 #define CDC_VA_TX0_TX_PATH_SEC3 109 #define CDC_VA_TX0_TX_PATH_SEC4 110 #define CDC_VA_TX0_TX_PATH_SEC5 111 #define CDC_VA_TX0_TX_PATH_SEC6 112 #define CDC_VA_TX0_TX_PATH_SEC7 113 #define CDC_VA_TX1_TX_PATH_CTL 114 #define CDC_VA_TX1_TX_PATH_CFG0 115 #define CDC_VA_TX1_TX_PATH_CFG1 116 #define CDC_VA_TX1_TX_VOL_CTL 117 #define CDC_VA_TX1_TX_PATH_SEC0 118 #define CDC_VA_TX1_TX_PATH_SEC1 119 #define CDC_VA_TX1_TX_PATH_SEC2 120 #define CDC_VA_TX1_TX_PATH_SEC3 121 #define CDC_VA_TX1_TX_PATH_SEC4 122 #define CDC_VA_TX1_TX_PATH_SEC5 123 #define CDC_VA_TX1_TX_PATH_SEC6 124 #define CDC_VA_TX2_TX_PATH_CTL 125 #define CDC_VA_TX2_TX_PATH_CFG0 126 #define CDC_VA_TX2_TX_PATH_CFG1 127 #define CDC_VA_TX2_TX_VOL_CTL 128 #define CDC_VA_TX2_TX_PATH_SEC0 129 #define CDC_VA_TX2_TX_PATH_SEC1 130 #define CDC_VA_TX2_TX_PATH_SEC2 131 #define CDC_VA_TX2_TX_PATH_SEC3 132 #define CDC_VA_TX2_TX_PATH_SEC4 133 #define CDC_VA_TX2_TX_PATH_SEC5 134 #define CDC_VA_TX2_TX_PATH_SEC6 135 #define CDC_VA_TX3_TX_PATH_CTL 136 #define CDC_VA_TX3_TX_PATH_CFG0 137 #define CDC_VA_TX_PATH_ADC_DMIC_SEL_MASK 138 #define CDC_VA_TX_PATH_ADC_DMIC_SEL_DMIC 139 #define CDC_VA_TX_PATH_ADC_DMIC_SEL_ADC 140 #define CDC_VA_TX3_TX_PATH_CFG1 141 #define CDC_VA_TX3_TX_VOL_CTL 142 #define CDC_VA_TX3_TX_PATH_SEC0 143 #define CDC_VA_TX3_TX_PATH_SEC1 144 #define CDC_VA_TX3_TX_PATH_SEC2 145 #define CDC_VA_TX3_TX_PATH_SEC3 146 #define CDC_VA_TX3_TX_PATH_SEC4 147 #define CDC_VA_TX3_TX_PATH_SEC5 148 #define CDC_VA_TX3_TX_PATH_SEC6 149 150 #define VA_MAX_OFFSET 151 152 #define VA_MACRO_NUM_DECIMATORS 4 153 #define VA_MACRO_RATES (SNDRV_PCM_RATE_8000 | 154 SNDRV_PCM_RATE_32000 | 155 SNDRV_PCM_RATE_96000 | 156 #define VA_MACRO_FORMATS (SNDRV_PCM_FMTBIT_S16 157 SNDRV_PCM_FMTBIT_S24_LE |\ 158 SNDRV_PCM_FMTBIT_S24_3LE) 159 160 #define VA_MACRO_MCLK_FREQ 9600000 161 #define VA_MACRO_TX_PATH_OFFSET 0x80 162 #define VA_MACRO_SWR_MIC_MUX_SEL_MASK 0xF 163 #define VA_MACRO_ADC_MUX_CFG_OFFSET 0x8 164 165 static const DECLARE_TLV_DB_SCALE(digital_gain 166 167 enum { 168 VA_MACRO_AIF_INVALID = 0, 169 VA_MACRO_AIF1_CAP, 170 VA_MACRO_AIF2_CAP, 171 VA_MACRO_AIF3_CAP, 172 VA_MACRO_MAX_DAIS, 173 }; 174 175 enum { 176 VA_MACRO_DEC0, 177 VA_MACRO_DEC1, 178 VA_MACRO_DEC2, 179 VA_MACRO_DEC3, 180 VA_MACRO_DEC4, 181 VA_MACRO_DEC5, 182 VA_MACRO_DEC6, 183 VA_MACRO_DEC7, 184 VA_MACRO_DEC_MAX, 185 }; 186 187 enum { 188 VA_MACRO_CLK_DIV_2, 189 VA_MACRO_CLK_DIV_3, 190 VA_MACRO_CLK_DIV_4, 191 VA_MACRO_CLK_DIV_6, 192 VA_MACRO_CLK_DIV_8, 193 VA_MACRO_CLK_DIV_16, 194 }; 195 196 #define VA_NUM_CLKS_MAX 3 197 198 struct va_macro { 199 struct device *dev; 200 unsigned long active_ch_mask[VA_MACRO_ 201 unsigned long active_ch_cnt[VA_MACRO_M 202 u16 dmic_clk_div; 203 bool has_swr_master; 204 bool has_npl_clk; 205 206 int dec_mode[VA_MACRO_NUM_DECIMATORS]; 207 struct regmap *regmap; 208 struct clk *mclk; 209 struct clk *npl; 210 struct clk *macro; 211 struct clk *dcodec; 212 struct clk *fsgen; 213 struct clk_hw hw; 214 struct lpass_macro *pds; 215 216 s32 dmic_0_1_clk_cnt; 217 s32 dmic_2_3_clk_cnt; 218 s32 dmic_4_5_clk_cnt; 219 s32 dmic_6_7_clk_cnt; 220 u8 dmic_0_1_clk_div; 221 u8 dmic_2_3_clk_div; 222 u8 dmic_4_5_clk_div; 223 u8 dmic_6_7_clk_div; 224 }; 225 226 #define to_va_macro(_hw) container_of(_hw, str 227 228 struct va_macro_data { 229 bool has_swr_master; 230 bool has_npl_clk; 231 int version; 232 }; 233 234 static const struct va_macro_data sm8250_va_da 235 .has_swr_master = false, 236 .has_npl_clk = false, 237 .version = LPASS_CODEC_VERSION_1_0, 238 }; 239 240 static const struct va_macro_data sm8450_va_da 241 .has_swr_master = true, 242 .has_npl_clk = true, 243 }; 244 245 static const struct va_macro_data sm8550_va_da 246 .has_swr_master = true, 247 .has_npl_clk = false, 248 }; 249 250 static bool va_is_volatile_register(struct dev 251 { 252 switch (reg) { 253 case CDC_VA_TOP_CSR_CORE_ID_0: 254 case CDC_VA_TOP_CSR_CORE_ID_1: 255 case CDC_VA_TOP_CSR_CORE_ID_2: 256 case CDC_VA_TOP_CSR_CORE_ID_3: 257 case CDC_VA_TOP_CSR_DMIC0_CTL: 258 case CDC_VA_TOP_CSR_DMIC1_CTL: 259 case CDC_VA_TOP_CSR_DMIC2_CTL: 260 case CDC_VA_TOP_CSR_DMIC3_CTL: 261 return true; 262 } 263 return false; 264 } 265 266 static const struct reg_default va_defaults[] 267 /* VA macro */ 268 { CDC_VA_CLK_RST_CTRL_MCLK_CONTROL, 0x 269 { CDC_VA_CLK_RST_CTRL_FS_CNT_CONTROL, 270 { CDC_VA_CLK_RST_CTRL_SWR_CONTROL, 0x0 271 { CDC_VA_TOP_CSR_TOP_CFG0, 0x00}, 272 { CDC_VA_TOP_CSR_DMIC0_CTL, 0x00}, 273 { CDC_VA_TOP_CSR_DMIC1_CTL, 0x00}, 274 { CDC_VA_TOP_CSR_DMIC2_CTL, 0x00}, 275 { CDC_VA_TOP_CSR_DMIC3_CTL, 0x00}, 276 { CDC_VA_TOP_CSR_DMIC_CFG, 0x80}, 277 { CDC_VA_TOP_CSR_DEBUG_BUS, 0x00}, 278 { CDC_VA_TOP_CSR_DEBUG_EN, 0x00}, 279 { CDC_VA_TOP_CSR_TX_I2S_CTL, 0x0C}, 280 { CDC_VA_TOP_CSR_I2S_CLK, 0x00}, 281 { CDC_VA_TOP_CSR_I2S_RESET, 0x00}, 282 { CDC_VA_TOP_CSR_CORE_ID_0, 0x00}, 283 { CDC_VA_TOP_CSR_CORE_ID_1, 0x00}, 284 { CDC_VA_TOP_CSR_CORE_ID_2, 0x00}, 285 { CDC_VA_TOP_CSR_CORE_ID_3, 0x00}, 286 { CDC_VA_TOP_CSR_SWR_MIC_CTL0, 0xEE}, 287 { CDC_VA_TOP_CSR_SWR_MIC_CTL1, 0xEE}, 288 { CDC_VA_TOP_CSR_SWR_MIC_CTL2, 0xEE}, 289 { CDC_VA_TOP_CSR_SWR_CTRL, 0x06}, 290 291 /* VA core */ 292 { CDC_VA_INP_MUX_ADC_MUX0_CFG0, 0x00}, 293 { CDC_VA_INP_MUX_ADC_MUX0_CFG1, 0x00}, 294 { CDC_VA_INP_MUX_ADC_MUX1_CFG0, 0x00}, 295 { CDC_VA_INP_MUX_ADC_MUX1_CFG1, 0x00}, 296 { CDC_VA_INP_MUX_ADC_MUX2_CFG0, 0x00}, 297 { CDC_VA_INP_MUX_ADC_MUX2_CFG1, 0x00}, 298 { CDC_VA_INP_MUX_ADC_MUX3_CFG0, 0x00}, 299 { CDC_VA_INP_MUX_ADC_MUX3_CFG1, 0x00}, 300 { CDC_VA_TX0_TX_PATH_CTL, 0x04}, 301 { CDC_VA_TX0_TX_PATH_CFG0, 0x10}, 302 { CDC_VA_TX0_TX_PATH_CFG1, 0x0B}, 303 { CDC_VA_TX0_TX_VOL_CTL, 0x00}, 304 { CDC_VA_TX0_TX_PATH_SEC0, 0x00}, 305 { CDC_VA_TX0_TX_PATH_SEC1, 0x00}, 306 { CDC_VA_TX0_TX_PATH_SEC2, 0x01}, 307 { CDC_VA_TX0_TX_PATH_SEC3, 0x3C}, 308 { CDC_VA_TX0_TX_PATH_SEC4, 0x20}, 309 { CDC_VA_TX0_TX_PATH_SEC5, 0x00}, 310 { CDC_VA_TX0_TX_PATH_SEC6, 0x00}, 311 { CDC_VA_TX0_TX_PATH_SEC7, 0x25}, 312 { CDC_VA_TX1_TX_PATH_CTL, 0x04}, 313 { CDC_VA_TX1_TX_PATH_CFG0, 0x10}, 314 { CDC_VA_TX1_TX_PATH_CFG1, 0x0B}, 315 { CDC_VA_TX1_TX_VOL_CTL, 0x00}, 316 { CDC_VA_TX1_TX_PATH_SEC0, 0x00}, 317 { CDC_VA_TX1_TX_PATH_SEC1, 0x00}, 318 { CDC_VA_TX1_TX_PATH_SEC2, 0x01}, 319 { CDC_VA_TX1_TX_PATH_SEC3, 0x3C}, 320 { CDC_VA_TX1_TX_PATH_SEC4, 0x20}, 321 { CDC_VA_TX1_TX_PATH_SEC5, 0x00}, 322 { CDC_VA_TX1_TX_PATH_SEC6, 0x00}, 323 { CDC_VA_TX2_TX_PATH_CTL, 0x04}, 324 { CDC_VA_TX2_TX_PATH_CFG0, 0x10}, 325 { CDC_VA_TX2_TX_PATH_CFG1, 0x0B}, 326 { CDC_VA_TX2_TX_VOL_CTL, 0x00}, 327 { CDC_VA_TX2_TX_PATH_SEC0, 0x00}, 328 { CDC_VA_TX2_TX_PATH_SEC1, 0x00}, 329 { CDC_VA_TX2_TX_PATH_SEC2, 0x01}, 330 { CDC_VA_TX2_TX_PATH_SEC3, 0x3C}, 331 { CDC_VA_TX2_TX_PATH_SEC4, 0x20}, 332 { CDC_VA_TX2_TX_PATH_SEC5, 0x00}, 333 { CDC_VA_TX2_TX_PATH_SEC6, 0x00}, 334 { CDC_VA_TX3_TX_PATH_CTL, 0x04}, 335 { CDC_VA_TX3_TX_PATH_CFG0, 0x10}, 336 { CDC_VA_TX3_TX_PATH_CFG1, 0x0B}, 337 { CDC_VA_TX3_TX_VOL_CTL, 0x00}, 338 { CDC_VA_TX3_TX_PATH_SEC0, 0x00}, 339 { CDC_VA_TX3_TX_PATH_SEC1, 0x00}, 340 { CDC_VA_TX3_TX_PATH_SEC2, 0x01}, 341 { CDC_VA_TX3_TX_PATH_SEC3, 0x3C}, 342 { CDC_VA_TX3_TX_PATH_SEC4, 0x20}, 343 { CDC_VA_TX3_TX_PATH_SEC5, 0x00}, 344 { CDC_VA_TX3_TX_PATH_SEC6, 0x00}, 345 }; 346 347 static bool va_is_rw_register(struct device *d 348 { 349 switch (reg) { 350 case CDC_VA_CLK_RST_CTRL_MCLK_CONTROL: 351 case CDC_VA_CLK_RST_CTRL_FS_CNT_CONTRO 352 case CDC_VA_CLK_RST_CTRL_SWR_CONTROL: 353 case CDC_VA_TOP_CSR_TOP_CFG0: 354 case CDC_VA_TOP_CSR_DMIC0_CTL: 355 case CDC_VA_TOP_CSR_DMIC1_CTL: 356 case CDC_VA_TOP_CSR_DMIC2_CTL: 357 case CDC_VA_TOP_CSR_DMIC3_CTL: 358 case CDC_VA_TOP_CSR_DMIC_CFG: 359 case CDC_VA_TOP_CSR_SWR_MIC_CTL0: 360 case CDC_VA_TOP_CSR_SWR_MIC_CTL1: 361 case CDC_VA_TOP_CSR_SWR_MIC_CTL2: 362 case CDC_VA_TOP_CSR_DEBUG_BUS: 363 case CDC_VA_TOP_CSR_DEBUG_EN: 364 case CDC_VA_TOP_CSR_TX_I2S_CTL: 365 case CDC_VA_TOP_CSR_I2S_CLK: 366 case CDC_VA_TOP_CSR_I2S_RESET: 367 case CDC_VA_INP_MUX_ADC_MUX0_CFG0: 368 case CDC_VA_INP_MUX_ADC_MUX0_CFG1: 369 case CDC_VA_INP_MUX_ADC_MUX1_CFG0: 370 case CDC_VA_INP_MUX_ADC_MUX1_CFG1: 371 case CDC_VA_INP_MUX_ADC_MUX2_CFG0: 372 case CDC_VA_INP_MUX_ADC_MUX2_CFG1: 373 case CDC_VA_INP_MUX_ADC_MUX3_CFG0: 374 case CDC_VA_INP_MUX_ADC_MUX3_CFG1: 375 case CDC_VA_TX0_TX_PATH_CTL: 376 case CDC_VA_TX0_TX_PATH_CFG0: 377 case CDC_VA_TX0_TX_PATH_CFG1: 378 case CDC_VA_TX0_TX_VOL_CTL: 379 case CDC_VA_TX0_TX_PATH_SEC0: 380 case CDC_VA_TX0_TX_PATH_SEC1: 381 case CDC_VA_TX0_TX_PATH_SEC2: 382 case CDC_VA_TX0_TX_PATH_SEC3: 383 case CDC_VA_TX0_TX_PATH_SEC4: 384 case CDC_VA_TX0_TX_PATH_SEC5: 385 case CDC_VA_TX0_TX_PATH_SEC6: 386 case CDC_VA_TX0_TX_PATH_SEC7: 387 case CDC_VA_TX1_TX_PATH_CTL: 388 case CDC_VA_TX1_TX_PATH_CFG0: 389 case CDC_VA_TX1_TX_PATH_CFG1: 390 case CDC_VA_TX1_TX_VOL_CTL: 391 case CDC_VA_TX1_TX_PATH_SEC0: 392 case CDC_VA_TX1_TX_PATH_SEC1: 393 case CDC_VA_TX1_TX_PATH_SEC2: 394 case CDC_VA_TX1_TX_PATH_SEC3: 395 case CDC_VA_TX1_TX_PATH_SEC4: 396 case CDC_VA_TX1_TX_PATH_SEC5: 397 case CDC_VA_TX1_TX_PATH_SEC6: 398 case CDC_VA_TX2_TX_PATH_CTL: 399 case CDC_VA_TX2_TX_PATH_CFG0: 400 case CDC_VA_TX2_TX_PATH_CFG1: 401 case CDC_VA_TX2_TX_VOL_CTL: 402 case CDC_VA_TX2_TX_PATH_SEC0: 403 case CDC_VA_TX2_TX_PATH_SEC1: 404 case CDC_VA_TX2_TX_PATH_SEC2: 405 case CDC_VA_TX2_TX_PATH_SEC3: 406 case CDC_VA_TX2_TX_PATH_SEC4: 407 case CDC_VA_TX2_TX_PATH_SEC5: 408 case CDC_VA_TX2_TX_PATH_SEC6: 409 case CDC_VA_TX3_TX_PATH_CTL: 410 case CDC_VA_TX3_TX_PATH_CFG0: 411 case CDC_VA_TX3_TX_PATH_CFG1: 412 case CDC_VA_TX3_TX_VOL_CTL: 413 case CDC_VA_TX3_TX_PATH_SEC0: 414 case CDC_VA_TX3_TX_PATH_SEC1: 415 case CDC_VA_TX3_TX_PATH_SEC2: 416 case CDC_VA_TX3_TX_PATH_SEC3: 417 case CDC_VA_TX3_TX_PATH_SEC4: 418 case CDC_VA_TX3_TX_PATH_SEC5: 419 case CDC_VA_TX3_TX_PATH_SEC6: 420 return true; 421 } 422 423 return false; 424 } 425 426 static bool va_is_readable_register(struct dev 427 { 428 switch (reg) { 429 case CDC_VA_TOP_CSR_CORE_ID_0: 430 case CDC_VA_TOP_CSR_CORE_ID_1: 431 case CDC_VA_TOP_CSR_CORE_ID_2: 432 case CDC_VA_TOP_CSR_CORE_ID_3: 433 return true; 434 } 435 436 return va_is_rw_register(dev, reg); 437 } 438 439 static const struct regmap_config va_regmap_co 440 .name = "va_macro", 441 .reg_bits = 32, 442 .val_bits = 32, 443 .reg_stride = 4, 444 .cache_type = REGCACHE_FLAT, 445 .reg_defaults = va_defaults, 446 .num_reg_defaults = ARRAY_SIZE(va_defa 447 .max_register = VA_MAX_OFFSET, 448 .volatile_reg = va_is_volatile_registe 449 .readable_reg = va_is_readable_registe 450 .writeable_reg = va_is_rw_register, 451 }; 452 453 static int va_clk_rsc_fs_gen_request(struct va 454 { 455 struct regmap *regmap = va->regmap; 456 457 if (enable) { 458 regmap_update_bits(regmap, CDC 459 CDC_VA_MCLK 460 CDC_VA_MCLK 461 /* clear the fs counter */ 462 regmap_update_bits(regmap, CDC 463 CDC_VA_FS_C 464 CDC_VA_FS_C 465 regmap_update_bits(regmap, CDC 466 CDC_VA_FS_C 467 CDC_VA_FS_C 468 469 regmap_update_bits(regmap, CDC 470 CDC_VA_FS_B 471 CDC_VA_FS_B 472 } else { 473 regmap_update_bits(regmap, CDC 474 CDC_VA_MCLK 475 476 regmap_update_bits(regmap, CDC 477 CDC_VA_FS_C 478 479 regmap_update_bits(regmap, CDC 480 CDC_VA_FS_B 481 } 482 483 return 0; 484 } 485 486 static int va_macro_mclk_enable(struct va_macr 487 { 488 struct regmap *regmap = va->regmap; 489 490 if (mclk_enable) { 491 va_clk_rsc_fs_gen_request(va, 492 regcache_mark_dirty(regmap); 493 regcache_sync_region(regmap, 0 494 } else { 495 va_clk_rsc_fs_gen_request(va, 496 } 497 498 return 0; 499 } 500 501 static int va_macro_mclk_event(struct snd_soc_ 502 struct snd_kcon 503 { 504 struct snd_soc_component *comp = snd_s 505 struct va_macro *va = snd_soc_componen 506 507 switch (event) { 508 case SND_SOC_DAPM_PRE_PMU: 509 return clk_prepare_enable(va-> 510 case SND_SOC_DAPM_POST_PMD: 511 clk_disable_unprepare(va->fsge 512 } 513 514 return 0; 515 } 516 517 static int va_macro_put_dec_enum(struct snd_kc 518 struct snd_ct 519 { 520 struct snd_soc_dapm_widget *widget = 521 snd_soc_dapm_kcontrol_widget(k 522 struct snd_soc_component *component = 523 snd_soc_dapm_to_component(widg 524 struct soc_enum *e = (struct soc_enum 525 unsigned int val; 526 u16 mic_sel_reg; 527 528 val = ucontrol->value.enumerated.item[ 529 530 switch (e->reg) { 531 case CDC_VA_INP_MUX_ADC_MUX0_CFG0: 532 mic_sel_reg = CDC_VA_TX0_TX_PA 533 break; 534 case CDC_VA_INP_MUX_ADC_MUX1_CFG0: 535 mic_sel_reg = CDC_VA_TX1_TX_PA 536 break; 537 case CDC_VA_INP_MUX_ADC_MUX2_CFG0: 538 mic_sel_reg = CDC_VA_TX2_TX_PA 539 break; 540 case CDC_VA_INP_MUX_ADC_MUX3_CFG0: 541 mic_sel_reg = CDC_VA_TX3_TX_PA 542 break; 543 default: 544 dev_err(component->dev, "%s: e 545 __func__, e->reg); 546 return -EINVAL; 547 } 548 549 if (val != 0) 550 snd_soc_component_update_bits( 551 552 553 554 return snd_soc_dapm_put_enum_double(kc 555 } 556 557 static int va_macro_tx_mixer_get(struct snd_kc 558 struct snd_ct 559 { 560 struct snd_soc_dapm_widget *widget = 561 snd_soc_dapm_kcontrol_widget(k 562 struct snd_soc_component *component = 563 snd_soc_dapm_t 564 struct soc_mixer_control *mc = 565 (struct soc_mixer_control *)kc 566 u32 dai_id = widget->shift; 567 u32 dec_id = mc->shift; 568 struct va_macro *va = snd_soc_componen 569 570 if (test_bit(dec_id, &va->active_ch_ma 571 ucontrol->value.integer.value[ 572 else 573 ucontrol->value.integer.value[ 574 575 return 0; 576 } 577 578 static int va_macro_tx_mixer_put(struct snd_kc 579 struct snd_ct 580 { 581 struct snd_soc_dapm_widget *widget = 582 snd_so 583 struct snd_soc_component *component = 584 snd_soc_dapm_t 585 struct snd_soc_dapm_update *update = N 586 struct soc_mixer_control *mc = 587 (struct soc_mixer_control *)kc 588 u32 dai_id = widget->shift; 589 u32 dec_id = mc->shift; 590 u32 enable = ucontrol->value.integer.v 591 struct va_macro *va = snd_soc_componen 592 593 if (enable) { 594 set_bit(dec_id, &va->active_ch 595 va->active_ch_cnt[dai_id]++; 596 } else { 597 clear_bit(dec_id, &va->active_ 598 va->active_ch_cnt[dai_id]--; 599 } 600 601 snd_soc_dapm_mixer_update_power(widget 602 603 return 0; 604 } 605 606 static int va_dmic_clk_enable(struct snd_soc_c 607 u32 dmic, bool e 608 { 609 struct va_macro *va = snd_soc_componen 610 u16 dmic_clk_reg; 611 s32 *dmic_clk_cnt; 612 u8 *dmic_clk_div; 613 u8 freq_change_mask; 614 u8 clk_div; 615 616 switch (dmic) { 617 case 0: 618 case 1: 619 dmic_clk_cnt = &(va->dmic_0_1_ 620 dmic_clk_div = &(va->dmic_0_1_ 621 dmic_clk_reg = CDC_VA_TOP_CSR_ 622 freq_change_mask = CDC_VA_DMIC 623 break; 624 case 2: 625 case 3: 626 dmic_clk_cnt = &(va->dmic_2_3_ 627 dmic_clk_div = &(va->dmic_2_3_ 628 dmic_clk_reg = CDC_VA_TOP_CSR_ 629 freq_change_mask = CDC_VA_DMIC 630 break; 631 case 4: 632 case 5: 633 dmic_clk_cnt = &(va->dmic_4_5_ 634 dmic_clk_div = &(va->dmic_4_5_ 635 dmic_clk_reg = CDC_VA_TOP_CSR_ 636 freq_change_mask = CDC_VA_DMIC 637 break; 638 case 6: 639 case 7: 640 dmic_clk_cnt = &(va->dmic_6_7_ 641 dmic_clk_div = &(va->dmic_6_7_ 642 dmic_clk_reg = CDC_VA_TOP_CSR_ 643 freq_change_mask = CDC_VA_DMIC 644 break; 645 default: 646 dev_err(component->dev, "%s: I 647 __func__); 648 return -EINVAL; 649 } 650 651 if (enable) { 652 clk_div = va->dmic_clk_div; 653 (*dmic_clk_cnt)++; 654 if (*dmic_clk_cnt == 1) { 655 snd_soc_component_upda 656 657 658 659 snd_soc_component_upda 660 CDC_VA 661 clk_di 662 snd_soc_component_upda 663 664 665 } else { 666 if (*dmic_clk_div > cl 667 snd_soc_compon 668 669 670 671 snd_soc_compon 672 673 674 snd_soc_compon 675 676 677 678 } else { 679 clk_div = *dmi 680 } 681 } 682 *dmic_clk_div = clk_div; 683 } else { 684 (*dmic_clk_cnt)--; 685 if (*dmic_clk_cnt == 0) { 686 snd_soc_component_upda 687 688 clk_div = 0; 689 snd_soc_component_upda 690 691 692 } else { 693 clk_div = va->dmic_clk 694 if (*dmic_clk_div > cl 695 clk_div = va-> 696 snd_soc_compon 697 698 699 700 snd_soc_compon 701 702 703 snd_soc_compon 704 705 706 707 } else { 708 clk_div = *dmi 709 } 710 } 711 *dmic_clk_div = clk_div; 712 } 713 714 return 0; 715 } 716 717 static int va_macro_enable_dmic(struct snd_soc 718 struct snd_kco 719 { 720 struct snd_soc_component *comp = snd_s 721 unsigned int dmic = w->shift; 722 723 switch (event) { 724 case SND_SOC_DAPM_PRE_PMU: 725 va_dmic_clk_enable(comp, dmic, 726 break; 727 case SND_SOC_DAPM_POST_PMD: 728 va_dmic_clk_enable(comp, dmic, 729 break; 730 } 731 732 return 0; 733 } 734 735 static int va_macro_enable_dec(struct snd_soc_ 736 struct snd_kcon 737 { 738 struct snd_soc_component *comp = snd_s 739 unsigned int decimator; 740 u16 tx_vol_ctl_reg, dec_cfg_reg, hpf_g 741 u16 tx_gain_ctl_reg; 742 u8 hpf_cut_off_freq; 743 744 struct va_macro *va = snd_soc_componen 745 746 decimator = w->shift; 747 748 tx_vol_ctl_reg = CDC_VA_TX0_TX_PATH_CT 749 VA_MACRO_TX_PA 750 hpf_gate_reg = CDC_VA_TX0_TX_PATH_SEC2 751 VA_MACRO_TX_PA 752 dec_cfg_reg = CDC_VA_TX0_TX_PATH_CFG0 753 VA_MACRO_TX_PA 754 tx_gain_ctl_reg = CDC_VA_TX0_TX_VOL_CT 755 VA_MACRO_TX_PA 756 757 switch (event) { 758 case SND_SOC_DAPM_PRE_PMU: 759 snd_soc_component_update_bits( 760 dec_cfg_reg, CDC_VA_AD 761 va->dec_mode[decimator 762 /* Enable TX PGA Mute */ 763 break; 764 case SND_SOC_DAPM_POST_PMU: 765 /* Enable TX CLK */ 766 snd_soc_component_update_bits( 767 768 769 snd_soc_component_update_bits( 770 771 772 773 usleep_range(1000, 1010); 774 hpf_cut_off_freq = (snd_soc_co 775 TX_HPF_CUT 776 777 if (hpf_cut_off_freq != CF_MIN 778 snd_soc_component_upda 779 780 781 782 snd_soc_component_upda 783 CDC_VA_T 784 CDC_VA_T 785 786 /* 787 * Minimum 1 clk cycle 788 */ 789 usleep_range(1000, 101 790 791 snd_soc_component_upda 792 hpf_gate_reg, 793 CDC_VA_TX_HPF_ 794 0x0); 795 } 796 797 798 usleep_range(1000, 1010); 799 snd_soc_component_update_bits( 800 801 802 /* 803 * 6ms delay is required as pe 804 */ 805 usleep_range(6000, 6010); 806 /* apply gain after decimator 807 snd_soc_component_write(comp, 808 snd_soc_component_read 809 break; 810 case SND_SOC_DAPM_POST_PMD: 811 /* Disable TX CLK */ 812 snd_soc_component_update_bits( 813 814 815 break; 816 } 817 return 0; 818 } 819 820 static int va_macro_dec_mode_get(struct snd_kc 821 struct snd_ct 822 { 823 struct snd_soc_component *comp = snd_s 824 struct va_macro *va = snd_soc_componen 825 struct soc_enum *e = (struct soc_enum 826 int path = e->shift_l; 827 828 ucontrol->value.enumerated.item[0] = v 829 830 return 0; 831 } 832 833 static int va_macro_dec_mode_put(struct snd_kc 834 struct snd_ct 835 { 836 struct snd_soc_component *comp = snd_s 837 int value = ucontrol->value.enumerated 838 struct soc_enum *e = (struct soc_enum 839 int path = e->shift_l; 840 struct va_macro *va = snd_soc_componen 841 842 va->dec_mode[path] = value; 843 844 return 0; 845 } 846 847 static int va_macro_hw_params(struct snd_pcm_s 848 struct snd_pcm_h 849 struct snd_soc_d 850 { 851 int tx_fs_rate; 852 struct snd_soc_component *component = 853 u32 decimator, sample_rate; 854 u16 tx_fs_reg; 855 struct device *va_dev = component->dev 856 struct va_macro *va = snd_soc_componen 857 858 sample_rate = params_rate(params); 859 switch (sample_rate) { 860 case 8000: 861 tx_fs_rate = 0; 862 break; 863 case 16000: 864 tx_fs_rate = 1; 865 break; 866 case 32000: 867 tx_fs_rate = 3; 868 break; 869 case 48000: 870 tx_fs_rate = 4; 871 break; 872 case 96000: 873 tx_fs_rate = 5; 874 break; 875 case 192000: 876 tx_fs_rate = 6; 877 break; 878 case 384000: 879 tx_fs_rate = 7; 880 break; 881 default: 882 dev_err(va_dev, "%s: Invalid T 883 __func__, params_rate( 884 return -EINVAL; 885 } 886 887 for_each_set_bit(decimator, &va->activ 888 VA_MACRO_DEC_MAX) { 889 tx_fs_reg = CDC_VA_TX0_TX_PATH 890 VA_MACRO_TX_PATH_O 891 snd_soc_component_update_bits( 892 893 } 894 return 0; 895 } 896 897 static int va_macro_get_channel_map(const stru 898 unsigned i 899 unsigned i 900 { 901 struct snd_soc_component *component = 902 struct device *va_dev = component->dev 903 struct va_macro *va = snd_soc_componen 904 905 switch (dai->id) { 906 case VA_MACRO_AIF1_CAP: 907 case VA_MACRO_AIF2_CAP: 908 case VA_MACRO_AIF3_CAP: 909 *tx_slot = va->active_ch_mask[ 910 *tx_num = va->active_ch_cnt[da 911 break; 912 default: 913 dev_err(va_dev, "%s: Invalid A 914 break; 915 } 916 return 0; 917 } 918 919 static int va_macro_digital_mute(struct snd_so 920 { 921 struct snd_soc_component *component = 922 struct va_macro *va = snd_soc_componen 923 u16 tx_vol_ctl_reg, decimator; 924 925 for_each_set_bit(decimator, &va->activ 926 VA_MACRO_DEC_MAX) { 927 tx_vol_ctl_reg = CDC_VA_TX0_TX 928 VA_MAC 929 if (mute) 930 snd_soc_component_upda 931 CDC_VA 932 CDC_VA 933 else 934 snd_soc_component_upda 935 CDC_VA 936 CDC_VA 937 } 938 939 return 0; 940 } 941 942 static const struct snd_soc_dai_ops va_macro_d 943 .hw_params = va_macro_hw_params, 944 .get_channel_map = va_macro_get_channe 945 .mute_stream = va_macro_digital_mute, 946 }; 947 948 static struct snd_soc_dai_driver va_macro_dais 949 { 950 .name = "va_macro_tx1", 951 .id = VA_MACRO_AIF1_CAP, 952 .capture = { 953 .stream_name = "VA_AIF 954 .rates = VA_MACRO_RATE 955 .formats = VA_MACRO_FO 956 .rate_max = 192000, 957 .rate_min = 8000, 958 .channels_min = 1, 959 .channels_max = 8, 960 }, 961 .ops = &va_macro_dai_ops, 962 }, 963 { 964 .name = "va_macro_tx2", 965 .id = VA_MACRO_AIF2_CAP, 966 .capture = { 967 .stream_name = "VA_AIF 968 .rates = VA_MACRO_RATE 969 .formats = VA_MACRO_FO 970 .rate_max = 192000, 971 .rate_min = 8000, 972 .channels_min = 1, 973 .channels_max = 8, 974 }, 975 .ops = &va_macro_dai_ops, 976 }, 977 { 978 .name = "va_macro_tx3", 979 .id = VA_MACRO_AIF3_CAP, 980 .capture = { 981 .stream_name = "VA_AIF 982 .rates = VA_MACRO_RATE 983 .formats = VA_MACRO_FO 984 .rate_max = 192000, 985 .rate_min = 8000, 986 .channels_min = 1, 987 .channels_max = 8, 988 }, 989 .ops = &va_macro_dai_ops, 990 }, 991 }; 992 993 static const char * const adc_mux_text[] = { 994 "VA_DMIC", "SWR_MIC" 995 }; 996 997 static SOC_ENUM_SINGLE_DECL(va_dec0_enum, CDC_ 998 0, adc_mux_text); 999 static SOC_ENUM_SINGLE_DECL(va_dec1_enum, CDC_ 1000 0, adc_mux_text); 1001 static SOC_ENUM_SINGLE_DECL(va_dec2_enum, CDC 1002 0, adc_mux_text); 1003 static SOC_ENUM_SINGLE_DECL(va_dec3_enum, CDC 1004 0, adc_mux_text); 1005 1006 static const struct snd_kcontrol_new va_dec0_ 1007 1008 static const struct snd_kcontrol_new va_dec1_ 1009 1010 static const struct snd_kcontrol_new va_dec2_ 1011 1012 static const struct snd_kcontrol_new va_dec3_ 1013 1014 1015 static const char * const dmic_mux_text[] = { 1016 "ZERO", "DMIC0", "DMIC1", "DMIC2", "D 1017 "DMIC4", "DMIC5", "DMIC6", "DMIC7" 1018 }; 1019 1020 static SOC_ENUM_SINGLE_DECL(va_dmic0_enum, CD 1021 4, dmic_mux_text); 1022 1023 static SOC_ENUM_SINGLE_DECL(va_dmic1_enum, CD 1024 4, dmic_mux_text); 1025 1026 static SOC_ENUM_SINGLE_DECL(va_dmic2_enum, CD 1027 4, dmic_mux_text); 1028 1029 static SOC_ENUM_SINGLE_DECL(va_dmic3_enum, CD 1030 4, dmic_mux_text); 1031 1032 static const struct snd_kcontrol_new va_dmic0 1033 va_dmic0_enum, snd_s 1034 va_macro_put_dec_enu 1035 1036 static const struct snd_kcontrol_new va_dmic1 1037 va_dmic1_enum, snd_s 1038 va_macro_put_dec_enu 1039 1040 static const struct snd_kcontrol_new va_dmic2 1041 va_dmic2_enum, snd_s 1042 va_macro_put_dec_enu 1043 1044 static const struct snd_kcontrol_new va_dmic3 1045 va_dmic3_enum, snd_s 1046 va_macro_put_dec_enu 1047 1048 static const struct snd_kcontrol_new va_aif1_ 1049 SOC_SINGLE_EXT("DEC0", SND_SOC_NOPM, 1050 va_macro_tx_mixer_get 1051 SOC_SINGLE_EXT("DEC1", SND_SOC_NOPM, 1052 va_macro_tx_mixer_get 1053 SOC_SINGLE_EXT("DEC2", SND_SOC_NOPM, 1054 va_macro_tx_mixer_get 1055 SOC_SINGLE_EXT("DEC3", SND_SOC_NOPM, 1056 va_macro_tx_mixer_get 1057 SOC_SINGLE_EXT("DEC4", SND_SOC_NOPM, 1058 va_macro_tx_mixer_get 1059 SOC_SINGLE_EXT("DEC5", SND_SOC_NOPM, 1060 va_macro_tx_mixer_get 1061 SOC_SINGLE_EXT("DEC6", SND_SOC_NOPM, 1062 va_macro_tx_mixer_get 1063 SOC_SINGLE_EXT("DEC7", SND_SOC_NOPM, 1064 va_macro_tx_mixer_get 1065 }; 1066 1067 static const struct snd_kcontrol_new va_aif2_ 1068 SOC_SINGLE_EXT("DEC0", SND_SOC_NOPM, 1069 va_macro_tx_mixer_get 1070 SOC_SINGLE_EXT("DEC1", SND_SOC_NOPM, 1071 va_macro_tx_mixer_get 1072 SOC_SINGLE_EXT("DEC2", SND_SOC_NOPM, 1073 va_macro_tx_mixer_get 1074 SOC_SINGLE_EXT("DEC3", SND_SOC_NOPM, 1075 va_macro_tx_mixer_get 1076 SOC_SINGLE_EXT("DEC4", SND_SOC_NOPM, 1077 va_macro_tx_mixer_get 1078 SOC_SINGLE_EXT("DEC5", SND_SOC_NOPM, 1079 va_macro_tx_mixer_get 1080 SOC_SINGLE_EXT("DEC6", SND_SOC_NOPM, 1081 va_macro_tx_mixer_get 1082 SOC_SINGLE_EXT("DEC7", SND_SOC_NOPM, 1083 va_macro_tx_mixer_get 1084 }; 1085 1086 static const struct snd_kcontrol_new va_aif3_ 1087 SOC_SINGLE_EXT("DEC0", SND_SOC_NOPM, 1088 va_macro_tx_mixer_get 1089 SOC_SINGLE_EXT("DEC1", SND_SOC_NOPM, 1090 va_macro_tx_mixer_get 1091 SOC_SINGLE_EXT("DEC2", SND_SOC_NOPM, 1092 va_macro_tx_mixer_get 1093 SOC_SINGLE_EXT("DEC3", SND_SOC_NOPM, 1094 va_macro_tx_mixer_get 1095 SOC_SINGLE_EXT("DEC4", SND_SOC_NOPM, 1096 va_macro_tx_mixer_get 1097 SOC_SINGLE_EXT("DEC5", SND_SOC_NOPM, 1098 va_macro_tx_mixer_get 1099 SOC_SINGLE_EXT("DEC6", SND_SOC_NOPM, 1100 va_macro_tx_mixer_get 1101 SOC_SINGLE_EXT("DEC7", SND_SOC_NOPM, 1102 va_macro_tx_mixer_get 1103 }; 1104 1105 static const struct snd_soc_dapm_widget va_ma 1106 SND_SOC_DAPM_AIF_OUT("VA_AIF1 CAP", " 1107 SND_SOC_NOPM, VA_MACRO_AIF1_C 1108 1109 SND_SOC_DAPM_AIF_OUT("VA_AIF2 CAP", " 1110 SND_SOC_NOPM, VA_MACRO_AIF2_C 1111 1112 SND_SOC_DAPM_AIF_OUT("VA_AIF3 CAP", " 1113 SND_SOC_NOPM, VA_MACRO_AIF3_C 1114 1115 SND_SOC_DAPM_MIXER("VA_AIF1_CAP Mixer 1116 VA_MACRO_AIF1_CAP, 0, 1117 va_aif1_cap_mixer, ARRAY_SIZE 1118 1119 SND_SOC_DAPM_MIXER("VA_AIF2_CAP Mixer 1120 VA_MACRO_AIF2_CAP, 0, 1121 va_aif2_cap_mixer, ARRAY_SIZE 1122 1123 SND_SOC_DAPM_MIXER("VA_AIF3_CAP Mixer 1124 VA_MACRO_AIF3_CAP, 0, 1125 va_aif3_cap_mixer, ARRAY_SIZE 1126 1127 SND_SOC_DAPM_MUX("VA DMIC MUX0", SND_ 1128 SND_SOC_DAPM_MUX("VA DMIC MUX1", SND_ 1129 SND_SOC_DAPM_MUX("VA DMIC MUX2", SND_ 1130 SND_SOC_DAPM_MUX("VA DMIC MUX3", SND_ 1131 1132 SND_SOC_DAPM_REGULATOR_SUPPLY("vdd-mi 1133 SND_SOC_DAPM_INPUT("DMIC0 Pin"), 1134 SND_SOC_DAPM_INPUT("DMIC1 Pin"), 1135 SND_SOC_DAPM_INPUT("DMIC2 Pin"), 1136 SND_SOC_DAPM_INPUT("DMIC3 Pin"), 1137 SND_SOC_DAPM_INPUT("DMIC4 Pin"), 1138 SND_SOC_DAPM_INPUT("DMIC5 Pin"), 1139 SND_SOC_DAPM_INPUT("DMIC6 Pin"), 1140 SND_SOC_DAPM_INPUT("DMIC7 Pin"), 1141 1142 SND_SOC_DAPM_ADC_E("VA DMIC0", NULL, 1143 va_macro_enable_dmic, SND_SOC 1144 SND_SOC_DAPM_POST_PMD), 1145 1146 SND_SOC_DAPM_ADC_E("VA DMIC1", NULL, 1147 va_macro_enable_dmic, SND_SOC 1148 SND_SOC_DAPM_POST_PMD), 1149 1150 SND_SOC_DAPM_ADC_E("VA DMIC2", NULL, 1151 va_macro_enable_dmic, SND_SOC 1152 SND_SOC_DAPM_POST_PMD), 1153 1154 SND_SOC_DAPM_ADC_E("VA DMIC3", NULL, 1155 va_macro_enable_dmic, SND_SOC 1156 SND_SOC_DAPM_POST_PMD), 1157 1158 SND_SOC_DAPM_ADC_E("VA DMIC4", NULL, 1159 va_macro_enable_dmic, SND_SOC 1160 SND_SOC_DAPM_POST_PMD), 1161 1162 SND_SOC_DAPM_ADC_E("VA DMIC5", NULL, 1163 va_macro_enable_dmic, SND_SOC 1164 SND_SOC_DAPM_POST_PMD), 1165 1166 SND_SOC_DAPM_ADC_E("VA DMIC6", NULL, 1167 va_macro_enable_dmic, SND_SOC 1168 SND_SOC_DAPM_POST_PMD), 1169 1170 SND_SOC_DAPM_ADC_E("VA DMIC7", NULL, 1171 va_macro_enable_dmic, SND_SOC 1172 SND_SOC_DAPM_POST_PMD), 1173 1174 SND_SOC_DAPM_INPUT("VA SWR_ADC0"), 1175 SND_SOC_DAPM_INPUT("VA SWR_ADC1"), 1176 SND_SOC_DAPM_INPUT("VA SWR_ADC2"), 1177 SND_SOC_DAPM_INPUT("VA SWR_ADC3"), 1178 SND_SOC_DAPM_INPUT("VA SWR_MIC0"), 1179 SND_SOC_DAPM_INPUT("VA SWR_MIC1"), 1180 SND_SOC_DAPM_INPUT("VA SWR_MIC2"), 1181 SND_SOC_DAPM_INPUT("VA SWR_MIC3"), 1182 SND_SOC_DAPM_INPUT("VA SWR_MIC4"), 1183 SND_SOC_DAPM_INPUT("VA SWR_MIC5"), 1184 SND_SOC_DAPM_INPUT("VA SWR_MIC6"), 1185 SND_SOC_DAPM_INPUT("VA SWR_MIC7"), 1186 1187 SND_SOC_DAPM_MUX_E("VA DEC0 MUX", SND 1188 &va_dec0_mux, va_m 1189 SND_SOC_DAPM_PRE_P 1190 SND_SOC_DAPM_PRE_P 1191 1192 SND_SOC_DAPM_MUX_E("VA DEC1 MUX", SND 1193 &va_dec1_mux, va_m 1194 SND_SOC_DAPM_PRE_P 1195 SND_SOC_DAPM_PRE_P 1196 1197 SND_SOC_DAPM_MUX_E("VA DEC2 MUX", SND 1198 &va_dec2_mux, va_m 1199 SND_SOC_DAPM_PRE_P 1200 SND_SOC_DAPM_PRE_P 1201 1202 SND_SOC_DAPM_MUX_E("VA DEC3 MUX", SND 1203 &va_dec3_mux, va_m 1204 SND_SOC_DAPM_PRE_P 1205 SND_SOC_DAPM_PRE_P 1206 1207 SND_SOC_DAPM_SUPPLY_S("VA_MCLK", -1, 1208 va_macro_mclk_e 1209 SND_SOC_DAPM_PR 1210 }; 1211 1212 static const struct snd_soc_dapm_route va_aud 1213 {"VA_AIF1 CAP", NULL, "VA_MCLK"}, 1214 {"VA_AIF2 CAP", NULL, "VA_MCLK"}, 1215 {"VA_AIF3 CAP", NULL, "VA_MCLK"}, 1216 1217 {"VA_AIF1 CAP", NULL, "VA_AIF1_CAP Mi 1218 {"VA_AIF2 CAP", NULL, "VA_AIF2_CAP Mi 1219 {"VA_AIF3 CAP", NULL, "VA_AIF3_CAP Mi 1220 1221 {"VA_AIF1_CAP Mixer", "DEC0", "VA DEC 1222 {"VA_AIF1_CAP Mixer", "DEC1", "VA DEC 1223 {"VA_AIF1_CAP Mixer", "DEC2", "VA DEC 1224 {"VA_AIF1_CAP Mixer", "DEC3", "VA DEC 1225 1226 {"VA_AIF2_CAP Mixer", "DEC0", "VA DEC 1227 {"VA_AIF2_CAP Mixer", "DEC1", "VA DEC 1228 {"VA_AIF2_CAP Mixer", "DEC2", "VA DEC 1229 {"VA_AIF2_CAP Mixer", "DEC3", "VA DEC 1230 1231 {"VA_AIF3_CAP Mixer", "DEC0", "VA DEC 1232 {"VA_AIF3_CAP Mixer", "DEC1", "VA DEC 1233 {"VA_AIF3_CAP Mixer", "DEC2", "VA DEC 1234 {"VA_AIF3_CAP Mixer", "DEC3", "VA DEC 1235 1236 {"VA DEC0 MUX", "VA_DMIC", "VA DMIC M 1237 {"VA DMIC MUX0", "DMIC0", "VA DMIC0"} 1238 {"VA DMIC MUX0", "DMIC1", "VA DMIC1"} 1239 {"VA DMIC MUX0", "DMIC2", "VA DMIC2"} 1240 {"VA DMIC MUX0", "DMIC3", "VA DMIC3"} 1241 {"VA DMIC MUX0", "DMIC4", "VA DMIC4"} 1242 {"VA DMIC MUX0", "DMIC5", "VA DMIC5"} 1243 {"VA DMIC MUX0", "DMIC6", "VA DMIC6"} 1244 {"VA DMIC MUX0", "DMIC7", "VA DMIC7"} 1245 1246 {"VA DEC1 MUX", "VA_DMIC", "VA DMIC M 1247 {"VA DMIC MUX1", "DMIC0", "VA DMIC0"} 1248 {"VA DMIC MUX1", "DMIC1", "VA DMIC1"} 1249 {"VA DMIC MUX1", "DMIC2", "VA DMIC2"} 1250 {"VA DMIC MUX1", "DMIC3", "VA DMIC3"} 1251 {"VA DMIC MUX1", "DMIC4", "VA DMIC4"} 1252 {"VA DMIC MUX1", "DMIC5", "VA DMIC5"} 1253 {"VA DMIC MUX1", "DMIC6", "VA DMIC6"} 1254 {"VA DMIC MUX1", "DMIC7", "VA DMIC7"} 1255 1256 {"VA DEC2 MUX", "VA_DMIC", "VA DMIC M 1257 {"VA DMIC MUX2", "DMIC0", "VA DMIC0"} 1258 {"VA DMIC MUX2", "DMIC1", "VA DMIC1"} 1259 {"VA DMIC MUX2", "DMIC2", "VA DMIC2"} 1260 {"VA DMIC MUX2", "DMIC3", "VA DMIC3"} 1261 {"VA DMIC MUX2", "DMIC4", "VA DMIC4"} 1262 {"VA DMIC MUX2", "DMIC5", "VA DMIC5"} 1263 {"VA DMIC MUX2", "DMIC6", "VA DMIC6"} 1264 {"VA DMIC MUX2", "DMIC7", "VA DMIC7"} 1265 1266 {"VA DEC3 MUX", "VA_DMIC", "VA DMIC M 1267 {"VA DMIC MUX3", "DMIC0", "VA DMIC0"} 1268 {"VA DMIC MUX3", "DMIC1", "VA DMIC1"} 1269 {"VA DMIC MUX3", "DMIC2", "VA DMIC2"} 1270 {"VA DMIC MUX3", "DMIC3", "VA DMIC3"} 1271 {"VA DMIC MUX3", "DMIC4", "VA DMIC4"} 1272 {"VA DMIC MUX3", "DMIC5", "VA DMIC5"} 1273 {"VA DMIC MUX3", "DMIC6", "VA DMIC6"} 1274 {"VA DMIC MUX3", "DMIC7", "VA DMIC7"} 1275 1276 { "VA DMIC0", NULL, "DMIC0 Pin" }, 1277 { "VA DMIC1", NULL, "DMIC1 Pin" }, 1278 { "VA DMIC2", NULL, "DMIC2 Pin" }, 1279 { "VA DMIC3", NULL, "DMIC3 Pin" }, 1280 { "VA DMIC4", NULL, "DMIC4 Pin" }, 1281 { "VA DMIC5", NULL, "DMIC5 Pin" }, 1282 { "VA DMIC6", NULL, "DMIC6 Pin" }, 1283 { "VA DMIC7", NULL, "DMIC7 Pin" }, 1284 }; 1285 1286 static const char * const dec_mode_mux_text[] 1287 "ADC_DEFAULT", "ADC_LOW_PWR", "ADC_HI 1288 }; 1289 1290 static const struct soc_enum dec_mode_mux_enu 1291 SOC_ENUM_SINGLE(SND_SOC_NOPM, 0, ARRA 1292 dec_mode_mux_text), 1293 SOC_ENUM_SINGLE(SND_SOC_NOPM, 1, ARRA 1294 dec_mode_mux_text), 1295 SOC_ENUM_SINGLE(SND_SOC_NOPM, 2, ARR 1296 dec_mode_mux_text), 1297 SOC_ENUM_SINGLE(SND_SOC_NOPM, 3, ARRA 1298 dec_mode_mux_text), 1299 }; 1300 1301 static const struct snd_kcontrol_new va_macro 1302 SOC_SINGLE_S8_TLV("VA_DEC0 Volume", C 1303 -84, 40, digital_ga 1304 SOC_SINGLE_S8_TLV("VA_DEC1 Volume", C 1305 -84, 40, digital_ga 1306 SOC_SINGLE_S8_TLV("VA_DEC2 Volume", C 1307 -84, 40, digital_ga 1308 SOC_SINGLE_S8_TLV("VA_DEC3 Volume", C 1309 -84, 40, digital_ga 1310 1311 SOC_ENUM_EXT("VA_DEC0 MODE", dec_mode 1312 va_macro_dec_mode_get, v 1313 SOC_ENUM_EXT("VA_DEC1 MODE", dec_mode 1314 va_macro_dec_mode_get, v 1315 SOC_ENUM_EXT("VA_DEC2 MODE", dec_mode 1316 va_macro_dec_mode_get, v 1317 SOC_ENUM_EXT("VA_DEC3 MODE", dec_mode 1318 va_macro_dec_mode_get, v 1319 }; 1320 1321 static int va_macro_component_probe(struct sn 1322 { 1323 struct va_macro *va = snd_soc_compone 1324 1325 snd_soc_component_init_regmap(compone 1326 1327 return 0; 1328 } 1329 1330 static const struct snd_soc_component_driver 1331 .name = "VA MACRO", 1332 .probe = va_macro_component_probe, 1333 .controls = va_macro_snd_controls, 1334 .num_controls = ARRAY_SIZE(va_macro_s 1335 .dapm_widgets = va_macro_dapm_widgets 1336 .num_dapm_widgets = ARRAY_SIZE(va_mac 1337 .dapm_routes = va_audio_map, 1338 .num_dapm_routes = ARRAY_SIZE(va_audi 1339 }; 1340 1341 static int fsgen_gate_enable(struct clk_hw *h 1342 { 1343 struct va_macro *va = to_va_macro(hw) 1344 struct regmap *regmap = va->regmap; 1345 int ret; 1346 1347 if (va->has_swr_master) { 1348 ret = clk_prepare_enable(va-> 1349 if (ret) 1350 return ret; 1351 } 1352 1353 ret = va_macro_mclk_enable(va, true); 1354 if (va->has_swr_master) 1355 regmap_update_bits(regmap, CD 1356 CDC_VA_SWR 1357 1358 return ret; 1359 } 1360 1361 static void fsgen_gate_disable(struct clk_hw 1362 { 1363 struct va_macro *va = to_va_macro(hw) 1364 struct regmap *regmap = va->regmap; 1365 1366 if (va->has_swr_master) 1367 regmap_update_bits(regmap, CD 1368 CDC_VA_SWR_CLK_EN_ 1369 1370 va_macro_mclk_enable(va, false); 1371 if (va->has_swr_master) 1372 clk_disable_unprepare(va->mcl 1373 } 1374 1375 static int fsgen_gate_is_enabled(struct clk_h 1376 { 1377 struct va_macro *va = to_va_macro(hw) 1378 int val; 1379 1380 regmap_read(va->regmap, CDC_VA_TOP_CS 1381 1382 return !!(val & CDC_VA_FS_BROADCAST_ 1383 } 1384 1385 static const struct clk_ops fsgen_gate_ops = 1386 .prepare = fsgen_gate_enable, 1387 .unprepare = fsgen_gate_disable, 1388 .is_enabled = fsgen_gate_is_enabled, 1389 }; 1390 1391 static int va_macro_register_fsgen_output(str 1392 { 1393 struct clk *parent = va->mclk; 1394 struct device *dev = va->dev; 1395 struct device_node *np = dev->of_node 1396 const char *parent_clk_name; 1397 const char *clk_name = "fsgen"; 1398 struct clk_init_data init; 1399 int ret; 1400 1401 if (va->has_npl_clk) 1402 parent = va->npl; 1403 1404 parent_clk_name = __clk_get_name(pare 1405 1406 of_property_read_string(np, "clock-ou 1407 1408 init.name = clk_name; 1409 init.ops = &fsgen_gate_ops; 1410 init.flags = 0; 1411 init.parent_names = &parent_clk_name; 1412 init.num_parents = 1; 1413 va->hw.init = &init; 1414 ret = devm_clk_hw_register(va->dev, & 1415 if (ret) 1416 return ret; 1417 1418 return devm_of_clk_add_hw_provider(de 1419 } 1420 1421 static int va_macro_validate_dmic_sample_rate 1422 1423 { 1424 u32 div_factor; 1425 u32 mclk_rate = VA_MACRO_MCLK_FREQ; 1426 1427 if (!dmic_sample_rate || mclk_rate % 1428 goto undefined_rate; 1429 1430 div_factor = mclk_rate / dmic_sample_ 1431 1432 switch (div_factor) { 1433 case 2: 1434 va->dmic_clk_div = VA_MACRO_C 1435 break; 1436 case 3: 1437 va->dmic_clk_div = VA_MACRO_C 1438 break; 1439 case 4: 1440 va->dmic_clk_div = VA_MACRO_C 1441 break; 1442 case 6: 1443 va->dmic_clk_div = VA_MACRO_C 1444 break; 1445 case 8: 1446 va->dmic_clk_div = VA_MACRO_C 1447 break; 1448 case 16: 1449 va->dmic_clk_div = VA_MACRO_C 1450 break; 1451 default: 1452 /* Any other DIV factor is in 1453 goto undefined_rate; 1454 } 1455 1456 return dmic_sample_rate; 1457 1458 undefined_rate: 1459 dev_err(va->dev, "%s: Invalid rate %d 1460 __func__, dmic_sample_rate, m 1461 dmic_sample_rate = 0; 1462 1463 return dmic_sample_rate; 1464 } 1465 1466 static void va_macro_set_lpass_codec_version( 1467 { 1468 int core_id_0 = 0, core_id_1 = 0, cor 1469 int version = LPASS_CODEC_VERSION_UNK 1470 1471 regmap_read(va->regmap, CDC_VA_TOP_CS 1472 regmap_read(va->regmap, CDC_VA_TOP_CS 1473 regmap_read(va->regmap, CDC_VA_TOP_CS 1474 1475 if ((core_id_0 == 0x01) && (core_id_1 1476 version = LPASS_CODEC_VERSION 1477 if ((core_id_0 == 0x02) && (core_id_1 1478 version = LPASS_CODEC_VERSION 1479 if ((core_id_0 == 0x02) && (core_id_1 1480 version = LPASS_CODEC_VERSION 1481 if ((core_id_0 == 0x02) && (core_id_1 1482 version = LPASS_CODEC_VERSION 1483 if ((core_id_0 == 0x02) && (core_id_1 1484 version = LPASS_CODEC_VERSION 1485 if ((core_id_0 == 0x02) && (core_id_1 1486 version = LPASS_CODEC_VERSION 1487 if ((core_id_0 == 0x02) && (core_id_1 1488 version = LPASS_CODEC_VERSION 1489 1490 if (version == LPASS_CODEC_VERSION_UN 1491 dev_warn(va->dev, "Unknown Co 1492 core_id_0, core_id_1 1493 1494 lpass_macro_set_codec_version(version 1495 1496 dev_dbg(va->dev, "LPASS Codec Version 1497 } 1498 1499 static int va_macro_probe(struct platform_dev 1500 { 1501 struct device *dev = &pdev->dev; 1502 const struct va_macro_data *data; 1503 struct va_macro *va; 1504 void __iomem *base; 1505 u32 sample_rate = 0; 1506 int ret; 1507 1508 va = devm_kzalloc(dev, sizeof(*va), G 1509 if (!va) 1510 return -ENOMEM; 1511 1512 va->dev = dev; 1513 1514 va->macro = devm_clk_get_optional(dev 1515 if (IS_ERR(va->macro)) 1516 return dev_err_probe(dev, PTR 1517 1518 va->dcodec = devm_clk_get_optional(de 1519 if (IS_ERR(va->dcodec)) 1520 return dev_err_probe(dev, PTR 1521 1522 va->mclk = devm_clk_get(dev, "mclk"); 1523 if (IS_ERR(va->mclk)) 1524 return dev_err_probe(dev, PTR 1525 1526 va->pds = lpass_macro_pds_init(dev); 1527 if (IS_ERR(va->pds)) 1528 return PTR_ERR(va->pds); 1529 1530 ret = of_property_read_u32(dev->of_no 1531 &sample_ra 1532 if (ret) { 1533 dev_err(dev, "qcom,dmic-sampl 1534 va->dmic_clk_div = VA_MACRO_C 1535 } else { 1536 ret = va_macro_validate_dmic_ 1537 if (!ret) { 1538 ret = -EINVAL; 1539 goto err; 1540 } 1541 } 1542 1543 base = devm_platform_ioremap_resource 1544 if (IS_ERR(base)) { 1545 ret = PTR_ERR(base); 1546 goto err; 1547 } 1548 1549 va->regmap = devm_regmap_init_mmio(de 1550 if (IS_ERR(va->regmap)) { 1551 ret = -EINVAL; 1552 goto err; 1553 } 1554 1555 dev_set_drvdata(dev, va); 1556 1557 data = of_device_get_match_data(dev); 1558 va->has_swr_master = data->has_swr_ma 1559 va->has_npl_clk = data->has_npl_clk; 1560 1561 /* mclk rate */ 1562 clk_set_rate(va->mclk, 2 * VA_MACRO_M 1563 1564 if (va->has_npl_clk) { 1565 va->npl = devm_clk_get(dev, " 1566 if (IS_ERR(va->npl)) { 1567 ret = PTR_ERR(va->npl 1568 goto err; 1569 } 1570 1571 clk_set_rate(va->npl, 2 * VA_ 1572 } 1573 1574 ret = clk_prepare_enable(va->macro); 1575 if (ret) 1576 goto err; 1577 1578 ret = clk_prepare_enable(va->dcodec); 1579 if (ret) 1580 goto err_dcodec; 1581 1582 ret = clk_prepare_enable(va->mclk); 1583 if (ret) 1584 goto err_mclk; 1585 1586 if (va->has_npl_clk) { 1587 ret = clk_prepare_enable(va-> 1588 if (ret) 1589 goto err_npl; 1590 } 1591 1592 /** 1593 * old version of codecs do not have 1594 * version from registers, get them f 1595 */ 1596 if (data->version) 1597 lpass_macro_set_codec_version 1598 else /* read version from register */ 1599 va_macro_set_lpass_codec_vers 1600 1601 if (va->has_swr_master) { 1602 /* Set default CLK div to 1 * 1603 regmap_update_bits(va->regmap 1604 CDC_VA_SWR_ 1605 CDC_VA_SWR_ 1606 regmap_update_bits(va->regmap 1607 CDC_VA_SWR_ 1608 CDC_VA_SWR_ 1609 regmap_update_bits(va->regmap 1610 CDC_VA_SWR_ 1611 CDC_VA_SWR_ 1612 1613 } 1614 1615 if (va->has_swr_master) { 1616 regmap_update_bits(va->regmap 1617 CDC_VA_SWR 1618 regmap_update_bits(va->regmap 1619 CDC_VA_SWR 1620 regmap_update_bits(va->regmap 1621 CDC_VA_SWR 1622 } 1623 1624 ret = devm_snd_soc_register_component 1625 1626 1627 if (ret) 1628 goto err_clkout; 1629 1630 pm_runtime_set_autosuspend_delay(dev, 1631 pm_runtime_use_autosuspend(dev); 1632 pm_runtime_mark_last_busy(dev); 1633 pm_runtime_set_active(dev); 1634 pm_runtime_enable(dev); 1635 1636 ret = va_macro_register_fsgen_output( 1637 if (ret) 1638 goto err_clkout; 1639 1640 va->fsgen = clk_hw_get_clk(&va->hw, " 1641 if (IS_ERR(va->fsgen)) { 1642 ret = PTR_ERR(va->fsgen); 1643 goto err_clkout; 1644 } 1645 1646 return 0; 1647 1648 err_clkout: 1649 if (va->has_npl_clk) 1650 clk_disable_unprepare(va->npl 1651 err_npl: 1652 clk_disable_unprepare(va->mclk); 1653 err_mclk: 1654 clk_disable_unprepare(va->dcodec); 1655 err_dcodec: 1656 clk_disable_unprepare(va->macro); 1657 err: 1658 lpass_macro_pds_exit(va->pds); 1659 1660 return ret; 1661 } 1662 1663 static void va_macro_remove(struct platform_d 1664 { 1665 struct va_macro *va = dev_get_drvdata 1666 1667 if (va->has_npl_clk) 1668 clk_disable_unprepare(va->npl 1669 1670 clk_disable_unprepare(va->mclk); 1671 clk_disable_unprepare(va->dcodec); 1672 clk_disable_unprepare(va->macro); 1673 1674 lpass_macro_pds_exit(va->pds); 1675 } 1676 1677 static int __maybe_unused va_macro_runtime_su 1678 { 1679 struct va_macro *va = dev_get_drvdata 1680 1681 regcache_cache_only(va->regmap, true) 1682 regcache_mark_dirty(va->regmap); 1683 1684 if (va->has_npl_clk) 1685 clk_disable_unprepare(va->npl 1686 1687 clk_disable_unprepare(va->mclk); 1688 1689 return 0; 1690 } 1691 1692 static int __maybe_unused va_macro_runtime_re 1693 { 1694 struct va_macro *va = dev_get_drvdata 1695 int ret; 1696 1697 ret = clk_prepare_enable(va->mclk); 1698 if (ret) { 1699 dev_err(va->dev, "unable to p 1700 return ret; 1701 } 1702 1703 if (va->has_npl_clk) { 1704 ret = clk_prepare_enable(va-> 1705 if (ret) { 1706 clk_disable_unprepare 1707 dev_err(va->dev, "una 1708 return ret; 1709 } 1710 } 1711 1712 regcache_cache_only(va->regmap, false 1713 regcache_sync(va->regmap); 1714 1715 return 0; 1716 } 1717 1718 1719 static const struct dev_pm_ops va_macro_pm_op 1720 SET_RUNTIME_PM_OPS(va_macro_runtime_s 1721 }; 1722 1723 static const struct of_device_id va_macro_dt_ 1724 { .compatible = "qcom,sc7280-lpass-va 1725 { .compatible = "qcom,sm8250-lpass-va 1726 { .compatible = "qcom,sm8450-lpass-va 1727 { .compatible = "qcom,sm8550-lpass-va 1728 { .compatible = "qcom,sc8280xp-lpass- 1729 {} 1730 }; 1731 MODULE_DEVICE_TABLE(of, va_macro_dt_match); 1732 1733 static struct platform_driver va_macro_driver 1734 .driver = { 1735 .name = "va_macro", 1736 .of_match_table = va_macro_dt 1737 .suppress_bind_attrs = true, 1738 .pm = &va_macro_pm_ops, 1739 }, 1740 .probe = va_macro_probe, 1741 .remove = va_macro_remove, 1742 }; 1743 1744 module_platform_driver(va_macro_driver); 1745 MODULE_DESCRIPTION("VA macro driver"); 1746 MODULE_LICENSE("GPL"); 1747
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.