[RFC PATCH 0/5] Flexible sysclk/pll configuration

Sameer Pujar spujar at nvidia.com
Fri Feb 26 06:24:48 CET 2021



On 2/25/2021 11:35 PM, Sameer Pujar wrote:
> This series attempts to add flexible system clock (sysclk) and pll
> configuration for the DAI controller from simple card or audio graph
> card.
>
> Sysclk configuration
> ====================
>    Motivation:
>    -----------
>      The problem this tries to address is, some Codecs may have
>      multiple clocks and multiple sources for its sysclk. For example
>      sysclk may depend on MCLK provided by SoC or it may used an
>      internal pll. The simple card or audio graph card driver is
>      generic and can be used on multiple platforms. So if a platform
>      using this driver needs a generic configuration, then the Codec
>      specific stuff cannot be hardcoded in the driver. Hence it would
>      be better if the info is driven from DT, especially from a
>      Codec DAI or endpoint subnode.
>
>    Solution:
>    ---------
>      "system-clock-id" and "system-clock-source" DT properties can be
>      exposed for a flexible sysclk configuration. These properties
>      go into a Codec DAI or endpoint subnode.
>
>      Please note that other sysclk related properties like
>      "system-clock-frequency" and "system-clock-direction-out" are
>      already present.
>
>      Currently snd_soc_dai_set_sysclk() does not have an argument
>      for source. This series adds this additional field and updates
>      all the required drivers. This is needed because ideally sysclk
>      "clk_id" and "source" fields are different. Some drivers are
>      making use of "clk_id" field to program source information.
>      **May be this needs to be corrected going ahead**
>
>
> Pll configuration
> =================
>    Motivation:
>    -----------
>      Similar to sysclk configuration, pll configuration also needs
>      little more flexibility. If a Codec has internal pll and it
>      can be sourced from multiple clocks a specific configuration
>      may be required for a given platform.
>
>      Some of the cases are:
>        - MCLK (supplied by SoC) --> Codec pll -> Codec sysclk
>        - SoC I2S bit clock (BCLK) --> Codec pll -> Codec sysclk
>
>    Solution:
>    ---------
>      Approach is similar to what is done for extending sysclk
>      flexibility. Following DT properties are added to address the
>      same.
>
>        "pll-id"
>        "pll-source"
>        "pll-input-reference"
>        "pll-output-reference"
>        "pll-input-frequency"
>        "pll-output-frequency"
>
>      All these are optional properties. Simple card or audio graph
>      card drivers can use above info and call snd_soc_dai_set_pll()
>      for necessary configuration.
>
> Sameer Pujar (5):
>    ASoC: soc-component: Fix return value of snd_soc_component_set_pll()
>    ASoC: soc-dai: Add sysclk source to snd_soc_dai_set_sysclk()
>    ASoC: audio-graph-card: Add bindings for sysclk and pll
>    ASoC: simple-card-utils: Parse sysclk id and source
>    ASoC: simple-card-utils: Support pll configuration
>
>   .../bindings/sound/audio-graph-port.yaml           |  71 +++++++++
>   include/sound/simple_card_utils.h                  |  35 +++++
>   include/sound/soc-dai.h                            |   4 +-
>   sound/soc/amd/acp-da7219-max98357a.c               |   2 +-
>   sound/soc/amd/acp-rt5645.c                         |   2 +-
>   sound/soc/amd/acp3x-rt5682-max9836.c               |   4 +-
>   sound/soc/atmel/atmel_wm8904.c                     |   2 +-
>   sound/soc/atmel/mchp-i2s-mcc.c                     |   2 +-

[...]

>   sound/soc/ti/omap-mcbsp.c                          |   2 +-
>   sound/soc/ti/omap3pandora.c                        |   4 +-
>   sound/soc/ti/rx51.c                                |   2 +-
>   sound/soc/uniphier/aio-cpu.c                       |   4 +-
>   sound/soc/ux500/ux500_msp_dai.c                    |   2 +-
>   271 files changed, 639 insertions(+), 389 deletions(-)
>

Looks like I missed some files to update which make use of 
snd_soc_dai_set_sysclk(). I will try to fix that. Meanwhile please 
review if the idea is right here.



More information about the Alsa-devel mailing list