ASoC: rsnd: fixup 6ch settings to 8ch
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Thu, 25 Apr 2019 06:16:58 +0000 (15:16 +0900)
committerMark Brown <broonie@kernel.org>
Thu, 25 Apr 2019 18:41:09 +0000 (19:41 +0100)
rsnd need to use 8ch clock settings for 6ch for TDM.
Otherwise, it can't work correctly.
This patch fixup it.

Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/sh/rcar/core.c
sound/soc/sh/rcar/rsnd.h
sound/soc/sh/rcar/ssi.c

index 4fe83e6..37cb615 100644 (file)
@@ -300,6 +300,18 @@ int rsnd_runtime_channel_after_ctu_with_params(struct rsnd_dai_stream *io,
        return chan;
 }
 
+int rsnd_channel_normalization(int chan)
+{
+       if ((chan > 8) || (chan < 0))
+               return 0;
+
+       /* TDM Extend Mode needs 8ch */
+       if (chan == 6)
+               chan = 8;
+
+       return chan;
+}
+
 int rsnd_runtime_channel_for_ssi_with_params(struct rsnd_dai_stream *io,
                                             struct snd_pcm_hw_params *params)
 {
@@ -312,11 +324,7 @@ int rsnd_runtime_channel_for_ssi_with_params(struct rsnd_dai_stream *io,
        if (rsnd_runtime_is_multi_ssi(io))
                chan /= rsnd_rdai_ssi_lane_get(rdai);
 
-       /* TDM Extend Mode needs 8ch */
-       if (chan == 6)
-               chan = 8;
-
-       return chan;
+       return rsnd_channel_normalization(chan);
 }
 
 int rsnd_runtime_is_multi_ssi(struct rsnd_dai_stream *io)
index 0e6ef4e..7727add 100644 (file)
@@ -446,6 +446,7 @@ void rsnd_parse_connect_common(struct rsnd_dai *rdai,
                struct device_node *playback,
                struct device_node *capture);
 
+int rsnd_channel_normalization(int chan);
 #define rsnd_runtime_channel_original(io) \
        rsnd_runtime_channel_original_with_params(io, NULL)
 int rsnd_runtime_channel_original_with_params(struct rsnd_dai_stream *io,
index f5afab6..44bda21 100644 (file)
@@ -303,6 +303,8 @@ static int rsnd_ssi_master_clk_start(struct rsnd_mod *mod,
        if (rsnd_runtime_is_tdm_split(io))
                chan = rsnd_io_converted_chan(io);
 
+       chan = rsnd_channel_normalization(chan);
+
        main_rate = rsnd_ssi_clk_query(rdai, rate, chan, &idx);
        if (!main_rate) {
                dev_err(dev, "unsupported clock rate\n");