Add support for Ubiquiti Rocket M XW devices
[openwrt.git] / target / linux / ar71xx / base-files / lib / ar71xx.sh
index 633fae1..645c5d9 100755 (executable)
@@ -37,22 +37,41 @@ wndr3700_board_detect() {
                machine="NETGEAR WNDR3700"
                ;;
        "33373031")
-               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
+               # Use awk to remove everything after the first zero byte
+               model="$(ar71xx_get_mtd_offset_size_format art 41 32 %c | awk 'BEGIN{FS="[[:cntrl:]]"} {print $1; exit}')"
+               case $model in
+               $'\xff'*)
+                       if [ "${model:24:1}" = 'N' ]; then
+                               machine="NETGEAR WNDRMAC"
+                       else
+                               machine="NETGEAR WNDR3700v2"
+                       fi
+                       ;;
+               '29763654+16+64'*)
+                       machine="NETGEAR ${model:14}"
+                       ;;
+               '29763654+16+128'*)
+                       machine="NETGEAR ${model:15}"
+                       ;;
+               *)
+                       # Unknown ID
                        machine="NETGEAR $model"
-               fi
-               ;;
+               esac
        esac
 
        AR71XX_BOARD_NAME="$name"
        AR71XX_MODEL="$machine"
 }
 
+cybertan_get_hw_magic() {
+       local part
+
+       part=$(find_mtd_part firmware)
+       [ -z "$part" ] && return 1
+
+       dd bs=8 count=1 skip=0 if=$part 2>/dev/null | hexdump -v -n 8 -e '1/1 "%02x"'
+}
+
 tplink_get_hwid() {
        local part
 
@@ -82,6 +101,18 @@ tplink_board_detect() {
        hwver="v${hwver#0}"
 
        case "$hwid" in
+       "015000"*)
+               model="EasyLink EL-M150"
+               ;;
+       "015300"*)
+               model="EasyLink EL-MINI"
+               ;;
+       "120000"*)
+               model="MERCURY MAC1200R"
+               ;;
+       "3C0001"*)
+               model="OOLITE"
+               ;;
        "070300"*)
                model="TP-Link TL-WR703N"
                ;;
@@ -94,6 +125,9 @@ tplink_board_detect() {
        "070100"*)
                model="TP-Link TL-WA701N/ND"
                ;;
+       "073000"*)
+               model="TP-Link TL-WA730RE"
+               ;;
        "074000"*)
                model="TP-Link TL-WR740N/ND"
                ;;
@@ -103,6 +137,15 @@ tplink_board_detect() {
        "074300"*)
                model="TP-Link TL-WR743N/ND"
                ;;
+       "075000"*)
+               model="TP-Link TL-WA750RE"
+               ;;
+       "721000"*)
+               model="TP-Link TL-WA7210N"
+               ;;
+       "751000"*)
+               model="TP-Link TL-WA7510N"
+               ;;
        "080100"*)
                model="TP-Link TL-WA801N/ND"
                ;;
@@ -115,11 +158,20 @@ tplink_board_detect() {
        "084200"*)
                model="TP-Link TL-WR842N/ND"
                ;;
+       "084300"*)
+               model="TP-Link TL-WR843N/ND"
+               ;;
+       "085000"*)
+               model="TP-Link TL-WA850RE"
+               ;;
+       "086000"*)
+               model="TP-Link TL-WA860RE"
+               ;;
        "090100"*)
                model="TP-Link TL-WA901N/ND"
                ;;
        "094100"*)
-               if [ "$hwid" == "09410002" -a "$mid" == "00420001" ]; then
+               if [ "$hwid" = "09410002" -a "$mid" = "00420001" ]; then
                        model="Rosewill RNX-N360RT"
                        hwver=""
                else
@@ -141,6 +193,9 @@ tplink_board_detect() {
        "001101"*)
                model="TP-Link TL-MR11U"
                ;;
+       "001201"*)
+               model="TP-Link TL-MR12U"
+               ;;
        "001301"*)
                model="TP-Link TL-MR13U"
                ;;
@@ -165,12 +220,29 @@ tplink_board_detect() {
        "430000"*)
                model="TP-Link TL-WDR4300"
                ;;
+       "430080"*)
+               iw reg set IL
+               model="TP-Link TL-WDR4300 (IL)"
+               ;;
        "431000"*)
                model="TP-Link TL-WDR4310"
                ;;
+       "49000002")
+               model="TP-Link TL-WDR4900"
+               ;;
        "453000"*)
                model="MERCURY MW4530R"
                ;;
