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