mediatek: filogic: asus-tuf-ax4200: use NVMEM-on-UBI

Use newly added support for NVMEM-on-UBI instead of extracting MAC
address and WiFi EEPROM data in userspace.

Signed-off-by: Daniel Golle <daniel@makrotopia.org>
This commit is contained in:
Daniel Golle 2024-02-19 03:18:47 +00:00
parent 33197d22f0
commit 25c9ebc6d4
3 changed files with 52 additions and 15 deletions

View File

@ -13,6 +13,7 @@
aliases { aliases {
serial0 = &uart0; serial0 = &uart0;
label-mac-device = &gmac0;
led-boot = &led_system; led-boot = &led_system;
led-failsafe = &led_system; led-failsafe = &led_system;
led-running = &led_system; led-running = &led_system;
@ -21,7 +22,7 @@
chosen { chosen {
stdout-path = "serial0:115200n8"; stdout-path = "serial0:115200n8";
bootargs-override = "ubi.mtd=UBI_DEV"; bootargs-override = "";
}; };
memory { memory {
@ -101,6 +102,8 @@
/* LAN */ /* LAN */
compatible = "mediatek,eth-mac"; compatible = "mediatek,eth-mac";
reg = <0>; reg = <0>;
nvmem-cells = <&macaddr_factory_4>;
nvmem-cell-names = "mac-address";
phy-mode = "2500base-x"; phy-mode = "2500base-x";
fixed-link { fixed-link {
@ -215,25 +218,66 @@
spi-tx-bus-width = <4>; spi-tx-bus-width = <4>;
spi-rx-bus-width = <4>; spi-rx-bus-width = <4>;
partitions: partitions { /*
* ASUS bootloader tries to replace the partitions defined in
* Device Tree and by that also deletes all additional properties
* needed for UBI and NVMEM-on-UBI.
* Prevent this from happening by tricking the loader to delete and
* replace a bait node instead.
*/
partitions: dummy {
compatible = "u-boot-dummy-partitions";
#address-cells = <1>;
#size-cells = <1>;
partition@0 {
reg = <0x0 0x0>;
label = "remove_me";
};
};
partitions {
compatible = "fixed-partitions"; compatible = "fixed-partitions";
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
partition@0 { partition@0 {
label = "bootloader";
reg = <0x0 0x400000>; reg = <0x0 0x400000>;
label = "bootloader";
read-only; read-only;
}; };
partition@400000 { partition@400000 {
label = "UBI_DEV"; compatible = "linux,ubi";
reg = <0x400000 0xfc00000>; reg = <0x400000 0xfc00000>;
label = "UBI_DEV";
volumes {
ubi_factory: ubi-volume-factory {
volname = "Factory";
};
};
}; };
}; };
}; };
}; };
&ubi_factory {
nvmem-layout {
compatible = "fixed-layout";
#address-cells = <1>;
#size-cells = <1>;
eeprom_factory_0: eeprom@0 {
reg = <0x0 0x1000>;
};
macaddr_factory_4: macaddr@4 {
reg = <0x4 0x6>;
};
};
};
&switch { &switch {
ports { ports {
#address-cells = <1>; #address-cells = <1>;
@ -340,10 +384,12 @@
}; };
&wifi { &wifi {
status = "okay"; nvmem-cells = <&eeprom_factory_0>;
pinctrl-names = "default", "dbdc"; nvmem-cell-names = "eeprom";
pinctrl-0 = <&wf_2g_5g_pins>; pinctrl-0 = <&wf_2g_5g_pins>;
pinctrl-1 = <&wf_dbdc_pins>; pinctrl-1 = <&wf_dbdc_pins>;
pinctrl-names = "default", "dbdc";
status = "okay";
}; };
&trng { &trng {

View File

@ -109,7 +109,6 @@ mediatek_setup_macs()
local label_mac="" local label_mac=""
case $board in case $board in
asus,tuf-ax4200|\
asus,tuf-ax6000) asus,tuf-ax6000)
CI_UBIPART="UBI_DEV" CI_UBIPART="UBI_DEV"
addr=$(mtd_get_mac_binary_ubi "Factory" 0x4) addr=$(mtd_get_mac_binary_ubi "Factory" 0x4)

View File

@ -57,14 +57,6 @@ case "$FIRMWARE" in
;; ;;
esac esac
;; ;;
"mediatek/mt7986_eeprom_mt7976_dbdc.bin")
case "$board" in
asus,tuf-ax4200)
CI_UBIPART="UBI_DEV"
caldata_extract_ubi "Factory" 0x0 0x1000
;;
esac
;;
"mediatek/mt7986_eeprom_mt7976_dual.bin") "mediatek/mt7986_eeprom_mt7976_dual.bin")
case "$board" in case "$board" in
asus,tuf-ax6000) asus,tuf-ax6000)