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 BCM6846

Add DTS for ARMv7 based broadband SoC BCM6846. bcm6846.dtsi is the
SoC description DTS header and bcm96846.dts is a simple DTS file for
Broadcom BCM96846 Reference board that only enable the UART port.

Signed-off-by: William Zhang <william.zhang@broadcom.com>
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>

authored by

William Zhang and committed by
Florian Fainelli
de1a99ac 865a7d67

+134
+1
arch/arm/boot/dts/Makefile
··· 184 184 dtb-$(CONFIG_ARCH_BCMBCA) += \ 185 185 bcm947622.dtb \ 186 186 bcm963178.dtb \ 187 + bcm96846.dtb \ 187 188 bcm96878.dtb 188 189 dtb-$(CONFIG_ARCH_CLPS711X) += \ 189 190 ep7211-edb7211.dtb
+103
arch/arm/boot/dts/bcm6846.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,bcm6846", "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 + 36 + L2_0: l2-cache0 { 37 + compatible = "cache"; 38 + }; 39 + }; 40 + 41 + timer { 42 + compatible = "arm,armv7-timer"; 43 + interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 44 + <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 45 + <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 46 + <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>; 47 + arm,cpu-registers-not-fw-configured; 48 + }; 49 + 50 + pmu: pmu { 51 + compatible = "arm,cortex-a7-pmu"; 52 + interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>, 53 + <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>; 54 + interrupt-affinity = <&CA7_0>, <&CA7_1>; 55 + }; 56 + 57 + clocks: clocks { 58 + periph_clk: periph-clk { 59 + compatible = "fixed-clock"; 60 + #clock-cells = <0>; 61 + clock-frequency = <200000000>; 62 + }; 63 + }; 64 + 65 + psci { 66 + compatible = "arm,psci-0.2"; 67 + method = "smc"; 68 + cpu_off = <1>; 69 + cpu_on = <2>; 70 + }; 71 + 72 + axi@81000000 { 73 + compatible = "simple-bus"; 74 + #address-cells = <1>; 75 + #size-cells = <1>; 76 + ranges = <0 0x81000000 0x4000>; 77 + 78 + gic: interrupt-controller@1000 { 79 + compatible = "arm,cortex-a7-gic"; 80 + #interrupt-cells = <3>; 81 + #address-cells = <0>; 82 + interrupt-controller; 83 + reg = <0x1000 0x1000>, 84 + <0x2000 0x2000>; 85 + }; 86 + }; 87 + 88 + bus@ff800000 { 89 + compatible = "simple-bus"; 90 + #address-cells = <1>; 91 + #size-cells = <1>; 92 + ranges = <0 0xff800000 0x800000>; 93 + 94 + uart0: serial@640 { 95 + compatible = "brcm,bcm6345-uart"; 96 + reg = <0x640 0x1b>; 97 + interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>; 98 + clocks = <&periph_clk>; 99 + clock-names = "refclk"; 100 + status = "disabled"; 101 + }; 102 + }; 103 + };
+30
arch/arm/boot/dts/bcm96846.dts
··· 1 + // SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2 + /* 3 + * Copyright 2022 Broadcom Ltd. 4 + */ 5 + 6 + /dts-v1/; 7 + 8 + #include "bcm6846.dtsi" 9 + 10 + / { 11 + model = "Broadcom BCM96846 Reference Board"; 12 + compatible = "brcm,bcm96846", "brcm,bcm6846", "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 + };