From: Gregory CLEMENT <gregory.clement@bootlin.com>
To: Pawel Dembicki <paweldembicki@gmail.com>,
linux-arm-kernel@lists.infradead.org
Cc: Andrew Lunn <andrew@lunn.ch>,
Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>,
Pawel Dembicki <paweldembicki@gmail.com>
Subject: Re: [PATCH] ARM: dts: mvebu: Add Ctera C-200 V2 board
Date: Mon, 28 Feb 2022 17:30:32 +0100 [thread overview]
Message-ID: <878rtv0x93.fsf@BL-laptop> (raw)
In-Reply-To: <20220216114309.27757-1-paweldembicki@gmail.com>
Pawel Dembicki <paweldembicki@gmail.com> writes:
> Ctera C200 V2 is armada-370 based 2-Bay NAS.
>
> Hardware:
> - SoC: Marvell 88F6707-A1 ARMv7 Processor 1,2GHz (ARMADA 370 SoC)
> - Ram: 1GB (2x Nanya NT5CC512M8DN-D1)
> - NAND Flash: 256MB (ESMT F59L2G81A-25T)
> - Lan: 1x GBE (Marvell 88E1318-NNB2)
> - Storage: 2x SATA HDD 3.5" Slot
> - USB: 2x USB 3.0 port (Renesas uPD720202)
> - Console: Internal J3 connector (1: Vcc, 2: Rx, 3: Tx, 4: GND)
> - LEDs: 13x GPIO controlled
> - Buttons: 2x GPIO controlled
>
> Signed-off-by: Pawel Dembicki <paweldembicki@gmail.com>
Applied on mvebu/dt
Thanks,
Gregory
> ---
> arch/arm/boot/dts/Makefile | 1 +
> arch/arm/boot/dts/armada-370-c200-v2.dts | 388 +++++++++++++++++++++++
> 2 files changed, 389 insertions(+)
> create mode 100644 arch/arm/boot/dts/armada-370-c200-v2.dts
>
> diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile
> index 31616f6ae173..bc7b3aac8135 100644
> --- a/arch/arm/boot/dts/Makefile
> +++ b/arch/arm/boot/dts/Makefile
> @@ -1416,6 +1416,7 @@ dtb-$(CONFIG_ARCH_ZYNQ) += \
> zynq-zybo.dtb \
> zynq-zybo-z7.dtb
> dtb-$(CONFIG_MACH_ARMADA_370) += \
> + armada-370-c200-v2.dtb \
> armada-370-db.dtb \
> armada-370-dlink-dns327l.dtb \
> armada-370-mirabox.dtb \
> diff --git a/arch/arm/boot/dts/armada-370-c200-v2.dts b/arch/arm/boot/dts/armada-370-c200-v2.dts
> new file mode 100644
> index 000000000000..dd9738233b36
> --- /dev/null
> +++ b/arch/arm/boot/dts/armada-370-c200-v2.dts
> @@ -0,0 +1,388 @@
> +// 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";
> +
> + power {
> + label = "Power Button";
> + linux,code = <KEY_POWER>;
> + gpios = <&gpio0 10 GPIO_ACTIVE_HIGH>;
> + };
> +
> + reset {
> + label = "Reset Button";
> + linux,code = <KEY_RESTART>;
> + gpios = <&gpio0 6 GPIO_ACTIVE_LOW>;
> + };
> +
> + usb1 {
> + label = "USB1 Button";
> + linux,code = <BTN_0>;
> + gpios = <&gpio1 0 GPIO_ACTIVE_LOW>;
> + };
> +
> + 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";
> +};
> --
> 2.25.1
>
--
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
prev parent reply other threads:[~2022-02-28 16:31 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-02-16 11:43 [PATCH] ARM: dts: mvebu: Add Ctera C-200 V2 board Pawel Dembicki
2022-02-28 16:30 ` Gregory CLEMENT [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=878rtv0x93.fsf@BL-laptop \
--to=gregory.clement@bootlin.com \
--cc=andrew@lunn.ch \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=paweldembicki@gmail.com \
--cc=sebastian.hesselbarth@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox