arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
/*
|
|
|
|
* Device Tree Source for AM642 SoC Family Main Domain peripherals
|
|
|
|
*
|
|
|
|
* Copyright (C) 2020-2021 Texas Instruments Incorporated - https://www.ti.com/
|
|
|
|
*/
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
#include <dt-bindings/phy/phy-cadence.h>
|
|
|
|
#include <dt-bindings/phy/phy-ti.h>
|
|
|
|
|
|
|
|
/ {
|
|
|
|
serdes_refclk: clock-cmnrefclk {
|
|
|
|
#clock-cells = <0>;
|
|
|
|
compatible = "fixed-clock";
|
|
|
|
clock-frequency = <0>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
&cbass_main {
|
|
|
|
oc_sram: sram@70000000 {
|
|
|
|
compatible = "mmio-sram";
|
|
|
|
reg = <0x00 0x70000000 0x00 0x200000>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges = <0x0 0x00 0x70000000 0x200000>;
|
|
|
|
|
2021-06-16 16:38:20 +00:00
|
|
|
tfa-sram@1c0000 {
|
|
|
|
reg = <0x1c0000 0x20000>;
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
};
|
2021-06-16 16:38:21 +00:00
|
|
|
|
|
|
|
dmsc-sram@1e0000 {
|
|
|
|
reg = <0x1e0000 0x1c000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
sproxy-sram@1fc000 {
|
|
|
|
reg = <0x1fc000 0x4000>;
|
|
|
|
};
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
main_conf: syscon@43000000 {
|
|
|
|
compatible = "ti,j721e-system-controller", "syscon", "simple-mfd";
|
|
|
|
reg = <0x0 0x43000000 0x0 0x20000>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges = <0x0 0x0 0x43000000 0x20000>;
|
|
|
|
|
|
|
|
serdes_ln_ctrl: mux-controller {
|
|
|
|
compatible = "mmio-mux";
|
|
|
|
#mux-control-cells = <1>;
|
|
|
|
mux-reg-masks = <0x4080 0x3>; /* SERDES0 lane0 select */
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
gic500: interrupt-controller@1800000 {
|
|
|
|
compatible = "arm,gic-v3";
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
ranges;
|
|
|
|
#interrupt-cells = <3>;
|
|
|
|
interrupt-controller;
|
|
|
|
reg = <0x00 0x01800000 0x00 0x10000>, /* GICD */
|
|
|
|
<0x00 0x01840000 0x00 0xC0000>; /* GICR */
|
|
|
|
/*
|
|
|
|
* vcpumntirq:
|
|
|
|
* virtual CPU interface maintenance interrupt
|
|
|
|
*/
|
|
|
|
interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
|
|
|
|
gic_its: msi-controller@1820000 {
|
|
|
|
compatible = "arm,gic-v3-its";
|
|
|
|
reg = <0x00 0x01820000 0x00 0x10000>;
|
|
|
|
socionext,synquacer-pre-its = <0x1000000 0x400000>;
|
|
|
|
msi-controller;
|
|
|
|
#msi-cells = <1>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
dmss: bus@48000000 {
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
compatible = "simple-mfd";
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
dma-ranges;
|
2021-09-10 21:37:43 +00:00
|
|
|
ranges = <0x00 0x48000000 0x00 0x48000000 0x00 0x06400000>;
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
|
|
|
|
ti,sci-dev-id = <25>;
|
|
|
|
|
|
|
|
secure_proxy_main: mailbox@4d000000 {
|
|
|
|
compatible = "ti,am654-secure-proxy";
|
|
|
|
#mbox-cells = <1>;
|
|
|
|
reg-names = "target_data", "rt", "scfg";
|
|
|
|
reg = <0x00 0x4d000000 0x00 0x80000>,
|
|
|
|
<0x00 0x4a600000 0x00 0x80000>,
|
|
|
|
<0x00 0x4a400000 0x00 0x80000>;
|
|
|
|
interrupt-names = "rx_012";
|
|
|
|
interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
};
|
|
|
|
|
|
|
|
inta_main_dmss: interrupt-controller@48000000 {
|
|
|
|
compatible = "ti,sci-inta";
|
|
|
|
reg = <0x00 0x48000000 0x00 0x100000>;
|
|
|
|
#interrupt-cells = <0>;
|
|
|
|
interrupt-controller;
|
|
|
|
interrupt-parent = <&gic500>;
|
|
|
|
msi-controller;
|
|
|
|
ti,sci = <&dmsc>;
|
|
|
|
ti,sci-dev-id = <28>;
|
|
|
|
ti,interrupt-ranges = <4 68 36>;
|
|
|
|
ti,unmapped-event-sources = <&main_bcdma>, <&main_pktdma>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_bcdma: dma-controller@485c0100 {
|
|
|
|
compatible = "ti,am64-dmss-bcdma";
|
|
|
|
reg = <0x00 0x485c0100 0x00 0x100>,
|
|
|
|
<0x00 0x4c000000 0x00 0x20000>,
|
|
|
|
<0x00 0x4a820000 0x00 0x20000>,
|
|
|
|
<0x00 0x4aa40000 0x00 0x20000>,
|
|
|
|
<0x00 0x4bc00000 0x00 0x100000>;
|
|
|
|
reg-names = "gcfg", "bchanrt", "rchanrt", "tchanrt", "ringrt";
|
|
|
|
msi-parent = <&inta_main_dmss>;
|
|
|
|
#dma-cells = <3>;
|
|
|
|
|
|
|
|
ti,sci = <&dmsc>;
|
|
|
|
ti,sci-dev-id = <26>;
|
|
|
|
ti,sci-rm-range-bchan = <0x20>; /* BLOCK_COPY_CHAN */
|
|
|
|
ti,sci-rm-range-rchan = <0x21>; /* SPLIT_TR_RX_CHAN */
|
|
|
|
ti,sci-rm-range-tchan = <0x22>; /* SPLIT_TR_TX_CHAN */
|
|
|
|
};
|
|
|
|
|
|
|
|
main_pktdma: dma-controller@485c0000 {
|
|
|
|
compatible = "ti,am64-dmss-pktdma";
|
|
|
|
reg = <0x00 0x485c0000 0x00 0x100>,
|
|
|
|
<0x00 0x4a800000 0x00 0x20000>,
|
|
|
|
<0x00 0x4aa00000 0x00 0x40000>,
|
|
|
|
<0x00 0x4b800000 0x00 0x400000>;
|
|
|
|
reg-names = "gcfg", "rchanrt", "tchanrt", "ringrt";
|
|
|
|
msi-parent = <&inta_main_dmss>;
|
|
|
|
#dma-cells = <2>;
|
|
|
|
|
|
|
|
ti,sci = <&dmsc>;
|
|
|
|
ti,sci-dev-id = <30>;
|
|
|
|
ti,sci-rm-range-tchan = <0x23>, /* UNMAPPED_TX_CHAN */
|
|
|
|
<0x24>, /* CPSW_TX_CHAN */
|
|
|
|
<0x25>, /* SAUL_TX_0_CHAN */
|
|
|
|
<0x26>, /* SAUL_TX_1_CHAN */
|
|
|
|
<0x27>, /* ICSSG_0_TX_CHAN */
|
|
|
|
<0x28>; /* ICSSG_1_TX_CHAN */
|
|
|
|
ti,sci-rm-range-tflow = <0x10>, /* RING_UNMAPPED_TX_CHAN */
|
|
|
|
<0x11>, /* RING_CPSW_TX_CHAN */
|
|
|
|
<0x12>, /* RING_SAUL_TX_0_CHAN */
|
|
|
|
<0x13>, /* RING_SAUL_TX_1_CHAN */
|
|
|
|
<0x14>, /* RING_ICSSG_0_TX_CHAN */
|
|
|
|
<0x15>; /* RING_ICSSG_1_TX_CHAN */
|
|
|
|
ti,sci-rm-range-rchan = <0x29>, /* UNMAPPED_RX_CHAN */
|
|
|
|
<0x2b>, /* CPSW_RX_CHAN */
|
|
|
|
<0x2d>, /* SAUL_RX_0_CHAN */
|
|
|
|
<0x2f>, /* SAUL_RX_1_CHAN */
|
|
|
|
<0x31>, /* SAUL_RX_2_CHAN */
|
|
|
|
<0x33>, /* SAUL_RX_3_CHAN */
|
|
|
|
<0x35>, /* ICSSG_0_RX_CHAN */
|
|
|
|
<0x37>; /* ICSSG_1_RX_CHAN */
|
|
|
|
ti,sci-rm-range-rflow = <0x2a>, /* FLOW_UNMAPPED_RX_CHAN */
|
|
|
|
<0x2c>, /* FLOW_CPSW_RX_CHAN */
|
|
|
|
<0x2e>, /* FLOW_SAUL_RX_0/1_CHAN */
|
|
|
|
<0x32>, /* FLOW_SAUL_RX_2/3_CHAN */
|
|
|
|
<0x36>, /* FLOW_ICSSG_0_RX_CHAN */
|
|
|
|
<0x38>; /* FLOW_ICSSG_1_RX_CHAN */
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
dmsc: system-controller@44043000 {
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
compatible = "ti,k2g-sci";
|
|
|
|
ti,host-id = <12>;
|
|
|
|
mbox-names = "rx", "tx";
|
|
|
|
mboxes= <&secure_proxy_main 12>,
|
|
|
|
<&secure_proxy_main 13>;
|
|
|
|
reg-names = "debug_messages";
|
|
|
|
reg = <0x00 0x44043000 0x00 0xfe0>;
|
|
|
|
|
|
|
|
k3_pds: power-controller {
|
|
|
|
compatible = "ti,sci-pm-domain";
|
|
|
|
#power-domain-cells = <2>;
|
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
k3_clks: clock-controller {
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
compatible = "ti,k2g-sci-clk";
|
|
|
|
#clock-cells = <2>;
|
|
|
|
};
|
|
|
|
|
|
|
|
k3_reset: reset-controller {
|
|
|
|
compatible = "ti,sci-reset";
|
|
|
|
#reset-cells = <2>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
main_pmx0: pinctrl@f4000 {
|
|
|
|
compatible = "pinctrl-single";
|
|
|
|
reg = <0x00 0xf4000 0x00 0x2d0>;
|
|
|
|
#pinctrl-cells = <1>;
|
|
|
|
pinctrl-single,register-width = <32>;
|
|
|
|
pinctrl-single,function-mask = <0xffffffff>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_conf: syscon@43000000 {
|
|
|
|
compatible = "syscon", "simple-mfd";
|
|
|
|
reg = <0x00 0x43000000 0x00 0x20000>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges = <0x00 0x00 0x43000000 0x20000>;
|
|
|
|
|
|
|
|
chipid@14 {
|
|
|
|
compatible = "ti,am654-chipid";
|
|
|
|
reg = <0x00000014 0x4>;
|
|
|
|
};
|
2021-05-10 14:36:12 +00:00
|
|
|
|
|
|
|
phy_gmii_sel: phy@4044 {
|
|
|
|
compatible = "ti,am654-phy-gmii-sel";
|
|
|
|
reg = <0x4044 0x8>;
|
|
|
|
#phy-cells = <1>;
|
|
|
|
};
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
main_uart0: serial@2800000 {
|
|
|
|
compatible = "ti,am64-uart", "ti,am654-uart";
|
|
|
|
reg = <0x00 0x02800000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 178 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clock-frequency = <48000000>;
|
|
|
|
current-speed = <115200>;
|
|
|
|
power-domains = <&k3_pds 146 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 146 0>;
|
|
|
|
clock-names = "fclk";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_uart1: serial@2810000 {
|
|
|
|
compatible = "ti,am64-uart", "ti,am654-uart";
|
|
|
|
reg = <0x00 0x02810000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 179 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clock-frequency = <48000000>;
|
|
|
|
current-speed = <115200>;
|
|
|
|
power-domains = <&k3_pds 152 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 152 0>;
|
|
|
|
clock-names = "fclk";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_uart2: serial@2820000 {
|
|
|
|
compatible = "ti,am64-uart", "ti,am654-uart";
|
|
|
|
reg = <0x00 0x02820000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 180 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clock-frequency = <48000000>;
|
|
|
|
current-speed = <115200>;
|
|
|
|
power-domains = <&k3_pds 153 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 153 0>;
|
|
|
|
clock-names = "fclk";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_uart3: serial@2830000 {
|
|
|
|
compatible = "ti,am64-uart", "ti,am654-uart";
|
|
|
|
reg = <0x00 0x02830000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 181 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clock-frequency = <48000000>;
|
|
|
|
current-speed = <115200>;
|
|
|
|
power-domains = <&k3_pds 154 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 154 0>;
|
|
|
|
clock-names = "fclk";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_uart4: serial@2840000 {
|
|
|
|
compatible = "ti,am64-uart", "ti,am654-uart";
|
|
|
|
reg = <0x00 0x02840000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 182 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clock-frequency = <48000000>;
|
|
|
|
current-speed = <115200>;
|
|
|
|
power-domains = <&k3_pds 155 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 155 0>;
|
|
|
|
clock-names = "fclk";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_uart5: serial@2850000 {
|
|
|
|
compatible = "ti,am64-uart", "ti,am654-uart";
|
|
|
|
reg = <0x00 0x02850000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 183 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clock-frequency = <48000000>;
|
|
|
|
current-speed = <115200>;
|
|
|
|
power-domains = <&k3_pds 156 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 156 0>;
|
|
|
|
clock-names = "fclk";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_uart6: serial@2860000 {
|
|
|
|
compatible = "ti,am64-uart", "ti,am654-uart";
|
|
|
|
reg = <0x00 0x02860000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
clock-frequency = <48000000>;
|
|
|
|
current-speed = <115200>;
|
|
|
|
power-domains = <&k3_pds 158 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 158 0>;
|
|
|
|
clock-names = "fclk";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_i2c0: i2c@20000000 {
|
|
|
|
compatible = "ti,am64-i2c", "ti,omap4-i2c";
|
|
|
|
reg = <0x00 0x20000000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 161 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 102 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 102 2>;
|
|
|
|
clock-names = "fck";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_i2c1: i2c@20010000 {
|
|
|
|
compatible = "ti,am64-i2c", "ti,omap4-i2c";
|
|
|
|
reg = <0x00 0x20010000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 162 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 103 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 103 2>;
|
|
|
|
clock-names = "fck";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_i2c2: i2c@20020000 {
|
|
|
|
compatible = "ti,am64-i2c", "ti,omap4-i2c";
|
|
|
|
reg = <0x00 0x20020000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 163 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 104 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 104 2>;
|
|
|
|
clock-names = "fck";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_i2c3: i2c@20030000 {
|
|
|
|
compatible = "ti,am64-i2c", "ti,omap4-i2c";
|
|
|
|
reg = <0x00 0x20030000 0x00 0x100>;
|
|
|
|
interrupts = <GIC_SPI 164 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 105 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 105 2>;
|
|
|
|
clock-names = "fck";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_spi0: spi@20100000 {
|
|
|
|
compatible = "ti,am654-mcspi", "ti,omap4-mcspi";
|
|
|
|
reg = <0x00 0x20100000 0x00 0x400>;
|
|
|
|
interrupts = <GIC_SPI 172 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 141 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 141 0>;
|
|
|
|
dmas = <&main_pktdma 0xc300 0>, <&main_pktdma 0x4300 0>;
|
|
|
|
dma-names = "tx0", "rx0";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_spi1: spi@20110000 {
|
|
|
|
compatible = "ti,am654-mcspi","ti,omap4-mcspi";
|
|
|
|
reg = <0x00 0x20110000 0x00 0x400>;
|
|
|
|
interrupts = <GIC_SPI 173 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 142 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 142 0>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_spi2: spi@20120000 {
|
|
|
|
compatible = "ti,am654-mcspi","ti,omap4-mcspi";
|
|
|
|
reg = <0x00 0x20120000 0x00 0x400>;
|
|
|
|
interrupts = <GIC_SPI 174 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 143 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 143 0>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_spi3: spi@20130000 {
|
|
|
|
compatible = "ti,am654-mcspi","ti,omap4-mcspi";
|
|
|
|
reg = <0x00 0x20130000 0x00 0x400>;
|
|
|
|
interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 144 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 144 0>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_spi4: spi@20140000 {
|
|
|
|
compatible = "ti,am654-mcspi","ti,omap4-mcspi";
|
|
|
|
reg = <0x00 0x20140000 0x00 0x400>;
|
|
|
|
interrupts = <GIC_SPI 175 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
power-domains = <&k3_pds 145 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 145 0>;
|
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
main_gpio_intr: interrupt-controller@a00000 {
|
|
|
|
compatible = "ti,sci-intr";
|
|
|
|
reg = <0x00 0x00a00000 0x00 0x800>;
|
|
|
|
ti,intr-trigger-type = <1>;
|
|
|
|
interrupt-controller;
|
|
|
|
interrupt-parent = <&gic500>;
|
|
|
|
#interrupt-cells = <1>;
|
|
|
|
ti,sci = <&dmsc>;
|
|
|
|
ti,sci-dev-id = <3>;
|
|
|
|
ti,interrupt-ranges = <0 32 16>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_gpio0: gpio@600000 {
|
|
|
|
compatible = "ti,am64-gpio", "ti,keystone-gpio";
|
|
|
|
reg = <0x0 0x00600000 0x0 0x100>;
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
interrupt-parent = <&main_gpio_intr>;
|
|
|
|
interrupts = <190>, <191>, <192>,
|
|
|
|
<193>, <194>, <195>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <2>;
|
|
|
|
ti,ngpio = <87>;
|
|
|
|
ti,davinci-gpio-unbanked = <0>;
|
|
|
|
power-domains = <&k3_pds 77 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 77 0>;
|
|
|
|
clock-names = "gpio";
|
|
|
|
};
|
|
|
|
|
|
|
|
main_gpio1: gpio@601000 {
|
|
|
|
compatible = "ti,am64-gpio", "ti,keystone-gpio";
|
|
|
|
reg = <0x0 0x00601000 0x0 0x100>;
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
interrupt-parent = <&main_gpio_intr>;
|
|
|
|
interrupts = <180>, <181>, <182>,
|
|
|
|
<183>, <184>, <185>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <2>;
|
|
|
|
ti,ngpio = <88>;
|
|
|
|
ti,davinci-gpio-unbanked = <0>;
|
|
|
|
power-domains = <&k3_pds 78 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 78 0>;
|
|
|
|
clock-names = "gpio";
|
|
|
|
};
|
|
|
|
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
sdhci0: mmc@fa10000 {
|
|
|
|
compatible = "ti,am64-sdhci-8bit";
|
|
|
|
reg = <0x00 0xfa10000 0x00 0x260>, <0x00 0xfa18000 0x00 0x134>;
|
|
|
|
interrupts = <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
power-domains = <&k3_pds 57 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 57 0>, <&k3_clks 57 1>;
|
|
|
|
clock-names = "clk_ahb", "clk_xin";
|
|
|
|
mmc-ddr-1_8v;
|
|
|
|
mmc-hs200-1_8v;
|
|
|
|
mmc-hs400-1_8v;
|
|
|
|
ti,trm-icp = <0x2>;
|
|
|
|
ti,otap-del-sel-legacy = <0x0>;
|
|
|
|
ti,otap-del-sel-mmc-hs = <0x0>;
|
|
|
|
ti,otap-del-sel-ddr52 = <0x6>;
|
|
|
|
ti,otap-del-sel-hs200 = <0x7>;
|
|
|
|
ti,otap-del-sel-hs400 = <0x4>;
|
|
|
|
};
|
|
|
|
|
|
|
|
sdhci1: mmc@fa00000 {
|
|
|
|
compatible = "ti,am64-sdhci-4bit";
|
|
|
|
reg = <0x00 0xfa00000 0x00 0x260>, <0x00 0xfa08000 0x00 0x134>;
|
|
|
|
interrupts = <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
power-domains = <&k3_pds 58 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 58 3>, <&k3_clks 58 4>;
|
|
|
|
clock-names = "clk_ahb", "clk_xin";
|
|
|
|
ti,trm-icp = <0x2>;
|
|
|
|
ti,otap-del-sel-legacy = <0x0>;
|
|
|
|
ti,otap-del-sel-sd-hs = <0xf>;
|
|
|
|
ti,otap-del-sel-sdr12 = <0xf>;
|
|
|
|
ti,otap-del-sel-sdr25 = <0xf>;
|
|
|
|
ti,otap-del-sel-sdr50 = <0xc>;
|
|
|
|
ti,otap-del-sel-sdr104 = <0x6>;
|
|
|
|
ti,otap-del-sel-ddr50 = <0x9>;
|
|
|
|
ti,clkbuf-sel = <0x7>;
|
|
|
|
};
|
2021-05-04 23:00:54 +00:00
|
|
|
|
2021-05-10 14:36:12 +00:00
|
|
|
cpsw3g: ethernet@8000000 {
|
|
|
|
compatible = "ti,am642-cpsw-nuss";
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
reg = <0x0 0x8000000 0x0 0x200000>;
|
|
|
|
reg-names = "cpsw_nuss";
|
|
|
|
ranges = <0x0 0x0 0x0 0x8000000 0x0 0x200000>;
|
|
|
|
clocks = <&k3_clks 13 0>;
|
|
|
|
assigned-clocks = <&k3_clks 13 1>;
|
|
|
|
assigned-clock-parents = <&k3_clks 13 9>;
|
|
|
|
clock-names = "fck";
|
|
|
|
power-domains = <&k3_pds 13 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
|
|
|
|
dmas = <&main_pktdma 0xC500 15>,
|
|
|
|
<&main_pktdma 0xC501 15>,
|
|
|
|
<&main_pktdma 0xC502 15>,
|
|
|
|
<&main_pktdma 0xC503 15>,
|
|
|
|
<&main_pktdma 0xC504 15>,
|
|
|
|
<&main_pktdma 0xC505 15>,
|
|
|
|
<&main_pktdma 0xC506 15>,
|
|
|
|
<&main_pktdma 0xC507 15>,
|
|
|
|
<&main_pktdma 0x4500 15>;
|
|
|
|
dma-names = "tx0", "tx1", "tx2", "tx3", "tx4", "tx5", "tx6",
|
|
|
|
"tx7", "rx";
|
|
|
|
|
|
|
|
ethernet-ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
cpsw_port1: port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
ti,mac-only;
|
|
|
|
label = "port1";
|
|
|
|
phys = <&phy_gmii_sel 1>;
|
2021-09-10 21:37:43 +00:00
|
|
|
mac-address = [00 00 00 00 00 00];
|
|
|
|
ti,syscon-efuse = <&main_conf 0x200>;
|
2021-05-10 14:36:12 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
cpsw_port2: port@2 {
|
|
|
|
reg = <2>;
|
|
|
|
ti,mac-only;
|
|
|
|
label = "port2";
|
|
|
|
phys = <&phy_gmii_sel 2>;
|
2021-09-10 21:37:43 +00:00
|
|
|
mac-address = [00 00 00 00 00 00];
|
2021-05-10 14:36:12 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
cpsw3g_mdio: mdio@f00 {
|
|
|
|
compatible = "ti,cpsw-mdio","ti,davinci_mdio";
|
|
|
|
reg = <0x0 0xf00 0x0 0x100>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
clocks = <&k3_clks 13 0>;
|
|
|
|
clock-names = "fck";
|
|
|
|
bus_freq = <1000000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
cpts@3d000 {
|
|
|
|
compatible = "ti,j721e-cpts";
|
|
|
|
reg = <0x0 0x3d000 0x0 0x400>;
|
|
|
|
clocks = <&k3_clks 13 1>;
|
|
|
|
clock-names = "cpts";
|
|
|
|
interrupts-extended = <&gic500 GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
interrupt-names = "cpts";
|
|
|
|
ti,cpts-ext-ts-inputs = <4>;
|
|
|
|
ti,cpts-periodic-outputs = <2>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
cpts@39000000 {
|
|
|
|
compatible = "ti,j721e-cpts";
|
|
|
|
reg = <0x0 0x39000000 0x0 0x400>;
|
|
|
|
reg-names = "cpts";
|
|
|
|
power-domains = <&k3_pds 84 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 84 0>;
|
|
|
|
clock-names = "cpts";
|
|
|
|
assigned-clocks = <&k3_clks 84 0>;
|
|
|
|
assigned-clock-parents = <&k3_clks 84 8>;
|
|
|
|
interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
interrupt-names = "cpts";
|
|
|
|
ti,cpts-periodic-outputs = <6>;
|
|
|
|
ti,cpts-ext-ts-inputs = <8>;
|
2021-05-04 23:00:54 +00:00
|
|
|
};
|
|
|
|
|
2021-06-04 16:30:35 +00:00
|
|
|
usbss0: cdns-usb@f900000{
|
2021-09-10 21:37:43 +00:00
|
|
|
compatible = "ti,am64-usb";
|
2021-06-04 16:30:35 +00:00
|
|
|
reg = <0x00 0xf900000 0x00 0x100>;
|
|
|
|
power-domains = <&k3_pds 161 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 161 9>, <&k3_clks 161 1>;
|
|
|
|
clock-names = "ref", "lpm";
|
|
|
|
assigned-clocks = <&k3_clks 161 9>; /* USB2_REFCLK */
|
|
|
|
assigned-clock-parents = <&k3_clks 161 10>; /* HF0SC0 */
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
ranges;
|
|
|
|
usb0: usb@f400000{
|
|
|
|
compatible = "cdns,usb3";
|
|
|
|
reg = <0x00 0xf400000 0x00 0x10000>,
|
|
|
|
<0x00 0xf410000 0x00 0x10000>,
|
|
|
|
<0x00 0xf420000 0x00 0x10000>;
|
|
|
|
reg-names = "otg",
|
|
|
|
"xhci",
|
|
|
|
"dev";
|
|
|
|
interrupts = <GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>, /* irq.0 */
|
|
|
|
<GIC_SPI 194 IRQ_TYPE_LEVEL_HIGH>, /* irq.6 */
|
|
|
|
<GIC_SPI 196 IRQ_TYPE_LEVEL_HIGH>; /* otgirq */
|
|
|
|
interrupt-names = "host",
|
|
|
|
"peripheral",
|
|
|
|
"otg";
|
|
|
|
maximum-speed = "super-speed";
|
|
|
|
dr_mode = "otg";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
tscadc0: tscadc@28001000 {
|
|
|
|
compatible = "ti,am654-tscadc", "ti,am3359-tscadc";
|
|
|
|
reg = <0x00 0x28001000 0x00 0x1000>;
|
|
|
|
interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
power-domains = <&k3_pds 0 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 0 0>;
|
|
|
|
assigned-clocks = <&k3_clks 0 0>;
|
|
|
|
assigned-clock-parents = <&k3_clks 0 3>;
|
|
|
|
assigned-clock-rates = <60000000>;
|
|
|
|
clock-names = "adc_tsc_fck";
|
|
|
|
|
|
|
|
adc {
|
|
|
|
#io-channel-cells = <1>;
|
|
|
|
compatible = "ti,am654-adc", "ti,am3359-adc";
|
|
|
|
};
|
2021-05-04 23:00:54 +00:00
|
|
|
};
|
2021-05-06 11:14:58 +00:00
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
fss: bus@fc00000 {
|
|
|
|
compatible = "simple-bus";
|
|
|
|
reg = <0x00 0x0fc00000 0x00 0x70000>;
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
ranges;
|
|
|
|
|
|
|
|
ospi0: spi@fc40000 {
|
|
|
|
compatible = "ti,am654-ospi", "cdns,qspi-nor";
|
|
|
|
reg = <0x00 0x0fc40000 0x00 0x100>,
|
|
|
|
<0x05 0x00000000 0x01 0x00000000>;
|
|
|
|
interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
cdns,fifo-depth = <256>;
|
|
|
|
cdns,fifo-width = <4>;
|
|
|
|
cdns,trigger-address = <0x0>;
|
|
|
|
#address-cells = <0x1>;
|
|
|
|
#size-cells = <0x0>;
|
|
|
|
clocks = <&k3_clks 75 6>;
|
|
|
|
assigned-clocks = <&k3_clks 75 6>;
|
|
|
|
assigned-clock-parents = <&k3_clks 75 7>;
|
|
|
|
assigned-clock-rates = <166666666>;
|
|
|
|
power-domains = <&k3_pds 75 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
};
|
2021-05-06 11:14:58 +00:00
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
hwspinlock: spinlock@2a000000 {
|
|
|
|
compatible = "ti,am64-hwspinlock";
|
|
|
|
reg = <0x00 0x2a000000 0x00 0x1000>;
|
|
|
|
#hwlock-cells = <1>;
|
|
|
|
};
|
|
|
|
|
|
|
|
mailbox0_cluster2: mailbox@29020000 {
|
|
|
|
compatible = "ti,am64-mailbox";
|
|
|
|
reg = <0x00 0x29020000 0x00 0x200>;
|
|
|
|
interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#mbox-cells = <1>;
|
|
|
|
ti,mbox-num-users = <4>;
|
|
|
|
ti,mbox-num-fifos = <16>;
|
|
|
|
};
|
|
|
|
|
|
|
|
mailbox0_cluster3: mailbox@29030000 {
|
|
|
|
compatible = "ti,am64-mailbox";
|
|
|
|
reg = <0x00 0x29030000 0x00 0x200>;
|
|
|
|
interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#mbox-cells = <1>;
|
|
|
|
ti,mbox-num-users = <4>;
|
|
|
|
ti,mbox-num-fifos = <16>;
|
|
|
|
};
|
|
|
|
|
|
|
|
mailbox0_cluster4: mailbox@29040000 {
|
|
|
|
compatible = "ti,am64-mailbox";
|
|
|
|
reg = <0x00 0x29040000 0x00 0x200>;
|
|
|
|
interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#mbox-cells = <1>;
|
|
|
|
ti,mbox-num-users = <4>;
|
|
|
|
ti,mbox-num-fifos = <16>;
|
|
|
|
};
|
|
|
|
|
|
|
|
mailbox0_cluster5: mailbox@29050000 {
|
|
|
|
compatible = "ti,am64-mailbox";
|
|
|
|
reg = <0x00 0x29050000 0x00 0x200>;
|
|
|
|
interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#mbox-cells = <1>;
|
|
|
|
ti,mbox-num-users = <4>;
|
|
|
|
ti,mbox-num-fifos = <16>;
|
|
|
|
};
|
|
|
|
|
|
|
|
mailbox0_cluster6: mailbox@29060000 {
|
|
|
|
compatible = "ti,am64-mailbox";
|
|
|
|
reg = <0x00 0x29060000 0x00 0x200>;
|
|
|
|
interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#mbox-cells = <1>;
|
|
|
|
ti,mbox-num-users = <4>;
|
|
|
|
ti,mbox-num-fifos = <16>;
|
|
|
|
};
|
|
|
|
|
|
|
|
mailbox0_cluster7: mailbox@29070000 {
|
|
|
|
compatible = "ti,am64-mailbox";
|
|
|
|
reg = <0x00 0x29070000 0x00 0x200>;
|
|
|
|
interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
#mbox-cells = <1>;
|
|
|
|
ti,mbox-num-users = <4>;
|
|
|
|
ti,mbox-num-fifos = <16>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_r5fss0: r5fss@78000000 {
|
|
|
|
compatible = "ti,am64-r5fss";
|
|
|
|
ti,cluster-mode = <0>;
|
2021-05-06 11:14:58 +00:00
|
|
|
#address-cells = <1>;
|
2021-09-10 21:37:43 +00:00
|
|
|
#size-cells = <1>;
|
|
|
|
ranges = <0x78000000 0x00 0x78000000 0x10000>,
|
|
|
|
<0x78100000 0x00 0x78100000 0x10000>,
|
|
|
|
<0x78200000 0x00 0x78200000 0x08000>,
|
|
|
|
<0x78300000 0x00 0x78300000 0x08000>;
|
|
|
|
power-domains = <&k3_pds 119 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
|
|
|
|
main_r5fss0_core0: r5f@78000000 {
|
|
|
|
compatible = "ti,am64-r5f";
|
|
|
|
reg = <0x78000000 0x00010000>,
|
|
|
|
<0x78100000 0x00010000>;
|
|
|
|
reg-names = "atcm", "btcm";
|
|
|
|
ti,sci = <&dmsc>;
|
|
|
|
ti,sci-dev-id = <121>;
|
|
|
|
ti,sci-proc-ids = <0x01 0xff>;
|
|
|
|
resets = <&k3_reset 121 1>;
|
|
|
|
firmware-name = "am64-main-r5f0_0-fw";
|
|
|
|
ti,atcm-enable = <1>;
|
|
|
|
ti,btcm-enable = <1>;
|
|
|
|
ti,loczrama = <1>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_r5fss0_core1: r5f@78200000 {
|
|
|
|
compatible = "ti,am64-r5f";
|
|
|
|
reg = <0x78200000 0x00008000>,
|
|
|
|
<0x78300000 0x00008000>;
|
|
|
|
reg-names = "atcm", "btcm";
|
|
|
|
ti,sci = <&dmsc>;
|
|
|
|
ti,sci-dev-id = <122>;
|
|
|
|
ti,sci-proc-ids = <0x02 0xff>;
|
|
|
|
resets = <&k3_reset 122 1>;
|
|
|
|
firmware-name = "am64-main-r5f0_1-fw";
|
|
|
|
ti,atcm-enable = <1>;
|
|
|
|
ti,btcm-enable = <1>;
|
|
|
|
ti,loczrama = <1>;
|
|
|
|
};
|
2021-05-06 11:14:58 +00:00
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
main_r5fss1: r5fss@78400000 {
|
|
|
|
compatible = "ti,am64-r5fss";
|
|
|
|
ti,cluster-mode = <0>;
|
2021-05-06 11:14:58 +00:00
|
|
|
#address-cells = <1>;
|
2021-09-10 21:37:43 +00:00
|
|
|
#size-cells = <1>;
|
|
|
|
ranges = <0x78400000 0x00 0x78400000 0x10000>,
|
|
|
|
<0x78500000 0x00 0x78500000 0x10000>,
|
|
|
|
<0x78600000 0x00 0x78600000 0x08000>,
|
|
|
|
<0x78700000 0x00 0x78700000 0x08000>;
|
|
|
|
power-domains = <&k3_pds 120 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
|
|
|
|
main_r5fss1_core0: r5f@78400000 {
|
|
|
|
compatible = "ti,am64-r5f";
|
|
|
|
reg = <0x78400000 0x00010000>,
|
|
|
|
<0x78500000 0x00010000>;
|
|
|
|
reg-names = "atcm", "btcm";
|
|
|
|
ti,sci = <&dmsc>;
|
|
|
|
ti,sci-dev-id = <123>;
|
|
|
|
ti,sci-proc-ids = <0x06 0xff>;
|
|
|
|
resets = <&k3_reset 123 1>;
|
|
|
|
firmware-name = "am64-main-r5f1_0-fw";
|
|
|
|
ti,atcm-enable = <1>;
|
|
|
|
ti,btcm-enable = <1>;
|
|
|
|
ti,loczrama = <1>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_r5fss1_core1: r5f@78600000 {
|
|
|
|
compatible = "ti,am64-r5f";
|
|
|
|
reg = <0x78600000 0x00008000>,
|
|
|
|
<0x78700000 0x00008000>;
|
|
|
|
reg-names = "atcm", "btcm";
|
|
|
|
ti,sci = <&dmsc>;
|
|
|
|
ti,sci-dev-id = <124>;
|
|
|
|
ti,sci-proc-ids = <0x07 0xff>;
|
|
|
|
resets = <&k3_reset 124 1>;
|
|
|
|
firmware-name = "am64-main-r5f1_1-fw";
|
|
|
|
ti,atcm-enable = <1>;
|
|
|
|
ti,btcm-enable = <1>;
|
|
|
|
ti,loczrama = <1>;
|
|
|
|
};
|
2021-05-06 11:14:58 +00:00
|
|
|
};
|
|
|
|
|
2021-09-10 21:37:43 +00:00
|
|
|
serdes_wiz0: wiz@f000000 {
|
|
|
|
compatible = "ti,am64-wiz-10g";
|
2021-05-06 11:14:58 +00:00
|
|
|
#address-cells = <1>;
|
2021-09-10 21:37:43 +00:00
|
|
|
#size-cells = <1>;
|
|
|
|
power-domains = <&k3_pds 162 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 162 0>, <&k3_clks 162 1>, <&serdes_refclk>;
|
|
|
|
clock-names = "fck", "core_ref_clk", "ext_ref_clk";
|
|
|
|
num-lanes = <1>;
|
|
|
|
#reset-cells = <1>;
|
|
|
|
#clock-cells = <1>;
|
|
|
|
ranges = <0x0f000000 0x0 0x0f000000 0x00010000>;
|
|
|
|
|
|
|
|
assigned-clocks = <&k3_clks 162 1>;
|
|
|
|
assigned-clock-parents = <&k3_clks 162 5>;
|
|
|
|
|
|
|
|
serdes0: serdes@f000000 {
|
|
|
|
compatible = "ti,j721e-serdes-10g";
|
|
|
|
reg = <0x0f000000 0x00010000>;
|
|
|
|
reg-names = "torrent_phy";
|
|
|
|
resets = <&serdes_wiz0 0>;
|
|
|
|
reset-names = "torrent_reset";
|
|
|
|
clocks = <&serdes_wiz0 TI_WIZ_PLL0_REFCLK>,
|
|
|
|
<&serdes_wiz0 TI_WIZ_PHY_EN_REFCLK>;
|
|
|
|
clock-names = "refclk", "phy_en_refclk";
|
|
|
|
assigned-clocks = <&serdes_wiz0 TI_WIZ_PLL0_REFCLK>,
|
|
|
|
<&serdes_wiz0 TI_WIZ_PLL1_REFCLK>,
|
|
|
|
<&serdes_wiz0 TI_WIZ_REFCLK_DIG>;
|
|
|
|
assigned-clock-parents = <&k3_clks 162 1>,
|
|
|
|
<&k3_clks 162 1>,
|
|
|
|
<&k3_clks 162 1>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
#clock-cells = <1>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
pcie0_rc: pcie@f102000 {
|
|
|
|
compatible = "ti,am64-pcie-host", "ti,j721e-pcie-host";
|
|
|
|
reg = <0x00 0x0f102000 0x00 0x1000>,
|
|
|
|
<0x00 0x0f100000 0x00 0x400>,
|
|
|
|
<0x00 0x0d000000 0x00 0x00800000>,
|
|
|
|
<0x00 0x68000000 0x00 0x00001000>;
|
|
|
|
reg-names = "intd_cfg", "user_cfg", "reg", "cfg";
|
|
|
|
interrupt-names = "link_state";
|
|
|
|
interrupts = <GIC_SPI 203 IRQ_TYPE_EDGE_RISING>;
|
|
|
|
device_type = "pci";
|
|
|
|
ti,syscon-pcie-ctrl = <&main_conf 0x4070>;
|
|
|
|
max-link-speed = <2>;
|
|
|
|
num-lanes = <1>;
|
|
|
|
power-domains = <&k3_pds 114 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 114 0>, <&serdes0 CDNS_TORRENT_REFCLK_DRIVER>;
|
|
|
|
clock-names = "fck", "pcie_refclk";
|
|
|
|
#address-cells = <3>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
bus-range = <0x0 0xff>;
|
|
|
|
cdns,no-bar-match-nbits = <64>;
|
|
|
|
vendor-id = <0x104c>;
|
|
|
|
device-id = <0xb010>;
|
|
|
|
msi-map = <0x0 &gic_its 0x0 0x10000>;
|
|
|
|
ranges = <0x01000000 0x00 0x68001000 0x00 0x68001000 0x00 0x0010000>,
|
|
|
|
<0x02000000 0x00 0x68011000 0x00 0x68011000 0x00 0x7fef000>;
|
|
|
|
dma-ranges = <0x02000000 0x0 0x0 0x0 0x0 0x00000010 0x0>;
|
|
|
|
};
|
|
|
|
|
|
|
|
pcie0_ep: pcie-ep@f102000 {
|
|
|
|
compatible = "ti,am64-pcie-ep", "ti,j721e-pcie-ep";
|
|
|
|
reg = <0x00 0x0f102000 0x00 0x1000>,
|
|
|
|
<0x00 0x0f100000 0x00 0x400>,
|
|
|
|
<0x00 0x0d000000 0x00 0x00800000>,
|
|
|
|
<0x00 0x68000000 0x00 0x08000000>;
|
|
|
|
reg-names = "intd_cfg", "user_cfg", "reg", "mem";
|
|
|
|
interrupt-names = "link_state";
|
|
|
|
interrupts = <GIC_SPI 203 IRQ_TYPE_EDGE_RISING>;
|
|
|
|
ti,syscon-pcie-ctrl = <&main_conf 0x4070>;
|
|
|
|
max-link-speed = <2>;
|
|
|
|
num-lanes = <1>;
|
|
|
|
power-domains = <&k3_pds 114 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
clocks = <&k3_clks 114 0>;
|
2021-05-06 11:14:58 +00:00
|
|
|
clock-names = "fck";
|
2021-09-10 21:37:43 +00:00
|
|
|
max-functions = /bits/ 8 <1>;
|
2021-05-06 11:14:58 +00:00
|
|
|
};
|
2022-10-26 11:15:55 +00:00
|
|
|
|
|
|
|
main_rti0: watchdog@e000000 {
|
|
|
|
compatible = "ti,j7-rti-wdt";
|
|
|
|
reg = <0x00 0xe000000 0x00 0x100>;
|
|
|
|
clocks = <&k3_clks 125 0>;
|
|
|
|
power-domains = <&k3_pds 125 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
assigned-clocks = <&k3_clks 125 0>;
|
|
|
|
assigned-clock-parents = <&k3_clks 125 2>;
|
|
|
|
};
|
|
|
|
|
|
|
|
main_rti1: watchdog@e010000 {
|
|
|
|
compatible = "ti,j7-rti-wdt";
|
|
|
|
reg = <0x00 0xe010000 0x00 0x100>;
|
|
|
|
clocks = <&k3_clks 126 0>;
|
|
|
|
power-domains = <&k3_pds 126 TI_SCI_PD_EXCLUSIVE>;
|
|
|
|
assigned-clocks = <&k3_clks 126 0>;
|
|
|
|
assigned-clock-parents = <&k3_clks 126 2>;
|
|
|
|
};
|
arm: dts: ti: Add Support for AM642 SoC
The AM642 SoC belongs to the K3 Multicore SoC architecture platform,
providing advanced system integration to enable applications such as
Motor Drives, PLC, Remote IO and IoT Gateways.
Some highlights of this SoC are:
* Dual Cortex-A53s in a single cluster, two clusters of dual Cortex-R5F
MCUs, and a single Cortex-M4F.
* Two Gigabit Industrial Communication Subsystems (ICSSG).
* Integrated Ethernet switch supporting up to a total of two external
ports.
* PCIe-GEN2x1L, USB3/USB2, 2xCAN-FD, eMMC and SD, UFS, OSPI memory
controller, QSPI, I2C, eCAP/eQEP, ePWM, ADC, among other
peripherals.
* Centralized System Controller for Security, Power, and Resource
Management (DMSC).
See AM64X Technical Reference Manual (SPRUIM2, Nov 2020)
for further details: https://www.ti.com/lit/pdf/spruim2
Introduce basic support for the AM642 SoC to enable SD/MMC boot.
Introduce a limited set of MAIN domain peripherals under cbass_main and
a set of MCU domain peripherals under cbass_mcu.
Signed-off-by: Dave Gerlach <d-gerlach@ti.com>
2021-04-23 16:27:44 +00:00
|
|
|
};
|