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

Quelle  armada-ap80x.dtsi   Sprache: unbekannt

 
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
/*
 * Copyright (C) 2019 Marvell Technology Group Ltd.
 *
 * Device Tree file for Marvell Armada AP80x.
 */

#include <dt-bindings/interrupt-controller/arm-gic.h>
#include <dt-bindings/thermal/thermal.h>

/dts-v1/;

/ {
 #address-cells = <2>;
 #size-cells = <2>;

 aliases {
  serial0 = &uart0;
  serial1 = &uart1;
  gpio0 = &ap_gpio;
  spi0 = &spi0;
 };

 psci {
  compatible = "arm,psci-0.2";
  method = "smc";
 };

 reserved-memory {
  #address-cells = <2>;
  #size-cells = <2>;
  ranges;

  /*
   * This area matches the mapping done with a
   * mainline U-Boot, and should be updated by the
   * bootloader.
   */

  psci-area@4000000 {
   reg = <0x0 0x4000000 0x0 0x200000>;
   no-map;
  };

  tee@4400000 {
   reg = <0 0x4400000 0 0x1000000>;
   no-map;
  };
 };

 timer {
  compatible = "arm,armv8-timer";
  interrupt-parent = <&gic>;
  interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
    <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
    <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
    <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
 };

 pmu {
  compatible = "arm,cortex-a72-pmu";
  interrupt-parent = <&pic>;
  interrupts = <17>;
 };

 soc {
  #address-cells = <2>;
  #size-cells = <2>;
  compatible = "simple-bus";
  interrupt-parent = <&gic>;
  ranges;

  bus@f0000000 {
   #address-cells = <1>;
   #size-cells = <1>;
   compatible = "simple-bus";
   ranges = <0x0 0x0 0xf0000000 0x1000000>;

   smmu: iommu@100000 {
    compatible = "marvell,ap806-smmu-500", "arm,mmu-500";
    reg = <0x100000 0x100000>;
    dma-coherent;
    #iommu-cells = <1>;
    #global-interrupts = <1>;
    interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
          <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
          <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
          <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
          <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
          <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
          <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
          <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
          <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
    status = "disabled";
   };

   gic: interrupt-controller@210000 {
    compatible = "arm,gic-400";
    #interrupt-cells = <3>;
    #address-cells = <1>;
    #size-cells = <1>;
    ranges;
    interrupt-controller;
    interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
    reg = <0x210000 0x10000>,
          <0x220000 0x20000>,
          <0x240000 0x20000>,
          <0x260000 0x20000>;

    gic_v2m0: v2m@280000 {
     compatible = "arm,gic-v2m-frame";
     msi-controller;
     reg = <0x280000 0x1000>;
     arm,msi-base-spi = <160>;
     arm,msi-num-spis = <32>;
    };
    gic_v2m1: v2m@290000 {
     compatible = "arm,gic-v2m-frame";
     msi-controller;
     reg = <0x290000 0x1000>;
     arm,msi-base-spi = <192>;
     arm,msi-num-spis = <32>;
    };
    gic_v2m2: v2m@2a0000 {
     compatible = "arm,gic-v2m-frame";
     msi-controller;
     reg = <0x2a0000 0x1000>;
     arm,msi-base-spi = <224>;
     arm,msi-num-spis = <32>;
    };
    gic_v2m3: v2m@2b0000 {
     compatible = "arm,gic-v2m-frame";
     msi-controller;
     reg = <0x2b0000 0x1000>;
     arm,msi-base-spi = <256>;
     arm,msi-num-spis = <32>;
    };
   };

   odmi: odmi@300000 {
    compatible = "marvell,odmi-controller";
    msi-controller;
    marvell,odmi-frames = <4>;
    reg = <0x300000 0x4000>,
          <0x304000 0x4000>,
          <0x308000 0x4000>,
          <0x30C000 0x4000>;
    marvell,spi-base = <128>, <136>, <144>, <152>;
   };

   gicp: gicp@3f0040 {
    compatible = "marvell,ap806-gicp";
    reg = <0x3f0040 0x10>;
    marvell,spi-ranges = <64 64>, <288 64>;
    msi-controller;
   };

   pic: interrupt-controller@3f0100 {
    compatible = "marvell,armada-8k-pic";
    reg = <0x3f0100 0x10>;
    #interrupt-cells = <1>;
    interrupt-controller;
    interrupts = <GIC_PPI 15 IRQ_TYPE_LEVEL_HIGH>;
   };

   sei: interrupt-controller@3f0200 {
    compatible = "marvell,ap806-sei";
    reg = <0x3f0200 0x40>;
    interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
    #interrupt-cells = <1>;
    interrupt-controller;
    msi-controller;
   };

   xor@400000 {
    compatible = "marvell,armada-7k-xor", "marvell,xor-v2";
    reg = <0x400000 0x1000>,
          <0x410000 0x1000>;
    msi-parent = <&gic_v2m0>;
    clocks = <&ap_clk 3>;
    dma-coherent;
   };

   xor@420000 {
    compatible = "marvell,armada-7k-xor", "marvell,xor-v2";
    reg = <0x420000 0x1000>,
          <0x430000 0x1000>;
    msi-parent = <&gic_v2m0>;
    clocks = <&ap_clk 3>;
    dma-coherent;
   };

   xor@440000 {
    compatible = "marvell,armada-7k-xor", "marvell,xor-v2";
    reg = <0x440000 0x1000>,
          <0x450000 0x1000>;
    msi-parent = <&gic_v2m0>;
    clocks = <&ap_clk 3>;
    dma-coherent;
   };

   xor@460000 {
    compatible = "marvell,armada-7k-xor", "marvell,xor-v2";
    reg = <0x460000 0x1000>,
          <0x470000 0x1000>;
    msi-parent = <&gic_v2m0>;
    clocks = <&ap_clk 3>;
    dma-coherent;
   };

   spi0: spi@510600 {
    compatible = "marvell,armada-380-spi";
    reg = <0x510600 0x50>;
    #address-cells = <1>;
    #size-cells = <0>;
    interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
    clocks = <&ap_clk 3>;
    status = "disabled";
   };

   i2c0: i2c@511000 {
    compatible = "marvell,mv78230-i2c";
    reg = <0x511000 0x20>;
    #address-cells = <1>;
    #size-cells = <0>;
    interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
    clocks = <&ap_clk 3>;
    status = "disabled";
   };

   uart0: serial@512000 {
    compatible = "snps,dw-apb-uart";
    reg = <0x512000 0x100>;
    reg-shift = <2>;
    interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
    reg-io-width = <1>;
    clocks = <&ap_clk 3>;
    status = "disabled";
   };

   uart1: serial@512100 {
    compatible = "snps,dw-apb-uart";
    reg = <0x512100 0x100>;
    reg-shift = <2>;
    interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
    reg-io-width = <1>;
    clocks = <&ap_clk 3>;
    status = "disabled";

   };

   watchdog: watchdog@610000 {
    compatible = "arm,sbsa-gwdt";
    reg = <0x610000 0x1000>, <0x600000 0x1000>;
    interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
   };

   ap_sdhci0: mmc@6e0000 {
    compatible = "marvell,armada-ap806-sdhci";
    reg = <0x6e0000 0x300>;
    interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
    clock-names = "core";
    clocks = <&ap_clk 4>;
    dma-coherent;
    marvell,xenon-phy-slow-mode;
    status = "disabled";
   };

   ap_syscon0: system-controller@6f4000 {
    compatible = "syscon", "simple-mfd";
    reg = <0x6f4000 0x2000>;

    ap_pinctrl: pinctrl {
     compatible = "marvell,ap806-pinctrl";

     uart0_pins: uart0-pins {
      marvell,pins = "mpp11", "mpp19";
      marvell,function = "uart0";
     };
    };

    ap_gpio: gpio@1040 {
     compatible = "marvell,armada-8k-gpio";
     offset = <0x1040>;
     ngpios = <20>;
     gpio-controller;
     #gpio-cells = <2>;
     gpio-ranges = <&ap_pinctrl 0 0 20>;
     marvell,pwm-offset = <0x10c0>;
     #pwm-cells = <2>;
     clocks = <&ap_clk 3>;
    };
   };

   ap_syscon1: system-controller@6f8000 {
    compatible = "syscon", "simple-mfd";
    reg = <0x6f8000 0x1000>;
    #address-cells = <1>;
    #size-cells = <1>;

    ap_thermal: thermal-sensor@80 {
     compatible = "marvell,armada-ap806-thermal";
     reg = <0x80 0x10>;
     interrupt-parent = <&sei>;
     interrupts = <18>;
     #thermal-sensor-cells = <1>;
    };
   };
  };
 };

 /*
  * The thermal IP features one internal sensor plus, if applicable, one
  * remote channel wired to one sensor per CPU.
  *
  * Only one thermal zone per AP/CP may trigger interrupts at a time, the
  * first one that will have a critical trip point will be chosen.
  */
 thermal-zones {
  ap_thermal_ic: ap-ic-thermal {
   polling-delay-passive = <0>; /* Interrupt driven */
   polling-delay = <0>; /* Interrupt driven */

   thermal-sensors = <&ap_thermal 0>;

   trips {
    ap_crit: ap-crit {
     temperature = <100000>; /* mC degrees */
     hysteresis = <2000>; /* mC degrees */
     type = "critical";
    };
   };

   cooling-maps { };
  };

  ap_thermal_cpu0: ap-cpu0-thermal {
   polling-delay-passive = <1000>;
   polling-delay = <1000>;

   thermal-sensors = <&ap_thermal 1>;

   trips {
    cpu0_hot: cpu0-hot {
     temperature = <85000>;
     hysteresis = <2000>;
     type = "passive";
    };
    cpu0_emerg: cpu0-emerg {
     temperature = <95000>;
     hysteresis = <2000>;
     type = "passive";
    };
   };

   cooling-maps {
    map0_hot: map0-hot {
     trip = <&cpu0_hot>;
     cooling-device = <&cpu0 1 2>,
      <&cpu1 1 2>;
    };
    map0_emerg: map0-ermerg {
     trip = <&cpu0_emerg>;
     cooling-device = <&cpu0 3 3>,
      <&cpu1 3 3>;
    };
   };
  };

  ap_thermal_cpu1: ap-cpu1-thermal {
   polling-delay-passive = <1000>;
   polling-delay = <1000>;

   thermal-sensors = <&ap_thermal 2>;

   trips {
    cpu1_hot: cpu1-hot {
     temperature = <85000>;
     hysteresis = <2000>;
     type = "passive";
    };
    cpu1_emerg: cpu1-emerg {
     temperature = <95000>;
     hysteresis = <2000>;
     type = "passive";
    };
   };

   cooling-maps {
    map1_hot: map1-hot {
     trip = <&cpu1_hot>;
     cooling-device = <&cpu0 1 2>,
      <&cpu1 1 2>;
    };
    map1_emerg: map1-emerg {
     trip = <&cpu1_emerg>;
     cooling-device = <&cpu0 3 3>,
      <&cpu1 3 3>;
    };
   };
  };

  ap_thermal_cpu2: ap-cpu2-thermal {
   polling-delay-passive = <1000>;
   polling-delay = <1000>;

   thermal-sensors = <&ap_thermal 3>;

   trips {
    cpu2_hot: cpu2-hot {
     temperature = <85000>;
     hysteresis = <2000>;
     type = "passive";
    };
    cpu2_emerg: cpu2-emerg {
     temperature = <95000>;
     hysteresis = <2000>;
     type = "passive";
    };
   };

   cooling-maps {
    map2_hot: map2-hot {
     trip = <&cpu2_hot>;
     cooling-device = <&cpu2 1 2>,
      <&cpu3 1 2>;
    };
    map2_emerg: map2-emerg {
     trip = <&cpu2_emerg>;
     cooling-device = <&cpu2 3 3>,
      <&cpu3 3 3>;
    };
   };
  };

  ap_thermal_cpu3: ap-cpu3-thermal {
   polling-delay-passive = <1000>;
   polling-delay = <1000>;

   thermal-sensors = <&ap_thermal 4>;

   trips {
    cpu3_hot: cpu3-hot {
     temperature = <85000>;
     hysteresis = <2000>;
     type = "passive";
    };
    cpu3_emerg: cpu3-emerg {
     temperature = <95000>;
     hysteresis = <2000>;
     type = "passive";
    };
   };

   cooling-maps {
    map3_hot: map3-bhot {
     trip = <&cpu3_hot>;
     cooling-device = <&cpu2 1 2>,
      <&cpu3 1 2>;
    };
    map3_emerg: map3-emerg {
     trip = <&cpu3_emerg>;
     cooling-device = <&cpu2 3 3>,
      <&cpu3 3 3>;
    };
   };
  };
 };
};

[ Dauer der Verarbeitung: 0.17 Sekunden  (vorverarbeitet)  ]