aboutsummaryrefslogtreecommitdiffstats
path: root/package/base-files/files/etc/init.d/system
diff options
context:
space:
mode:
authorJohn Crispin <blogic@openwrt.org>2014-02-18 13:33:40 +0000
committerJohn Crispin <blogic@openwrt.org>2014-02-18 13:33:40 +0000
commit6cd00fa25cf595a729264418d25470ba4ad73083 (patch)
treea437a5380ff266fa8af92bdef6ba1f9b534dda5d /package/base-files/files/etc/init.d/system
parente2af138349ebc13b30139b3d3367200789746b8f (diff)
downloadmaster-187ad058-6cd00fa25cf595a729264418d25470ba4ad73083.tar.gz
master-187ad058-6cd00fa25cf595a729264418d25470ba4ad73083.tar.bz2
master-187ad058-6cd00fa25cf595a729264418d25470ba4ad73083.zip
base-files: split /etc/init.d/boot into 2 files
this allows us to bind a procd trigger to system.@system[-1] Signed-off-by: John Crispin <blogic@openwrt.org> git-svn-id: svn://svn.openwrt.org/openwrt/trunk@39615 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/base-files/files/etc/init.d/system')
-rwxr-xr-xpackage/base-files/files/etc/init.d/system51
1 files changed, 51 insertions, 0 deletions
diff --git a/package/base-files/files/etc/init.d/system b/package/base-files/files/etc/init.d/system
new file mode 100755
index 0000000000..24a9fdee68
--- /dev/null
+++ b/package/base-files/files/etc/init.d/system
@@ -0,0 +1,51 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2014 OpenWrt.org
+
+START=10
+USE_PROCD=1
+
+validate_system_section()
+{
+ uci_validate_section system system "${1}" \
+ 'hostname:string:OpenWrt' \
+ 'conloglevel:uinteger' \
+ 'buffersize:uinteger' \
+ 'timezone:string:UTC' \
+ 'zonename:string'
+
+ return $?
+}
+
+system_config() {
+ local cfg="$1"
+
+ local hostname conloglevel buffersize timezone zonename
+
+ validate_system_section "${1}" || {
+ echo "validation failed"
+ return 1
+ }
+
+ echo "$hostname" > /proc/sys/kernel/hostname
+ [ -z "$conloglevel" -a -z "$buffersize" ] || dmesg ${conloglevel:+-n $conloglevel} ${buffersize:+-s $buffersize}
+ echo "$timezone" > /tmp/TZ
+ [ -n "$zonename" ] && [ -f "/usr/share/zoneinfo/$zonename" ] && ln -s "/usr/share/zoneinfo/$zonename" /tmp/localtime
+
+ # apply timezone to kernel
+ date -k
+}
+
+reload_service() {
+ config_load system
+ config_foreach system_config system
+}
+
+service_triggers()
+{
+ procd_add_reload_trigger "system"
+ procd_add_validation validate_system_section
+}
+
+start_service() {
+ reload_service
+}