Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/Linux/arch/powerpc/boot/dts/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 11 kB image not shown  

Quelle  turris1x.dts   Sprache: unbekannt

 
// SPDX-License-Identifier: GPL-2.0+
/*
 * Turris 1.x Device Tree Source
 *
 * Copyright 2013 - 2022 CZ.NIC z.s.p.o. (http://www.nic.cz/)
 *
 * Pinout, Schematics and Altium hardware design files are open source
 * and available at: https://docs.turris.cz/hw/turris-1x/turris-1x/
 */

#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/leds/common.h>
/include/ "fsl/p2020si-pre.dtsi"

/ {
 model = "Turris 1.x";
 compatible = "cznic,turris1x";

 aliases {
  ethernet0 = &enet0;
  ethernet1 = &enet1;
  ethernet2 = &enet2;
  serial0 = &serial0;
  serial1 = &serial1;
  pci0 = &pci0;
  pci1 = &pci1;
  pci2 = &pci2;
  spi0 = &spi0;
 };

 memory {
  device_type = "memory";
 };

 soc: soc@ffe00000 {
  ranges = <0x0 0x0 0xffe00000 0x00100000>;

  i2c@3000 {
   /* PCA9557PW GPIO controller for boot config */
   gpio-controller@18 {
    compatible = "nxp,pca9557";
    label = "bootcfg";
    reg = <0x18>;
    #gpio-cells = <2>;
    gpio-controller;
    polarity = <0x00>;
   };

   /* STM32F030R8T6 MCU for power control */
   power-control@2a {
    /*
     * Turris Power Control firmware runs on STM32F0 MCU.
     * This firmware is open source and available at:
     * https://gitlab.nic.cz/turris/hw/turris_power_control
     */
    reg = <0x2a>;
   };

   /* DDR3 SPD/EEPROM PSWP instruction */
   eeprom@32 {
    reg = <0x32>;
   };

   /* SA56004ED temperature control */
   temperature-sensor@4c {
    compatible = "nxp,sa56004";
    reg = <0x4c>;
    interrupt-parent = <&gpio>;
    interrupts = <12 IRQ_TYPE_LEVEL_LOW>, /* GPIO12 - ALERT pin */
          <13 IRQ_TYPE_LEVEL_LOW>; /* GPIO13 - CRIT pin */
    #address-cells = <1>;
    #size-cells = <0>;

    /* Local temperature sensor (SA56004ED internal) */
    channel@0 {
     reg = <0>;
     label = "board";
    };

    /* Remote temperature sensor (D+/D- connected to P2020 CPU Temperature Diode) */
    channel@1 {
     reg = <1>;
     label = "cpu";
    };
   };

   /* DDR3 SPD/EEPROM */
   eeprom@52 {
    compatible = "atmel,spd";
    reg = <0x52>;
   };

   /* MCP79402-I/ST Protected EEPROM */
   eeprom@57 {
    reg = <0x57>;
   };

   /* ATSHA204-TH-DA-T crypto module */
   crypto@64 {
    compatible = "atmel,atsha204";
    reg = <0x64>;
   };

   /* IDT6V49205BNLGI clock generator */
   clock-generator@69 {
    compatible = "idt,6v49205b";
    reg = <0x69>;
   };

   /* MCP79402-I/ST RTC */
   rtc@6f {
    compatible = "microchip,mcp7940x";
    reg = <0x6f>;
    interrupt-parent = <&gpio>;
    interrupts = <14 0>; /* GPIO14 - MFP pin */
   };
  };

  /* SPI on connector P1 */
  spi0: spi@7000 {
  };

  gpio: gpio-controller@fc00 {
   #interrupt-cells = <2>;
   interrupt-controller;
  };

  /* Connected to SMSC USB2412-DZK 2-Port USB 2.0 Hub Controller */
  usb@22000 {
   phy_type = "ulpi";
   dr_mode = "host";
  };

  enet0: ethernet@24000 {
   /* Connected to port 6 of QCA8337N-AL3C switch */
   phy-connection-type = "rgmii-id";

   fixed-link {
    speed = <1000>;
    full-duplex;
   };
  };

  mdio@24520 {
   /* KSZ9031RNXCA ethernet phy for WAN port */
   phy: ethernet-phy@7 {
    interrupts = <3 1 0 0>;
    reg = <0x7>;
   };

   /* QCA8337N-AL3C switch with integrated ethernet PHYs for LAN ports */
   switch@10 {
    compatible = "qca,qca8337";
    interrupts = <2 1 0 0>;
    reg = <0x10>;

    ports {
     #address-cells = <1>;
     #size-cells = <0>;

     port@0 {
      reg = <0>;
      label = "cpu";
      ethernet = <&enet1>;
      phy-mode = "rgmii-id";

      fixed-link {
       speed = <1000>;
       full-duplex;
      };
     };

     port@1 {
      reg = <1>;
      label = "lan5";
     };

     port@2 {
      reg = <2>;
      label = "lan4";
     };

     port@3 {
      reg = <3>;
      label = "lan3";
     };

     port@4 {
      reg = <4>;
      label = "lan2";
     };

     port@5 {
      reg = <5>;
      label = "lan1";
     };

     port@6 {
      reg = <6>;
      label = "cpu";
      ethernet = <&enet0>;
      phy-mode = "rgmii-id";

      fixed-link {
       speed = <1000>;
       full-duplex;
      };
     };
    };
   };
  };

  ptp_clock@24e00 {
   fsl,tclk-period = <5>;
   fsl,tmr-prsc = <200>;
   fsl,tmr-add = <0xcccccccd>;
   fsl,tmr-fiper1 = <0x3b9ac9fb>;
   fsl,tmr-fiper2 = <0x0001869b>;
   fsl,max-adj = <249999999>;
  };

  enet1: ethernet@25000 {
   /* Connected to port 0 of QCA8337N-AL3C switch */
   phy-connection-type = "rgmii-id";

   fixed-link {
    speed = <1000>;
    full-duplex;
   };
  };

  mdio@25520 {
   status = "disabled";
  };

  enet2: ethernet@26000 {
   /* Connected to KSZ9031RNXCA ethernet phy (WAN port) */
   label = "wan";
   phy-handle = <&phy>;
   phy-connection-type = "rgmii-id";
  };

  mdio@26520 {
   status = "disabled";
  };

  sdhc@2e000 {
   bus-width = <4>;
   cd-gpios = <&gpio 8 GPIO_ACTIVE_LOW>;
  };
 };

 lbc: localbus@ffe05000 {
  reg = <0 0xffe05000 0 0x1000>;

  ranges = <0x0 0x0 0x0 0xef000000 0x01000000>, /* NOR */
    <0x1 0x0 0x0 0xff800000 0x00040000>, /* NAND */
    <0x3 0x0 0x0 0xffa00000 0x00020000>; /* CPLD */

  /* S29GL128P90TFIR10 NOR */
  nor@0,0 {
   compatible = "cfi-flash";
   reg = <0x0 0x0 0x01000000>;
   bank-width = <2>;
   device-width = <1>;

   partitions {
    compatible = "fixed-partitions";
    #address-cells = <1>;
    #size-cells = <1>;

    partition@0 {
     /* 128 kB for Device Tree Blob */
     reg = <0x00000000 0x00020000>;
     label = "dtb";
    };

    partition@20000 {
     /* 1.7 MB for Linux Kernel Image */
     reg = <0x00020000 0x001a0000>;
     label = "kernel";
    };

    partition@1c0000 {
     /* 1.5 MB for Rescue JFFS2 Root File System */
     reg = <0x001c0000 0x00180000>;
     label = "rescue";
    };

    partition@340000 {
     /* 11 MB for TAR.XZ Archive with Factory content of NAND Root File System */
     reg = <0x00340000 0x00b00000>;
     label = "factory";
    };

    partition@e40000 {
     /* 768 kB for Certificates JFFS2 File System */
     reg = <0x00e40000 0x000c0000>;
     label = "certificates";
    };

    /* free unused space 0x00f00000-0x00f20000 */

    partition@f20000 {
     /* 128 kB for U-Boot Environment Variables */
     reg = <0x00f20000 0x00020000>;
     label = "u-boot-env";
    };

    partition@f40000 {
     /* 768 kB for U-Boot Bootloader Image */
     reg = <0x00f40000 0x000c0000>;
     label = "u-boot";
    };
   };
  };

  /* MT29F2G08ABAEAWP:E NAND */
  nand@1,0 {
   compatible = "fsl,p2020-fcm-nand", "fsl,elbc-fcm-nand";
   reg = <0x1 0x0 0x00040000>;
   nand-ecc-mode = "soft";
   nand-ecc-algo = "bch";

   partitions {
    compatible = "fixed-partitions";
    #address-cells = <1>;
    #size-cells = <1>;

    partition@0 {
     /* 256 MB for UBI with one volume: UBIFS Root File System */
     reg = <0x00000000 0x10000000>;
     label = "rootfs";
    };
   };
  };

  /* LCMXO1200C-3FTN256C FPGA */
  cpld@3,0 {
   /*
    * Turris CPLD firmware which runs on this Lattice FPGA,
    * is extended version of P1021RDB-PC CPLD v4.1 firmware.
    * It is backward compatible with its original version
    * and the only extension is support for Turris LEDs.
    * Turris CPLD firmware is open source and available at:
    * https://gitlab.nic.cz/turris/hw/turris_cpld/-/blob/master/CZ_NIC_Router_CPLD.v
    */
   compatible = "cznic,turris1x-cpld", "fsl,p1021rdb-pc-cpld", "simple-bus", "syscon";
   reg = <0x3 0x0 0x30>;
   #address-cells = <1>;
   #size-cells = <1>;
   ranges = <0x0 0x3 0x0 0x00020000>;

   /* MAX6370KA+T watchdog */
   watchdog@2 {
    /*
     * CPLD firmware maps SET0, SET1 and SET2
     * input logic of MAX6370KA+T chip to CPLD
     * memory space at byte offset 0x2. WDI
     * input logic is outside of the CPLD and
     * connected via external GPIO.
     */
    compatible = "maxim,max6370";
    reg = <0x02 0x01>;
    gpios = <&gpio 11 GPIO_ACTIVE_LOW>;
   };

   reboot@d {
    /*
     * CPLD firmware which manages system reset and
     * watchdog registers has bugs. It does not
     * autoclear system reset register after change
     * and watchdog ignores reset line on immediate
     * succeeding reset cycle triggered by watchdog.
     * These bugs have to be workarounded in U-Boot
     * bootloader. So use system reset via syscon as
     * a last resort because older U-Boot versions
     * do not have workaround for watchdog.
     *
     * Reset method via rstcr's global-utilities
     * (the preferred one) has priority level 128,
     * watchdog has priority level 0 and default
     * syscon-reboot priority level is 192.
     *
     * So define syscon-reboot with custom priority
     * level 64 (between rstcr and watchdog) because
     * rstcr should stay as default preferred reset
     * method and reset via watchdog is more broken
     * than system reset via syscon.
     */
    compatible = "syscon-reboot";
    reg = <0x0d 0x01>;
    offset = <0x0d>;
    mask = <0x01>;
    value = <0x01>;
    priority = <64>;
   };

   led-controller@13 {
    /*
     * LEDs are controlled by CPLD firmware.
     * All five LAN LEDs share common RGB settings
     * and so it is not possible to set different
     * colors on different LAN ports.
     */
    compatible = "cznic,turris1x-leds";
    reg = <0x13 0x1d>;
    #address-cells = <1>;
    #size-cells = <0>;

    multi-led@0 {
     reg = <0x0>;
     color = <LED_COLOR_ID_RGB>;
     function = LED_FUNCTION_WAN;
    };

    multi-led@1 {
     reg = <0x1>;
     color = <LED_COLOR_ID_RGB>;
     function = LED_FUNCTION_LAN;
     function-enumerator = <5>;
    };

    multi-led@2 {
     reg = <0x2>;
     color = <LED_COLOR_ID_RGB>;
     function = LED_FUNCTION_LAN;
     function-enumerator = <4>;
    };

    multi-led@3 {
     reg = <0x3>;
     color = <LED_COLOR_ID_RGB>;
     function = LED_FUNCTION_LAN;
     function-enumerator = <3>;
    };

    multi-led@4 {
     reg = <0x4>;
     color = <LED_COLOR_ID_RGB>;
     function = LED_FUNCTION_LAN;
     function-enumerator = <2>;
    };

    multi-led@5 {
     reg = <0x5>;
     color = <LED_COLOR_ID_RGB>;
     function = LED_FUNCTION_LAN;
     function-enumerator = <1>;
    };

    multi-led@6 {
     reg = <0x6>;
     color = <LED_COLOR_ID_RGB>;
     function = LED_FUNCTION_WLAN;
    };

    multi-led@7 {
     reg = <0x7>;
     color = <LED_COLOR_ID_RGB>;
     function = LED_FUNCTION_POWER;
    };
   };
  };
 };

 pci2: pcie@ffe08000 {
  /*
   * PCIe bus for on-board TUSB7340RKM USB 3.0 xHCI controller.
   * This xHCI controller is available only on Turris 1.1 boards.
   * Turris 1.0 boards have nothing connected to this PCIe bus,
   * so system would see only PCIe Root Port of this PCIe Root
   * Complex. TUSB7340RKM xHCI controller has four SuperSpeed
   * channels. Channel 0 is connected to the front USB 3.0 port,
   * channel 1 (but only USB 2.0 subset) to USB 2.0 pins on mPCIe
   * slot 1 (CN5), channels 2 and 3 to connector P600.
   *
   * P2020 PCIe Root Port does not use PCIe MEM and xHCI controller
   * uses 64kB + 8kB of PCIe MEM. No PCIe IO is used or required.
   * So allocate 128kB of PCIe MEM for this PCIe bus.
   */
  reg = <0 0xffe08000 0 0x1000>;
  ranges = <0x02000000 0x0 0xc0000000 0 0xc0000000 0x0 0x00020000>, /* MEM */
    <0x01000000 0x0 0x00000000 0 0xffc20000 0x0 0x00010000>; /* IO */

  pcie@0 {
   ranges;
  };
 };

 pci1: pcie@ffe09000 {
  /* PCIe bus on mPCIe slot 2 (CN6) for expansion mPCIe card */
  reg = <0 0xffe09000 0 0x1000>;
  ranges = <0x02000000 0x0 0xa0000000 0 0xa0000000 0x0 0x20000000>, /* MEM */
    <0x01000000 0x0 0x00000000 0 0xffc10000 0x0 0x00010000>; /* IO */

  pcie@0 {
   ranges;
  };
 };

 pci0: pcie@ffe0a000 {
  /*
   * PCIe bus on mPCIe slot 1 (CN5) for expansion mPCIe card.
   * Turris 1.1 boards have in this mPCIe slot additional USB 2.0
   * pins via channel 1 of TUSB7340RKM xHCI controller and also
   * additional SIM card slot, both for USB-based WWAN cards.
   */
  reg = <0 0xffe0a000 0 0x1000>;
  ranges = <0x02000000 0x0 0x80000000 0 0x80000000 0x0 0x20000000>, /* MEM */
    <0x01000000 0x0 0x00000000 0 0xffc00000 0x0 0x00010000>; /* IO */

  pcie@0 {
   ranges;
  };
 };
};

/include/ "fsl/p2020si-post.dtsi"

[ Dauer der Verarbeitung: 0.3 Sekunden  (vorverarbeitet)  ]