~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/powerpc/boot/dts/turris1x.dts

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 // SPDX-License-Identifier: GPL-2.0+
  2 /*
  3  * Turris 1.x Device Tree Source
  4  *
  5  * Copyright 2013 - 2022 CZ.NIC z.s.p.o. (http://www.nic.cz/)
  6  *
  7  * Pinout, Schematics and Altium hardware design files are open source
  8  * and available at: https://docs.turris.cz/hw/turris-1x/turris-1x/
  9  */
 10 
 11 #include <dt-bindings/gpio/gpio.h>
 12 #include <dt-bindings/interrupt-controller/irq.h>
 13 #include <dt-bindings/leds/common.h>
 14 /include/ "fsl/p2020si-pre.dtsi"
 15 
 16 / {
 17         model = "Turris 1.x";
 18         compatible = "cznic,turris1x";
 19 
 20         aliases {
 21                 ethernet0 = &enet0;
 22                 ethernet1 = &enet1;
 23                 ethernet2 = &enet2;
 24                 serial0 = &serial0;
 25                 serial1 = &serial1;
 26                 pci0 = &pci0;
 27                 pci1 = &pci1;
 28                 pci2 = &pci2;
 29                 spi0 = &spi0;
 30         };
 31 
 32         memory {
 33                 device_type = "memory";
 34         };
 35 
 36         soc: soc@ffe00000 {
 37                 ranges = <0x0 0x0 0xffe00000 0x00100000>;
 38 
 39                 i2c@3000 {
 40                         /* PCA9557PW GPIO controller for boot config */
 41                         gpio-controller@18 {
 42                                 compatible = "nxp,pca9557";
 43                                 label = "bootcfg";
 44                                 reg = <0x18>;
 45                                 #gpio-cells = <2>;
 46                                 gpio-controller;
 47                                 polarity = <0x00>;
 48                         };
 49 
 50                         /* STM32F030R8T6 MCU for power control */
 51                         power-control@2a {
 52                                 /*
 53                                  * Turris Power Control firmware runs on STM32F0 MCU.
 54                                  * This firmware is open source and available at:
 55                                  * https://gitlab.nic.cz/turris/hw/turris_power_control
 56                                  */
 57                                 reg = <0x2a>;
 58                         };
 59 
 60                         /* DDR3 SPD/EEPROM PSWP instruction */
 61                         eeprom@32 {
 62                                 reg = <0x32>;
 63                         };
 64 
 65                         /* SA56004ED temperature control */
 66                         temperature-sensor@4c {
 67                                 compatible = "nxp,sa56004";
 68                                 reg = <0x4c>;
 69                                 interrupt-parent = <&gpio>;
 70                                 interrupts = <12 IRQ_TYPE_LEVEL_LOW>, /* GPIO12 - ALERT pin */
 71                                              <13 IRQ_TYPE_LEVEL_LOW>; /* GPIO13 - CRIT pin */
 72                                 #address-cells = <1>;
 73                                 #size-cells = <0>;
 74 
 75                                 /* Local temperature sensor (SA56004ED internal) */
 76                                 channel@0 {
 77                                         reg = <0>;
 78                                         label = "board";
 79                                 };
 80 
 81                                 /* Remote temperature sensor (D+/D- connected to P2020 CPU Temperature Diode) */
 82                                 channel@1 {
 83                                         reg = <1>;
 84                                         label = "cpu";
 85                                 };
 86                         };
 87 
 88                         /* DDR3 SPD/EEPROM */
 89                         eeprom@52 {
 90                                 compatible = "atmel,spd";
 91                                 reg = <0x52>;
 92                         };
 93 
 94                         /* MCP79402-I/ST Protected EEPROM */
 95                         eeprom@57 {
 96                                 reg = <0x57>;
 97                         };
 98 
 99                         /* ATSHA204-TH-DA-T crypto module */
100                         crypto@64 {
101                                 compatible = "atmel,atsha204";
102                                 reg = <0x64>;
103                         };
104 
105                         /* IDT6V49205BNLGI clock generator */
106                         clock-generator@69 {
107                                 compatible = "idt,6v49205b";
108                                 reg = <0x69>;
109                         };
110 
111                         /* MCP79402-I/ST RTC */
112                         rtc@6f {
113                                 compatible = "microchip,mcp7940x";
114                                 reg = <0x6f>;
115                                 interrupt-parent = <&gpio>;
116                                 interrupts = <14 0>; /* GPIO14 - MFP pin */
117                         };
118                 };
119 
120                 /* SPI on connector P1 */
121                 spi0: spi@7000 {
122                 };
123 
124                 gpio: gpio-controller@fc00 {
125                         #interrupt-cells = <2>;
126                         interrupt-controller;
127                 };
128 
129                 /* Connected to SMSC USB2412-DZK 2-Port USB 2.0 Hub Controller */
130                 usb@22000 {
131                         phy_type = "ulpi";
132                         dr_mode = "host";
133                 };
134 
135                 enet0: ethernet@24000 {
136                         /* Connected to port 6 of QCA8337N-AL3C switch */
137                         phy-connection-type = "rgmii-id";
138 
139                         fixed-link {
140                                 speed = <1000>;
141                                 full-duplex;
142                         };
143                 };
144 
145                 mdio@24520 {
146                         /* KSZ9031RNXCA ethernet phy for WAN port */
147                         phy: ethernet-phy@7 {
148                                 interrupts = <3 1 0 0>;
149                                 reg = <0x7>;
150                         };
151 
152                         /* QCA8337N-AL3C switch with integrated ethernet PHYs for LAN ports */
153                         switch@10 {
154                                 compatible = "qca,qca8337";
155                                 interrupts = <2 1 0 0>;
156                                 reg = <0x10>;
157 
158                                 ports {
159                                         #address-cells = <1>;
160                                         #size-cells = <0>;
161 
162                                         port@0 {
163                                                 reg = <0>;
164                                                 label = "cpu";
165                                                 ethernet = <&enet1>;
166                                                 phy-mode = "rgmii-id";
167 
168                                                 fixed-link {
169                                                         speed = <1000>;
170                                                         full-duplex;
171                                                 };
172                                         };
173 
174                                         port@1 {
175                                                 reg = <1>;
176                                                 label = "lan5";
177                                         };
178 
179                                         port@2 {
180                                                 reg = <2>;
181                                                 label = "lan4";
182                                         };
183 
184                                         port@3 {
185                                                 reg = <3>;
186                                                 label = "lan3";
187                                         };
188 
189                                         port@4 {
190                                                 reg = <4>;
191                                                 label = "lan2";
192                                         };
193 
194                                         port@5 {
195                                                 reg = <5>;
196                                                 label = "lan1";
197                                         };
198 
199                                         port@6 {
200                                                 reg = <6>;
201                                                 label = "cpu";
202                                                 ethernet = <&enet0>;
203                                                 phy-mode = "rgmii-id";
204 
205                                                 fixed-link {
206                                                         speed = <1000>;
207                                                         full-duplex;
208                                                 };
209                                         };
210                                 };
211                         };
212                 };
213 
214                 ptp_clock@24e00 {
215                         fsl,tclk-period = <5>;
216                         fsl,tmr-prsc = <200>;
217                         fsl,tmr-add = <0xcccccccd>;
218                         fsl,tmr-fiper1 = <0x3b9ac9fb>;
219                         fsl,tmr-fiper2 = <0x0001869b>;
220                         fsl,max-adj = <249999999>;
221                 };
222 
223                 enet1: ethernet@25000 {
224                         /* Connected to port 0 of QCA8337N-AL3C switch */
225                         phy-connection-type = "rgmii-id";
226 
227                         fixed-link {
228                                 speed = <1000>;
229                                 full-duplex;
230                         };
231                 };
232 
233                 mdio@25520 {
234                         status = "disabled";
235                 };
236 
237                 enet2: ethernet@26000 {
238                         /* Connected to KSZ9031RNXCA ethernet phy (WAN port) */
239                         label = "wan";
240                         phy-handle = <&phy>;
241                         phy-connection-type = "rgmii-id";
242                 };
243 
244                 mdio@26520 {
245                         status = "disabled";
246                 };
247 
248                 sdhc@2e000 {
249                         bus-width = <4>;
250                         cd-gpios = <&gpio 8 GPIO_ACTIVE_LOW>;
251                 };
252         };
253 
254         lbc: localbus@ffe05000 {
255                 reg = <0 0xffe05000 0 0x1000>;
256 
257                 ranges = <0x0 0x0 0x0 0xef000000 0x01000000>, /* NOR */
258                          <0x1 0x0 0x0 0xff800000 0x00040000>, /* NAND */
259                          <0x3 0x0 0x0 0xffa00000 0x00020000>; /* CPLD */
260 
261                 /* S29GL128P90TFIR10 NOR */
262                 nor@0,0 {
263                         compatible = "cfi-flash";
264                         reg = <0x0 0x0 0x01000000>;
265                         bank-width = <2>;
266                         device-width = <1>;
267 
268                         partitions {
269                                 compatible = "fixed-partitions";
270                                 #address-cells = <1>;
271                                 #size-cells = <1>;
272 
273                                 partition@0 {
274                                         /* 128 kB for Device Tree Blob */
275                                         reg = <0x00000000 0x00020000>;
276                                         label = "dtb";
277                                 };
278 
279                                 partition@20000 {
280                                         /* 1.7 MB for Linux Kernel Image */
281                                         reg = <0x00020000 0x001a0000>;
282                                         label = "kernel";
283                                 };
284 
285                                 partition@1c0000 {
286                                         /* 1.5 MB for Rescue JFFS2 Root File System */
287                                         reg = <0x001c0000 0x00180000>;
288                                         label = "rescue";
289                                 };
290 
291                                 partition@340000 {
292                                         /* 11 MB for TAR.XZ Archive with Factory content of NAND Root File System */
293                                         reg = <0x00340000 0x00b00000>;
294                                         label = "factory";
295                                 };
296 
297                                 partition@e40000 {
298                                         /* 768 kB for Certificates JFFS2 File System */
299                                         reg = <0x00e40000 0x000c0000>;
300                                         label = "certificates";
301                                 };
302 
303                                 /* free unused space 0x00f00000-0x00f20000 */
304 
305                                 partition@f20000 {
306                                         /* 128 kB for U-Boot Environment Variables */
307                                         reg = <0x00f20000 0x00020000>;
308                                         label = "u-boot-env";
309                                 };
310 
311                                 partition@f40000 {
312                                         /* 768 kB for U-Boot Bootloader Image */
313                                         reg = <0x00f40000 0x000c0000>;
314                                         label = "u-boot";
315                                 };
316                         };
317                 };
318 
319                 /* MT29F2G08ABAEAWP:E NAND */
320                 nand@1,0 {
321                         compatible = "fsl,p2020-fcm-nand", "fsl,elbc-fcm-nand";
322                         reg = <0x1 0x0 0x00040000>;
323                         nand-ecc-mode = "soft";
324                         nand-ecc-algo = "bch";
325 
326                         partitions {
327                                 compatible = "fixed-partitions";
328                                 #address-cells = <1>;
329                                 #size-cells = <1>;
330 
331                                 partition@0 {
332                                         /* 256 MB for UBI with one volume: UBIFS Root File System */
333                                         reg = <0x00000000 0x10000000>;
334                                         label = "rootfs";
335                                 };
336                         };
337                 };
338 
339                 /* LCMXO1200C-3FTN256C FPGA */
340                 cpld@3,0 {
341                         /*
342                          * Turris CPLD firmware which runs on this Lattice FPGA,
343                          * is extended version of P1021RDB-PC CPLD v4.1 firmware.
344                          * It is backward compatible with its original version
345                          * and the only extension is support for Turris LEDs.
346                          * Turris CPLD firmware is open source and available at:
347                          * https://gitlab.nic.cz/turris/hw/turris_cpld/-/blob/master/CZ_NIC_Router_CPLD.v
348                          */
349                         compatible = "cznic,turris1x-cpld", "fsl,p1021rdb-pc-cpld", "simple-bus", "syscon";
350                         reg = <0x3 0x0 0x30>;
351                         #address-cells = <1>;
352                         #size-cells = <1>;
353                         ranges = <0x0 0x3 0x0 0x00020000>;
354 
355                         /* MAX6370KA+T watchdog */
356                         watchdog@2 {
357                                 /*
358                                  * CPLD firmware maps SET0, SET1 and SET2
359                                  * input logic of MAX6370KA+T chip to CPLD
360                                  * memory space at byte offset 0x2. WDI
361                                  * input logic is outside of the CPLD and
362                                  * connected via external GPIO.
363                                  */
364                                 compatible = "maxim,max6370";
365                                 reg = <0x02 0x01>;
366                                 gpios = <&gpio 11 GPIO_ACTIVE_LOW>;
367                         };
368 
369                         reboot@d {
370                                 /*
371                                  * CPLD firmware which manages system reset and
372                                  * watchdog registers has bugs. It does not
373                                  * autoclear system reset register after change
374                                  * and watchdog ignores reset line on immediate
375                                  * succeeding reset cycle triggered by watchdog.
376                                  * These bugs have to be workarounded in U-Boot
377                                  * bootloader. So use system reset via syscon as
378                                  * a last resort because older U-Boot versions
379                                  * do not have workaround for watchdog.
380                                  *
381                                  * Reset method via rstcr's global-utilities
382                                  * (the preferred one) has priority level 128,
383                                  * watchdog has priority level 0 and default
384                                  * syscon-reboot priority level is 192.
385                                  *
386                                  * So define syscon-reboot with custom priority
387                                  * level 64 (between rstcr and watchdog) because
388                                  * rstcr should stay as default preferred reset
389                                  * method and reset via watchdog is more broken
390                                  * than system reset via syscon.
391                                  */
392                                 compatible = "syscon-reboot";
393                                 reg = <0x0d 0x01>;
394                                 offset = <0x0d>;
395                                 mask = <0x01>;
396                                 value = <0x01>;
397                                 priority = <64>;
398                         };
399 
400                         led-controller@13 {
401                                 /*
402                                  * LEDs are controlled by CPLD firmware.
403                                  * All five LAN LEDs share common RGB settings
404                                  * and so it is not possible to set different
405                                  * colors on different LAN ports.
406                                  */
407                                 compatible = "cznic,turris1x-leds";
408                                 reg = <0x13 0x1d>;
409                                 #address-cells = <1>;
410                                 #size-cells = <0>;
411 
412                                 multi-led@0 {
413                                         reg = <0x0>;
414                                         color = <LED_COLOR_ID_RGB>;
415                                         function = LED_FUNCTION_WAN;
416                                 };
417 
418                                 multi-led@1 {
419                                         reg = <0x1>;
420                                         color = <LED_COLOR_ID_RGB>;
421                                         function = LED_FUNCTION_LAN;
422                                         function-enumerator = <5>;
423                                 };
424 
425                                 multi-led@2 {
426                                         reg = <0x2>;
427                                         color = <LED_COLOR_ID_RGB>;
428                                         function = LED_FUNCTION_LAN;
429                                         function-enumerator = <4>;
430                                 };
431 
432                                 multi-led@3 {
433                                         reg = <0x3>;
434                                         color = <LED_COLOR_ID_RGB>;
435                                         function = LED_FUNCTION_LAN;
436                                         function-enumerator = <3>;
437                                 };
438 
439                                 multi-led@4 {
440                                         reg = <0x4>;
441                                         color = <LED_COLOR_ID_RGB>;
442                                         function = LED_FUNCTION_LAN;
443                                         function-enumerator = <2>;
444                                 };
445 
446                                 multi-led@5 {
447                                         reg = <0x5>;
448                                         color = <LED_COLOR_ID_RGB>;
449                                         function = LED_FUNCTION_LAN;
450                                         function-enumerator = <1>;
451                                 };
452 
453                                 multi-led@6 {
454                                         reg = <0x6>;
455                                         color = <LED_COLOR_ID_RGB>;
456                                         function = LED_FUNCTION_WLAN;
457                                 };
458 
459                                 multi-led@7 {
460                                         reg = <0x7>;
461                                         color = <LED_COLOR_ID_RGB>;
462                                         function = LED_FUNCTION_POWER;
463                                 };
464                         };
465                 };
466         };
467 
468         pci2: pcie@ffe08000 {
469                 /*
470                  * PCIe bus for on-board TUSB7340RKM USB 3.0 xHCI controller.
471                  * This xHCI controller is available only on Turris 1.1 boards.
472                  * Turris 1.0 boards have nothing connected to this PCIe bus,
473                  * so system would see only PCIe Root Port of this PCIe Root
474                  * Complex. TUSB7340RKM xHCI controller has four SuperSpeed
475                  * channels. Channel 0 is connected to the front USB 3.0 port,
476                  * channel 1 (but only USB 2.0 subset) to USB 2.0 pins on mPCIe
477                  * slot 1 (CN5), channels 2 and 3 to connector P600.
478                  *
479                  * P2020 PCIe Root Port does not use PCIe MEM and xHCI controller
480                  * uses 64kB + 8kB of PCIe MEM. No PCIe IO is used or required.
481                  * So allocate 128kB of PCIe MEM for this PCIe bus.
482                  */
483                 reg = <0 0xffe08000 0 0x1000>;
484                 ranges = <0x02000000 0x0 0xc0000000 0 0xc0000000 0x0 0x00020000>, /* MEM */
485                          <0x01000000 0x0 0x00000000 0 0xffc20000 0x0 0x00010000>; /* IO */
486 
487                 pcie@0 {
488                         ranges;
489                 };
490         };
491 
492         pci1: pcie@ffe09000 {
493                 /* PCIe bus on mPCIe slot 2 (CN6) for expansion mPCIe card */
494                 reg = <0 0xffe09000 0 0x1000>;
495                 ranges = <0x02000000 0x0 0xa0000000 0 0xa0000000 0x0 0x20000000>, /* MEM */
496                          <0x01000000 0x0 0x00000000 0 0xffc10000 0x0 0x00010000>; /* IO */
497 
498                 pcie@0 {
499                         ranges;
500                 };
501         };
502 
503         pci0: pcie@ffe0a000 {
504                 /*
505                  * PCIe bus on mPCIe slot 1 (CN5) for expansion mPCIe card.
506                  * Turris 1.1 boards have in this mPCIe slot additional USB 2.0
507                  * pins via channel 1 of TUSB7340RKM xHCI controller and also
508                  * additional SIM card slot, both for USB-based WWAN cards.
509                  */
510                 reg = <0 0xffe0a000 0 0x1000>;
511                 ranges = <0x02000000 0x0 0x80000000 0 0x80000000 0x0 0x20000000>, /* MEM */
512                          <0x01000000 0x0 0x00000000 0 0xffc00000 0x0 0x00010000>; /* IO */
513 
514                 pcie@0 {
515                         ranges;
516                 };
517         };
518 };
519 
520 /include/ "fsl/p2020si-post.dtsi"

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php