ar71xx: add board support for ubnt loco m xw
[openwrt/svn-archive/archive.git] / target / linux / ar71xx / base-files / lib / ar71xx.sh
index 19f19e7ae79193a486093b9094df6a17611a06d7..a7cbb80946633b60fd6493a5d443bbe17be74111 100755 (executable)
@@ -53,6 +53,15 @@ wndr3700_board_detect() {
        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,15 +91,30 @@ tplink_board_detect() {
        hwver="v${hwver#0}"
 
        case "$hwid" in
+       "015000"*)
+               model="EasyLink EL-M150"
+               ;;
+       "015300"*)
+               model="EasyLink EL-MINI"
+               ;;
+       "3C0001"*)
+               model="OOLITE"
+               ;;
        "070300"*)
                model="TP-Link TL-WR703N"
                ;;
+       "071000"*)
+               model="TP-Link TL-WR710N"
+               ;;
        "072001"*)
                model="TP-Link TL-WR720N"
                ;;
        "070100"*)
                model="TP-Link TL-WA701N/ND"
                ;;
+       "073000"*)
+               model="TP-Link TL-WA730RE"
+               ;;
        "074000"*)
                model="TP-Link TL-WR740N/ND"
                ;;
@@ -100,6 +124,12 @@ tplink_board_detect() {
        "074300"*)
                model="TP-Link TL-WR743N/ND"
                ;;
+       "075000"*)
+               model="TP-Link TL-WA750RE"
+               ;;
+       "751000"*)
+               model="TP-Link TL-WA7510N"
+               ;;
        "080100"*)
                model="TP-Link TL-WA801N/ND"
                ;;
@@ -112,6 +142,12 @@ tplink_board_detect() {
        "084200"*)
                model="TP-Link TL-WR842N/ND"
                ;;
+       "085000"*)
+               model="TP-Link TL-WA850RE"
+               ;;
+       "086000"*)
+               model="TP-Link TL-WA860RE"
+               ;;
        "090100"*)
                model="TP-Link TL-WA901N/ND"
                ;;
@@ -138,6 +174,9 @@ tplink_board_detect() {
        "001101"*)
                model="TP-Link TL-MR11U"
                ;;
+       "001301"*)
+               model="TP-Link TL-MR13U"
+               ;;
        "302000"*)
                model="TP-Link TL-MR3020"
                ;;
@@ -159,9 +198,22 @@ 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"
+               ;;
        *)
                hwver=""
                ;;
@@ -177,6 +229,12 @@ ar71xx_board_detect() {
        machine=$(awk 'BEGIN{FS="[ \t]+:[ \t]"} /machine/ {print $2}' /proc/cpuinfo)
 
        case "$machine" in
+       *"Oolite V1.0")
+               name="oolite"
+               ;;
+       *"AirGateway")
+               name="airgateway"
+               ;;
        *"AirRouter")
                name="airrouter"
                ;;
@@ -222,6 +280,9 @@ ar71xx_board_detect() {
        *AP83)
                name="ap83"
                ;;
+       *"Archer C5")
+               name="archer-c5"
+               ;;
        *"Archer C7")
                name="archer-c7"
                ;;
@@ -237,9 +298,15 @@ ar71xx_board_detect() {
        *"DB120 reference board")
                name="db120"
                ;;
+       *"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"
                ;;
@@ -252,9 +319,30 @@ 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"
+               ;;
+       *"EnGenius ESR1750")
+               name="esr1750"
+               ;;
+       *"EnGenius ESR900")
+               name="esr900"
+               ;;
        *JA76PF)
                name="ja76pf"
                ;;
@@ -264,14 +352,29 @@ 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"
                ;;
        *"Hornet-UB")
-               name="hornet-ub"
+               local size
+               size=$(awk '/firmware/ { print $2 }' /proc/mtd)
+
+               if [ "x$size" = "x00790000" ]; then
+                       name="hornet-ub"
+               fi
+
+               if [ "x$size" = "x00f90000" ]; then
+                       name="hornet-ub-x2"
+               fi
                ;;
        *LS-SR71)
                name="ls-sr71"
