[openwrt/openwrt] ramips: add support for Sercomm S1500 devices
LEDE Commits
lede-commits at lists.infradead.org
Sun Jul 2 06:21:04 PDT 2023
hauke pushed a commit to openwrt/openwrt.git, branch openwrt-23.05:
https://git.openwrt.org/436ef3772809e5e34e18b623e8ff93d34af1ea5d
commit 436ef3772809e5e34e18b623e8ff93d34af1ea5d
Author: Mikhail Zhilkin <csharper2005 at gmail.com>
AuthorDate: Sun Jun 11 20:50:23 2023 +0000
ramips: add support for Sercomm S1500 devices
This commit adds support for following wireless routers:
- Beeline SmartBox PRO (Serсomm S1500 AWI)
- WiFire S1500.NBN (Serсomm S1500 BUC)
This commit is based on this PR:
- Link: https://github.com/openwrt/openwrt/pull/4770
- Author: Maximilian Weinmann <x1 at disroot.org>
The opening of this PR was agreed with author.
My changes:
- Sorting, minor changes and some movings between dts and dtsi
- Move leds to dts when possible
- Recipes for the factory image
- Update of the installation/recovery/return to stock guides
- Add reset GPIO for the pcie1
Common specification
--------------------
SoC: MediaTek MT7621AT (880 MHz, 2 cores)
Switch: MediaTek MT7530 (via SoC MT7621AT)
Wireless: 2.4 GHz, MT7602EN, b/g/n, 2x2
Wireless: 5 GHz, MT7612EN, a/n/ac, 2x2
Ethernet: 5 ports - 5×GbE (WAN, LAN1-4)
Mini PCIe: via J2 on PCB, not soldered on the board
UART: J4 -> GND[], TX, VCC(3.3V), RX
BootLoader: U-Boot SerComm/Mediatek
Beeline SmartBox PRO specification
----------------------------------
RAM (Nanya NT5CB128M16FP): 256 MiB
NAND-Flash (ESMT F59L2G81A): 256 MiB
USB ports: 2xUSB2.0
LEDs: Status (white), WPS (blue), 2g (white), 5g (white) + 10 LED Ethernet
Buttons: 2 button (reset, wps), 1 switch button (ROUT<->REP)
Power: 12 VDC, 1.5 A
PCB Sticker: 970AWI0QW00N256SMT Ver. 1.0
CSN: SG15********
MAC LAN: 94:4A:0C:**:**:**
Manufacturer's code: 0AWI0500QW1
WiFire S1500.NBN specification
------------------------------
RAM (Nanya NT5CC64M16GP): 128 MiB
NAND-Flash (ESMT F59L1G81MA): 128 MiB
USB ports: 1xUSB2.0
LEDs: Status (white), WPS (white), 2g (white), 5g (white) + 10 LED Ethernet
Buttons: 2 button (RESET, WPS)
Power: 12 VDC, 1.0 A
PCB Sticker: 970BUC0RW00N128SMT Ver. 1.0
CSN: MH16********
MAC WAN: E0:60:66:**:**:**
Manufacturer's code: 0BUC0500RW1
MAC address table (PRO)
-----------------------
use address source
LAN *:23 factory 0x1000 (label)
WAN *:24 factory $label +1
2g *:23 factory $label
5g *:25 factory $label +2
MAC addresses (NBN)
-------------------
use address source
LAN *:0e factory 0x1000
WAN *:0f LAN +1 (label)
2g *:0f LAN +1
5g *:10 LAN +2
OEM easy installation
---------------------
1. Remove all dots from the factory image filename (except the dot
before file extension)
2. Upload and update the firmware via the original web interface
3. Two options are possible after the reboot:
a. OpenWrt - that's OK, the mission accomplished
b. Stock firmware - install Stock firmware (to switch booflag from
Sercomm0 to Sercomm1) and then OpenWrt factory image.
Return to Stock
---------------
1. Change the bootflag to Sercomm1 in OpenWrt CLI and then reboot:
printf 1 | dd bs=1 seek=7 count=1 of=/dev/mtdblock2
reboot
2. Install stock firmware via the web OEM firmware interface
Recovery
--------
Use sercomm-recovery tool.
Link: https://github.com/danitool/sercomm-recovery
Tested-by: Pavel Ivanov <pi635v at gmail.com>
Tested-by: Denis Myshaev <denis.myshaev at gmail.com>
Tested-by: Oleg Galeev <olegingaleev at gmail.com>
Tested-By: Ivan Pavlov <AuthorReflex at gmail.com>
Co-authored-by: Maximilian Weinmann <x1 at disroot.org>
Signed-off-by: Mikhail Zhilkin <csharper2005 at gmail.com>
(cherry picked from commit 2d6784a033a994043759fa3b94c48afd5df81f88)
---
package/boot/uboot-envtools/files/ramips | 12 +-
.../ramips/dts/mt7621_beeline_smartbox-pro.dts | 118 +++++++++
target/linux/ramips/dts/mt7621_sercomm_s1500.dtsi | 281 +++++++++++++++++++++
.../linux/ramips/dts/mt7621_wifire_s1500-nbn.dts | 81 ++++++
target/linux/ramips/image/common-sercomm.mk | 39 ++-
target/linux/ramips/image/mt7621.mk | 35 +++
.../ramips/mt7621/base-files/etc/board.d/01_leds | 8 +
.../mt7621/base-files/lib/upgrade/platform.sh | 2 +
8 files changed, 568 insertions(+), 8 deletions(-)
diff --git a/package/boot/uboot-envtools/files/ramips b/package/boot/uboot-envtools/files/ramips
index b3f37c7c3e..5fb5c45a51 100644
--- a/package/boot/uboot-envtools/files/ramips
+++ b/package/boot/uboot-envtools/files/ramips
@@ -44,6 +44,13 @@ etisalat,s3|\
rostelecom,rt-sf-1)
ubootenv_add_uci_config "/dev/mtd0" "0x80000" "0x1000" "0x20000"
;;
+beeline,smartbox-pro|\
+tplink,ec330-g5u-v1|\
+wifire,s1500-nbn)
+ idx="$(find_mtd_index u-boot-env)"
+ [ -n "$idx" ] && \
+ ubootenv_add_uci_config "/dev/mtd$idx" "0x0" "0x1000" "0x20000"
+ ;;
buffalo,wsr-1166dhp|\
buffalo,wsr-600dhp|\
kroks,kndrt31r16|\
@@ -96,11 +103,6 @@ snr,cpe-w4n-mt)
[ -n "$idx" ] && \
ubootenv_add_uci_config "/dev/mtd$idx" "0x0" "0x1000" "0x1000"
;;
-tplink,ec330-g5u-v1)
- idx="$(find_mtd_index u-boot-env)"
- [ -n "$idx" ] && \
- ubootenv_add_uci_config "/dev/mtd$idx" "0x0" "0x1000" "0x20000"
- ;;
xiaomi,mi-router-3g-v2|\
xiaomi,mi-router-4a-gigabit|\
xiaomi,miwifi-3c)
diff --git a/target/linux/ramips/dts/mt7621_beeline_smartbox-pro.dts b/target/linux/ramips/dts/mt7621_beeline_smartbox-pro.dts
new file mode 100644
index 0000000000..e3e248d48f
--- /dev/null
+++ b/target/linux/ramips/dts/mt7621_beeline_smartbox-pro.dts
@@ -0,0 +1,118 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+
+#include "mt7621_sercomm_s1500.dtsi"
+
+/ {
+ compatible = "beeline,smartbox-pro", "mediatek,mt7621-soc";
+ model = "Beeline SmartBox PRO";
+
+ aliases {
+ label-mac-device = &gmac0;
+ };
+
+ keys {
+ switch_bt {
+ label = "ROUT<->REP Switch_bt";
+ gpios = <&gpio 6 GPIO_ACTIVE_LOW>;
+ linux,input-type = <EV_SW>;
+ linux,code = <KEY_RFKILL>;
+ debounce-interval = <60>;
+ };
+ };
+
+ ubi-concat {
+ compatible = "mtd-concat";
+ devices = <&ubiconcat0 &ubiconcat1 &ubiconcat2 &ubiconcat3 \
+ &ubiconcat4 &ubiconcat5 &ubiconcat6>;
+
+ partitions {
+ compatible = "fixed-partitions";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ partition at 0 {
+ label = "ubi";
+ reg = <0x0 0xd2e0000>;
+ };
+ };
+ };
+};
+
+&led_wps {
+ label = "blue:wps";
+ color = <LED_COLOR_ID_BLUE>;
+};
+
+&partitions {
+ partition at 0_all {
+ label = "ALL";
+ reg = <0x0 0xff80000>;
+ read-only;
+ };
+
+ partition at 200000 {
+ label = "sys_data";
+ reg = <0x200000 0x1400000>;
+
+ compatible = "fixed-partitions";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ ubiconcat5: partition at 0 {
+ label = "sys_data_1";
+ reg = <0x0 0x600000>;
+ };
+
+ /*
+ * Sercomm U-Boot saves the environment at 0x800000 from
+ * the start of the NAND, destroying the "sys_data"
+ * partition. To prevent this, we split "sys_data" into
+ * two parts with "u-boot-env" partition between them.
+ */
+ partition at 600000 {
+ label = "u-boot-env";
+ reg = <0x600000 0x20000>;
+ };
+
+ ubiconcat6: partition at 620000 {
+ label = "sys_data_2";
+ reg = <0x620000 0xde0000>;
+ };
+ };
+
+ ubiconcat0: partition at 1f00000 {
+ label = "RootFS_1";
+ reg = <0x1f00000 0x1e00000>;
+ };
+
+ partition at 3d00000 {
+ label = "RootFS_2";
+ reg = <0x3d00000 0x1e00000>;
+ read-only;
+ };
+
+ ubiconcat1: partition at 5b00000 {
+ label = "JVM/OSGI1";
+ reg = <0x5b00000 0x3200000>;
+ };
+
+ ubiconcat2: partition at 8d00000 {
+ label = "JVM/OSGI2";
+ reg = <0x8d00000 0x3200000>;
+ };
+
+ ubiconcat3: partition at bf00000 {
+ label = "OSGI data";
+ reg = <0xbf00000 0x3c00000>;
+ };
+
+ ubiconcat4: partition at fb00000 {
+ label = "Ftool";
+ reg = <0xfb00000 0x100000>;
+ };
+
+ /*
+ * 4 MiB Reserved for the Bad Blocka
+ * 0x10000000-0xfc00000=0x400000
+ */
+};
diff --git a/target/linux/ramips/dts/mt7621_sercomm_s1500.dtsi b/target/linux/ramips/dts/mt7621_sercomm_s1500.dtsi
new file mode 100644
index 0000000000..91053f15bc
--- /dev/null
+++ b/target/linux/ramips/dts/mt7621_sercomm_s1500.dtsi
@@ -0,0 +1,281 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+
+#include "mt7621.dtsi"
+
+#include <dt-bindings/gpio/gpio.h>
+#include <dt-bindings/input/input.h>
+#include <dt-bindings/leds/common.h>
+
+/ {
+ aliases {
+ led-boot = &led_status;
+ led-running = &led_status;
+ led-upgrade = &led_wps;
+ led-failsafe = &led_wps;
+ };
+
+ keys {
+ compatible = "gpio-keys";
+
+ reset {
+ label = "reset";
+ gpios = <&gpio 7 GPIO_ACTIVE_LOW>;
+ linux,code = <KEY_RESTART>;
+ };
+
+ wps {
+ label = "wps";
+ gpios = <&gpio 18 GPIO_ACTIVE_LOW>;
+ linux,code = <KEY_WPS_BUTTON>;
+ };
+ };
+
+ leds {
+ compatible = "gpio-leds";
+
+ led-0 {
+ label = "amber:lan4";
+ color = <LED_COLOR_ID_AMBER>;
+ function = LED_FUNCTION_LAN;
+ function-enumerator = <0>;
+ linux,default-trigger = "mt7530-0:00:1Gbps";
+ gpios = <&gpio 3 GPIO_ACTIVE_LOW>;
+ };
+
+ led-1 {
+ label = "green:lan4";
+ color = <LED_COLOR_ID_GREEN>;
+ function = LED_FUNCTION_LAN;
+ function-enumerator = <1>;
+ gpios = <&gpio 4 GPIO_ACTIVE_LOW>;
+ };
+
+ led-2 {
+ label = "amber:lan3";
+ color = <LED_COLOR_ID_AMBER>;
+ function = LED_FUNCTION_LAN;
+ function-enumerator = <2>;
+ linux,default-trigger = "mt7530-0:01:1Gbps";
+ gpios = <&gpio 10 GPIO_ACTIVE_LOW>;
+ };
+
+ led-3 {
+ label = "green:lan3";
+ color = <LED_COLOR_ID_GREEN>;
+ function = LED_FUNCTION_LAN;
+ function-enumerator = <3>;
+ gpios = <&gpio 12 GPIO_ACTIVE_LOW>;
+ };
+
+ led-4 {
+ label = "amber:lan2";
+ color = <LED_COLOR_ID_AMBER>;
+ function = LED_FUNCTION_LAN;
+ function-enumerator = <4>;
+ linux,default-trigger = "mt7530-0:02:1Gbps";
+ gpios = <&gpio 14 GPIO_ACTIVE_LOW>;
+ };
+
+ led-5 {
+ label = "amber:lan1";
+ color = <LED_COLOR_ID_AMBER>;
+ function = LED_FUNCTION_LAN;
+ function-enumerator = <5>;
+ linux,default-trigger = "mt7530-0:03:1Gbps";
+ gpios = <&gpio 22 GPIO_ACTIVE_LOW>;
+ };
+
+ led-6 {
+ label = "green:lan1";
+ color = <LED_COLOR_ID_GREEN>;
+ function = LED_FUNCTION_LAN;
+ function-enumerator = <6>;
+ gpios = <&gpio 23 GPIO_ACTIVE_LOW>;
+ };
+
+ led-7 {
+ label = "amber:wan";
+ color = <LED_COLOR_ID_AMBER>;
+ function = LED_FUNCTION_WAN;
+ function-enumerator = <0>;
+ linux,default-trigger = "mt7530-0:04:1Gbps";
+ gpios = <&gpio 24 GPIO_ACTIVE_LOW>;
+ };
+
+ led-8 {
+ label = "green:wan";
+ color = <LED_COLOR_ID_GREEN>;
+ function = LED_FUNCTION_WAN;
+ function-enumerator = <1>;
+ gpios = <&gpio 25 GPIO_ACTIVE_LOW>;
+ };
+
+ led-9 {
+ label = "green:lan2";
+ color = <LED_COLOR_ID_GREEN>;
+ function = LED_FUNCTION_LAN;
+ function-enumerator = <7>;
+ gpios = <&gpio 26 GPIO_ACTIVE_LOW>;
+ };
+
+ led-10 {
+ label = "white:wlan2g";
+ color = <LED_COLOR_ID_WHITE>;
+ function = LED_FUNCTION_WLAN;
+ function-enumerator = <0>;
+ linux,default-trigger = "phy1radio";
+ gpios = <&gpio 28 GPIO_ACTIVE_LOW>;
+ };
+
+ led_wps: led-11 {
+ function = LED_FUNCTION_WPS;
+ function-enumerator = <0>;
+ gpios = <&gpio 29 GPIO_ACTIVE_LOW>;
+ panic-indicator;
+ };
+
+ led_status: led-12 {
+ label = "white:status";
+ color = <LED_COLOR_ID_WHITE>;
+ function = LED_FUNCTION_STATUS;
+ function-enumerator = <0>;
+ gpios = <&gpio 30 GPIO_ACTIVE_LOW>;
+ };
+
+ led-13 {
+ label = "white:wlan5g";
+ color = <LED_COLOR_ID_WHITE>;
+ function = LED_FUNCTION_WLAN;
+ function-enumerator = <1>;
+ linux,default-trigger = "phy0radio";
+ gpios = <&gpio 32 GPIO_ACTIVE_LOW>;
+ };
+ };
+};
+
+ðernet {
+ pinctrl-0 = <&mdio_pins>, <&rgmii1_pins>;
+};
+
+&gmac0 {
+ nvmem-cells = <&macaddr_factory_1000>;
+ nvmem-cell-names = "mac-address";
+};
+
+&nand {
+ status = "okay";
+
+ partitions: partitions {
+ compatible = "fixed-partitions";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ partition at 0 {
+ label = "u-boot";
+ reg = <0x0 0x100000>;
+ read-only;
+ };
+
+ factory: partition at 100000 {
+ label = "Factory";
+ reg = <0x100000 0x100000>;
+ read-only;
+
+ compatible = "nvmem-cells";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ macaddr_factory_1000: macaddr at 1000 {
+ reg = <0x1000 0x6>;
+ };
+ };
+
+ partition at 1600000 {
+ label = "boot_flag";
+ reg = <0x1600000 0x100000>;
+ };
+
+ partition at 1700000 {
+ label = "kernel";
+ reg = <0x1700000 0x400000>;
+ };
+
+ partition at 1b00000 {
+ label = "Kernel_2";
+ reg = <0x1b00000 0x400000>;
+ read-only;
+ };
+ };
+};
+
+&pcie {
+ status = "okay";
+
+ reset-gpios = <&gpio 8 GPIO_ACTIVE_LOW>,
+ <&gpio 19 GPIO_ACTIVE_LOW>;
+};
+
+&pcie0 {
+ wifi at 0,0 {
+ compatible = "mediatek,mt76";
+ reg = <0x0000 0 0 0 0>;
+ ieee80211-freq-limit = <5000000 6000000>;
+ mediatek,mtd-eeprom = <&factory 0x8000>;
+
+ nvmem-cells = <&macaddr_factory_1000>;
+ nvmem-cell-names = "mac-address";
+ mac-address-increment = <2>;
+ };
+};
+
+&pcie1 {
+ wlan_2g: wifi at 0,0 {
+ compatible = "mediatek,mt76";
+ reg = <0x0000 0 0 0 0>;
+ ieee80211-freq-limit = <2400000 2500000>;
+ mediatek,mtd-eeprom = <&factory 0x0>;
+
+ nvmem-cells = <&macaddr_factory_1000>;
+ nvmem-cell-names = "mac-address";
+ };
+};
+
+&state_default {
+ gpio {
+ groups = "wdt", "uart3", "jtag", "uart2", "i2c", "rgmii2";
+ function = "gpio";
+ };
+};
+
+&switch0 {
+ ports {
+ port at 0 {
+ status = "okay";
+ label = "lan4";
+ };
+
+ port at 1 {
+ status = "okay";
+ label = "lan3";
+ };
+
+ port at 2 {
+ status = "okay";
+ label = "lan2";
+ };
+
+ port at 3 {
+ status = "okay";
+ label = "lan1";
+ };
+
+ wan: port at 4 {
+ status = "okay";
+ label = "wan";
+
+ nvmem-cells = <&macaddr_factory_1000>;
+ nvmem-cell-names = "mac-address";
+ mac-address-increment = <1>;
+ };
+ };
+};
diff --git a/target/linux/ramips/dts/mt7621_wifire_s1500-nbn.dts b/target/linux/ramips/dts/mt7621_wifire_s1500-nbn.dts
new file mode 100644
index 0000000000..6c0e2965aa
--- /dev/null
+++ b/target/linux/ramips/dts/mt7621_wifire_s1500-nbn.dts
@@ -0,0 +1,81 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+
+#include "mt7621_sercomm_s1500.dtsi"
+
+/ {
+ compatible = "wifire,s1500-nbn", "mediatek,mt7621-soc";
+ model = "WiFire S1500.NBN";
+
+ aliases {
+ label-mac-device = &wan;
+ };
+
+ ubi-concat {
+ compatible = "mtd-concat";
+ devices = <&ubiconcat0 &ubiconcat1 &ubiconcat2 &ubiconcat3>;
+
+ partitions {
+ compatible = "fixed-partitions";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ partition at 0 {
+ label = "ubi";
+ reg = <0x0 0x4680000>;
+ };
+ };
+ };
+};
+
+&led_wps {
+ label = "white:wps";
+ color = <LED_COLOR_ID_WHITE>;
+};
+
+&partitions {
+ partition at 0_all {
+ label = "ALL";
+ reg = <0x0 0x7f80000>;
+ read-only;
+ };
+
+ partition at 80000 {
+ label = "u-boot-env";
+ reg = <0x80000 0x20000>;
+ };
+
+ ubiconcat1: partition at 200000 {
+ label = "sys_data";
+ reg = <0x200000 0x1400000>;
+ };
+
+ ubiconcat0: partition at 1f00000 {
+ label = "RootFS_1";
+ reg = <0x1f00000 0x2e00000>;
+ };
+
+ partition at 4d00000 {
+ label = "RootFS_2";
+ reg = <0x4d00000 0x2e00000>;
+ read-only;
+ };
+
+ ubiconcat2: partition at 7b00000 {
+ label = "Ftool";
+ reg = <0x7b00000 0x100000>;
+ };
+
+ ubiconcat3: partition at 7c00000 {
+ label = "BCT";
+ reg = <0x7c00000 0x380000>;
+ };
+
+ /*
+ * 512 KiB reserved for the Bad Blocks
+ * 0x8000000-0x7f80000=0x80000
+ */
+};
+
+&wlan_2g {
+ mac-address-increment = <1>;
+};
diff --git a/target/linux/ramips/image/common-sercomm.mk b/target/linux/ramips/image/common-sercomm.mk
index b743df4408..4060da0923 100644
--- a/target/linux/ramips/image/common-sercomm.mk
+++ b/target/linux/ramips/image/common-sercomm.mk
@@ -1,6 +1,12 @@
DEVICE_VARS += SERCOMM_KERNEL_OFFSET SERCOMM_ROOTFS_OFFSET
DEVICE_VARS += SERCOMM_KERNEL2_OFFSET SERCOMM_ROOTFS2_OFFSET
+define Build/sercomm-append-tail
+ printf 16 | dd seek=$$((0x90)) of=$@ bs=1 conv=notrunc 2>/dev/null
+ printf 11223344556677889900112233445566 | \
+ sed 's/../\\x&/g' | xargs -d . printf >> $@
+endef
+
define Build/sercomm-crypto
$(TOPDIR)/scripts/sercomm-crypto.py \
--input-file $@ \
@@ -32,6 +38,10 @@ define Build/sercomm-factory-cqr
mv $@.fhdr $@
endef
+define Build/sercomm-fix-buc-pid
+ printf 1 | dd seek=$$((0x13)) of=$@ bs=1 conv=notrunc 2>/dev/null
+endef
+
define Build/sercomm-kernel
$(TOPDIR)/scripts/sercomm-kernel-header.py \
--kernel-image $@ \
@@ -102,19 +112,28 @@ define Build/sercomm-prepend-tagged-kernel
mv $(IMAGE_KERNEL).tagged $@
endef
+define Build/sercomm-reset-slot1-chksum
+ printf "\xff\xff\xff\xff" | \
+ dd of=$@ seek=$$((0x118)) bs=1 conv=notrunc 2>/dev/null
+endef
+
define Device/sercomm
$(Device/nand)
LOADER_TYPE := bin
+ IMAGES += factory.img
+endef
+
+define Device/sercomm_cxx_dxx
+ $(Device/sercomm)
KERNEL_SIZE := 6144k
KERNEL_LOADADDR := 0x81001000
LZMA_TEXT_START := 0x82800000
SERCOMM_KERNEL_OFFSET := 0x400100
SERCOMM_ROOTFS_OFFSET := 0x1000000
- IMAGES += factory.img
endef
define Device/sercomm_cxx
- $(Device/sercomm)
+ $(Device/sercomm_cxx_dxx)
SERCOMM_KERNEL2_OFFSET := 0xa00100
SERCOMM_ROOTFS2_OFFSET := 0x3000000
KERNEL := kernel-bin | append-dtb | lzma | loader-kernel | lzma -a0 | \
@@ -126,7 +145,7 @@ define Device/sercomm_cxx
endef
define Device/sercomm_dxx
- $(Device/sercomm)
+ $(Device/sercomm_cxx_dxx)
KERNEL := kernel-bin | append-dtb | lzma | loader-kernel | lzma -a0 | \
uImage lzma | sercomm-kernel
KERNEL_INITRAMFS := kernel-bin | append-dtb | lzma | loader-kernel | \
@@ -136,3 +155,17 @@ define Device/sercomm_dxx
sercomm-part-tag rootfs | sercomm-prepend-tagged-kernel kernel | \
gzip | sercomm-payload | sercomm-crypto
endef
+
+define Device/sercomm_s1500
+ $(Device/sercomm)
+ SERCOMM_KERNEL_OFFSET := 0x1700100
+ SERCOMM_ROOTFS_OFFSET := 0x1f00000
+ SERCOMM_KERNEL2_OFFSET := 0x1b00100
+ KERNEL := kernel-bin | append-dtb | lzma | loader-kernel | lzma -a0 | \
+ uImage lzma
+ KERNEL_INITRAMFS := kernel-bin | append-dtb | lzma | loader-kernel | \
+ lzma -a0 | uImage lzma
+ IMAGE/sysupgrade.bin := append-kernel | sercomm-kernel | \
+ sysupgrade-tar kernel=$$$$@ | append-metadata
+ DEVICE_PACKAGES := kmod-mt76x2 kmod-usb3
+endef
diff --git a/target/linux/ramips/image/mt7621.mk b/target/linux/ramips/image/mt7621.mk
index a5b69839a7..e426eac5b6 100644
--- a/target/linux/ramips/image/mt7621.mk
+++ b/target/linux/ramips/image/mt7621.mk
@@ -398,6 +398,23 @@ define Device/beeline_smartbox-giga
endef
TARGET_DEVICES += beeline_smartbox-giga
+define Device/beeline_smartbox-pro
+ $(Device/sercomm_s1500)
+ DEVICE_VENDOR := Beeline
+ DEVICE_MODEL := SmartBox PRO
+ DEVICE_ALT0_VENDOR := Sercomm
+ DEVICE_ALT0_MODEL := S1500 AWI
+ IMAGE_SIZE := 34816k
+ IMAGE/factory.img := append-kernel | sercomm-kernel-factory | \
+ sercomm-reset-slot1-chksum | append-ubi | check-size | \
+ sercomm-factory-cqr | sercomm-append-tail | sercomm-mkhash
+ SERCOMM_HWID := AWI
+ SERCOMM_HWVER := 10000
+ SERCOMM_ROOTFS2_OFFSET := 0x3d00000
+ SERCOMM_SWVER := 2020
+endef
+TARGET_DEVICES += beeline_smartbox-pro
+
define Device/beeline_smartbox-turbo
$(Device/sercomm_dxx)
IMAGE_SIZE := 32768k
@@ -2427,6 +2444,24 @@ define Device/wevo_w2914ns-v2
endef
TARGET_DEVICES += wevo_w2914ns-v2
+define Device/wifire_s1500-nbn
+ $(Device/sercomm_s1500)
+ DEVICE_VENDOR := WiFire
+ DEVICE_MODEL := S1500.NBN
+ DEVICE_ALT0_VENDOR := Sercomm
+ DEVICE_ALT0_MODEL := S1500 BUC
+ IMAGE_SIZE := 51200k
+ IMAGE/factory.img := append-kernel | sercomm-kernel-factory | \
+ sercomm-reset-slot1-chksum | append-ubi | check-size | \
+ sercomm-factory-cqr | sercomm-fix-buc-pid | sercomm-mkhash | \
+ sercomm-crypto
+ SERCOMM_HWID := BUC
+ SERCOMM_HWVER := 10000
+ SERCOMM_ROOTFS2_OFFSET := 0x4d00000
+ SERCOMM_SWVER := 2015
+endef
+TARGET_DEVICES += wifire_s1500-nbn
+
define Device/winstars_ws-wn583a6
$(Device/dsa-migration)
$(Device/uimage-lzma-loader)
diff --git a/target/linux/ramips/mt7621/base-files/etc/board.d/01_leds b/target/linux/ramips/mt7621/base-files/etc/board.d/01_leds
index 9b15da0d22..1f91905bd8 100644
--- a/target/linux/ramips/mt7621/base-files/etc/board.d/01_leds
+++ b/target/linux/ramips/mt7621/base-files/etc/board.d/01_leds
@@ -40,6 +40,14 @@ etisalat,s3|\
rostelecom,rt-sf-1)
ucidef_set_led_netdev "wan" "wan" "blue:wan" "wan"
;;
+beeline,smartbox-pro|\
+wifire,s1500-nbn)
+ ucidef_set_led_netdev "lan1" "lan1" "green:lan1" "lan1" "link tx rx"
+ ucidef_set_led_netdev "lan2" "lan2" "green:lan2" "lan2" "link tx rx"
+ ucidef_set_led_netdev "lan3" "lan3" "green:lan3" "lan3" "link tx rx"
+ ucidef_set_led_netdev "lan4" "lan4" "green:lan4" "lan4" "link tx rx"
+ ucidef_set_led_netdev "wan" "wan" "green:wan" "wan" "link tx rx"
+ ;;
belkin,rt1800)
ucidef_set_led_netdev "wan" "wan" "white:wan" "wan"
;;
diff --git a/target/linux/ramips/mt7621/base-files/lib/upgrade/platform.sh b/target/linux/ramips/mt7621/base-files/lib/upgrade/platform.sh
index cef58ec3ba..5d8305b788 100755
--- a/target/linux/ramips/mt7621/base-files/lib/upgrade/platform.sh
+++ b/target/linux/ramips/mt7621/base-files/lib/upgrade/platform.sh
@@ -59,6 +59,7 @@ platform_do_upgrade() {
asus,rt-ax54|\
beeline,smartbox-flash|\
beeline,smartbox-giga|\
+ beeline,smartbox-pro|\
beeline,smartbox-turbo|\
beeline,smartbox-turbo-plus|\
belkin,rt1800|\
@@ -106,6 +107,7 @@ platform_do_upgrade() {
sercomm,na502s|\
sim,simax1800t|\
tplink,ec330-g5u-v1|\
+ wifire,s1500-nbn|\
xiaomi,mi-router-3g|\
xiaomi,mi-router-3-pro|\
xiaomi,mi-router-4|\
More information about the lede-commits
mailing list