From 764b5a63d118afc00aeb64ff19dff9e8f90c2da7 Mon Sep 17 00:00:00 2001 From: aiamadeus <2789289348@qq.com> Date: Thu, 12 Dec 2024 23:16:03 +0800 Subject: [PATCH] mediatek: add u-boot mod version for Cudy TR3000 --- .../mediatek/dts/mt7981b-cudy-tr3000-mod.dts | 20 ++++++++++++++ .../mediatek/dts/mt7981b-cudy-tr3000-v1.dts | 27 ++++++++++--------- .../filogic/base-files/etc/board.d/02_network | 2 +- .../etc/hotplug.d/ieee80211/11_fix_wifi_mac | 2 +- target/linux/mediatek/image/filogic.mk | 15 +++++++++++ 5 files changed, 51 insertions(+), 15 deletions(-) create mode 100644 target/linux/mediatek/dts/mt7981b-cudy-tr3000-mod.dts diff --git a/target/linux/mediatek/dts/mt7981b-cudy-tr3000-mod.dts b/target/linux/mediatek/dts/mt7981b-cudy-tr3000-mod.dts new file mode 100644 index 000000000..d2dea1357 --- /dev/null +++ b/target/linux/mediatek/dts/mt7981b-cudy-tr3000-mod.dts @@ -0,0 +1,20 @@ +// SPDX-License-Identifier: GPL-2.0-or-later OR MIT + +/dts-v1/; +#include "mt7981b-cudy-tr3000-v1.dts" + +/ { + model = "Cudy TR3000 (U-Boot mod)"; + compatible = "cudy,tr3000-mod", "mediatek,mt7981"; +}; + +&spi0 { + flash@0 { + partitions { + partition@5c0000 { + label = "ubi"; + reg = <0x5c0000 0x7000000>; + }; + }; + }; +}; diff --git a/target/linux/mediatek/dts/mt7981b-cudy-tr3000-v1.dts b/target/linux/mediatek/dts/mt7981b-cudy-tr3000-v1.dts index 100fab4ae..a12555a26 100644 --- a/target/linux/mediatek/dts/mt7981b-cudy-tr3000-v1.dts +++ b/target/linux/mediatek/dts/mt7981b-cudy-tr3000-v1.dts @@ -14,10 +14,10 @@ aliases { label-mac-device = &gmac1; - led-boot = &led_status; - led-failsafe = &led_status; - led-running = &led_status; - led-upgrade = &led_status; + led-boot = &led_sys_red; + led-failsafe = &led_sys_red; + led-running = &led_sys_white; + led-upgrade = &led_sys_white; serial0 = &uart0; }; @@ -36,8 +36,8 @@ mode { label = "mode"; - linux,input-type = ; linux,code = ; + linux,input-type = ; gpios = <&pio 0 GPIO_ACTIVE_LOW>; debounce-interval = <60>; }; @@ -46,13 +46,13 @@ leds { compatible = "gpio-leds"; - led_status: led-0 { + led_sys_red: led-0 { function = LED_FUNCTION_POWER; color = ; gpios = <&pio 11 GPIO_ACTIVE_LOW>; }; - led-1 { + led_sys_white: led-1 { function = LED_FUNCTION_STATUS; color = ; gpios = <&pio 10 GPIO_ACTIVE_LOW>; @@ -105,10 +105,11 @@ phy1: phy@1 { compatible = "ethernet-phy-ieee802.3-c45"; reg = <1>; - reset-gpios = <&pio 39 GPIO_ACTIVE_LOW>; - interrupts = <38 IRQ_TYPE_LEVEL_LOW>; reset-assert-us = <100000>; reset-deassert-us = <100000>; + reset-gpios = <&pio 39 GPIO_ACTIVE_LOW>; + interrupts = <38 IRQ_TYPE_LEVEL_LOW>; + interrupt-parent = <&pio>; realtek,aldps-enable; }; }; @@ -189,15 +190,15 @@ }; }; - partition@3C0000 { + partition@3c0000 { label = "FIP"; - reg = <0x3C0000 0x0200000>; + reg = <0x3c0000 0x0200000>; read-only; }; - partition@580000 { + partition@5c0000 { label = "ubi"; - reg = <0x5C0000 0x4000000>; + reg = <0x5c0000 0x4000000>; compatible = "linux,ubi"; }; }; diff --git a/target/linux/mediatek/filogic/base-files/etc/board.d/02_network b/target/linux/mediatek/filogic/base-files/etc/board.d/02_network index 42db91c7a..990e0df21 100644 --- a/target/linux/mediatek/filogic/base-files/etc/board.d/02_network +++ b/target/linux/mediatek/filogic/base-files/etc/board.d/02_network @@ -45,7 +45,7 @@ mediatek_setup_interfaces() tenbay,wr3000k) ucidef_set_interfaces_lan_wan "lan1 lan2 lan3" wan ;; - cudy,tr3000-v1|\ + cudy,tr3000*|\ glinet,gl-mt2500|\ glinet,gl-mt3000|\ glinet,gl-x3000|\ diff --git a/target/linux/mediatek/filogic/base-files/etc/hotplug.d/ieee80211/11_fix_wifi_mac b/target/linux/mediatek/filogic/base-files/etc/hotplug.d/ieee80211/11_fix_wifi_mac index c62d2e983..383ee95ca 100644 --- a/target/linux/mediatek/filogic/base-files/etc/hotplug.d/ieee80211/11_fix_wifi_mac +++ b/target/linux/mediatek/filogic/base-files/etc/hotplug.d/ieee80211/11_fix_wifi_mac @@ -43,7 +43,7 @@ case "$board" in [ "$PHYNBR" = "0" ] && macaddr_add $addr 1 > /sys${DEVPATH}/macaddress [ "$PHYNBR" = "1" ] && macaddr_setbit_la $(macaddr_add $addr 2) > /sys${DEVPATH}/macaddress ;; - cudy,tr3000-v1) + cudy,tr3000*) addr=$(mtd_get_mac_binary bdinfo 0xde00) [ "$PHYNBR" = "0" ] && echo "$addr" > /sys${DEVPATH}/macaddress [ "$PHYNBR" = "1" ] && macaddr_setbit_la $(macaddr_add $addr 1) > /sys${DEVPATH}/macaddress diff --git a/target/linux/mediatek/image/filogic.mk b/target/linux/mediatek/image/filogic.mk index b731d809f..469474034 100644 --- a/target/linux/mediatek/image/filogic.mk +++ b/target/linux/mediatek/image/filogic.mk @@ -316,6 +316,21 @@ define Device/cmcc_rax3000m-nand endef TARGET_DEVICES += cmcc_rax3000m-nand +define Device/cudy_tr3000-mod + DEVICE_VENDOR := Cudy + DEVICE_MODEL := TR3000 + DEVICE_VARIANT := (U-Boot mod) + DEVICE_DTS := mt7981b-cudy-tr3000-mod + DEVICE_DTS_DIR := ../dts + UBINIZE_OPTS := -E 5 + BLOCKSIZE := 128k + PAGESIZE := 2048 + KERNEL_IN_UBI := 1 + IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata + DEVICE_PACKAGES := kmod-usb3 kmod-mt7981-firmware mt7981-wo-firmware +endef +TARGET_DEVICES += cudy_tr3000-mod + define Device/cudy_tr3000-v1 DEVICE_VENDOR := Cudy DEVICE_MODEL := TR3000