summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMathias Kresin <dev@kresin.me>2017-04-07 18:01:17 +0200
committerMathias Kresin <dev@kresin.me>2017-07-15 23:13:34 +0200
commit78cf5eed6edaa38561e9c9c3ff14a36c1eedfadd (patch)
tree2fcf94f7ad5e69d0ea2ef62a83365f5afd98bb6b
parentac3e05c5d757334944fbf1f14583164cd1d69172 (diff)
downloadopenwrt-78cf5eed6edaa38561e9c9c3ff14a36c1eedfadd.tar.gz
openwrt-78cf5eed6edaa38561e9c9c3ff14a36c1eedfadd.tar.bz2
openwrt-78cf5eed6edaa38561e9c9c3ff14a36c1eedfadd.zip
treewide: do board detection during preinit
Do the board detection during preinit to unify it across all targets. Signed-off-by: Mathias Kresin <dev@kresin.me>
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/01_sysinfo12
-rw-r--r--target/linux/cns3xxx/base-files/lib/cns3xxx.sh27
-rw-r--r--target/linux/cns3xxx/base-files/lib/preinit/01_sysinfo9
-rwxr-xr-xtarget/linux/imx6/base-files/lib/imx6.sh1
-rw-r--r--target/linux/imx6/base-files/lib/preinit/01_sysinfo9
-rw-r--r--target/linux/ixp4xx/base-files/lib/ixp4xx.sh50
-rw-r--r--target/linux/ixp4xx/base-files/lib/preinit/01_sysinfo9
-rwxr-xr-xtarget/linux/kirkwood/base-files/lib/kirkwood.sh1
-rw-r--r--target/linux/kirkwood/base-files/lib/preinit/01_sysinfo9
-rwxr-xr-xtarget/linux/mvebu/base-files/lib/mvebu.sh1
-rw-r--r--target/linux/mvebu/base-files/lib/preinit/01_sysinfo9
-rw-r--r--target/linux/orion/base-files/lib/preinit/01_sysinfo12
-rw-r--r--target/linux/ppc40x/base-files/lib/preinit/01_sysinfo12
13 files changed, 136 insertions, 25 deletions
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/01_sysinfo b/target/linux/brcm47xx/base-files/lib/preinit/01_sysinfo
new file mode 100644
index 0000000000..8a2de67bc5
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/01_sysinfo
@@ -0,0 +1,12 @@
+#!/bin/sh
+
+do_sysinfo_brcm47xx() {
+ local name="$(sed -ne 's/^machine[ \t]*: //p' /proc/cpuinfo)"
+ [ -z "$name" ] && name="unknown"
+
+ [ -e "/tmp/sysinfo/" ] || mkdir -p "/tmp/sysinfo/"
+ echo "$name" > /tmp/sysinfo/board_name
+ echo "unknown" > /tmp/sysinfo/model
+}
+
+boot_hook_add preinit_main do_sysinfo_brcm47xx
diff --git a/target/linux/cns3xxx/base-files/lib/cns3xxx.sh b/target/linux/cns3xxx/base-files/lib/cns3xxx.sh
index 476f9be21d..fb2c1043e1 100644
--- a/target/linux/cns3xxx/base-files/lib/cns3xxx.sh
+++ b/target/linux/cns3xxx/base-files/lib/cns3xxx.sh
@@ -1,9 +1,9 @@
#!/bin/sh
-#
-# Copyright (C) 2012 OpenWrt.org
-#
-cns3xxx_board_name() {
+CNS3XXX_BOARD_NAME=
+CNS3XXX_MODEL=
+
+cns3xxx_board_detect() {
local machine
local name
@@ -17,6 +17,21 @@ cns3xxx_board_name() {
name="generic";
;;
esac
-
- echo $name
+
+ [ -z "$CNS3XXX_BOARD_NAME" ] && CNS3XXX_BOARD_NAME="$name"
+ [ -z "$CNS3XXX_MODEL" ] && CNS3XXX_MODEL="$machine"
+
+ [ -e "/tmp/sysinfo/" ] || mkdir -p "/tmp/sysinfo/"
+
+ echo "$CNS3XXX_BOARD_NAME" > /tmp/sysinfo/board_name
+ echo "$CNS3XXX_MODEL" > /tmp/sysinfo/model
+}
+
+cns3xxx_board_name() {
+ local name
+
+ [ -f /tmp/sysinfo/board_name ] && name=$(cat /tmp/sysinfo/board_name)
+ [ -z "$name" ] && name="unknown"
+
+ echo "$name"
}
diff --git a/target/linux/cns3xxx/base-files/lib/preinit/01_sysinfo b/target/linux/cns3xxx/base-files/lib/preinit/01_sysinfo
new file mode 100644
index 0000000000..cc7b5551e9
--- /dev/null
+++ b/target/linux/cns3xxx/base-files/lib/preinit/01_sysinfo
@@ -0,0 +1,9 @@
+#!/bin/sh
+
+do_sysinfo_cns3xxx() {
+ . /lib/cns3xxx.sh
+
+ cns3xxx_board_detect
+}
+
+boot_hook_add preinit_main do_sysinfo_cns3xxx
diff --git a/target/linux/imx6/base-files/lib/imx6.sh b/target/linux/imx6/base-files/lib/imx6.sh
index 94adf1ccb3..385c54f9f9 100755
--- a/target/linux/imx6/base-files/lib/imx6.sh
+++ b/target/linux/imx6/base-files/lib/imx6.sh
@@ -75,7 +75,6 @@ imx6_board_detect() {
imx6_board_name() {
local name
- [ -f /tmp/sysinfo/board_name ] || imx6_board_detect
[ -f /tmp/sysinfo/board_name ] && name=$(cat /tmp/sysinfo/board_name)
[ -z "$name" ] && name="unknown"
diff --git a/target/linux/imx6/base-files/lib/preinit/01_sysinfo b/target/linux/imx6/base-files/lib/preinit/01_sysinfo
new file mode 100644
index 0000000000..0a91aed010
--- /dev/null
+++ b/target/linux/imx6/base-files/lib/preinit/01_sysinfo
@@ -0,0 +1,9 @@
+#!/bin/sh
+
+do_sysinfo_imx6() {
+ . /lib/imx6.sh
+
+ imx6_board_detect
+}
+
+boot_hook_add preinit_main do_sysinfo_imx6
diff --git a/target/linux/ixp4xx/base-files/lib/ixp4xx.sh b/target/linux/ixp4xx/base-files/lib/ixp4xx.sh
index f7a6b76eda..7486356b9c 100644
--- a/target/linux/ixp4xx/base-files/lib/ixp4xx.sh
+++ b/target/linux/ixp4xx/base-files/lib/ixp4xx.sh
@@ -3,23 +3,41 @@
# Copyright (C) 2012 OpenWrt.org
#
-ixp4xx_board_name() {
- local machine
- local name
-
- machine=$(awk 'BEGIN{FS="[ \t]+:[ \t]"} /Hardware/ {print $2}' /proc/cpuinfo)
-
- case "$machine" in
- "Gateworks Cambria"*)
- name="cambria"
- ;;
- "Gateworks Avila"*)
- name="avila"
- ;;
- *)
- name="generic";
- ;;
+IXP4XX_BOARD_NAME=
+IXP4XX_MODEL=
+
+ixp4xx_board_detect() {
+ local machine
+ local name
+
+ machine=$(awk 'BEGIN{FS="[ \t]+:[ \t]"} /Hardware/ {print $2}' /proc/cpuinfo)
+
+ case "$machine" in
+ "Gateworks Cambria"*)
+ name="cambria"
+ ;;
+ "Gateworks Avila"*)
+ name="avila"
+ ;;
+ *)
+ name="generic";
+ ;;
esac
+ [ -z "$IXP4XX_BOARD_NAME" ] && IXP4XX_BOARD_NAME="$name"
+ [ -z "$IXP4XX_MODEL" ] && IXP4XX_MODEL="$machine"
+
+ [ -e "/tmp/sysinfo/" ] || mkdir -p "/tmp/sysinfo/"
+
+ echo "$IXP4XX_BOARD_NAME" > /tmp/sysinfo/board_name
+ echo "$IXP4XX_MODEL" > /tmp/sysinfo/model
+}
+
+ixp4xx_board_name() {
+ local name
+
+ [ -f /tmp/sysinfo/board_name ] && name=$(cat /tmp/sysinfo/board_name)
+ [ -z "$name" ] && name="unknown"
+
echo $name
}
diff --git a/target/linux/ixp4xx/base-files/lib/preinit/01_sysinfo b/target/linux/ixp4xx/base-files/lib/preinit/01_sysinfo
new file mode 100644
index 0000000000..7699e9a10e
--- /dev/null
+++ b/target/linux/ixp4xx/base-files/lib/preinit/01_sysinfo
@@ -0,0 +1,9 @@
+#!/bin/sh
+
+do_sysinfo_ixp4xx() {
+ . /lib/ixp4xx.sh
+
+ ixp4xx_board_detect
+}
+
+boot_hook_add preinit_main do_sysinfo_ixp4xx
diff --git a/target/linux/kirkwood/base-files/lib/kirkwood.sh b/target/linux/kirkwood/base-files/lib/kirkwood.sh
index c29a315f79..20c6ebdfde 100755
--- a/target/linux/kirkwood/base-files/lib/kirkwood.sh
+++ b/target/linux/kirkwood/base-files/lib/kirkwood.sh
@@ -90,7 +90,6 @@ kirkwood_board_detect() {
kirkwood_board_name() {
local name
- [ -f /tmp/sysinfo/board_name ] || kirkwood_board_detect
[ -f /tmp/sysinfo/board_name ] && name=$(cat /tmp/sysinfo/board_name)
[ -z "$name" ] && name="unknown"
diff --git a/target/linux/kirkwood/base-files/lib/preinit/01_sysinfo b/target/linux/kirkwood/base-files/lib/preinit/01_sysinfo
new file mode 100644
index 0000000000..d45fc92ec3
--- /dev/null
+++ b/target/linux/kirkwood/base-files/lib/preinit/01_sysinfo
@@ -0,0 +1,9 @@
+#!/bin/sh
+
+do_sysinfo_kirkwood() {
+ . /lib/kirkwood.sh
+
+ kirkwood_board_detect
+}
+
+boot_hook_add preinit_main do_sysinfo_kirkwood
diff --git a/target/linux/mvebu/base-files/lib/mvebu.sh b/target/linux/mvebu/base-files/lib/mvebu.sh
index ecf3d44848..9096860dd4 100755
--- a/target/linux/mvebu/base-files/lib/mvebu.sh
+++ b/target/linux/mvebu/base-files/lib/mvebu.sh
@@ -75,7 +75,6 @@ mvebu_board_detect() {
mvebu_board_name() {
local name
- [ -f /tmp/sysinfo/board_name ] || mvebu_board_detect
[ -f /tmp/sysinfo/board_name ] && name=$(cat /tmp/sysinfo/board_name)
[ -z "$name" ] && name="unknown"
diff --git a/target/linux/mvebu/base-files/lib/preinit/01_sysinfo b/target/linux/mvebu/base-files/lib/preinit/01_sysinfo
new file mode 100644
index 0000000000..6f473cfa13
--- /dev/null
+++ b/target/linux/mvebu/base-files/lib/preinit/01_sysinfo
@@ -0,0 +1,9 @@
+#!/bin/sh
+
+do_sysinfo_mvebu() {
+ . /lib/mvebu.sh
+
+ mvebu_board_detect
+}
+
+boot_hook_add preinit_main do_sysinfo_mvebu
diff --git a/target/linux/orion/base-files/lib/preinit/01_sysinfo b/target/linux/orion/base-files/lib/preinit/01_sysinfo
new file mode 100644
index 0000000000..1ef07d774f
--- /dev/null
+++ b/target/linux/orion/base-files/lib/preinit/01_sysinfo
@@ -0,0 +1,12 @@
+#!/bin/sh
+
+do_sysinfo_orion() {
+ local name="$(sed -n /Hardware/s/.*:.//p /proc/cpuinfo)"
+ [ -z "$name" ] && name="unknown"
+
+ [ -e "/tmp/sysinfo/" ] || mkdir -p "/tmp/sysinfo/"
+ echo "$name" > /tmp/sysinfo/board_name
+ echo "unknown" > /tmp/sysinfo/model
+}
+
+boot_hook_add preinit_main do_sysinfo_orion
diff --git a/target/linux/ppc40x/base-files/lib/preinit/01_sysinfo b/target/linux/ppc40x/base-files/lib/preinit/01_sysinfo
new file mode 100644
index 0000000000..9f82c84b2b
--- /dev/null
+++ b/target/linux/ppc40x/base-files/lib/preinit/01_sysinfo
@@ -0,0 +1,12 @@
+#!/bin/sh
+
+do_sysinfo_ppc40x() {
+ local name="$(awk 'BEGIN{FS="[ \t]+:[ \t]"} /model/ {print $2}' /proc/cpuinfo)"
+ [ -z "$name" ] && name="unknown"
+
+ [ -e "/tmp/sysinfo/" ] || mkdir -p "/tmp/sysinfo/"
+ echo "$name" > /tmp/sysinfo/board_name
+ echo "unknown" > /tmp/sysinfo/model
+}
+
+boot_hook_add preinit_main do_sysinfo_ppc40x