ar71xx: add user-space support for the BXU2000n-2 A1 board
[openwrt.git] / target / linux / ar71xx / base-files / lib / ar71xx.sh
index 900c9ad..cd03168 100755 (executable)
@@ -62,12 +62,22 @@ tplink_get_hwid() {
        dd if=$part bs=4 count=1 skip=16 2>/dev/null | hexdump -v -n 4 -e '1/1 "%02x"'
 }
 
+tplink_get_mid() {
+       local part
+
+       part=$(find_mtd_part firmware)
+       [ -z "$part" ] && return 1
+
+       dd if=$part bs=4 count=1 skip=17 2>/dev/null | hexdump -v -n 4 -e '1/1 "%02x"'
+}
+
 tplink_board_detect() {
        local model="$1"
        local hwid
        local hwver
 
        hwid=$(tplink_get_hwid)
+       mid=$(tplink_get_mid)
        hwver=${hwid:6:2}
        hwver="v${hwver#0}"
 
@@ -75,6 +85,9 @@ tplink_board_detect() {
        "070300"*)
                model="TP-Link TL-WR703N"
                ;;
+       "071000"*)
+               model="TP-Link TL-WR710N"
+               ;;
        "072001"*)
                model="TP-Link TL-WR720N"
                ;;
@@ -106,7 +119,12 @@ tplink_board_detect() {
                model="TP-Link TL-WA901N/ND"
                ;;
        "094100"*)
-               model="TP-Link TL-WR941N/ND"
+               if [ "$hwid" == "09410002" -a "$mid" == "00420001" ]; then
+                       model="Rosewill RNX-N360RT"
+                       hwver=""
+               else
+                       model="TP-Link TL-WR941N/ND"
+               fi
                ;;
        "104100"*)
                model="TP-Link TL-WR1041N/ND"
@@ -117,9 +135,15 @@ tplink_board_detect() {
        "254300"*)
                model="TP-Link TL-WR2543N/ND"
                ;;
-       "110101"*)
+       "001001"*)
+               model="TP-Link TL-MR10U"
+               ;;
+       "001101"*)
                model="TP-Link TL-MR11U"
                ;;
+       "001301"*)
+               model="TP-Link TL-MR13U"
+               ;;
        "302000"*)
                model="TP-Link TL-MR3020"
                ;;
@@ -144,6 +168,9 @@ tplink_board_detect() {
        "431000"*)
                model="TP-Link TL-WDR4310"
                ;;
+       "453000"*)
+               model="MERCURY MW4530R"
+               ;;
        *)
                hwver=""
                ;;
@@ -204,6 +231,9 @@ ar71xx_board_detect() {
        *AP83)
                name="ap83"
                ;;
+       *"Archer C7")
+               name="archer-c7"
+               ;;
        *"Atheros AP96")
                name="ap96"
                ;;
@@ -216,6 +246,9 @@ ar71xx_board_detect() {
        *"DB120 reference board")
                name="db120"
                ;;
+       *"DIR-505 rev. A1")
+               name="dir-505-a1"
+               ;;
        *"DIR-600 rev. A1")
                name="dir-600-a1"
                ;;
@@ -250,7 +283,16 @@ ar71xx_board_detect() {
                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"
@@ -261,6 +303,9 @@ ar71xx_board_detect() {
        *MR600)
                name="mr600"
                ;;
+       *"My Net N600")
+               name="mynet-n600"
+               ;;
        *MZK-W04NU)
                name="mzk-w04nu"
                ;;
@@ -333,6 +378,9 @@ ar71xx_board_detect() {
        *"RouterBOARD 2011L")
                name="rb-2011l"
                ;;
+       *"RouterBOARD 2011UAS")
+               name="rb-2011uas"
+               ;;
        *"RouterBOARD 2011UAS-2HnD")
                name="rb-2011uas-2hnd"
                ;;
@@ -357,6 +405,9 @@ ar71xx_board_detect() {
        *TEW-712BR)
                name="tew-712br"
                ;;
+       *TEW-732BR)
+               name="tew-732br"
+               ;;
        *"TL-WR1041N v2")
                name="tl-wr1041n-v2"
                ;;
@@ -375,6 +426,9 @@ ar71xx_board_detect() {
        *TL-MR3040)
                name="tl-mr3040"
                ;;
+       *"TL-MR3040 v2")
+               name="tl-mr3040-v2"
+               ;;
        *TL-MR3220)
                name="tl-mr3220"
                ;;
@@ -423,12 +477,21 @@ ar71xx_board_detect() {
        *"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"
+               ;;
        *UniFi)
                name="unifi"
                ;;
@@ -468,6 +531,12 @@ ar71xx_board_detect() {
        *WNR2000)
                name="wnr2000"
                ;;
+       *WNR2200)
+               name="wnr2200"
+               ;;
+       *"WNR612 V2")
+               name="wnr612-v2"
+               ;;
        *WRT160NL)
                name="wrt160nl"
                ;;
@@ -501,6 +570,15 @@ ar71xx_board_detect() {
        *EmbWir-Dorin-Router)
                name="ew-dorin-router"
                ;;
+       "8devices Carambola2"*)
+               name="carambola2"
+               ;;
+       *"Sitecom WLR-8100")
+               name="wlr8100"
+               ;;
+       *"BHU BXU2000n-2 rev. A1")
+               name="bxu2000n-2-a1"
+               ;;
        esac
 
        case "$machine" in