From: Richard Fitzgerald <rf@opensource.cirrus.com>
To: <broonie@kernel.org>, <robh+dt@kernel.org>,
<kuninori.morimoto.gx@renesas.com>, <nsaenzjulienne@suse.de>
Cc: devicetree@vger.kernel.org, alsa-devel@alsa-project.org,
patches@opensource.cirrus.com, linux-kernel@vger.kernel.org,
Richard Fitzgerald <rf@opensource.cirrus.com>,
bcm-kernel-feedback-list@broadcom.com,
linux-rpi-kernel@lists.infradead.org,
linux-arm-kernel@lists.infradead.org
Subject: [PATCH v3 6/6] ARM: dts: Add dts for RPi4b + Cirrus Logic Lochnagar2 + CS47L15
Date: Thu, 17 Dec 2020 15:41:42 +0000 [thread overview]
Message-ID: <20201217154142.24301-7-rf@opensource.cirrus.com> (raw)
In-Reply-To: <20201217154142.24301-1-rf@opensource.cirrus.com>
This adds a devicetree configuration for Raspberry Pi 4b connected to
Cirrus Logic Lochnagar 2 audio development board and CS47L15 codec.
The common (codec-independent) Lochnagar 2 configuration is separated
into a dtsi to simplify re-using it for other codecs.
Signed-off-by: Richard Fitzgerald <rf@opensource.cirrus.com>
---
MAINTAINERS | 1 +
arch/arm/boot/dts/Makefile | 1 +
...bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts | 186 ++++++++++++++++
.../dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi | 201 ++++++++++++++++++
4 files changed, 389 insertions(+)
create mode 100644 arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
create mode 100644 arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
diff --git a/MAINTAINERS b/MAINTAINERS
index 5cc595ac7b28..7dca1db52144 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -4193,6 +4193,7 @@ M: Charles Keepax <ckeepax@opensource.cirrus.com>
M: Richard Fitzgerald <rf@opensource.cirrus.com>
L: patches@opensource.cirrus.com
S: Supported
+F: arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar*
F: Documentation/devicetree/bindings/clock/cirrus,lochnagar.yaml
F: Documentation/devicetree/bindings/hwmon/cirrus,lochnagar.yaml
F: Documentation/devicetree/bindings/mfd/cirrus,lochnagar.yaml
diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile
index ce66ffd5a1bb..240cc58fd954 100644
--- a/arch/arm/boot/dts/Makefile
+++ b/arch/arm/boot/dts/Makefile
@@ -93,6 +93,7 @@ dtb-$(CONFIG_ARCH_BCM2835) += \
bcm2837-rpi-3-b-plus.dtb \
bcm2837-rpi-cm3-io3.dtb \
bcm2711-rpi-4-b.dtb \
+ bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dtb \
bcm2835-rpi-zero.dtb \
bcm2835-rpi-zero-w.dtb
dtb-$(CONFIG_ARCH_BCM_5301X) += \
diff --git a/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
new file mode 100644
index 000000000000..b6b91289bc6f
--- /dev/null
+++ b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
@@ -0,0 +1,186 @@
+// SPDX-License-Identifier: GPL-2.0
+/dts-v1/;
+#include "bcm2711-rpi4b-cirrus-lochnagar.dtsi"
+#include <dt-bindings/sound/madera.h>
+
+/ {
+ sound {
+ status = "okay";
+
+ compatible = "audio-graph-card";
+ label = "sound-card-cs47l15";
+
+ clocks = <&clk_24m>, <&fll1_out>, <&fll1_dsp>;
+ clock-names = "ln-clk-24m", "fll1-out", "fll1-dsp";
+
+ plls = <
+ &cs47l15 MADERA_FLL1_REFCLK MADERA_FLL_SRC_MCLK1 98304000
+ >;
+ plls-clocks = "ln-clk-24m";
+
+ sysclks = <
+ &cs47l15 MADERA_CLK_SYSCLK_1 MADERA_CLK_SRC_FLL1 0
+ &cs47l15 MADERA_CLK_DSPCLK MADERA_CLK_SRC_FLL1 0
+ >;
+ sysclks-clocks = "fll1-out", "fll1-dsp";
+
+ widgets = "Microphone", "Microphone Jack",
+ "Headphone", "Headphone Jack";
+
+ routing = "Microphone Jack", "MICBIAS1A",
+ "IN1BRN", "Microphone Jack",
+ "IN1BRP", "Microphone Jack",
+ "Headphone Jack", "HPOUTL",
+ "Headphone Jack", "HPOUTR";
+
+ dais = <&cpu_i2s_port &cs47l15_trace_port>;
+
+ /* Main output from FLL1 */
+ fll1_out: fll1_out {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <98304000>;
+ };
+
+ /* x1.5 DSP output from FLL1 */
+ fll1_dsp: fll1_dsp {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <147456000>;
+ };
+ };
+};
+
+&i2s {
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ cpu_i2s_port: port@0 {
+ reg = <0>;
+ cpu_i2s_ep: endpoint {
+ remote-endpoint = <&cs47l15_aif1>;
+ dai-format = "i2s";
+ };
+ };
+ };
+};
+
+&spi {
+ status = "okay";
+
+ cs47l15: cs47l15@1 {
+ status = "okay";
+
+ compatible = "cirrus,cs47l15";
+ reg = <0x1>;
+
+ spi-max-frequency = <11000000>;
+
+ interrupts = <27 8>;
+ interrupt-controller;
+ #interrupt-cells = <2>;
+ interrupt-parent = <&gpio>;
+ gpio-controller;
+ #gpio-cells = <2>;
+ #sound-dai-cells = <1>;
+
+ AVDD-supply = <&lochnagar_vdd1v8>;
+ DCVDD-supply = <&lochnagar_vddcore>;
+ DBVDD1-supply = <&lochnagar_vdd1v8>;
+ CPVDD1-supply = <&lochnagar_vdd1v8>;
+ SPKVDD-supply = <&wallvdd>;
+ MICVDD-supply = <&lochnagar_micvdd>;
+
+ reset-gpios = <&lochnagar_pin 0 0>;
+
+ cirrus,dmic-ref = <
+ MADERA_DMIC_REF_MICBIAS1
+ >;
+ cirrus,inmode = <
+ MADERA_INMODE_SE MADERA_INMODE_SE /* IN1A */
+ MADERA_INMODE_DIFF MADERA_INMODE_DIFF /* IN1B */
+ MADERA_INMODE_SE MADERA_INMODE_SE /* IN2A */
+ MADERA_INMODE_DIFF MADERA_INMODE_DIFF /* IN2B */
+ >;
+
+ clocks = <&lochnagar_clk LOCHNAGAR_CDC_MCLK1>,
+ <&lochnagar_clk LOCHNAGAR_CDC_MCLK2>;
+ clock-names = "mclk1", "mclk2";
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&cdc_irq &cs47l15_defaults>;
+
+ cs47l15_defaults: cs47l15-gpio-defaults {
+ aif1 {
+ groups = "aif1";
+ function = "aif1";
+ bias-bus-hold;
+ };
+ aif2 {
+ groups = "aif2";
+ function = "aif2";
+ bias-bus-hold;
+ };
+ aif3 {
+ groups = "aif3";
+ function = "aif3";
+ bias-bus-hold;
+ };
+ pdmspk1 {
+ groups = "pdmspk1";
+ function = "pdmspk1";
+ };
+ };
+
+ micvdd {
+ regulator-min-microvolt = <3000000>;
+ regulator-max-microvolt = <3000000>;
+ };
+
+ MICBIAS1 {
+ regulator-min-microvolt = <2800000>;
+ regulator-max-microvolt = <2800000>;
+ };
+ MICBIAS1A {
+ regulator-active-discharge = <1>;
+ };
+ MICBIAS1B {
+ regulator-active-discharge = <1>;
+ };
+ MICBIAS1C {
+ regulator-active-discharge = <1>;
+ };
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ cs47l15_aif1_port: port@0 {
+ reg = <0>;
+ cs47l15_aif1: endpoint {
+ remote-endpoint = <&cpu_i2s_ep>;
+ bitclock-master;
+ frame-master;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ /* Debug trace compressed stream */
+ cs47l15_trace_port: port@3 {
+ reg = <3>;
+ cs47l15_trace_cpu: endpoint {
+ remote-endpoint = <&cs47l15_trace_codec>;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ port@4 {
+ reg = <4>;
+ cs47l15_trace_codec: endpoint {
+ remote-endpoint = <&cs47l15_trace_cpu>;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ };
+ };
+};
diff --git a/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
new file mode 100644
index 000000000000..af498d7ad18a
--- /dev/null
+++ b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
@@ -0,0 +1,201 @@
+// SPDX-License-Identifier: GPL-2.0
+/dts-v1/;
+#include "bcm2711-rpi-4-b.dts"
+#include <dt-bindings/clk/lochnagar.h>
+#include <dt-bindings/pinctrl/bcm2835.h>
+#include <dt-bindings/pinctrl/lochnagar.h>
+
+/ {
+ wallvdd: wallvdd@0 {
+ compatible = "regulator-fixed";
+
+ regulator-name = "WALL_VDD_5V";
+ regulator-min-microvolt = <5000000>;
+ regulator-max-microvolt = <5000000>;
+ regulator-boot-on;
+ regulator-always-on;
+ };
+
+};
+
+&gpio {
+ lochnagar_present: lochnagar_present {
+ brcm,pins = <22>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ lochnagar_reset: lochnagar_reset {
+ brcm,pins = <24>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ cdc_irq: cdc_irq {
+ brcm,pins = <27>;
+ brcm,function = <BCM2835_FSEL_GPIO_IN>;
+ };
+
+ spi_pins: spi_pins {
+ brcm,pins = <9 10 11>;
+ brcm,function = <BCM2835_FSEL_ALT0>;
+ };
+
+ spi_cs: spi_cs {
+ brcm,pins = <7 8>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ i2s_pins: i2s_pins {
+ brcm,pins = <18 19 20 21>;
+ brcm,function = <BCM2835_FSEL_ALT0>;
+ };
+};
+
+&i2s {
+ status = "okay";
+ #sound-dai-cells = <1>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&i2s_pins>;
+ dmas = <&dma 2>, <&dma 3>;
+ dma-names = "tx", "rx";
+};
+
+&i2c1 {
+ status = "okay";
+
+ lochnagar: lochnagar@22 {
+ status = "okay";
+
+ compatible = "cirrus,lochnagar2";
+ reg = <0x22>;
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&lochnagar_present &lochnagar_reset>;
+
+ reset-gpio = <&gpio 24 0>;
+ present-gpio = <&gpio 22 0>;
+
+ lochnagar_vdd1v8: VDD1V8 {
+ compatible = "regulator-fixed";
+
+ regulator-name = "VDD1V8";
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ regulator-boot-on;
+ regulator-always-on;
+
+ vin-supply = <&wallvdd>;
+ };
+
+ clk_pmic: clk_pmic {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <32768>;
+ };
+ clk_24m: clk_24m {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <24576000>;
+ };
+
+ lochnagar_clk: clk {
+ compatible = "cirrus,lochnagar2-clk";
+
+ #clock-cells = <1>;
+
+ clocks = <&clk_pmic>, <&clk_24m>;
+ clock-names = "ln-pmic-32k", "ln-clk-24m";
+
+ assigned-clocks = <&lochnagar_clk LOCHNAGAR_CDC_MCLK1>,
+ <&lochnagar_clk LOCHNAGAR_CDC_MCLK2>,
+ <&lochnagar_clk LOCHNAGAR_SOUNDCARD_MCLK>;
+ assigned-clock-parents = <&clk_24m>,
+ <&clk_pmic>,
+ <&clk_24m>;
+ };
+
+ lochnagar_pin: pin {
+ compatible = "cirrus,lochnagar-pinctrl";
+
+ gpio-controller;
+ #gpio-cells = <2>;
+ gpio-ranges = <&lochnagar_pin 0 0 LOCHNAGAR2_PIN_NUM_GPIOS>;
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&pin_settings>;
+
+ pin_settings: pin_settings {
+ rpi_aif {
+ input-enable;
+ groups = "gf-aif1";
+ function = "codec-aif1";
+ };
+ codec_aif1 {
+ output-master;
+ groups = "codec-aif1";
+ function = "gf-aif1";
+ };
+ sc_codec_aif {
+ output-enable;
+ groups = "codec-aif2";
+ function = "soundcard-aif";
+ };
+ sc_lochnagar_aif {
+ input-enable;
+ groups = "soundcard-aif";
+ function = "codec-aif2";
+ };
+ };
+ };
+
+ lochnagar_hwmon: hwmon {
+ compatible = "cirrus,lochnagar2-hwmon";
+ };
+
+ lochnagar_micvdd: MICVDD {
+ compatible = "cirrus,lochnagar2-micvdd";
+
+ SYSVDD-supply = <&wallvdd>;
+
+ regulator-min-microvolt = <3000000>;
+ regulator-max-microvolt = <3000000>;
+ };
+
+ MIC1VDD {
+ compatible = "cirrus,lochnagar2-mic1vdd";
+
+ regulator-always-on;
+ cirrus,micbias-input = <2>;
+ };
+
+ MIC2VDD {
+ compatible = "cirrus,lochnagar2-mic2vdd";
+
+ regulator-always-on;
+ cirrus,micbias-input = <3>;
+ };
+
+ lochnagar_vddcore: VDDCORE {
+ compatible = "cirrus,lochnagar2-vddcore";
+
+ SYSVDD-supply = <&wallvdd>;
+
+ regulator-min-microvolt = <1200000>;
+ regulator-max-microvolt = <1200000>;
+ };
+
+ lochnagar_sc: soundcard {
+ compatible = "cirrus,lochnagar2-soundcard";
+
+ #sound-dai-cells = <1>;
+
+ clocks = <&lochnagar_clk LOCHNAGAR_SOUNDCARD_MCLK>;
+ clock-names = "mclk";
+ };
+ };
+};
+
+&spi {
+ pinctrl-names = "default";
+ pinctrl-0 = <&spi_pins &spi_cs>;
+ cs-gpios = <&gpio 8 1>, <&gpio 7 1>;
+};
--
2.20.1
WARNING: multiple messages have this Message-ID (diff)
From: Richard Fitzgerald <rf@opensource.cirrus.com>
To: <broonie@kernel.org>, <robh+dt@kernel.org>,
<kuninori.morimoto.gx@renesas.com>, <nsaenzjulienne@suse.de>
Cc: devicetree@vger.kernel.org, alsa-devel@alsa-project.org,
patches@opensource.cirrus.com, linux-kernel@vger.kernel.org,
Richard Fitzgerald <rf@opensource.cirrus.com>,
bcm-kernel-feedback-list@broadcom.com,
linux-rpi-kernel@lists.infradead.org,
linux-arm-kernel@lists.infradead.org
Subject: [PATCH v3 6/6] ARM: dts: Add dts for RPi4b + Cirrus Logic Lochnagar2 + CS47L15
Date: Thu, 17 Dec 2020 15:41:42 +0000 [thread overview]
Message-ID: <20201217154142.24301-7-rf@opensource.cirrus.com> (raw)
In-Reply-To: <20201217154142.24301-1-rf@opensource.cirrus.com>
This adds a devicetree configuration for Raspberry Pi 4b connected to
Cirrus Logic Lochnagar 2 audio development board and CS47L15 codec.
The common (codec-independent) Lochnagar 2 configuration is separated
into a dtsi to simplify re-using it for other codecs.
Signed-off-by: Richard Fitzgerald <rf@opensource.cirrus.com>
---
MAINTAINERS | 1 +
arch/arm/boot/dts/Makefile | 1 +
...bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts | 186 ++++++++++++++++
.../dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi | 201 ++++++++++++++++++
4 files changed, 389 insertions(+)
create mode 100644 arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
create mode 100644 arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
diff --git a/MAINTAINERS b/MAINTAINERS
index 5cc595ac7b28..7dca1db52144 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -4193,6 +4193,7 @@ M: Charles Keepax <ckeepax@opensource.cirrus.com>
M: Richard Fitzgerald <rf@opensource.cirrus.com>
L: patches@opensource.cirrus.com
S: Supported
+F: arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar*
F: Documentation/devicetree/bindings/clock/cirrus,lochnagar.yaml
F: Documentation/devicetree/bindings/hwmon/cirrus,lochnagar.yaml
F: Documentation/devicetree/bindings/mfd/cirrus,lochnagar.yaml
diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile
index ce66ffd5a1bb..240cc58fd954 100644
--- a/arch/arm/boot/dts/Makefile
+++ b/arch/arm/boot/dts/Makefile
@@ -93,6 +93,7 @@ dtb-$(CONFIG_ARCH_BCM2835) += \
bcm2837-rpi-3-b-plus.dtb \
bcm2837-rpi-cm3-io3.dtb \
bcm2711-rpi-4-b.dtb \
+ bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dtb \
bcm2835-rpi-zero.dtb \
bcm2835-rpi-zero-w.dtb
dtb-$(CONFIG_ARCH_BCM_5301X) += \
diff --git a/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
new file mode 100644
index 000000000000..b6b91289bc6f
--- /dev/null
+++ b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
@@ -0,0 +1,186 @@
+// SPDX-License-Identifier: GPL-2.0
+/dts-v1/;
+#include "bcm2711-rpi4b-cirrus-lochnagar.dtsi"
+#include <dt-bindings/sound/madera.h>
+
+/ {
+ sound {
+ status = "okay";
+
+ compatible = "audio-graph-card";
+ label = "sound-card-cs47l15";
+
+ clocks = <&clk_24m>, <&fll1_out>, <&fll1_dsp>;
+ clock-names = "ln-clk-24m", "fll1-out", "fll1-dsp";
+
+ plls = <
+ &cs47l15 MADERA_FLL1_REFCLK MADERA_FLL_SRC_MCLK1 98304000
+ >;
+ plls-clocks = "ln-clk-24m";
+
+ sysclks = <
+ &cs47l15 MADERA_CLK_SYSCLK_1 MADERA_CLK_SRC_FLL1 0
+ &cs47l15 MADERA_CLK_DSPCLK MADERA_CLK_SRC_FLL1 0
+ >;
+ sysclks-clocks = "fll1-out", "fll1-dsp";
+
+ widgets = "Microphone", "Microphone Jack",
+ "Headphone", "Headphone Jack";
+
+ routing = "Microphone Jack", "MICBIAS1A",
+ "IN1BRN", "Microphone Jack",
+ "IN1BRP", "Microphone Jack",
+ "Headphone Jack", "HPOUTL",
+ "Headphone Jack", "HPOUTR";
+
+ dais = <&cpu_i2s_port &cs47l15_trace_port>;
+
+ /* Main output from FLL1 */
+ fll1_out: fll1_out {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <98304000>;
+ };
+
+ /* x1.5 DSP output from FLL1 */
+ fll1_dsp: fll1_dsp {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <147456000>;
+ };
+ };
+};
+
+&i2s {
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ cpu_i2s_port: port@0 {
+ reg = <0>;
+ cpu_i2s_ep: endpoint {
+ remote-endpoint = <&cs47l15_aif1>;
+ dai-format = "i2s";
+ };
+ };
+ };
+};
+
+&spi {
+ status = "okay";
+
+ cs47l15: cs47l15@1 {
+ status = "okay";
+
+ compatible = "cirrus,cs47l15";
+ reg = <0x1>;
+
+ spi-max-frequency = <11000000>;
+
+ interrupts = <27 8>;
+ interrupt-controller;
+ #interrupt-cells = <2>;
+ interrupt-parent = <&gpio>;
+ gpio-controller;
+ #gpio-cells = <2>;
+ #sound-dai-cells = <1>;
+
+ AVDD-supply = <&lochnagar_vdd1v8>;
+ DCVDD-supply = <&lochnagar_vddcore>;
+ DBVDD1-supply = <&lochnagar_vdd1v8>;
+ CPVDD1-supply = <&lochnagar_vdd1v8>;
+ SPKVDD-supply = <&wallvdd>;
+ MICVDD-supply = <&lochnagar_micvdd>;
+
+ reset-gpios = <&lochnagar_pin 0 0>;
+
+ cirrus,dmic-ref = <
+ MADERA_DMIC_REF_MICBIAS1
+ >;
+ cirrus,inmode = <
+ MADERA_INMODE_SE MADERA_INMODE_SE /* IN1A */
+ MADERA_INMODE_DIFF MADERA_INMODE_DIFF /* IN1B */
+ MADERA_INMODE_SE MADERA_INMODE_SE /* IN2A */
+ MADERA_INMODE_DIFF MADERA_INMODE_DIFF /* IN2B */
+ >;
+
+ clocks = <&lochnagar_clk LOCHNAGAR_CDC_MCLK1>,
+ <&lochnagar_clk LOCHNAGAR_CDC_MCLK2>;
+ clock-names = "mclk1", "mclk2";
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&cdc_irq &cs47l15_defaults>;
+
+ cs47l15_defaults: cs47l15-gpio-defaults {
+ aif1 {
+ groups = "aif1";
+ function = "aif1";
+ bias-bus-hold;
+ };
+ aif2 {
+ groups = "aif2";
+ function = "aif2";
+ bias-bus-hold;
+ };
+ aif3 {
+ groups = "aif3";
+ function = "aif3";
+ bias-bus-hold;
+ };
+ pdmspk1 {
+ groups = "pdmspk1";
+ function = "pdmspk1";
+ };
+ };
+
+ micvdd {
+ regulator-min-microvolt = <3000000>;
+ regulator-max-microvolt = <3000000>;
+ };
+
+ MICBIAS1 {
+ regulator-min-microvolt = <2800000>;
+ regulator-max-microvolt = <2800000>;
+ };
+ MICBIAS1A {
+ regulator-active-discharge = <1>;
+ };
+ MICBIAS1B {
+ regulator-active-discharge = <1>;
+ };
+ MICBIAS1C {
+ regulator-active-discharge = <1>;
+ };
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ cs47l15_aif1_port: port@0 {
+ reg = <0>;
+ cs47l15_aif1: endpoint {
+ remote-endpoint = <&cpu_i2s_ep>;
+ bitclock-master;
+ frame-master;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ /* Debug trace compressed stream */
+ cs47l15_trace_port: port@3 {
+ reg = <3>;
+ cs47l15_trace_cpu: endpoint {
+ remote-endpoint = <&cs47l15_trace_codec>;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ port@4 {
+ reg = <4>;
+ cs47l15_trace_codec: endpoint {
+ remote-endpoint = <&cs47l15_trace_cpu>;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ };
+ };
+};
diff --git a/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
new file mode 100644
index 000000000000..af498d7ad18a
--- /dev/null
+++ b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
@@ -0,0 +1,201 @@
+// SPDX-License-Identifier: GPL-2.0
+/dts-v1/;
+#include "bcm2711-rpi-4-b.dts"
+#include <dt-bindings/clk/lochnagar.h>
+#include <dt-bindings/pinctrl/bcm2835.h>
+#include <dt-bindings/pinctrl/lochnagar.h>
+
+/ {
+ wallvdd: wallvdd@0 {
+ compatible = "regulator-fixed";
+
+ regulator-name = "WALL_VDD_5V";
+ regulator-min-microvolt = <5000000>;
+ regulator-max-microvolt = <5000000>;
+ regulator-boot-on;
+ regulator-always-on;
+ };
+
+};
+
+&gpio {
+ lochnagar_present: lochnagar_present {
+ brcm,pins = <22>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ lochnagar_reset: lochnagar_reset {
+ brcm,pins = <24>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ cdc_irq: cdc_irq {
+ brcm,pins = <27>;
+ brcm,function = <BCM2835_FSEL_GPIO_IN>;
+ };
+
+ spi_pins: spi_pins {
+ brcm,pins = <9 10 11>;
+ brcm,function = <BCM2835_FSEL_ALT0>;
+ };
+
+ spi_cs: spi_cs {
+ brcm,pins = <7 8>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ i2s_pins: i2s_pins {
+ brcm,pins = <18 19 20 21>;
+ brcm,function = <BCM2835_FSEL_ALT0>;
+ };
+};
+
+&i2s {
+ status = "okay";
+ #sound-dai-cells = <1>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&i2s_pins>;
+ dmas = <&dma 2>, <&dma 3>;
+ dma-names = "tx", "rx";
+};
+
+&i2c1 {
+ status = "okay";
+
+ lochnagar: lochnagar@22 {
+ status = "okay";
+
+ compatible = "cirrus,lochnagar2";
+ reg = <0x22>;
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&lochnagar_present &lochnagar_reset>;
+
+ reset-gpio = <&gpio 24 0>;
+ present-gpio = <&gpio 22 0>;
+
+ lochnagar_vdd1v8: VDD1V8 {
+ compatible = "regulator-fixed";
+
+ regulator-name = "VDD1V8";
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ regulator-boot-on;
+ regulator-always-on;
+
+ vin-supply = <&wallvdd>;
+ };
+
+ clk_pmic: clk_pmic {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <32768>;
+ };
+ clk_24m: clk_24m {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <24576000>;
+ };
+
+ lochnagar_clk: clk {
+ compatible = "cirrus,lochnagar2-clk";
+
+ #clock-cells = <1>;
+
+ clocks = <&clk_pmic>, <&clk_24m>;
+ clock-names = "ln-pmic-32k", "ln-clk-24m";
+
+ assigned-clocks = <&lochnagar_clk LOCHNAGAR_CDC_MCLK1>,
+ <&lochnagar_clk LOCHNAGAR_CDC_MCLK2>,
+ <&lochnagar_clk LOCHNAGAR_SOUNDCARD_MCLK>;
+ assigned-clock-parents = <&clk_24m>,
+ <&clk_pmic>,
+ <&clk_24m>;
+ };
+
+ lochnagar_pin: pin {
+ compatible = "cirrus,lochnagar-pinctrl";
+
+ gpio-controller;
+ #gpio-cells = <2>;
+ gpio-ranges = <&lochnagar_pin 0 0 LOCHNAGAR2_PIN_NUM_GPIOS>;
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&pin_settings>;
+
+ pin_settings: pin_settings {
+ rpi_aif {
+ input-enable;
+ groups = "gf-aif1";
+ function = "codec-aif1";
+ };
+ codec_aif1 {
+ output-master;
+ groups = "codec-aif1";
+ function = "gf-aif1";
+ };
+ sc_codec_aif {
+ output-enable;
+ groups = "codec-aif2";
+ function = "soundcard-aif";
+ };
+ sc_lochnagar_aif {
+ input-enable;
+ groups = "soundcard-aif";
+ function = "codec-aif2";
+ };
+ };
+ };
+
+ lochnagar_hwmon: hwmon {
+ compatible = "cirrus,lochnagar2-hwmon";
+ };
+
+ lochnagar_micvdd: MICVDD {
+ compatible = "cirrus,lochnagar2-micvdd";
+
+ SYSVDD-supply = <&wallvdd>;
+
+ regulator-min-microvolt = <3000000>;
+ regulator-max-microvolt = <3000000>;
+ };
+
+ MIC1VDD {
+ compatible = "cirrus,lochnagar2-mic1vdd";
+
+ regulator-always-on;
+ cirrus,micbias-input = <2>;
+ };
+
+ MIC2VDD {
+ compatible = "cirrus,lochnagar2-mic2vdd";
+
+ regulator-always-on;
+ cirrus,micbias-input = <3>;
+ };
+
+ lochnagar_vddcore: VDDCORE {
+ compatible = "cirrus,lochnagar2-vddcore";
+
+ SYSVDD-supply = <&wallvdd>;
+
+ regulator-min-microvolt = <1200000>;
+ regulator-max-microvolt = <1200000>;
+ };
+
+ lochnagar_sc: soundcard {
+ compatible = "cirrus,lochnagar2-soundcard";
+
+ #sound-dai-cells = <1>;
+
+ clocks = <&lochnagar_clk LOCHNAGAR_SOUNDCARD_MCLK>;
+ clock-names = "mclk";
+ };
+ };
+};
+
+&spi {
+ pinctrl-names = "default";
+ pinctrl-0 = <&spi_pins &spi_cs>;
+ cs-gpios = <&gpio 8 1>, <&gpio 7 1>;
+};
--
2.20.1
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
WARNING: multiple messages have this Message-ID (diff)
From: Richard Fitzgerald <rf@opensource.cirrus.com>
To: <broonie@kernel.org>, <robh+dt@kernel.org>,
<kuninori.morimoto.gx@renesas.com>, <nsaenzjulienne@suse.de>
Cc: <linux-kernel@vger.kernel.org>, <devicetree@vger.kernel.org>,
<alsa-devel@alsa-project.org>, <patches@opensource.cirrus.com>,
<bcm-kernel-feedback-list@broadcom.com>,
<linux-rpi-kernel@lists.infradead.org>,
<linux-arm-kernel@lists.infradead.org>,
Richard Fitzgerald <rf@opensource.cirrus.com>
Subject: [PATCH v3 6/6] ARM: dts: Add dts for RPi4b + Cirrus Logic Lochnagar2 + CS47L15
Date: Thu, 17 Dec 2020 15:41:42 +0000 [thread overview]
Message-ID: <20201217154142.24301-7-rf@opensource.cirrus.com> (raw)
In-Reply-To: <20201217154142.24301-1-rf@opensource.cirrus.com>
This adds a devicetree configuration for Raspberry Pi 4b connected to
Cirrus Logic Lochnagar 2 audio development board and CS47L15 codec.
The common (codec-independent) Lochnagar 2 configuration is separated
into a dtsi to simplify re-using it for other codecs.
Signed-off-by: Richard Fitzgerald <rf@opensource.cirrus.com>
---
MAINTAINERS | 1 +
arch/arm/boot/dts/Makefile | 1 +
...bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts | 186 ++++++++++++++++
.../dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi | 201 ++++++++++++++++++
4 files changed, 389 insertions(+)
create mode 100644 arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
create mode 100644 arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
diff --git a/MAINTAINERS b/MAINTAINERS
index 5cc595ac7b28..7dca1db52144 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -4193,6 +4193,7 @@ M: Charles Keepax <ckeepax@opensource.cirrus.com>
M: Richard Fitzgerald <rf@opensource.cirrus.com>
L: patches@opensource.cirrus.com
S: Supported
+F: arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar*
F: Documentation/devicetree/bindings/clock/cirrus,lochnagar.yaml
F: Documentation/devicetree/bindings/hwmon/cirrus,lochnagar.yaml
F: Documentation/devicetree/bindings/mfd/cirrus,lochnagar.yaml
diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile
index ce66ffd5a1bb..240cc58fd954 100644
--- a/arch/arm/boot/dts/Makefile
+++ b/arch/arm/boot/dts/Makefile
@@ -93,6 +93,7 @@ dtb-$(CONFIG_ARCH_BCM2835) += \
bcm2837-rpi-3-b-plus.dtb \
bcm2837-rpi-cm3-io3.dtb \
bcm2711-rpi-4-b.dtb \
+ bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dtb \
bcm2835-rpi-zero.dtb \
bcm2835-rpi-zero-w.dtb
dtb-$(CONFIG_ARCH_BCM_5301X) += \
diff --git a/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
new file mode 100644
index 000000000000..b6b91289bc6f
--- /dev/null
+++ b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar-cs47l15.dts
@@ -0,0 +1,186 @@
+// SPDX-License-Identifier: GPL-2.0
+/dts-v1/;
+#include "bcm2711-rpi4b-cirrus-lochnagar.dtsi"
+#include <dt-bindings/sound/madera.h>
+
+/ {
+ sound {
+ status = "okay";
+
+ compatible = "audio-graph-card";
+ label = "sound-card-cs47l15";
+
+ clocks = <&clk_24m>, <&fll1_out>, <&fll1_dsp>;
+ clock-names = "ln-clk-24m", "fll1-out", "fll1-dsp";
+
+ plls = <
+ &cs47l15 MADERA_FLL1_REFCLK MADERA_FLL_SRC_MCLK1 98304000
+ >;
+ plls-clocks = "ln-clk-24m";
+
+ sysclks = <
+ &cs47l15 MADERA_CLK_SYSCLK_1 MADERA_CLK_SRC_FLL1 0
+ &cs47l15 MADERA_CLK_DSPCLK MADERA_CLK_SRC_FLL1 0
+ >;
+ sysclks-clocks = "fll1-out", "fll1-dsp";
+
+ widgets = "Microphone", "Microphone Jack",
+ "Headphone", "Headphone Jack";
+
+ routing = "Microphone Jack", "MICBIAS1A",
+ "IN1BRN", "Microphone Jack",
+ "IN1BRP", "Microphone Jack",
+ "Headphone Jack", "HPOUTL",
+ "Headphone Jack", "HPOUTR";
+
+ dais = <&cpu_i2s_port &cs47l15_trace_port>;
+
+ /* Main output from FLL1 */
+ fll1_out: fll1_out {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <98304000>;
+ };
+
+ /* x1.5 DSP output from FLL1 */
+ fll1_dsp: fll1_dsp {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <147456000>;
+ };
+ };
+};
+
+&i2s {
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ cpu_i2s_port: port@0 {
+ reg = <0>;
+ cpu_i2s_ep: endpoint {
+ remote-endpoint = <&cs47l15_aif1>;
+ dai-format = "i2s";
+ };
+ };
+ };
+};
+
+&spi {
+ status = "okay";
+
+ cs47l15: cs47l15@1 {
+ status = "okay";
+
+ compatible = "cirrus,cs47l15";
+ reg = <0x1>;
+
+ spi-max-frequency = <11000000>;
+
+ interrupts = <27 8>;
+ interrupt-controller;
+ #interrupt-cells = <2>;
+ interrupt-parent = <&gpio>;
+ gpio-controller;
+ #gpio-cells = <2>;
+ #sound-dai-cells = <1>;
+
+ AVDD-supply = <&lochnagar_vdd1v8>;
+ DCVDD-supply = <&lochnagar_vddcore>;
+ DBVDD1-supply = <&lochnagar_vdd1v8>;
+ CPVDD1-supply = <&lochnagar_vdd1v8>;
+ SPKVDD-supply = <&wallvdd>;
+ MICVDD-supply = <&lochnagar_micvdd>;
+
+ reset-gpios = <&lochnagar_pin 0 0>;
+
+ cirrus,dmic-ref = <
+ MADERA_DMIC_REF_MICBIAS1
+ >;
+ cirrus,inmode = <
+ MADERA_INMODE_SE MADERA_INMODE_SE /* IN1A */
+ MADERA_INMODE_DIFF MADERA_INMODE_DIFF /* IN1B */
+ MADERA_INMODE_SE MADERA_INMODE_SE /* IN2A */
+ MADERA_INMODE_DIFF MADERA_INMODE_DIFF /* IN2B */
+ >;
+
+ clocks = <&lochnagar_clk LOCHNAGAR_CDC_MCLK1>,
+ <&lochnagar_clk LOCHNAGAR_CDC_MCLK2>;
+ clock-names = "mclk1", "mclk2";
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&cdc_irq &cs47l15_defaults>;
+
+ cs47l15_defaults: cs47l15-gpio-defaults {
+ aif1 {
+ groups = "aif1";
+ function = "aif1";
+ bias-bus-hold;
+ };
+ aif2 {
+ groups = "aif2";
+ function = "aif2";
+ bias-bus-hold;
+ };
+ aif3 {
+ groups = "aif3";
+ function = "aif3";
+ bias-bus-hold;
+ };
+ pdmspk1 {
+ groups = "pdmspk1";
+ function = "pdmspk1";
+ };
+ };
+
+ micvdd {
+ regulator-min-microvolt = <3000000>;
+ regulator-max-microvolt = <3000000>;
+ };
+
+ MICBIAS1 {
+ regulator-min-microvolt = <2800000>;
+ regulator-max-microvolt = <2800000>;
+ };
+ MICBIAS1A {
+ regulator-active-discharge = <1>;
+ };
+ MICBIAS1B {
+ regulator-active-discharge = <1>;
+ };
+ MICBIAS1C {
+ regulator-active-discharge = <1>;
+ };
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ cs47l15_aif1_port: port@0 {
+ reg = <0>;
+ cs47l15_aif1: endpoint {
+ remote-endpoint = <&cpu_i2s_ep>;
+ bitclock-master;
+ frame-master;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ /* Debug trace compressed stream */
+ cs47l15_trace_port: port@3 {
+ reg = <3>;
+ cs47l15_trace_cpu: endpoint {
+ remote-endpoint = <&cs47l15_trace_codec>;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ port@4 {
+ reg = <4>;
+ cs47l15_trace_codec: endpoint {
+ remote-endpoint = <&cs47l15_trace_cpu>;
+ system-clock-frequency = <0>;
+ mclk-fs = <0>;
+ };
+ };
+ };
+ };
+};
diff --git a/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
new file mode 100644
index 000000000000..af498d7ad18a
--- /dev/null
+++ b/arch/arm/boot/dts/bcm2711-rpi4b-cirrus-lochnagar.dtsi
@@ -0,0 +1,201 @@
+// SPDX-License-Identifier: GPL-2.0
+/dts-v1/;
+#include "bcm2711-rpi-4-b.dts"
+#include <dt-bindings/clk/lochnagar.h>
+#include <dt-bindings/pinctrl/bcm2835.h>
+#include <dt-bindings/pinctrl/lochnagar.h>
+
+/ {
+ wallvdd: wallvdd@0 {
+ compatible = "regulator-fixed";
+
+ regulator-name = "WALL_VDD_5V";
+ regulator-min-microvolt = <5000000>;
+ regulator-max-microvolt = <5000000>;
+ regulator-boot-on;
+ regulator-always-on;
+ };
+
+};
+
+&gpio {
+ lochnagar_present: lochnagar_present {
+ brcm,pins = <22>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ lochnagar_reset: lochnagar_reset {
+ brcm,pins = <24>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ cdc_irq: cdc_irq {
+ brcm,pins = <27>;
+ brcm,function = <BCM2835_FSEL_GPIO_IN>;
+ };
+
+ spi_pins: spi_pins {
+ brcm,pins = <9 10 11>;
+ brcm,function = <BCM2835_FSEL_ALT0>;
+ };
+
+ spi_cs: spi_cs {
+ brcm,pins = <7 8>;
+ brcm,function = <BCM2835_FSEL_GPIO_OUT>;
+ };
+
+ i2s_pins: i2s_pins {
+ brcm,pins = <18 19 20 21>;
+ brcm,function = <BCM2835_FSEL_ALT0>;
+ };
+};
+
+&i2s {
+ status = "okay";
+ #sound-dai-cells = <1>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&i2s_pins>;
+ dmas = <&dma 2>, <&dma 3>;
+ dma-names = "tx", "rx";
+};
+
+&i2c1 {
+ status = "okay";
+
+ lochnagar: lochnagar@22 {
+ status = "okay";
+
+ compatible = "cirrus,lochnagar2";
+ reg = <0x22>;
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&lochnagar_present &lochnagar_reset>;
+
+ reset-gpio = <&gpio 24 0>;
+ present-gpio = <&gpio 22 0>;
+
+ lochnagar_vdd1v8: VDD1V8 {
+ compatible = "regulator-fixed";
+
+ regulator-name = "VDD1V8";
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ regulator-boot-on;
+ regulator-always-on;
+
+ vin-supply = <&wallvdd>;
+ };
+
+ clk_pmic: clk_pmic {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <32768>;
+ };
+ clk_24m: clk_24m {
+ compatible = "fixed-clock";
+ #clock-cells = <0>;
+ clock-frequency = <24576000>;
+ };
+
+ lochnagar_clk: clk {
+ compatible = "cirrus,lochnagar2-clk";
+
+ #clock-cells = <1>;
+
+ clocks = <&clk_pmic>, <&clk_24m>;
+ clock-names = "ln-pmic-32k", "ln-clk-24m";
+
+ assigned-clocks = <&lochnagar_clk LOCHNAGAR_CDC_MCLK1>,
+ <&lochnagar_clk LOCHNAGAR_CDC_MCLK2>,
+ <&lochnagar_clk LOCHNAGAR_SOUNDCARD_MCLK>;
+ assigned-clock-parents = <&clk_24m>,
+ <&clk_pmic>,
+ <&clk_24m>;
+ };
+
+ lochnagar_pin: pin {
+ compatible = "cirrus,lochnagar-pinctrl";
+
+ gpio-controller;
+ #gpio-cells = <2>;
+ gpio-ranges = <&lochnagar_pin 0 0 LOCHNAGAR2_PIN_NUM_GPIOS>;
+
+ pinctrl-names = "default";
+ pinctrl-0 = <&pin_settings>;
+
+ pin_settings: pin_settings {
+ rpi_aif {
+ input-enable;
+ groups = "gf-aif1";
+ function = "codec-aif1";
+ };
+ codec_aif1 {
+ output-master;
+ groups = "codec-aif1";
+ function = "gf-aif1";
+ };
+ sc_codec_aif {
+ output-enable;
+ groups = "codec-aif2";
+ function = "soundcard-aif";
+ };
+ sc_lochnagar_aif {
+ input-enable;
+ groups = "soundcard-aif";
+ function = "codec-aif2";
+ };
+ };
+ };
+
+ lochnagar_hwmon: hwmon {
+ compatible = "cirrus,lochnagar2-hwmon";
+ };
+
+ lochnagar_micvdd: MICVDD {
+ compatible = "cirrus,lochnagar2-micvdd";
+
+ SYSVDD-supply = <&wallvdd>;
+
+ regulator-min-microvolt = <3000000>;
+ regulator-max-microvolt = <3000000>;
+ };
+
+ MIC1VDD {
+ compatible = "cirrus,lochnagar2-mic1vdd";
+
+ regulator-always-on;
+ cirrus,micbias-input = <2>;
+ };
+
+ MIC2VDD {
+ compatible = "cirrus,lochnagar2-mic2vdd";
+
+ regulator-always-on;
+ cirrus,micbias-input = <3>;
+ };
+
+ lochnagar_vddcore: VDDCORE {
+ compatible = "cirrus,lochnagar2-vddcore";
+
+ SYSVDD-supply = <&wallvdd>;
+
+ regulator-min-microvolt = <1200000>;
+ regulator-max-microvolt = <1200000>;
+ };
+
+ lochnagar_sc: soundcard {
+ compatible = "cirrus,lochnagar2-soundcard";
+
+ #sound-dai-cells = <1>;
+
+ clocks = <&lochnagar_clk LOCHNAGAR_SOUNDCARD_MCLK>;
+ clock-names = "mclk";
+ };
+ };
+};
+
+&spi {
+ pinctrl-names = "default";
+ pinctrl-0 = <&spi_pins &spi_cs>;
+ cs-gpios = <&gpio 8 1>, <&gpio 7 1>;
+};
--
2.20.1
next prev parent reply other threads:[~2020-12-17 15:44 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-12-17 15:41 [PATCH v3 0/6] Add support for Rpi4b + Cirrus Lochnagar2 and CS47L15 Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` [PATCH v3 1/6] of: base: Add of_count_phandle_with_fixed_args() Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` [PATCH v3 2/6] ASoC: audio-graph-card: Add plls and sysclks DT bindings Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-21 22:34 ` Rob Herring
2020-12-21 22:34 ` Rob Herring
2020-12-21 22:34 ` Rob Herring
2020-12-17 15:41 ` [PATCH v3 3/6] ASoC: audio-graph-card: Support setting component plls and sysclks Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-18 0:03 ` Kuninori Morimoto
2020-12-18 0:03 ` Kuninori Morimoto
2020-12-18 0:03 ` Kuninori Morimoto
2020-12-21 10:38 ` Richard Fitzgerald
2020-12-21 10:38 ` Richard Fitzgerald
2020-12-21 10:38 ` Richard Fitzgerald
2020-12-17 15:41 ` [PATCH v3 4/6] ASoC: madera: Allow codecs to be selected from kernel config Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` [PATCH v3 5/6] ASoC: madera: Export clock config defines to dt-bindings Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald [this message]
2020-12-17 15:41 ` [PATCH v3 6/6] ARM: dts: Add dts for RPi4b + Cirrus Logic Lochnagar2 + CS47L15 Richard Fitzgerald
2020-12-17 15:41 ` Richard Fitzgerald
2020-12-17 17:11 ` Florian Fainelli
2020-12-17 17:11 ` Florian Fainelli
2020-12-17 17:11 ` Florian Fainelli
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20201217154142.24301-7-rf@opensource.cirrus.com \
--to=rf@opensource.cirrus.com \
--cc=alsa-devel@alsa-project.org \
--cc=bcm-kernel-feedback-list@broadcom.com \
--cc=broonie@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=kuninori.morimoto.gx@renesas.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-rpi-kernel@lists.infradead.org \
--cc=nsaenzjulienne@suse.de \
--cc=patches@opensource.cirrus.com \
--cc=robh+dt@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.