|
@@ -0,0 +1,367 @@
|
|
|
+From f5d83b714e304d5f3229da434af2eeea033c4f5d Mon Sep 17 00:00:00 2001
|
|
|
+From: William Zhang <[email protected]>
|
|
|
+Date: Mon, 6 Feb 2023 22:58:15 -0800
|
|
|
+Subject: [PATCH] arm64: dts: broadcom: bcmbca: Add spi controller node
|
|
|
+
|
|
|
+Add support for HSSPI controller in ARMv8 chip dts files.
|
|
|
+
|
|
|
+Signed-off-by: William Zhang <[email protected]>
|
|
|
+Link: https://lore.kernel.org/r/[email protected]
|
|
|
+Signed-off-by: Florian Fainelli <[email protected]>
|
|
|
+---
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm4908.dtsi | 18 +++++++++++++++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm4912.dtsi | 20 +++++++++++++++++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm63146.dtsi | 19 ++++++++++++++++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm63158.dtsi | 19 ++++++++++++++++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm6813.dtsi | 20 +++++++++++++++++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm6856.dtsi | 18 +++++++++++++++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm6858.dtsi | 18 +++++++++++++++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm94908.dts | 4 ++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm94912.dts | 4 ++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm963146.dts | 4 ++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm963158.dts | 4 ++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm96813.dts | 4 ++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm96856.dts | 4 ++++
|
|
|
+ .../boot/dts/broadcom/bcmbca/bcm96858.dts | 4 ++++
|
|
|
+ 14 files changed, 160 insertions(+)
|
|
|
+
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm4908.dtsi
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm4908.dtsi
|
|
|
+@@ -107,6 +107,12 @@
|
|
|
+ clock-frequency = <50000000>;
|
|
|
+ clock-output-names = "periph";
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi_pll: hsspi-pll {
|
|
|
++ compatible = "fixed-clock";
|
|
|
++ #clock-cells = <0>;
|
|
|
++ clock-frequency = <400000000>;
|
|
|
++ };
|
|
|
+ };
|
|
|
+
|
|
|
+ soc {
|
|
|
+@@ -531,6 +537,18 @@
|
|
|
+ #size-cells = <0>;
|
|
|
+ };
|
|
|
+
|
|
|
++ hsspi: spi@1000{
|
|
|
++ #address-cells = <1>;
|
|
|
++ #size-cells = <0>;
|
|
|
++ compatible = "brcm,bcm4908-hsspi", "brcm,bcmbca-hsspi-v1.0";
|
|
|
++ reg = <0x1000 0x600>;
|
|
|
++ interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
++ clocks = <&hsspi_pll &hsspi_pll>;
|
|
|
++ clock-names = "hsspi", "pll";
|
|
|
++ num-cs = <8>;
|
|
|
++ status = "disabled";
|
|
|
++ };
|
|
|
++
|
|
|
+ nand-controller@1800 {
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <0>;
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm4912.dtsi
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm4912.dtsi
|
|
|
+@@ -79,6 +79,7 @@
|
|
|
+ #clock-cells = <0>;
|
|
|
+ clock-frequency = <200000000>;
|
|
|
+ };
|
|
|
++
|
|
|
+ uart_clk: uart-clk {
|
|
|
+ compatible = "fixed-factor-clock";
|
|
|
+ #clock-cells = <0>;
|
|
|
+@@ -86,6 +87,12 @@
|
|
|
+ clock-div = <4>;
|
|
|
+ clock-mult = <1>;
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi_pll: hsspi-pll {
|
|
|
++ compatible = "fixed-clock";
|
|
|
++ #clock-cells = <0>;
|
|
|
++ clock-frequency = <200000000>;
|
|
|
++ };
|
|
|
+ };
|
|
|
+
|
|
|
+ psci {
|
|
|
+@@ -117,6 +124,19 @@
|
|
|
+ #size-cells = <1>;
|
|
|
+ ranges = <0x0 0x0 0xff800000 0x800000>;
|
|
|
+
|
|
|
++ hsspi: spi@1000 {
|
|
|
++ #address-cells = <1>;
|
|
|
++ #size-cells = <0>;
|
|
|
++ compatible = "brcm,bcm4912-hsspi", "brcm,bcmbca-hsspi-v1.1";
|
|
|
++ reg = <0x1000 0x600>, <0x2610 0x4>;
|
|
|
++ reg-names = "hsspi", "spim-ctrl";
|
|
|
++ interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
++ clocks = <&hsspi_pll &hsspi_pll>;
|
|
|
++ clock-names = "hsspi", "pll";
|
|
|
++ num-cs = <8>;
|
|
|
++ status = "disabled";
|
|
|
++ };
|
|
|
++
|
|
|
+ uart0: serial@12000 {
|
|
|
+ compatible = "arm,pl011", "arm,primecell";
|
|
|
+ reg = <0x12000 0x1000>;
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm63146.dtsi
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm63146.dtsi
|
|
|
+@@ -60,6 +60,7 @@
|
|
|
+ #clock-cells = <0>;
|
|
|
+ clock-frequency = <200000000>;
|
|
|
+ };
|
|
|
++
|
|
|
+ uart_clk: uart-clk {
|
|
|
+ compatible = "fixed-factor-clock";
|
|
|
+ #clock-cells = <0>;
|
|
|
+@@ -67,6 +68,12 @@
|
|
|
+ clock-div = <4>;
|
|
|
+ clock-mult = <1>;
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi_pll: hsspi-pll {
|
|
|
++ compatible = "fixed-clock";
|
|
|
++ #clock-cells = <0>;
|
|
|
++ clock-frequency = <200000000>;
|
|
|
++ };
|
|
|
+ };
|
|
|
+
|
|
|
+ psci {
|
|
|
+@@ -99,6 +106,18 @@
|
|
|
+ #size-cells = <1>;
|
|
|
+ ranges = <0x0 0x0 0xff800000 0x800000>;
|
|
|
+
|
|
|
++ hsspi: spi@1000 {
|
|
|
++ #address-cells = <1>;
|
|
|
++ #size-cells = <0>;
|
|
|
++ compatible = "brcm,bcm63146-hsspi", "brcm,bcmbca-hsspi-v1.0";
|
|
|
++ reg = <0x1000 0x600>;
|
|
|
++ interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
++ clocks = <&hsspi_pll &hsspi_pll>;
|
|
|
++ clock-names = "hsspi", "pll";
|
|
|
++ num-cs = <8>;
|
|
|
++ status = "disabled";
|
|
|
++ };
|
|
|
++
|
|
|
+ uart0: serial@12000 {
|
|
|
+ compatible = "arm,pl011", "arm,primecell";
|
|
|
+ reg = <0x12000 0x1000>;
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm63158.dtsi
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm63158.dtsi
|
|
|
+@@ -79,6 +79,7 @@
|
|
|
+ #clock-cells = <0>;
|
|
|
+ clock-frequency = <200000000>;
|
|
|
+ };
|
|
|
++
|
|
|
+ uart_clk: uart-clk {
|
|
|
+ compatible = "fixed-factor-clock";
|
|
|
+ #clock-cells = <0>;
|
|
|
+@@ -86,6 +87,12 @@
|
|
|
+ clock-div = <4>;
|
|
|
+ clock-mult = <1>;
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi_pll: hsspi-pll {
|
|
|
++ compatible = "fixed-clock";
|
|
|
++ #clock-cells = <0>;
|
|
|
++ clock-frequency = <400000000>;
|
|
|
++ };
|
|
|
+ };
|
|
|
+
|
|
|
+ psci {
|
|
|
+@@ -117,6 +124,18 @@
|
|
|
+ #size-cells = <1>;
|
|
|
+ ranges = <0x0 0x0 0xff800000 0x800000>;
|
|
|
+
|
|
|
++ hsspi: spi@1000 {
|
|
|
++ #address-cells = <1>;
|
|
|
++ #size-cells = <0>;
|
|
|
++ compatible = "brcm,bcm63158-hsspi", "brcm,bcmbca-hsspi-v1.0";
|
|
|
++ reg = <0x1000 0x600>;
|
|
|
++ interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
++ clocks = <&hsspi_pll &hsspi_pll>;
|
|
|
++ clock-names = "hsspi", "pll";
|
|
|
++ num-cs = <8>;
|
|
|
++ status = "disabled";
|
|
|
++ };
|
|
|
++
|
|
|
+ uart0: serial@12000 {
|
|
|
+ compatible = "arm,pl011", "arm,primecell";
|
|
|
+ reg = <0x12000 0x1000>;
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm6813.dtsi
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm6813.dtsi
|
|
|
+@@ -79,6 +79,7 @@
|
|
|
+ #clock-cells = <0>;
|
|
|
+ clock-frequency = <200000000>;
|
|
|
+ };
|
|
|
++
|
|
|
+ uart_clk: uart-clk {
|
|
|
+ compatible = "fixed-factor-clock";
|
|
|
+ #clock-cells = <0>;
|
|
|
+@@ -86,6 +87,12 @@
|
|
|
+ clock-div = <4>;
|
|
|
+ clock-mult = <1>;
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi_pll: hsspi-pll {
|
|
|
++ compatible = "fixed-clock";
|
|
|
++ #clock-cells = <0>;
|
|
|
++ clock-frequency = <200000000>;
|
|
|
++ };
|
|
|
+ };
|
|
|
+
|
|
|
+ psci {
|
|
|
+@@ -117,6 +124,19 @@
|
|
|
+ #size-cells = <1>;
|
|
|
+ ranges = <0x0 0x0 0xff800000 0x800000>;
|
|
|
+
|
|
|
++ hsspi: spi@1000 {
|
|
|
++ #address-cells = <1>;
|
|
|
++ #size-cells = <0>;
|
|
|
++ compatible = "brcm,bcm6813-hsspi", "brcm,bcmbca-hsspi-v1.1";
|
|
|
++ reg = <0x1000 0x600>, <0x2610 0x4>;
|
|
|
++ reg-names = "hsspi", "spim-ctrl";
|
|
|
++ interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
++ clocks = <&hsspi_pll &hsspi_pll>;
|
|
|
++ clock-names = "hsspi", "pll";
|
|
|
++ num-cs = <8>;
|
|
|
++ status = "disabled";
|
|
|
++ };
|
|
|
++
|
|
|
+ uart0: serial@12000 {
|
|
|
+ compatible = "arm,pl011", "arm,primecell";
|
|
|
+ reg = <0x12000 0x1000>;
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm6856.dtsi
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm6856.dtsi
|
|
|
+@@ -60,6 +60,12 @@
|
|
|
+ #clock-cells = <0>;
|
|
|
+ clock-frequency = <200000000>;
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi_pll: hsspi-pll {
|
|
|
++ compatible = "fixed-clock";
|
|
|
++ #clock-cells = <0>;
|
|
|
++ clock-frequency = <400000000>;
|
|
|
++ };
|
|
|
+ };
|
|
|
+
|
|
|
+ psci {
|
|
|
+@@ -100,5 +106,17 @@
|
|
|
+ clock-names = "refclk";
|
|
|
+ status = "disabled";
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi: spi@1000 {
|
|
|
++ #address-cells = <1>;
|
|
|
++ #size-cells = <0>;
|
|
|
++ compatible = "brcm,bcm6856-hsspi", "brcm,bcmbca-hsspi-v1.0";
|
|
|
++ reg = <0x1000 0x600>;
|
|
|
++ interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
++ clocks = <&hsspi_pll &hsspi_pll>;
|
|
|
++ clock-names = "hsspi", "pll";
|
|
|
++ num-cs = <8>;
|
|
|
++ status = "disabled";
|
|
|
++ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm6858.dtsi
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm6858.dtsi
|
|
|
+@@ -78,6 +78,12 @@
|
|
|
+ #clock-cells = <0>;
|
|
|
+ clock-frequency = <200000000>;
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi_pll: hsspi-pll {
|
|
|
++ compatible = "fixed-clock";
|
|
|
++ #clock-cells = <0>;
|
|
|
++ clock-frequency = <400000000>;
|
|
|
++ };
|
|
|
+ };
|
|
|
+
|
|
|
+ psci {
|
|
|
+@@ -137,5 +143,17 @@
|
|
|
+ clock-names = "refclk";
|
|
|
+ status = "disabled";
|
|
|
+ };
|
|
|
++
|
|
|
++ hsspi: spi@1000 {
|
|
|
++ #address-cells = <1>;
|
|
|
++ #size-cells = <0>;
|
|
|
++ compatible = "brcm,bcm6858-hsspi", "brcm,bcmbca-hsspi-v1.0";
|
|
|
++ reg = <0x1000 0x600>;
|
|
|
++ interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
++ clocks = <&hsspi_pll &hsspi_pll>;
|
|
|
++ clock-names = "hsspi", "pll";
|
|
|
++ num-cs = <8>;
|
|
|
++ status = "disabled";
|
|
|
++ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm94908.dts
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm94908.dts
|
|
|
+@@ -28,3 +28,7 @@
|
|
|
+ &uart0 {
|
|
|
+ status = "okay";
|
|
|
+ };
|
|
|
++
|
|
|
++&hsspi {
|
|
|
++ status = "okay";
|
|
|
++};
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm94912.dts
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm94912.dts
|
|
|
+@@ -28,3 +28,7 @@
|
|
|
+ &uart0 {
|
|
|
+ status = "okay";
|
|
|
+ };
|
|
|
++
|
|
|
++&hsspi {
|
|
|
++ status = "okay";
|
|
|
++};
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm963146.dts
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm963146.dts
|
|
|
+@@ -28,3 +28,7 @@
|
|
|
+ &uart0 {
|
|
|
+ status = "okay";
|
|
|
+ };
|
|
|
++
|
|
|
++&hsspi {
|
|
|
++ status = "okay";
|
|
|
++};
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm963158.dts
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm963158.dts
|
|
|
+@@ -28,3 +28,7 @@
|
|
|
+ &uart0 {
|
|
|
+ status = "okay";
|
|
|
+ };
|
|
|
++
|
|
|
++&hsspi {
|
|
|
++ status = "okay";
|
|
|
++};
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm96813.dts
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm96813.dts
|
|
|
+@@ -28,3 +28,7 @@
|
|
|
+ &uart0 {
|
|
|
+ status = "okay";
|
|
|
+ };
|
|
|
++
|
|
|
++&hsspi {
|
|
|
++ status = "okay";
|
|
|
++};
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm96856.dts
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm96856.dts
|
|
|
+@@ -28,3 +28,7 @@
|
|
|
+ &uart0 {
|
|
|
+ status = "okay";
|
|
|
+ };
|
|
|
++
|
|
|
++&hsspi {
|
|
|
++ status = "okay";
|
|
|
++};
|
|
|
+--- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm96858.dts
|
|
|
++++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm96858.dts
|
|
|
+@@ -28,3 +28,7 @@
|
|
|
+ &uart0 {
|
|
|
+ status = "okay";
|
|
|
+ };
|
|
|
++
|
|
|
++&hsspi {
|
|
|
++ status = "okay";
|
|
|
++};
|