• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // SPDX-License-Identifier: GPL-2.0
2 //
3 // Freescale ASRC ALSA SoC Digital Audio Interface (DAI) driver
4 //
5 // Copyright (C) 2014 Freescale Semiconductor, Inc.
6 //
7 // Author: Nicolin Chen <nicoleotsuka@gmail.com>
8 
9 #include <linux/clk.h>
10 #include <linux/delay.h>
11 #include <linux/dma-mapping.h>
12 #include <linux/module.h>
13 #include <linux/of_platform.h>
14 #include <linux/platform_data/dma-imx.h>
15 #include <linux/pm_runtime.h>
16 #include <sound/dmaengine_pcm.h>
17 #include <sound/pcm_params.h>
18 
19 #include "fsl_asrc.h"
20 
21 #define IDEAL_RATIO_DECIMAL_DEPTH 26
22 #define DIVIDER_NUM  64
23 
24 #define pair_err(fmt, ...) \
25 	dev_err(&asrc->pdev->dev, "Pair %c: " fmt, 'A' + index, ##__VA_ARGS__)
26 
27 #define pair_dbg(fmt, ...) \
28 	dev_dbg(&asrc->pdev->dev, "Pair %c: " fmt, 'A' + index, ##__VA_ARGS__)
29 
30 /* Corresponding to process_option */
31 static unsigned int supported_asrc_rate[] = {
32 	5512, 8000, 11025, 12000, 16000, 22050, 24000, 32000, 44100, 48000,
33 	64000, 88200, 96000, 128000, 176400, 192000,
34 };
35 
36 static struct snd_pcm_hw_constraint_list fsl_asrc_rate_constraints = {
37 	.count = ARRAY_SIZE(supported_asrc_rate),
38 	.list = supported_asrc_rate,
39 };
40 
41 /*
42  * The following tables map the relationship between asrc_inclk/asrc_outclk in
43  * fsl_asrc.h and the registers of ASRCSR
44  */
45 static unsigned char input_clk_map_imx35[ASRC_CLK_MAP_LEN] = {
46 	0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf,
47 	3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
48 	3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
49 };
50 
51 static unsigned char output_clk_map_imx35[ASRC_CLK_MAP_LEN] = {
52 	0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf,
53 	3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
54 	3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
55 };
56 
57 /* i.MX53 uses the same map for input and output */
58 static unsigned char input_clk_map_imx53[ASRC_CLK_MAP_LEN] = {
59 /*	0x0  0x1  0x2  0x3  0x4  0x5  0x6  0x7  0x8  0x9  0xa  0xb  0xc  0xd  0xe  0xf */
60 	0x0, 0x1, 0x2, 0x7, 0x4, 0x5, 0x6, 0x3, 0x8, 0x9, 0xa, 0xb, 0xc, 0xf, 0xe, 0xd,
61 	0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7,
62 	0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7,
63 };
64 
65 static unsigned char output_clk_map_imx53[ASRC_CLK_MAP_LEN] = {
66 /*	0x0  0x1  0x2  0x3  0x4  0x5  0x6  0x7  0x8  0x9  0xa  0xb  0xc  0xd  0xe  0xf */
67 	0x8, 0x9, 0xa, 0x7, 0xc, 0x5, 0x6, 0xb, 0x0, 0x1, 0x2, 0x3, 0x4, 0xf, 0xe, 0xd,
68 	0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7,
69 	0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7, 0x7,
70 };
71 
72 /*
73  * i.MX8QM/i.MX8QXP uses the same map for input and output.
74  * clk_map_imx8qm[0] is for i.MX8QM asrc0
75  * clk_map_imx8qm[1] is for i.MX8QM asrc1
76  * clk_map_imx8qxp[0] is for i.MX8QXP asrc0
77  * clk_map_imx8qxp[1] is for i.MX8QXP asrc1
78  */
79 static unsigned char clk_map_imx8qm[2][ASRC_CLK_MAP_LEN] = {
80 	{
81 	0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0x0,
82 	0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf,
83 	0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf,
84 	},
85 	{
86 	0xf, 0xf, 0xf, 0xf, 0xf, 0x7, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0x0,
87 	0x0, 0x1, 0x2, 0x3, 0xb, 0xc, 0xf, 0xf, 0xd, 0xe, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf,
88 	0x4, 0x5, 0x6, 0xf, 0x8, 0x9, 0xa, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf,
89 	},
90 };
91 
92 static unsigned char clk_map_imx8qxp[2][ASRC_CLK_MAP_LEN] = {
93 	{
94 	0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0x0,
95 	0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0xf, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xf, 0xf,
96 	0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf,
97 	},
98 	{
99 	0xf, 0xf, 0xf, 0xf, 0xf, 0x7, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0x0,
100 	0x0, 0x1, 0x2, 0x3, 0x7, 0x8, 0xf, 0xf, 0x9, 0xa, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf,
101 	0xf, 0xf, 0x6, 0xf, 0xf, 0xf, 0xa, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf, 0xf,
102 	},
103 };
104 
105 /*
106  * According to RM, the divider range is 1 ~ 8,
107  * prescaler is power of 2 from 1 ~ 128.
108  */
109 static int asrc_clk_divider[DIVIDER_NUM] = {
110 	1,  2,  4,  8,  16,  32,  64,  128,  /* divider = 1 */
111 	2,  4,  8, 16,  32,  64, 128,  256,  /* divider = 2 */
112 	3,  6, 12, 24,  48,  96, 192,  384,  /* divider = 3 */
113 	4,  8, 16, 32,  64, 128, 256,  512,  /* divider = 4 */
114 	5, 10, 20, 40,  80, 160, 320,  640,  /* divider = 5 */
115 	6, 12, 24, 48,  96, 192, 384,  768,  /* divider = 6 */
116 	7, 14, 28, 56, 112, 224, 448,  896,  /* divider = 7 */
117 	8, 16, 32, 64, 128, 256, 512, 1024,  /* divider = 8 */
118 };
119 
120 /*
121  * Check if the divider is available for internal ratio mode
122  */
fsl_asrc_divider_avail(int clk_rate,int rate,int * div)123 static bool fsl_asrc_divider_avail(int clk_rate, int rate, int *div)
124 {
125 	u32 rem, i;
126 	u64 n;
127 
128 	if (div)
129 		*div = 0;
130 
131 	if (clk_rate == 0 || rate == 0)
132 		return false;
133 
134 	n = clk_rate;
135 	rem = do_div(n, rate);
136 
137 	if (div)
138 		*div = n;
139 
140 	if (rem != 0)
141 		return false;
142 
143 	for (i = 0; i < DIVIDER_NUM; i++) {
144 		if (n == asrc_clk_divider[i])
145 			break;
146 	}
147 
148 	if (i == DIVIDER_NUM)
149 		return false;
150 
151 	return true;
152 }
153 
154 /**
155  * fsl_asrc_sel_proc - Select the pre-processing and post-processing options
156  * @inrate: input sample rate
157  * @outrate: output sample rate
158  * @pre_proc: return value for pre-processing option
159  * @post_proc: return value for post-processing option
160  *
161  * Make sure to exclude following unsupported cases before
162  * calling this function:
163  * 1) inrate > 8.125 * outrate
164  * 2) inrate > 16.125 * outrate
165  *
166  */
fsl_asrc_sel_proc(int inrate,int outrate,int * pre_proc,int * post_proc)167 static void fsl_asrc_sel_proc(int inrate, int outrate,
168 			     int *pre_proc, int *post_proc)
169 {
170 	bool post_proc_cond2;
171 	bool post_proc_cond0;
172 
173 	/* select pre_proc between [0, 2] */
174 	if (inrate * 8 > 33 * outrate)
175 		*pre_proc = 2;
176 	else if (inrate * 8 > 15 * outrate) {
177 		if (inrate > 152000)
178 			*pre_proc = 2;
179 		else
180 			*pre_proc = 1;
181 	} else if (inrate < 76000)
182 		*pre_proc = 0;
183 	else if (inrate > 152000)
184 		*pre_proc = 2;
185 	else
186 		*pre_proc = 1;
187 
188 	/* Condition for selection of post-processing */
189 	post_proc_cond2 = (inrate * 15 > outrate * 16 && outrate < 56000) ||
190 			  (inrate > 56000 && outrate < 56000);
191 	post_proc_cond0 = inrate * 23 < outrate * 8;
192 
193 	if (post_proc_cond2)
194 		*post_proc = 2;
195 	else if (post_proc_cond0)
196 		*post_proc = 0;
197 	else
198 		*post_proc = 1;
199 }
200 
201 /**
202  * fsl_asrc_request_pair - Request ASRC pair
203  * @channels: number of channels
204  * @pair: pointer to pair
205  *
206  * It assigns pair by the order of A->C->B because allocation of pair B,
207  * within range [ANCA, ANCA+ANCB-1], depends on the channels of pair A
208  * while pair A and pair C are comparatively independent.
209  */
fsl_asrc_request_pair(int channels,struct fsl_asrc_pair * pair)210 static int fsl_asrc_request_pair(int channels, struct fsl_asrc_pair *pair)
211 {
212 	enum asrc_pair_index index = ASRC_INVALID_PAIR;
213 	struct fsl_asrc *asrc = pair->asrc;
214 	struct device *dev = &asrc->pdev->dev;
215 	unsigned long lock_flags;
216 	int i, ret = 0;
217 
218 	spin_lock_irqsave(&asrc->lock, lock_flags);
219 
220 	for (i = ASRC_PAIR_A; i < ASRC_PAIR_MAX_NUM; i++) {
221 		if (asrc->pair[i] != NULL)
222 			continue;
223 
224 		index = i;
225 
226 		if (i != ASRC_PAIR_B)
227 			break;
228 	}
229 
230 	if (index == ASRC_INVALID_PAIR) {
231 		dev_err(dev, "all pairs are busy now\n");
232 		ret = -EBUSY;
233 	} else if (asrc->channel_avail < channels) {
234 		dev_err(dev, "can't afford required channels: %d\n", channels);
235 		ret = -EINVAL;
236 	} else {
237 		asrc->channel_avail -= channels;
238 		asrc->pair[index] = pair;
239 		pair->channels = channels;
240 		pair->index = index;
241 	}
242 
243 	spin_unlock_irqrestore(&asrc->lock, lock_flags);
244 
245 	return ret;
246 }
247 
248 /**
249  * fsl_asrc_release_pair - Release ASRC pair
250  * @pair: pair to release
251  *
252  * It clears the resource from asrc and releases the occupied channels.
253  */
fsl_asrc_release_pair(struct fsl_asrc_pair * pair)254 static void fsl_asrc_release_pair(struct fsl_asrc_pair *pair)
255 {
256 	struct fsl_asrc *asrc = pair->asrc;
257 	enum asrc_pair_index index = pair->index;
258 	unsigned long lock_flags;
259 
260 	/* Make sure the pair is disabled */
261 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
262 			   ASRCTR_ASRCEi_MASK(index), 0);
263 
264 	spin_lock_irqsave(&asrc->lock, lock_flags);
265 
266 	asrc->channel_avail += pair->channels;
267 	asrc->pair[index] = NULL;
268 	pair->error = 0;
269 
270 	spin_unlock_irqrestore(&asrc->lock, lock_flags);
271 }
272 
273 /**
274  * fsl_asrc_set_watermarks- configure input and output thresholds
275  * @pair: pointer to pair
276  * @in: input threshold
277  * @out: output threshold
278  */
fsl_asrc_set_watermarks(struct fsl_asrc_pair * pair,u32 in,u32 out)279 static void fsl_asrc_set_watermarks(struct fsl_asrc_pair *pair, u32 in, u32 out)
280 {
281 	struct fsl_asrc *asrc = pair->asrc;
282 	enum asrc_pair_index index = pair->index;
283 
284 	regmap_update_bits(asrc->regmap, REG_ASRMCR(index),
285 			   ASRMCRi_EXTTHRSHi_MASK |
286 			   ASRMCRi_INFIFO_THRESHOLD_MASK |
287 			   ASRMCRi_OUTFIFO_THRESHOLD_MASK,
288 			   ASRMCRi_EXTTHRSHi |
289 			   ASRMCRi_INFIFO_THRESHOLD(in) |
290 			   ASRMCRi_OUTFIFO_THRESHOLD(out));
291 }
292 
293 /**
294  * fsl_asrc_cal_asrck_divisor - Calculate the total divisor between asrck clock rate and sample rate
295  * @pair: pointer to pair
296  * @div: divider
297  *
298  * It follows the formula clk_rate = samplerate * (2 ^ prescaler) * divider
299  */
fsl_asrc_cal_asrck_divisor(struct fsl_asrc_pair * pair,u32 div)300 static u32 fsl_asrc_cal_asrck_divisor(struct fsl_asrc_pair *pair, u32 div)
301 {
302 	u32 ps;
303 
304 	/* Calculate the divisors: prescaler [2^0, 2^7], divder [1, 8] */
305 	for (ps = 0; div > 8; ps++)
306 		div >>= 1;
307 
308 	return ((div - 1) << ASRCDRi_AxCPi_WIDTH) | ps;
309 }
310 
311 /**
312  * fsl_asrc_set_ideal_ratio - Calculate and set the ratio for Ideal Ratio mode only
313  * @pair: pointer to pair
314  * @inrate: input rate
315  * @outrate: output rate
316  *
317  * The ratio is a 32-bit fixed point value with 26 fractional bits.
318  */
fsl_asrc_set_ideal_ratio(struct fsl_asrc_pair * pair,int inrate,int outrate)319 static int fsl_asrc_set_ideal_ratio(struct fsl_asrc_pair *pair,
320 				    int inrate, int outrate)
321 {
322 	struct fsl_asrc *asrc = pair->asrc;
323 	enum asrc_pair_index index = pair->index;
324 	unsigned long ratio;
325 	int i;
326 
327 	if (!outrate) {
328 		pair_err("output rate should not be zero\n");
329 		return -EINVAL;
330 	}
331 
332 	/* Calculate the intergal part of the ratio */
333 	ratio = (inrate / outrate) << IDEAL_RATIO_DECIMAL_DEPTH;
334 
335 	/* ... and then the 26 depth decimal part */
336 	inrate %= outrate;
337 
338 	for (i = 1; i <= IDEAL_RATIO_DECIMAL_DEPTH; i++) {
339 		inrate <<= 1;
340 
341 		if (inrate < outrate)
342 			continue;
343 
344 		ratio |= 1 << (IDEAL_RATIO_DECIMAL_DEPTH - i);
345 		inrate -= outrate;
346 
347 		if (!inrate)
348 			break;
349 	}
350 
351 	regmap_write(asrc->regmap, REG_ASRIDRL(index), ratio);
352 	regmap_write(asrc->regmap, REG_ASRIDRH(index), ratio >> 24);
353 
354 	return 0;
355 }
356 
357 /**
358  * fsl_asrc_config_pair - Configure the assigned ASRC pair
359  * @pair: pointer to pair
360  * @use_ideal_rate: boolean configuration
361  *
362  * It configures those ASRC registers according to a configuration instance
363  * of struct asrc_config which includes in/output sample rate, width, channel
364  * and clock settings.
365  *
366  * Note:
367  * The ideal ratio configuration can work with a flexible clock rate setting.
368  * Using IDEAL_RATIO_RATE gives a faster converting speed but overloads ASRC.
369  * For a regular audio playback, the clock rate should not be slower than an
370  * clock rate aligning with the output sample rate; For a use case requiring
371  * faster conversion, set use_ideal_rate to have the faster speed.
372  */
fsl_asrc_config_pair(struct fsl_asrc_pair * pair,bool use_ideal_rate)373 static int fsl_asrc_config_pair(struct fsl_asrc_pair *pair, bool use_ideal_rate)
374 {
375 	struct fsl_asrc_pair_priv *pair_priv = pair->private;
376 	struct asrc_config *config = pair_priv->config;
377 	struct fsl_asrc *asrc = pair->asrc;
378 	struct fsl_asrc_priv *asrc_priv = asrc->private;
379 	enum asrc_pair_index index = pair->index;
380 	enum asrc_word_width input_word_width;
381 	enum asrc_word_width output_word_width;
382 	u32 inrate, outrate, indiv, outdiv;
383 	u32 clk_index[2], div[2];
384 	u64 clk_rate;
385 	int in, out, channels;
386 	int pre_proc, post_proc;
387 	struct clk *clk;
388 	bool ideal, div_avail;
389 
390 	if (!config) {
391 		pair_err("invalid pair config\n");
392 		return -EINVAL;
393 	}
394 
395 	/* Validate channels */
396 	if (config->channel_num < 1 || config->channel_num > 10) {
397 		pair_err("does not support %d channels\n", config->channel_num);
398 		return -EINVAL;
399 	}
400 
401 	switch (snd_pcm_format_width(config->input_format)) {
402 	case 8:
403 		input_word_width = ASRC_WIDTH_8_BIT;
404 		break;
405 	case 16:
406 		input_word_width = ASRC_WIDTH_16_BIT;
407 		break;
408 	case 24:
409 		input_word_width = ASRC_WIDTH_24_BIT;
410 		break;
411 	default:
412 		pair_err("does not support this input format, %d\n",
413 			 config->input_format);
414 		return -EINVAL;
415 	}
416 
417 	switch (snd_pcm_format_width(config->output_format)) {
418 	case 16:
419 		output_word_width = ASRC_WIDTH_16_BIT;
420 		break;
421 	case 24:
422 		output_word_width = ASRC_WIDTH_24_BIT;
423 		break;
424 	default:
425 		pair_err("does not support this output format, %d\n",
426 			 config->output_format);
427 		return -EINVAL;
428 	}
429 
430 	inrate = config->input_sample_rate;
431 	outrate = config->output_sample_rate;
432 	ideal = config->inclk == INCLK_NONE;
433 
434 	/* Validate input and output sample rates */
435 	for (in = 0; in < ARRAY_SIZE(supported_asrc_rate); in++)
436 		if (inrate == supported_asrc_rate[in])
437 			break;
438 
439 	if (in == ARRAY_SIZE(supported_asrc_rate)) {
440 		pair_err("unsupported input sample rate: %dHz\n", inrate);
441 		return -EINVAL;
442 	}
443 
444 	for (out = 0; out < ARRAY_SIZE(supported_asrc_rate); out++)
445 		if (outrate == supported_asrc_rate[out])
446 			break;
447 
448 	if (out == ARRAY_SIZE(supported_asrc_rate)) {
449 		pair_err("unsupported output sample rate: %dHz\n", outrate);
450 		return -EINVAL;
451 	}
452 
453 	if ((outrate >= 5512 && outrate <= 30000) &&
454 	    (outrate > 24 * inrate || inrate > 8 * outrate)) {
455 		pair_err("exceed supported ratio range [1/24, 8] for \
456 				inrate/outrate: %d/%d\n", inrate, outrate);
457 		return -EINVAL;
458 	}
459 
460 	/* Validate input and output clock sources */
461 	clk_index[IN] = asrc_priv->clk_map[IN][config->inclk];
462 	clk_index[OUT] = asrc_priv->clk_map[OUT][config->outclk];
463 
464 	/* We only have output clock for ideal ratio mode */
465 	clk = asrc_priv->asrck_clk[clk_index[ideal ? OUT : IN]];
466 
467 	clk_rate = clk_get_rate(clk);
468 	div_avail = fsl_asrc_divider_avail(clk_rate, inrate, &div[IN]);
469 
470 	/*
471 	 * The divider range is [1, 1024], defined by the hardware. For non-
472 	 * ideal ratio configuration, clock rate has to be strictly aligned
473 	 * with the sample rate. For ideal ratio configuration, clock rates
474 	 * only result in different converting speeds. So remainder does not
475 	 * matter, as long as we keep the divider within its valid range.
476 	 */
477 	if (div[IN] == 0 || (!ideal && !div_avail)) {
478 		pair_err("failed to support input sample rate %dHz by asrck_%x\n",
479 				inrate, clk_index[ideal ? OUT : IN]);
480 		return -EINVAL;
481 	}
482 
483 	div[IN] = min_t(u32, 1024, div[IN]);
484 
485 	clk = asrc_priv->asrck_clk[clk_index[OUT]];
486 	clk_rate = clk_get_rate(clk);
487 	if (ideal && use_ideal_rate)
488 		div_avail = fsl_asrc_divider_avail(clk_rate, IDEAL_RATIO_RATE, &div[OUT]);
489 	else
490 		div_avail = fsl_asrc_divider_avail(clk_rate, outrate, &div[OUT]);
491 
492 	/* Output divider has the same limitation as the input one */
493 	if (div[OUT] == 0 || (!ideal && !div_avail)) {
494 		pair_err("failed to support output sample rate %dHz by asrck_%x\n",
495 				outrate, clk_index[OUT]);
496 		return -EINVAL;
497 	}
498 
499 	div[OUT] = min_t(u32, 1024, div[OUT]);
500 
501 	/* Set the channel number */
502 	channels = config->channel_num;
503 
504 	if (asrc_priv->soc->channel_bits < 4)
505 		channels /= 2;
506 
507 	/* Update channels for current pair */
508 	regmap_update_bits(asrc->regmap, REG_ASRCNCR,
509 			   ASRCNCR_ANCi_MASK(index, asrc_priv->soc->channel_bits),
510 			   ASRCNCR_ANCi(index, channels, asrc_priv->soc->channel_bits));
511 
512 	/* Default setting: Automatic selection for processing mode */
513 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
514 			   ASRCTR_ATSi_MASK(index), ASRCTR_ATS(index));
515 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
516 			   ASRCTR_USRi_MASK(index), 0);
517 
518 	/* Set the input and output clock sources */
519 	regmap_update_bits(asrc->regmap, REG_ASRCSR,
520 			   ASRCSR_AICSi_MASK(index) | ASRCSR_AOCSi_MASK(index),
521 			   ASRCSR_AICS(index, clk_index[IN]) |
522 			   ASRCSR_AOCS(index, clk_index[OUT]));
523 
524 	/* Calculate the input clock divisors */
525 	indiv = fsl_asrc_cal_asrck_divisor(pair, div[IN]);
526 	outdiv = fsl_asrc_cal_asrck_divisor(pair, div[OUT]);
527 
528 	/* Suppose indiv and outdiv includes prescaler, so add its MASK too */
529 	regmap_update_bits(asrc->regmap, REG_ASRCDR(index),
530 			   ASRCDRi_AOCPi_MASK(index) | ASRCDRi_AICPi_MASK(index) |
531 			   ASRCDRi_AOCDi_MASK(index) | ASRCDRi_AICDi_MASK(index),
532 			   ASRCDRi_AOCP(index, outdiv) | ASRCDRi_AICP(index, indiv));
533 
534 	/* Implement word_width configurations */
535 	regmap_update_bits(asrc->regmap, REG_ASRMCR1(index),
536 			   ASRMCR1i_OW16_MASK | ASRMCR1i_IWD_MASK,
537 			   ASRMCR1i_OW16(output_word_width) |
538 			   ASRMCR1i_IWD(input_word_width));
539 
540 	/* Enable BUFFER STALL */
541 	regmap_update_bits(asrc->regmap, REG_ASRMCR(index),
542 			   ASRMCRi_BUFSTALLi_MASK, ASRMCRi_BUFSTALLi);
543 
544 	/* Set default thresholds for input and output FIFO */
545 	fsl_asrc_set_watermarks(pair, ASRC_INPUTFIFO_THRESHOLD,
546 				ASRC_INPUTFIFO_THRESHOLD);
547 
548 	/* Configure the following only for Ideal Ratio mode */
549 	if (!ideal)
550 		return 0;
551 
552 	/* Clear ASTSx bit to use Ideal Ratio mode */
553 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
554 			   ASRCTR_ATSi_MASK(index), 0);
555 
556 	/* Enable Ideal Ratio mode */
557 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
558 			   ASRCTR_IDRi_MASK(index) | ASRCTR_USRi_MASK(index),
559 			   ASRCTR_IDR(index) | ASRCTR_USR(index));
560 
561 	fsl_asrc_sel_proc(inrate, outrate, &pre_proc, &post_proc);
562 
563 	/* Apply configurations for pre- and post-processing */
564 	regmap_update_bits(asrc->regmap, REG_ASRCFG,
565 			   ASRCFG_PREMODi_MASK(index) |	ASRCFG_POSTMODi_MASK(index),
566 			   ASRCFG_PREMOD(index, pre_proc) |
567 			   ASRCFG_POSTMOD(index, post_proc));
568 
569 	return fsl_asrc_set_ideal_ratio(pair, inrate, outrate);
570 }
571 
572 /**
573  * fsl_asrc_start_pair - Start the assigned ASRC pair
574  * @pair: pointer to pair
575  *
576  * It enables the assigned pair and makes it stopped at the stall level.
577  */
fsl_asrc_start_pair(struct fsl_asrc_pair * pair)578 static void fsl_asrc_start_pair(struct fsl_asrc_pair *pair)
579 {
580 	struct fsl_asrc *asrc = pair->asrc;
581 	enum asrc_pair_index index = pair->index;
582 	int reg, retry = 10, i;
583 
584 	/* Enable the current pair */
585 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
586 			   ASRCTR_ASRCEi_MASK(index), ASRCTR_ASRCE(index));
587 
588 	/* Wait for status of initialization */
589 	do {
590 		udelay(5);
591 		regmap_read(asrc->regmap, REG_ASRCFG, &reg);
592 		reg &= ASRCFG_INIRQi_MASK(index);
593 	} while (!reg && --retry);
594 
595 	/* Make the input fifo to ASRC STALL level */
596 	regmap_read(asrc->regmap, REG_ASRCNCR, &reg);
597 	for (i = 0; i < pair->channels * 4; i++)
598 		regmap_write(asrc->regmap, REG_ASRDI(index), 0);
599 
600 	/* Enable overload interrupt */
601 	regmap_write(asrc->regmap, REG_ASRIER, ASRIER_AOLIE);
602 }
603 
604 /**
605  * fsl_asrc_stop_pair - Stop the assigned ASRC pair
606  * @pair: pointer to pair
607  */
fsl_asrc_stop_pair(struct fsl_asrc_pair * pair)608 static void fsl_asrc_stop_pair(struct fsl_asrc_pair *pair)
609 {
610 	struct fsl_asrc *asrc = pair->asrc;
611 	enum asrc_pair_index index = pair->index;
612 
613 	/* Stop the current pair */
614 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
615 			   ASRCTR_ASRCEi_MASK(index), 0);
616 }
617 
618 /**
619  * fsl_asrc_get_dma_channel- Get DMA channel according to the pair and direction.
620  * @pair: pointer to pair
621  * @dir: DMA direction
622  */
fsl_asrc_get_dma_channel(struct fsl_asrc_pair * pair,bool dir)623 static struct dma_chan *fsl_asrc_get_dma_channel(struct fsl_asrc_pair *pair,
624 						 bool dir)
625 {
626 	struct fsl_asrc *asrc = pair->asrc;
627 	enum asrc_pair_index index = pair->index;
628 	char name[4];
629 
630 	sprintf(name, "%cx%c", dir == IN ? 'r' : 't', index + 'a');
631 
632 	return dma_request_slave_channel(&asrc->pdev->dev, name);
633 }
634 
fsl_asrc_dai_startup(struct snd_pcm_substream * substream,struct snd_soc_dai * dai)635 static int fsl_asrc_dai_startup(struct snd_pcm_substream *substream,
636 				struct snd_soc_dai *dai)
637 {
638 	struct fsl_asrc *asrc = snd_soc_dai_get_drvdata(dai);
639 	struct fsl_asrc_priv *asrc_priv = asrc->private;
640 
641 	/* Odd channel number is not valid for older ASRC (channel_bits==3) */
642 	if (asrc_priv->soc->channel_bits == 3)
643 		snd_pcm_hw_constraint_step(substream->runtime, 0,
644 					   SNDRV_PCM_HW_PARAM_CHANNELS, 2);
645 
646 
647 	return snd_pcm_hw_constraint_list(substream->runtime, 0,
648 			SNDRV_PCM_HW_PARAM_RATE, &fsl_asrc_rate_constraints);
649 }
650 
651 /* Select proper clock source for internal ratio mode */
fsl_asrc_select_clk(struct fsl_asrc_priv * asrc_priv,struct fsl_asrc_pair * pair,int in_rate,int out_rate)652 static void fsl_asrc_select_clk(struct fsl_asrc_priv *asrc_priv,
653 				struct fsl_asrc_pair *pair,
654 				int in_rate,
655 				int out_rate)
656 {
657 	struct fsl_asrc_pair_priv *pair_priv = pair->private;
658 	struct asrc_config *config = pair_priv->config;
659 	int rate[2], select_clk[2]; /* Array size 2 means IN and OUT */
660 	int clk_rate, clk_index;
661 	int i, j;
662 
663 	rate[IN] = in_rate;
664 	rate[OUT] = out_rate;
665 
666 	/* Select proper clock source for internal ratio mode */
667 	for (j = 0; j < 2; j++) {
668 		for (i = 0; i < ASRC_CLK_MAP_LEN; i++) {
669 			clk_index = asrc_priv->clk_map[j][i];
670 			clk_rate = clk_get_rate(asrc_priv->asrck_clk[clk_index]);
671 			/* Only match a perfect clock source with no remainder */
672 			if (fsl_asrc_divider_avail(clk_rate, rate[j], NULL))
673 				break;
674 		}
675 
676 		select_clk[j] = i;
677 	}
678 
679 	/* Switch to ideal ratio mode if there is no proper clock source */
680 	if (select_clk[IN] == ASRC_CLK_MAP_LEN || select_clk[OUT] == ASRC_CLK_MAP_LEN) {
681 		select_clk[IN] = INCLK_NONE;
682 		select_clk[OUT] = OUTCLK_ASRCK1_CLK;
683 	}
684 
685 	config->inclk = select_clk[IN];
686 	config->outclk = select_clk[OUT];
687 }
688 
fsl_asrc_dai_hw_params(struct snd_pcm_substream * substream,struct snd_pcm_hw_params * params,struct snd_soc_dai * dai)689 static int fsl_asrc_dai_hw_params(struct snd_pcm_substream *substream,
690 				  struct snd_pcm_hw_params *params,
691 				  struct snd_soc_dai *dai)
692 {
693 	struct fsl_asrc *asrc = snd_soc_dai_get_drvdata(dai);
694 	struct fsl_asrc_priv *asrc_priv = asrc->private;
695 	struct snd_pcm_runtime *runtime = substream->runtime;
696 	struct fsl_asrc_pair *pair = runtime->private_data;
697 	struct fsl_asrc_pair_priv *pair_priv = pair->private;
698 	unsigned int channels = params_channels(params);
699 	unsigned int rate = params_rate(params);
700 	struct asrc_config config;
701 	int ret;
702 
703 	ret = fsl_asrc_request_pair(channels, pair);
704 	if (ret) {
705 		dev_err(dai->dev, "fail to request asrc pair\n");
706 		return ret;
707 	}
708 
709 	pair_priv->config = &config;
710 
711 	config.pair = pair->index;
712 	config.channel_num = channels;
713 
714 	if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
715 		config.input_format   = params_format(params);
716 		config.output_format  = asrc->asrc_format;
717 		config.input_sample_rate  = rate;
718 		config.output_sample_rate = asrc->asrc_rate;
719 	} else {
720 		config.input_format   = asrc->asrc_format;
721 		config.output_format  = params_format(params);
722 		config.input_sample_rate  = asrc->asrc_rate;
723 		config.output_sample_rate = rate;
724 	}
725 
726 	fsl_asrc_select_clk(asrc_priv, pair,
727 			    config.input_sample_rate,
728 			    config.output_sample_rate);
729 
730 	ret = fsl_asrc_config_pair(pair, false);
731 	if (ret) {
732 		dev_err(dai->dev, "fail to config asrc pair\n");
733 		return ret;
734 	}
735 
736 	return 0;
737 }
738 
fsl_asrc_dai_hw_free(struct snd_pcm_substream * substream,struct snd_soc_dai * dai)739 static int fsl_asrc_dai_hw_free(struct snd_pcm_substream *substream,
740 				struct snd_soc_dai *dai)
741 {
742 	struct snd_pcm_runtime *runtime = substream->runtime;
743 	struct fsl_asrc_pair *pair = runtime->private_data;
744 
745 	if (pair)
746 		fsl_asrc_release_pair(pair);
747 
748 	return 0;
749 }
750 
fsl_asrc_dai_trigger(struct snd_pcm_substream * substream,int cmd,struct snd_soc_dai * dai)751 static int fsl_asrc_dai_trigger(struct snd_pcm_substream *substream, int cmd,
752 				struct snd_soc_dai *dai)
753 {
754 	struct snd_pcm_runtime *runtime = substream->runtime;
755 	struct fsl_asrc_pair *pair = runtime->private_data;
756 
757 	switch (cmd) {
758 	case SNDRV_PCM_TRIGGER_START:
759 	case SNDRV_PCM_TRIGGER_RESUME:
760 	case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
761 		fsl_asrc_start_pair(pair);
762 		break;
763 	case SNDRV_PCM_TRIGGER_STOP:
764 	case SNDRV_PCM_TRIGGER_SUSPEND:
765 	case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
766 		fsl_asrc_stop_pair(pair);
767 		break;
768 	default:
769 		return -EINVAL;
770 	}
771 
772 	return 0;
773 }
774 
775 static const struct snd_soc_dai_ops fsl_asrc_dai_ops = {
776 	.startup      = fsl_asrc_dai_startup,
777 	.hw_params    = fsl_asrc_dai_hw_params,
778 	.hw_free      = fsl_asrc_dai_hw_free,
779 	.trigger      = fsl_asrc_dai_trigger,
780 };
781 
fsl_asrc_dai_probe(struct snd_soc_dai * dai)782 static int fsl_asrc_dai_probe(struct snd_soc_dai *dai)
783 {
784 	struct fsl_asrc *asrc = snd_soc_dai_get_drvdata(dai);
785 
786 	snd_soc_dai_init_dma_data(dai, &asrc->dma_params_tx,
787 				  &asrc->dma_params_rx);
788 
789 	return 0;
790 }
791 
792 #define FSL_ASRC_FORMATS	(SNDRV_PCM_FMTBIT_S24_LE | \
793 				 SNDRV_PCM_FMTBIT_S16_LE | \
794 				 SNDRV_PCM_FMTBIT_S24_3LE)
795 
796 static struct snd_soc_dai_driver fsl_asrc_dai = {
797 	.probe = fsl_asrc_dai_probe,
798 	.playback = {
799 		.stream_name = "ASRC-Playback",
800 		.channels_min = 1,
801 		.channels_max = 10,
802 		.rate_min = 5512,
803 		.rate_max = 192000,
804 		.rates = SNDRV_PCM_RATE_KNOT,
805 		.formats = FSL_ASRC_FORMATS |
806 			   SNDRV_PCM_FMTBIT_S8,
807 	},
808 	.capture = {
809 		.stream_name = "ASRC-Capture",
810 		.channels_min = 1,
811 		.channels_max = 10,
812 		.rate_min = 5512,
813 		.rate_max = 192000,
814 		.rates = SNDRV_PCM_RATE_KNOT,
815 		.formats = FSL_ASRC_FORMATS,
816 	},
817 	.ops = &fsl_asrc_dai_ops,
818 };
819 
fsl_asrc_readable_reg(struct device * dev,unsigned int reg)820 static bool fsl_asrc_readable_reg(struct device *dev, unsigned int reg)
821 {
822 	switch (reg) {
823 	case REG_ASRCTR:
824 	case REG_ASRIER:
825 	case REG_ASRCNCR:
826 	case REG_ASRCFG:
827 	case REG_ASRCSR:
828 	case REG_ASRCDR1:
829 	case REG_ASRCDR2:
830 	case REG_ASRSTR:
831 	case REG_ASRPM1:
832 	case REG_ASRPM2:
833 	case REG_ASRPM3:
834 	case REG_ASRPM4:
835 	case REG_ASRPM5:
836 	case REG_ASRTFR1:
837 	case REG_ASRCCR:
838 	case REG_ASRDOA:
839 	case REG_ASRDOB:
840 	case REG_ASRDOC:
841 	case REG_ASRIDRHA:
842 	case REG_ASRIDRLA:
843 	case REG_ASRIDRHB:
844 	case REG_ASRIDRLB:
845 	case REG_ASRIDRHC:
846 	case REG_ASRIDRLC:
847 	case REG_ASR76K:
848 	case REG_ASR56K:
849 	case REG_ASRMCRA:
850 	case REG_ASRFSTA:
851 	case REG_ASRMCRB:
852 	case REG_ASRFSTB:
853 	case REG_ASRMCRC:
854 	case REG_ASRFSTC:
855 	case REG_ASRMCR1A:
856 	case REG_ASRMCR1B:
857 	case REG_ASRMCR1C:
858 		return true;
859 	default:
860 		return false;
861 	}
862 }
863 
fsl_asrc_volatile_reg(struct device * dev,unsigned int reg)864 static bool fsl_asrc_volatile_reg(struct device *dev, unsigned int reg)
865 {
866 	switch (reg) {
867 	case REG_ASRSTR:
868 	case REG_ASRDIA:
869 	case REG_ASRDIB:
870 	case REG_ASRDIC:
871 	case REG_ASRDOA:
872 	case REG_ASRDOB:
873 	case REG_ASRDOC:
874 	case REG_ASRFSTA:
875 	case REG_ASRFSTB:
876 	case REG_ASRFSTC:
877 	case REG_ASRCFG:
878 		return true;
879 	default:
880 		return false;
881 	}
882 }
883 
fsl_asrc_writeable_reg(struct device * dev,unsigned int reg)884 static bool fsl_asrc_writeable_reg(struct device *dev, unsigned int reg)
885 {
886 	switch (reg) {
887 	case REG_ASRCTR:
888 	case REG_ASRIER:
889 	case REG_ASRCNCR:
890 	case REG_ASRCFG:
891 	case REG_ASRCSR:
892 	case REG_ASRCDR1:
893 	case REG_ASRCDR2:
894 	case REG_ASRSTR:
895 	case REG_ASRPM1:
896 	case REG_ASRPM2:
897 	case REG_ASRPM3:
898 	case REG_ASRPM4:
899 	case REG_ASRPM5:
900 	case REG_ASRTFR1:
901 	case REG_ASRCCR:
902 	case REG_ASRDIA:
903 	case REG_ASRDIB:
904 	case REG_ASRDIC:
905 	case REG_ASRIDRHA:
906 	case REG_ASRIDRLA:
907 	case REG_ASRIDRHB:
908 	case REG_ASRIDRLB:
909 	case REG_ASRIDRHC:
910 	case REG_ASRIDRLC:
911 	case REG_ASR76K:
912 	case REG_ASR56K:
913 	case REG_ASRMCRA:
914 	case REG_ASRMCRB:
915 	case REG_ASRMCRC:
916 	case REG_ASRMCR1A:
917 	case REG_ASRMCR1B:
918 	case REG_ASRMCR1C:
919 		return true;
920 	default:
921 		return false;
922 	}
923 }
924 
925 static struct reg_default fsl_asrc_reg[] = {
926 	{ REG_ASRCTR, 0x0000 }, { REG_ASRIER, 0x0000 },
927 	{ REG_ASRCNCR, 0x0000 }, { REG_ASRCFG, 0x0000 },
928 	{ REG_ASRCSR, 0x0000 }, { REG_ASRCDR1, 0x0000 },
929 	{ REG_ASRCDR2, 0x0000 }, { REG_ASRSTR, 0x0000 },
930 	{ REG_ASRRA, 0x0000 }, { REG_ASRRB, 0x0000 },
931 	{ REG_ASRRC, 0x0000 }, { REG_ASRPM1, 0x0000 },
932 	{ REG_ASRPM2, 0x0000 }, { REG_ASRPM3, 0x0000 },
933 	{ REG_ASRPM4, 0x0000 }, { REG_ASRPM5, 0x0000 },
934 	{ REG_ASRTFR1, 0x0000 }, { REG_ASRCCR, 0x0000 },
935 	{ REG_ASRDIA, 0x0000 }, { REG_ASRDOA, 0x0000 },
936 	{ REG_ASRDIB, 0x0000 }, { REG_ASRDOB, 0x0000 },
937 	{ REG_ASRDIC, 0x0000 }, { REG_ASRDOC, 0x0000 },
938 	{ REG_ASRIDRHA, 0x0000 }, { REG_ASRIDRLA, 0x0000 },
939 	{ REG_ASRIDRHB, 0x0000 }, { REG_ASRIDRLB, 0x0000 },
940 	{ REG_ASRIDRHC, 0x0000 }, { REG_ASRIDRLC, 0x0000 },
941 	{ REG_ASR76K, 0x0A47 }, { REG_ASR56K, 0x0DF3 },
942 	{ REG_ASRMCRA, 0x0000 }, { REG_ASRFSTA, 0x0000 },
943 	{ REG_ASRMCRB, 0x0000 }, { REG_ASRFSTB, 0x0000 },
944 	{ REG_ASRMCRC, 0x0000 }, { REG_ASRFSTC, 0x0000 },
945 	{ REG_ASRMCR1A, 0x0000 }, { REG_ASRMCR1B, 0x0000 },
946 	{ REG_ASRMCR1C, 0x0000 },
947 };
948 
949 static const struct regmap_config fsl_asrc_regmap_config = {
950 	.reg_bits = 32,
951 	.reg_stride = 4,
952 	.val_bits = 32,
953 
954 	.max_register = REG_ASRMCR1C,
955 	.reg_defaults = fsl_asrc_reg,
956 	.num_reg_defaults = ARRAY_SIZE(fsl_asrc_reg),
957 	.readable_reg = fsl_asrc_readable_reg,
958 	.volatile_reg = fsl_asrc_volatile_reg,
959 	.writeable_reg = fsl_asrc_writeable_reg,
960 	.cache_type = REGCACHE_FLAT,
961 };
962 
963 /**
964  * fsl_asrc_init - Initialize ASRC registers with a default configuration
965  * @asrc: ASRC context
966  */
fsl_asrc_init(struct fsl_asrc * asrc)967 static int fsl_asrc_init(struct fsl_asrc *asrc)
968 {
969 	unsigned long ipg_rate;
970 
971 	/* Halt ASRC internal FP when input FIFO needs data for pair A, B, C */
972 	regmap_write(asrc->regmap, REG_ASRCTR, ASRCTR_ASRCEN);
973 
974 	/* Disable interrupt by default */
975 	regmap_write(asrc->regmap, REG_ASRIER, 0x0);
976 
977 	/* Apply recommended settings for parameters from Reference Manual */
978 	regmap_write(asrc->regmap, REG_ASRPM1, 0x7fffff);
979 	regmap_write(asrc->regmap, REG_ASRPM2, 0x255555);
980 	regmap_write(asrc->regmap, REG_ASRPM3, 0xff7280);
981 	regmap_write(asrc->regmap, REG_ASRPM4, 0xff7280);
982 	regmap_write(asrc->regmap, REG_ASRPM5, 0xff7280);
983 
984 	/* Base address for task queue FIFO. Set to 0x7C */
985 	regmap_update_bits(asrc->regmap, REG_ASRTFR1,
986 			   ASRTFR1_TF_BASE_MASK, ASRTFR1_TF_BASE(0xfc));
987 
988 	/*
989 	 * Set the period of the 76KHz and 56KHz sampling clocks based on
990 	 * the ASRC processing clock.
991 	 * On iMX6, ipg_clk = 133MHz, REG_ASR76K = 0x06D6, REG_ASR56K = 0x0947
992 	 */
993 	ipg_rate = clk_get_rate(asrc->ipg_clk);
994 	regmap_write(asrc->regmap, REG_ASR76K, ipg_rate / 76000);
995 	return regmap_write(asrc->regmap, REG_ASR56K, ipg_rate / 56000);
996 }
997 
998 /**
999  * fsl_asrc_isr- Interrupt handler for ASRC
1000  * @irq: irq number
1001  * @dev_id: ASRC context
1002  */
fsl_asrc_isr(int irq,void * dev_id)1003 static irqreturn_t fsl_asrc_isr(int irq, void *dev_id)
1004 {
1005 	struct fsl_asrc *asrc = (struct fsl_asrc *)dev_id;
1006 	struct device *dev = &asrc->pdev->dev;
1007 	enum asrc_pair_index index;
1008 	u32 status;
1009 
1010 	regmap_read(asrc->regmap, REG_ASRSTR, &status);
1011 
1012 	/* Clean overload error */
1013 	regmap_write(asrc->regmap, REG_ASRSTR, ASRSTR_AOLE);
1014 
1015 	/*
1016 	 * We here use dev_dbg() for all exceptions because ASRC itself does
1017 	 * not care if FIFO overflowed or underrun while a warning in the
1018 	 * interrupt would result a ridged conversion.
1019 	 */
1020 	for (index = ASRC_PAIR_A; index < ASRC_PAIR_MAX_NUM; index++) {
1021 		if (!asrc->pair[index])
1022 			continue;
1023 
1024 		if (status & ASRSTR_ATQOL) {
1025 			asrc->pair[index]->error |= ASRC_TASK_Q_OVERLOAD;
1026 			dev_dbg(dev, "ASRC Task Queue FIFO overload\n");
1027 		}
1028 
1029 		if (status & ASRSTR_AOOL(index)) {
1030 			asrc->pair[index]->error |= ASRC_OUTPUT_TASK_OVERLOAD;
1031 			pair_dbg("Output Task Overload\n");
1032 		}
1033 
1034 		if (status & ASRSTR_AIOL(index)) {
1035 			asrc->pair[index]->error |= ASRC_INPUT_TASK_OVERLOAD;
1036 			pair_dbg("Input Task Overload\n");
1037 		}
1038 
1039 		if (status & ASRSTR_AODO(index)) {
1040 			asrc->pair[index]->error |= ASRC_OUTPUT_BUFFER_OVERFLOW;
1041 			pair_dbg("Output Data Buffer has overflowed\n");
1042 		}
1043 
1044 		if (status & ASRSTR_AIDU(index)) {
1045 			asrc->pair[index]->error |= ASRC_INPUT_BUFFER_UNDERRUN;
1046 			pair_dbg("Input Data Buffer has underflowed\n");
1047 		}
1048 	}
1049 
1050 	return IRQ_HANDLED;
1051 }
1052 
fsl_asrc_get_fifo_addr(u8 dir,enum asrc_pair_index index)1053 static int fsl_asrc_get_fifo_addr(u8 dir, enum asrc_pair_index index)
1054 {
1055 	return REG_ASRDx(dir, index);
1056 }
1057 
1058 static int fsl_asrc_runtime_resume(struct device *dev);
1059 static int fsl_asrc_runtime_suspend(struct device *dev);
1060 
fsl_asrc_probe(struct platform_device * pdev)1061 static int fsl_asrc_probe(struct platform_device *pdev)
1062 {
1063 	struct device_node *np = pdev->dev.of_node;
1064 	struct fsl_asrc_priv *asrc_priv;
1065 	struct fsl_asrc *asrc;
1066 	struct resource *res;
1067 	void __iomem *regs;
1068 	int irq, ret, i;
1069 	u32 asrc_fmt = 0;
1070 	u32 map_idx;
1071 	char tmp[16];
1072 	u32 width;
1073 
1074 	asrc = devm_kzalloc(&pdev->dev, sizeof(*asrc), GFP_KERNEL);
1075 	if (!asrc)
1076 		return -ENOMEM;
1077 
1078 	asrc_priv = devm_kzalloc(&pdev->dev, sizeof(*asrc_priv), GFP_KERNEL);
1079 	if (!asrc_priv)
1080 		return -ENOMEM;
1081 
1082 	asrc->pdev = pdev;
1083 	asrc->private = asrc_priv;
1084 
1085 	/* Get the addresses and IRQ */
1086 	regs = devm_platform_get_and_ioremap_resource(pdev, 0, &res);
1087 	if (IS_ERR(regs))
1088 		return PTR_ERR(regs);
1089 
1090 	asrc->paddr = res->start;
1091 
1092 	asrc->regmap = devm_regmap_init_mmio(&pdev->dev, regs, &fsl_asrc_regmap_config);
1093 	if (IS_ERR(asrc->regmap)) {
1094 		dev_err(&pdev->dev, "failed to init regmap\n");
1095 		return PTR_ERR(asrc->regmap);
1096 	}
1097 
1098 	irq = platform_get_irq(pdev, 0);
1099 	if (irq < 0)
1100 		return irq;
1101 
1102 	ret = devm_request_irq(&pdev->dev, irq, fsl_asrc_isr, 0,
1103 			       dev_name(&pdev->dev), asrc);
1104 	if (ret) {
1105 		dev_err(&pdev->dev, "failed to claim irq %u: %d\n", irq, ret);
1106 		return ret;
1107 	}
1108 
1109 	asrc->mem_clk = devm_clk_get(&pdev->dev, "mem");
1110 	if (IS_ERR(asrc->mem_clk)) {
1111 		dev_err(&pdev->dev, "failed to get mem clock\n");
1112 		return PTR_ERR(asrc->mem_clk);
1113 	}
1114 
1115 	asrc->ipg_clk = devm_clk_get(&pdev->dev, "ipg");
1116 	if (IS_ERR(asrc->ipg_clk)) {
1117 		dev_err(&pdev->dev, "failed to get ipg clock\n");
1118 		return PTR_ERR(asrc->ipg_clk);
1119 	}
1120 
1121 	asrc->spba_clk = devm_clk_get(&pdev->dev, "spba");
1122 	if (IS_ERR(asrc->spba_clk))
1123 		dev_warn(&pdev->dev, "failed to get spba clock\n");
1124 
1125 	for (i = 0; i < ASRC_CLK_MAX_NUM; i++) {
1126 		sprintf(tmp, "asrck_%x", i);
1127 		asrc_priv->asrck_clk[i] = devm_clk_get(&pdev->dev, tmp);
1128 		if (IS_ERR(asrc_priv->asrck_clk[i])) {
1129 			dev_err(&pdev->dev, "failed to get %s clock\n", tmp);
1130 			return PTR_ERR(asrc_priv->asrck_clk[i]);
1131 		}
1132 	}
1133 
1134 	asrc_priv->soc = of_device_get_match_data(&pdev->dev);
1135 	asrc->use_edma = asrc_priv->soc->use_edma;
1136 	asrc->get_dma_channel = fsl_asrc_get_dma_channel;
1137 	asrc->request_pair = fsl_asrc_request_pair;
1138 	asrc->release_pair = fsl_asrc_release_pair;
1139 	asrc->get_fifo_addr = fsl_asrc_get_fifo_addr;
1140 	asrc->pair_priv_size = sizeof(struct fsl_asrc_pair_priv);
1141 
1142 	if (of_device_is_compatible(np, "fsl,imx35-asrc")) {
1143 		asrc_priv->clk_map[IN] = input_clk_map_imx35;
1144 		asrc_priv->clk_map[OUT] = output_clk_map_imx35;
1145 	} else if (of_device_is_compatible(np, "fsl,imx53-asrc")) {
1146 		asrc_priv->clk_map[IN] = input_clk_map_imx53;
1147 		asrc_priv->clk_map[OUT] = output_clk_map_imx53;
1148 	} else if (of_device_is_compatible(np, "fsl,imx8qm-asrc") ||
1149 		   of_device_is_compatible(np, "fsl,imx8qxp-asrc")) {
1150 		ret = of_property_read_u32(np, "fsl,asrc-clk-map", &map_idx);
1151 		if (ret) {
1152 			dev_err(&pdev->dev, "failed to get clk map index\n");
1153 			return ret;
1154 		}
1155 
1156 		if (map_idx > 1) {
1157 			dev_err(&pdev->dev, "unsupported clk map index\n");
1158 			return -EINVAL;
1159 		}
1160 		if (of_device_is_compatible(np, "fsl,imx8qm-asrc")) {
1161 			asrc_priv->clk_map[IN] = clk_map_imx8qm[map_idx];
1162 			asrc_priv->clk_map[OUT] = clk_map_imx8qm[map_idx];
1163 		} else {
1164 			asrc_priv->clk_map[IN] = clk_map_imx8qxp[map_idx];
1165 			asrc_priv->clk_map[OUT] = clk_map_imx8qxp[map_idx];
1166 		}
1167 	}
1168 
1169 	asrc->channel_avail = 10;
1170 
1171 	ret = of_property_read_u32(np, "fsl,asrc-rate",
1172 				   &asrc->asrc_rate);
1173 	if (ret) {
1174 		dev_err(&pdev->dev, "failed to get output rate\n");
1175 		return ret;
1176 	}
1177 
1178 	ret = of_property_read_u32(np, "fsl,asrc-format", &asrc_fmt);
1179 	asrc->asrc_format = (__force snd_pcm_format_t)asrc_fmt;
1180 	if (ret) {
1181 		ret = of_property_read_u32(np, "fsl,asrc-width", &width);
1182 		if (ret) {
1183 			dev_err(&pdev->dev, "failed to decide output format\n");
1184 			return ret;
1185 		}
1186 
1187 		switch (width) {
1188 		case 16:
1189 			asrc->asrc_format = SNDRV_PCM_FORMAT_S16_LE;
1190 			break;
1191 		case 24:
1192 			asrc->asrc_format = SNDRV_PCM_FORMAT_S24_LE;
1193 			break;
1194 		default:
1195 			dev_warn(&pdev->dev,
1196 				 "unsupported width, use default S24_LE\n");
1197 			asrc->asrc_format = SNDRV_PCM_FORMAT_S24_LE;
1198 			break;
1199 		}
1200 	}
1201 
1202 	if (!(FSL_ASRC_FORMATS & pcm_format_to_bits(asrc->asrc_format))) {
1203 		dev_warn(&pdev->dev, "unsupported width, use default S24_LE\n");
1204 		asrc->asrc_format = SNDRV_PCM_FORMAT_S24_LE;
1205 	}
1206 
1207 	platform_set_drvdata(pdev, asrc);
1208 	spin_lock_init(&asrc->lock);
1209 	pm_runtime_enable(&pdev->dev);
1210 	if (!pm_runtime_enabled(&pdev->dev)) {
1211 		ret = fsl_asrc_runtime_resume(&pdev->dev);
1212 		if (ret)
1213 			goto err_pm_disable;
1214 	}
1215 
1216 	ret = pm_runtime_get_sync(&pdev->dev);
1217 	if (ret < 0) {
1218 		pm_runtime_put_noidle(&pdev->dev);
1219 		goto err_pm_get_sync;
1220 	}
1221 
1222 	ret = fsl_asrc_init(asrc);
1223 	if (ret) {
1224 		dev_err(&pdev->dev, "failed to init asrc %d\n", ret);
1225 		goto err_pm_get_sync;
1226 	}
1227 
1228 	ret = pm_runtime_put_sync(&pdev->dev);
1229 	if (ret < 0 && ret != -ENOSYS)
1230 		goto err_pm_get_sync;
1231 
1232 	ret = devm_snd_soc_register_component(&pdev->dev, &fsl_asrc_component,
1233 					      &fsl_asrc_dai, 1);
1234 	if (ret) {
1235 		dev_err(&pdev->dev, "failed to register ASoC DAI\n");
1236 		goto err_pm_get_sync;
1237 	}
1238 
1239 	return 0;
1240 
1241 err_pm_get_sync:
1242 	if (!pm_runtime_status_suspended(&pdev->dev))
1243 		fsl_asrc_runtime_suspend(&pdev->dev);
1244 err_pm_disable:
1245 	pm_runtime_disable(&pdev->dev);
1246 	return ret;
1247 }
1248 
fsl_asrc_remove(struct platform_device * pdev)1249 static int fsl_asrc_remove(struct platform_device *pdev)
1250 {
1251 	pm_runtime_disable(&pdev->dev);
1252 	if (!pm_runtime_status_suspended(&pdev->dev))
1253 		fsl_asrc_runtime_suspend(&pdev->dev);
1254 
1255 	return 0;
1256 }
1257 
fsl_asrc_runtime_resume(struct device * dev)1258 static int fsl_asrc_runtime_resume(struct device *dev)
1259 {
1260 	struct fsl_asrc *asrc = dev_get_drvdata(dev);
1261 	struct fsl_asrc_priv *asrc_priv = asrc->private;
1262 	int i, ret;
1263 	u32 asrctr;
1264 
1265 	ret = clk_prepare_enable(asrc->mem_clk);
1266 	if (ret)
1267 		return ret;
1268 	ret = clk_prepare_enable(asrc->ipg_clk);
1269 	if (ret)
1270 		goto disable_mem_clk;
1271 	if (!IS_ERR(asrc->spba_clk)) {
1272 		ret = clk_prepare_enable(asrc->spba_clk);
1273 		if (ret)
1274 			goto disable_ipg_clk;
1275 	}
1276 	for (i = 0; i < ASRC_CLK_MAX_NUM; i++) {
1277 		ret = clk_prepare_enable(asrc_priv->asrck_clk[i]);
1278 		if (ret)
1279 			goto disable_asrck_clk;
1280 	}
1281 
1282 	/* Stop all pairs provisionally */
1283 	regmap_read(asrc->regmap, REG_ASRCTR, &asrctr);
1284 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
1285 			   ASRCTR_ASRCEi_ALL_MASK, 0);
1286 
1287 	/* Restore all registers */
1288 	regcache_cache_only(asrc->regmap, false);
1289 	regcache_mark_dirty(asrc->regmap);
1290 	regcache_sync(asrc->regmap);
1291 
1292 	regmap_update_bits(asrc->regmap, REG_ASRCFG,
1293 			   ASRCFG_NDPRi_ALL_MASK | ASRCFG_POSTMODi_ALL_MASK |
1294 			   ASRCFG_PREMODi_ALL_MASK, asrc_priv->regcache_cfg);
1295 
1296 	/* Restart enabled pairs */
1297 	regmap_update_bits(asrc->regmap, REG_ASRCTR,
1298 			   ASRCTR_ASRCEi_ALL_MASK, asrctr);
1299 
1300 	return 0;
1301 
1302 disable_asrck_clk:
1303 	for (i--; i >= 0; i--)
1304 		clk_disable_unprepare(asrc_priv->asrck_clk[i]);
1305 	if (!IS_ERR(asrc->spba_clk))
1306 		clk_disable_unprepare(asrc->spba_clk);
1307 disable_ipg_clk:
1308 	clk_disable_unprepare(asrc->ipg_clk);
1309 disable_mem_clk:
1310 	clk_disable_unprepare(asrc->mem_clk);
1311 	return ret;
1312 }
1313 
fsl_asrc_runtime_suspend(struct device * dev)1314 static int fsl_asrc_runtime_suspend(struct device *dev)
1315 {
1316 	struct fsl_asrc *asrc = dev_get_drvdata(dev);
1317 	struct fsl_asrc_priv *asrc_priv = asrc->private;
1318 	int i;
1319 
1320 	regmap_read(asrc->regmap, REG_ASRCFG,
1321 		    &asrc_priv->regcache_cfg);
1322 
1323 	regcache_cache_only(asrc->regmap, true);
1324 
1325 	for (i = 0; i < ASRC_CLK_MAX_NUM; i++)
1326 		clk_disable_unprepare(asrc_priv->asrck_clk[i]);
1327 	if (!IS_ERR(asrc->spba_clk))
1328 		clk_disable_unprepare(asrc->spba_clk);
1329 	clk_disable_unprepare(asrc->ipg_clk);
1330 	clk_disable_unprepare(asrc->mem_clk);
1331 
1332 	return 0;
1333 }
1334 
1335 static const struct dev_pm_ops fsl_asrc_pm = {
1336 	SET_RUNTIME_PM_OPS(fsl_asrc_runtime_suspend, fsl_asrc_runtime_resume, NULL)
1337 	SET_SYSTEM_SLEEP_PM_OPS(pm_runtime_force_suspend,
1338 				pm_runtime_force_resume)
1339 };
1340 
1341 static const struct fsl_asrc_soc_data fsl_asrc_imx35_data = {
1342 	.use_edma = false,
1343 	.channel_bits = 3,
1344 };
1345 
1346 static const struct fsl_asrc_soc_data fsl_asrc_imx53_data = {
1347 	.use_edma = false,
1348 	.channel_bits = 4,
1349 };
1350 
1351 static const struct fsl_asrc_soc_data fsl_asrc_imx8qm_data = {
1352 	.use_edma = true,
1353 	.channel_bits = 4,
1354 };
1355 
1356 static const struct fsl_asrc_soc_data fsl_asrc_imx8qxp_data = {
1357 	.use_edma = true,
1358 	.channel_bits = 4,
1359 };
1360 
1361 static const struct of_device_id fsl_asrc_ids[] = {
1362 	{ .compatible = "fsl,imx35-asrc", .data = &fsl_asrc_imx35_data },
1363 	{ .compatible = "fsl,imx53-asrc", .data = &fsl_asrc_imx53_data },
1364 	{ .compatible = "fsl,imx8qm-asrc", .data = &fsl_asrc_imx8qm_data },
1365 	{ .compatible = "fsl,imx8qxp-asrc", .data = &fsl_asrc_imx8qxp_data },
1366 	{}
1367 };
1368 MODULE_DEVICE_TABLE(of, fsl_asrc_ids);
1369 
1370 static struct platform_driver fsl_asrc_driver = {
1371 	.probe = fsl_asrc_probe,
1372 	.remove = fsl_asrc_remove,
1373 	.driver = {
1374 		.name = "fsl-asrc",
1375 		.of_match_table = fsl_asrc_ids,
1376 		.pm = &fsl_asrc_pm,
1377 	},
1378 };
1379 module_platform_driver(fsl_asrc_driver);
1380 
1381 MODULE_DESCRIPTION("Freescale ASRC ASoC driver");
1382 MODULE_AUTHOR("Nicolin Chen <nicoleotsuka@gmail.com>");
1383 MODULE_ALIAS("platform:fsl-asrc");
1384 MODULE_LICENSE("GPL v2");
1385