brcm63xx: populate /tmp/sysinfo
authorJonas Gorski <jogo@openwrt.org>
Mon, 16 Mar 2015 11:52:20 +0000 (11:52 +0000)
committerJonas Gorski <jogo@openwrt.org>
Mon, 16 Mar 2015 11:52:20 +0000 (11:52 +0000)
Take full board name from devicetree, if present. Provide a method
for retrieving the board name.

Signed-off-by: Jonas Gorski <jogo@openwrt.org>
SVN-Revision: 44833

target/linux/brcm63xx/base-files/lib/brcm63xx.sh

index e1d52c2e27a090d0eae898565e7d7975a95f489b..d16d52bec5ca3c0801125088fa7e004a69c15beb 100755 (executable)
@@ -11,178 +11,317 @@ sys_mtd_part=""
 brcm63xx_has_reset_button=""
 ifname=""
 
+brcm63xx_legacy_detect() {
+       local board_name
+
+       case "$1" in
+       963281TAN)
+               board_name="bcm963281tan"
+               ;;
+       963281T_TEF)
+               board_name="a4001n1"
+               ;;
+       96328avng)
+               board_name="bcm96328avng"
+               ;;
+       96328dg2x2)
+               board_name="a4401n"
+               ;;
+       96328A-1241N)
+               board_name="ar-5381u"
+               ;;
+       96328A-1441N1)
+               board_name="ar-5387un"
+               ;;
+       96348GW)
+               board_name="bcm96348gw"
+               ;;
+       96348GW-11)
+               board_name="bcm96348gw-11"
+               ;;
+       96358-502V)
+               board_name="spw303v"
+               ;;
+       96368M-1341N)
+               board_name="vr-3025un"
+               ;;
+       96368M-1541N)
+               board_name="vr-3025u"
+               ;;
+       96369R-1231N)
+               board_name="wap-5813n"
+               ;;
+       AR1004G)
+               board_name="ar1004g"
+               ;;
+       AW4139 |\
+       AW4339U)
+               board_name="dsl-274xb-c"
+               ;;
+       AW5200B)
+               board_name="dsl-275xb-d"
+               ;;
+       CPVA642)
+               board_name="cpva642"
+               ;;
+       CT536_CT5621)
+               board_name="ct536_ct5621"
+               ;;
+       CVG834G_E15R3921)
+               board_name="cvg834g"
+               ;;
+       D-4P-W)
+               board_name="dsl-2640b-b"
+               ;;
+       DGND3700v1_3800B)
+               board_name="dgnd3700v1_dgnd3800b"
+               ;;
+       "F@ST2504n")
+               board_name="fast2504n"
+               ;;
+       'F@ST2704V2')
+               board_name="fast2704v2"
+               ;;
+       GW6000)
+               board_name="gw6000"
+               ;;
+       GW6200)
+               board_name="gw6200"
+               ;;
+       HW553)
+               board_name="hg553"
+               ;;
+       HW556_A)
+               board_name="hg556a_a"
+               ;;
+       HW556_B)
+               board_name="hg556a_b"
+               ;;
+       HW556_C)
+               board_name="hg556a_c"
+               ;;
+       HW6358GW_B)
+               board_name="hg620"
+               ;;
+       NB6)
+               board_name="neufbox6"
+               ;;
+       P870HW-51a_v2)
+               board_name="p870hw-51a_v2"
+               ;;
+       RTA770BW)
+               board_name="rta770bw"
+               ;;
+       RTA770W)
+               board_name="rta770w"
+               ;;
+       SPW500V)
+               board_name="spw500v"
+               ;;
+       V2110)
+               board_name="v2110"
+               ;;
+       *)
+               board_name="unknown"
+               ;;
+       esac
+
+       echo "$board_name"
+}
+
 brcm63xx_detect() {
+       local board_name model
+
        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
 
-       case "$board_id" in
-       963281TAN)
+       if [ -e /proc/device-tree ]; then
+               model=$(cat /proc/device-tree/model)
+       else
+               model="Unknown bcm63xx board"
+       fi
+
+       board_name=$(brcm63xx_legacy_detect "$board_id")
+
+       case "$board_name" in
+       bcm963281tan)
                status_led="963281TAN::power"
                ifname=eth0
                ;;
-       963281T_TEF)
+       a4001n1)
                brcm63xx_has_reset_button="true"
                status_led="A4001N1:green:power"
                ifname=eth0
                ;;
-       96328avng)
+       bcm96328avng)
                status_led="96328avng::power"
                ifname=eth0
                ;;
-       96328dg2x2)
+       a4001n)
                brcm63xx_has_reset_button="true"
                status_led="A4001N:green:power"
                ifname="eth0"
                ;;