+       "934100"*)
+               model="NC-LINK SMART-300"
+               ;;
+       "c50000"*)
+               model="TP-Link Archer C5"
+               ;;
+       "750000"*|\
+       "c70000"*)
+               model="TP-Link Archer C7"
+               ;;
        *)
                hwver=""
                ;;
@@ -179,6 +251,52 @@ tplink_board_detect() {
        AR71XX_MODEL="$model $hwver"
 }
 
+tplink_pharos_get_model_string() {
+       local part
+       part=$(find_mtd_part 'product-info')
+       [ -z "$part" ] && return 1
+
+       # The returned string will end with \r\n, but we don't remove it here
+       # to simplify matching against it in the sysupgrade image check
+       dd if=$part bs=1 skip=4360 2>/dev/null | head -n 1
+}
+
+tplink_pharos_board_detect() {
+       local model_string="$(tplink_pharos_get_model_string | tr -d '\r')"
+       local oIFS="$IFS"; IFS=":"; set -- $model_string; IFS="$oIFS"
+       local model
+
+       case "$1" in
+       'CPE210(TP-LINK|UN|N300-2)')
+               model='TP-Link CPE210'
+               ;;
+       'CPE220(TP-LINK|UN|N300-2)')
+               model='TP-Link CPE220'
+               ;;
+       'CPE510(TP-LINK|UN|N300-5)')
+               model='TP-Link CPE510'
+               ;;
+       'CPE520(TP-LINK|UN|N300-5)')
+               model='TP-Link CPE520'
+               ;;
+       esac
+
+       [ -n "$model" ] && AR71XX_MODEL="$model v$2"
+}
+
+gl_inet_board_detect() {
+       local size="$(mtd_get_part_size 'firmware')"
+
+       case "$size" in
+       8192000)
+               AR71XX_MODEL='GL-iNet 6408A v1'
+               ;;
+       16580608)
+               AR71XX_MODEL='GL-iNet 6416A v1'
+               ;;
+       esac
+}
+
 ar71xx_board_detect() {
        local machine
        local name
@@ -186,6 +304,15 @@ ar71xx_board_detect() {
        machine=$(awk 'BEGIN{FS="[ \t]+:[ \t]"} /machine/ {print $2}' /proc/cpuinfo)
 
        case "$machine" in
+       *"Oolite V1.0")
+               name="oolite"
+               ;;
+       *"AC1750DB")
+               name="f9k1115v2"
+               ;;
+       *"AirGateway")
+               name="airgateway"
+               ;;
        *"AirRouter")
                name="airrouter"
                ;;
@@ -231,6 +358,9 @@ ar71xx_board_detect() {
        *AP83)
                name="ap83"
                ;;
+       *"Archer C5")
+               name="archer-c5"
+               ;;
        *"Archer C7")
                name="archer-c7"
                ;;
@@ -243,15 +373,28 @@ ar71xx_board_detect() {
        *CAP4200AG)
                name="cap4200ag"
                ;;
+       *"CPE210/220/510/520")
+               name="cpe510"
+               tplink_pharos_board_detect
+               ;;
        *"DB120 reference board")
                name="db120"
                ;;
+       *"DGL-5500 rev. A1")
+               name="dgl-5500-a1"
+               ;;
+       *"DHP-1565 rev. A1")
+               name="dhp-1565-a1"
+               ;;
        *"DIR-505 rev. A1")
                name="dir-505-a1"
                ;;
        *"DIR-600 rev. A1")
                name="dir-600-a1"
                ;;
+       *"DIR-615 rev. E1")
+               name="dir-615-e1"
+               ;;
        *"DIR-615 rev. E4")
                name="dir-615-e4"
                ;;
@@ -264,9 +407,31 @@ ar71xx_board_detect() {
        *"DIR-835 rev. A1")
                name="dir-835-a1"
                ;;
+       *"Dragino v2")
+               name="dragino2"
+               ;;
+       *"EAP300 v2")
+               name="eap300v2"
+               ;;
        *EAP7660D)
                name="eap7660d"
                ;;
+       *EL-M150)
+               name="el-m150"
+               ;;
+       *EL-MINI)
+               name="el-mini"
+               ;;
+       *"GL-CONNECT INET v1")
+               name="gl-inet"
+               gl_inet_board_detect
+               ;;
+       *"EnGenius ESR1750")
+               name="esr1750"
+               ;;
+       *"EnGenius ESR900")
+               name="esr900"
+               ;;
        *JA76PF)
                name="ja76pf"
                ;;
@@ -276,9 +441,15 @@ ar71xx_board_detect() {
        *"Bullet M")
                name="bullet-m"
                ;;
+       *"Loco M XW")
+               name="loco-m-xw"
+               ;;
        *"Nanostation M")
                name="nanostation-m"
                ;;
