blob: 065ed10a79fa7ec3e9bb76bcc6733799a38823e7 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Linus Walleij9be0d7f2017-01-21 13:00:15 +01002/*
3 * Device Tree file for Cortina systems Gemini SoC
4 */
5
Linus Walleij9be0d7f2017-01-21 13:00:15 +01006#include <dt-bindings/interrupt-controller/irq.h>
Linus Walleij5896a4d2017-05-24 10:43:21 +02007#include <dt-bindings/clock/cortina,gemini-clock.h>
8#include <dt-bindings/reset/cortina,gemini-reset.h>
Linus Walleij9be0d7f2017-01-21 13:00:15 +01009#include <dt-bindings/gpio/gpio.h>
10
11/ {
12 soc {
13 #address-cells = <1>;
14 #size-cells = <1>;
15 ranges;
16 compatible = "simple-bus";
17 interrupt-parent = <&intcon>;
18
19 flash@30000000 {
20 compatible = "cortina,gemini-flash", "cfi-flash";
21 syscon = <&syscon>;
Linus Walleijf328c2e2017-07-05 16:59:33 +020022 pinctrl-names = "default";
23 pinctrl-0 = <&pflash_default_pins>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +010024 bank-width = <2>;
25 #address-cells = <1>;
26 #size-cells = <1>;
27 status = "disabled";
28 };
29
30 syscon: syscon@40000000 {
Linus Walleij3863c522017-04-13 16:09:53 +020031 compatible = "cortina,gemini-syscon",
32 "syscon", "simple-mfd";
Linus Walleij9be0d7f2017-01-21 13:00:15 +010033 reg = <0x40000000 0x1000>;
Linus Walleij664ed4e2017-04-20 21:43:38 +020034 #clock-cells = <1>;
Linus Walleij3863c522017-04-13 16:09:53 +020035 #reset-cells = <1>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +010036
37 syscon-reboot {
38 compatible = "syscon-reboot";
39 regmap = <&syscon>;
40 /* GLOBAL_RESET register */
41 offset = <0x0c>;
42 /* RESET_GLOBAL | RESET_CPU1 */
43 mask = <0xC0000000>;
44 };
Linus Walleijf328c2e2017-07-05 16:59:33 +020045
46 pinctrl {
47 compatible = "cortina,gemini-pinctrl";
48 regmap = <&syscon>;
49 /* Hog the DRAM pins */
50 pinctrl-names = "default";
51 pinctrl-0 = <&dram_default_pins>, <&system_default_pins>,
52 <&vcontrol_default_pins>;
53
54 dram_default_pins: pinctrl-dram {
55 mux {
56 function = "dram";
57 groups = "dramgrp";
58 };
59 };
60 rtc_default_pins: pinctrl-rtc {
61 mux {
62 function = "rtc";
63 groups = "rtcgrp";
64 };
65 };
66 power_default_pins: pinctrl-power {
67 mux {
68 function = "power";
69 groups = "powergrp";
70 };
71 };
72 cir_default_pins: pinctrl-cir {
73 mux {
74 function = "cir";
75 groups = "cirgrp";
76 };
77 };
78 system_default_pins: pinctrl-system {
79 mux {
80 function = "system";
81 groups = "systemgrp";
82 };
83 };
84 vcontrol_default_pins: pinctrl-vcontrol {
85 mux {
86 function = "vcontrol";
87 groups = "vcontrolgrp";
88 };
89 };
90 ice_default_pins: pinctrl-ice {
91 mux {
92 function = "ice";
93 groups = "icegrp";
94 };
95 };
96 uart_default_pins: pinctrl-uart {
97 mux {
98 function = "uart";
99 groups = "uartrxtxgrp";
100 };
101 };
102 pflash_default_pins: pinctrl-pflash {
103 mux {
104 function = "pflash";
105 groups = "pflashgrp";
106 };
107 };
108 usb_default_pins: pinctrl-usb {
109 mux {
110 function = "usb";
111 groups = "usbgrp";
112 };
113 };
114 gmii_default_pins: pinctrl-gmii {
Linus Walleij8f3093b2017-11-06 00:05:28 +0100115 /*
116 * Only activate GMAC0 by default since
117 * GMAC1 will overlap with 8 GPIO lines
118 * gpio2a, gpio2b. Overlay groups with
119 * "gmii_gmac0_grp", "gmii_gmac1_grp" for
120 * both ethernet interfaces.
121 */
Linus Walleijf328c2e2017-07-05 16:59:33 +0200122 mux {
123 function = "gmii";
Linus Walleij8f3093b2017-11-06 00:05:28 +0100124 groups = "gmii_gmac0_grp";
Linus Walleijf328c2e2017-07-05 16:59:33 +0200125 };
126 };
127 pci_default_pins: pinctrl-pci {
128 mux {
129 function = "pci";
130 groups = "pcigrp";
131 };
132 };
133 sata_default_pins: pinctrl-sata {
134 mux {
135 function = "sata";
136 groups = "satagrp";
137 };
138 };
139 /* Activate both groups of pins for this state */
140 sata_and_ide_pins: pinctrl-sata-ide {
141 mux0 {
142 function = "sata";
143 groups = "satagrp";
144 };
145 mux1 {
146 function = "ide";
147 groups = "idegrp";
148 };
149 };
Linus Walleijd2b85242017-10-11 19:45:19 +0200150 tvc_default_pins: pinctrl-tvc {
151 mux {
152 function = "tvc";
153 groups = "tvcgrp";
154 };
155 };
Linus Walleijf328c2e2017-07-05 16:59:33 +0200156 };
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100157 };
158
Linus Walleij6ae4d212017-01-22 23:34:38 +0100159 watchdog@41000000 {
Linus Walleij8633e4f2017-10-16 16:26:07 +0200160 compatible = "cortina,gemini-watchdog", "faraday,ftwdt010";
Linus Walleij6ae4d212017-01-22 23:34:38 +0100161 reg = <0x41000000 0x1000>;
162 interrupts = <3 IRQ_TYPE_LEVEL_HIGH>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200163 resets = <&syscon GEMINI_RESET_WDOG>;
164 clocks = <&syscon GEMINI_CLK_APB>;
Linus Walleij8633e4f2017-10-16 16:26:07 +0200165 clock-names = "PCLK";
Linus Walleij6ae4d212017-01-22 23:34:38 +0100166 };
167
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100168 uart0: serial@42000000 {
169 compatible = "ns16550a";
170 reg = <0x42000000 0x100>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200171 resets = <&syscon GEMINI_RESET_UART>;
172 clocks = <&syscon GEMINI_CLK_UART>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100173 interrupts = <18 IRQ_TYPE_LEVEL_HIGH>;
Linus Walleijf328c2e2017-07-05 16:59:33 +0200174 pinctrl-names = "default";
175 pinctrl-0 = <&uart_default_pins>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100176 reg-shift = <2>;
177 };
178
179 timer@43000000 {
Linus Walleij664ed4e2017-04-20 21:43:38 +0200180 compatible = "faraday,fttmr010";
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100181 reg = <0x43000000 0x1000>;
182 interrupt-parent = <&intcon>;
183 interrupts = <14 IRQ_TYPE_EDGE_FALLING>, /* Timer 1 */
184 <15 IRQ_TYPE_EDGE_FALLING>, /* Timer 2 */
185 <16 IRQ_TYPE_EDGE_FALLING>; /* Timer 3 */
Linus Walleij5896a4d2017-05-24 10:43:21 +0200186 resets = <&syscon GEMINI_RESET_TIMER>;
Linus Walleij664ed4e2017-04-20 21:43:38 +0200187 /* APB clock or RTC clock */
Linus Walleij5896a4d2017-05-24 10:43:21 +0200188 clocks = <&syscon GEMINI_CLK_APB>, <&syscon GEMINI_CLK_RTC>;
Linus Walleij664ed4e2017-04-20 21:43:38 +0200189 clock-names = "PCLK", "EXTCLK";
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100190 syscon = <&syscon>;
191 };
192
193 rtc@45000000 {
194 compatible = "cortina,gemini-rtc";
195 reg = <0x45000000 0x100>;
196 interrupts = <17 IRQ_TYPE_LEVEL_HIGH>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200197 resets = <&syscon GEMINI_RESET_RTC>;
198 clocks = <&syscon GEMINI_CLK_APB>, <&syscon GEMINI_CLK_RTC>;
Linus Walleij664ed4e2017-04-20 21:43:38 +0200199 clock-names = "PCLK", "EXTCLK";
Linus Walleijf328c2e2017-07-05 16:59:33 +0200200 pinctrl-names = "default";
201 pinctrl-0 = <&rtc_default_pins>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100202 };
203
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100204 sata: sata@46000000 {
205 compatible = "cortina,gemini-sata-bridge";
206 reg = <0x46000000 0x100>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200207 resets = <&syscon GEMINI_RESET_SATA0>,
208 <&syscon GEMINI_RESET_SATA1>;
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100209 reset-names = "sata0", "sata1";
Linus Walleij5896a4d2017-05-24 10:43:21 +0200210 clocks = <&syscon GEMINI_CLK_GATE_SATA0>,
211 <&syscon GEMINI_CLK_GATE_SATA1>;
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100212 clock-names = "SATA0_PCLK", "SATA1_PCLK";
Linus Walleijf328c2e2017-07-05 16:59:33 +0200213 /*
214 * This defines the special "ide" state that needs
215 * to be explicitly enabled to enable the IDE pins,
216 * as these pins are normally used for other things.
217 */
218 pinctrl-names = "default", "ide";
219 pinctrl-0 = <&sata_default_pins>;
220 pinctrl-1 = <&sata_and_ide_pins>;
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100221 syscon = <&syscon>;
222 status = "disabled";
223 };
224
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100225 intcon: interrupt-controller@48000000 {
226 compatible = "faraday,ftintc010";
227 reg = <0x48000000 0x1000>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200228 resets = <&syscon GEMINI_RESET_INTCON0>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100229 interrupt-controller;
230 #interrupt-cells = <2>;
231 };
232
Linus Walleije9f2c2a2017-01-30 20:21:49 +0100233 power-controller@4b000000 {
234 compatible = "cortina,gemini-power-controller";
235 reg = <0x4b000000 0x100>;
236 interrupts = <26 IRQ_TYPE_EDGE_RISING>;
Linus Walleijf328c2e2017-07-05 16:59:33 +0200237 pinctrl-names = "default";
238 pinctrl-0 = <&power_default_pins>;
Linus Walleije9f2c2a2017-01-30 20:21:49 +0100239 };
240
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100241 gpio0: gpio@4d000000 {
Linus Walleij552c8042017-03-13 00:20:45 +0100242 compatible = "cortina,gemini-gpio", "faraday,ftgpio010";
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100243 reg = <0x4d000000 0x100>;
244 interrupts = <22 IRQ_TYPE_LEVEL_HIGH>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200245 resets = <&syscon GEMINI_RESET_GPIO0>;
246 clocks = <&syscon GEMINI_CLK_APB>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100247 gpio-controller;
248 #gpio-cells = <2>;
249 interrupt-controller;
250 #interrupt-cells = <2>;
251 };
252
253 gpio1: gpio@4e000000 {
Linus Walleij552c8042017-03-13 00:20:45 +0100254 compatible = "cortina,gemini-gpio", "faraday,ftgpio010";
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100255 reg = <0x4e000000 0x100>;
256 interrupts = <23 IRQ_TYPE_LEVEL_HIGH>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200257 resets = <&syscon GEMINI_RESET_GPIO1>;
258 clocks = <&syscon GEMINI_CLK_APB>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100259 gpio-controller;
260 #gpio-cells = <2>;
261 interrupt-controller;
262 #interrupt-cells = <2>;
263 };
264
265 gpio2: gpio@4f000000 {
Linus Walleij552c8042017-03-13 00:20:45 +0100266 compatible = "cortina,gemini-gpio", "faraday,ftgpio010";
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100267 reg = <0x4f000000 0x100>;
268 interrupts = <24 IRQ_TYPE_LEVEL_HIGH>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200269 resets = <&syscon GEMINI_RESET_GPIO2>;
270 clocks = <&syscon GEMINI_CLK_APB>;
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100271 gpio-controller;
272 #gpio-cells = <2>;
273 interrupt-controller;
274 #interrupt-cells = <2>;
275 };
Linus Walleije3aeca12017-01-28 21:15:15 +0100276
277 pci@50000000 {
278 compatible = "cortina,gemini-pci", "faraday,ftpci100";
279 /*
280 * The first 256 bytes in the IO range is actually used
281 * to configure the host bridge.
282 */
283 reg = <0x50000000 0x100>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200284 resets = <&syscon GEMINI_RESET_PCI>;
285 clocks = <&syscon GEMINI_CLK_GATE_PCI>, <&syscon GEMINI_CLK_PCI>;
Linus Walleij664ed4e2017-04-20 21:43:38 +0200286 clock-names = "PCLK", "PCICLK";
Linus Walleijf328c2e2017-07-05 16:59:33 +0200287 pinctrl-names = "default";
288 pinctrl-0 = <&pci_default_pins>;
Linus Walleije3aeca12017-01-28 21:15:15 +0100289 #address-cells = <3>;
290 #size-cells = <2>;
291 #interrupt-cells = <1>;
292 status = "disabled";
293
294 bus-range = <0x00 0xff>;
295 /* PCI ranges mappings */
296 ranges =
297 /* 1MiB I/O space 0x50000000-0x500fffff */
298 <0x01000000 0 0 0x50000000 0 0x00100000>,
299 /* 128MiB non-prefetchable memory 0x58000000-0x5fffffff */
300 <0x02000000 0 0x58000000 0x58000000 0 0x08000000>;
301
302 /* DMA ranges */
303 dma-ranges =
304 /* 128MiB at 0x00000000-0x07ffffff */
305 <0x02000000 0 0x00000000 0x00000000 0 0x08000000>,
306 /* 64MiB at 0x00000000-0x03ffffff */
307 <0x02000000 0 0x00000000 0x00000000 0 0x04000000>,
308 /* 64MiB at 0x00000000-0x03ffffff */
309 <0x02000000 0 0x00000000 0x00000000 0 0x04000000>;
310
311 /*
312 * This PCI host bridge variant has a cascaded interrupt
313 * controller embedded in the host bridge.
314 */
315 pci_intc: interrupt-controller {
316 interrupt-parent = <&intcon>;
317 interrupts = <8 IRQ_TYPE_LEVEL_HIGH>;
318 interrupt-controller;
319 #address-cells = <0>;
320 #interrupt-cells = <1>;
321 };
322 };
Linus Walleij9eeb0222017-04-01 19:55:48 +0200323
Linus Walleij8f3093b2017-11-06 00:05:28 +0100324 ethernet@60000000 {
325 compatible = "cortina,gemini-ethernet";
326 reg = <0x60000000 0x4000>, /* Global registers, queue */
327 <0x60004000 0x2000>, /* V-bit */
328 <0x60006000 0x2000>; /* A-bit */
329 pinctrl-names = "default";
330 pinctrl-0 = <&gmii_default_pins>;
331 status = "disabled";
332 #address-cells = <1>;
333 #size-cells = <1>;
334 ranges;
335
336 gmac0: ethernet-port@0 {
337 compatible = "cortina,gemini-ethernet-port";
338 reg = <0x60008000 0x2000>, /* Port 0 DMA/TOE */
339 <0x6000a000 0x2000>; /* Port 0 GMAC */
340 interrupt-parent = <&intcon>;
341 interrupts = <1 IRQ_TYPE_LEVEL_HIGH>;
342 resets = <&syscon GEMINI_RESET_GMAC0>;
343 clocks = <&syscon GEMINI_CLK_GATE_GMAC0>;
344 clock-names = "PCLK";
345 };
346
347 gmac1: ethernet-port@1 {
348 compatible = "cortina,gemini-ethernet-port";
349 reg = <0x6000c000 0x2000>, /* Port 1 DMA/TOE */
350 <0x6000e000 0x2000>; /* Port 1 GMAC */
351 interrupt-parent = <&intcon>;
352 interrupts = <2 IRQ_TYPE_LEVEL_HIGH>;
353 resets = <&syscon GEMINI_RESET_GMAC1>;
354 clocks = <&syscon GEMINI_CLK_GATE_GMAC1>;
355 clock-names = "PCLK";
356 };
357 };
358
Linus Walleij67ac6542019-12-31 18:14:28 +0100359 ide@63000000 {
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100360 compatible = "cortina,gemini-pata", "faraday,ftide010";
361 reg = <0x63000000 0x1000>;
362 interrupts = <4 IRQ_TYPE_EDGE_RISING>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200363 resets = <&syscon GEMINI_RESET_IDE>;
364 clocks = <&syscon GEMINI_CLK_GATE_IDE>;
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100365 clock-names = "PCLK";
366 sata = <&sata>;
367 status = "disabled";
Linus Walleij67ac6542019-12-31 18:14:28 +0100368 #address-cells = <1>;
369 #size-cells = <0>;
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100370 };
371
Linus Walleij67ac6542019-12-31 18:14:28 +0100372 ide@63400000 {
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100373 compatible = "cortina,gemini-pata", "faraday,ftide010";
374 reg = <0x63400000 0x1000>;
375 interrupts = <5 IRQ_TYPE_EDGE_RISING>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200376 resets = <&syscon GEMINI_RESET_IDE>;
377 clocks = <&syscon GEMINI_CLK_GATE_IDE>;
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100378 clock-names = "PCLK";
379 sata = <&sata>;
380 status = "disabled";
Linus Walleij67ac6542019-12-31 18:14:28 +0100381 #address-cells = <1>;
382 #size-cells = <0>;
Linus Walleij0d7a2c32017-03-20 23:39:26 +0100383 };
384
Linus Walleij9eeb0222017-04-01 19:55:48 +0200385 dma-controller@67000000 {
386 compatible = "faraday,ftdma020", "arm,pl080", "arm,primecell";
387 /* Faraday Technology FTDMAC020 variant */
388 arm,primecell-periphid = <0x0003b080>;
389 reg = <0x67000000 0x1000>;
390 interrupts = <9 IRQ_TYPE_EDGE_RISING>;
Linus Walleij5896a4d2017-05-24 10:43:21 +0200391 resets = <&syscon GEMINI_RESET_DMAC>;
392 clocks = <&syscon GEMINI_CLK_AHB>;
Linus Walleij9eeb0222017-04-01 19:55:48 +0200393 clock-names = "apb_pclk";
394 /* Bus interface AHB1 (AHB0) is totally tilted */
395 lli-bus-interface-ahb2;
396 mem-bus-interface-ahb2;
397 memcpy-burst-size = <256>;
398 memcpy-bus-width = <32>;
399 #dma-cells = <2>;
400 };
Linus Walleijd2b85242017-10-11 19:45:19 +0200401
402 display-controller@6a000000 {
403 compatible = "cortina,gemini-tvc", "faraday,tve200";
404 reg = <0x6a000000 0x1000>;
405 interrupts = <13 IRQ_TYPE_EDGE_RISING>;
406 resets = <&syscon GEMINI_RESET_TVC>;
407 clocks = <&syscon GEMINI_CLK_GATE_TVC>,
408 <&syscon GEMINI_CLK_TVC>;
409 clock-names = "PCLK", "TVE";
410 pinctrl-names = "default";
411 pinctrl-0 = <&tvc_default_pins>;
412 #address-cells = <1>;
413 #size-cells = <0>;
414 status = "disabled";
415 };
Linus Walleijd6d0cef2017-04-21 20:50:22 +0200416
417 usb@68000000 {
418 compatible = "cortina,gemini-usb", "faraday,fotg210";
419 reg = <0x68000000 0x1000>;
420 interrupts = <10 IRQ_TYPE_LEVEL_HIGH>;
421 resets = <&syscon GEMINI_RESET_USB0>;
422 clocks = <&syscon GEMINI_CLK_GATE_USB0>;
423 clock-names = "PCLK";
424 /*
425 * This will claim pins for USB0 and USB1 at the same
426 * time as they are using some common pins. If you for
427 * some reason have a system using USB1 at 96000000 but
428 * NOT using USB0 at 68000000 you wll have to add the
429 * usb_default_pins to the USB controller at 96000000
430 * in your .dts for the board.
431 */
432 pinctrl-names = "default";
433 pinctrl-0 = <&usb_default_pins>;
434 syscon = <&syscon>;
435 status = "disabled";
436 };
437
438 usb@69000000 {
439 compatible = "cortina,gemini-usb", "faraday,fotg210";
440 reg = <0x69000000 0x1000>;
441 interrupts = <11 IRQ_TYPE_LEVEL_HIGH>;
442 resets = <&syscon GEMINI_RESET_USB1>;
443 clocks = <&syscon GEMINI_CLK_GATE_USB1>;
444 clock-names = "PCLK";
445 syscon = <&syscon>;
446 status = "disabled";
447 };
Linus Walleij9be0d7f2017-01-21 13:00:15 +0100448 };
449};