bcm2837.dtsi 2.1 KB
Newer Older
1
#include "bcm283x.dtsi"
2
#include "bcm2835-common.dtsi"
3
#include "bcm2835-rpi-common.dtsi"
4 5

/ {
6
	compatible = "brcm,bcm2837";
7 8 9 10 11 12

	soc {
		ranges = <0x7e000000 0x3f000000 0x1000000>,
			 <0x40000000 0x40000000 0x00001000>;
		dma-ranges = <0xc0000000 0x00000000 0x3f000000>;

13
		local_intc: local_intc@40000000 {
14 15 16
			compatible = "brcm,bcm2836-l1-intc";
			reg = <0x40000000 0x100>;
			interrupt-controller;
17
			#interrupt-cells = <2>;
18 19 20 21
			interrupt-parent = <&local_intc>;
		};
	};

22 23 24 25 26 27
	arm-pmu {
		compatible = "arm,cortex-a53-pmu";
		interrupt-parent = <&local_intc>;
		interrupts = <9 IRQ_TYPE_LEVEL_HIGH>;
	};

28 29 30
	timer {
		compatible = "arm,armv7-timer";
		interrupt-parent = <&local_intc>;
31 32 33 34
		interrupts = <0 IRQ_TYPE_LEVEL_HIGH>, // PHYS_SECURE_PPI
			     <1 IRQ_TYPE_LEVEL_HIGH>, // PHYS_NONSECURE_PPI
			     <3 IRQ_TYPE_LEVEL_HIGH>, // VIRT_PPI
			     <2 IRQ_TYPE_LEVEL_HIGH>; // HYP_PPI
35 36 37 38 39 40
		always-on;
	};

	cpus: cpus {
		#address-cells = <1>;
		#size-cells = <0>;
41
		enable-method = "brcm,bcm2836-smp"; // for ARM 32-bit
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83

		cpu0: cpu@0 {
			device_type = "cpu";
			compatible = "arm,cortex-a53";
			reg = <0>;
			enable-method = "spin-table";
			cpu-release-addr = <0x0 0x000000d8>;
		};

		cpu1: cpu@1 {
			device_type = "cpu";
			compatible = "arm,cortex-a53";
			reg = <1>;
			enable-method = "spin-table";
			cpu-release-addr = <0x0 0x000000e0>;
		};

		cpu2: cpu@2 {
			device_type = "cpu";
			compatible = "arm,cortex-a53";
			reg = <2>;
			enable-method = "spin-table";
			cpu-release-addr = <0x0 0x000000e8>;
		};

		cpu3: cpu@3 {
			device_type = "cpu";
			compatible = "arm,cortex-a53";
			reg = <3>;
			enable-method = "spin-table";
			cpu-release-addr = <0x0 0x000000f0>;
		};
	};
};

/* Make the BCM2835-style global interrupt controller be a child of the
 * CPU-local interrupt controller.
 */
&intc {
	compatible = "brcm,bcm2836-armctrl-ic";
	reg = <0x7e00b200 0x200>;
	interrupt-parent = <&local_intc>;
84
	interrupts = <8 IRQ_TYPE_LEVEL_HIGH>;
85
};
86

87 88 89 90
&cpu_thermal {
	coefficients = <(-538)	412000>;
};

91 92 93 94 95
/* enable thermal sensor with the correct compatible property set */
&thermal {
	compatible = "brcm,bcm2837-thermal";
	status = "okay";
};