+       *"Nanostation M XW")
+               name="nanostation-m-xw"
+               ;;
        *JWAP003)
                name="jwap003"
                ;;
@@ -297,15 +468,30 @@ ar71xx_board_detect() {
        *LS-SR71)
                name="ls-sr71"
                ;;
+       *"MAC1200R")
+               name="mc-mac1200r"
+               ;;
        *MR600v2)
                name="mr600v2"
                ;;
        *MR600)
                name="mr600"
                ;;
+       *MR900)
+               name="mr900"
+               ;;
+       *MR900v2)
+               name="mr900v2"
+               ;;
        *"My Net N600")
                name="mynet-n600"
                ;;
+       *"My Net N750")
+               name="mynet-n750"
+               ;;
+       *"WD My Net Wi-Fi Range Extender")
+               name="mynet-rext"
+               ;;
        *MZK-W04NU)
                name="mzk-w04nu"
                ;;
@@ -315,15 +501,30 @@ ar71xx_board_detect() {
        *"NBG460N/550N/550NH")
                name="nbg460n_550n_550nh"
                ;;
+       *"Zyxel NBG6716")
+               name="nbg6716"
+               ;;
        *OM2P)
                name="om2p"
                ;;
+       *OM2Pv2)
+               name="om2pv2"
+               ;;
        *"OM2P HS")
                name="om2p-hs"
                ;;
+       *"OM2P HSv2")
+               name="om2p-hsv2"
+               ;;
        *"OM2P LC")
                name="om2p-lc"
                ;;
+       *OM5P)
+               name="om5p"
+               ;;
+       *"OM5P AN")
+               name="om5p-an"
+               ;;
        *PB42)
                name="pb42"
                ;;
@@ -333,6 +534,9 @@ ar71xx_board_detect() {
        *PB92)
                name="pb92"
                ;;
+       *"Qihoo 360 C301")
+               name="qihoo-c301"
+               ;;
        *"RouterBOARD 411/A/AH")
                name="rb-411"
                ;;
@@ -372,21 +576,54 @@ ar71xx_board_detect() {
        *"RouterBOARD 751G")
                name="rb-751g"
                ;;
+       *"RouterBOARD 911G-2HPnD")
+               name="rb-911g-2hpnd"
+               ;;
+       *"RouterBOARD 911G-5HPnD")
+               name="rb-911g-5hpnd"
+               ;;
+       *"RouterBOARD 911G-5HPacD")
+               name="rb-911g-5hpacd"
+               ;;
+       *"RouterBOARD 912UAG-2HPnD")
+               name="rb-912uag-2hpnd"
+               ;;
+       *"RouterBOARD 912UAG-5HPnD")
+               name="rb-912uag-5hpnd"
+               ;;
        *"RouterBOARD 951G-2HnD")
                name="rb-951g-2hnd"
                ;;
+       *"RouterBOARD 951Ui-2HnD")
+               name="rb-951ui-2hnd"
+               ;;
        *"RouterBOARD 2011L")
                name="rb-2011l"
                ;;
        *"RouterBOARD 2011UAS")
                name="rb-2011uas"
                ;;
+       *"RouterBOARD 2011UiAS")
+               name="rb-2011uias"
+               ;;
        *"RouterBOARD 2011UAS-2HnD")
                name="rb-2011uas-2hnd"
                ;;
+       *"RouterBOARD 2011UiAS-2HnD")
+               name="rb-2011uias-2hnd"
+               ;;
+       *"RouterBOARD SXT Lite2")
+               name="rb-sxt2n"
+               ;;
+       *"RouterBOARD SXT Lite5")
+               name="rb-sxt5n"
+               ;;
        *"Rocket M")
                name="rocket-m"
                ;;
+       *"Rocket M XW")
+               name="rocket-m-xw"
+               ;;
        *RouterStation)
                name="routerstation"
                ;;
@@ -396,6 +633,9 @@ ar71xx_board_detect() {
        *RW2458N)
                name="rw2458n"
                ;;
+       *"SMART-300")
+               name="smart-300"
+               ;;
        *TEW-632BRP)
                name="tew-632brp"
                ;;
@@ -414,6 +654,9 @@ ar71xx_board_detect() {
        *TL-WR1043ND)
                name="tl-wr1043nd"
                ;;
+       *"TL-WR1043ND v2")
+               name="tl-wr1043nd-v2"
+               ;;
        *TL-WR2543N*)
                name="tl-wr2543n"
                ;;
@@ -441,21 +684,48 @@ ar71xx_board_detect() {
        *"TL-MR3420 v2")
                name="tl-mr3420-v2"
                ;;
