aboutsummaryrefslogtreecommitdiffstats
path: root/package/base-files/files/etc
diff options
context:
space:
mode:
Diffstat (limited to 'package/base-files/files/etc')
-rwxr-xr-xpackage/base-files/files/etc/init.d/boot9
-rwxr-xr-xpackage/base-files/files/etc/init.d/led63
-rwxr-xr-xpackage/base-files/files/etc/init.d/sysfixtime22
-rw-r--r--package/base-files/files/etc/profile2
-rwxr-xr-xpackage/base-files/files/etc/rc.common14
-rw-r--r--package/base-files/files/etc/shadow2
-rw-r--r--package/base-files/files/etc/shinit21
-rw-r--r--package/base-files/files/etc/sysctl.d/10-default.conf1
8 files changed, 93 insertions, 41 deletions
diff --git a/package/base-files/files/etc/init.d/boot b/package/base-files/files/etc/init.d/boot
index a1e8e828dd2..d17754d0879 100755
--- a/package/base-files/files/etc/init.d/boot
+++ b/package/base-files/files/etc/init.d/boot
@@ -21,9 +21,10 @@ boot() {
[ -f /proc/mounts ] || /sbin/mount_root
[ -f /proc/jffs2_bbc ] && echo "S" > /proc/jffs2_bbc
- mkdir -p /var/run
- mkdir -p /var/log
mkdir -p /var/lock
+ chmod 1777 /var/lock
+ mkdir -p /var/log
+ mkdir -p /var/run
mkdir -p /var/state
mkdir -p /var/tmp
mkdir -p /tmp/.uci
@@ -38,6 +39,7 @@ boot() {
grep -q pstore /proc/filesystems && /bin/mount -o noatime -t pstore pstore /sys/fs/pstore
[ "$FAILSAFE" = "true" ] && touch /tmp/.failsafe
+ touch /tmp/.config_pending
/sbin/kmodloader
[ ! -f /etc/config/wireless ] && {
@@ -46,7 +48,10 @@ boot() {
}
/bin/config_generate
+ rm -f /tmp/.config_pending
+ /sbin/wifi config
uci_apply_defaults
+ sync
# temporary hack until configd exists
/sbin/reload_config
diff --git a/package/base-files/files/etc/init.d/led b/package/base-files/files/etc/init.d/led
index 51cb8b51784..ea2688cab29 100755
--- a/package/base-files/files/etc/init.d/led
+++ b/package/base-files/files/etc/init.d/led
@@ -3,6 +3,39 @@
START=96
+led_color_set() {
+ local cfg="$1"
+ local sysfs="$2"
+
+ local max_b
+ local colors
+ local color
+ local multi_intensity
+ local value
+ local write
+
+ [ -e /sys/class/leds/${sysfs}/multi_intensity ] || return
+ [ -e /sys/class/leds/${sysfs}/multi_index ] || return
+
+ max_b="$(cat /sys/class/leds/${sysfs}/max_brightness)"
+ colors="$(cat /sys/class/leds/${sysfs}/multi_index | tr " " "\n")"
+ multi_intensity=""
+ for color in $colors; do
+ config_get value $1 "color_${color}" "0"
+ [ "$value" -gt 0 ] && write=1
+ [ "$value" -gt "$max_b" ] && value="$max_b"
+ multi_intensity="${multi_intensity}${value} "
+ done
+
+ # Check if any color is configured
+ [ "$write" = 1 ] || return
+ # Remove last whitespace
+ multi_intensity="${multi_intensity:0:-1}"
+
+ echo "setting '${name}' led color to '${multi_intensity}'"
+ echo "${multi_intensity}" > /sys/class/leds/${sysfs}/multi_intensity
+}
+
load_led() {
local name
local sysfs
@@ -29,7 +62,7 @@ load_led() {
config_get delay $1 delay "150"
config_get message $1 message ""
config_get gpio $1 gpio "0"
- config_get inverted $1 inverted "0"
+ config_get_bool inverted $1 inverted "0"
# execute application led trigger
[ -f "/usr/libexec/led-trigger/${trigger}" ] && {
@@ -49,26 +82,38 @@ load_led() {
[ -e /sys/class/leds/${sysfs}/brightness ] && {
echo "setting up led ${name}"
- printf "%s %s %d\n" \
+ printf "%s %s %d" \
"$sysfs" \
"$(sed -ne 's/^.*\[\(.*\)\].*$/\1/p' /sys/class/leds/${sysfs}/trigger)" \
"$(cat /sys/class/leds/${sysfs}/brightness)" \
>> /var/run/led.state
+ # Save default color if supported
+ [ -e /sys/class/leds/${sysfs}/multi_intensity ] && {
+ printf " %s" \
+ "$(sed 's/\ /:/g' /sys/class/leds/${sysfs}/multi_intensity)" \
+ >> /var/run/led.state
+ }
+ printf "\n" >> /var/run/led.state
[ "$default" = 0 ] &&
echo 0 >/sys/class/leds/${sysfs}/brightness
- echo $trigger > /sys/class/leds/${sysfs}/trigger 2> /dev/null
- ret="$?"
-
[ $default = 1 ] &&
cat /sys/class/leds/${sysfs}/max_brightness > /sys/class/leds/${sysfs}/brightness
+ led_color_set "$1" "$sysfs"
+
+ echo $trigger > /sys/class/leds/${sysfs}/trigger 2> /dev/null
+ ret="$?"
[ $ret = 0 ] || {
echo >&2 "Skipping trigger '$trigger' for led '$name' due to missing kernel module"
return 1
}
case "$trigger" in
+ "heartbeat")
+ echo "${inverted}" > "/sys/class/leds/${sysfs}/invert"
+ ;;
+
"netdev")
[ -n "$dev" ] && {
echo $dev > /sys/class/leds/${sysfs}/device_name
@@ -124,13 +169,17 @@ load_led() {
start() {
[ -e /sys/class/leds/ ] && {
[ -s /var/run/led.state ] && {
- local led trigger brightness
- while read led trigger brightness; do
+ local led trigger brightness color
+ while read led trigger brightness color; do
[ -e "/sys/class/leds/$led/trigger" ] && \
echo "$trigger" > "/sys/class/leds/$led/trigger"
[ -e "/sys/class/leds/$led/brightness" ] && \
echo "$brightness" > "/sys/class/leds/$led/brightness"
+
+ [ -e "/sys/class/leds/$led/multi_intensity" ] && \
+ echo "$color" | sed 's/:/\ /g' > \
+ "/sys/class/leds/$led/multi_intensity"
done < /var/run/led.state
rm /var/run/led.state
}
diff --git a/package/base-files/files/etc/init.d/sysfixtime b/package/base-files/files/etc/init.d/sysfixtime
index aab5b153d07..93f792266aa 100755
--- a/package/base-files/files/etc/init.d/sysfixtime
+++ b/package/base-files/files/etc/init.d/sysfixtime
@@ -8,23 +8,33 @@ RTC_DEV=/dev/rtc0
HWCLOCK=/sbin/hwclock
boot() {
- start && exit 0
-
- local maxtime="$(maxtime)"
+ hwclock_load
+ local maxtime="$(find_max_time)"
local curtime="$(date +%s)"
- [ $curtime -lt $maxtime ] && date -s @$maxtime
+ if [ $curtime -lt $maxtime ]; then
+ date -s @$maxtime
+ hwclock_save
+ fi
}
start() {
- [ -e "$RTC_DEV" ] && [ -e "$HWCLOCK" ] && $HWCLOCK -s -u -f $RTC_DEV
+ hwclock_load
}
stop() {
+ hwclock_save
+}
+
+hwclock_load() {
+ [ -e "$RTC_DEV" ] && [ -e "$HWCLOCK" ] && $HWCLOCK -s -u -f $RTC_DEV
+}
+
+hwclock_save(){
[ -e "$RTC_DEV" ] && [ -e "$HWCLOCK" ] && $HWCLOCK -w -u -f $RTC_DEV && \
logger -t sysfixtime "saved '$(date)' to $RTC_DEV"
}
-maxtime() {
+find_max_time() {
local file newest
for file in $( find /etc -type f ) ; do
diff --git a/package/base-files/files/etc/profile b/package/base-files/files/etc/profile
index 0beff1608f6..76b149b9fae 100644
--- a/package/base-files/files/etc/profile
+++ b/package/base-files/files/etc/profile
@@ -3,7 +3,7 @@
[ -f /etc/banner ] && cat /etc/banner
[ -n "$FAILSAFE" ] && cat /etc/banner.failsafe
-fgrep -sq '/ overlay ro,' /proc/mounts && {
+grep -Fsq '/ overlay ro,' /proc/mounts && {
echo 'Your JFFS2-partition seems full and overlayfs is mounted read-only.'
echo 'Please try to remove files from /overlay/upper/... and reboot!'
}
diff --git a/package/base-files/files/etc/rc.common b/package/base-files/files/etc/rc.common
index 5dcbf5138d5..d7473038444 100755
--- a/package/base-files/files/etc/rc.common
+++ b/package/base-files/files/etc/rc.common
@@ -105,9 +105,9 @@ service_data() {
}
service_running() {
- local service="${1:-$(basename $initscript)}"
- local instance="${2:-*}"
- procd_running "$service" "$instance" "$@"
+ local instance="${1:-*}"
+
+ procd_running "$(basename $initscript)" "$instance"
}
${INIT_TRACE:+set -x}
@@ -126,6 +126,7 @@ extra_command "enabled" "Check if service is started on boot"
extra_command "running" "Check if service is running"
extra_command "status" "Service status"
extra_command "trace" "Start with syscall trace"
+ extra_command "info" "Dump procd service info"
. $IPKG_INSTROOT/lib/functions/procd.sh
basescript=$(readlink "$initscript")
@@ -149,6 +150,13 @@ extra_command "enabled" "Check if service is started on boot"
start "$@"
}
+ info() {
+ json_init
+ json_add_string name "$(basename ${basescript:-$initscript})"
+ json_add_boolean verbose "1"
+ _procd_ubus_call list
+ }
+
stop() {
procd_lock
stop_service "$@"
diff --git a/package/base-files/files/etc/shadow b/package/base-files/files/etc/shadow
index 4b4154f21f4..39bdb9c90a3 100644
--- a/package/base-files/files/etc/shadow
+++ b/package/base-files/files/etc/shadow
@@ -1,4 +1,4 @@
-root::0:0:99999:7:::
+root:::0:99999:7:::
daemon:*:0:0:99999:7:::
ftp:*:0:0:99999:7:::
network:*:0:0:99999:7:::
diff --git a/package/base-files/files/etc/shinit b/package/base-files/files/etc/shinit
index 6b682d8769d..8df9771e656 100644
--- a/package/base-files/files/etc/shinit
+++ b/package/base-files/files/etc/shinit
@@ -8,26 +8,5 @@ alias ll='ls -alF --color=auto'
[ -x /usr/bin/arp -o -x /sbin/arp ] || arp() { cat /proc/net/arp; }
[ -x /usr/bin/ldd ] || ldd() { LD_TRACE_LOADED_OBJECTS=1 $*; }
-service() {
- if [ -f "/etc/init.d/$1" ]; then
- /etc/init.d/$@
- else
- echo "Usage: service <service> [command]"
- if [ -n "$1" ]; then
- echo "Service "'"'"$1"'"'" not found, the following services are available:"
- else
- echo "The following services are available:"
- fi
- for F in /etc/init.d/* ; do
- printf "%-30s\t%10s\t%10s\n" "$F" \
- $( $($F enabled) && echo "enabled" || echo "disabled" ) \
- $( [ "$(ubus call service list "{ 'verbose': true, 'name': '$(basename $F)' }" \
- | jsonfilter -q -e "@['$(basename $F)'].instances[*].running" | uniq)" = "true" ] \
- && echo "running" || echo "stopped" )
- done;
- return 1
- fi
-}
-
[ -n "$KSH_VERSION" -o \! -s "$HOME/.shinit" ] || . "$HOME/.shinit"
[ -z "$KSH_VERSION" -o \! -s "$HOME/.mkshrc" ] || . "$HOME/.mkshrc"
diff --git a/package/base-files/files/etc/sysctl.d/10-default.conf b/package/base-files/files/etc/sysctl.d/10-default.conf
index bc8c5796951..ee7df2bfa61 100644
--- a/package/base-files/files/etc/sysctl.d/10-default.conf
+++ b/package/base-files/files/etc/sysctl.d/10-default.conf
@@ -9,6 +9,7 @@ fs.protected_hardlinks=1
fs.protected_symlinks=1
net.core.bpf_jit_enable=1
+net.core.bpf_jit_kallsyms=1
net.ipv4.conf.default.arp_ignore=1
net.ipv4.conf.all.arp_ignore=1