ar71xx: add user-space support for the NETGEAR WNDR4300
[openwrt.git] / target / linux / ar71xx / base-files / lib / ar71xx.sh
index fa73010..6ff6db9 100755 (executable)
@@ -6,18 +6,22 @@
 AR71XX_BOARD_NAME=
 AR71XX_MODEL=
 
-ar71xx_get_mem_total() {
-       $(awk '/MemTotal:/ {print($2)}' /proc/meminfo)
-}
+ar71xx_get_mtd_offset_size_format() {
+       local mtd="$1"
+       local offset="$2"
+       local size="$3"
+       local format="$4"
+       local dev
 
-ar71xx_get_mtd_part_magic() {
-       local part="$1"
-       local mtd
+       dev=$(find_mtd_part $mtd)
+       [ -z "$dev" ] && return
 
-       mtd=$(find_mtd_part $part)
-       [ -z "$mtd" ] && return
+       dd if=$dev bs=1 skip=$offset count=$size 2>/dev/null | hexdump -v -e "1/1 \"$format\""
+}
 
-       dd if=$mtd bs=4 count=1 2>/dev/null | hexdump -v -n 4 -e '1/1 "%02x"'
+ar71xx_get_mtd_part_magic() {
+       local mtd="$1"
+       ar71xx_get_mtd_offset_size_format "$mtd" 0 4 %02x
 }
 
 wndr3700_board_detect() {
@@ -33,13 +37,14 @@ wndr3700_board_detect() {
                machine="NETGEAR WNDR3700"
                ;;
        "33373031")
-               local mt
-
-               mt=$(ar71xx_get_mem_total)
-               if [ "$mt" -lt "65536" ]; then
+               local model
+               model=$(ar71xx_get_mtd_offset_size_format art 56 10 %c)
+               if [ -z "$model" ] || [ "$model" = $'\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff' ]; then
                        machine="NETGEAR WNDR3700v2"
+               elif [ -z "$model" ] || [ "$model" = $'\xff\xff\xff\xff\xff\xff\xff\xff\xffN' ]; then
+                       machine="NETGEAR WNDRMAC"
                else
-                       machine="NETGEAR WNDR3800"
+                       machine="NETGEAR $model"
                fi
                ;;
        esac
@@ -70,6 +75,9 @@ tplink_board_detect() {
        "070300"*)
                model="TP-Link TL-WR703N"
                ;;
+       "070100"*)
+               model="TP-Link TL-WA701N/ND"
+               ;;
        "074000"*)
                model="TP-Link TL-WR740N/ND"
                ;;
@@ -82,21 +90,48 @@ tplink_board_detect() {
        "084100"*)
                model="TP-Link TL-WR841N/ND"
                ;;
+       "084200"*)
+               model="TP-Link TL-WR842N/ND"
+               ;;
        "090100"*)
                model="TP-Link TL-WA901N/ND"
                ;;
        "094100"*)
                model="TP-Link TL-WR941N/ND"
                ;;
+       "104100"*)
+               model="TP-Link TL-WR1041N/ND"
+               ;;
        "104300"*)
                model="TP-Link TL-WR1043N/ND"
                ;;
+       "254300"*)
+               model="TP-Link TL-WR2543N/ND"
+               ;;
+       "110101"*)
+               model="TP-Link TL-MR11U"
+               ;;
+       "302000"*)
+               model="TP-Link TL-MR3020"
+               ;;
+       "304000"*)
+               model="TP-Link TL-MR3040"
+               ;;
        "322000"*)
                model="TP-Link TL-MR3220"
                ;;
        "342000"*)
                model="TP-Link TL-MR3420"
                ;;
+       "360000"*)
+               model="TP-Link TL-WDR3600"
+               ;;
+       "430000"*)
+               model="TP-Link TL-WDR4300"
+               ;;
+       "431000"*)
+               model="TP-Link TL-WDR4310"
+               ;;
        *)
                hwver=""
                ;;
@@ -115,33 +150,57 @@ ar71xx_board_detect() {
        *"AirRouter")
                name="airrouter"
                ;;
+       *"ALFA Network AP96")
+               name="alfa-ap96"
+               ;;
+       *"ALFA Network N2/N5")
+               name="alfa-nx"
+               ;;
        *ALL0258N)
                name="all0258n"
                ;;
+       *ALL0305)
+               name="all0305"
+               ;;
+       *ALL0315N)
+               name="all0315n"
+               ;;
+       *AP113)
+               name="ap113"
+               ;;
        *AP121)
                name="ap121"
                ;;
        *AP121-MINI)
                name="ap121-mini"
                ;;
+       *"AP136 reference board")
+               name="ap136"
+               ;;
        *AP81)
                name="ap81"
                ;;
        *AP83)
                name="ap83"
                ;;
-       *AP96)
+       *"Atheros AP96")
                name="ap96"
                ;;
        *AW-NR580)
                name="aw-nr580"
                ;;
-       *DB120)
+       *CAP4200AG)
+               name="cap4200ag"
+               ;;
+       *"DB120 reference board")
                name="db120"
                ;;
        *"DIR-600 rev. A1")
                name="dir-600-a1"
                ;;
+       *"DIR-615 rev. E4")
+               name="dir-615-e4"
+               ;;
        *"DIR-825 rev. B1")
                name="dir-825-b1"
                ;;
@@ -151,6 +210,9 @@ ar71xx_board_detect() {
        *JA76PF)
                name="ja76pf"
                ;;
+       *JA76PF2)
+               name="ja76pf2"
+               ;;
        *"Bullet M")
                name="bullet-m"
                ;;
