| // SPDX-License-Identifier: (GPL-2.0-or-later OR MIT) |
| /* |
| * Device Tree file for Ctera C200-V2 |
| * |
| * Copyright (C) 2022 Pawel Dembicki <paweldembicki@gmail.com> |
| */ |
| |
| /dts-v1/; |
| |
| #include "armada-370.dtsi" |
| #include <dt-bindings/gpio/gpio.h> |
| #include <dt-bindings/input/input.h> |
| #include <dt-bindings/thermal/thermal.h> |
| #include <dt-bindings/leds/common.h> |
| |
| / { |
| model = "Ctera C200 V2"; |
| compatible = "ctera,c200-v2", "marvell,armada370", "marvell,armada-370-xp"; |
| |
| chosen { |
| bootargs = "console=ttyS0,115200"; |
| stdout-path = "serial0:115200n8"; |
| }; |
| |
| memory { |
| device_type = "memory"; |
| reg = <0x00000000 0x40000000>; /* 1024 MB */ |
| }; |
| |
| soc { |
| ranges = <MBUS_ID(0xf0, 0x01) 0 0xd0000000 0x100000 |
| MBUS_ID(0x01, 0xe0) 0 0xfff00000 0x100000 |
| MBUS_ID(0x09, 0x01) 0 0xf1100000 0x10000>; |
| }; |
| |
| thermal-zones { |
| ethphy-thermal { |
| polling-delay = <20000>; |
| polling-delay-passive = <2000>; |
| |
| thermal-sensors = <ðphy0>; |
| |
| trips { |
| ethphy_alert1: trip1 { |
| temperature = <65000>; |
| hysteresis = <4000>; |
| type = "passive"; |
| }; |
| |
| ethphy_crit: trip2 { |
| temperature = <100000>; |
| hysteresis = <2000>; |
| type = "critical"; |
| }; |
| }; |
| }; |
| }; |
| |
| beeper { |
| compatible = "pwm-beeper"; |
| pinctrl-0 = <&pmx_beeper>; |
| pinctrl-names = "default"; |
| pwms = <&gpio1 31 4000>; |
| }; |
| |
| gpio-poweroff { |
| compatible = "gpio-poweroff"; |
| pinctrl-0 = <&pmx_poweroff>; |
| pinctrl-names = "default"; |
| gpios = <&gpio0 7 GPIO_ACTIVE_HIGH>; |
| }; |
| |
| keys { |
| compatible = "gpio-keys"; |
| pinctrl-0 = <&pmx_buttons>; |
| pinctrl-names = "default"; |
| |
| button-power { |
| label = "Power Button"; |
| linux,code = <KEY_POWER>; |
| gpios = <&gpio0 10 GPIO_ACTIVE_HIGH>; |
| }; |
| |
| button-reset { |
| label = "Reset Button"; |
| linux,code = <KEY_RESTART>; |
| gpios = <&gpio0 6 GPIO_ACTIVE_LOW>; |
| }; |
| |
| button-usb1 { |
| label = "USB1 Button"; |
| linux,code = <BTN_0>; |
| gpios = <&gpio1 0 GPIO_ACTIVE_LOW>; |
| }; |
| |
| button-usb2 { |
| label = "USB2 Button"; |
| linux,code = <BTN_1>; |
| gpios = <&gpio0 14 GPIO_ACTIVE_LOW>; |
| }; |
| }; |
| |
| leds { |
| compatible = "gpio-leds"; |
| pinctrl-0 = <&pmx_leds1 &pmx_leds2>; |
| pinctrl-names = "default"; |
| |
| led-0 { |
| function = LED_FUNCTION_USB; |
| function-enumerator = <2>; |
| color = <LED_COLOR_ID_RED>; |
| gpios = <&gpio0 12 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-1 { |
| function = LED_FUNCTION_USB; |
| function-enumerator = <2>; |
| color = <LED_COLOR_ID_GREEN>; |
| gpios = <&gpio0 13 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-2 { |
| function = LED_FUNCTION_USB; |
| function-enumerator = <1>; |
| color = <LED_COLOR_ID_RED>; |
| gpios = <&gpio0 15 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-3 { |
| function = LED_FUNCTION_USB; |
| function-enumerator = <1>; |
| color = <LED_COLOR_ID_GREEN>; |
| gpios = <&gpio0 16 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-4 { |
| function = LED_FUNCTION_DISK; |
| function-enumerator = <2>; |
| color = <LED_COLOR_ID_GREEN>; |
| gpios = <&gpio1 15 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-5 { |
| function = LED_FUNCTION_DISK; |
| function-enumerator = <1>; |
| color = <LED_COLOR_ID_RED>; |
| gpios = <&gpio1 18 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-6 { |
| function = LED_FUNCTION_DISK; |
| function-enumerator = <2>; |
| color = <LED_COLOR_ID_RED>; |
| gpios = <&gpio1 19 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-7 { |
| function = LED_FUNCTION_INDICATOR; |
| color = <LED_COLOR_ID_BLUE>; |
| gpios = <&gpio1 20 GPIO_ACTIVE_HIGH>; |
| }; |
| |
| led-8 { |
| function = LED_FUNCTION_DISK_ERR; |
| color = <LED_COLOR_ID_RED>; |
| gpios = <&gpio1 21 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-9 { |
| function = LED_FUNCTION_DISK_ERR; |
| color = <LED_COLOR_ID_GREEN>; |
| gpios = <&gpio1 23 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-10 { |
| function = LED_FUNCTION_STATUS; |
| color = <LED_COLOR_ID_RED>; |
| gpios = <&gpio1 24 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-11 { |
| function = LED_FUNCTION_DISK; |
| function-enumerator = <1>; |
| color = <LED_COLOR_ID_GREEN>; |
| gpios = <&gpio1 25 GPIO_ACTIVE_LOW>; |
| }; |
| |
| led-12 { |
| function = LED_FUNCTION_STATUS; |
| color = <LED_COLOR_ID_GREEN>; |
| gpios = <&gpio1 26 GPIO_ACTIVE_LOW>; |
| }; |
| }; |
| }; |
| |
| &coherencyfab { |
| broken-idle; |
| }; |
| |
| ð1 { |
| pinctrl-0 = <&ge1_rgmii_pins>; |
| pinctrl-names = "default"; |
| status = "okay"; |
| phy-handle = <ðphy0>; |
| phy-connection-type = "rgmii-id"; |
| }; |
| |
| &i2c0 { |
| pinctrl-0 = <&i2c0_pins>; |
| pinctrl-names = "default"; |
| clock-frequency = <100000>; |
| status = "okay"; |
| |
| hwmon@2a { |
| compatible = "nuvoton,nct7802"; |
| reg = <0x2a>; |
| }; |
| |
| rtc@30 { |
| compatible = "sii,s35390a"; |
| reg = <0x30>; |
| }; |
| }; |
| |
| &mdio { |
| pinctrl-0 = <&mdio_pins>; |
| pinctrl-names = "default"; |
| |
| ethphy0: ethernet-phy@0 { /* Marvell 88E1318 */ |
| reg = <0>; |
| #thermal-sensor-cells = <0>; |
| }; |
| }; |
| |
| &nand_controller { |
| status = "okay"; |
| |
| nand@0 { |
| reg = <0>; |
| label = "pxa3xx_nand-0"; |
| nand-rb = <0>; |
| marvell,nand-keep-config; |
| nand-on-flash-bbt; |
| nand-ecc-strength = <4>; |
| nand-ecc-step-size = <512>; |
| |
| partitions { |
| compatible = "fixed-partitions"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| |
| partition@0 { |
| label = "uboot"; |
| reg = <0x0000000 0x200000>; |
| read-only; |
| }; |
| |
| partition@200000 { |
| label = "certificate"; |
| reg = <0x0200000 0x100000>; |
| read-only; |
| }; |
| |
| partition@300000 { |
| label = "preset_cfg"; |
| reg = <0x0300000 0x100000>; |
| read-only; |
| }; |
| |
| partition@400000 { |
| label = "dev_params"; |
| reg = <0x0400000 0x100000>; |
| read-only; |
| }; |
| partition@500000 { |
| label = "active_bank"; |
| reg = <0x0500000 0x0100000>; |
| }; |
| |
| partition@600000 { |
| label = "magic"; |
| reg = <0x0600000 0x0100000>; |
| read-only; |
| }; |
| |
| partition@700000 { |
| label = "bank1"; |
| reg = <0x0700000 0x2800000>; |
| }; |
| |
| partition@2f00000 { |
| label = "bank2"; |
| reg = <0x2f00000 0x2800000>; |
| }; |
| |
| /* 0x5700000-0x5a00000 undefined in vendor firmware */ |
| |
| partition@5a00000 { |
| label = "reserved"; |
| reg = <0x5a00000 0x2000000>; |
| }; |
| |
| partition@7a00000 { |
| label = "rootfs"; |
| reg = <0x7a00000 0x8600000>; |
| }; |
| }; |
| }; |
| }; |
| |
| &pciec { |
| status = "okay"; |
| |
| pcie@1,0 { /* Renesas uPD720202 USB 3.0 controller */ |
| pinctrl-0 = <&pmx_pcie>; |
| pinctrl-names = "default"; |
| status = "okay"; |
| reset-gpios = <&gpio1 27 GPIO_ACTIVE_LOW>; |
| }; |
| }; |
| |
| &pinctrl { |
| pmx_poweroff: pmx-poweroff { |
| marvell,pins = "mpp7"; |
| marvell,function = "gpo"; |
| }; |
| |
| pmx_power_cpu: pmx-power-cpu { |
| marvell,pins = "mpp4"; |
| marvell,function = "vdd"; |
| }; |
| |
| pmx_buttons: pmx-buttons { |
| marvell,pins = "mpp6", "mpp10", "mpp14", "mpp32"; |
| marvell,function = "gpio"; |
| }; |
| |
| pmx_leds1: pmx-leds1 { |
| marvell,pins = "mpp47"; |
| marvell,function = "gpo"; |
| }; |
| |
| pmx_leds2: pmx-leds2 { |
| marvell,pins = "mpp12", "mpp13", "mpp15", "mpp16", "mpp50", "mpp51", |
| "mpp52", "mpp53", "mpp55", "mpp56", "mpp57", "mpp58"; |
| marvell,function = "gpio"; |
| }; |
| |
| pmx_pcie: pmx-pcie { |
| marvell,pins = "mpp59"; |
| marvell,function = "gpio"; |
| }; |
| |
| pmx_beeper: pmx-beeper { |
| marvell,pins = "mpp63"; |
| marvell,function = "gpio"; |
| }; |
| }; |
| |
| &pmsu { |
| pinctrl-0 = <&pmx_power_cpu>; |
| pinctrl-names = "default"; |
| }; |
| |
| &rtc { |
| status = "disabled"; |
| }; |
| |
| &sata { |
| nr-ports = <2>; |
| status = "okay"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| hdd0_temp: sata-port@0 { |
| reg = <0>; |
| #thermal-sensor-cells = <0>; |
| }; |
| |
| hdd1_temp: sata-port@1 { |
| reg = <1>; |
| #thermal-sensor-cells = <0>; |
| }; |
| }; |
| |
| &uart0 { |
| status = "okay"; |
| }; |