xref: /linux/scripts/dtc/include-prefixes/arm/ti/omap/am3517.dtsi (revision 724ba6751532055db75992fc6ae21c3e322e94a7)
1*724ba675SRob Herring// SPDX-License-Identifier: GPL-2.0-only
2*724ba675SRob Herring/*
3*724ba675SRob Herring * Device Tree Source for am3517 SoC
4*724ba675SRob Herring *
5*724ba675SRob Herring * Copyright (C) 2013 Texas Instruments Incorporated - https://www.ti.com/
6*724ba675SRob Herring */
7*724ba675SRob Herring
8*724ba675SRob Herring#include "omap3.dtsi"
9*724ba675SRob Herring
10*724ba675SRob Herring/* AM3517 doesn't appear to have the crypto engines defined in omap3.dtsi */
11*724ba675SRob Herring/delete-node/ &aes1_target;
12*724ba675SRob Herring/delete-node/ &aes2_target;
13*724ba675SRob Herring
14*724ba675SRob Herring/ {
15*724ba675SRob Herring	aliases {
16*724ba675SRob Herring		serial3 = &uart4;
17*724ba675SRob Herring		can = &hecc;
18*724ba675SRob Herring	};
19*724ba675SRob Herring
20*724ba675SRob Herring	cpus {
21*724ba675SRob Herring		cpu: cpu@0 {
22*724ba675SRob Herring			/* Based on OMAP3630 variants OPP50 and OPP100 */
23*724ba675SRob Herring			operating-points-v2 = <&cpu0_opp_table>;
24*724ba675SRob Herring
25*724ba675SRob Herring			clock-latency = <300000>; /* From legacy driver */
26*724ba675SRob Herring		};
27*724ba675SRob Herring	};
28*724ba675SRob Herring
29*724ba675SRob Herring	cpu0_opp_table: opp-table {
30*724ba675SRob Herring		compatible = "operating-points-v2-ti-cpu";
31*724ba675SRob Herring		syscon = <&scm_conf>;
32*724ba675SRob Herring		/*
33*724ba675SRob Herring		 * AM3517 TRM only lists 600MHz @ 1.2V, but omap36xx
34*724ba675SRob Herring		 * appear to operate at 300MHz as well. Since AM3517 only
35*724ba675SRob Herring		 * lists one operating voltage, it will remain fixed at 1.2V
36*724ba675SRob Herring		 */
37*724ba675SRob Herring		opp50-300000000 {
38*724ba675SRob Herring			opp-hz = /bits/ 64 <300000000>;
39*724ba675SRob Herring			opp-microvolt = <1200000>;
40*724ba675SRob Herring			opp-supported-hw = <0xffffffff 0xffffffff>;
41*724ba675SRob Herring			opp-suspend;
42*724ba675SRob Herring		};
43*724ba675SRob Herring
44*724ba675SRob Herring		opp100-600000000 {
45*724ba675SRob Herring			opp-hz = /bits/ 64 <600000000>;
46*724ba675SRob Herring			opp-microvolt = <1200000>;
47*724ba675SRob Herring			opp-supported-hw = <0xffffffff 0xffffffff>;
48*724ba675SRob Herring		};
49*724ba675SRob Herring	};
50*724ba675SRob Herring
51*724ba675SRob Herring	ocp@68000000 {
52*724ba675SRob Herring		target-module@5c040000 {
53*724ba675SRob Herring			compatible = "ti,sysc-omap2", "ti,sysc";
54*724ba675SRob Herring			reg = <0x5c040400 0x4>,
55*724ba675SRob Herring			      <0x5c040404 0x4>,
56*724ba675SRob Herring			      <0x5c040408 0x4>;
57*724ba675SRob Herring			reg-names = "rev", "sysc", "syss";
58*724ba675SRob Herring			ti,sysc-mask = <(SYSC_OMAP2_ENAWAKEUP |
59*724ba675SRob Herring					 SYSC_OMAP2_SOFTRESET |
60*724ba675SRob Herring					 SYSC_OMAP2_AUTOIDLE)>;
61*724ba675SRob Herring			ti,sysc-midle = <SYSC_IDLE_FORCE>,
62*724ba675SRob Herring					<SYSC_IDLE_NO>,
63*724ba675SRob Herring					<SYSC_IDLE_SMART>;
64*724ba675SRob Herring			ti,sysc-sidle = <SYSC_IDLE_FORCE>,
65*724ba675SRob Herring					<SYSC_IDLE_NO>,
66*724ba675SRob Herring					<SYSC_IDLE_SMART>;
67*724ba675SRob Herring			ti,syss-mask = <1>;
68*724ba675SRob Herring			clocks = <&hsotgusb_ick_am35xx>;
69*724ba675SRob Herring			clock-names = "fck";
70*724ba675SRob Herring			#address-cells = <1>;
71*724ba675SRob Herring			#size-cells = <1>;
72*724ba675SRob Herring			ranges = <0x0 0x5c040000 0x1000>;
73*724ba675SRob Herring
74*724ba675SRob Herring			am35x_otg_hs: am35x_otg_hs@0 {
75*724ba675SRob Herring				compatible = "ti,omap3-musb";
76*724ba675SRob Herring				status = "disabled";
77*724ba675SRob Herring				reg = <0 0x1000>;
78*724ba675SRob Herring				interrupts = <71>;
79*724ba675SRob Herring				interrupt-names = "mc";
80*724ba675SRob Herring			};
81*724ba675SRob Herring		};
82*724ba675SRob Herring
83*724ba675SRob Herring		davinci_emac: ethernet@5c000000 {
84*724ba675SRob Herring			compatible = "ti,am3517-emac";
85*724ba675SRob Herring			ti,hwmods = "davinci_emac";
86*724ba675SRob Herring			status = "disabled";
87*724ba675SRob Herring			reg = <0x5c000000 0x30000>;
88*724ba675SRob Herring			interrupts = <67 68 69 70>;
89*724ba675SRob Herring			syscon = <&scm_conf>;
90*724ba675SRob Herring			ti,davinci-ctrl-reg-offset = <0x10000>;
91*724ba675SRob Herring			ti,davinci-ctrl-mod-reg-offset = <0>;
92*724ba675SRob Herring			ti,davinci-ctrl-ram-offset = <0x20000>;
93*724ba675SRob Herring			ti,davinci-ctrl-ram-size = <0x2000>;
94*724ba675SRob Herring			ti,davinci-rmii-en = /bits/ 8 <1>;
95*724ba675SRob Herring			local-mac-address = [ 00 00 00 00 00 00 ];
96*724ba675SRob Herring			clocks = <&emac_ick>;
97*724ba675SRob Herring			clock-names = "ick";
98*724ba675SRob Herring		};
99*724ba675SRob Herring
100*724ba675SRob Herring		davinci_mdio: mdio@5c030000 {
101*724ba675SRob Herring			compatible = "ti,davinci_mdio";
102*724ba675SRob Herring			ti,hwmods = "davinci_mdio";
103*724ba675SRob Herring			status = "disabled";
104*724ba675SRob Herring			reg = <0x5c030000 0x1000>;
105*724ba675SRob Herring			bus_freq = <1000000>;
106*724ba675SRob Herring			#address-cells = <1>;
107*724ba675SRob Herring			#size-cells = <0>;
108*724ba675SRob Herring			clocks = <&emac_fck>;
109*724ba675SRob Herring			clock-names = "fck";
110*724ba675SRob Herring		};
111*724ba675SRob Herring
112*724ba675SRob Herring		uart4: serial@4809e000 {
113*724ba675SRob Herring			compatible = "ti,omap3-uart";
114*724ba675SRob Herring			ti,hwmods = "uart4";
115*724ba675SRob Herring			status = "disabled";
116*724ba675SRob Herring			reg = <0x4809e000 0x400>;
117*724ba675SRob Herring			interrupts = <84>;
118*724ba675SRob Herring			dmas = <&sdma 55 &sdma 54>;
119*724ba675SRob Herring			dma-names = "tx", "rx";
120*724ba675SRob Herring			clock-frequency = <48000000>;
121*724ba675SRob Herring		};
122*724ba675SRob Herring
123*724ba675SRob Herring		omap3_pmx_core2: pinmux@480025d8 {
124*724ba675SRob Herring			compatible = "ti,omap3-padconf", "pinctrl-single";
125*724ba675SRob Herring			reg = <0x480025d8 0x24>;
126*724ba675SRob Herring			#address-cells = <1>;
127*724ba675SRob Herring			#size-cells = <0>;
128*724ba675SRob Herring			#pinctrl-cells = <1>;
129*724ba675SRob Herring			#interrupt-cells = <1>;
130*724ba675SRob Herring			interrupt-controller;
131*724ba675SRob Herring			pinctrl-single,register-width = <16>;
132*724ba675SRob Herring			pinctrl-single,function-mask = <0xff1f>;
133*724ba675SRob Herring		};
134*724ba675SRob Herring
135*724ba675SRob Herring		hecc: can@5c050000 {
136*724ba675SRob Herring			compatible = "ti,am3517-hecc";
137*724ba675SRob Herring			status = "disabled";
138*724ba675SRob Herring			reg = <0x5c050000 0x80>,
139*724ba675SRob Herring			      <0x5c053000 0x180>,
140*724ba675SRob Herring			      <0x5c052000 0x200>;
141*724ba675SRob Herring			reg-names = "hecc", "hecc-ram", "mbx";
142*724ba675SRob Herring			interrupts = <24>;
143*724ba675SRob Herring			clocks = <&hecc_ck>;
144*724ba675SRob Herring		};
145*724ba675SRob Herring
146*724ba675SRob Herring		/*
147*724ba675SRob Herring		 * On am3517 the OCP registers do not seem to be accessible
148*724ba675SRob Herring		 * similar to the omap34xx. Maybe SGX is permanently set to
149*724ba675SRob Herring		 * "OCP bypass mode", or maybe there is OCP_SYSCONFIG that is
150*724ba675SRob Herring		 * write-only at 0x50000e10. We detect SGX based on the SGX
151*724ba675SRob Herring		 * revision register instead of the unreadable OCP revision
152*724ba675SRob Herring		 * register.
153*724ba675SRob Herring		 */
154*724ba675SRob Herring		sgx_module: target-module@50000000 {
155*724ba675SRob Herring			compatible = "ti,sysc-omap2", "ti,sysc";
156*724ba675SRob Herring			reg = <0x50000014 0x4>;
157*724ba675SRob Herring			reg-names = "rev";
158*724ba675SRob Herring			clocks = <&sgx_fck>, <&sgx_ick>;
159*724ba675SRob Herring			clock-names = "fck", "ick";
160*724ba675SRob Herring			#address-cells = <1>;
161*724ba675SRob Herring			#size-cells = <1>;
162*724ba675SRob Herring			ranges = <0 0x50000000 0x4000>;
163*724ba675SRob Herring
164*724ba675SRob Herring			/*
165*724ba675SRob Herring			 * Closed source PowerVR driver, no child device
166*724ba675SRob Herring			 * binding or driver in mainline
167*724ba675SRob Herring			 */
168*724ba675SRob Herring		};
169*724ba675SRob Herring	};
170*724ba675SRob Herring};
171*724ba675SRob Herring
172*724ba675SRob Herring/* Not currently working, probably needs at least different clocks */
173*724ba675SRob Herring&rng_target {
174*724ba675SRob Herring	status = "disabled";
175*724ba675SRob Herring	/delete-property/ clocks;
176*724ba675SRob Herring};
177*724ba675SRob Herring
178*724ba675SRob Herring/* Table Table 5-79 of the TRM shows 480ab000 is reserved */
179*724ba675SRob Herring&usb_otg_target {
180*724ba675SRob Herring	status = "disabled";
181*724ba675SRob Herring};
182*724ba675SRob Herring
183*724ba675SRob Herring&iva {
184*724ba675SRob Herring	status = "disabled";
185*724ba675SRob Herring};
186*724ba675SRob Herring
187*724ba675SRob Herring&mailbox {
188*724ba675SRob Herring	status = "disabled";
189*724ba675SRob Herring};
190*724ba675SRob Herring
191*724ba675SRob Herring&mmu_isp {
192*724ba675SRob Herring	status = "disabled";
193*724ba675SRob Herring};
194*724ba675SRob Herring
195*724ba675SRob Herring#include "am35xx-clocks.dtsi"
196*724ba675SRob Herring#include "omap36xx-am35xx-omap3430es2plus-clocks.dtsi"
197*724ba675SRob Herring
198*724ba675SRob Herring/* Preferred always-on timer for clocksource */
199*724ba675SRob Herring&timer1_target {
200*724ba675SRob Herring	ti,no-reset-on-init;
201*724ba675SRob Herring	ti,no-idle;
202*724ba675SRob Herring	timer@0 {
203*724ba675SRob Herring		assigned-clocks = <&gpt1_fck>;
204*724ba675SRob Herring		assigned-clock-parents = <&sys_ck>;
205*724ba675SRob Herring	};
206*724ba675SRob Herring};
207*724ba675SRob Herring
208*724ba675SRob Herring/* Preferred timer for clockevent */
209*724ba675SRob Herring&timer2_target {
210*724ba675SRob Herring	ti,no-reset-on-init;
211*724ba675SRob Herring	ti,no-idle;
212*724ba675SRob Herring	timer@0 {
213*724ba675SRob Herring		assigned-clocks = <&gpt2_fck>;
214*724ba675SRob Herring		assigned-clock-parents = <&sys_ck>;
215*724ba675SRob Herring	};
216*724ba675SRob Herring};
217