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

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

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

Diff markup

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


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

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

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

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

sflogo.php