aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xtarget/linux/brcm63xx/base-files/lib/brcm63xx.sh217
1 files changed, 154 insertions, 63 deletions
diff --git a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh
index d16d52bec5..4b603a1730 100755
--- a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh
+++ b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh
@@ -11,113 +11,208 @@ sys_mtd_part=""
brcm63xx_has_reset_button=""
ifname=""
-brcm63xx_legacy_detect() {
+brcm63xx_dt_detect() {
local board_name
case "$1" in
- 963281TAN)
- board_name="bcm963281tan"
+ "ADB P.DG A4001N")
+ board_name="a4001n"
;;
- 963281T_TEF)
+ "ADB P.DG A4001N1")
board_name="a4001n1"
;;
- 96328avng)
- board_name="bcm96328avng"
+ "Alcatel RG100A")
+ board_name="rg100a"
;;
- 96328dg2x2)
- board_name="a4401n"
+ "ASMAX AR 1004g")
+ board_name="ar100g"
;;
- 96328A-1241N)
- board_name="ar-5381u"
+ "Belkin F5D7633")
+ board_name="f5d7633"
;;
- 96328A-1441N1)
- board_name="ar-5387un"
+ "Broadcom 96348R reference board")
+ board_name="bcm96348r"
;;
- 96348GW)
- board_name="bcm96348gw"
+ "Broadcom bcm963281TAN reference board")
+ board_name="bcm963281tan"
;;
- 96348GW-11)
+ "Broadcom BCM96328avng reference board")
+ board_name="bcm6328avng"
+ ;;
+ "Broadcom BCM96345GW2 reference board")
+ board_name="bcm96345gw2"
+ ;;
+ "Broadcom BCM96348GW-10 reference board")
+ board_name="bcm96348gw-10"
+ ;;
+ "Broadcom BCM96348GW-11 reference board")
board_name="bcm96348gw-11"
;;
- 96358-502V)
- board_name="spw303v"
+ "Broadcom BCM96348GW reference board")
+ board_name="bcm96358gw"
;;
- 96368M-1341N)
- board_name="vr-3025un"
+ "Broadcom BCM96358VW reference board")
+ board_name="bcm96358vw"
+ ;;
+ "Broadcom BCM96358VW2 reference board")
+ board_name="bcm96358vw2"
+ ;;
+ "Broadcom BCM96368MVNgr reference board")
+ board_name="bcm96368mvngr"
+ ;;
+ "Broadcom BCM96368MVWG reference board")
+ board_name="bcm96368mvwg"
+ ;;
+ "BT Voyager V2500V")
+ board_name="v2500v"
+ ;;
+ "Comtrend AR-5381u")
+ board_name="ar-5381u"
+ ;;
+ "Comtrend AR-5387un")
+ board_name="ar-5387un"
;;
- 96368M-1541N)
+ "Comtrend CT-5365")
+ board_name="ct-5365"
+ ;;
+ "Comtrend CT-536+/CT-5621T")
+ board_name="ct-536p_5621t"
+ ;;
+ "Comtrend CT-6373")
+ board_name="ct-6373"
+ ;;
+ "Comtrend VR-3025u")
board_name="vr-3025u"
;;
- 96369R-1231N)
+ "Comtrend VR-3025un")
+ board_name="vr-3025un"
+ ;;
+ "Comtrend WAP-5813n")
board_name="wap-5813n"
;;
- AR1004G)
- board_name="ar1004g"
+ "Davolink DV-201AMR")
+ board_name="dv-201amr"
;;
- AW4139 |\
- AW4339U)
+ "D-Link DSL-2640B rev B2")
+ board_name="dsl-2640b-b"
+ ;;
+ "D-Link DSL-2650U")
+ board_name="dsl-2650u"
+ ;;
+ "D-Link DSL-2740B/DSL-2741B rev C2/3")
board_name="dsl-274xb-c"
;;
- AW5200B)
- board_name="dsl-275xb-d"
+ "D-Link DSL-2740B/DSL-2741B rev F1")
+ board_name="dsl-274xb-f"
;;
- CPVA642)
- board_name="cpva642"
+ "D-Link DVA-G3810BN/TL")
+ board_name="dva-g3810bn"
+ ;;
+ "Dynalink RTA1025W")
+ board_name="rta1025w"
+ ;;
+ "Dynalink RTA1320")
+ board_name="rta1320"
+ ;;
+ "Huawei EchoLife HG520v")
+ board_name="hg520v"
+ ;;
+ "Huawei EchoLife HG553")
+ board_name="hg553"
+ ;;
+ "Huawei EchoLife HG556a (version A)")
+ board_name="hg556a_a"
+ ;;
+ "Huawei EchoLife HG556a (version B)")
+ board_name="hg556a_b"
;;
- CT536_CT5621)
- board_name="ct536_ct5621"
+ "Huawei EchoLife HG556a (version C)")
+ board_name="hg556a_c"
+ ;;
+ "Inventel Livebox 1")
+ board_name="livebox1"
;;
- CVG834G_E15R3921)
+ "Netgear CVG834G")
board_name="cvg834g"
;;
- D-4P-W)
- board_name="dsl-2640b-b"
+ "Netgear DG834GT/PN")
+ board_name="dg834gt"
;;
- DGND3700v1_3800B)
+ "Netgear DGND3700v1/DGND3800B")
board_name="dgnd3700v1_dgnd3800b"
;;
- "F@ST2504n")
+ "Pirelli A226G")
+ board_name="a226g"
+ ;;
+ "Pirelli A226M")
+ board_name="a226m"
+ ;;
+ "Pirelli A226M-FWB")
+ board_name="a226m-fwb"
+ ;;
+ "Pirelli Alice Gate AGPF-S0")
+ board_name="agpf-s0"
+ ;;
+ "Sagem F@ST2404")
+ board_name="fast2404"
+ ;;
+ "Sagem F@ST2504n")
board_name="fast2504n"
;;
- 'F@ST2704V2')
+ "Sagem F@ST2604")
+ board_name="fast2604"
+ ;;
+ "Sagem F@ST2704V2")
board_name="fast2704v2"
;;
- GW6000)
- board_name="gw6000"
+ "SFR Neuf Box 4"*)
+ board_name="neufbox4"
;;
- GW6200)
- board_name="gw6200"
+ "SFR neufbox 6 (Sercomm)")
+ board_name="neufbox6"
;;
- HW553)
- board_name="hg553"
+ "T-Com Speedport W303 V")
+ board_name="spw303v"
;;
- HW556_A)
- board_name="hg556a_a"
+ "T-Com Speedport W500 V")
+ board_name="spw500v"
;;
- HW556_B)
- board_name="hg556a_b"
+ "TECOM GW6000")
+ board_name="g6000"
;;
- HW556_C)
- board_name="hg556a_c"
+ "TECOM GW6200")
+ board_name="g6200"
;;
- HW6358GW_B)
- board_name="hg620"
+ "Telsey CPVA642-type (CPA-ZNTE60T)")
+ board_name="cpva642"
;;
- NB6)
- board_name="neufbox6"
+ "TP-Link TD-W8900GB")
+ board_name="td-w8900gb"
;;
- P870HW-51a_v2)
+ "USRobotics 9108")
+ board_name="usr9108"
+ ;;
+ "Zyxel P870HW-51a v2")
board_name="p870hw-51a_v2"
;;
+ *)
+ board_name="unknown"
+ ;;
+ esac
+
+ echo "$board_name"
+}
+
+brcm63xx_legacy_detect() {
+ local board_name
+
+ case "$1" in
RTA770BW)
board_name="rta770bw"
;;
RTA770W)
board_name="rta770w"
;;
- SPW500V)
- board_name="spw500v"
- ;;
V2110)
board_name="v2110"
;;
@@ -134,18 +229,14 @@ brcm63xx_detect() {
board_id=$(awk 'BEGIN{FS="[ \t:/]+"} /system type/ {print $4}' /proc/cpuinfo)
- if [ "$board_id" = "96358VW" ] && [ -n "$(swconfig dev eth1 help 2>/dev/null)" ]; then
- board_id="DVAG3810BN"
- fi
-
if [ -e /proc/device-tree ]; then
model=$(cat /proc/device-tree/model)
+ board_name=$(brcm63xx_dt_detect "$model")
else
model="Unknown bcm63xx board"
+ board_name=$(brcm63xx_legacy_detect "$board_id")
fi
- board_name=$(brcm63xx_legacy_detect "$board_id")
-
case "$board_name" in
bcm963281tan)
status_led="963281TAN::power"