~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/sound/soc/codecs/lpass-va-macro.c

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /sound/soc/codecs/lpass-va-macro.c (Version linux-6.12-rc7) and /sound/soc/codecs/lpass-va-macro.c (Version linux-5.18.19)


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

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php