@@ -160,9 +222,15 @@ ar71xx_board_detect() {
        *JWAP003)
                name="jwap003"
                ;;
+       *"Hornet-UB")
+               name="hornet-ub"
+               ;;
        *LS-SR71)
                name="ls-sr71"
                ;;
+       *MR600)
+               name="mr600"
+               ;;
        *MZK-W04NU)
                name="mzk-w04nu"
                ;;
@@ -175,10 +243,16 @@ ar71xx_board_detect() {
        *OM2P)
                name="om2p"
                ;;
+       *"OM2P HS")
+               name="om2p-hs"
+               ;;
+       *"OM2P LC")
+               name="om2p-lc"
+               ;;
        *PB42)
                name="pb42"
                ;;
-       *PB44)
+       *"PB44 reference board")
                name="pb44"
                ;;
        *PB92)
@@ -196,6 +270,9 @@ ar71xx_board_detect() {
        *"RouterBOARD 433UAH")
                name="rb-433u"
                ;;
+       *"RouterBOARD 435G")
+               name="rb-435g"
+               ;;
        *"RouterBOARD 450")
                name="rb-450"
                ;;
@@ -211,6 +288,21 @@ ar71xx_board_detect() {
        *"RouterBOARD 750")
                name="rb-750"
                ;;
+       *"RouterBOARD 750GL")
+               name="rb-750gl"
+               ;;
+       *"RouterBOARD 751")
+               name="rb-751"
+               ;;
+       *"RouterBOARD 751G")
+               name="rb-751g"
+               ;;
+       *"RouterBOARD 2011L")
+               name="rb-2011l"
+               ;;
+       *"RouterBOARD 2011UAS-2HnD")
+               name="rb-2011uas-2hnd"
+               ;;
        *"Rocket M")
                name="rocket-m"
                ;;
@@ -220,27 +312,54 @@ ar71xx_board_detect() {
        *"RouterStation Pro")
                name="routerstation-pro"
                ;;
+       *RW2458N)
+               name="rw2458n"
+               ;;
        *TEW-632BRP)
                name="tew-632brp"
                ;;
+       *TEW-673GRU)
+               name="tew-673gru"
+               ;;
+       *TEW-712BR)
+               name="tew-712br"
+               ;;
+       *"TL-WR1041N v2")
+               name="tl-wr1041n-v2"
+               ;;
        *TL-WR1043ND)
                name="tl-wr1043nd"
                ;;
+       *TL-WR2543N*)
+               name="tl-wr2543n"
+               ;;
        *"DIR-615 rev. C1")
                name="dir-615-c1"
                ;;
+       *TL-MR3020)
+               name="tl-mr3020"
+               ;;
+       *TL-MR3040)
+               name="tl-mr3040"
+               ;;
        *TL-MR3220)
                name="tl-mr3220"
                ;;
        *TL-MR3420)
                name="tl-mr3420"
                ;;
+       *TL-WA7510N)
+               name="tl-wa7510n"
+               ;;
        *TL-WA901ND)
                name="tl-wa901nd"
                ;;
        *"TL-WA901ND v2")
                name="tl-wa901nd-v2"
                ;;
+       *"TL-WDR3600/4300/4310")
+               name="tl-wdr4300"
+               ;;
        *TL-WR741ND)
                name="tl-wr741nd"
                ;;
@@ -250,12 +369,21 @@ ar71xx_board_detect() {
        *"TL-WR841N v1")
                name="tl-wr841n-v1"
                ;;
+       *"TL-WR841N/ND v7")
+               name="tl-wr841n-v7"
+               ;;
+       *"TL-WR841N/ND v8")
+               name="tl-wr841n-v8"
+               ;;
        *TL-WR941ND)
                name="tl-wr941nd"
                ;;
        *"TL-WR703N v1")
                name="tl-wr703n"
                ;;
+       *"TL-MR11U")
+               name="tl-mr11u"
+               ;;
        *UniFi)
                name="unifi"
                ;;
@@ -265,12 +393,24 @@ ar71xx_board_detect() {
        *WHR-HP-GN)
                name="whr-hp-gn"
                ;;
+       *WLAE-AG300N)
+               name="wlae-ag300n"
+               ;;
+       *"UniFiAP Outdoor")
+               name="unifi-outdoor"
+               ;;
        *WP543)
                name="wp543"
                ;;
-       *"WNDR3700/WNDR3800")
+       *WPE72)
+               name="wpe72"
+               ;;
+       *"WNDR3700/WNDR3800/WNDRMAC")
                wndr3700_board_detect "$machine"
                ;;
+       *"WNDR4300")
+               name="wndr4300"
+               ;;
        *WNR2000)
                name="wnr2000"
                ;;
@@ -289,6 +429,9 @@ ar71xx_board_detect() {
        *WZR-HP-G450H)
                name="wzr-hp-g450h"
                ;;
+       *WZR-HP-G300NH2)
+               name="wzr-hp-g300nh2"
+               ;;
        *WHR-HP-G300N)
                name="whr-hp-g300n"
                ;;
@@ -298,10 +441,16 @@ ar71xx_board_detect() {
        *ZCN-1523H-5)
                name="zcn-1523h-5"
                ;;
+       *EmbWir-Dorin)
+               name="ew-dorin"
+               ;;
+       *EmbWir-Dorin-Router)
+               name="ew-dorin-router"
+               ;;
        esac
 
        case "$machine" in
-       *TL-WR* | *TL-WA* | *TL-MR*)
+       *TL-WR* | *TL-WA* | *TL-MR* | *TL-WD*)
                tplink_board_detect "$machine"
                ;;
        esac