Commit ab023374 authored by Kuninori Morimoto's avatar Kuninori Morimoto Committed by Mark Brown

ASoC: rsnd: remove default division of clock out

Current adg has default division for BRRA/BRRB, but it was created at
very beginning of the driver implementation, and is now an unnecessary
settings.

Because it has this default division, unexpected clockout might
be selected. For example if it requests only 44.1kHz base clockout,
unrequested 48kHz base clockout also will be selected.

This patch remove default division of clock out
Reported-by: default avatarVincenzo De Michele <vincenzo.michele@davinci.de>
Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Link: https://lore.kernel.org/r/87il96zlep.wl-kuninori.morimoto.gx@renesas.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 80d4984f
...@@ -485,7 +485,6 @@ static int rsnd_adg_get_clkout(struct rsnd_priv *priv) ...@@ -485,7 +485,6 @@ static int rsnd_adg_get_clkout(struct rsnd_priv *priv)
struct device_node *np = dev->of_node; struct device_node *np = dev->of_node;
struct property *prop; struct property *prop;
u32 ckr, brgx, brga, brgb; u32 ckr, brgx, brga, brgb;
u32 rate, div;
u32 req_rate[ADG_HZ_SIZE] = {}; u32 req_rate[ADG_HZ_SIZE] = {};
uint32_t count = 0; uint32_t count = 0;
unsigned long req_Hz[ADG_HZ_SIZE]; unsigned long req_Hz[ADG_HZ_SIZE];
...@@ -559,6 +558,8 @@ static int rsnd_adg_get_clkout(struct rsnd_priv *priv) ...@@ -559,6 +558,8 @@ static int rsnd_adg_get_clkout(struct rsnd_priv *priv)
* clock-frequency = <22579200 24576000>; * clock-frequency = <22579200 24576000>;
*/ */
for_each_rsnd_clkin(clk, adg, i) { for_each_rsnd_clkin(clk, adg, i) {
u32 rate, div;
rate = clk_get_rate(clk); rate = clk_get_rate(clk);
if (0 == rate) /* not used */ if (0 == rate) /* not used */
...@@ -569,10 +570,8 @@ static int rsnd_adg_get_clkout(struct rsnd_priv *priv) ...@@ -569,10 +570,8 @@ static int rsnd_adg_get_clkout(struct rsnd_priv *priv)
if (i == CLKI) if (i == CLKI)
/* see [APPROXIMATE] */ /* see [APPROXIMATE] */
rate = (clk_get_rate(clk) / req_Hz[ADG_HZ_441]) * req_Hz[ADG_HZ_441]; rate = (clk_get_rate(clk) / req_Hz[ADG_HZ_441]) * req_Hz[ADG_HZ_441];
if (!adg->brg_rate[ADG_HZ_441] && (0 == rate % 44100)) { if (!adg->brg_rate[ADG_HZ_441] && req_Hz[ADG_HZ_441] && (0 == rate % 44100)) {
div = 6; div = rate / req_Hz[ADG_HZ_441];
if (req_Hz[ADG_HZ_441])
div = rate / req_Hz[ADG_HZ_441];
brgx = rsnd_adg_calculate_brgx(div); brgx = rsnd_adg_calculate_brgx(div);
if (BRRx_MASK(brgx) == brgx) { if (BRRx_MASK(brgx) == brgx) {
brga = brgx; brga = brgx;
...@@ -590,10 +589,8 @@ static int rsnd_adg_get_clkout(struct rsnd_priv *priv) ...@@ -590,10 +589,8 @@ static int rsnd_adg_get_clkout(struct rsnd_priv *priv)
if (i == CLKI) if (i == CLKI)
/* see [APPROXIMATE] */ /* see [APPROXIMATE] */
rate = (clk_get_rate(clk) / req_Hz[ADG_HZ_48]) * req_Hz[ADG_HZ_48]; rate = (clk_get_rate(clk) / req_Hz[ADG_HZ_48]) * req_Hz[ADG_HZ_48];
if (!adg->brg_rate[ADG_HZ_48] && (0 == rate % 48000)) { if (!adg->brg_rate[ADG_HZ_48] && req_Hz[ADG_HZ_48] && (0 == rate % 48000)) {
div = 6; div = rate / req_Hz[ADG_HZ_48];
if (req_Hz[ADG_HZ_48])
div = rate / req_Hz[ADG_HZ_48];
brgx = rsnd_adg_calculate_brgx(div); brgx = rsnd_adg_calculate_brgx(div);
if (BRRx_MASK(brgx) == brgx) { if (BRRx_MASK(brgx) == brgx) {
brgb = brgx; brgb = brgx;
......
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