X-Git-Url: https://git.archive.openwrt.org/?p=openwrt.git;a=blobdiff_plain;f=target%2Flinux%2Far71xx%2Fbase-files%2Flib%2Far71xx.sh;h=645c5d9a506becf263c72a00770595cc471ec6e2;hp=d89f097a083d9b3b70970b760ffbde0e95754be3;hb=19ac39e650f4d0a2506d5841babd9978940ce2c8;hpb=4bc7c8d549437a344988d8fa2056a3e9de2127bf diff --git a/target/linux/ar71xx/base-files/lib/ar71xx.sh b/target/linux/ar71xx/base-files/lib/ar71xx.sh index d89f097a08..645c5d9a50 100755 --- a/target/linux/ar71xx/base-files/lib/ar71xx.sh +++ b/target/linux/ar71xx/base-files/lib/ar71xx.sh @@ -37,16 +37,26 @@ 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" @@ -91,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" ;; @@ -103,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" ;; @@ -115,6 +140,12 @@ tplink_board_detect() { "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" ;; @@ -127,14 +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 @@ -156,6 +193,9 @@ tplink_board_detect() { "001101"*) model="TP-Link TL-MR11U" ;; + "001201"*) + model="TP-Link TL-MR12U" + ;; "001301"*) model="TP-Link TL-MR13U" ;; @@ -180,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="" ;; @@ -194,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 @@ -201,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" ;; @@ -246,6 +358,9 @@ ar71xx_board_detect() { *AP83) name="ap83" ;; + *"Archer C5") + name="archer-c5" + ;; *"Archer C7") name="archer-c7" ;; @@ -258,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" ;; @@ -279,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" ;; @@ -291,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" ;; @@ -312,15 +468,27 @@ 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" ;; @@ -333,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" ;; @@ -351,6 +534,9 @@ ar71xx_board_detect() { *PB92) name="pb92" ;; + *"Qihoo 360 C301") + name="qihoo-c301" + ;; *"RouterBOARD 411/A/AH") name="rb-411" ;; @@ -390,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" ;; @@ -414,6 +633,9 @@ ar71xx_board_detect() { *RW2458N) name="rw2458n" ;; + *"SMART-300") + name="smart-300" + ;; *TEW-632BRP) name="tew-632brp" ;; @@ -462,15 +684,27 @@ ar71xx_board_detect() { *"TL-MR3420 v2") name="tl-mr3420-v2" ;; + *"TL-WA701ND v2") + name="tl-wa701nd-v2" + ;; + *"TL-WA7210N v2") + name="tl-wa7210n-v2" + ;; *TL-WA750RE) name="tl-wa750re" ;; - *TL-WA7510N) + *"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" ;; @@ -480,12 +714,18 @@ ar71xx_board_detect() { *"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" ;; @@ -501,12 +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" ;; @@ -522,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" ;; @@ -543,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" ;; @@ -570,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" ;; @@ -612,13 +888,13 @@ ar71xx_board_detect() { *"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"