treewide: move MAC address patch functions to common library
[openwrt/openwrt.git] / target / linux / ramips / base-files / etc / hotplug.d / firmware / 10-rt2x00-eeprom
index 47f7f016af166f85c945127d049ce8066422305b..f33ed82f625cce9f8aae6471ccc8a0c7b549149d 100644 (file)
@@ -1,73 +1,46 @@
 #!/bin/sh
 
-rt2x00_eeprom_die() {
-       echo "rt2x00 eeprom: " "$*"
-       exit 1
-}
+[ -e /lib/firmware/$FIRMWARE ] && exit 0
 
-rt2x00_eeprom_extract() {
+. /lib/functions/caldata.sh
+
+jboot_eeprom_extract() {
        local part=$1
        local offset=$2
-       local count=$3
        local mtd
 
-       . /etc/functions.sh
-
        mtd=$(find_mtd_part $part)
        [ -n "$mtd" ] || \
-               rt2x00_eeprom_die "no mtd device found for partition $part"
+               caldata_die "no mtd device found for partition $part"
 
-       dd if=$mtd of=/lib/firmware/$FIRMWARE bs=1 skip=$offset count=$count || \
-               rt2x00_eeprom_die "failed to extract from $mtd"
+       jboot_config_read -i $mtd -o $offset -e /lib/firmware/$FIRMWARE  2>/dev/null || \
+               caldata_die "failed to extract from $mtd"
 }
 
-[ -e /lib/firmware/$FIRMWARE ] && exit 0
+board=$(board_name)
 
 case "$FIRMWARE" in
-"RT288X.eeprom" | \
-"RT305X.eeprom")
-       . /lib/ramips.sh
-
-       local board=$(ramips_board_name)
-
+"soc_wmac.eeprom")
        case $board in
-       dir-300-b1 | \
-       dir-600-b1 | \
-       dir-600-b2)
-               rt2x00_eeprom_extract "devdata" 16384 272
+       dlink,dir-510l|\
+       dlink,dwr-116-a1|\
+       dlink,dwr-118-a1|\
+       dlink,dwr-118-a2|\
+       dlink,dwr-921-c1|\
+       dlink,dwr-922-e2|\
+       lava,lr-25g001)
+               wan_mac=$(jboot_config_read -m -i $(find_mtd_part "config") -o 0xE000)
+               wifi_mac=$(macaddr_add "$wan_mac" 1)
+               jboot_eeprom_extract "config" 0xE000
+               caldata_patch_mac $wifi_mac 0x4
                ;;
-
-       rt-g32-b1)
-               rt2x00_eeprom_extract "devconf" 0 272
-               ;;
-
-       f5d8235-v2)
-               rt2x00_eeprom_extract "u-boot" 262144 272
+       dovado,tiny-ac)
+               wifi_mac=$(mtd_get_mac_ascii u-boot-env INIC_MAC_ADDR)
+               caldata_extract "factory" 0x0 0x200
+               caldata_patch_mac $wifi_mac 0x4
                ;;
-
-       argus-atp52b | \
-       bc2 | \
-       esr-9753 | \
-       fonera20n | \
-       hw550-3g | \
-       mofi3500-3gn | \
-       pwh2004 | \
-       nbg-419n | \
-       nw718 | \
-       omni-emb | \
-       rt-n15 | \
-       v22rw-2x2 | \
-       w502u | \
-       wcr-150gn | \
-       whr-g300n | \
-       wl-351 | \
-       wli-tx4-ag300n | \
-       wr512-3gn)
-               rt2x00_eeprom_extract "factory" 0 272
-               ;;
-
        *)
-               rt2x00_eeprom_die "board $board is not supported yet"
+               caldata_die "Please define mtd-eeprom in $board DTS file!"
                ;;
        esac
        ;;