1// SPDX-License-Identifier: GPL-2.0
2/*
3 * Keystone 2 Lamarr SoC specific device tree
4 *
5 * Copyright (C) 2014-2017 Texas Instruments Incorporated - https://www.ti.com/
6 */
7
8#include <dt-bindings/reset/ti-syscon.h>
9
10/ {
11	compatible = "ti,k2l", "ti,keystone";
12	model = "Texas Instruments Keystone 2 Lamarr SoC";
13
14	cpus {
15		#address-cells = <1>;
16		#size-cells = <0>;
17
18		interrupt-parent = <&gic>;
19
20		cpu@0 {
21			compatible = "arm,cortex-a15";
22			device_type = "cpu";
23			reg = <0>;
24		};
25
26		cpu@1 {
27			compatible = "arm,cortex-a15";
28			device_type = "cpu";
29			reg = <1>;
30		};
31	};
32
33	aliases {
34		rproc0 = &dsp0;
35		rproc1 = &dsp1;
36		rproc2 = &dsp2;
37		rproc3 = &dsp3;
38	};
39};
40
41&soc0 {
42		/include/ "keystone-k2l-clocks.dtsi"
43
44		uart2: serial@2348400 {
45			compatible = "ti,da830-uart", "ns16550a";
46			current-speed = <115200>;
47			reg-shift = <2>;
48			reg-io-width = <4>;
49			reg = <0x02348400 0x100>;
50			clocks = <&clkuart2>;
51			interrupts = <GIC_SPI 432 IRQ_TYPE_EDGE_RISING>;
52		};
53
54		uart3:	serial@2348800 {
55			compatible = "ti,da830-uart", "ns16550a";
56			current-speed = <115200>;
57			reg-shift = <2>;
58			reg-io-width = <4>;
59			reg = <0x02348800 0x100>;
60			clocks = <&clkuart3>;
61			interrupts = <GIC_SPI 435 IRQ_TYPE_EDGE_RISING>;
62		};
63
64		gpio1: gpio@2348000 {
65			compatible = "ti,keystone-gpio";
66			reg = <0x02348000 0x100>;
67			gpio-controller;
68			#gpio-cells = <2>;
69			/* HW Interrupts mapped to GPIO pins */
70			interrupts = <GIC_SPI 152 IRQ_TYPE_EDGE_RISING>,
71					<GIC_SPI 153 IRQ_TYPE_EDGE_RISING>,
72					<GIC_SPI 154 IRQ_TYPE_EDGE_RISING>,
73					<GIC_SPI 155 IRQ_TYPE_EDGE_RISING>,
74					<GIC_SPI 156 IRQ_TYPE_EDGE_RISING>,
75					<GIC_SPI 157 IRQ_TYPE_EDGE_RISING>,
76					<GIC_SPI 158 IRQ_TYPE_EDGE_RISING>,
77					<GIC_SPI 159 IRQ_TYPE_EDGE_RISING>,
78					<GIC_SPI 160 IRQ_TYPE_EDGE_RISING>,
79					<GIC_SPI 161 IRQ_TYPE_EDGE_RISING>,
80					<GIC_SPI 162 IRQ_TYPE_EDGE_RISING>,
81					<GIC_SPI 163 IRQ_TYPE_EDGE_RISING>,
82					<GIC_SPI 164 IRQ_TYPE_EDGE_RISING>,
83					<GIC_SPI 165 IRQ_TYPE_EDGE_RISING>,
84					<GIC_SPI 166 IRQ_TYPE_EDGE_RISING>,
85					<GIC_SPI 167 IRQ_TYPE_EDGE_RISING>,
86					<GIC_SPI 168 IRQ_TYPE_EDGE_RISING>,
87					<GIC_SPI 169 IRQ_TYPE_EDGE_RISING>,
88					<GIC_SPI 170 IRQ_TYPE_EDGE_RISING>,
89					<GIC_SPI 171 IRQ_TYPE_EDGE_RISING>,
90					<GIC_SPI 172 IRQ_TYPE_EDGE_RISING>,
91					<GIC_SPI 173 IRQ_TYPE_EDGE_RISING>,
92					<GIC_SPI 174 IRQ_TYPE_EDGE_RISING>,
93					<GIC_SPI 175 IRQ_TYPE_EDGE_RISING>,
94					<GIC_SPI 176 IRQ_TYPE_EDGE_RISING>,
95					<GIC_SPI 401 IRQ_TYPE_EDGE_RISING>,
96					<GIC_SPI 402 IRQ_TYPE_EDGE_RISING>,
97					<GIC_SPI 403 IRQ_TYPE_EDGE_RISING>,
98					<GIC_SPI 404 IRQ_TYPE_EDGE_RISING>,
99					<GIC_SPI 405 IRQ_TYPE_EDGE_RISING>,
100					<GIC_SPI 406 IRQ_TYPE_EDGE_RISING>,
101					<GIC_SPI 407 IRQ_TYPE_EDGE_RISING>;
102			clocks = <&clkgpio>;
103			clock-names = "gpio";
104			ti,ngpio = <32>;
105			ti,davinci-gpio-unbanked = <32>;
106		};
107
108		k2l_pmx: pinmux@2620690 {
109			compatible = "pinctrl-single";
110			reg = <0x02620690 0xc>;
111			#address-cells = <1>;
112			#size-cells = <0>;
113			#pinctrl-cells = <2>;
114			pinctrl-single,bit-per-mux;
115			pinctrl-single,register-width = <32>;
116			pinctrl-single,function-mask = <0x1>;
117			status = "disabled";
118
119			uart3_emifa_pins: uart3-emifa-pins {
120				pinctrl-single,bits = <
121					/* UART3_EMIFA_SEL */
122					0x0 0x0  0xc0
123				>;
124			};
125
126			uart2_emifa_pins: uart2-emifa-pins {
127			pinctrl-single,bits = <
128					/* UART2_EMIFA_SEL */
129					0x0 0x0  0x30
130				>;
131			};
132
133			uart01_spi2_pins: uart01-spi2-pins {
134				pinctrl-single,bits = <
135					/* UART01_SPI2_SEL */
136					0x0 0x0 0x4
137				>;
138			};
139
140			dfesync_rp1_pins: dfesync-rp1-pins {
141				pinctrl-single,bits = <
142					/* DFESYNC_RP1_SEL */
143					0x0 0x0 0x2
144				>;
145			};
146
147			avsif_pins: avsif-pins {
148				pinctrl-single,bits = <
149					/* AVSIF_SEL */
150					0x0 0x0 0x1
151				>;
152			};
153
154			gpio_emu_pins: gpio-emu-pins {
155				pinctrl-single,bits = <
156				/*
157				 * GPIO_EMU_SEL[31]: 0-GPIO31, 1-EMU33
158				 * GPIO_EMU_SEL[30]: 0-GPIO30, 1-EMU32
159				 * GPIO_EMU_SEL[29]: 0-GPIO29, 1-EMU31
160				 * GPIO_EMU_SEL[28]: 0-GPIO28, 1-EMU30
161				 * GPIO_EMU_SEL[27]: 0-GPIO27, 1-EMU29
162				 * GPIO_EMU_SEL[26]: 0-GPIO26, 1-EMU28
163				 * GPIO_EMU_SEL[25]: 0-GPIO25, 1-EMU27
164				 * GPIO_EMU_SEL[24]: 0-GPIO24, 1-EMU26
165				 * GPIO_EMU_SEL[23]: 0-GPIO23, 1-EMU25
166				 * GPIO_EMU_SEL[22]: 0-GPIO22, 1-EMU24
167				 * GPIO_EMU_SEL[21]: 0-GPIO21, 1-EMU23
168				 * GPIO_EMU_SEL[20]: 0-GPIO20, 1-EMU22
169				 * GPIO_EMU_SEL[19]: 0-GPIO19, 1-EMU21
170				 * GPIO_EMU_SEL[18]: 0-GPIO18, 1-EMU20
171				 * GPIO_EMU_SEL[17]: 0-GPIO17, 1-EMU19
172				 */
173					0x4 0x0000 0xfffe0000
174				>;
175			};
176
177			gpio_timio_pins: gpio-timio-pins {
178				pinctrl-single,bits = <
179				/*
180				 * GPIO_TIMIO_SEL[15]: 0-GPIO15, 1-TIMO7
181				 * GPIO_TIMIO_SEL[14]: 0-GPIO14, 1-TIMO6
182				 * GPIO_TIMIO_SEL[13]: 0-GPIO13, 1-TIMO5
183				 * GPIO_TIMIO_SEL[12]: 0-GPIO12, 1-TIMO4
184				 * GPIO_TIMIO_SEL[11]: 0-GPIO11, 1-TIMO3
185				 * GPIO_TIMIO_SEL[10]: 0-GPIO10, 1-TIMO2
186				 * GPIO_TIMIO_SEL[9]: 0-GPIO9, 1-TIMI7
187				 * GPIO_TIMIO_SEL[8]: 0-GPIO8, 1-TIMI6
188				 * GPIO_TIMIO_SEL[7]: 0-GPIO7, 1-TIMI5
189				 * GPIO_TIMIO_SEL[6]: 0-GPIO6, 1-TIMI4
190				 * GPIO_TIMIO_SEL[5]: 0-GPIO5, 1-TIMI3
191				 * GPIO_TIMIO_SEL[4]: 0-GPIO4, 1-TIMI2
192				 */
193					0x4 0x0 0xfff0
194				>;
195			};
196
197			gpio_spi2cs_pins: gpio-spi2cs-pins {
198				pinctrl-single,bits = <
199				/*
200				 * GPIO_SPI2CS_SEL[3]: 0-GPIO3, 1-SPI2CS4
201				 * GPIO_SPI2CS_SEL[2]: 0-GPIO2, 1-SPI2CS3
202				 * GPIO_SPI2CS_SEL[1]: 0-GPIO1, 1-SPI2CS2
203				 * GPIO_SPI2CS_SEL[0]: 0-GPIO0, 1-SPI2CS1
204				 */
205					0x4 0x0 0xf
206				>;
207			};
208
209			gpio_dfeio_pins: gpio-dfeio-pins {
210				pinctrl-single,bits = <
211				/*
212				 * GPIO_DFEIO_SEL[31]: 0-DFEIO17, 1-GPIO63
213				 * GPIO_DFEIO_SEL[30]: 0-DFEIO16, 1-GPIO62
214				 * GPIO_DFEIO_SEL[29]: 0-DFEIO15, 1-GPIO61
215				 * GPIO_DFEIO_SEL[28]: 0-DFEIO14, 1-GPIO60
216				 * GPIO_DFEIO_SEL[27]: 0-DFEIO13, 1-GPIO59
217				 * GPIO_DFEIO_SEL[26]: 0-DFEIO12, 1-GPIO58
218				 * GPIO_DFEIO_SEL[25]: 0-DFEIO11, 1-GPIO57
219				 * GPIO_DFEIO_SEL[24]: 0-DFEIO10, 1-GPIO56
220				 * GPIO_DFEIO_SEL[23]: 0-DFEIO9, 1-GPIO55
221				 * GPIO_DFEIO_SEL[22]: 0-DFEIO8, 1-GPIO54
222				 * GPIO_DFEIO_SEL[21]: 0-DFEIO7, 1-GPIO53
223				 * GPIO_DFEIO_SEL[20]: 0-DFEIO6, 1-GPIO52
224				 * GPIO_DFEIO_SEL[19]: 0-DFEIO5, 1-GPIO51
225				 * GPIO_DFEIO_SEL[18]: 0-DFEIO4, 1-GPIO50
226				 * GPIO_DFEIO_SEL[17]: 0-DFEIO3, 1-GPIO49
227				 * GPIO_DFEIO_SEL[16]: 0-DFEIO2, 1-GPIO48
228				 */
229					0x8 0x0 0xffff0000
230				>;
231			};
232
233			gpio_emifa_pins: gpio-emifa-pins {
234				pinctrl-single,bits = <
235				/*
236				 * GPIO_EMIFA_SEL[15]: 0-EMIFA17, 1-GPIO47
237				 * GPIO_EMIFA_SEL[14]: 0-EMIFA16, 1-GPIO46
238				 * GPIO_EMIFA_SEL[13]: 0-EMIFA15, 1-GPIO45
239				 * GPIO_EMIFA_SEL[12]: 0-EMIFA14, 1-GPIO44
240				 * GPIO_EMIFA_SEL[11]: 0-EMIFA13, 1-GPIO43
241				 * GPIO_EMIFA_SEL[10]: 0-EMIFA10, 1-GPIO42
242				 * GPIO_EMIFA_SEL[9]: 0-EMIFA9, 1-GPIO41
243				 * GPIO_EMIFA_SEL[8]: 0-EMIFA8, 1-GPIO40
244				 * GPIO_EMIFA_SEL[7]: 0-EMIFA7, 1-GPIO39
245				 * GPIO_EMIFA_SEL[6]: 0-EMIFA6, 1-GPIO38
246				 * GPIO_EMIFA_SEL[5]: 0-EMIFA5, 1-GPIO37
247				 * GPIO_EMIFA_SEL[4]: 0-EMIFA4, 1-GPIO36
248				 * GPIO_EMIFA_SEL[3]: 0-EMIFA3, 1-GPIO35
249				 * GPIO_EMIFA_SEL[2]: 0-EMIFA2, 1-GPIO34
250				 * GPIO_EMIFA_SEL[1]: 0-EMIFA1, 1-GPIO33
251				 * GPIO_EMIFA_SEL[0]: 0-EMIFA0, 1-GPIO32
252				 */
253					0x8 0x0 0xffff
254				>;
255			};
256		};
257
258		msm_ram: sram@c000000 {
259			compatible = "mmio-sram";
260			reg = <0x0c000000 0x200000>;
261			ranges = <0x0 0x0c000000 0x200000>;
262			#address-cells = <1>;
263			#size-cells = <1>;
264
265			bm-sram@1f8000 {
266				reg = <0x001f8000 0x8000>;
267			};
268		};
269
270		psc: power-sleep-controller@2350000 {
271			pscrst: reset-controller {
272				compatible = "ti,k2l-pscrst", "ti,syscon-reset";
273				#reset-cells = <1>;
274
275				ti,reset-bits = <
276					0xa3c 8 0xa3c 8 0x83c 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 0: dsp0 */
277					0xa40 8 0xa40 8 0x840 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 1: dsp1 */
278					0xa44 8 0xa44 8 0x844 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 2: dsp2 */
279					0xa48 8 0xa48 8 0x848 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 3: dsp3 */
280				>;
281			};
282		};
283
284		osr: sram@70000000 {
285			compatible = "mmio-sram";
286			reg = <0x70000000 0x10000>;
287			#address-cells = <1>;
288			#size-cells = <1>;
289			clocks = <&clkosr>;
290		};
291
292		devctrl: device-state-control@2620000 {
293			dspgpio0: keystone_dsp_gpio@240 {
294				compatible = "ti,keystone-dsp-gpio";
295				reg = <0x240 0x4>;
296				gpio-controller;
297				#gpio-cells = <2>;
298				gpio,syscon-dev = <&devctrl 0x240>;
299			};
300
301			dspgpio1: keystone_dsp_gpio@244 {
302				compatible = "ti,keystone-dsp-gpio";
303				reg = <0x244 0x4>;
304				gpio-controller;
305				#gpio-cells = <2>;
306				gpio,syscon-dev = <&devctrl 0x244>;
307			};
308
309			dspgpio2: keystone_dsp_gpio@248 {
310				compatible = "ti,keystone-dsp-gpio";
311				reg = <0x248 0x4>;
312				gpio-controller;
313				#gpio-cells = <2>;
314				gpio,syscon-dev = <&devctrl 0x248>;
315			};
316
317			dspgpio3: keystone_dsp_gpio@24c {
318				compatible = "ti,keystone-dsp-gpio";
319				reg = <0x24c 0x4>;
320				gpio-controller;
321				#gpio-cells = <2>;
322				gpio,syscon-dev = <&devctrl 0x24c>;
323			};
324		};
325
326		dsp0: dsp@10800000 {
327			compatible = "ti,k2l-dsp";
328			reg = <0x10800000 0x00100000>,
329			      <0x10e00000 0x00008000>,
330			      <0x10f00000 0x00008000>;
331			reg-names = "l2sram", "l1pram", "l1dram";
332			clocks = <&clkgem0>;
333			ti,syscon-dev = <&devctrl 0x844>;
334			resets = <&pscrst 0>;
335			interrupt-parent = <&kirq0>;
336			interrupts = <0 8>;
337			interrupt-names = "vring", "exception";
338			kick-gpios = <&dspgpio0 27 0>;
339			status = "disabled";
340		};
341
342		dsp1: dsp@11800000 {
343			compatible = "ti,k2l-dsp";
344			reg = <0x11800000 0x00100000>,
345			      <0x11e00000 0x00008000>,
346			      <0x11f00000 0x00008000>;
347			reg-names = "l2sram", "l1pram", "l1dram";
348			clocks = <&clkgem1>;
349			ti,syscon-dev = <&devctrl 0x848>;
350			resets = <&pscrst 1>;
351			interrupt-parent = <&kirq0>;
352			interrupts = <1 9>;
353			interrupt-names = "vring", "exception";
354			kick-gpios = <&dspgpio1 27 0>;
355			status = "disabled";
356		};
357
358		dsp2: dsp@12800000 {
359			compatible = "ti,k2l-dsp";
360			reg = <0x12800000 0x00100000>,
361			      <0x12e00000 0x00008000>,
362			      <0x12f00000 0x00008000>;
363			reg-names = "l2sram", "l1pram", "l1dram";
364			clocks = <&clkgem2>;
365			ti,syscon-dev = <&devctrl 0x84c>;
366			resets = <&pscrst 2>;
367			interrupt-parent = <&kirq0>;
368			interrupts = <2 10>;
369			interrupt-names = "vring", "exception";
370			kick-gpios = <&dspgpio2 27 0>;
371			status = "disabled";
372		};
373
374		dsp3: dsp@13800000 {
375			compatible = "ti,k2l-dsp";
376			reg = <0x13800000 0x00100000>,
377			      <0x13e00000 0x00008000>,
378			      <0x13f00000 0x00008000>;
379			reg-names = "l2sram", "l1pram", "l1dram";
380			clocks = <&clkgem3>;
381			ti,syscon-dev = <&devctrl 0x850>;
382			resets = <&pscrst 3>;
383			interrupt-parent = <&kirq0>;
384			interrupts = <3 11>;
385			interrupt-names = "vring", "exception";
386			kick-gpios = <&dspgpio3 27 0>;
387			status = "disabled";
388		};
389
390		mdio: mdio@26200f00 {
391			compatible = "ti,keystone_mdio", "ti,davinci_mdio";
392			#address-cells = <1>;
393			#size-cells = <0>;
394			reg = <0x26200f00 0x100>;
395			status = "disabled";
396			clocks = <&clkcpgmac>;
397			clock-names = "fck";
398			bus_freq = <2500000>;
399		};
400		/include/ "keystone-k2l-netcp.dtsi"
401};
402
403&spi0 {
404       ti,davinci-spi-num-cs = <5>;
405};
406
407&spi1 {
408       ti,davinci-spi-num-cs = <3>;
409};
410
411&spi2 {
412       ti,davinci-spi-num-cs = <5>;
413       /* Pin muxed. Enabled and configured by Bootloader */
414       status = "disabled";
415};
416