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 ace4c1acd556887161464a4df6d41f564f6098ef..f33ed82f625cce9f8aae6471ccc8a0c7b549149d 100644 (file)
 #!/bin/sh
 
-rt2x00_eeprom_die() {
-       echo "rt2x00 eeprom: " "$*"
-       exit 1
-}
+[ -e /lib/firmware/$FIRMWARE ] && exit 0
+
+. /lib/functions/caldata.sh
 
-rt2x00_eeprom_extract() {
+jboot_eeprom_extract() {
        local part=$1
        local offset=$2
-       local count=$3
        local mtd
 
-       . /lib/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 2>/dev/null || \
-               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
-
-. /lib/ramips.sh
-
-board=$(ramips_board_name)
+board=$(board_name)
 
 case "$FIRMWARE" in
 "soc_wmac.eeprom")
        case $board in
-       dir-300-b1 | \
-       dir-600-b1 | \
-       dir-600-b2)
-               rt2x00_eeprom_extract "devdata" 16384 272
-               ;;
-
-       dap-1350)
-               rt2x00_eeprom_extract "devdata" 0 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
+               ;;
+       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
                ;;
-
-       dir-615-d | \
-       rt-n10-plus | \
-       rt-g32-b1)
-               rt2x00_eeprom_extract "devconf" 0 272
-               ;;
-
-       f5d8235-v1 | \
-       f5d8235-v2)
-               rt2x00_eeprom_extract "u-boot" 262144 272
-               ;;
-
-       3g-6200n | \
-       all0239-3g | \
-       all0256n | \
-       all5002 | \
-       argus-atp52b | \
-       bc2 | \
-       broadway | \
-       carambola | \
-       dir-615-h1 | \
-       dir-620-a1 | \
-       esr-9753 | \
-       fonera20n | \
-       rt-n13u | \
-       freestation5 | \
-       hw550-3g | \
-       mofi3500-3gn | \
-       pwh2004 | \
-       nbg-419n | \
-       nw718 | \
-       omni-emb | \
-       psr-680w | \
-       rt-n15 | \
-       rt-n56u | \
-       sl-r7205 | \
-       v11st-fe | \
-       v22rw-2x2 | \
-       w306r-v20 | \
-       w502u | \
-       wcr-150gn | \
-       whr-g300n | \
-       wl-330n | \
-       wl-330n3g | \
-       wl-351 | \
-       wli-tx4-ag300n | \
-       wr512-3gn | \
-       wr6202 | \
-       ur-336un | \
-       xdxrn502j)
-               rt2x00_eeprom_extract "factory" 0 272
-               ;;
-
-       wl341v3)
-               rt2x00_eeprom_extract "board-nvram" 64880 272
-               ;;
-
        *)
-               rt2x00_eeprom_die "board $board is not supported yet"
-               ;;
-       esac
-       ;;
-
-"rt2x00pci_1_0.eeprom")
-       case $board in
-       rt-n56u)
-               rt2x00_eeprom_extract "factory" 32768 272
+               caldata_die "Please define mtd-eeprom in $board DTS file!"
                ;;
        esac
        ;;