@@ -282,6 +385,15 @@ ar71xx_board_detect() {
        *MR600)
                name="mr600"
                ;;
+       *"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"
                ;;
@@ -291,15 +403,27 @@ 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"
+               ;;
        *PB42)
                name="pb42"
                ;;
@@ -348,18 +472,45 @@ ar71xx_board_detect() {
        *"RouterBOARD 751G")
                name="rb-751g"
                ;;
+       *"RouterBOARD 911G-2HPnD")
+               name="rb-911g-2hpnd"
+               ;;
+       *"RouterBOARD 911G-5HPnD")
+               name="rb-911g-5hpnd"
+               ;;
+       *"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"
                ;;
@@ -372,6 +523,9 @@ ar71xx_board_detect() {
        *RW2458N)
                name="rw2458n"
                ;;
+       *"SMART-300")
+               name="smart-300"
+               ;;
        *TEW-632BRP)
                name="tew-632brp"
                ;;
@@ -381,12 +535,18 @@ ar71xx_board_detect() {
        *TEW-712BR)
                name="tew-712br"
                ;;
+       *TEW-732BR)
+               name="tew-732br"
+               ;;
        *"TL-WR1041N v2")
                name="tl-wr1041n-v2"
                ;;
        *TL-WR1043ND)
                name="tl-wr1043nd"
                ;;
+       *"TL-WR1043ND v2")
+               name="tl-wr1043nd-v2"
+               ;;
        *TL-WR2543N*)
                name="tl-wr2543n"
                ;;
@@ -399,6 +559,9 @@ ar71xx_board_detect() {
        *TL-MR3040)
                name="tl-mr3040"
                ;;
+       *"TL-MR3040 v2")
+               name="tl-mr3040-v2"
+               ;;
        *TL-MR3220)
                name="tl-mr3220"
                ;;
@@ -411,21 +574,39 @@ ar71xx_board_detect() {
        *"TL-MR3420 v2")
                name="tl-mr3420-v2"
                ;;
-       *TL-WA7510N)
+       *TL-WA750RE)
+               name="tl-wa750re"
+               ;;
+       *"TL-WA7510N v1")
                name="tl-wa7510n"
                ;;
+       *TL-WA850RE)
+               name="tl-wa850re"
+               ;;
+       *"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"
                ;;
@@ -441,18 +622,36 @@ 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-WR703N v1")
                name="tl-wr703n"
                ;;
+       *"TL-WR710N v1")
+               name="tl-wr710n"
+               ;;
        *"TL-WR720N v3")
                name="tl-wr720n-v3"
                ;;
+       *"TL-MR10U")
+               name="tl-mr10u"
+               ;;
        *"TL-MR11U")
                name="tl-mr11u"
                ;;
+       *"TL-MR13U")
+               name="tl-mr13u"
+               ;;
+       *"Tube2H")
+               name="tube2h"
+               ;;
        *UniFi)
                name="unifi"
                ;;
@@ -483,6 +682,9 @@ ar71xx_board_detect() {
        *"WNDR3700/WNDR3800/WNDRMAC")
                wndr3700_board_detect "$machine"
                ;;
+       *"WNDR3700v4")
+               name="wndr3700v4"
+               ;;
        *"WNDR4300")
                name="wndr4300"
                ;;
@@ -492,6 +694,12 @@ ar71xx_board_detect() {
        *WNR2000)
                name="wnr2000"
                ;;
+       *WNR2200)
+               name="wnr2200"
+               ;;
+       *"WNR612 V2")
+               name="wnr612-v2"
+               ;;
        *WRT160NL)
                name="wrt160nl"
                ;;
@@ -528,6 +736,15 @@ ar71xx_board_detect() {
        "8devices Carambola2"*)
                name="carambola2"
                ;;
+       *"Sitecom WLR-8100")
+               name="wlr8100"
+               ;;
+       *"BHU BXU2000n-2 rev. A1")
+               name="bxu2000n-2-a1"
+               ;;
+       *"HiWiFi HC6361")
+               name="hiwifi-hc6361"
+               ;;
        esac
 
        case "$machine" in