| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 |
- // SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
- /*
- * Copyright 2020-2022 Advanced Micro Devices, Inc.
- */
- #include <dt-bindings/gpio/gpio.h>
- #include "dt-bindings/interrupt-controller/arm-gic.h"
- / {
- model = "Elba ASIC Board";
- compatible = "amd,pensando-elba";
- interrupt-parent = <&gic>;
- #address-cells = <2>;
- #size-cells = <2>;
- dma-coherent;
- ahb_clk: oscillator0 {
- compatible = "fixed-clock";
- #clock-cells = <0>;
- };
- emmc_clk: oscillator2 {
- compatible = "fixed-clock";
- #clock-cells = <0>;
- };
- flash_clk: oscillator3 {
- compatible = "fixed-clock";
- #clock-cells = <0>;
- };
- ref_clk: oscillator4 {
- compatible = "fixed-clock";
- #clock-cells = <0>;
- };
- psci {
- compatible = "arm,psci-0.2";
- method = "smc";
- };
- timer {
- compatible = "arm,armv8-timer";
- interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>,
- <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>,
- <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>,
- <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>;
- };
- pmu {
- compatible = "arm,cortex-a72-pmu";
- interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_LOW>;
- };
- soc: soc {
- compatible = "simple-bus";
- #address-cells = <2>;
- #size-cells = <2>;
- ranges;
- i2c0: i2c@400 {
- compatible = "snps,designware-i2c";
- reg = <0x0 0x400 0x0 0x100>;
- clocks = <&ahb_clk>;
- #address-cells = <1>;
- #size-cells = <0>;
- i2c-sda-hold-time-ns = <480>;
- interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
- status = "disabled";
- };
- wdt0: watchdog@1400 {
- compatible = "snps,dw-wdt";
- reg = <0x0 0x1400 0x0 0x100>;
- clocks = <&ahb_clk>;
- interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
- status = "disabled";
- };
- qspi: spi@2400 {
- compatible = "amd,pensando-elba-qspi", "cdns,qspi-nor";
- reg = <0x0 0x2400 0x0 0x400>,
- <0x0 0x7fff0000 0x0 0x1000>;
- #address-cells = <1>;
- #size-cells = <0>;
- interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
- clocks = <&flash_clk>;
- cdns,fifo-depth = <1024>;
- cdns,fifo-width = <4>;
- cdns,trigger-address = <0x7fff0000>;
- status = "disabled";
- };
- spi0: spi@2800 {
- compatible = "amd,pensando-elba-spi";
- reg = <0x0 0x2800 0x0 0x100>;
- #address-cells = <1>;
- #size-cells = <0>;
- amd,pensando-elba-syscon = <&syscon>;
- clocks = <&ahb_clk>;
- interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
- num-cs = <2>;
- status = "disabled";
- };
- gpio0: gpio@4000 {
- compatible = "snps,dw-apb-gpio";
- reg = <0x0 0x4000 0x0 0x78>;
- #address-cells = <1>;
- #size-cells = <0>;
- status = "disabled";
- porta: gpio-port@0 {
- compatible = "snps,dw-apb-gpio-port";
- reg = <0>;
- gpio-controller;
- #gpio-cells = <2>;
- ngpios = <8>;
- interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
- interrupt-controller;
- interrupt-parent = <&gic>;
- #interrupt-cells = <2>;
- };
- portb: gpio-port@1 {
- compatible = "snps,dw-apb-gpio-port";
- reg = <1>;
- gpio-controller;
- #gpio-cells = <2>;
- ngpios = <8>;
- };
- };
- uart0: serial@4800 {
- compatible = "ns16550a";
- reg = <0x0 0x4800 0x0 0x100>;
- clocks = <&ref_clk>;
- interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
- reg-shift = <2>;
- reg-io-width = <4>;
- };
- gic: interrupt-controller@800000 {
- compatible = "arm,gic-v3";
- reg = <0x0 0x800000 0x0 0x200000>, /* GICD */
- <0x0 0xa00000 0x0 0x200000>, /* GICR */
- <0x0 0x60000000 0x0 0x2000>, /* GICC */
- <0x0 0x60010000 0x0 0x1000>, /* GICH */
- <0x0 0x60020000 0x0 0x2000>; /* GICV */
- #address-cells = <2>;
- #size-cells = <2>;
- #interrupt-cells = <3>;
- ranges;
- interrupt-controller;
- interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
- /*
- * Elba specific pre-ITS is enabled using the
- * existing property socionext,synquacer-pre-its
- */
- gic_its: msi-controller@820000 {
- compatible = "arm,gic-v3-its";
- reg = <0x0 0x820000 0x0 0x10000>;
- msi-controller;
- #msi-cells = <1>;
- socionext,synquacer-pre-its =
- <0xc00000 0x1000000>;
- };
- };
- emmc: mmc@30440000 {
- compatible = "amd,pensando-elba-sd4hc", "cdns,sd4hc";
- reg = <0x0 0x30440000 0x0 0x10000>,
- <0x0 0x30480044 0x0 0x4>; /* byte-lane ctrl */
- clocks = <&emmc_clk>;
- interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
- cdns,phy-input-delay-sd-highspeed = <0x4>;
- cdns,phy-input-delay-legacy = <0x4>;
- cdns,phy-input-delay-sd-uhs-sdr50 = <0x6>;
- cdns,phy-input-delay-sd-uhs-ddr50 = <0x16>;
- mmc-ddr-1_8v;
- status = "disabled";
- };
- syscon: syscon@307c0000 {
- compatible = "amd,pensando-elba-syscon", "syscon";
- reg = <0x0 0x307c0000 0x0 0x3000>;
- };
- };
- };
|