-       96328A-1241N)
+       ar-5381u)
                brcm63xx_has_reset_button="true"
                status_led="AR-5381u:green:power"
                ifname=eth0
                ;;
-       96328A-1441N1)
+       ar-5387un)
                brcm63xx_has_reset_button="true"
                status_led="AR-5387un:green:power"
                ifname=eth0
                ;;
-       96348GW)
+       bcm96348gw)
                status_led="96348GW:green:power"
                brcm63xx_has_reset_button="true"
                ifname=eth1
                ;;
-       96348GW-11)
+       bcm96348gw-11)
                status_led="96348GW-11:green:power"
                brcm63xx_has_reset_button="true"
                ifname=eth1
                ;;
-       96358-502V)
+       spw303v)
                status_led="spw303v:green:power+adsl"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       96368M-1341N)
+       vr-3025un)
                brcm63xx_has_reset_button="true"
                status_led="VR-3025un:green:power"
                ifname="eth0"
                ;;
-       96368M-1541N)
+       vr-3025u)
                brcm63xx_has_reset_button="true"
                status_led="VR-3025u:green:power"
                ifname="eth0"
                ;;
-       96369R-1231N)
+       wap-5813n)
                brcm63xx_has_reset_button="true"
                status_led="WAP-5813n:green:power"
                ifname="eth0"
                ;;
-       AR1004G)
+       ar1004g)
                status_led="AR1004G:green:power"
                brcm63xx_has_reset_button="true"
                ;;
-       AW4139 |\
-       AW4339U)
+       dsl-274xb-c)
                status_led="dsl-274xb:green:power"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       AW5200B)
+       dsl-275xb-d)
                status_led="dsl-275xb:green:power"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       CPVA642)
+       cpva642)
                status_led="CPVA642:green:power:"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       CT536_CT5621)
+       ct536_ct5621)
                status_led="CT536_CT5621:green:power"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       CVG834G_E15R3921)
+       cvg834g)
                status_led="CVG834G:green:power"
                ifname=eth0
                ;;
-       D-4P-W)
+       dsl-2640b-b)
                status_led="D-4P-W:green:power"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       DGND3700v1_3800B)
+       dgnd3700v1_dgnd3800b)
                status_led="DGND3700v1_3800B:green:power"
                brcm63xx_has_reset_button="true"
                ifname="eth0"
                ;;
-       "F@ST2504n")
+       fast2504n)
                status_led="fast2504n:green:ok"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       'F@ST2704V2')
+       fast2704v2)
                status_led="F@ST2704V2:green:power"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       GW6000)
+       gw6000)
                brcm63xx_has_reset_button="true"
                ifname=eth1
                ;;
-       GW6200)
+       gw6200)
                status_led="GW6200:green:line1"
                status_led2="GW6200:green:tel"
                brcm63xx_has_reset_button="true"
                ifname=eth1
                ;;
-       HW553)
+       hg553)
                status_led="HW553:blue:power"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       HW556*)
+       hg556a_*)
                status_led="HW556:red:power"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       HW6358GW_B)
+       hg520)
                status_led="HW520:green:net"
                brcm63xx_has_reset_button="true"
                ifname="eth0"
                ;;
-       NB6)
+       neufbox6)
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       P870HW-51a_v2)
+       p870hw-51a_v2)
                brcm63xx_has_reset_button="true"
                status_led="P870HW-51a:green:power"
                ifname="eth0"
                ;;
-       RTA770BW)
+       rta770bw)
                brcm63xx_has_reset_button="true"
                status_led="RTA770BW:green:diag"
                ifname=eth0
                ;;
-       RTA770W)
+       rta770w)
                brcm63xx_has_reset_button="true"
                status_led="RTA770W:green:diag"
                ifname=eth0
                ;;
-       SPW500V)
+       spw500v)
                status_led="SPW500V:green:power"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       V2110)
+       v2110)
                status_led="V2110:power:green"
                brcm63xx_has_reset_button="true"
                ifname=eth0
                ;;
-       *)
-               ;;
        esac
+
+       [ -e "/tmp/sysinfo" ] || mkdir -p "/tmp/sysinfo"
+
+       echo "$board_name" > /tmp/sysinfo/board_name
+       echo "$model" > /tmp/sysinfo/model
+}
+
+brcm63xx_board_name() {
+       local name
+
+       [ -f /tmp/sysinfo/board_name ] && name=$(cat /tmp/sysinfo/board_name)
+       [ -n "$name" ] || name="unknown"
+
+       echo $name
 }
 
 brcm63xx_detect