[openwrt/openwrt] realtek: add ZyXEL GS1900-24HPv2 support

LEDE Commits lede-commits at lists.infradead.org
Mon Sep 13 09:37:35 PDT 2021


hauke pushed a commit to openwrt/openwrt.git, branch master:
https://git.openwrt.org/c5b44af2fc5ffe620405ccb743b6f4acc461d4de

commit c5b44af2fc5ffe620405ccb743b6f4acc461d4de
Author: Soma Zambelly <zambelly.soma at gmail.com>
AuthorDate: Tue Aug 24 23:46:08 2021 +0200

    realtek: add ZyXEL GS1900-24HPv2 support
    
    The ZyXEL GS1900-24HPv2 is a 24 port PoE switch with two SFP ports, similar to the other GS1900 switches.
    
    Specifications
    --------------
    * Device:    ZyXEL GS1900-24HPv2
    * SoC:       Realtek RTL8382M 500 MHz MIPS 4KEc
    * Flash:     16 MiB
    * RAM:       W631GG8MB-12 128 MiB DDR3 SDRAM
                 (stock firmware is configured to use only 64 MiB)
    * Ethernet:  24x 10/100/1000 Mbps, 2x SFP 100/1000 Mbps
    * LEDs:      1 PWR LED (green, not configurable)
                 1 SYS LED (green, configurable)
                 24 ethernet port link/activity LEDs (green, SoC controlled)
                 24 ethernet port PoE status LEDs
                 2 SFP status/activity LEDs (green, SoC controlled)
    * Buttons:   1 "RESTORE" button on front panel
                 1 "RESET" button on front panel
    * Power      120-240V AC C13
    * UART:      1 serial header (J41) with populated standard pin connector on
                 the left edge of the PCB, angled towards the side.
                 The casing has a rectangular cutout on the side that provides
                 external access to these pins.
                 Pinout (front to back):
                 + GND
                 + TX
                 + RX
                 + VCC
    
    Serial connection parameters for both devices: 115200 8N1.
    
    Installation
    ------------
    
    OEM upgrade method:
    
    (Possible on master once https://patchwork.ozlabs.org/project/openwrt/patch/20210624210408.19248-1-bjorn@mork.no/ is merged)
    
    * Log in to OEM management web interface
    * Navigate to Maintenance > Firmware > Management
    * If "Active Image" has the first option selected, OpenWrt will need to be
      flashed to the "Active" partition. If the second option is selected,
      OpenWrt will need to be flashed to the "Backup" partition.
    * Navigate to Maintenance > Firmware > Upload
    * Upload the openwrt-realtek-generic-zyxel_gs1900-24hp-v2-initramfs-kernel.bin
      file by your preferred method to the previously determined partition.
      When prompted, select to boot from the newly flashed image, and reboot the switch.
    * Once OpenWrt has booted, scp the sysupgrade image to /tmp and flash it:
       > sysupgrade -n /tmp/openwrt-realtek-generic-zyxel_gs1900-24hp-v2-squashfs-sysupgrade.bin
       it may be necessary to restart the network (/etc/init.d/network restart) on
       the running initramfs image.
    
    U-Boot TFTP method:
    
    * Configure your client with a static 192.168.1.x IP (e.g. 192.168.1.10).
    * Set up a TFTP server on your client and make it serve the initramfs image.
    * Connect serial, power up the switch, interrupt U-boot by hitting the
      space bar, and enable the network:
       > rtk network on
    * Since the GS1900-24HPv2 is a dual-partition device, you want to keep the OEM
      firmware on the backup partition for the time being. OpenWrt can only boot
      from the first partition anyway (hardcoded in the DTS). To make sure we are
      manipulating the first partition, issue the following commands:
      > setsys bootpartition 0
      > savesys
    * Download the image onto the device and boot from it:
       > tftpboot 0x84f00000 192.168.1.10:openwrt-realtek-generic-zyxel_gs1900-24hp-v2-initramfs-kernel.bin
       > bootm
    * Once OpenWrt has booted, scp the sysupgrade image to /tmp and flash it:
       > sysupgrade -n /tmp/openwrt-realtek-generic-zyxel_gs1900-24hp-v2-squashfs-sysupgrade.bin
       it may be necessary to restart the network (/etc/init.d/network restart) on
       the running initramfs image.
    
    Signed-off-by: Soma Zambelly <zambelly.soma at gmail.com>
---
 package/boot/uboot-envtools/files/realtek          |   3 +-
 .../realtek/base-files/etc/board.d/02_network      |   3 +
 .../realtek/dts/rtl8382_zyxel_gs1900-24hp-v2.dts   | 117 +++++++++++++++++++++
 target/linux/realtek/image/Makefile                |   9 ++
 4 files changed, 131 insertions(+), 1 deletion(-)

diff --git a/package/boot/uboot-envtools/files/realtek b/package/boot/uboot-envtools/files/realtek
index 75a399208e..914d15583b 100644
--- a/package/boot/uboot-envtools/files/realtek
+++ b/package/boot/uboot-envtools/files/realtek
@@ -14,7 +14,8 @@ d-link,dgs-1210-10p|\
 zyxel,gs1900-8|\
 zyxel,gs1900-8hp-v1|\
 zyxel,gs1900-8hp-v2|\
-zyxel,gs1900-10hp)
+zyxel,gs1900-10hp|\
+zyxel,gs1900-24hp-v2)
 	idx="$(find_mtd_index u-boot-env)"
 	[ -n "$idx" ] && \
 		ubootenv_add_uci_config "/dev/mtd$idx" "0x0" "0x400" "0x10000"
