mirror of
https://github.com/Evolution-X-Devices/kernel_xiaomi_sm8450-devicetrees
synced 2026-01-27 14:44:08 +00:00
ARM: dts: msm: Add initial device tree for Cape
Add following initial nodes to support Cape
1. CPU Cluster Map
2. Interrupt Controller
3. Arch Timer & Mem Timer
Enable MTP,CDP,ATP devices for Cape
No Rumi Device Trees for Cape.
Change-Id: I8b15baa0a5da3630130c6fa7df9f523f586e43ba
This commit is contained in:
committed by
Gerrit - the friendly Code Review server
parent
aa3ee2274e
commit
28a74ad098
@@ -92,6 +92,9 @@ SoCs:
|
||||
- DIWALI
|
||||
compatible = "qcom,diwali"
|
||||
|
||||
- CAPE
|
||||
compatible = "qcom,cape"
|
||||
|
||||
- NEO
|
||||
compatible = "qcom,neo"
|
||||
|
||||
@@ -257,5 +260,8 @@ compatible = "qcom,waipiop-hdk"
|
||||
compatible = "qcom,waipiop-mtp"
|
||||
compatible = "qcom,waipiop-cdp"
|
||||
compatible = "qcom,waipiop-qrd"
|
||||
compatible = "qcom,cape-mtp"
|
||||
compatible = "qcom,cape-atp"
|
||||
compatible = "qcom,cape-cdp"
|
||||
compatible = "qcom,diwali-rumi"
|
||||
compatible = "qcom,neo-rumi"
|
||||
|
||||
@@ -166,6 +166,20 @@ else
|
||||
dtb-$(CONFIG_ARCH_DIWALI) += diwali-rumi.dtb
|
||||
endif
|
||||
|
||||
ifeq ($(CONFIG_BUILD_ARM64_DT_OVERLAY),y)
|
||||
dtbo-$(CONFIG_ARCH_CAPE) += cape-mtp-overlay.dtbo \
|
||||
cape-cdp-overlay.dtbo \
|
||||
cape-atp-overlay.dtbo
|
||||
|
||||
cape-mtp-overlay.dtbo-base := cape.dtb
|
||||
cape-cdp-overlay.dtbo-base := cape.dtb
|
||||
cape-atp-overlay.dtbo-base := cape.dtb
|
||||
else
|
||||
dtb-$(CONFIG_ARCH_CAPE) += cape-mtp.dtb \
|
||||
cape-cdp.dtb \
|
||||
cape-atp.dtb
|
||||
endif
|
||||
|
||||
ifeq ($(CONFIG_BUILD_ARM64_DT_OVERLAY),y)
|
||||
dtbo-$(CONFIG_ARCH_HOLI) += holi-rumi-overlay.dtbo
|
||||
dtbo-$(CONFIG_ARCH_HOLI) += holi-rumi-overlay.dtbo \
|
||||
|
||||
11
qcom/cape-atp-overlay.dts
Normal file
11
qcom/cape-atp-overlay.dts
Normal file
@@ -0,0 +1,11 @@
|
||||
/dts-v1/;
|
||||
/plugin/;
|
||||
|
||||
#include "cape-atp.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. Cape ATP";
|
||||
compatible = "qcom,cape-atp", "qcom,cape", "qcom,atp";
|
||||
qcom,msm-id = <530 0x10000>;
|
||||
qcom,board-id = <33 0>;
|
||||
};
|
||||
10
qcom/cape-atp.dts
Normal file
10
qcom/cape-atp.dts
Normal file
@@ -0,0 +1,10 @@
|
||||
/dts-v1/;
|
||||
|
||||
#include "cape.dtsi"
|
||||
#include "cape-atp.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. Cape ATP";
|
||||
compatible = "qcom,cape-atp", "qcom,cape", "qcom,atp";
|
||||
qcom,board-id = <33 0>;
|
||||
};
|
||||
1
qcom/cape-atp.dtsi
Normal file
1
qcom/cape-atp.dtsi
Normal file
@@ -0,0 +1 @@
|
||||
&soc { };
|
||||
11
qcom/cape-cdp-overlay.dts
Normal file
11
qcom/cape-cdp-overlay.dts
Normal file
@@ -0,0 +1,11 @@
|
||||
/dts-v1/;
|
||||
/plugin/;
|
||||
|
||||
#include "cape-cdp.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. Cape CDP";
|
||||
compatible = "qcom,cape-cdp", "qcom,cape", "qcom,cdp";
|
||||
qcom,msm-id = <530 0x10000>;
|
||||
qcom,board-id = <1 0>;
|
||||
};
|
||||
10
qcom/cape-cdp.dts
Normal file
10
qcom/cape-cdp.dts
Normal file
@@ -0,0 +1,10 @@
|
||||
/dts-v1/;
|
||||
|
||||
#include "cape.dtsi"
|
||||
#include "cape-cdp.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. Cape CDP";
|
||||
compatible = "qcom,cape-cdp", "qcom,cape", "qcom,cdp";
|
||||
qcom,board-id = <1 0>;
|
||||
};
|
||||
1
qcom/cape-cdp.dtsi
Normal file
1
qcom/cape-cdp.dtsi
Normal file
@@ -0,0 +1 @@
|
||||
&soc { };
|
||||
12
qcom/cape-mtp-overlay.dts
Normal file
12
qcom/cape-mtp-overlay.dts
Normal file
@@ -0,0 +1,12 @@
|
||||
/dts-v1/;
|
||||
/plugin/;
|
||||
|
||||
#include "cape-mtp.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. Cape MTP";
|
||||
compatible = "qcom,cape-mtp", "qcom,cape", "qcom,mtp";
|
||||
qcom,msm-id = <530 0x10000>;
|
||||
qcom,board-id = <8 0>;
|
||||
};
|
||||
|
||||
10
qcom/cape-mtp.dts
Normal file
10
qcom/cape-mtp.dts
Normal file
@@ -0,0 +1,10 @@
|
||||
/dts-v1/;
|
||||
|
||||
#include "cape.dtsi"
|
||||
#include "cape-mtp.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. Cape MTP";
|
||||
compatible = "qcom,cape-mtp", "qcom,cape", "qcom,mtp";
|
||||
qcom,board-id = <8 0>;
|
||||
};
|
||||
1
qcom/cape-mtp.dtsi
Normal file
1
qcom/cape-mtp.dtsi
Normal file
@@ -0,0 +1 @@
|
||||
&soc { };
|
||||
9
qcom/cape.dts
Normal file
9
qcom/cape.dts
Normal file
@@ -0,0 +1,9 @@
|
||||
/dts-v1/;
|
||||
|
||||
#include "cape.dtsi"
|
||||
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. Cape SoC";
|
||||
compatible = "qcom,cape";
|
||||
qcom,board-id = <0 0>;
|
||||
};
|
||||
260
qcom/cape.dtsi
Normal file
260
qcom/cape.dtsi
Normal file
@@ -0,0 +1,260 @@
|
||||
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
||||
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. Cape";
|
||||
compatible = "qcom,cape";
|
||||
qcom,msm-id = <530 0x10000>;
|
||||
interrupt-parent = <&intc>;
|
||||
|
||||
#address-cells = <2>;
|
||||
#size-cells = <2>;
|
||||
|
||||
chosen: chosen { };
|
||||
|
||||
memory { device_type = "memory"; reg = <0 0 0 0>; };
|
||||
|
||||
reserved_memory: reserved-memory { };
|
||||
|
||||
aliases { };
|
||||
|
||||
firmware: firmware { };
|
||||
|
||||
cpus {
|
||||
#address-cells = <2>;
|
||||
#size-cells = <0>;
|
||||
|
||||
CPU0: cpu@0 {
|
||||
device_type = "cpu";
|
||||
compatible = "qcom,kryo";
|
||||
reg = <0x0 0x0>;
|
||||
enable-method = "psci";
|
||||
next-level-cache = <&L2_0>;
|
||||
L2_0: l2-cache {
|
||||
compatible = "arm,arch-cache";
|
||||
cache-level = <2>;
|
||||
next-level-cache = <&L3_0>;
|
||||
|
||||
L3_0: l3-cache {
|
||||
compatible = "arm,arch-cache";
|
||||
cache-level = <3>;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
CPU1: cpu@100 {
|
||||
device_type = "cpu";
|
||||
compatible = "qcom,kryo";
|
||||
reg = <0x0 0x100>;
|
||||
enable-method = "psci";
|
||||
next-level-cache = <&L2_0>; /* silver L2 sharing */
|
||||
};
|
||||
|
||||
CPU2: cpu@200 {
|
||||
device_type = "cpu";
|
||||
compatible = "qcom,kryo";
|
||||
reg = <0x0 0x200>;
|
||||
enable-method = "psci";
|
||||
next-level-cache = <&L2_2>;
|
||||
L2_2: l2-cache {
|
||||
compatible = "arm,arch-cache";
|
||||
cache-level = <2>;
|
||||
next-level-cache = <&L3_0>;
|
||||
};
|
||||
};
|
||||
|
||||
CPU3: cpu@300 {
|
||||
device_type = "cpu";
|
||||
compatible = "qcom,kryo";
|
||||
reg = <0x0 0x300>;
|
||||
enable-method = "psci";
|
||||
next-level-cache = <&L2_2>; /* silver L2 sharing */
|
||||
};
|
||||
|
||||
CPU4: cpu@400 {
|
||||
device_type = "cpu";
|
||||
compatible = "qcom,kryo";
|
||||
reg = <0x0 0x400>;
|
||||
enable-method = "psci";
|
||||
next-level-cache = <&L2_4>;
|
||||
L2_4: l2-cache {
|
||||
compatible = "arm,arch-cache";
|
||||
cache-level = <2>;
|
||||
next-level-cache = <&L3_0>;
|
||||
};
|
||||
};
|
||||
|
||||
CPU5: cpu@500 {
|
||||
device_type = "cpu";
|
||||
compatible = "qcom,kryo";
|
||||
reg = <0x0 0x500>;
|
||||
enable-method = "psci";
|
||||
next-level-cache = <&L2_5>;
|
||||
L2_5: l2-cache {
|
||||
compatible = "arm,arch-cache";
|
||||
cache-level = <2>;
|
||||
next-level-cache = <&L3_0>;
|
||||
};
|
||||
};
|
||||
|
||||
CPU6: cpu@600 {
|
||||
device_type = "cpu";
|
||||
compatible = "qcom,kryo";
|
||||
reg = <0x0 0x600>;
|
||||
enable-method = "psci";
|
||||
next-level-cache = <&L2_6>;
|
||||
L2_6: l2-cache {
|
||||
compatible = "arm,arch-cache";
|
||||
cache-level = <2>;
|
||||
next-level-cache = <&L3_0>;
|
||||
};
|
||||
};
|
||||
|
||||
CPU7: cpu@700 {
|
||||
device_type = "cpu";
|
||||
compatible = "qcom,kryo";
|
||||
reg = <0x0 0x700>;
|
||||
enable-method = "psci";
|
||||
next-level-cache = <&L2_7>;
|
||||
L2_7: l2-cache {
|
||||
compatible = "arm,arch-cache";
|
||||
cache-level = <2>;
|
||||
next-level-cache = <&L3_0>;
|
||||
};
|
||||
};
|
||||
|
||||
cpu-map {
|
||||
cluster0 {
|
||||
core0 {
|
||||
cpu = <&CPU0>;
|
||||
};
|
||||
|
||||
core1 {
|
||||
cpu = <&CPU1>;
|
||||
};
|
||||
|
||||
core2 {
|
||||
cpu = <&CPU2>;
|
||||
};
|
||||
|
||||
core3 {
|
||||
cpu = <&CPU3>;
|
||||
};
|
||||
};
|
||||
|
||||
cluster1 {
|
||||
core0 {
|
||||
cpu = <&CPU4>;
|
||||
};
|
||||
|
||||
core1 {
|
||||
cpu = <&CPU5>;
|
||||
};
|
||||
|
||||
core2 {
|
||||
cpu = <&CPU6>;
|
||||
};
|
||||
};
|
||||
|
||||
cluster2 {
|
||||
core0 {
|
||||
cpu = <&CPU7>;
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
soc: soc { };
|
||||
};
|
||||
|
||||
&firmware {
|
||||
qcom_scm {
|
||||
compatible = "qcom,scm";
|
||||
};
|
||||
};
|
||||
|
||||
&soc {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
ranges = <0 0 0 0xffffffff>;
|
||||
compatible = "simple-bus";
|
||||
|
||||
intc: interrupt-controller@17100000 {
|
||||
compatible = "arm,gic-v3";
|
||||
#interrupt-cells = <3>;
|
||||
interrupt-controller;
|
||||
#redistributor-regions = <1>;
|
||||
redistributor-stride = <0x0 0x40000>;
|
||||
reg = <0x17100000 0x10000>, /* GICD */
|
||||
<0x17180000 0x200000>; /* GICR * 8 */
|
||||
interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_LOW>;
|
||||
};
|
||||
|
||||
arch_timer: timer {
|
||||
compatible = "arm,armv8-timer";
|
||||
interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
|
||||
<GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
|
||||
<GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
|
||||
<GIC_PPI 12 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>;
|
||||
clock-frequency = <19200000>;
|
||||
};
|
||||
|
||||
memtimer: timer@17420000 {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
ranges;
|
||||
compatible = "arm,armv7-timer-mem";
|
||||
reg = <0x17420000 0x1000>;
|
||||
clock-frequency = <19200000>;
|
||||
|
||||
frame@17421000 {
|
||||
frame-number = <0>;
|
||||
interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>,
|
||||
<GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
|
||||
reg = <0x17421000 0x1000>,
|
||||
<0x17422000 0x1000>;
|
||||
};
|
||||
|
||||
frame@17423000 {
|
||||
frame-number = <1>;
|
||||
interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
|
||||
reg = <0x17423000 0x1000>;
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
frame@17425000 {
|
||||
frame-number = <2>;
|
||||
interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
|
||||
reg = <0x17425000 0x1000>;
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
frame@17427000 {
|
||||
frame-number = <3>;
|
||||
interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
|
||||
reg = <0x17427000 0x1000>;
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
frame@17429000 {
|
||||
frame-number = <4>;
|
||||
interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
|
||||
reg = <0x17429000 0x1000>;
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
frame@1742b000 {
|
||||
frame-number = <5>;
|
||||
interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
|
||||
reg = <0x1742b000 0x1000>;
|
||||
status = "disabled";
|
||||
};
|
||||
|
||||
frame@1742d000 {
|
||||
frame-number = <6>;
|
||||
interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
|
||||
reg = <0x1742d000 0x1000>;
|
||||
status = "disabled";
|
||||
};
|
||||
};
|
||||
|
||||
};
|
||||
Reference in New Issue
Block a user