[alsa-devel] [RFC v2 PATCH] ASoC: wm8904: add CCF support

Luis Alberto Sanchez luisalbertosanchez3 at gmail.com
Tue Mar 25 13:09:17 CET 2014


El mar 25, 2014 7:59 AM, "Boris BREZILLON" <b.brezillon.dev at gmail.com>
escribió:

> Hello Bo,
>
> Le 25/03/2014 10:56, Bo Shen a écrit :
>
>> Enable WM8904 to support common clock framework.
>>    - Now it supports use SoC provided clock or external oscillator
>>      as MCLK.
>>
>> Signed-off-by: Bo Shen <voice.shen at atmel.com>
>> ---
>>   Documentation/devicetree/bindings/sound/wm8904.txt | 48
>> ++++++++++++++++++++++
>>   sound/soc/codecs/wm8904.c                          | 17 ++++++++
>>   2 files changed, 65 insertions(+)
>>   create mode 100644 Documentation/devicetree/bindings/sound/wm8904.txt
>>
>> diff --git a/Documentation/devicetree/bindings/sound/wm8904.txt
>> b/Documentation/devicetree/bindings/sound/wm8904.txt
>> new file mode 100644
>> index 0000000..bcf4aa0
>> --- /dev/null
>> +++ b/Documentation/devicetree/bindings/sound/wm8904.txt
>> @@ -0,0 +1,48 @@
>> +WM8904 audio CODEC
>> +
>> +This device supports I2C only.
>> +
>> +Required properties:
>> +  - compatible: "wlf,wm8904"
>> +  - reg: the I2C address of the device.
>> +  - clocks and clock-names: reference to
>> +    <Documentation/devicetree/bindings/clock/clock-bindings.txt>
>> +
>> +Pins on the device (for linking into audio routes):
>> +
>> +  * IN1L
>> +  * IN1R
>> +  * IN2L
>> +  * IN2R
>> +  * IN3L
>> +  * IN3R
>> +  * HPOUTL
>> +  * HPOUTR
>> +  * LINEOUTL
>> +  * LINEOUTR
>> +  * MICBIAS
>> +
>> +Examples:
>> +
>> +1. Using SoC provided clock as mclk:
>> +codec: wm8904 at 1a {
>> +       compatible = "wlf,wm8904";
>> +       reg = <0x1a>;
>> +       clocks = <&pck0>;
>> +       clock-names = "mclk";
>> +};
>>
>
>
>  +
>> +2. Using external oscillator as mclk:
>> +codec: wm8904 at 1a {
>> +       compatible = "wlf,wm8904";
>> +       reg = <0x1a>;
>> +
>> +       wm8904_osc {
>> +               compatible = "fixed-clock";
>> +               #clock-cells = <0>;
>> +               #clock-frequency = <12000000>;
>> +       }
>> +
>> +       clocks = <&wm8904_osc>;
>> +       clock-names = "mclk";
>> +};
>>
>
> I think there is a misunderstanding here (and it certainly comes from my
> explanations during our last talk :)): both cases should be handled the
> same
> way because an external oscillator is no more or less than an external clk
> (we don't care how this clk is generated).
>
> I suggested to put the osc node inside the wm8904 one but I thought you
> were
> trying to represent the internal 12MHz clk generated when using the fll
> free
> running mode.
>
>  diff --git a/sound/soc/codecs/wm8904.c b/sound/soc/codecs/wm8904.c
>> index 49c35c3..4db6a26 100644
>> --- a/sound/soc/codecs/wm8904.c
>> +++ b/sound/soc/codecs/wm8904.c
>> @@ -11,6 +11,7 @@
>>    * published by the Free Software Foundation.
>>    */
>>   +#include <linux/clk.h>
>>   #include <linux/module.h>
>>   #include <linux/moduleparam.h>
>>   #include <linux/init.h>
>> @@ -49,6 +50,7 @@ static const char *wm8904_supply_names[WM8904_NUM_SUPPLIES]
>> = {
>>   /* codec private data */
>>   struct wm8904_priv {
>>         struct regmap *regmap;
>> +       struct clk *mclk;
>>         enum wm8904_type devtype;
>>   @@ -1828,6 +1830,9 @@ static int wm8904_set_bias_level(struct
>> snd_soc_codec *codec,
>>         switch (level) {
>>         case SND_SOC_BIAS_ON:
>> +               if (IS_ENABLED(CONFIG_COMMON_CLK))
>> +                       if (wm8904->mclk)
>> +                               clk_prepare_enable(wm8904->mclk);
>>                 break;
>>         case SND_SOC_BIAS_PREPARE:
>> @@ -1894,6 +1899,9 @@ static int wm8904_set_bias_level(struct
>> snd_soc_codec *codec,
>>                 regulator_bulk_disable(ARRAY_SIZE(wm8904->supplies),
>>                                        wm8904->supplies);
>> +               if (IS_ENABLED(CONFIG_COMMON_CLK))
>> +                       if (wm8904->mclk)
>> +                               clk_disable_unprepare(wm8904->mclk);
>>                 break;
>>         }
>>         codec->dapm.bias_level = level;
>> @@ -2139,6 +2147,15 @@ static int wm8904_i2c_probe(struct i2c_client *i2c,
>>                 return ret;
>>         }
>>   +     if (IS_ENABLED(CONFIG_COMMON_CLK)) {
>> +               wm8904->mclk = devm_clk_get(&i2c->dev, "mclk");
>> +               if (IS_ERR(wm8904->mclk)) {
>> +                       dev_err(&i2c->dev, "Failed to get MCLK\n");
>> +                       ret = PTR_ERR(wm8904->mclk);
>> +                       goto err_enable;
>> +               }
>> +       }
>> +
>>         ret = regmap_read(wm8904->regmap, WM8904_SW_RESET_AND_ID, &val);
>>         if (ret < 0) {
>>                 dev_err(&i2c->dev, "Failed to read ID register: %d\n",
>> ret);
>>
>
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel at alsa-project.org
> http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
>


More information about the Alsa-devel mailing list