[alsa-devel] [PATCH v5 1/5] ASoC: codecs: Add msm8916-wcd analog codec

Rob Herring robh at kernel.org
Fri Sep 16 17:41:51 CEST 2016


On Thu, Sep 08, 2016 at 02:04:52PM +0100, Srinivas Kandagatla wrote:
> msm8916-wcd codec is found in Qualcomm msm8916 and apq8016 processors.
> This codec IP is split in to two parts (Digital & Analog).
> Analog part is integrated in to PMIC PM8916 and the digital part is
> integrated into Application processor. Data transfer between Analog and
> Digital Die is done via a internal bus called PDM.
> 
> This patch adds support to Analog part of the Codec which is integrated
> into PMIC PM8916.
> 
> Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla at linaro.org>
> ---
>  .../bindings/sound/qcom,msm8916-wcd-analog.txt     |  83 ++
>  sound/soc/codecs/Kconfig                           |   4 +
>  sound/soc/codecs/Makefile                          |   3 +-
>  sound/soc/codecs/msm8916-wcd-analog.c              | 888 +++++++++++++++++++++
>  4 files changed, 977 insertions(+), 1 deletion(-)
>  create mode 100644 Documentation/devicetree/bindings/sound/qcom,msm8916-wcd-analog.txt
>  create mode 100644 sound/soc/codecs/msm8916-wcd-analog.c
> 
> diff --git a/Documentation/devicetree/bindings/sound/qcom,msm8916-wcd-analog.txt b/Documentation/devicetree/bindings/sound/qcom,msm8916-wcd-analog.txt
> new file mode 100644
> index 0000000..f426c06
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/sound/qcom,msm8916-wcd-analog.txt
> @@ -0,0 +1,83 @@
> +msm8916 analog audio CODEC
> +
> +Bindings for codec Analog IP which is integrated in pmic pm8916,
> +
> +## Bindings for codec core on pmic:
> +
> +Required properties
> + - compatible = "qcom,msm8916-wcd-analog-codec";
> + - reg: represents the slave base address provided to the peripheral.
> + - interrupt-parent : The parent interrupt controller.
> + - interrupts: List of interrupts in given SPMI peripheral.
> + - interrupt-names: Names specified to above list of interrupts in same
> +		    order. List of supported interrupt names are:
> +  "cdc_spk_cnp_int" - Speaker click and pop interrupt.
> +  "cdc_spk_clip_int" - Speaker clip interrupt.
> +  "cdc_spk_ocp_int" - Speaker over current protect interrupt.
> +  "mbhc_ins_rem_det1" - jack insert removal detect interrupt 1.
> +  "mbhc_but_rel_det" - button release interrupt.
> +  "mbhc_but_press_det" - button press event
> +  "mbhc_ins_rem_det" - jack insert removal detect interrupt.
> +  "mbhc_switch_int"	- multi button headset interrupt.
> +  "cdc_ear_ocp_int" - Earphone over current protect interrupt.
> +  "cdc_hphr_ocp_int" - Headphone R over current protect interrupt.
> +  "cdc_hphl_ocp_det" - Headphone L over current protect interrupt.
> +  "cdc_ear_cnp_int" - earphone cnp interrupt.
> +  "cdc_hphr_cnp_int" - hphr click and pop interrupt.
> +  "cdc_hphl_cnp_int" - hphl click and pop interrupt.
> +
> + - clocks: Handle to mclk.
> + - clock-names: should be "mclk".
> + - VDD-CDC-IO-supply: phandle to VDD_CDC_IO regulator device tree node.
> + - VDD-CDC-TX-RX-CX-supply: phandle to VDD_CDC_TX/RX/CX regulator device tree node.
> + - VDD-MICBIAS-supply: phandle of VDD_MICBIAS supply's regulator device tree node.

Lowercase please.

> +
> +Optional Properties:
> +- qcom,micbias1-ext-cap: present if micbias1 has external capacitor connected.
> +- qcom,micbias2-ext-cap: present if micbias2 has external capacitor connected.

Explicitly state these are bool.

> +
> +Example:
> +
> +spmi_bus {
> +	...
> +	msm8916_wcd_codec at f000{

audio-codec at ...

> +		compatible = "qcom,msm8916-wcd-analog-codec";
> +		reg = <0xf000 0x200>;
> +		reg-names = "pmic-codec-core";
> +		clocks = <&gcc GCC_CODEC_DIGCODEC_CLK>;
> +		clock-names = "mclk";
> +		interrupt-parent = <&spmi_bus>;
> +		interrupts = <0x1 0xf0 0x0 IRQ_TYPE_NONE>,
> +			     <0x1 0xf0 0x1 IRQ_TYPE_NONE>,
> +			     <0x1 0xf0 0x2 IRQ_TYPE_NONE>,
> +			     <0x1 0xf0 0x3 IRQ_TYPE_NONE>,
> +			     <0x1 0xf0 0x4 IRQ_TYPE_NONE>,
> +			     <0x1 0xf0 0x5 IRQ_TYPE_NONE>,
> +			     <0x1 0xf0 0x6 IRQ_TYPE_NONE>,
> +			     <0x1 0xf0 0x7 IRQ_TYPE_NONE>,
> +			     <0x1 0xf1 0x0 IRQ_TYPE_NONE>,
> +			     <0x1 0xf1 0x1 IRQ_TYPE_NONE>,
> +			     <0x1 0xf1 0x2 IRQ_TYPE_NONE>,
> +			     <0x1 0xf1 0x3 IRQ_TYPE_NONE>,
> +			     <0x1 0xf1 0x4 IRQ_TYPE_NONE>,
> +			     <0x1 0xf1 0x5 IRQ_TYPE_NONE>;
> +		interrupt-names = "cdc_spk_cnp_int",
> +				  "cdc_spk_clip_int",
> +				  "cdc_spk_ocp_int",
> +				  "mbhc_ins_rem_det1",
> +				  "mbhc_but_rel_det",
> +				  "mbhc_but_press_det",
> +				  "mbhc_ins_rem_det",
> +				  "mbhc_switch_int",
> +				  "cdc_ear_ocp_int",
> +				  "cdc_hphr_ocp_int",
> +				  "cdc_hphl_ocp_det",
> +				  "cdc_ear_cnp_int",
> +				  "cdc_hphr_cnp_int",
> +				  "cdc_hphl_cnp_int";
> +	               VDD-CDC-IO-supply = <&pm8916_l5>;
> +	               VDD-CDC-TX-RX-CX-supply = <&pm8916_l5>;
> +	               VDD-MICBIAS-supply = <&pm8916_l13>;
> +	               #sound-dai-cells = <1>;
> +	};
> +};


More information about the Alsa-devel mailing list