Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
| 2 | /* |
Roger Quadros | 01f573e | 2023-08-05 11:14:40 +0300 | [diff] [blame] | 3 | * Copyright (C) 2020-2023 Texas Instruments Incorporated - https://www.ti.com/ |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 4 | */ |
| 5 | |
Roger Quadros | 01f573e | 2023-08-05 11:14:40 +0300 | [diff] [blame] | 6 | #include "k3-am642-evm.dts" |
Dave Gerlach | fe0f3e3 | 2021-05-04 18:00:52 -0500 | [diff] [blame] | 7 | #include "k3-am64-evm-ddr4-1600MTs.dtsi" |
| 8 | #include "k3-am64-ddr.dtsi" |
Roger Quadros | 01f573e | 2023-08-05 11:14:40 +0300 | [diff] [blame] | 9 | |
| 10 | #include "k3-am642-evm-u-boot.dtsi" |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 11 | |
| 12 | / { |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 13 | aliases { |
| 14 | remoteproc0 = &sysctrler; |
| 15 | remoteproc1 = &a53_0; |
| 16 | }; |
| 17 | |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 18 | a53_0: a53@0 { |
| 19 | compatible = "ti,am654-rproc"; |
| 20 | reg = <0x00 0x00a90000 0x00 0x10>; |
| 21 | power-domains = <&k3_pds 61 TI_SCI_PD_EXCLUSIVE>, |
Manorit Chawdhry | 3922cf6 | 2023-04-14 09:47:57 +0530 | [diff] [blame] | 22 | <&k3_pds 135 TI_SCI_PD_EXCLUSIVE>, |
| 23 | <&k3_pds 137 TI_SCI_PD_EXCLUSIVE>; |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 24 | resets = <&k3_reset 135 0>; |
| 25 | clocks = <&k3_clks 61 0>; |
| 26 | assigned-clocks = <&k3_clks 61 0>, <&k3_clks 135 0>; |
| 27 | assigned-clock-parents = <&k3_clks 61 2>; |
| 28 | assigned-clock-rates = <200000000>, <1000000000>; |
| 29 | ti,sci = <&dmsc>; |
| 30 | ti,sci-proc-id = <32>; |
| 31 | ti,sci-host-id = <10>; |
Simon Glass | 8c103c3 | 2023-02-13 08:56:33 -0700 | [diff] [blame] | 32 | bootph-pre-ram; |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 33 | }; |
| 34 | |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 35 | clk_200mhz: dummy-clock-200mhz { |
| 36 | compatible = "fixed-clock"; |
| 37 | #clock-cells = <0>; |
| 38 | clock-frequency = <200000000>; |
Simon Glass | 8c103c3 | 2023-02-13 08:56:33 -0700 | [diff] [blame] | 39 | bootph-pre-ram; |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 40 | }; |
| 41 | }; |
| 42 | |
| 43 | &cbass_main { |
| 44 | sysctrler: sysctrler { |
| 45 | compatible = "ti,am654-system-controller"; |
| 46 | mboxes= <&secure_proxy_main 1>, <&secure_proxy_main 0>; |
| 47 | mbox-names = "tx", "rx"; |
Simon Glass | 8c103c3 | 2023-02-13 08:56:33 -0700 | [diff] [blame] | 48 | bootph-pre-ram; |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 49 | }; |
| 50 | }; |
| 51 | |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 52 | &dmsc { |
| 53 | mboxes= <&secure_proxy_main 0>, |
| 54 | <&secure_proxy_main 1>, |
| 55 | <&secure_proxy_main 0>; |
| 56 | mbox-names = "rx", "tx", "notify"; |
| 57 | ti,host-id = <35>; |
| 58 | ti,secure-host; |
| 59 | }; |
| 60 | |
Roger Quadros | 398bd29 | 2023-09-29 16:46:42 +0300 | [diff] [blame] | 61 | &memorycontroller { |
| 62 | vtt-supply = <&vtt_supply>; |
| 63 | }; |
| 64 | |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 65 | &sdhci0 { |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 66 | clocks = <&clk_200mhz>; |
| 67 | clock-names = "clk_xin"; |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 68 | }; |
| 69 | |
| 70 | &sdhci1 { |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 71 | clocks = <&clk_200mhz>; |
| 72 | clock-names = "clk_xin"; |
Dave Gerlach | b6059dd | 2021-04-23 11:27:46 -0500 | [diff] [blame] | 73 | }; |
| 74 | |
Roger Quadros | 01f573e | 2023-08-05 11:14:40 +0300 | [diff] [blame] | 75 | /* UART is initialized before SYSFW is started |
| 76 | * so we can't do any power-domain/clock operations. |
| 77 | * Delete clock/power-domain properties to avoid |
| 78 | * UART init failure |
| 79 | */ |
| 80 | &main_uart0 { |
| 81 | /delete-property/ power-domains; |
| 82 | /delete-property/ clocks; |
| 83 | /delete-property/ clock-names; |
| 84 | }; |
| 85 | |
| 86 | /* timer init is called as part of rproc_start() while |
| 87 | * starting System Firmware, so any clock/power-domain |
| 88 | * operations will fail as SYSFW is not yet up and running. |
| 89 | * Delete all clock/power-domain properties to avoid |
| 90 | * timer init failure. |
| 91 | * This is an always on timer at 20MHz. |
| 92 | */ |
| 93 | &main_timer0 { |
| 94 | /delete-property/ clocks; |
| 95 | /delete-property/ assigned-clocks; |
| 96 | /delete-property/ assigned-clock-parents; |
Nishanth Menon | ab4c072 | 2021-05-04 18:00:55 -0500 | [diff] [blame] | 97 | /delete-property/ power-domains; |
| 98 | }; |
Jonathan Humphreys | b9091c1 | 2024-02-23 18:17:02 -0600 | [diff] [blame] | 99 | |
| 100 | &ospi0 { |
| 101 | reg = <0x00 0x0fc40000 0x00 0x100>, |
| 102 | <0x00 0x60000000 0x00 0x8000000>; |
| 103 | }; |