2020-02-11 20:48:25 +08:00
|
|
|
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
|
|
|
|
/*
|
|
|
|
* Copyright 2019 NXP
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <dt-bindings/clock/imx8mp-clock.h>
|
2022-03-30 12:46:19 +02:00
|
|
|
#include <dt-bindings/power/imx8mp-power.h>
|
2022-09-02 16:58:01 +08:00
|
|
|
#include <dt-bindings/reset/imx8mp-reset.h>
|
2025-03-20 14:09:51 +02:00
|
|
|
#include <dt-bindings/reset/imx8mp-reset-audiomix.h>
|
2020-02-11 20:48:25 +08:00
|
|
|
#include <dt-bindings/gpio/gpio.h>
|
|
|
|
#include <dt-bindings/input/input.h>
|
2022-07-08 16:56:31 +08:00
|
|
|
#include <dt-bindings/interconnect/fsl,imx8mp.h>
|
2020-02-11 20:48:25 +08:00
|
|
|
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
2020-04-03 20:03:24 +08:00
|
|
|
#include <dt-bindings/thermal/thermal.h>
|
2020-02-11 20:48:25 +08:00
|
|
|
|
|
|
|
#include "imx8mp-pinfunc.h"
|
|
|
|
|
|
|
|
/ {
|
|
|
|
interrupt-parent = <&gic>;
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
|
|
|
|
aliases {
|
|
|
|
ethernet0 = &fec;
|
2021-02-28 22:18:33 +01:00
|
|
|
ethernet1 = &eqos;
|
2020-02-11 20:48:25 +08:00
|
|
|
gpio0 = &gpio1;
|
|
|
|
gpio1 = &gpio2;
|
|
|
|
gpio2 = &gpio3;
|
|
|
|
gpio3 = &gpio4;
|
|
|
|
gpio4 = &gpio5;
|
2020-05-20 10:02:46 +08:00
|
|
|
i2c0 = &i2c1;
|
|
|
|
i2c1 = &i2c2;
|
|
|
|
i2c2 = &i2c3;
|
|
|
|
i2c3 = &i2c4;
|
|
|
|
i2c4 = &i2c5;
|
|
|
|
i2c5 = &i2c6;
|
2020-02-11 20:48:25 +08:00
|
|
|
mmc0 = &usdhc1;
|
|
|
|
mmc1 = &usdhc2;
|
|
|
|
mmc2 = &usdhc3;
|
|
|
|
serial0 = &uart1;
|
|
|
|
serial1 = &uart2;
|
|
|
|
serial2 = &uart3;
|
|
|
|
serial3 = &uart4;
|
2021-03-09 06:31:15 +01:00
|
|
|
spi0 = &flexspi;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
cpus {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
2024-10-07 15:44:24 +02:00
|
|
|
idle-states {
|
|
|
|
entry-method = "psci";
|
|
|
|
|
|
|
|
cpu_pd_wait: cpu-pd-wait {
|
|
|
|
compatible = "arm,idle-state";
|
|
|
|
arm,psci-suspend-param = <0x0010033>;
|
|
|
|
local-timer-stop;
|
|
|
|
entry-latency-us = <1000>;
|
|
|
|
exit-latency-us = <700>;
|
|
|
|
min-residency-us = <2700>;
|
|
|
|
wakeup-latency-us = <1500>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
A53_0: cpu@0 {
|
|
|
|
device_type = "cpu";
|
|
|
|
compatible = "arm,cortex-a53";
|
|
|
|
reg = <0x0>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_ARM>;
|
|
|
|
enable-method = "psci";
|
2021-11-12 14:26:02 +08:00
|
|
|
i-cache-size = <0x8000>;
|
|
|
|
i-cache-line-size = <64>;
|
|
|
|
i-cache-sets = <256>;
|
|
|
|
d-cache-size = <0x8000>;
|
|
|
|
d-cache-line-size = <64>;
|
|
|
|
d-cache-sets = <128>;
|
2020-02-11 20:48:25 +08:00
|
|
|
next-level-cache = <&A53_L2>;
|
2022-03-11 18:23:51 +01:00
|
|
|
nvmem-cells = <&cpu_speed_grade>;
|
|
|
|
nvmem-cell-names = "speed_grade";
|
2022-03-11 18:23:52 +01:00
|
|
|
operating-points-v2 = <&a53_opp_table>;
|
2020-04-03 20:03:24 +08:00
|
|
|
#cooling-cells = <2>;
|
2024-10-07 15:44:24 +02:00
|
|
|
cpu-idle-states = <&cpu_pd_wait>;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
A53_1: cpu@1 {
|
|
|
|
device_type = "cpu";
|
|
|
|
compatible = "arm,cortex-a53";
|
|
|
|
reg = <0x1>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_ARM>;
|
|
|
|
enable-method = "psci";
|
2021-11-12 14:26:02 +08:00
|
|
|
i-cache-size = <0x8000>;
|
|
|
|
i-cache-line-size = <64>;
|
|
|
|
i-cache-sets = <256>;
|
|
|
|
d-cache-size = <0x8000>;
|
|
|
|
d-cache-line-size = <64>;
|
|
|
|
d-cache-sets = <128>;
|
2020-02-11 20:48:25 +08:00
|
|
|
next-level-cache = <&A53_L2>;
|
2022-03-11 18:23:52 +01:00
|
|
|
operating-points-v2 = <&a53_opp_table>;
|
2020-04-03 20:03:24 +08:00
|
|
|
#cooling-cells = <2>;
|
2024-10-07 15:44:24 +02:00
|
|
|
cpu-idle-states = <&cpu_pd_wait>;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
A53_2: cpu@2 {
|
|
|
|
device_type = "cpu";
|
|
|
|
compatible = "arm,cortex-a53";
|
|
|
|
reg = <0x2>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_ARM>;
|
|
|
|
enable-method = "psci";
|
2021-11-12 14:26:02 +08:00
|
|
|
i-cache-size = <0x8000>;
|
|
|
|
i-cache-line-size = <64>;
|
|
|
|
i-cache-sets = <256>;
|
|
|
|
d-cache-size = <0x8000>;
|
|
|
|
d-cache-line-size = <64>;
|
|
|
|
d-cache-sets = <128>;
|
2020-02-11 20:48:25 +08:00
|
|
|
next-level-cache = <&A53_L2>;
|
2022-03-11 18:23:52 +01:00
|
|
|
operating-points-v2 = <&a53_opp_table>;
|
2020-04-03 20:03:24 +08:00
|
|
|
#cooling-cells = <2>;
|
2024-10-07 15:44:24 +02:00
|
|
|
cpu-idle-states = <&cpu_pd_wait>;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
A53_3: cpu@3 {
|
|
|
|
device_type = "cpu";
|
|
|
|
compatible = "arm,cortex-a53";
|
|
|
|
reg = <0x3>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_ARM>;
|
|
|
|
enable-method = "psci";
|
2021-11-12 14:26:02 +08:00
|
|
|
i-cache-size = <0x8000>;
|
|
|
|
i-cache-line-size = <64>;
|
|
|
|
i-cache-sets = <256>;
|
|
|
|
d-cache-size = <0x8000>;
|
|
|
|
d-cache-line-size = <64>;
|
|
|
|
d-cache-sets = <128>;
|
2020-02-11 20:48:25 +08:00
|
|
|
next-level-cache = <&A53_L2>;
|
2022-03-11 18:23:52 +01:00
|
|
|
operating-points-v2 = <&a53_opp_table>;
|
2020-04-03 20:03:24 +08:00
|
|
|
#cooling-cells = <2>;
|
2024-10-07 15:44:24 +02:00
|
|
|
cpu-idle-states = <&cpu_pd_wait>;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
A53_L2: l2-cache0 {
|
|
|
|
compatible = "cache";
|
2022-11-07 16:57:01 +01:00
|
|
|
cache-unified;
|
2021-11-12 14:26:02 +08:00
|
|
|
cache-level = <2>;
|
|
|
|
cache-size = <0x80000>;
|
|
|
|
cache-line-size = <64>;
|
|
|
|
cache-sets = <512>;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-03-11 18:23:52 +01:00
|
|
|
a53_opp_table: opp-table {
|
|
|
|
compatible = "operating-points-v2";
|
|
|
|
opp-shared;
|
|
|
|
|
|
|
|
opp-1200000000 {
|
|
|
|
opp-hz = /bits/ 64 <1200000000>;
|
|
|
|
opp-microvolt = <850000>;
|
|
|
|
opp-supported-hw = <0x8a0>, <0x7>;
|
|
|
|
clock-latency-ns = <150000>;
|
|
|
|
opp-suspend;
|
|
|
|
};
|
|
|
|
|
|
|
|
opp-1600000000 {
|
|
|
|
opp-hz = /bits/ 64 <1600000000>;
|
|
|
|
opp-microvolt = <950000>;
|
|
|
|
opp-supported-hw = <0xa0>, <0x7>;
|
|
|
|
clock-latency-ns = <150000>;
|
|
|
|
opp-suspend;
|
|
|
|
};
|
|
|
|
|
|
|
|
opp-1800000000 {
|
|
|
|
opp-hz = /bits/ 64 <1800000000>;
|
|
|
|
opp-microvolt = <1000000>;
|
|
|
|
opp-supported-hw = <0x20>, <0x3>;
|
|
|
|
clock-latency-ns = <150000>;
|
|
|
|
opp-suspend;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
osc_32k: clock-osc-32k {
|
|
|
|
compatible = "fixed-clock";
|
|
|
|
#clock-cells = <0>;
|
|
|
|
clock-frequency = <32768>;
|
|
|
|
clock-output-names = "osc_32k";
|
|
|
|
};
|
|
|
|
|
|
|
|
osc_24m: clock-osc-24m {
|
|
|
|
compatible = "fixed-clock";
|
|
|
|
#clock-cells = <0>;
|
|
|
|
clock-frequency = <24000000>;
|
|
|
|
clock-output-names = "osc_24m";
|
|
|
|
};
|
|
|
|
|
|
|
|
clk_ext1: clock-ext1 {
|
|
|
|
compatible = "fixed-clock";
|
|
|
|
#clock-cells = <0>;
|
|
|
|
clock-frequency = <133000000>;
|
|
|
|
clock-output-names = "clk_ext1";
|
|
|
|
};
|
|
|
|
|
|
|
|
clk_ext2: clock-ext2 {
|
|
|
|
compatible = "fixed-clock";
|
|
|
|
#clock-cells = <0>;
|
|
|
|
clock-frequency = <133000000>;
|
|
|
|
clock-output-names = "clk_ext2";
|
|
|
|
};
|
|
|
|
|
|
|
|
clk_ext3: clock-ext3 {
|
|
|
|
compatible = "fixed-clock";
|
|
|
|
#clock-cells = <0>;
|
|
|
|
clock-frequency = <133000000>;
|
|
|
|
clock-output-names = "clk_ext3";
|
|
|
|
};
|
|
|
|
|
|
|
|
clk_ext4: clock-ext4 {
|
|
|
|
compatible = "fixed-clock";
|
|
|
|
#clock-cells = <0>;
|
2022-05-26 22:42:56 +02:00
|
|
|
clock-frequency = <133000000>;
|
2020-02-11 20:48:25 +08:00
|
|
|
clock-output-names = "clk_ext4";
|
|
|
|
};
|
|
|
|
|
2023-09-06 08:54:43 -03:00
|
|
|
funnel {
|
|
|
|
/*
|
|
|
|
* non-configurable funnel don't show up on the AMBA
|
|
|
|
* bus. As such no need to add "arm,primecell".
|
|
|
|
*/
|
|
|
|
compatible = "arm,coresight-static-funnel";
|
|
|
|
|
|
|
|
in-ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
|
|
|
|
ca_funnel_in_port0: endpoint {
|
|
|
|
remote-endpoint = <&etm0_out_port>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
ca_funnel_in_port1: endpoint {
|
|
|
|
remote-endpoint = <&etm1_out_port>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@2 {
|
|
|
|
reg = <2>;
|
|
|
|
|
|
|
|
ca_funnel_in_port2: endpoint {
|
|
|
|
remote-endpoint = <&etm2_out_port>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@3 {
|
|
|
|
reg = <3>;
|
|
|
|
|
|
|
|
ca_funnel_in_port3: endpoint {
|
|
|
|
remote-endpoint = <&etm3_out_port>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
out-ports {
|
|
|
|
port {
|
|
|
|
|
|
|
|
ca_funnel_out_port0: endpoint {
|
|
|
|
remote-endpoint = <&hugo_funnel_in_port0>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-07-23 14:05:40 +03:00
|
|
|
reserved-memory {
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
ranges;
|
|
|
|
|
|
|
|
dsp_reserved: dsp@92400000 {
|
2025-03-20 14:09:53 +02:00
|
|
|
reg = <0 0x92400000 0 0x1000000>;
|
2021-07-23 14:05:40 +03:00
|
|
|
no-map;
|
2023-10-25 09:28:32 +02:00
|
|
|
status = "disabled";
|
2021-07-23 14:05:40 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-09-29 17:15:22 +08:00
|
|
|
pmu {
|
|
|
|
compatible = "arm,cortex-a53-pmu";
|
|
|
|
interrupts = <GIC_PPI 7
|
|
|
|
(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
psci {
|
|
|
|
compatible = "arm,psci-1.0";
|
|
|
|
method = "smc";
|
|
|
|
};
|
|
|
|
|
2020-04-03 20:03:24 +08:00
|
|
|
thermal-zones {
|
|
|
|
cpu-thermal {
|
|
|
|
polling-delay-passive = <250>;
|
|
|
|
polling-delay = <2000>;
|
|
|
|
thermal-sensors = <&tmu 0>;
|
|
|
|
trips {
|
|
|
|
cpu_alert0: trip0 {
|
|
|
|
temperature = <85000>;
|
|
|
|
hysteresis = <2000>;
|
|
|
|
type = "passive";
|
|
|
|
};
|
|
|
|
|
|
|
|
cpu_crit0: trip1 {
|
|
|
|
temperature = <95000>;
|
|
|
|
hysteresis = <2000>;
|
|
|
|
type = "critical";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
cooling-maps {
|
|
|
|
map0 {
|
|
|
|
trip = <&cpu_alert0>;
|
|
|
|
cooling-device =
|
|
|
|
<&A53_0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&A53_1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&A53_2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
2025-05-08 10:18:02 +00:00
|
|
|
<&A53_3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&gpu3d THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&gpu2d THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&npu THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
|
2020-04-03 20:03:24 +08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
soc-thermal {
|
|
|
|
polling-delay-passive = <250>;
|
|
|
|
polling-delay = <2000>;
|
|
|
|
thermal-sensors = <&tmu 1>;
|
|
|
|
trips {
|
|
|
|
soc_alert0: trip0 {
|
|
|
|
temperature = <85000>;
|
|
|
|
hysteresis = <2000>;
|
|
|
|
type = "passive";
|
|
|
|
};
|
|
|
|
|
|
|
|
soc_crit0: trip1 {
|
|
|
|
temperature = <95000>;
|
|
|
|
hysteresis = <2000>;
|
|
|
|
type = "critical";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
cooling-maps {
|
|
|
|
map0 {
|
|
|
|
trip = <&soc_alert0>;
|
|
|
|
cooling-device =
|
|
|
|
<&A53_0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&A53_1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&A53_2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
2025-05-08 10:18:02 +00:00
|
|
|
<&A53_3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&gpu3d THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&gpu2d THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
|
|
|
|
<&npu THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
|
2020-04-03 20:03:24 +08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
timer {
|
|
|
|
compatible = "arm,armv8-timer";
|
2020-09-29 10:40:15 +02:00
|
|
|
interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
|
|
|
|
<GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
|
|
|
|
<GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
|
|
|
|
<GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
|
2020-02-11 20:48:25 +08:00
|
|
|
clock-frequency = <8000000>;
|
|
|
|
arm,no-tick-in-suspend;
|
|
|
|
};
|
|
|
|
|
2022-06-14 13:39:43 -03:00
|
|
|
soc: soc@0 {
|
2021-01-04 17:15:42 +08:00
|
|
|
compatible = "fsl,imx8mp-soc", "simple-bus";
|
2020-02-11 20:48:25 +08:00
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges = <0x0 0x0 0x0 0x3e000000>;
|
2021-01-04 17:15:43 +08:00
|
|
|
nvmem-cells = <&imx8mp_uid>;
|
|
|
|
nvmem-cell-names = "soc_unique_id";
|
2020-02-11 20:48:25 +08:00
|
|
|
|
2023-05-15 11:01:49 -04:00
|
|
|
etm0: etm@28440000 {
|
|
|
|
compatible = "arm,coresight-etm4x", "arm,primecell";
|
2023-07-05 16:59:53 -04:00
|
|
|
reg = <0x28440000 0x1000>;
|
2023-05-15 11:01:49 -04:00
|
|
|
cpu = <&A53_0>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MAIN_AXI>;
|
|
|
|
clock-names = "apb_pclk";
|
|
|
|
|
|
|
|
out-ports {
|
|
|
|
port {
|
|
|
|
etm0_out_port: endpoint {
|
|
|
|
remote-endpoint = <&ca_funnel_in_port0>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
etm1: etm@28540000 {
|
|
|
|
compatible = "arm,coresight-etm4x", "arm,primecell";
|
2023-07-05 16:59:53 -04:00
|
|
|
reg = <0x28540000 0x1000>;
|
2023-05-15 11:01:49 -04:00
|
|
|
cpu = <&A53_1>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MAIN_AXI>;
|
|
|
|
clock-names = "apb_pclk";
|
|
|
|
|
|
|
|
out-ports {
|
|
|
|
port {
|
|
|
|
etm1_out_port: endpoint {
|
|
|
|
remote-endpoint = <&ca_funnel_in_port1>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
etm2: etm@28640000 {
|
|
|
|
compatible = "arm,coresight-etm4x", "arm,primecell";
|
2023-07-05 16:59:53 -04:00
|
|
|
reg = <0x28640000 0x1000>;
|
2023-05-15 11:01:49 -04:00
|
|
|
cpu = <&A53_2>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MAIN_AXI>;
|
|
|
|
clock-names = "apb_pclk";
|
|
|
|
|
|
|
|
out-ports {
|
|
|
|
port {
|
|
|
|
etm2_out_port: endpoint {
|
|
|
|
remote-endpoint = <&ca_funnel_in_port2>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
etm3: etm@28740000 {
|
|
|
|
compatible = "arm,coresight-etm4x", "arm,primecell";
|
2023-07-05 16:59:53 -04:00
|
|
|
reg = <0x28740000 0x1000>;
|
2023-05-15 11:01:49 -04:00
|
|
|
cpu = <&A53_3>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MAIN_AXI>;
|
|
|
|
clock-names = "apb_pclk";
|
|
|
|
|
|
|
|
out-ports {
|
|
|
|
port {
|
|
|
|
etm3_out_port: endpoint {
|
|
|
|
remote-endpoint = <&ca_funnel_in_port3>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
funnel@28c03000 {
|
|
|
|
compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
|
|
|
|
reg = <0x28c03000 0x1000>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MAIN_AXI>;
|
|
|
|
clock-names = "apb_pclk";
|
|
|
|
|
|
|
|
in-ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
|
|
|
|
hugo_funnel_in_port0: endpoint {
|
|
|
|
remote-endpoint = <&ca_funnel_out_port0>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
hugo_funnel_in_port1: endpoint {
|
|
|
|
/* M7 input */
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@2 {
|
|
|
|
reg = <2>;
|
|
|
|
|
|
|
|
hugo_funnel_in_port2: endpoint {
|
|
|
|
/* DSP input */
|
|
|
|
};
|
|
|
|
};
|
|
|
|
/* the other input ports are not connect to anything */
|
|
|
|
};
|
|
|
|
|
|
|
|
out-ports {
|
|
|
|
port {
|
|
|
|
hugo_funnel_out_port0: endpoint {
|
|
|
|
remote-endpoint = <&etf_in_port>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
etf@28c04000 {
|
|
|
|
compatible = "arm,coresight-tmc", "arm,primecell";
|
|
|
|
reg = <0x28c04000 0x1000>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MAIN_AXI>;
|
|
|
|
clock-names = "apb_pclk";
|
|
|
|
|
|
|
|
in-ports {
|
|
|
|
port {
|
|
|
|
etf_in_port: endpoint {
|
|
|
|
remote-endpoint = <&hugo_funnel_out_port0>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
out-ports {
|
|
|
|
port {
|
|
|
|
etf_out_port: endpoint {
|
|
|
|
remote-endpoint = <&etr_in_port>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
etr@28c06000 {
|
|
|
|
compatible = "arm,coresight-tmc", "arm,primecell";
|
|
|
|
reg = <0x28c06000 0x1000>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MAIN_AXI>;
|
|
|
|
clock-names = "apb_pclk";
|
|
|
|
|
|
|
|
in-ports {
|
|
|
|
port {
|
|
|
|
etr_in_port: endpoint {
|
|
|
|
remote-endpoint = <&etf_out_port>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
aips1: bus@30000000 {
|
2020-03-11 15:17:56 +08:00
|
|
|
compatible = "fsl,aips-bus", "simple-bus";
|
2020-03-31 15:37:25 -03:00
|
|
|
reg = <0x30000000 0x400000>;
|
2020-02-11 20:48:25 +08:00
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges;
|
|
|
|
|
|
|
|
gpio1: gpio@30200000 {
|
|
|
|
compatible = "fsl,imx8mp-gpio", "fsl,imx35-gpio";
|
|
|
|
reg = <0x30200000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPIO1_ROOT>;
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <2>;
|
|
|
|
gpio-ranges = <&iomuxc 0 5 30>;
|
|
|
|
};
|
|
|
|
|
|
|
|
gpio2: gpio@30210000 {
|
|
|
|
compatible = "fsl,imx8mp-gpio", "fsl,imx35-gpio";
|
|
|
|
reg = <0x30210000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPIO2_ROOT>;
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <2>;
|
|
|
|
gpio-ranges = <&iomuxc 0 35 21>;
|
|
|
|
};
|
|
|
|
|
|
|
|
gpio3: gpio@30220000 {
|
|
|
|
compatible = "fsl,imx8mp-gpio", "fsl,imx35-gpio";
|
|
|
|
reg = <0x30220000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPIO3_ROOT>;
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <2>;
|
2021-01-15 09:18:05 +08:00
|
|
|
gpio-ranges = <&iomuxc 0 56 26>, <&iomuxc 26 144 4>;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
gpio4: gpio@30230000 {
|
|
|
|
compatible = "fsl,imx8mp-gpio", "fsl,imx35-gpio";
|
|
|
|
reg = <0x30230000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPIO4_ROOT>;
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <2>;
|
|
|
|
gpio-ranges = <&iomuxc 0 82 32>;
|
|
|
|
};
|
|
|
|
|
|
|
|
gpio5: gpio@30240000 {
|
|
|
|
compatible = "fsl,imx8mp-gpio", "fsl,imx35-gpio";
|
|
|
|
reg = <0x30240000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPIO5_ROOT>;
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <2>;
|
|
|
|
gpio-ranges = <&iomuxc 0 114 30>;
|
|
|
|
};
|
|
|
|
|
2020-04-03 20:03:24 +08:00
|
|
|
tmu: tmu@30260000 {
|
|
|
|
compatible = "fsl,imx8mp-tmu";
|
|
|
|
reg = <0x30260000 0x10000>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_TSENSOR_ROOT>;
|
2022-12-02 17:23:52 +01:00
|
|
|
nvmem-cells = <&tmu_calib>;
|
|
|
|
nvmem-cell-names = "calib";
|
2020-04-03 20:03:24 +08:00
|
|
|
#thermal-sensor-cells = <1>;
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
wdog1: watchdog@30280000 {
|
|
|
|
compatible = "fsl,imx8mp-wdt", "fsl,imx21-wdt";
|
|
|
|
reg = <0x30280000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_WDOG1_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2021-03-07 18:30:03 +08:00
|
|
|
wdog2: watchdog@30290000 {
|
|
|
|
compatible = "fsl,imx8mp-wdt", "fsl,imx21-wdt";
|
|
|
|
reg = <0x30290000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_WDOG2_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
wdog3: watchdog@302a0000 {
|
|
|
|
compatible = "fsl,imx8mp-wdt", "fsl,imx21-wdt";
|
|
|
|
reg = <0x302a0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_WDOG3_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2023-03-27 19:35:26 +02:00
|
|
|
gpt1: timer@302d0000 {
|
|
|
|
compatible = "fsl,imx8mp-gpt", "fsl,imx6dl-gpt";
|
|
|
|
reg = <0x302d0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPT1_ROOT>, <&clk IMX8MP_CLK_GPT1>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
};
|
|
|
|
|
|
|
|
gpt2: timer@302e0000 {
|
|
|
|
compatible = "fsl,imx8mp-gpt", "fsl,imx6dl-gpt";
|
|
|
|
reg = <0x302e0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPT2_ROOT>, <&clk IMX8MP_CLK_GPT2>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
};
|
|
|
|
|
|
|
|
gpt3: timer@302f0000 {
|
|
|
|
compatible = "fsl,imx8mp-gpt", "fsl,imx6dl-gpt";
|
|
|
|
reg = <0x302f0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPT3_ROOT>, <&clk IMX8MP_CLK_GPT3>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
iomuxc: pinctrl@30330000 {
|
|
|
|
compatible = "fsl,imx8mp-iomuxc";
|
|
|
|
reg = <0x30330000 0x10000>;
|
|
|
|
};
|
|
|
|
|
2023-01-04 08:25:45 +08:00
|
|
|
gpr: syscon@30340000 {
|
2020-02-11 20:48:25 +08:00
|
|
|
compatible = "fsl,imx8mp-iomuxc-gpr", "syscon";
|
|
|
|
reg = <0x30340000 0x10000>;
|
|
|
|
};
|
|
|
|
|
2020-05-28 11:12:48 +08:00
|
|
|
ocotp: efuse@30350000 {
|
2020-06-11 09:36:53 +08:00
|
|
|
compatible = "fsl,imx8mp-ocotp", "fsl,imx8mm-ocotp", "syscon";
|
2020-02-11 20:48:25 +08:00
|
|
|
reg = <0x30350000 0x10000>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_OCOTP_ROOT>;
|
|
|
|
/* For nvmem subnodes */
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
|
2022-12-02 17:23:51 +01:00
|
|
|
/*
|
|
|
|
* The register address below maps to the MX8M
|
|
|
|
* Fusemap Description Table entries this way.
|
|
|
|
* Assuming
|
|
|
|
* reg = <ADDR SIZE>;
|
|
|
|
* then
|
|
|
|
* Fuse Address = (ADDR * 4) + 0x400
|
|
|
|
* Note that if SIZE is greater than 4, then
|
|
|
|
* each subsequent fuse is located at offset
|
|
|
|
* +0x10 in Fusemap Description Table (e.g.
|
|
|
|
* reg = <0x8 0x8> describes fuses 0x420 and
|
|
|
|
* 0x430).
|
|
|
|
*/
|
|
|
|
imx8mp_uid: unique-id@8 { /* 0x420-0x430 */
|
2021-01-04 17:15:43 +08:00
|
|
|
reg = <0x8 0x8>;
|
|
|
|
};
|
|
|
|
|
2022-12-02 17:23:51 +01:00
|
|
|
cpu_speed_grade: speed-grade@10 { /* 0x440 */
|
2020-02-11 20:48:25 +08:00
|
|
|
reg = <0x10 4>;
|
|
|
|
};
|
2021-01-16 16:44:30 +08:00
|
|
|
|
2022-12-02 17:23:51 +01:00
|
|
|
eth_mac1: mac-address@90 { /* 0x640 */
|
2021-01-16 16:44:30 +08:00
|
|
|
reg = <0x90 6>;
|
|
|
|
};
|
2021-11-23 16:05:06 +08:00
|
|
|
|
2022-12-02 17:23:51 +01:00
|
|
|
eth_mac2: mac-address@96 { /* 0x658 */
|
2021-11-23 16:05:06 +08:00
|
|
|
reg = <0x96 6>;
|
|
|
|
};
|
2022-12-02 17:23:52 +01:00
|
|
|
|
|
|
|
tmu_calib: calib@264 { /* 0xd90-0xdc0 */
|
|
|
|
reg = <0x264 0x10>;
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
2022-09-23 15:49:43 +08:00
|
|
|
anatop: clock-controller@30360000 {
|
|
|
|
compatible = "fsl,imx8mp-anatop", "fsl,imx8mm-anatop";
|
2020-02-11 20:48:25 +08:00
|
|
|
reg = <0x30360000 0x10000>;
|
2022-09-23 15:49:43 +08:00
|
|
|
#clock-cells = <1>;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
snvs: snvs@30370000 {
|
|
|
|
compatible = "fsl,sec-v4.0-mon","syscon", "simple-mfd";
|
|
|
|
reg = <0x30370000 0x10000>;
|
|
|
|
|
|
|
|
snvs_rtc: snvs-rtc-lp {
|
|
|
|
compatible = "fsl,sec-v4.0-mon-rtc-lp";
|
2023-07-02 20:51:48 +02:00
|
|
|
regmap = <&snvs>;
|
2020-02-11 20:48:25 +08:00
|
|
|
offset = <0x34>;
|
|
|
|
interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_SNVS_ROOT>;
|
|
|
|
clock-names = "snvs-rtc";
|
|
|
|
};
|
|
|
|
|
|
|
|
snvs_pwrkey: snvs-powerkey {
|
|
|
|
compatible = "fsl,sec-v4.0-pwrkey";
|
|
|
|
regmap = <&snvs>;
|
|
|
|
interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
|
2020-03-12 15:34:10 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_SNVS_ROOT>;
|
|
|
|
clock-names = "snvs-pwrkey";
|
2020-02-11 20:48:25 +08:00
|
|
|
linux,keycode = <KEY_POWER>;
|
|
|
|
wakeup-source;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2022-08-23 18:56:02 +02:00
|
|
|
|
|
|
|
snvs_lpgpr: snvs-lpgpr {
|
|
|
|
compatible = "fsl,imx8mp-snvs-lpgpr",
|
|
|
|
"fsl,imx7d-snvs-lpgpr";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
clk: clock-controller@30380000 {
|
|
|
|
compatible = "fsl,imx8mp-ccm";
|
|
|
|
reg = <0x30380000 0x10000>;
|
2023-10-12 10:31:21 +02:00
|
|
|
interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
|
2020-02-11 20:48:25 +08:00
|
|
|
#clock-cells = <1>;
|
|
|
|
clocks = <&osc_32k>, <&osc_24m>, <&clk_ext1>, <&clk_ext2>,
|
|
|
|
<&clk_ext3>, <&clk_ext4>;
|
|
|
|
clock-names = "osc_32k", "osc_24m", "clk_ext1", "clk_ext2",
|
|
|
|
"clk_ext3", "clk_ext4";
|
2020-05-07 13:56:10 +08:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_A53_SRC>,
|
|
|
|
<&clk IMX8MP_CLK_A53_CORE>,
|
|
|
|
<&clk IMX8MP_CLK_NOC>,
|
2020-02-11 20:48:25 +08:00
|
|
|
<&clk IMX8MP_CLK_NOC_IO>,
|
2023-06-02 21:10:13 +02:00
|
|
|
<&clk IMX8MP_CLK_GIC>;
|
2020-05-07 13:56:10 +08:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>,
|
|
|
|
<&clk IMX8MP_ARM_PLL_OUT>,
|
|
|
|
<&clk IMX8MP_SYS_PLL2_1000M>,
|
2020-02-11 20:48:25 +08:00
|
|
|
<&clk IMX8MP_SYS_PLL1_800M>,
|
2023-06-02 21:10:13 +02:00
|
|
|
<&clk IMX8MP_SYS_PLL2_500M>;
|
2020-05-07 13:56:10 +08:00
|
|
|
assigned-clock-rates = <0>, <0>,
|
|
|
|
<1000000000>,
|
2020-02-11 20:48:25 +08:00
|
|
|
<800000000>,
|
2023-06-02 21:10:13 +02:00
|
|
|
<500000000>;
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
2020-02-26 17:13:50 +08:00
|
|
|
|
|
|
|
src: reset-controller@30390000 {
|
|
|
|
compatible = "fsl,imx8mp-src", "syscon";
|
|
|
|
reg = <0x30390000 0x10000>;
|
2020-05-09 16:17:51 +08:00
|
|
|
interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
|
2020-02-26 17:13:50 +08:00
|
|
|
#reset-cells = <1>;
|
|
|
|
};
|
2022-03-30 12:46:19 +02:00
|
|
|
|
|
|
|
gpc: gpc@303a0000 {
|
|
|
|
compatible = "fsl,imx8mp-gpc";
|
|
|
|
reg = <0x303a0000 0x1000>;
|
|
|
|
interrupt-parent = <&gic>;
|
2022-12-17 12:08:48 -06:00
|
|
|
interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
|
2022-03-30 12:46:19 +02:00
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <3>;
|
|
|
|
|
|
|
|
pgc {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
2022-04-06 17:34:00 +02:00
|
|
|
pgc_mipi_phy1: power-domain@0 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_MIPI_PHY1>;
|
|
|
|
};
|
|
|
|
|
2022-04-06 17:33:59 +02:00
|
|
|
pgc_pcie_phy: power-domain@1 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_PCIE_PHY>;
|
|
|
|
};
|
|
|
|
|
|
|
|
pgc_usb1_phy: power-domain@2 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_USB1_PHY>;
|
|
|
|
};
|
|
|
|
|
|
|
|
pgc_usb2_phy: power-domain@3 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_USB2_PHY>;
|
|
|
|
};
|
|
|
|
|
2024-06-17 17:39:51 -05:00
|
|
|
pgc_mlmix: power-domain@4 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_MLMIX>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_ML_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_ML_AHB>,
|
|
|
|
<&clk IMX8MP_CLK_NPU_ROOT>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_ML_CORE>,
|
|
|
|
<&clk IMX8MP_CLK_ML_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_ML_AHB>;
|
2025-02-04 19:27:37 +01:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_1000M>,
|
2024-06-17 17:39:51 -05:00
|
|
|
<&clk IMX8MP_SYS_PLL1_800M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL1_800M>;
|
2025-02-04 19:27:37 +01:00
|
|
|
assigned-clock-rates = <1000000000>,
|
2024-06-17 17:39:51 -05:00
|
|
|
<800000000>,
|
2025-02-04 19:27:37 +01:00
|
|
|
<400000000>;
|
2024-06-17 17:39:51 -05:00
|
|
|
};
|
|
|
|
|
2023-05-08 13:42:35 +02:00
|
|
|
pgc_audio: power-domain@5 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_AUDIOMIX>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_AUDIO_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_AUDIO_AXI>;
|
arm64: dts: imx8mp: Fix SDMA2/3 clocks
Commit 16c984524862 ("arm64: dts: imx8mp: don't initialize audio clocks
from CCM node") removed the Audio clocks from the main clock node, because
the intent is to force people to setup the audio PLL clocks per board
instead of having a common set of rates, since not all boards may use
the various audio PLL clocks in the same way.
Unfortunately, with this parenting removed, the SDMA2 and SDMA3
clocks were slowed to 24MHz because the SDMA2/3 clocks are controlled
via the audio_blk_ctrl which is clocked from IMX8MP_CLK_AUDIO_ROOT,
and that clock is enabled by pgc_audio.
Per the TRM, "The SDMA2/3 target frequency is 400MHz IPG and 400MHz
AHB, always 1:1 mode, to make sure there is enough throughput for all
the audio use cases."
Instead of cluttering the clock node, place the clock rate and parent
information into the pgc_audio node.
With the parenting and clock rates restored for IMX8MP_CLK_AUDIO_AHB,
and IMX8MP_CLK_AUDIO_AXI_SRC, it appears the SDMA2 and SDMA3 run at
400MHz again.
Fixes: 16c984524862 ("arm64: dts: imx8mp: don't initialize audio clocks from CCM node")
Signed-off-by: Adam Ford <aford173@gmail.com>
Reviewed-by: Lucas Stach <l.stach@pengutronix.de>
Reviewed-by: Fabio Estevam <festevam@gmail.com>
Signed-off-by: Shawn Guo <shawnguo@kernel.org>
2023-08-19 05:50:01 -05:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_AUDIO_AHB>,
|
|
|
|
<&clk IMX8MP_CLK_AUDIO_AXI_SRC>;
|
2023-11-24 10:51:04 +01:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL1_800M>;
|
arm64: dts: imx8mp: Fix SDMA2/3 clocks
Commit 16c984524862 ("arm64: dts: imx8mp: don't initialize audio clocks
from CCM node") removed the Audio clocks from the main clock node, because
the intent is to force people to setup the audio PLL clocks per board
instead of having a common set of rates, since not all boards may use
the various audio PLL clocks in the same way.
Unfortunately, with this parenting removed, the SDMA2 and SDMA3
clocks were slowed to 24MHz because the SDMA2/3 clocks are controlled
via the audio_blk_ctrl which is clocked from IMX8MP_CLK_AUDIO_ROOT,
and that clock is enabled by pgc_audio.
Per the TRM, "The SDMA2/3 target frequency is 400MHz IPG and 400MHz
AHB, always 1:1 mode, to make sure there is enough throughput for all
the audio use cases."
Instead of cluttering the clock node, place the clock rate and parent
information into the pgc_audio node.
With the parenting and clock rates restored for IMX8MP_CLK_AUDIO_AHB,
and IMX8MP_CLK_AUDIO_AXI_SRC, it appears the SDMA2 and SDMA3 run at
400MHz again.
Fixes: 16c984524862 ("arm64: dts: imx8mp: don't initialize audio clocks from CCM node")
Signed-off-by: Adam Ford <aford173@gmail.com>
Reviewed-by: Lucas Stach <l.stach@pengutronix.de>
Reviewed-by: Fabio Estevam <festevam@gmail.com>
Signed-off-by: Shawn Guo <shawnguo@kernel.org>
2023-08-19 05:50:01 -05:00
|
|
|
assigned-clock-rates = <400000000>,
|
2025-02-26 11:45:13 -05:00
|
|
|
<800000000>;
|
2023-05-08 13:42:35 +02:00
|
|
|
};
|
|
|
|
|
2022-03-30 12:46:19 +02:00
|
|
|
pgc_gpu2d: power-domain@6 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_GPU2D>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPU2D_ROOT>;
|
|
|
|
power-domains = <&pgc_gpumix>;
|
|
|
|
};
|
|
|
|
|
|
|
|
pgc_gpumix: power-domain@7 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_GPUMIX>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPU_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_GPU_AHB>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_GPU_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_GPU_AHB>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL1_800M>;
|
|
|
|
assigned-clock-rates = <800000000>, <400000000>;
|
|
|
|
};
|
|
|
|
|
2024-06-19 05:10:44 -05:00
|
|
|
pgc_vpumix: power-domain@8 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_VPUMIX>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_VPU_ROOT>;
|
|
|
|
};
|
|
|
|
|
2022-03-30 12:46:19 +02:00
|
|
|
pgc_gpu3d: power-domain@9 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_GPU3D>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPU3D_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_GPU3D_SHADER_CORE>;
|
|
|
|
power-domains = <&pgc_gpumix>;
|
|
|
|
};
|
2022-04-06 17:33:59 +02:00
|
|
|
|
2022-04-06 17:34:00 +02:00
|
|
|
pgc_mediamix: power-domain@10 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_MEDIAMIX>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_AXI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>;
|
|
|
|
};
|
|
|
|
|
2024-06-19 05:10:44 -05:00
|
|
|
pgc_vpu_g1: power-domain@11 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_VPU_G1>;
|
|
|
|
};
|
|
|
|
|
|
|
|
pgc_vpu_g2: power-domain@12 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_VPU_G2>;
|
|
|
|
};
|
|
|
|
|
|
|
|
pgc_vpu_vc8000e: power-domain@13 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_VPU_VC8000E>;
|
|
|
|
};
|
|
|
|
|
2024-02-27 16:04:37 -06:00
|
|
|
pgc_hdmimix: power-domain@14 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_HDMIMIX>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_HDMI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_APB>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_HDMI_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_APB>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_500M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL1_133M>;
|
|
|
|
assigned-clock-rates = <500000000>, <133000000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
pgc_hdmi_phy: power-domain@15 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_HDMI_PHY>;
|
|
|
|
};
|
|
|
|
|
2022-04-06 17:34:00 +02:00
|
|
|
pgc_mipi_phy2: power-domain@16 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_MIPI_PHY2>;
|
|
|
|
};
|
|
|
|
|
2022-12-17 12:08:49 -06:00
|
|
|
pgc_hsiomix: power-domain@17 {
|
2022-04-06 17:33:59 +02:00
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_HSIOMIX>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_HSIO_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_HSIO_ROOT>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_HSIO_AXI>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_500M>;
|
|
|
|
assigned-clock-rates = <500000000>;
|
|
|
|
};
|
2022-04-06 17:34:00 +02:00
|
|
|
|
|
|
|
pgc_ispdwp: power-domain@18 {
|
|
|
|
#power-domain-cells = <0>;
|
|
|
|
reg = <IMX8MP_POWER_DOMAIN_MEDIAMIX_ISPDWP>;
|
2022-06-20 11:20:44 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_ISP_ROOT>;
|
2022-04-06 17:34:00 +02:00
|
|
|
};
|
2022-03-30 12:46:19 +02:00
|
|
|
};
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
aips2: bus@30400000 {
|
2020-03-11 15:17:56 +08:00
|
|
|
compatible = "fsl,aips-bus", "simple-bus";
|
2020-03-31 15:37:25 -03:00
|
|
|
reg = <0x30400000 0x400000>;
|
2020-02-11 20:48:25 +08:00
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges;
|
|
|
|
|
|
|
|
pwm1: pwm@30660000 {
|
|
|
|
compatible = "fsl,imx8mp-pwm", "fsl,imx27-pwm";
|
|
|
|
reg = <0x30660000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_PWM1_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_PWM1_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
2022-05-02 11:49:01 +02:00
|
|
|
#pwm-cells = <3>;
|
2020-02-11 20:48:25 +08:00
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
pwm2: pwm@30670000 {
|
|
|
|
compatible = "fsl,imx8mp-pwm", "fsl,imx27-pwm";
|
|
|
|
reg = <0x30670000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_PWM2_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_PWM2_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
2022-05-02 11:49:01 +02:00
|
|
|
#pwm-cells = <3>;
|
2020-02-11 20:48:25 +08:00
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
pwm3: pwm@30680000 {
|
|
|
|
compatible = "fsl,imx8mp-pwm", "fsl,imx27-pwm";
|
|
|
|
reg = <0x30680000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_PWM3_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_PWM3_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
2022-05-02 11:49:01 +02:00
|
|
|
#pwm-cells = <3>;
|
2020-02-11 20:48:25 +08:00
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
pwm4: pwm@30690000 {
|
|
|
|
compatible = "fsl,imx8mp-pwm", "fsl,imx27-pwm";
|
|
|
|
reg = <0x30690000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_PWM4_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_PWM4_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
2022-05-02 11:49:01 +02:00
|
|
|
#pwm-cells = <3>;
|
2020-02-11 20:48:25 +08:00
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-02-20 12:50:32 +08:00
|
|
|
|
|
|
|
system_counter: timer@306a0000 {
|
|
|
|
compatible = "nxp,sysctr-timer";
|
|
|
|
reg = <0x306a0000 0x20000>;
|
|
|
|
interrupts = <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&osc_24m>;
|
|
|
|
clock-names = "per";
|
|
|
|
};
|
2023-03-27 19:35:26 +02:00
|
|
|
|
|
|
|
gpt6: timer@306e0000 {
|
|
|
|
compatible = "fsl,imx8mp-gpt", "fsl,imx6dl-gpt";
|
|
|
|
reg = <0x306e0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPT6_ROOT>, <&clk IMX8MP_CLK_GPT6>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
};
|
|
|
|
|
|
|
|
gpt5: timer@306f0000 {
|
|
|
|
compatible = "fsl,imx8mp-gpt", "fsl,imx6dl-gpt";
|
|
|
|
reg = <0x306f0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPT5_ROOT>, <&clk IMX8MP_CLK_GPT5>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
};
|
|
|
|
|
|
|
|
gpt4: timer@30700000 {
|
|
|
|
compatible = "fsl,imx8mp-gpt", "fsl,imx6dl-gpt";
|
|
|
|
reg = <0x30700000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPT4_ROOT>, <&clk IMX8MP_CLK_GPT4>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
aips3: bus@30800000 {
|
2020-03-11 15:17:56 +08:00
|
|
|
compatible = "fsl,aips-bus", "simple-bus";
|
2020-03-31 15:37:25 -03:00
|
|
|
reg = <0x30800000 0x400000>;
|
2020-02-11 20:48:25 +08:00
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges;
|
|
|
|
|
2022-12-18 11:05:44 -06:00
|
|
|
spba-bus@30800000 {
|
|
|
|
compatible = "fsl,spba-bus", "simple-bus";
|
|
|
|
reg = <0x30800000 0x100000>;
|
2020-02-11 20:48:25 +08:00
|
|
|
#address-cells = <1>;
|
2022-12-18 11:05:44 -06:00
|
|
|
#size-cells = <1>;
|
|
|
|
ranges;
|
2020-02-11 20:48:25 +08:00
|
|
|
|
2022-12-18 11:05:44 -06:00
|
|
|
ecspi1: spi@30820000 {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
compatible = "fsl,imx8mp-ecspi", "fsl,imx6ul-ecspi";
|
|
|
|
reg = <0x30820000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_ECSPI1_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_ECSPI1_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
assigned-clock-rates = <80000000>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_ECSPI1>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>;
|
|
|
|
dmas = <&sdma1 0 7 1>, <&sdma1 1 7 2>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
|
2022-12-18 11:05:44 -06:00
|
|
|
ecspi2: spi@30830000 {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
compatible = "fsl,imx8mp-ecspi", "fsl,imx6ul-ecspi";
|
|
|
|
reg = <0x30830000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_ECSPI2_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_ECSPI2_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
assigned-clock-rates = <80000000>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_ECSPI2>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>;
|
|
|
|
dmas = <&sdma1 2 7 1>, <&sdma1 3 7 2>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
|
2022-12-18 11:05:44 -06:00
|
|
|
ecspi3: spi@30840000 {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
compatible = "fsl,imx8mp-ecspi", "fsl,imx6ul-ecspi";
|
|
|
|
reg = <0x30840000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_ECSPI3_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_ECSPI3_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
assigned-clock-rates = <80000000>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_ECSPI3>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>;
|
|
|
|
dmas = <&sdma1 4 7 1>, <&sdma1 5 7 2>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
|
2022-12-18 11:05:44 -06:00
|
|
|
uart1: serial@30860000 {
|
|
|
|
compatible = "fsl,imx8mp-uart", "fsl,imx6q-uart";
|
|
|
|
reg = <0x30860000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_UART1_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_UART1_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
dmas = <&sdma1 22 4 0>, <&sdma1 23 4 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
|
2022-12-18 11:05:44 -06:00
|
|
|
uart3: serial@30880000 {
|
|
|
|
compatible = "fsl,imx8mp-uart", "fsl,imx6q-uart";
|
|
|
|
reg = <0x30880000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_UART3_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_UART3_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
dmas = <&sdma1 26 4 0>, <&sdma1 27 4 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
|
2022-12-18 11:05:44 -06:00
|
|
|
uart2: serial@30890000 {
|
|
|
|
compatible = "fsl,imx8mp-uart", "fsl,imx6q-uart";
|
|
|
|
reg = <0x30890000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_UART2_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_UART2_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
dmas = <&sdma1 24 4 0>, <&sdma1 25 4 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-11-02 10:16:34 +08:00
|
|
|
|
2022-12-18 11:05:44 -06:00
|
|
|
flexcan1: can@308c0000 {
|
|
|
|
compatible = "fsl,imx8mp-flexcan";
|
|
|
|
reg = <0x308c0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_IPG_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_CAN1_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_CAN1>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_40M>;
|
|
|
|
assigned-clock-rates = <40000000>;
|
|
|
|
fsl,clk-source = /bits/ 8 <0>;
|
|
|
|
fsl,stop-mode = <&gpr 0x10 4>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
flexcan2: can@308d0000 {
|
|
|
|
compatible = "fsl,imx8mp-flexcan";
|
|
|
|
reg = <0x308d0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_IPG_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_CAN2_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_CAN2>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_40M>;
|
|
|
|
assigned-clock-rates = <40000000>;
|
|
|
|
fsl,clk-source = /bits/ 8 <0>;
|
|
|
|
fsl,stop-mode = <&gpr 0x10 5>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-11-02 10:16:34 +08:00
|
|
|
};
|
|
|
|
|
2020-02-24 14:50:23 +02:00
|
|
|
crypto: crypto@30900000 {
|
|
|
|
compatible = "fsl,sec-v4.0";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
reg = <0x30900000 0x40000>;
|
|
|
|
ranges = <0 0x30900000 0x40000>;
|
|
|
|
interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_AHB>,
|
|
|
|
<&clk IMX8MP_CLK_IPG_ROOT>;
|
|
|
|
clock-names = "aclk", "ipg";
|
|
|
|
|
|
|
|
sec_jr0: jr@1000 {
|
|
|
|
compatible = "fsl,sec-v4.0-job-ring";
|
|
|
|
reg = <0x1000 0x1000>;
|
|
|
|
interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
|
2022-06-08 14:02:23 -03:00
|
|
|
status = "disabled";
|
2020-02-24 14:50:23 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
sec_jr1: jr@2000 {
|
|
|
|
compatible = "fsl,sec-v4.0-job-ring";
|
|
|
|
reg = <0x2000 0x1000>;
|
|
|
|
interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
};
|
|
|
|
|
|
|
|
sec_jr2: jr@3000 {
|
|
|
|
compatible = "fsl,sec-v4.0-job-ring";
|
|
|
|
reg = <0x3000 0x1000>;
|
|
|
|
interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
i2c1: i2c@30a20000 {
|
|
|
|
compatible = "fsl,imx8mp-i2c", "fsl,imx21-i2c";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
reg = <0x30a20000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_I2C1_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
i2c2: i2c@30a30000 {
|
|
|
|
compatible = "fsl,imx8mp-i2c", "fsl,imx21-i2c";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
reg = <0x30a30000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_I2C2_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
i2c3: i2c@30a40000 {
|
|
|
|
compatible = "fsl,imx8mp-i2c", "fsl,imx21-i2c";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
reg = <0x30a40000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_I2C3_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
i2c4: i2c@30a50000 {
|
|
|
|
compatible = "fsl,imx8mp-i2c", "fsl,imx21-i2c";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
reg = <0x30a50000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_I2C4_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
uart4: serial@30a60000 {
|
|
|
|
compatible = "fsl,imx8mp-uart", "fsl,imx6q-uart";
|
|
|
|
reg = <0x30a60000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_UART4_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_UART4_ROOT>;
|
|
|
|
clock-names = "ipg", "per";
|
|
|
|
dmas = <&sdma1 28 4 0>, <&sdma1 29 4 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2020-06-01 16:20:01 +08:00
|
|
|
mu: mailbox@30aa0000 {
|
|
|
|
compatible = "fsl,imx8mp-mu", "fsl,imx6sx-mu";
|
|
|
|
reg = <0x30aa0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MU_ROOT>;
|
|
|
|
#mbox-cells = <2>;
|
|
|
|
};
|
|
|
|
|
2021-07-23 14:05:40 +03:00
|
|
|
mu2: mailbox@30e60000 {
|
|
|
|
compatible = "fsl,imx8mp-mu", "fsl,imx6sx-mu";
|
|
|
|
reg = <0x30e60000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#mbox-cells = <2>;
|
2025-03-20 14:09:52 +02:00
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_MU2_ROOT>;
|
2021-07-23 14:05:40 +03:00
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
i2c5: i2c@30ad0000 {
|
|
|
|
compatible = "fsl,imx8mp-i2c", "fsl,imx21-i2c";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
reg = <0x30ad0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_I2C5_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
i2c6: i2c@30ae0000 {
|
|
|
|
compatible = "fsl,imx8mp-i2c", "fsl,imx21-i2c";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
reg = <0x30ae0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_I2C6_ROOT>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
usdhc1: mmc@30b40000 {
|
2022-04-10 14:35:43 -05:00
|
|
|
compatible = "fsl,imx8mp-usdhc", "fsl,imx8mm-usdhc", "fsl,imx7d-usdhc";
|
2020-02-11 20:48:25 +08:00
|
|
|
reg = <0x30b40000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>;
|
2024-10-12 10:52:21 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_IPG_ROOT>,
|
2020-02-11 20:48:25 +08:00
|
|
|
<&clk IMX8MP_CLK_NAND_USDHC_BUS>,
|
|
|
|
<&clk IMX8MP_CLK_USDHC1_ROOT>;
|
|
|
|
clock-names = "ipg", "ahb", "per";
|
|
|
|
fsl,tuning-start-tap = <20>;
|
2022-05-26 22:42:56 +02:00
|
|
|
fsl,tuning-step = <2>;
|
2020-02-11 20:48:25 +08:00
|
|
|
bus-width = <4>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
usdhc2: mmc@30b50000 {
|
2022-04-10 14:35:43 -05:00
|
|
|
compatible = "fsl,imx8mp-usdhc", "fsl,imx8mm-usdhc", "fsl,imx7d-usdhc";
|
2020-02-11 20:48:25 +08:00
|
|
|
reg = <0x30b50000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
|
2024-10-12 10:52:21 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_IPG_ROOT>,
|
2020-02-11 20:48:25 +08:00
|
|
|
<&clk IMX8MP_CLK_NAND_USDHC_BUS>,
|
|
|
|
<&clk IMX8MP_CLK_USDHC2_ROOT>;
|
|
|
|
clock-names = "ipg", "ahb", "per";
|
|
|
|
fsl,tuning-start-tap = <20>;
|
2022-05-26 22:42:56 +02:00
|
|
|
fsl,tuning-step = <2>;
|
2020-02-11 20:48:25 +08:00
|
|
|
bus-width = <4>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
usdhc3: mmc@30b60000 {
|
2022-04-10 14:35:43 -05:00
|
|
|
compatible = "fsl,imx8mp-usdhc", "fsl,imx8mm-usdhc", "fsl,imx7d-usdhc";
|
2020-02-11 20:48:25 +08:00
|
|
|
reg = <0x30b60000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
|
2024-10-12 10:52:21 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_IPG_ROOT>,
|
2020-02-11 20:48:25 +08:00
|
|
|
<&clk IMX8MP_CLK_NAND_USDHC_BUS>,
|
|
|
|
<&clk IMX8MP_CLK_USDHC3_ROOT>;
|
|
|
|
clock-names = "ipg", "ahb", "per";
|
|
|
|
fsl,tuning-start-tap = <20>;
|
2022-05-26 22:42:56 +02:00
|
|
|
fsl,tuning-step = <2>;
|
2020-02-11 20:48:25 +08:00
|
|
|
bus-width = <4>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2021-03-09 06:31:15 +01:00
|
|
|
flexspi: spi@30bb0000 {
|
|
|
|
compatible = "nxp,imx8mp-fspi";
|
|
|
|
reg = <0x30bb0000 0x10000>, <0x8000000 0x10000000>;
|
|
|
|
reg-names = "fspi_base", "fspi_mmap";
|
|
|
|
interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_QSPI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_QSPI_ROOT>;
|
2021-09-08 12:21:26 +05:30
|
|
|
clock-names = "fspi_en", "fspi";
|
2021-03-09 06:31:15 +01:00
|
|
|
assigned-clock-rates = <80000000>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_QSPI>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
sdma1: dma-controller@30bd0000 {
|
|
|
|
compatible = "fsl,imx8mp-sdma", "fsl,imx8mq-sdma";
|
|
|
|
reg = <0x30bd0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_SDMA1_ROOT>,
|
2020-09-01 18:21:49 +08:00
|
|
|
<&clk IMX8MP_CLK_AHB>;
|
2020-02-11 20:48:25 +08:00
|
|
|
clock-names = "ipg", "ahb";
|
|
|
|
#dma-cells = <3>;
|
|
|
|
fsl,sdma-ram-script-name = "imx/sdma/sdma-imx7d.bin";
|
|
|
|
};
|
|
|
|
|
|
|
|
fec: ethernet@30be0000 {
|
2020-04-29 18:04:14 +08:00
|
|
|
compatible = "fsl,imx8mp-fec", "fsl,imx8mq-fec", "fsl,imx6sx-fec";
|
2020-02-11 20:48:25 +08:00
|
|
|
reg = <0x30be0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>,
|
2020-08-18 22:59:46 -03:00
|
|
|
<GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>;
|
2020-02-11 20:48:25 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_ENET1_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_SIM_ENET_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_TIMER>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_REF>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_PHY_REF>;
|
|
|
|
clock-names = "ipg", "ahb", "ptp",
|
|
|
|
"enet_clk_ref", "enet_out";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_ENET_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_TIMER>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_REF>,
|
2021-01-16 16:44:28 +08:00
|
|
|
<&clk IMX8MP_CLK_ENET_PHY_REF>;
|
2020-02-11 20:48:25 +08:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_266M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL2_100M>,
|
2021-01-16 16:44:28 +08:00
|
|
|
<&clk IMX8MP_SYS_PLL2_125M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL2_50M>;
|
|
|
|
assigned-clock-rates = <0>, <100000000>, <125000000>, <0>;
|
2020-02-11 20:48:25 +08:00
|
|
|
fsl,num-tx-queues = <3>;
|
|
|
|
fsl,num-rx-queues = <3>;
|
2021-01-16 16:44:30 +08:00
|
|
|
nvmem-cells = <ð_mac1>;
|
|
|
|
nvmem-cell-names = "mac-address";
|
2021-01-16 16:44:31 +08:00
|
|
|
fsl,stop-mode = <&gpr 0x10 3>;
|
2020-02-11 20:48:25 +08:00
|
|
|
status = "disabled";
|
|
|
|
};
|
2021-02-28 22:18:33 +01:00
|
|
|
|
|
|
|
eqos: ethernet@30bf0000 {
|
|
|
|
compatible = "nxp,imx8mp-dwmac-eqos", "snps,dwmac-5.10a";
|
|
|
|
reg = <0x30bf0000 0x10000>;
|
2021-07-19 15:18:21 +08:00
|
|
|
interrupts = <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
interrupt-names = "macirq", "eth_wake_irq";
|
2021-02-28 22:18:33 +01:00
|
|
|
clocks = <&clk IMX8MP_CLK_ENET_QOS_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_QOS_ENET_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_QOS_TIMER>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_QOS>;
|
|
|
|
clock-names = "stmmaceth", "pclk", "ptp_ref", "tx";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_ENET_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_QOS_TIMER>,
|
|
|
|
<&clk IMX8MP_CLK_ENET_QOS>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_266M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL2_100M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL2_125M>;
|
|
|
|
assigned-clock-rates = <0>, <100000000>, <125000000>;
|
2021-11-23 16:05:06 +08:00
|
|
|
nvmem-cells = <ð_mac2>;
|
|
|
|
nvmem-cell-names = "mac-address";
|
2021-02-28 22:18:33 +01:00
|
|
|
intf_mode = <&gpr 0x4>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
|
2023-05-08 13:42:35 +02:00
|
|
|
aips5: bus@30c00000 {
|
|
|
|
compatible = "fsl,aips-bus", "simple-bus";
|
|
|
|
reg = <0x30c00000 0x400000>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges;
|
|
|
|
|
|
|
|
spba-bus@30c00000 {
|
|
|
|
compatible = "fsl,spba-bus", "simple-bus";
|
|
|
|
reg = <0x30c00000 0x100000>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges;
|
|
|
|
|
|
|
|
sai1: sai@30c10000 {
|
|
|
|
compatible = "fsl,imx8mp-sai", "fsl,imx8mq-sai";
|
|
|
|
reg = <0x30c10000 0x10000>;
|
|
|
|
#sound-dai-cells = <0>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI1_IPG>,
|
|
|
|
<&clk IMX8MP_CLK_DUMMY>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI1_MCLK1>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI1_MCLK2>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI1_MCLK3>;
|
|
|
|
clock-names = "bus", "mclk0", "mclk1", "mclk2", "mclk3";
|
|
|
|
dmas = <&sdma2 0 2 0>, <&sdma2 1 2 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
sai2: sai@30c20000 {
|
|
|
|
compatible = "fsl,imx8mp-sai", "fsl,imx8mq-sai";
|
|
|
|
reg = <0x30c20000 0x10000>;
|
|
|
|
#sound-dai-cells = <0>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI2_IPG>,
|
|
|
|
<&clk IMX8MP_CLK_DUMMY>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI2_MCLK1>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI2_MCLK2>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI2_MCLK3>;
|
|
|
|
clock-names = "bus", "mclk0", "mclk1", "mclk2", "mclk3";
|
|
|
|
dmas = <&sdma2 2 2 0>, <&sdma2 3 2 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
sai3: sai@30c30000 {
|
|
|
|
compatible = "fsl,imx8mp-sai", "fsl,imx8mq-sai";
|
|
|
|
reg = <0x30c30000 0x10000>;
|
|
|
|
#sound-dai-cells = <0>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI3_IPG>,
|
|
|
|
<&clk IMX8MP_CLK_DUMMY>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI3_MCLK1>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI3_MCLK2>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI3_MCLK3>;
|
|
|
|
clock-names = "bus", "mclk0", "mclk1", "mclk2", "mclk3";
|
|
|
|
dmas = <&sdma2 4 2 0>, <&sdma2 5 2 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
sai5: sai@30c50000 {
|
|
|
|
compatible = "fsl,imx8mp-sai", "fsl,imx8mq-sai";
|
|
|
|
reg = <0x30c50000 0x10000>;
|
|
|
|
#sound-dai-cells = <0>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI5_IPG>,
|
|
|
|
<&clk IMX8MP_CLK_DUMMY>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI5_MCLK1>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI5_MCLK2>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI5_MCLK3>;
|
|
|
|
clock-names = "bus", "mclk0", "mclk1", "mclk2", "mclk3";
|
|
|
|
dmas = <&sdma2 8 2 0>, <&sdma2 9 2 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
sai6: sai@30c60000 {
|
|
|
|
compatible = "fsl,imx8mp-sai", "fsl,imx8mq-sai";
|
|
|
|
reg = <0x30c60000 0x10000>;
|
|
|
|
#sound-dai-cells = <0>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI6_IPG>,
|
|
|
|
<&clk IMX8MP_CLK_DUMMY>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI6_MCLK1>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI6_MCLK2>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI6_MCLK3>;
|
|
|
|
clock-names = "bus", "mclk0", "mclk1", "mclk2", "mclk3";
|
|
|
|
dmas = <&sdma2 10 2 0>, <&sdma2 11 2 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
sai7: sai@30c80000 {
|
|
|
|
compatible = "fsl,imx8mp-sai", "fsl,imx8mq-sai";
|
|
|
|
reg = <0x30c80000 0x10000>;
|
|
|
|
#sound-dai-cells = <0>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI7_IPG>,
|
|
|
|
<&clk IMX8MP_CLK_DUMMY>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI7_MCLK1>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI7_MCLK2>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SAI7_MCLK3>;
|
|
|
|
clock-names = "bus", "mclk0", "mclk1", "mclk2", "mclk3";
|
|
|
|
dmas = <&sdma2 12 2 0>, <&sdma2 13 2 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
interrupts = <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2023-08-30 23:44:29 -05:00
|
|
|
|
|
|
|
easrc: easrc@30c90000 {
|
|
|
|
compatible = "fsl,imx8mp-easrc", "fsl,imx8mn-easrc";
|
|
|
|
reg = <0x30c90000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_ASRC_IPG>;
|
|
|
|
clock-names = "mem";
|
|
|
|
dmas = <&sdma2 16 23 0> , <&sdma2 17 23 0>,
|
|
|
|
<&sdma2 18 23 0> , <&sdma2 19 23 0>,
|
|
|
|
<&sdma2 20 23 0> , <&sdma2 21 23 0>,
|
|
|
|
<&sdma2 22 23 0> , <&sdma2 23 23 0>;
|
|
|
|
dma-names = "ctx0_rx", "ctx0_tx",
|
|
|
|
"ctx1_rx", "ctx1_tx",
|
|
|
|
"ctx2_rx", "ctx2_tx",
|
|
|
|
"ctx3_rx", "ctx3_tx";
|
|
|
|
firmware-name = "imx/easrc/easrc-imx8mn.bin";
|
|
|
|
fsl,asrc-rate = <8000>;
|
|
|
|
fsl,asrc-format = <2>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2023-08-30 23:44:30 -05:00
|
|
|
|
|
|
|
micfil: audio-controller@30ca0000 {
|
|
|
|
compatible = "fsl,imx8mp-micfil";
|
|
|
|
reg = <0x30ca0000 0x10000>;
|
|
|
|
#sound-dai-cells = <0>;
|
|
|
|
interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_PDM_IPG>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_PDM_SEL>,
|
|
|
|
<&clk IMX8MP_AUDIO_PLL1_OUT>,
|
|
|
|
<&clk IMX8MP_AUDIO_PLL2_OUT>,
|
|
|
|
<&clk IMX8MP_CLK_EXT3>;
|
|
|
|
clock-names = "ipg_clk", "ipg_clk_app",
|
|
|
|
"pll8k", "pll11k", "clkext3";
|
|
|
|
dmas = <&sdma2 24 25 0x80000000>;
|
|
|
|
dma-names = "rx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2024-02-28 11:30:11 +08:00
|
|
|
aud2htx: aud2htx@30cb0000 {
|
|
|
|
compatible = "fsl,imx8mp-aud2htx";
|
|
|
|
reg = <0x30cb0000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_AUD2HTX_IPG>;
|
|
|
|
clock-names = "bus";
|
|
|
|
dmas = <&sdma2 26 2 0>;
|
|
|
|
dma-names = "tx";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2024-06-27 17:53:00 +08:00
|
|
|
|
|
|
|
xcvr: xcvr@30cc0000 {
|
|
|
|
compatible = "fsl,imx8mp-xcvr";
|
|
|
|
reg = <0x30cc0000 0x800>,
|
|
|
|
<0x30cc0800 0x400>,
|
|
|
|
<0x30cc0c00 0x080>,
|
|
|
|
<0x30cc0e00 0x080>;
|
|
|
|
reg-names = "ram", "regs", "rxfifo",
|
|
|
|
"txfifo";
|
|
|
|
interrupts = /* XCVR IRQ 0 */
|
|
|
|
<GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
/* XCVR IRQ 1 */
|
|
|
|
<GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
/* XCVR PHY - SPDIF wakeup IRQ */
|
|
|
|
<GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_EARC_IPG>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_EARC_PHY>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SPBA2_ROOT>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_AUDPLL_ROOT>;
|
|
|
|
clock-names = "ipg", "phy", "spba", "pll_ipg";
|
|
|
|
dmas = <&sdma2 30 2 0>, <&sdma2 31 2 0>;
|
|
|
|
dma-names = "rx", "tx";
|
|
|
|
resets = <&audio_blk_ctrl 0>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2023-05-08 13:42:35 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
sdma3: dma-controller@30e00000 {
|
|
|
|
compatible = "fsl,imx8mp-sdma", "fsl,imx8mq-sdma";
|
|
|
|
reg = <0x30e00000 0x10000>;
|
|
|
|
#dma-cells = <3>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SDMA3_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_AUDIO_ROOT>;
|
|
|
|
clock-names = "ipg", "ahb";
|
|
|
|
interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
fsl,sdma-ram-script-name = "imx/sdma/sdma-imx7d.bin";
|
|
|
|
};
|
|
|
|
|
|
|
|
sdma2: dma-controller@30e10000 {
|
|
|
|
compatible = "fsl,imx8mp-sdma", "fsl,imx8mq-sdma";
|
|
|
|
reg = <0x30e10000 0x10000>;
|
|
|
|
#dma-cells = <3>;
|
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_SDMA2_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_AUDIO_ROOT>;
|
|
|
|
clock-names = "ipg", "ahb";
|
|
|
|
interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
fsl,sdma-ram-script-name = "imx/sdma/sdma-imx7d.bin";
|
|
|
|
};
|
|
|
|
|
|
|
|
audio_blk_ctrl: clock-controller@30e20000 {
|
|
|
|
compatible = "fsl,imx8mp-audio-blk-ctrl";
|
|
|
|
reg = <0x30e20000 0x10000>;
|
|
|
|
#clock-cells = <1>;
|
2024-06-27 17:53:00 +08:00
|
|
|
#reset-cells = <1>;
|
2023-05-08 13:42:35 +02:00
|
|
|
clocks = <&clk IMX8MP_CLK_AUDIO_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_SAI1>,
|
|
|
|
<&clk IMX8MP_CLK_SAI2>,
|
|
|
|
<&clk IMX8MP_CLK_SAI3>,
|
|
|
|
<&clk IMX8MP_CLK_SAI5>,
|
|
|
|
<&clk IMX8MP_CLK_SAI6>,
|
2025-02-26 11:45:12 -05:00
|
|
|
<&clk IMX8MP_CLK_SAI7>,
|
|
|
|
<&clk IMX8MP_CLK_AUDIO_AXI_ROOT>;
|
2023-05-08 13:42:35 +02:00
|
|
|
clock-names = "ahb",
|
|
|
|
"sai1", "sai2", "sai3",
|
2025-02-26 11:45:12 -05:00
|
|
|
"sai5", "sai6", "sai7", "axi";
|
2023-05-08 13:42:35 +02:00
|
|
|
power-domains = <&pgc_audio>;
|
2024-05-09 13:14:57 +08:00
|
|
|
assigned-clocks = <&clk IMX8MP_AUDIO_PLL1>,
|
|
|
|
<&clk IMX8MP_AUDIO_PLL2>;
|
|
|
|
assigned-clock-rates = <393216000>, <361267200>;
|
2023-05-08 13:42:35 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-07-07 07:47:57 +08:00
|
|
|
noc: interconnect@32700000 {
|
|
|
|
compatible = "fsl,imx8mp-noc", "fsl,imx8m-noc";
|
|
|
|
reg = <0x32700000 0x100000>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_NOC>;
|
|
|
|
#interconnect-cells = <1>;
|
|
|
|
operating-points-v2 = <&noc_opp_table>;
|
|
|
|
|
|
|
|
noc_opp_table: opp-table {
|
|
|
|
compatible = "operating-points-v2";
|
|
|
|
|
2022-11-02 20:31:02 +01:00
|
|
|
opp-200000000 {
|
2022-07-07 07:47:57 +08:00
|
|
|
opp-hz = /bits/ 64 <200000000>;
|
|
|
|
};
|
|
|
|
|
2025-04-22 09:12:35 +02:00
|
|
|
/* Nominal drive mode maximum */
|
|
|
|
opp-800000000 {
|
|
|
|
opp-hz = /bits/ 64 <800000000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Overdrive mode maximum */
|
2022-11-02 20:31:02 +01:00
|
|
|
opp-1000000000 {
|
2022-07-07 07:47:57 +08:00
|
|
|
opp-hz = /bits/ 64 <1000000000>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-04-06 17:33:59 +02:00
|
|
|
aips4: bus@32c00000 {
|
|
|
|
compatible = "fsl,aips-bus", "simple-bus";
|
|
|
|
reg = <0x32c00000 0x400000>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges;
|
|
|
|
|
2023-05-16 10:13:53 +02:00
|
|
|
isi_0: isi@32e00000 {
|
|
|
|
compatible = "fsl,imx8mp-isi";
|
|
|
|
reg = <0x32e00000 0x4000>;
|
|
|
|
interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_AXI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>;
|
|
|
|
clock-names = "axi", "apb";
|
|
|
|
fsl,blk-ctrl = <&media_blk_ctrl>;
|
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_ISI>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
|
|
|
|
isi_in_0: endpoint {
|
|
|
|
remote-endpoint = <&mipi_csi_0_out>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
isi_in_1: endpoint {
|
|
|
|
remote-endpoint = <&mipi_csi_1_out>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-08-14 19:14:51 +03:00
|
|
|
isp_0: isp@32e10000 {
|
|
|
|
compatible = "fsl,imx8mp-isp";
|
|
|
|
reg = <0x32e10000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_ISP_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>;
|
|
|
|
clock-names = "isp", "aclk", "hclk";
|
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_ISP>;
|
|
|
|
fsl,blk-ctrl = <&media_blk_ctrl 0>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
isp_1: isp@32e20000 {
|
|
|
|
compatible = "fsl,imx8mp-isp";
|
|
|
|
reg = <0x32e20000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_ISP_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>;
|
|
|
|
clock-names = "isp", "aclk", "hclk";
|
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_ISP>;
|
|
|
|
fsl,blk-ctrl = <&media_blk_ctrl 1>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-05-16 10:13:54 +02:00
|
|
|
dewarp: dwe@32e30000 {
|
|
|
|
compatible = "nxp,imx8mp-dw100";
|
|
|
|
reg = <0x32e30000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_AXI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>;
|
|
|
|
clock-names = "axi", "ahb";
|
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_DWE>;
|
|
|
|
};
|
|
|
|
|
2023-05-16 10:13:53 +02:00
|
|
|
mipi_csi_0: csi@32e40000 {
|
|
|
|
compatible = "fsl,imx8mp-mipi-csi2", "fsl,imx8mm-mipi-csi2";
|
|
|
|
reg = <0x32e40000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
|
2024-08-14 02:40:10 +03:00
|
|
|
clock-frequency = <250000000>;
|
2023-05-16 10:13:53 +02:00
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_CAM1_PIX_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_MIPI_PHY1_REF_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>;
|
|
|
|
clock-names = "pclk", "wrap", "phy", "axi";
|
2024-01-10 11:00:48 +01:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_CAM1_PIX>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_MIPI_PHY1_REF>;
|
2024-08-14 02:40:10 +03:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_250M>,
|
2024-01-10 11:00:48 +01:00
|
|
|
<&clk IMX8MP_CLK_24M>;
|
2023-05-16 10:13:53 +02:00
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_MIPI_CSI2_1>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
mipi_csi_0_out: endpoint {
|
|
|
|
remote-endpoint = <&isi_in_0>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
mipi_csi_1: csi@32e50000 {
|
|
|
|
compatible = "fsl,imx8mp-mipi-csi2", "fsl,imx8mm-mipi-csi2";
|
|
|
|
reg = <0x32e50000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
|
2024-08-14 02:40:10 +03:00
|
|
|
clock-frequency = <250000000>;
|
2023-05-16 10:13:53 +02:00
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_CAM2_PIX_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_MIPI_PHY1_REF_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>;
|
|
|
|
clock-names = "pclk", "wrap", "phy", "axi";
|
2024-04-05 22:21:53 +02:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_CAM2_PIX>,
|
2024-01-10 11:00:48 +01:00
|
|
|
<&clk IMX8MP_CLK_MEDIA_MIPI_PHY1_REF>;
|
2024-08-14 02:40:10 +03:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_250M>,
|
2024-01-10 11:00:48 +01:00
|
|
|
<&clk IMX8MP_CLK_24M>;
|
2023-05-16 10:13:53 +02:00
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_MIPI_CSI2_2>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
mipi_csi_1_out: endpoint {
|
|
|
|
remote-endpoint = <&isi_in_1>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-04-05 18:52:14 +02:00
|
|
|
mipi_dsi: dsi@32e60000 {
|
|
|
|
compatible = "fsl,imx8mp-mipi-dsim";
|
|
|
|
reg = <0x32e60000 0x400>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_MIPI_PHY1_REF>;
|
|
|
|
clock-names = "bus_clk", "sclk_mipi";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_APB>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_MIPI_PHY1_REF>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>,
|
|
|
|
<&clk IMX8MP_CLK_24M>;
|
|
|
|
assigned-clock-rates = <200000000>, <24000000>;
|
|
|
|
samsung,pll-clock-frequency = <24000000>;
|
|
|
|
interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_MIPI_DSI_1>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
|
|
|
|
dsim_from_lcdif1: endpoint {
|
|
|
|
remote-endpoint = <&lcdif1_to_dsim>;
|
|
|
|
};
|
|
|
|
};
|
2024-03-01 10:14:12 +01:00
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
mipi_dsi_out: endpoint {
|
|
|
|
};
|
|
|
|
};
|
2023-04-05 18:52:14 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
lcdif1: display-controller@32e80000 {
|
|
|
|
compatible = "fsl,imx8mp-lcdif";
|
|
|
|
reg = <0x32e80000 0x10000>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_DISP1_PIX_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>;
|
|
|
|
clock-names = "pix", "axi", "disp_axi";
|
|
|
|
interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_LCDIF_1>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
port {
|
|
|
|
lcdif1_to_dsim: endpoint {
|
|
|
|
remote-endpoint = <&dsim_from_lcdif1>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-12-08 10:08:41 +01:00
|
|
|
lcdif2: display-controller@32e90000 {
|
|
|
|
compatible = "fsl,imx8mp-lcdif";
|
2023-03-27 10:06:00 +08:00
|
|
|
reg = <0x32e90000 0x10000>;
|
2022-12-08 10:08:41 +01:00
|
|
|
interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_DISP2_PIX_ROOT>,
|
2023-02-17 20:15:38 +01:00
|
|
|
<&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>;
|
2022-12-08 10:08:41 +01:00
|
|
|
clock-names = "pix", "axi", "disp_axi";
|
|
|
|
power-domains = <&media_blk_ctrl IMX8MP_MEDIABLK_PD_LCDIF_2>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
port {
|
|
|
|
lcdif2_to_ldb: endpoint {
|
|
|
|
remote-endpoint = <&ldb_from_lcdif2>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-04-06 17:34:01 +02:00
|
|
|
media_blk_ctrl: blk-ctrl@32ec0000 {
|
|
|
|
compatible = "fsl,imx8mp-media-blk-ctrl",
|
2023-02-27 16:54:22 +01:00
|
|
|
"syscon";
|
2022-04-06 17:34:01 +02:00
|
|
|
reg = <0x32ec0000 0x10000>;
|
2022-12-08 10:08:41 +01:00
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
2022-04-06 17:34:01 +02:00
|
|
|
power-domains = <&pgc_mediamix>,
|
|
|
|
<&pgc_mipi_phy1>,
|
|
|
|
<&pgc_mipi_phy1>,
|
|
|
|
<&pgc_mediamix>,
|
|
|
|
<&pgc_mediamix>,
|
|
|
|
<&pgc_mipi_phy2>,
|
|
|
|
<&pgc_mediamix>,
|
|
|
|
<&pgc_ispdwp>,
|
|
|
|
<&pgc_ispdwp>,
|
|
|
|
<&pgc_mipi_phy2>;
|
|
|
|
power-domain-names = "bus", "mipi-dsi1", "mipi-csi1",
|
|
|
|
"lcdif1", "isi", "mipi-csi2",
|
|
|
|
"lcdif2", "isp", "dwe",
|
|
|
|
"mipi-dsi2";
|
2022-07-08 16:56:31 +08:00
|
|
|
interconnects =
|
|
|
|
<&noc IMX8MP_ICM_LCDIF_RD &noc IMX8MP_ICN_MEDIA>,
|
|
|
|
<&noc IMX8MP_ICM_LCDIF_WR &noc IMX8MP_ICN_MEDIA>,
|
|
|
|
<&noc IMX8MP_ICM_ISI0 &noc IMX8MP_ICN_MEDIA>,
|
|
|
|
<&noc IMX8MP_ICM_ISI1 &noc IMX8MP_ICN_MEDIA>,
|
|
|
|
<&noc IMX8MP_ICM_ISI2 &noc IMX8MP_ICN_MEDIA>,
|
|
|
|
<&noc IMX8MP_ICM_ISP0 &noc IMX8MP_ICN_MEDIA>,
|
|
|
|
<&noc IMX8MP_ICM_ISP1 &noc IMX8MP_ICN_MEDIA>,
|
|
|
|
<&noc IMX8MP_ICM_DWE &noc IMX8MP_ICN_MEDIA>;
|
|
|
|
interconnect-names = "lcdif-rd", "lcdif-wr", "isi0",
|
|
|
|
"isi1", "isi2", "isp0", "isp1",
|
|
|
|
"dwe";
|
2022-04-06 17:34:01 +02:00
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_APB_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_AXI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_CAM1_PIX_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_CAM2_PIX_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_DISP1_PIX_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_DISP2_PIX_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_ISP_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_MIPI_PHY1_REF_ROOT>;
|
|
|
|
clock-names = "apb", "axi", "cam1", "cam2",
|
|
|
|
"disp1", "disp2", "isp", "phy";
|
|
|
|
|
2024-08-14 19:14:51 +03:00
|
|
|
/*
|
|
|
|
* The ISP maximum frequency is 400MHz in normal mode
|
|
|
|
* and 500MHz in overdrive mode. The 400MHz operating
|
|
|
|
* point hasn't been successfully tested yet, so set
|
|
|
|
* IMX8MP_CLK_MEDIA_ISP to 500MHz for the time being.
|
|
|
|
*/
|
2022-04-06 17:34:01 +02:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_AXI>,
|
2023-05-11 20:04:23 -05:00
|
|
|
<&clk IMX8MP_CLK_MEDIA_APB>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_DISP1_PIX>,
|
|
|
|
<&clk IMX8MP_CLK_MEDIA_DISP2_PIX>,
|
2024-08-14 19:14:51 +03:00
|
|
|
<&clk IMX8MP_CLK_MEDIA_ISP>,
|
2023-05-11 20:04:23 -05:00
|
|
|
<&clk IMX8MP_VIDEO_PLL1>;
|
2022-04-06 17:34:01 +02:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_1000M>,
|
2023-05-11 20:04:23 -05:00
|
|
|
<&clk IMX8MP_SYS_PLL1_800M>,
|
|
|
|
<&clk IMX8MP_VIDEO_PLL1_OUT>,
|
2024-08-14 19:14:51 +03:00
|
|
|
<&clk IMX8MP_VIDEO_PLL1_OUT>,
|
|
|
|
<&clk IMX8MP_SYS_PLL2_500M>;
|
2023-05-11 20:04:23 -05:00
|
|
|
assigned-clock-rates = <500000000>, <200000000>,
|
2024-08-14 19:14:51 +03:00
|
|
|
<0>, <0>, <500000000>,
|
|
|
|
<1039500000>;
|
2022-04-06 17:34:01 +02:00
|
|
|
#power-domain-cells = <1>;
|
2022-12-08 10:08:41 +01:00
|
|
|
|
|
|
|
lvds_bridge: bridge@5c {
|
|
|
|
compatible = "fsl,imx8mp-ldb";
|
|
|
|
reg = <0x5c 0x4>, <0x128 0x4>;
|
|
|
|
reg-names = "ldb", "lvds";
|
2024-02-23 17:15:22 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_MEDIA_LDB_ROOT>;
|
2023-02-27 16:54:23 +01:00
|
|
|
clock-names = "ldb";
|
2022-12-08 10:08:41 +01:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_MEDIA_LDB>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_VIDEO_PLL1_OUT>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
|
|
|
|
ldb_from_lcdif2: endpoint {
|
|
|
|
remote-endpoint = <&lcdif2_to_ldb>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
ldb_lvds_ch0: endpoint {
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@2 {
|
|
|
|
reg = <2>;
|
|
|
|
|
|
|
|
ldb_lvds_ch1: endpoint {
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2022-04-06 17:34:01 +02:00
|
|
|
};
|
|
|
|
|
2022-09-02 16:58:01 +08:00
|
|
|
pcie_phy: pcie-phy@32f00000 {
|
|
|
|
compatible = "fsl,imx8mp-pcie-phy";
|
|
|
|
reg = <0x32f00000 0x10000>;
|
|
|
|
resets = <&src IMX8MP_RESET_PCIEPHY>,
|
|
|
|
<&src IMX8MP_RESET_PCIEPHY_PERST>;
|
|
|
|
reset-names = "pciephy", "perst";
|
|
|
|
power-domains = <&hsio_blk_ctrl IMX8MP_HSIOBLK_PD_PCIE_PHY>;
|
|
|
|
#phy-cells = <0>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2022-04-06 17:33:59 +02:00
|
|
|
hsio_blk_ctrl: blk-ctrl@32f10000 {
|
|
|
|
compatible = "fsl,imx8mp-hsio-blk-ctrl", "syscon";
|
|
|
|
reg = <0x32f10000 0x24>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_USB_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_PCIE_ROOT>;
|
|
|
|
clock-names = "usb", "pcie";
|
|
|
|
power-domains = <&pgc_hsiomix>, <&pgc_hsiomix>,
|
|
|
|
<&pgc_usb1_phy>, <&pgc_usb2_phy>,
|
|
|
|
<&pgc_hsiomix>, <&pgc_pcie_phy>;
|
|
|
|
power-domain-names = "bus", "usb", "usb-phy1",
|
|
|
|
"usb-phy2", "pcie", "pcie-phy";
|
2022-07-08 16:56:32 +08:00
|
|
|
interconnects = <&noc IMX8MP_ICM_NOC_PCIE &noc IMX8MP_ICN_HSIO>,
|
|
|
|
<&noc IMX8MP_ICM_USB1 &noc IMX8MP_ICN_HSIO>,
|
|
|
|
<&noc IMX8MP_ICM_USB2 &noc IMX8MP_ICN_HSIO>,
|
|
|
|
<&noc IMX8MP_ICM_PCIE &noc IMX8MP_ICN_HSIO>;
|
|
|
|
interconnect-names = "noc-pcie", "usb1", "usb2", "pcie";
|
2022-04-06 17:33:59 +02:00
|
|
|
#power-domain-cells = <1>;
|
2022-12-16 21:08:21 +01:00
|
|
|
#clock-cells = <0>;
|
2022-04-06 17:33:59 +02:00
|
|
|
};
|
2024-02-27 16:04:37 -06:00
|
|
|
|
|
|
|
hdmi_blk_ctrl: blk-ctrl@32fc0000 {
|
|
|
|
compatible = "fsl,imx8mp-hdmi-blk-ctrl", "syscon";
|
|
|
|
reg = <0x32fc0000 0x1000>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_HDMI_APB>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_REF_266M>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_24M>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_FDCC_TST>;
|
|
|
|
clock-names = "apb", "axi", "ref_266m", "ref_24m", "fdcc";
|
|
|
|
power-domains = <&pgc_hdmimix>, <&pgc_hdmimix>,
|
|
|
|
<&pgc_hdmimix>, <&pgc_hdmimix>,
|
|
|
|
<&pgc_hdmimix>, <&pgc_hdmimix>,
|
|
|
|
<&pgc_hdmimix>, <&pgc_hdmi_phy>,
|
|
|
|
<&pgc_hdmimix>, <&pgc_hdmimix>;
|
|
|
|
power-domain-names = "bus", "irqsteer", "lcdif",
|
|
|
|
"pai", "pvi", "trng",
|
|
|
|
"hdmi-tx", "hdmi-tx-phy",
|
|
|
|
"hdcp", "hrv";
|
|
|
|
#power-domain-cells = <1>;
|
|
|
|
};
|
2024-02-27 16:04:38 -06:00
|
|
|
|
|
|
|
irqsteer_hdmi: interrupt-controller@32fc2000 {
|
2024-05-28 09:11:41 +02:00
|
|
|
compatible = "fsl,imx8mp-irqsteer", "fsl,imx-irqsteer";
|
2024-02-27 16:04:38 -06:00
|
|
|
reg = <0x32fc2000 0x1000>;
|
|
|
|
interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <1>;
|
|
|
|
fsl,channel = <1>;
|
|
|
|
fsl,num-irqs = <64>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_HDMI_APB>;
|
|
|
|
clock-names = "ipg";
|
|
|
|
power-domains = <&hdmi_blk_ctrl IMX8MP_HDMIBLK_PD_IRQSTEER>;
|
|
|
|
};
|
2024-02-27 16:04:39 -06:00
|
|
|
|
|
|
|
hdmi_pvi: display-bridge@32fc4000 {
|
|
|
|
compatible = "fsl,imx8mp-hdmi-pvi";
|
|
|
|
reg = <0x32fc4000 0x1000>;
|
|
|
|
interrupt-parent = <&irqsteer_hdmi>;
|
|
|
|
interrupts = <12>;
|
|
|
|
power-domains = <&hdmi_blk_ctrl IMX8MP_HDMIBLK_PD_PVI>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
pvi_from_lcdif3: endpoint {
|
|
|
|
remote-endpoint = <&lcdif3_to_pvi>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
pvi_to_hdmi_tx: endpoint {
|
|
|
|
remote-endpoint = <&hdmi_tx_from_pvi>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
lcdif3: display-controller@32fc6000 {
|
|
|
|
compatible = "fsl,imx8mp-lcdif";
|
|
|
|
reg = <0x32fc6000 0x1000>;
|
|
|
|
interrupt-parent = <&irqsteer_hdmi>;
|
|
|
|
interrupts = <8>;
|
|
|
|
clocks = <&hdmi_tx_phy>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_APB>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_ROOT>;
|
|
|
|
clock-names = "pix", "axi", "disp_axi";
|
|
|
|
power-domains = <&hdmi_blk_ctrl IMX8MP_HDMIBLK_PD_LCDIF>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
port {
|
|
|
|
lcdif3_to_pvi: endpoint {
|
|
|
|
remote-endpoint = <&pvi_from_lcdif3>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
hdmi_tx: hdmi@32fd8000 {
|
|
|
|
compatible = "fsl,imx8mp-hdmi-tx";
|
|
|
|
reg = <0x32fd8000 0x7eff>;
|
|
|
|
interrupt-parent = <&irqsteer_hdmi>;
|
|
|
|
interrupts = <0>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_HDMI_APB>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_REF_266M>,
|
|
|
|
<&clk IMX8MP_CLK_32K>,
|
|
|
|
<&hdmi_tx_phy>;
|
|
|
|
clock-names = "iahb", "isfr", "cec", "pix";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_HDMI_REF_266M>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_266M>;
|
|
|
|
power-domains = <&hdmi_blk_ctrl IMX8MP_HDMIBLK_PD_HDMI_TX>;
|
|
|
|
reg-io-width = <1>;
|
|
|
|
status = "disabled";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
|
|
|
|
hdmi_tx_from_pvi: endpoint {
|
|
|
|
remote-endpoint = <&pvi_to_hdmi_tx>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
/* Point endpoint to the HDMI connector */
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
hdmi_tx_phy: phy@32fdff00 {
|
|
|
|
compatible = "fsl,imx8mp-hdmi-phy";
|
|
|
|
reg = <0x32fdff00 0x100>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_HDMI_APB>,
|
|
|
|
<&clk IMX8MP_CLK_HDMI_24M>;
|
|
|
|
clock-names = "apb", "ref";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_HDMI_24M>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_CLK_24M>;
|
|
|
|
power-domains = <&hdmi_blk_ctrl IMX8MP_HDMIBLK_PD_HDMI_TX_PHY>;
|
|
|
|
#clock-cells = <0>;
|
|
|
|
#phy-cells = <0>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
2022-04-06 17:33:59 +02:00
|
|
|
};
|
|
|
|
|
2025-04-23 20:41:23 -04:00
|
|
|
pcie0: pcie: pcie@33800000 {
|
2022-09-02 16:58:01 +08:00
|
|
|
compatible = "fsl,imx8mp-pcie";
|
|
|
|
reg = <0x33800000 0x400000>, <0x1ff00000 0x80000>;
|
|
|
|
reg-names = "dbi", "config";
|
2022-12-16 20:59:32 +01:00
|
|
|
clocks = <&clk IMX8MP_CLK_HSIO_ROOT>,
|
2023-01-16 11:16:49 +01:00
|
|
|
<&clk IMX8MP_CLK_HSIO_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_PCIE_ROOT>;
|
|
|
|
clock-names = "pcie", "pcie_bus", "pcie_aux";
|
2022-12-16 20:59:32 +01:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_PCIE_AUX>;
|
|
|
|
assigned-clock-rates = <10000000>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_50M>;
|
2022-09-02 16:58:01 +08:00
|
|
|
#address-cells = <3>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
device_type = "pci";
|
|
|
|
bus-range = <0x00 0xff>;
|
2023-07-02 20:51:48 +02:00
|
|
|
ranges = <0x81000000 0 0x00000000 0x1ff80000 0 0x00010000>, /* downstream I/O 64KB */
|
|
|
|
<0x82000000 0 0x18000000 0x18000000 0 0x07f00000>; /* non-prefetchable memory */
|
2022-09-02 16:58:01 +08:00
|
|
|
num-lanes = <1>;
|
|
|
|
num-viewport = <4>;
|
|
|
|
interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
interrupt-names = "msi";
|
|
|
|
#interrupt-cells = <1>;
|
|
|
|
interrupt-map-mask = <0 0 0 0x7>;
|
|
|
|
interrupt-map = <0 0 0 1 &gic GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<0 0 0 2 &gic GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<0 0 0 3 &gic GIC_SPI 124 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<0 0 0 4 &gic GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
fsl,max-link-speed = <3>;
|
|
|
|
linux,pci-domain = <0>;
|
|
|
|
power-domains = <&hsio_blk_ctrl IMX8MP_HSIOBLK_PD_PCIE>;
|
|
|
|
resets = <&src IMX8MP_RESET_PCIE_CTRL_APPS_EN>,
|
|
|
|
<&src IMX8MP_RESET_PCIE_CTRL_APPS_TURNOFF>;
|
|
|
|
reset-names = "apps", "turnoff";
|
|
|
|
phys = <&pcie_phy>;
|
|
|
|
phy-names = "pcie-phy";
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2025-04-23 20:41:23 -04:00
|
|
|
pcie0_ep: pcie_ep: pcie-ep@33800000 {
|
2023-02-15 14:18:35 +08:00
|
|
|
compatible = "fsl,imx8mp-pcie-ep";
|
2024-08-13 15:42:22 +08:00
|
|
|
reg = <0x33800000 0x100000>,
|
|
|
|
<0x18000000 0x8000000>,
|
|
|
|
<0x33900000 0x100000>,
|
|
|
|
<0x33b00000 0x100000>;
|
|
|
|
reg-names = "dbi", "addr_space", "dbi2", "atu";
|
2023-02-15 14:18:35 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_HSIO_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_HSIO_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_PCIE_ROOT>;
|
|
|
|
clock-names = "pcie", "pcie_bus", "pcie_aux";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_PCIE_AUX>;
|
|
|
|
assigned-clock-rates = <10000000>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_50M>;
|
|
|
|
num-lanes = <1>;
|
|
|
|
interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>; /* eDMA */
|
|
|
|
interrupt-names = "dma";
|
|
|
|
fsl,max-link-speed = <3>;
|
|
|
|
power-domains = <&hsio_blk_ctrl IMX8MP_HSIOBLK_PD_PCIE>;
|
|
|
|
resets = <&src IMX8MP_RESET_PCIE_CTRL_APPS_EN>,
|
|
|
|
<&src IMX8MP_RESET_PCIE_CTRL_APPS_TURNOFF>;
|
|
|
|
reset-names = "apps", "turnoff";
|
|
|
|
phys = <&pcie_phy>;
|
|
|
|
phy-names = "pcie-phy";
|
|
|
|
num-ib-windows = <4>;
|
|
|
|
num-ob-windows = <4>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2022-03-30 12:46:20 +02:00
|
|
|
gpu3d: gpu@38000000 {
|
|
|
|
compatible = "vivante,gc";
|
|
|
|
reg = <0x38000000 0x8000>;
|
|
|
|
interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPU3D_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_GPU3D_SHADER_CORE>,
|
|
|
|
<&clk IMX8MP_CLK_GPU_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_GPU_AHB>;
|
|
|
|
clock-names = "core", "shader", "bus", "reg";
|
2025-05-08 10:18:02 +00:00
|
|
|
#cooling-cells = <2>;
|
2022-03-30 12:46:20 +02:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_GPU3D_CORE>,
|
|
|
|
<&clk IMX8MP_CLK_GPU3D_SHADER_CORE>;
|
2025-02-04 19:27:37 +01:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_1000M>,
|
|
|
|
<&clk IMX8MP_SYS_PLL2_1000M>;
|
|
|
|
assigned-clock-rates = <1000000000>, <1000000000>;
|
2022-03-30 12:46:20 +02:00
|
|
|
power-domains = <&pgc_gpu3d>;
|
|
|
|
};
|
|
|
|
|
|
|
|
gpu2d: gpu@38008000 {
|
|
|
|
compatible = "vivante,gc";
|
|
|
|
reg = <0x38008000 0x8000>;
|
|
|
|
interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_GPU2D_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_GPU_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_GPU_AHB>;
|
|
|
|
clock-names = "core", "bus", "reg";
|
2025-05-08 10:18:02 +00:00
|
|
|
#cooling-cells = <2>;
|
2022-03-30 12:46:20 +02:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_GPU2D_CORE>;
|
2025-02-04 19:27:37 +01:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_1000M>;
|
|
|
|
assigned-clock-rates = <1000000000>;
|
2022-03-30 12:46:20 +02:00
|
|
|
power-domains = <&pgc_gpu2d>;
|
|
|
|
};
|
|
|
|
|
2022-12-20 15:56:38 +01:00
|
|
|
vpu_g1: video-codec@38300000 {
|
|
|
|
compatible = "nxp,imx8mm-vpu-g1";
|
|
|
|
reg = <0x38300000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_VPU_G1_ROOT>;
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_VPU_G1>;
|
2025-06-11 19:39:22 -05:00
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>;
|
|
|
|
assigned-clock-rates = <800000000>;
|
2022-12-20 15:56:38 +01:00
|
|
|
power-domains = <&vpumix_blk_ctrl IMX8MP_VPUBLK_PD_G1>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vpu_g2: video-codec@38310000 {
|
|
|
|
compatible = "nxp,imx8mq-vpu-g2";
|
|
|
|
reg = <0x38310000 0x10000>;
|
|
|
|
interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_VPU_G2_ROOT>;
|
2025-06-11 19:39:22 -05:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_VPU_G2>, <&clk IMX8MP_VPU_PLL_OUT>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_VPU_PLL_OUT>;
|
|
|
|
assigned-clock-rates = <700000000>, <700000000>;
|
2022-12-20 15:56:38 +01:00
|
|
|
power-domains = <&vpumix_blk_ctrl IMX8MP_VPUBLK_PD_G2>;
|
|
|
|
};
|
|
|
|
|
2022-08-22 14:45:36 +08:00
|
|
|
vpumix_blk_ctrl: blk-ctrl@38330000 {
|
|
|
|
compatible = "fsl,imx8mp-vpu-blk-ctrl", "syscon";
|
|
|
|
reg = <0x38330000 0x100>;
|
|
|
|
#power-domain-cells = <1>;
|
|
|
|
power-domains = <&pgc_vpumix>, <&pgc_vpu_g1>,
|
|
|
|
<&pgc_vpu_g2>, <&pgc_vpu_vc8000e>;
|
|
|
|
power-domain-names = "bus", "g1", "g2", "vc8000e";
|
|
|
|
clocks = <&clk IMX8MP_CLK_VPU_G1_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_VPU_G2_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_VPU_VC8KE_ROOT>;
|
|
|
|
clock-names = "g1", "g2", "vc8000e";
|
2025-06-11 19:39:22 -05:00
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_VPU_BUS>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_SYS_PLL1_800M>;
|
|
|
|
assigned-clock-rates = <800000000>;
|
2022-08-22 14:45:36 +08:00
|
|
|
interconnects = <&noc IMX8MP_ICM_VPU_G1 &noc IMX8MP_ICN_VIDEO>,
|
|
|
|
<&noc IMX8MP_ICM_VPU_G2 &noc IMX8MP_ICN_VIDEO>,
|
|
|
|
<&noc IMX8MP_ICM_VPU_H1 &noc IMX8MP_ICN_VIDEO>;
|
|
|
|
interconnect-names = "g1", "g2", "vc8000e";
|
|
|
|
};
|
|
|
|
|
2023-10-22 11:19:10 -05:00
|
|
|
npu: npu@38500000 {
|
|
|
|
compatible = "vivante,gc";
|
|
|
|
reg = <0x38500000 0x200000>;
|
|
|
|
interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_NPU_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_NPU_ROOT>,
|
|
|
|
<&clk IMX8MP_CLK_ML_AXI>,
|
|
|
|
<&clk IMX8MP_CLK_ML_AHB>;
|
|
|
|
clock-names = "core", "shader", "bus", "reg";
|
2025-05-08 10:18:02 +00:00
|
|
|
#cooling-cells = <2>;
|
2023-10-22 11:19:10 -05:00
|
|
|
power-domains = <&pgc_mlmix>;
|
|
|
|
};
|
|
|
|
|
2020-02-11 20:48:25 +08:00
|
|
|
gic: interrupt-controller@38800000 {
|
|
|
|
compatible = "arm,gic-v3";
|
|
|
|
reg = <0x38800000 0x10000>,
|
|
|
|
<0x38880000 0xc0000>;
|
|
|
|
#interrupt-cells = <3>;
|
|
|
|
interrupt-controller;
|
|
|
|
interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
interrupt-parent = <&gic>;
|
|
|
|
};
|
2020-06-29 16:42:30 +08:00
|
|
|
|
2022-03-21 15:51:31 +08:00
|
|
|
edacmc: memory-controller@3d400000 {
|
|
|
|
compatible = "snps,ddrc-3.80a";
|
|
|
|
reg = <0x3d400000 0x400000>;
|
|
|
|
interrupts = <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
};
|
|
|
|
|
2020-06-29 16:42:30 +08:00
|
|
|
ddr-pmu@3d800000 {
|
|
|
|
compatible = "fsl,imx8mp-ddr-pmu", "fsl,imx8m-ddr-pmu";
|
|
|
|
reg = <0x3d800000 0x400000>;
|
|
|
|
interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
};
|
2020-12-29 19:37:45 +08:00
|
|
|
|
|
|
|
usb3_phy0: usb-phy@381f0040 {
|
|
|
|
compatible = "fsl,imx8mp-usb-phy";
|
|
|
|
reg = <0x381f0040 0x40>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_USB_PHY_ROOT>;
|
|
|
|
clock-names = "phy";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_USB_PHY_REF>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_CLK_24M>;
|
2022-04-06 17:33:59 +02:00
|
|
|
power-domains = <&hsio_blk_ctrl IMX8MP_HSIOBLK_PD_USB_PHY1>;
|
2020-12-29 19:37:45 +08:00
|
|
|
#phy-cells = <0>;
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
usb3_0: usb@32f10100 {
|
|
|
|
compatible = "fsl,imx8mp-dwc3";
|
2022-02-18 16:27:07 +01:00
|
|
|
reg = <0x32f10100 0x8>,
|
|
|
|
<0x381f0000 0x20>;
|
2020-12-29 19:37:45 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_HSIO_ROOT>,
|
2022-09-30 22:54:23 +08:00
|
|
|
<&clk IMX8MP_CLK_USB_SUSP>;
|
2020-12-29 19:37:45 +08:00
|
|
|
clock-names = "hsio", "suspend";
|
|
|
|
interrupts = <GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>;
|
2022-04-06 17:33:59 +02:00
|
|
|
power-domains = <&hsio_blk_ctrl IMX8MP_HSIOBLK_PD_USB>;
|
2020-12-29 19:37:45 +08:00
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
dma-ranges = <0x40000000 0x40000000 0xc0000000>;
|
|
|
|
ranges;
|
|
|
|
status = "disabled";
|
|
|
|
|
2021-03-29 15:27:14 +08:00
|
|
|
usb_dwc3_0: usb@38100000 {
|
2020-12-29 19:37:45 +08:00
|
|
|
compatible = "snps,dwc3";
|
|
|
|
reg = <0x38100000 0x10000>;
|
2022-09-30 22:54:23 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_USB_ROOT>,
|
2020-12-29 19:37:45 +08:00
|
|
|
<&clk IMX8MP_CLK_USB_CORE_REF>,
|
2022-09-30 22:54:23 +08:00
|
|
|
<&clk IMX8MP_CLK_USB_SUSP>;
|
2020-12-29 19:37:45 +08:00
|
|
|
clock-names = "bus_early", "ref", "suspend";
|
|
|
|
interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
phys = <&usb3_phy0>, <&usb3_phy0>;
|
|
|
|
phy-names = "usb2-phy", "usb3-phy";
|
2022-09-15 08:28:54 +02:00
|
|
|
snps,gfladj-refclk-lpm-sel-quirk;
|
2023-11-06 02:14:36 +00:00
|
|
|
snps,parkmode-disable-ss-quirk;
|
2020-12-29 19:37:45 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
usb3_phy1: usb-phy@382f0040 {
|
|
|
|
compatible = "fsl,imx8mp-usb-phy";
|
|
|
|
reg = <0x382f0040 0x40>;
|
|
|
|
clocks = <&clk IMX8MP_CLK_USB_PHY_ROOT>;
|
|
|
|
clock-names = "phy";
|
|
|
|
assigned-clocks = <&clk IMX8MP_CLK_USB_PHY_REF>;
|
|
|
|
assigned-clock-parents = <&clk IMX8MP_CLK_24M>;
|
2022-04-06 17:33:59 +02:00
|
|
|
power-domains = <&hsio_blk_ctrl IMX8MP_HSIOBLK_PD_USB_PHY2>;
|
2020-12-29 19:37:45 +08:00
|
|
|
#phy-cells = <0>;
|
2022-01-19 14:23:48 +01:00
|
|
|
status = "disabled";
|
2020-12-29 19:37:45 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
usb3_1: usb@32f10108 {
|
|
|
|
compatible = "fsl,imx8mp-dwc3";
|
2022-02-18 16:27:07 +01:00
|
|
|
reg = <0x32f10108 0x8>,
|
|
|
|
<0x382f0000 0x20>;
|
2020-12-29 19:37:45 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_HSIO_ROOT>,
|
2022-09-30 22:54:23 +08:00
|
|
|
<&clk IMX8MP_CLK_USB_SUSP>;
|
2020-12-29 19:37:45 +08:00
|
|
|
clock-names = "hsio", "suspend";
|
|
|
|
interrupts = <GIC_SPI 149 IRQ_TYPE_LEVEL_HIGH>;
|
2022-04-06 17:33:59 +02:00
|
|
|
power-domains = <&hsio_blk_ctrl IMX8MP_HSIOBLK_PD_USB>;
|
2020-12-29 19:37:45 +08:00
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
dma-ranges = <0x40000000 0x40000000 0xc0000000>;
|
|
|
|
ranges;
|
|
|
|
status = "disabled";
|
|
|
|
|
2021-03-29 15:27:14 +08:00
|
|
|
usb_dwc3_1: usb@38200000 {
|
2020-12-29 19:37:45 +08:00
|
|
|
compatible = "snps,dwc3";
|
|
|
|
reg = <0x38200000 0x10000>;
|
2022-09-30 22:54:23 +08:00
|
|
|
clocks = <&clk IMX8MP_CLK_USB_ROOT>,
|
2020-12-29 19:37:45 +08:00
|
|
|
<&clk IMX8MP_CLK_USB_CORE_REF>,
|
2022-09-30 22:54:23 +08:00
|
|
|
<&clk IMX8MP_CLK_USB_SUSP>;
|
2020-12-29 19:37:45 +08:00
|
|
|
clock-names = "bus_early", "ref", "suspend";
|
|
|
|
interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
phys = <&usb3_phy1>, <&usb3_phy1>;
|
|
|
|
phy-names = "usb2-phy", "usb3-phy";
|
2022-09-15 08:28:54 +02:00
|
|
|
snps,gfladj-refclk-lpm-sel-quirk;
|
2023-11-06 02:14:36 +00:00
|
|
|
snps,parkmode-disable-ss-quirk;
|
2020-12-29 19:37:45 +08:00
|
|
|
};
|
|
|
|
};
|
2021-07-23 14:05:40 +03:00
|
|
|
|
|
|
|
dsp: dsp@3b6e8000 {
|
2025-03-20 14:09:53 +02:00
|
|
|
compatible = "fsl,imx8mp-hifi4";
|
2021-07-23 14:05:40 +03:00
|
|
|
reg = <0x3b6e8000 0x88000>;
|
2025-03-20 14:09:54 +02:00
|
|
|
clocks = <&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_DSP_ROOT>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_OCRAMA_IPG>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_DSP_ROOT>,
|
|
|
|
<&audio_blk_ctrl IMX8MP_CLK_AUDIOMIX_DSPDBG_ROOT>;
|
|
|
|
clock-names = "ipg", "ocram", "core", "debug";
|
2025-03-20 14:09:53 +02:00
|
|
|
power-domains = <&pgc_audio>;
|
|
|
|
mbox-names = "tx", "rx", "rxdb";
|
|
|
|
mboxes = <&mu2 0 0>, <&mu2 1 0>, <&mu2 3 0>;
|
|
|
|
firmware-name = "imx/dsp/hifi4.bin";
|
2025-03-20 14:09:51 +02:00
|
|
|
resets = <&audio_blk_ctrl IMX8MP_AUDIOMIX_DSP_RUNSTALL>;
|
|
|
|
reset-names = "runstall";
|
2021-07-23 14:05:40 +03:00
|
|
|
status = "disabled";
|
|
|
|
};
|
2020-02-11 20:48:25 +08:00
|
|
|
};
|
|
|
|
};
|