xref: /linux/scripts/dtc/include-prefixes/arm/ti/omap/am3517.dtsi (revision 79790b6818e96c58fe2bffee1b418c16e64e7b80)
1724ba675SRob Herring// SPDX-License-Identifier: GPL-2.0-only
2724ba675SRob Herring/*
3724ba675SRob Herring * Device Tree Source for am3517 SoC
4724ba675SRob Herring *
5724ba675SRob Herring * Copyright (C) 2013 Texas Instruments Incorporated - https://www.ti.com/
6724ba675SRob Herring */
7724ba675SRob Herring
8724ba675SRob Herring#include "omap3.dtsi"
9724ba675SRob Herring
10724ba675SRob Herring/* AM3517 doesn't appear to have the crypto engines defined in omap3.dtsi */
11724ba675SRob Herring/delete-node/ &aes1_target;
12724ba675SRob Herring/delete-node/ &aes2_target;
13724ba675SRob Herring
14724ba675SRob Herring/ {
15724ba675SRob Herring	aliases {
16724ba675SRob Herring		serial3 = &uart4;
17724ba675SRob Herring		can = &hecc;
18ba05a788SAdam Ford		ethernet = &davinci_emac;
19724ba675SRob Herring	};
20724ba675SRob Herring
21724ba675SRob Herring	cpus {
22724ba675SRob Herring		cpu: cpu@0 {
23724ba675SRob Herring			/* Based on OMAP3630 variants OPP50 and OPP100 */
24724ba675SRob Herring			operating-points-v2 = <&cpu0_opp_table>;
25724ba675SRob Herring
26724ba675SRob Herring			clock-latency = <300000>; /* From legacy driver */
27724ba675SRob Herring		};
28724ba675SRob Herring	};
29724ba675SRob Herring
30724ba675SRob Herring	cpu0_opp_table: opp-table {
31724ba675SRob Herring		compatible = "operating-points-v2-ti-cpu";
32724ba675SRob Herring		syscon = <&scm_conf>;
33724ba675SRob Herring		/*
34724ba675SRob Herring		 * AM3517 TRM only lists 600MHz @ 1.2V, but omap36xx
35724ba675SRob Herring		 * appear to operate at 300MHz as well. Since AM3517 only
36724ba675SRob Herring		 * lists one operating voltage, it will remain fixed at 1.2V
37724ba675SRob Herring		 */
385821d766SNishanth Menon		opp-50-300000000 {
395821d766SNishanth Menon			/* OPP50 */
40724ba675SRob Herring			opp-hz = /bits/ 64 <300000000>;
41724ba675SRob Herring			opp-microvolt = <1200000>;
42724ba675SRob Herring			opp-supported-hw = <0xffffffff 0xffffffff>;
43724ba675SRob Herring			opp-suspend;
44724ba675SRob Herring		};
45724ba675SRob Herring
465821d766SNishanth Menon		opp-100-600000000 {
475821d766SNishanth Menon			/* OPP100 */
48724ba675SRob Herring			opp-hz = /bits/ 64 <600000000>;
49724ba675SRob Herring			opp-microvolt = <1200000>;
50724ba675SRob Herring			opp-supported-hw = <0xffffffff 0xffffffff>;
51724ba675SRob Herring		};
52724ba675SRob Herring	};
53724ba675SRob Herring
54724ba675SRob Herring	ocp@68000000 {
55724ba675SRob Herring		target-module@5c040000 {
56724ba675SRob Herring			compatible = "ti,sysc-omap2", "ti,sysc";
57724ba675SRob Herring			reg = <0x5c040400 0x4>,
58724ba675SRob Herring			      <0x5c040404 0x4>,
59724ba675SRob Herring			      <0x5c040408 0x4>;
60724ba675SRob Herring			reg-names = "rev", "sysc", "syss";
61724ba675SRob Herring			ti,sysc-mask = <(SYSC_OMAP2_ENAWAKEUP |
62724ba675SRob Herring					 SYSC_OMAP2_SOFTRESET |
63724ba675SRob Herring					 SYSC_OMAP2_AUTOIDLE)>;
64724ba675SRob Herring			ti,sysc-midle = <SYSC_IDLE_FORCE>,
65724ba675SRob Herring					<SYSC_IDLE_NO>,
66724ba675SRob Herring					<SYSC_IDLE_SMART>;
67724ba675SRob Herring			ti,sysc-sidle = <SYSC_IDLE_FORCE>,
68724ba675SRob Herring					<SYSC_IDLE_NO>,
69724ba675SRob Herring					<SYSC_IDLE_SMART>;
70724ba675SRob Herring			ti,syss-mask = <1>;
71724ba675SRob Herring			clocks = <&hsotgusb_ick_am35xx>;
72724ba675SRob Herring			clock-names = "fck";
73724ba675SRob Herring			#address-cells = <1>;
74724ba675SRob Herring			#size-cells = <1>;
75724ba675SRob Herring			ranges = <0x0 0x5c040000 0x1000>;
76724ba675SRob Herring
77724ba675SRob Herring			am35x_otg_hs: am35x_otg_hs@0 {
78724ba675SRob Herring				compatible = "ti,omap3-musb";
79724ba675SRob Herring				status = "disabled";
80724ba675SRob Herring				reg = <0 0x1000>;
81724ba675SRob Herring				interrupts = <71>;
82724ba675SRob Herring				interrupt-names = "mc";
83724ba675SRob Herring			};
84724ba675SRob Herring		};
85724ba675SRob Herring
86724ba675SRob Herring		davinci_emac: ethernet@5c000000 {
87724ba675SRob Herring			compatible = "ti,am3517-emac";
88724ba675SRob Herring			ti,hwmods = "davinci_emac";
89724ba675SRob Herring			status = "disabled";
90724ba675SRob Herring			reg = <0x5c000000 0x30000>;
91724ba675SRob Herring			interrupts = <67 68 69 70>;
92724ba675SRob Herring			syscon = <&scm_conf>;
93724ba675SRob Herring			ti,davinci-ctrl-reg-offset = <0x10000>;
94724ba675SRob Herring			ti,davinci-ctrl-mod-reg-offset = <0>;
95724ba675SRob Herring			ti,davinci-ctrl-ram-offset = <0x20000>;
96724ba675SRob Herring			ti,davinci-ctrl-ram-size = <0x2000>;
97724ba675SRob Herring			ti,davinci-rmii-en = /bits/ 8 <1>;
98724ba675SRob Herring			local-mac-address = [ 00 00 00 00 00 00 ];
99724ba675SRob Herring			clocks = <&emac_ick>;
100724ba675SRob Herring			clock-names = "ick";
101724ba675SRob Herring		};
102724ba675SRob Herring
103724ba675SRob Herring		davinci_mdio: mdio@5c030000 {
104724ba675SRob Herring			compatible = "ti,davinci_mdio";
105724ba675SRob Herring			ti,hwmods = "davinci_mdio";
106724ba675SRob Herring			status = "disabled";
107724ba675SRob Herring			reg = <0x5c030000 0x1000>;
108724ba675SRob Herring			bus_freq = <1000000>;
109724ba675SRob Herring			#address-cells = <1>;
110724ba675SRob Herring			#size-cells = <0>;
111724ba675SRob Herring			clocks = <&emac_fck>;
112724ba675SRob Herring			clock-names = "fck";
113724ba675SRob Herring		};
114724ba675SRob Herring
115724ba675SRob Herring		uart4: serial@4809e000 {
116724ba675SRob Herring			compatible = "ti,omap3-uart";
117724ba675SRob Herring			ti,hwmods = "uart4";
118724ba675SRob Herring			status = "disabled";
119724ba675SRob Herring			reg = <0x4809e000 0x400>;
120724ba675SRob Herring			interrupts = <84>;
121724ba675SRob Herring			dmas = <&sdma 55 &sdma 54>;
122724ba675SRob Herring			dma-names = "tx", "rx";
123724ba675SRob Herring			clock-frequency = <48000000>;
124724ba675SRob Herring		};
125724ba675SRob Herring
126724ba675SRob Herring		omap3_pmx_core2: pinmux@480025d8 {
127724ba675SRob Herring			compatible = "ti,omap3-padconf", "pinctrl-single";
128724ba675SRob Herring			reg = <0x480025d8 0x24>;
129724ba675SRob Herring			#address-cells = <1>;
130724ba675SRob Herring			#size-cells = <0>;
131724ba675SRob Herring			#pinctrl-cells = <1>;
132724ba675SRob Herring			#interrupt-cells = <1>;
133724ba675SRob Herring			interrupt-controller;
134724ba675SRob Herring			pinctrl-single,register-width = <16>;
135724ba675SRob Herring			pinctrl-single,function-mask = <0xff1f>;
136724ba675SRob Herring		};
137724ba675SRob Herring
138724ba675SRob Herring		hecc: can@5c050000 {
139724ba675SRob Herring			compatible = "ti,am3517-hecc";
140724ba675SRob Herring			status = "disabled";
141724ba675SRob Herring			reg = <0x5c050000 0x80>,
142724ba675SRob Herring			      <0x5c053000 0x180>,
143724ba675SRob Herring			      <0x5c052000 0x200>;
144724ba675SRob Herring			reg-names = "hecc", "hecc-ram", "mbx";
145724ba675SRob Herring			interrupts = <24>;
146724ba675SRob Herring			clocks = <&hecc_ck>;
147724ba675SRob Herring		};
148724ba675SRob Herring
149724ba675SRob Herring		/*
150724ba675SRob Herring		 * On am3517 the OCP registers do not seem to be accessible
151724ba675SRob Herring		 * similar to the omap34xx. Maybe SGX is permanently set to
152724ba675SRob Herring		 * "OCP bypass mode", or maybe there is OCP_SYSCONFIG that is
153724ba675SRob Herring		 * write-only at 0x50000e10. We detect SGX based on the SGX
154724ba675SRob Herring		 * revision register instead of the unreadable OCP revision
155724ba675SRob Herring		 * register.
156724ba675SRob Herring		 */
157724ba675SRob Herring		sgx_module: target-module@50000000 {
158724ba675SRob Herring			compatible = "ti,sysc-omap2", "ti,sysc";
159724ba675SRob Herring			reg = <0x50000014 0x4>;
160724ba675SRob Herring			reg-names = "rev";
161724ba675SRob Herring			clocks = <&sgx_fck>, <&sgx_ick>;
162724ba675SRob Herring			clock-names = "fck", "ick";
163724ba675SRob Herring			#address-cells = <1>;
164724ba675SRob Herring			#size-cells = <1>;
165*70f028ffSAndrew Davis			ranges = <0 0x50000000 0x10000>;
166724ba675SRob Herring
167*70f028ffSAndrew Davis			gpu@0 {
168*70f028ffSAndrew Davis				compatible = "ti,omap3430-gpu", "img,powervr-sgx530";
169*70f028ffSAndrew Davis				reg = <0x0 0x10000>; /* 64kB */
170*70f028ffSAndrew Davis				interrupts = <21>;
171*70f028ffSAndrew Davis			};
172724ba675SRob Herring		};
173724ba675SRob Herring	};
174724ba675SRob Herring};
175724ba675SRob Herring
176724ba675SRob Herring/* Not currently working, probably needs at least different clocks */
177724ba675SRob Herring&rng_target {
178724ba675SRob Herring	status = "disabled";
179724ba675SRob Herring	/delete-property/ clocks;
180724ba675SRob Herring};
181724ba675SRob Herring
182724ba675SRob Herring/* Table Table 5-79 of the TRM shows 480ab000 is reserved */
183724ba675SRob Herring&usb_otg_target {
184724ba675SRob Herring	status = "disabled";
185724ba675SRob Herring};
186724ba675SRob Herring
187724ba675SRob Herring&iva {
188724ba675SRob Herring	status = "disabled";
189724ba675SRob Herring};
190724ba675SRob Herring
191724ba675SRob Herring&mailbox {
192724ba675SRob Herring	status = "disabled";
193724ba675SRob Herring};
194724ba675SRob Herring
195724ba675SRob Herring&mmu_isp {
196724ba675SRob Herring	status = "disabled";
197724ba675SRob Herring};
198724ba675SRob Herring
199724ba675SRob Herring#include "am35xx-clocks.dtsi"
200724ba675SRob Herring#include "omap36xx-am35xx-omap3430es2plus-clocks.dtsi"
201724ba675SRob Herring
202724ba675SRob Herring/* Preferred always-on timer for clocksource */
203724ba675SRob Herring&timer1_target {
204724ba675SRob Herring	ti,no-reset-on-init;
205724ba675SRob Herring	ti,no-idle;
206724ba675SRob Herring	timer@0 {
207724ba675SRob Herring		assigned-clocks = <&gpt1_fck>;
208724ba675SRob Herring		assigned-clock-parents = <&sys_ck>;
209724ba675SRob Herring	};
210724ba675SRob Herring};
211724ba675SRob Herring
212724ba675SRob Herring/* Preferred timer for clockevent */
213724ba675SRob Herring&timer2_target {
214724ba675SRob Herring	ti,no-reset-on-init;
215724ba675SRob Herring	ti,no-idle;
216724ba675SRob Herring	timer@0 {
217724ba675SRob Herring		assigned-clocks = <&gpt2_fck>;
218724ba675SRob Herring		assigned-clock-parents = <&sys_ck>;
219724ba675SRob Herring	};
220724ba675SRob Herring};
221