ASoC: rsnd: adg :: AUDIO-CLKOUTn asynchronizes support
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Thu, 9 Jun 2016 03:21:37 +0000 (03:21 +0000)
committerMark Brown <broonie@kernel.org>
Thu, 9 Jun 2016 10:40:43 +0000 (11:40 +0100)
AUDIO-CLKOUTn can asynchronizes with L/R clock.
AUDIO-CLKOUTn synchronizes with L/R clock is now default behavior.

Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
Documentation/devicetree/bindings/sound/renesas,rsnd.txt
sound/soc/sh/rcar/adg.c

index c7b29df4a96353735f23d75576f284d8f16aa649..15a7316e4c913c837fc8f03358c94a466447fe38 100644 (file)
@@ -373,6 +373,8 @@ Optional properties:
 - #clock-cells                 : it must be 0 if your system has audio_clkout
                                  it must be 1 if your system has audio_clkout0/1/2/3
 - clock-frequency              : for all audio_clkout0/1/2/3
+- clkout-lr-asynchronous       : boolean property. it indicates that audio_clkoutn
+                                 is asynchronizes with lr-clock.
 
 SSI subnode properties:
 - interrupts                   : Should contain SSI interrupt for PIO transfer
index 49354d17ea553795e45f7f04e4603429dbca70f1..7d3e0e46d64a0866e8156d1ed1640c27afc730e3 100644 (file)
@@ -33,11 +33,15 @@ struct rsnd_adg {
        struct clk *clkout[CLKOUTMAX];
        struct clk_onecell_data onecell;
        struct rsnd_mod mod;
+       u32 flags;
 
        int rbga_rate_for_441khz; /* RBGA */
        int rbgb_rate_for_48khz;  /* RBGB */
 };
 
+#define LRCLK_ASYNC    (1 << 0)
+#define adg_mode_flags(adg)    (adg->flags)
+
 #define for_each_rsnd_clk(pos, adg, i)         \
        for (i = 0;                             \
             (i < CLKMAX) &&                    \
@@ -355,6 +359,16 @@ found_clock:
 
        rsnd_adg_set_ssi_clk(ssi_mod, data);
 
+       if (!(adg_mode_flags(adg) & LRCLK_ASYNC)) {
+               struct rsnd_mod *adg_mod = rsnd_mod_get(adg);
+               u32 ckr = 0;
+
+               if (0 == (rate % 8000))
+                       ckr = 0x80000000;
+
+               rsnd_mod_bset(adg_mod, SSICKR, 0x80000000, ckr);
+       }
+
        dev_dbg(dev, "ADG: %s[%d] selects 0x%x for %d\n",
                rsnd_mod_name(ssi_mod), rsnd_mod_id(ssi_mod),
                data, rate);
@@ -532,6 +546,7 @@ int rsnd_adg_probe(struct rsnd_priv *priv)
 {
        struct rsnd_adg *adg;
        struct device *dev = rsnd_priv_to_dev(priv);
+       struct device_node *np = dev->of_node;
 
        adg = devm_kzalloc(dev, sizeof(*adg), GFP_KERNEL);
        if (!adg) {
@@ -545,6 +560,9 @@ int rsnd_adg_probe(struct rsnd_priv *priv)
        rsnd_adg_get_clkin(priv, adg);
        rsnd_adg_get_clkout(priv, adg);
 
+       if (of_get_property(np, "clkout-lr-asynchronous", NULL))
+               adg->flags = LRCLK_ASYNC;
+
        priv->adg = adg;
 
        return 0;