system_config() {
local cfg="$1"
- local hostname
-
- config_get hostname "$cfg" hostname
- echo "${hostname:-OpenWrt}" > /proc/sys/kernel/hostname
+
+ local hostname conloglevel timezone
+
+ config_get hostname "$cfg" hostname 'OpenWrt'
+ echo "$hostname" > /proc/sys/kernel/hostname
config_get conloglevel "$cfg" conloglevel
- [ -n "$conloglevel" ] && dmesg -n "$conloglevel"
+ config_get buffersize "$cfg" buffersize
+ [ -z "$conloglevel" -a -z "$buffersize" ] || dmesg ${conloglevel:+-n $conloglevel} ${buffersize:+-s $buffersize}
- config_get timezone "$cfg" timezone
- [ -z "$timezone" ] && timezone=UTC
+ config_get timezone "$cfg" timezone 'UTC'
echo "$timezone" > /tmp/TZ
- config_get log_ip "$cfg" log_ip
- config_get log_size "$cfg" log_size
- config_get log_port "$cfg" log_port
- [ -x /sbin/syslogd ] && syslogd -C${log_size:-16} ${log_ip:+-L -R $log_ip${log_port:+:$log_port}}
- [ -x /sbin/klogd ] && klogd
+ if [ -x /sbin/syslogd ]; then
+ local log_ip log_size log_port log_type log_file
+ config_get log_ip "$cfg" log_ip
+ config_get log_size "$cfg" log_size 16
+ config_get log_port "$cfg" log_port 514
+ config_get log_type "$cfg" log_type circular
+ config_get log_file "$cfg" log_file "/var/log/messages"
+ if [ "$log_type" = "file" ]; then
+ syslogd -s $log_size -O $log_file ${log_ip:+-L -R ${log_ip}:${log_port}} -S
+ else
+ syslogd -C${log_size} ${log_ip:+-L -R ${log_ip}:${log_port}}
+ fi
+ fi
+ config_get klogconloglevel "$cfg" klogconloglevel
+ [ -x /sbin/klogd ] && klogd ${klogconloglevel:+-c $klogconloglevel}
}
apply_uci_config() {(
touch /var/log/lastlog
touch /tmp/resolv.conf.auto
ln -sf /tmp/resolv.conf.auto /tmp/resolv.conf
+ grep -q debugfs /proc/filesystems && mount -t debugfs debugfs /sys/kernel/debug
[ "$FAILSAFE" = "true" ] && touch /tmp/.failsafe
killall -q hotplug2