-       *TL-WA7510N)
+       *"TL-WA701ND v2")
+               name="tl-wa701nd-v2"
+               ;;
+       *"TL-WA7210N v2")
+               name="tl-wa7210n-v2"
+               ;;
+       *TL-WA750RE)
+               name="tl-wa750re"
+               ;;
+       *"TL-WA7510N v1")
                name="tl-wa7510n"
                ;;
+       *TL-WA850RE)
+               name="tl-wa850re"
+               ;;
+       *TL-WA860RE)
+               name="tl-wa860re"
+               ;;
+       *"TL-WA830RE v2")
+               name="tl-wa830re-v2"
+               ;;
+       *"TL-WA801ND v2")
+               name="tl-wa801nd-v2"
+               ;;
        *TL-WA901ND)
                name="tl-wa901nd"
                ;;
        *"TL-WA901ND v2")
                name="tl-wa901nd-v2"
                ;;
+       *"TL-WA901ND v3")
+               name="tl-wa901nd-v3"
+               ;;
        *"TL-WDR3500")
                name="tl-wdr3500"
                ;;
        *"TL-WDR3600/4300/4310")
                name="tl-wdr4300"
                ;;
+       *"TL-WDR4900 v2")
+               name="tl-wdr4900-v2"
+               ;;
        *TL-WR741ND)
                name="tl-wr741nd"
                ;;
@@ -471,9 +741,18 @@ ar71xx_board_detect() {
        *"TL-WR841N/ND v8")
                name="tl-wr841n-v8"
                ;;
+       *"TL-WR841N/ND v9")
+               name="tl-wr841n-v9"
+               ;;
+       *"TL-WR842N/ND v2")
+               name="tl-wr842n-v2"
+               ;;
        *TL-WR941ND)
                name="tl-wr941nd"
                ;;
+       *"TL-WR941N/ND v5")
+               name="tl-wr941nd-v5"
+               ;;
        *"TL-WR703N v1")
                name="tl-wr703n"
                ;;
@@ -489,9 +768,15 @@ ar71xx_board_detect() {
        *"TL-MR11U")
                name="tl-mr11u"
                ;;
-       *"TL-MR13U")
+       *"TL-MR12U")
+               name="tl-mr12u"
+               ;;
+       *"TL-MR13U v1")
                name="tl-mr13u"
                ;;
+       *"Tube2H")
+               name="tube2h"
+               ;;
        *UniFi)
                name="unifi"
                ;;
@@ -510,21 +795,39 @@ ar71xx_board_detect() {
        *"UniFiAP Outdoor")
                name="unifi-outdoor"
                ;;
+       *"UniFiAP Outdoor+")
+               name="unifi-outdoor-plus"
+               ;;
        *WP543)
                name="wp543"
                ;;
        *WPE72)
                name="wpe72"
                ;;
+       *WPJ344)
+               name="wpj344"
+               ;;
+       *WPJ558)
+               name="wpj558"
+               ;;
        *WNDAP360)
                name="wndap360"
                ;;
        *"WNDR3700/WNDR3800/WNDRMAC")
                wndr3700_board_detect "$machine"
                ;;
+       *"R6100")
+               name="r6100"
+               ;;
+       *"WNDR3700v4")
+               name="wndr3700v4"
+               ;;
        *"WNDR4300")
                name="wndr4300"
                ;;
+       *"WNR2000 V4")
+               name="wnr2000-v4"
+               ;;
        *"WNR2000 V3")
                name="wnr2000-v3"
                ;;
@@ -537,12 +840,18 @@ ar71xx_board_detect() {
        *"WNR612 V2")
                name="wnr612-v2"
                ;;
+       *"WNR1000 V2")
+               name="wnr1000-v2"
+               ;;
        *WRT160NL)
                name="wrt160nl"
                ;;
        *WRT400N)
                name="wrt400n"
                ;;
+       *"WZR-450HP2")
+               name="wzr-450hp2"
+               ;;
        *"WZR-HP-AG300H/WZR-600DHP")
                name="wzr-hp-ag300h"
                ;;
@@ -576,13 +885,16 @@ ar71xx_board_detect() {
        *"Sitecom WLR-8100")
                name="wlr8100"
                ;;
+       *"BHU BXU2000n-2 rev. A1")
+               name="bxu2000n-2-a1"
+               ;;
+       *"HiWiFi HC6361")
+               name="hiwifi-hc6361"
+               ;;
        esac
 
-       case "$machine" in
-       *TL-WR* | *TL-WA* | *TL-MR* | *TL-WD*)
+       [ -z "$AR71XX_MODEL" ] && [ "${machine:0:8}" = 'TP-LINK ' ] && \
                tplink_board_detect "$machine"
-               ;;
-       esac
 
        [ -z "$name" ] && name="unknown"