Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

ARM: dts: Add DTS files for bcmbca SoC BCM6878

Add dts for ARMv7 based broadband SoC BCM6878. bcm6878.dtsi is the
SoC description dts header and bcm96878.dts is a simple dts file for
Broadcom BCM96878 Reference board that only enable the UART port.

Signed-off-by: Anand Gore <anand.gore@broadcom.com>
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>

authored by

Anand Gore and committed by
Florian Fainelli
6bcad714 ad8fb6b8

+142 -1
+2 -1
arch/arm/boot/dts/Makefile
··· 183 183 bcm7445-bcm97445svmb.dtb 184 184 dtb-$(CONFIG_ARCH_BCMBCA) += \ 185 185 bcm947622.dtb \ 186 - bcm963178.dtb 186 + bcm963178.dtb \ 187 + bcm96878.dtb 187 188 dtb-$(CONFIG_ARCH_CLPS711X) += \ 188 189 ep7211-edb7211.dtb 189 190 dtb-$(CONFIG_ARCH_DAVINCI) += \
+110
arch/arm/boot/dts/bcm6878.dtsi
··· 1 + // SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2 + /* 3 + * Copyright 2022 Broadcom Ltd. 4 + */ 5 + 6 + #include <dt-bindings/interrupt-controller/arm-gic.h> 7 + #include <dt-bindings/interrupt-controller/irq.h> 8 + 9 + / { 10 + compatible = "brcm,bcm6878", "brcm,bcmbca"; 11 + #address-cells = <1>; 12 + #size-cells = <1>; 13 + 14 + interrupt-parent = <&gic>; 15 + 16 + cpus { 17 + #address-cells = <1>; 18 + #size-cells = <0>; 19 + 20 + CA7_0: cpu@0 { 21 + device_type = "cpu"; 22 + compatible = "arm,cortex-a7"; 23 + reg = <0x0>; 24 + next-level-cache = <&L2_0>; 25 + enable-method = "psci"; 26 + }; 27 + 28 + CA7_1: cpu@1 { 29 + device_type = "cpu"; 30 + compatible = "arm,cortex-a7"; 31 + reg = <0x1>; 32 + next-level-cache = <&L2_0>; 33 + enable-method = "psci"; 34 + }; 35 + L2_0: l2-cache0 { 36 + compatible = "cache"; 37 + }; 38 + }; 39 + 40 + timer { 41 + compatible = "arm,armv7-timer"; 42 + interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 43 + <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 44 + <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 45 + <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>; 46 + arm,cpu-registers-not-fw-configured; 47 + }; 48 + 49 + pmu: pmu { 50 + compatible = "arm,cortex-a7-pmu"; 51 + interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>, 52 + <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>; 53 + interrupt-affinity = <&CA7_0>, <&CA7_1>; 54 + }; 55 + 56 + clocks: clocks { 57 + periph_clk: periph-clk { 58 + compatible = "fixed-clock"; 59 + #clock-cells = <0>; 60 + clock-frequency = <200000000>; 61 + }; 62 + uart_clk: uart-clk { 63 + compatible = "fixed-factor-clock"; 64 + #clock-cells = <0>; 65 + clocks = <&periph_clk>; 66 + clock-div = <4>; 67 + clock-mult = <1>; 68 + }; 69 + }; 70 + 71 + psci { 72 + compatible = "arm,psci-0.2"; 73 + method = "smc"; 74 + }; 75 + 76 + axi@81000000 { 77 + compatible = "simple-bus"; 78 + #address-cells = <1>; 79 + #size-cells = <1>; 80 + ranges = <0 0x81000000 0x8000>; 81 + 82 + gic: interrupt-controller@1000 { 83 + compatible = "arm,cortex-a7-gic"; 84 + #interrupt-cells = <3>; 85 + interrupt-controller; 86 + reg = <0x1000 0x1000>, 87 + <0x2000 0x2000>, 88 + <0x4000 0x2000>, 89 + <0x6000 0x2000>; 90 + interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(2) | 91 + IRQ_TYPE_LEVEL_HIGH)>; 92 + }; 93 + }; 94 + 95 + bus@ff800000 { 96 + compatible = "simple-bus"; 97 + #address-cells = <1>; 98 + #size-cells = <1>; 99 + ranges = <0 0xff800000 0x800000>; 100 + 101 + uart0: serial@12000 { 102 + compatible = "arm,pl011", "arm,primecell"; 103 + reg = <0x12000 0x1000>; 104 + interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>; 105 + clocks = <&uart_clk>, <&uart_clk>; 106 + clock-names = "uartclk", "apb_pclk"; 107 + status = "disabled"; 108 + }; 109 + }; 110 + };
+30
arch/arm/boot/dts/bcm96878.dts
··· 1 + // SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2 + /* 3 + * Copyright 2019 Broadcom Ltd. 4 + */ 5 + 6 + /dts-v1/; 7 + 8 + #include "bcm6878.dtsi" 9 + 10 + / { 11 + model = "Broadcom BCM96878 Reference Board"; 12 + compatible = "brcm,bcm96878", "brcm,bcm6878", "brcm,bcmbca"; 13 + 14 + aliases { 15 + serial0 = &uart0; 16 + }; 17 + 18 + chosen { 19 + stdout-path = "serial0:115200n8"; 20 + }; 21 + 22 + memory@0 { 23 + device_type = "memory"; 24 + reg = <0x0 0x08000000>; 25 + }; 26 + }; 27 + 28 + &uart0 { 29 + status = "okay"; 30 + };