diff --git a/target/linux/realtek/base-files/etc/board.d/02_network b/target/linux/realtek/base-files/etc/board.d/02_network
index 6568017b52..58461c9c99 100644
--- a/target/linux/realtek/base-files/etc/board.d/02_network
+++ b/target/linux/realtek/base-files/etc/board.d/02_network
@@ -61,6 +61,9 @@ zyxel,gs1900-8hp-v1|\
 zyxel,gs1900-8hp-v2)
 	ucidef_set_poe 70 "$lan_list"
 	;;
+zyxel,gs1900-24hp-v2)
+	ucidef_set_poe 170 "$lan_list"
+	;;
 esac
 
 board_config_flush
diff --git a/target/linux/realtek/dts/rtl8382_zyxel_gs1900-24hp-v2.dts b/target/linux/realtek/dts/rtl8382_zyxel_gs1900-24hp-v2.dts
new file mode 100644
index 0000000000..c16152521e
--- /dev/null
+++ b/target/linux/realtek/dts/rtl8382_zyxel_gs1900-24hp-v2.dts
@@ -0,0 +1,117 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+
+#include "rtl8380_zyxel_gs1900.dtsi"
+
+/ {
+	compatible = "zyxel,gs1900-24hp-v2", "realtek,rtl838x-soc";
+	model = "ZyXEL GS1900-24HP v2 Switch";
+
+	/* i2c of the left SFP cage: port 25 */
+	i2c0: i2c-gpio-0 {
+		compatible = "i2c-gpio";
+		sda-gpios = <&gpio1 24 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
+		scl-gpios = <&gpio1 25 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
+		i2c-gpio,delay-us = <2>;
+		#address-cells = <1>;
+		#size-cells = <0>;
+	};
+
+	sfp0: sfp-p25 {
+		compatible = "sff,sfp";
+		i2c-bus = <&i2c0>;
+		los-gpio = <&gpio1 27 GPIO_ACTIVE_HIGH>;
+		tx-fault-gpio = <&gpio1 22 GPIO_ACTIVE_HIGH>;
+		mod-def0-gpio = <&gpio1 26 GPIO_ACTIVE_LOW>;
+		tx-disable-gpio = <&gpio1 23 GPIO_ACTIVE_HIGH>;
+	};
+
+	/* i2c of the right SFP cage: port 26 */
+	i2c1: i2c-gpio-1 {
+		compatible = "i2c-gpio";
+		sda-gpios = <&gpio1 30 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
+		scl-gpios = <&gpio1 31 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
+		i2c-gpio,delay-us = <2>;
+		#address-cells = <1>;
+		#size-cells = <0>;
+	};
+
+	sfp1: sfp-p26 {
+		compatible = "sff,sfp";
+		i2c-bus = <&i2c1>;
+		los-gpio = <&gpio1 33 GPIO_ACTIVE_HIGH>;
+		tx-fault-gpio = <&gpio1 28 GPIO_ACTIVE_HIGH>;
+		mod-def0-gpio = <&gpio1 32 GPIO_ACTIVE_LOW>;
+		tx-disable-gpio = <&gpio1 29 GPIO_ACTIVE_HIGH>;
+	};
+};
+
+&mdio {
+	EXTERNAL_PHY(0)
+	EXTERNAL_PHY(1)
+	EXTERNAL_PHY(2)
+	EXTERNAL_PHY(3)
+	EXTERNAL_PHY(4)
+	EXTERNAL_PHY(5)
+	EXTERNAL_PHY(6)
+	EXTERNAL_PHY(7)
+
+	EXTERNAL_PHY(16)
+	EXTERNAL_PHY(17)
+	EXTERNAL_PHY(18)
+	EXTERNAL_PHY(19)
+	EXTERNAL_PHY(20)
+	EXTERNAL_PHY(21)
+	EXTERNAL_PHY(22)
+	EXTERNAL_PHY(23)
+
+	INTERNAL_PHY(24)
+	INTERNAL_PHY(26)
+};
+
+&switch0 {
+	ports {
+		SWITCH_PORT(0, 1, qsgmii)
+		SWITCH_PORT(1, 2, qsgmii)
+		SWITCH_PORT(2, 3, qsgmii)
+		SWITCH_PORT(3, 4, qsgmii)
+		SWITCH_PORT(4, 5, qsgmii)
+		SWITCH_PORT(5, 6, qsgmii)
+		SWITCH_PORT(6, 7, qsgmii)
+		SWITCH_PORT(7, 8, qsgmii)
+
+		SWITCH_PORT(8, 9, internal)
+		SWITCH_PORT(9, 10, internal)
+		SWITCH_PORT(10, 11, internal)
+		SWITCH_PORT(11, 12, internal)
+		SWITCH_PORT(12, 13, internal)
+		SWITCH_PORT(13, 14, internal)
+		SWITCH_PORT(14, 15, internal)
+		SWITCH_PORT(15, 16, internal)
+
+		SWITCH_PORT(16, 17, qsgmii)
+		SWITCH_PORT(17, 18, qsgmii)
+		SWITCH_PORT(18, 19, qsgmii)
+		SWITCH_PORT(19, 20, qsgmii)
+		SWITCH_PORT(20, 21, qsgmii)
+		SWITCH_PORT(21, 22, qsgmii)
+		SWITCH_PORT(22, 23, qsgmii)
+		SWITCH_PORT(23, 24, qsgmii)
+
+
+		port at 24 {
+			reg = <24>;
+			label = "lan25";
+			phy-mode = "1000base-x";
+			managed = "in-band-status";
+			sfp = <&sfp0>;
+		};
+
+		port at 26 {
+			reg = <26>;
+			label = "lan26";
+			phy-mode = "1000base-x";
+			managed = "in-band-status";
+			sfp = <&sfp1>;
+		};
+	};
+};
diff --git a/target/linux/realtek/image/Makefile b/target/linux/realtek/image/Makefile
index cf0d588851..5900750797 100644
--- a/target/linux/realtek/image/Makefile
+++ b/target/linux/realtek/image/Makefile
@@ -153,4 +153,13 @@ define Device/zyxel_gs1900-8hp-v2
 endef
 TARGET_DEVICES += zyxel_gs1900-8hp-v2
 
+define Device/zyxel_gs1900-24hp-v2
+  $(Device/zyxel_gs1900)
+  SOC := rtl8382
+  DEVICE_MODEL := GS1900-24HP
+  DEVICE_VARIANT := v2
+  ZYXEL_VERS := ABTP
+endef
+TARGET_DEVICES += zyxel_gs1900-24hp-v2
+
 $(eval $(call BuildImage))



More information about the lede-commits mailing list