Commit 518f6bab authored by Jyri Sarha's avatar Jyri Sarha Committed by Mark Brown

ASoC: davinci-macsp: Optimize implicit BLCK sample-rate rule

There is no need to copy the list of all supported sample-rates.
Finding the supported endpoints within the current range is enough
(see snd_interval_list()).
Signed-off-by: default avatarJyri Sarha <jsarha@ti.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent 5935a056
...@@ -1023,27 +1023,35 @@ static int davinci_mcasp_hw_rule_rate(struct snd_pcm_hw_params *params, ...@@ -1023,27 +1023,35 @@ static int davinci_mcasp_hw_rule_rate(struct snd_pcm_hw_params *params,
hw_param_interval(params, SNDRV_PCM_HW_PARAM_RATE); hw_param_interval(params, SNDRV_PCM_HW_PARAM_RATE);
int sbits = params_width(params); int sbits = params_width(params);
int slots = rd->mcasp->tdm_slots; int slots = rd->mcasp->tdm_slots;
unsigned int list[ARRAY_SIZE(davinci_mcasp_dai_rates)]; struct snd_interval range;
int i, count = 0; int i;
snd_interval_any(&range);
range.empty = 1;
for (i = 0; i < ARRAY_SIZE(davinci_mcasp_dai_rates); i++) { for (i = 0; i < ARRAY_SIZE(davinci_mcasp_dai_rates); i++) {
if (ri->min <= davinci_mcasp_dai_rates[i] && if (snd_interval_test(ri, davinci_mcasp_dai_rates[i])) {
ri->max >= davinci_mcasp_dai_rates[i]) {
uint bclk_freq = sbits*slots* uint bclk_freq = sbits*slots*
davinci_mcasp_dai_rates[i]; davinci_mcasp_dai_rates[i];
int ppm; int ppm;
davinci_mcasp_calc_clk_div(rd->mcasp, bclk_freq, &ppm); davinci_mcasp_calc_clk_div(rd->mcasp, bclk_freq, &ppm);
if (abs(ppm) < DAVINCI_MAX_RATE_ERROR_PPM) if (abs(ppm) < DAVINCI_MAX_RATE_ERROR_PPM) {
list[count++] = davinci_mcasp_dai_rates[i]; if (range.empty) {
range.min = davinci_mcasp_dai_rates[i];
range.empty = 0;
} }
range.max = davinci_mcasp_dai_rates[i];
} }
}
}
dev_dbg(rd->mcasp->dev, dev_dbg(rd->mcasp->dev,
"%d frequencies (%d-%d) for %d sbits and %d tdm slots\n", "Frequencies %d-%d -> %d-%d for %d sbits and %d tdm slots\n",
count, ri->min, ri->max, sbits, slots); ri->min, ri->max, range.min, range.max, sbits, slots);
return snd_interval_list(hw_param_interval(params, rule->var), return snd_interval_refine(hw_param_interval(params, rule->var),
count, list, 0); &range);
} }
static int davinci_mcasp_hw_rule_format(struct snd_pcm_hw_params *params, static int davinci_mcasp_hw_rule_format(struct snd_pcm_hw_params *params,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment