1 // SPDX-License-Identifier: GPL-2.0
3 * Device Tree file for Cortina systems Gemini SoC
6 #include <dt-bindings/interrupt-controller/irq.h>
7 #include <dt-bindings/clock/cortina,gemini-clock.h>
8 #include <dt-bindings/reset/cortina,gemini-reset.h>
9 #include <dt-bindings/gpio/gpio.h>
16 compatible = "simple-bus";
17 interrupt-parent = <&intcon>;
19 flash: flash@30000000 {
20 compatible = "cortina,gemini-flash", "cfi-flash";
22 pinctrl-names = "default";
23 pinctrl-0 = <&pflash_default_pins>;
30 syscon: syscon@40000000 {
31 compatible = "cortina,gemini-syscon",
32 "syscon", "simple-mfd";
33 reg = <0x40000000 0x1000>;
38 compatible = "syscon-reboot";
40 /* GLOBAL_RESET register */
42 /* RESET_GLOBAL | RESET_CPU1 */
47 compatible = "cortina,gemini-pinctrl";
49 /* Hog the DRAM pins */
50 pinctrl-names = "default";
51 pinctrl-0 = <&dram_default_pins>, <&system_default_pins>,
52 <&vcontrol_default_pins>;
54 dram_default_pins: pinctrl-dram {
60 rtc_default_pins: pinctrl-rtc {
66 power_default_pins: pinctrl-power {
72 cir_default_pins: pinctrl-cir {
78 system_default_pins: pinctrl-system {
84 vcontrol_default_pins: pinctrl-vcontrol {
86 function = "vcontrol";
87 groups = "vcontrolgrp";
90 ice_default_pins: pinctrl-ice {
96 uart_default_pins: pinctrl-uart {
99 groups = "uartrxtxgrp";
102 pflash_default_pins: pinctrl-pflash {
105 groups = "pflashgrp";
108 usb_default_pins: pinctrl-usb {
114 gmii_default_pins: pinctrl-gmii {
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.
124 groups = "gmii_gmac0_grp";
127 pci_default_pins: pinctrl-pci {
133 sata_default_pins: pinctrl-sata {
139 /* Activate both groups of pins for this state */
140 sata_and_ide_pins: pinctrl-sata-ide {
150 tvc_default_pins: pinctrl-tvc {
160 compatible = "cortina,gemini-watchdog", "faraday,ftwdt010";
161 reg = <0x41000000 0x1000>;
162 interrupts = <3 IRQ_TYPE_LEVEL_HIGH>;
163 resets = <&syscon GEMINI_RESET_WDOG>;
164 clocks = <&syscon GEMINI_CLK_APB>;
165 clock-names = "PCLK";
168 uart0: serial@42000000 {
169 compatible = "ns16550a";
170 reg = <0x42000000 0x100>;
171 resets = <&syscon GEMINI_RESET_UART>;
172 clocks = <&syscon GEMINI_CLK_UART>;
173 interrupts = <18 IRQ_TYPE_LEVEL_HIGH>;
174 pinctrl-names = "default";
175 pinctrl-0 = <&uart_default_pins>;
180 compatible = "faraday,fttmr010";
181 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 */
186 resets = <&syscon GEMINI_RESET_TIMER>;
187 /* APB clock or RTC clock */
188 clocks = <&syscon GEMINI_CLK_APB>, <&syscon GEMINI_CLK_RTC>;
189 clock-names = "PCLK", "EXTCLK";
194 compatible = "cortina,gemini-rtc", "faraday,ftrtc010";
195 reg = <0x45000000 0x100>;
196 interrupts = <17 IRQ_TYPE_LEVEL_HIGH>;
197 resets = <&syscon GEMINI_RESET_RTC>;
198 clocks = <&syscon GEMINI_CLK_APB>, <&syscon GEMINI_CLK_RTC>;
199 clock-names = "PCLK", "EXTCLK";
200 pinctrl-names = "default";
201 pinctrl-0 = <&rtc_default_pins>;
204 sata: sata@46000000 {
205 compatible = "cortina,gemini-sata-bridge";
206 reg = <0x46000000 0x100>;
207 resets = <&syscon GEMINI_RESET_SATA0>,
208 <&syscon GEMINI_RESET_SATA1>;
209 reset-names = "sata0", "sata1";
210 clocks = <&syscon GEMINI_CLK_GATE_SATA0>,
211 <&syscon GEMINI_CLK_GATE_SATA1>;
212 clock-names = "SATA0_PCLK", "SATA1_PCLK";
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.
218 pinctrl-names = "default", "ide";
219 pinctrl-0 = <&sata_default_pins>;
220 pinctrl-1 = <&sata_and_ide_pins>;
225 intcon: interrupt-controller@48000000 {
226 compatible = "faraday,ftintc010";
227 reg = <0x48000000 0x1000>;
228 resets = <&syscon GEMINI_RESET_INTCON0>;
229 interrupt-controller;
230 #interrupt-cells = <2>;
233 power-controller@4b000000 {
234 compatible = "cortina,gemini-power-controller";
235 reg = <0x4b000000 0x100>;
236 interrupts = <26 IRQ_TYPE_EDGE_RISING>;
237 pinctrl-names = "default";
238 pinctrl-0 = <&power_default_pins>;
241 gpio0: gpio@4d000000 {
242 compatible = "cortina,gemini-gpio", "faraday,ftgpio010";
243 reg = <0x4d000000 0x100>;
244 interrupts = <22 IRQ_TYPE_LEVEL_HIGH>;
245 resets = <&syscon GEMINI_RESET_GPIO0>;
246 clocks = <&syscon GEMINI_CLK_APB>;
249 interrupt-controller;
250 #interrupt-cells = <2>;
253 gpio1: gpio@4e000000 {
254 compatible = "cortina,gemini-gpio", "faraday,ftgpio010";
255 reg = <0x4e000000 0x100>;
256 interrupts = <23 IRQ_TYPE_LEVEL_HIGH>;
257 resets = <&syscon GEMINI_RESET_GPIO1>;
258 clocks = <&syscon GEMINI_CLK_APB>;
261 interrupt-controller;
262 #interrupt-cells = <2>;
265 gpio2: gpio@4f000000 {
266 compatible = "cortina,gemini-gpio", "faraday,ftgpio010";
267 reg = <0x4f000000 0x100>;
268 interrupts = <24 IRQ_TYPE_LEVEL_HIGH>;
269 resets = <&syscon GEMINI_RESET_GPIO2>;
270 clocks = <&syscon GEMINI_CLK_APB>;
273 interrupt-controller;
274 #interrupt-cells = <2>;
278 compatible = "cortina,gemini-pci", "faraday,ftpci100";
280 * The first 256 bytes in the IO range is actually used
281 * to configure the host bridge.
283 reg = <0x50000000 0x100>;
284 resets = <&syscon GEMINI_RESET_PCI>;
285 clocks = <&syscon GEMINI_CLK_GATE_PCI>, <&syscon GEMINI_CLK_PCI>;
286 clock-names = "PCLK", "PCICLK";
287 pinctrl-names = "default";
288 pinctrl-0 = <&pci_default_pins>;
290 #address-cells = <3>;
294 #interrupt-cells = <1>;
295 interrupt-map-mask = <0xf800 0 0 7>;
297 <0x4800 0 0 1 &pci_intc 0>, /* Slot 9 */
298 <0x4800 0 0 2 &pci_intc 1>,
299 <0x4800 0 0 3 &pci_intc 2>,
300 <0x4800 0 0 4 &pci_intc 3>,
301 <0x5000 0 0 1 &pci_intc 1>, /* Slot 10 */
302 <0x5000 0 0 2 &pci_intc 2>,
303 <0x5000 0 0 3 &pci_intc 3>,
304 <0x5000 0 0 4 &pci_intc 0>,
305 <0x5800 0 0 1 &pci_intc 2>, /* Slot 11 */
306 <0x5800 0 0 2 &pci_intc 3>,
307 <0x5800 0 0 3 &pci_intc 0>,
308 <0x5800 0 0 4 &pci_intc 1>,
309 <0x6000 0 0 1 &pci_intc 3>, /* Slot 12 */
310 <0x6000 0 0 2 &pci_intc 0>,
311 <0x6000 0 0 3 &pci_intc 1>,
312 <0x6000 0 0 4 &pci_intc 2>;
314 bus-range = <0x00 0xff>;
315 /* PCI ranges mappings */
317 /* 1MiB I/O space 0x50000000-0x500fffff */
318 <0x01000000 0 0 0x50000000 0 0x00100000>,
319 /* 128MiB non-prefetchable memory 0x58000000-0x5fffffff */
320 <0x02000000 0 0x58000000 0x58000000 0 0x08000000>;
324 /* 128MiB at 0x00000000-0x07ffffff */
325 <0x02000000 0 0x00000000 0x00000000 0 0x08000000>,
326 /* 64MiB at 0x00000000-0x03ffffff */
327 <0x02000000 0 0x00000000 0x00000000 0 0x04000000>,
328 /* 64MiB at 0x00000000-0x03ffffff */
329 <0x02000000 0 0x00000000 0x00000000 0 0x04000000>;
332 * This PCI host bridge variant has a cascaded interrupt
333 * controller embedded in the host bridge.
335 pci_intc: interrupt-controller {
336 interrupt-parent = <&intcon>;
337 interrupts = <8 IRQ_TYPE_LEVEL_HIGH>;
338 interrupt-controller;
339 #address-cells = <0>;
340 #interrupt-cells = <1>;
344 ethernet: ethernet@60000000 {
345 compatible = "cortina,gemini-ethernet";
346 reg = <0x60000000 0x4000>, /* Global registers, queue */
347 <0x60004000 0x2000>, /* V-bit */
348 <0x60006000 0x2000>; /* A-bit */
349 pinctrl-names = "default";
350 pinctrl-0 = <&gmii_default_pins>;
352 #address-cells = <1>;
356 gmac0: ethernet-port@0 {
357 compatible = "cortina,gemini-ethernet-port";
358 reg = <0x60008000 0x2000>, /* Port 0 DMA/TOE */
359 <0x6000a000 0x2000>; /* Port 0 GMAC */
360 interrupt-parent = <&intcon>;
361 interrupts = <1 IRQ_TYPE_LEVEL_HIGH>;
362 resets = <&syscon GEMINI_RESET_GMAC0>;
363 clocks = <&syscon GEMINI_CLK_GATE_GMAC0>;
364 clock-names = "PCLK";
367 gmac1: ethernet-port@1 {
368 compatible = "cortina,gemini-ethernet-port";
369 reg = <0x6000c000 0x2000>, /* Port 1 DMA/TOE */
370 <0x6000e000 0x2000>; /* Port 1 GMAC */
371 interrupt-parent = <&intcon>;
372 interrupts = <2 IRQ_TYPE_LEVEL_HIGH>;
373 resets = <&syscon GEMINI_RESET_GMAC1>;
374 clocks = <&syscon GEMINI_CLK_GATE_GMAC1>;
375 clock-names = "PCLK";
379 crypto: crypto@62000000 {
380 compatible = "cortina,sl3516-crypto";
381 reg = <0x62000000 0x10000>;
382 interrupts = <7 IRQ_TYPE_EDGE_RISING>;
383 resets = <&syscon GEMINI_RESET_SECURITY>;
384 clocks = <&syscon GEMINI_CLK_GATE_SECURITY>;
388 compatible = "cortina,gemini-pata", "faraday,ftide010";
389 reg = <0x63000000 0x1000>;
390 interrupts = <4 IRQ_TYPE_EDGE_RISING>;
391 resets = <&syscon GEMINI_RESET_IDE>;
392 clocks = <&syscon GEMINI_CLK_GATE_IDE>;
393 clock-names = "PCLK";
396 #address-cells = <1>;
401 compatible = "cortina,gemini-pata", "faraday,ftide010";
402 reg = <0x63400000 0x1000>;
403 interrupts = <5 IRQ_TYPE_EDGE_RISING>;
404 resets = <&syscon GEMINI_RESET_IDE>;
405 clocks = <&syscon GEMINI_CLK_GATE_IDE>;
406 clock-names = "PCLK";
409 #address-cells = <1>;
413 dma-controller@67000000 {
414 compatible = "faraday,ftdma020", "arm,pl080", "arm,primecell";
415 /* Faraday Technology FTDMAC020 variant */
416 arm,primecell-periphid = <0x0003b080>;
417 reg = <0x67000000 0x1000>;
418 interrupts = <9 IRQ_TYPE_EDGE_RISING>;
419 resets = <&syscon GEMINI_RESET_DMAC>;
420 clocks = <&syscon GEMINI_CLK_AHB>;
421 clock-names = "apb_pclk";
422 /* Bus interface AHB1 (AHB0) is totally tilted */
423 lli-bus-interface-ahb2;
424 mem-bus-interface-ahb2;
425 memcpy-burst-size = <256>;
426 memcpy-bus-width = <32>;
430 display-controller@6a000000 {
431 compatible = "cortina,gemini-tvc", "faraday,tve200";
432 reg = <0x6a000000 0x1000>;
433 interrupts = <13 IRQ_TYPE_EDGE_RISING>;
434 resets = <&syscon GEMINI_RESET_TVC>;
435 clocks = <&syscon GEMINI_CLK_GATE_TVC>,
436 <&syscon GEMINI_CLK_TVC>;
437 clock-names = "PCLK", "TVE";
438 pinctrl-names = "default";
439 pinctrl-0 = <&tvc_default_pins>;
444 compatible = "cortina,gemini-usb", "faraday,fotg210";
445 reg = <0x68000000 0x1000>;
446 interrupts = <10 IRQ_TYPE_LEVEL_HIGH>;
447 resets = <&syscon GEMINI_RESET_USB0>;
448 clocks = <&syscon GEMINI_CLK_GATE_USB0>;
449 clock-names = "PCLK";
451 * This will claim pins for USB0 and USB1 at the same
452 * time as they are using some common pins. If you for
453 * some reason have a system using USB1 at 96000000 but
454 * NOT using USB0 at 68000000 you wll have to add the
455 * usb_default_pins to the USB controller at 96000000
456 * in your .dts for the board.
458 pinctrl-names = "default";
459 pinctrl-0 = <&usb_default_pins>;
465 compatible = "cortina,gemini-usb", "faraday,fotg210";
466 reg = <0x69000000 0x1000>;
467 interrupts = <11 IRQ_TYPE_LEVEL_HIGH>;
468 resets = <&syscon GEMINI_RESET_USB1>;
469 clocks = <&syscon GEMINI_CLK_GATE_USB1>;
470 clock-names = "PCLK";