ASR_BASE
Change-Id: Icf3719cc0afe3eeb3edc7fa80a2eb5199ca9dda1
diff --git a/package/base-files/files/etc/init.d/boot b/package/base-files/files/etc/init.d/boot
new file mode 100755
index 0000000..d91f591
--- /dev/null
+++ b/package/base-files/files/etc/init.d/boot
@@ -0,0 +1,62 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2006-2011 OpenWrt.org
+
+START=10
+STOP=90
+
+uci_apply_defaults() {
+ . /lib/functions/system.sh
+
+ cd /etc/uci-defaults || return 0
+ files="$(ls)"
+ [ -z "$files" ] && return 0
+ for file in $files; do
+ ( . "./$(basename $file)" ) && rm -f "$file"
+ done
+ uci commit
+}
+
+boot() {
+ [ -f /proc/mounts ] || /sbin/mount_root
+ [ -f /proc/jffs2_bbc ] && echo "S" > /proc/jffs2_bbc
+ [ -f /proc/net/vlan/config ] && vconfig set_name_type DEV_PLUS_VID_NO_PAD
+
+ mkdir -p /var/lock
+ chmod 1777 /var/lock
+ mkdir -p /var/log
+ mkdir -p /var/run
+ ln -s /var/run /run
+ ln -s /var/lock /run/lock
+ mkdir -p /var/state
+ mkdir -p /var/tmp
+ mkdir -p /var/camera
+ mkdir -p /tmp/.uci
+ chmod 0700 /tmp/.uci
+ echo 0 > /tmp/dBm
+ touch /var/log/wtmp
+ touch /var/log/lastlog
+ mkdir -p /tmp/resolv.conf.d
+ touch /tmp/resolv.conf.d/resolv.conf.auto
+ ln -sf /tmp/resolv.conf.d/resolv.conf.auto /tmp/resolv.conf
+ grep -q debugfs /proc/filesystems && /bin/mount -o nosuid,nodev,noexec,noatime -t debugfs debugfs /sys/kernel/debug
+ grep -q bpf /proc/filesystems && /bin/mount -o nosuid,nodev,noexec,noatime,mode=0700 -t bpf bpffs /sys/fs/bpf
+ grep -q pstore /proc/filesystems && /bin/mount -o nosuid,nodev,noexec,noatime -t pstore pstore /sys/fs/pstore
+ [ "$FAILSAFE" = "true" ] && touch /tmp/.failsafe
+
+ touch /tmp/.config_pending
+ /bin/pppmodem &
+
+ mkdir -p /tmp/.uci
+ [ -f /etc/uci-defaults/30_uboot-envtools ] && (. /etc/uci-defaults/30_uboot-envtools)
+ /bin/config_generate
+ rm -f /tmp/.config_pending
+ /sbin/wifi config
+ uci_apply_defaults
+ sync
+
+ # temporary hack until configd exists
+ /sbin/reload_config
+
+ # let mount done early to boot telephony success
+ [ -d /tmp/root ] && mount_root done
+}
diff --git a/package/base-files/files/etc/init.d/done b/package/base-files/files/etc/init.d/done
new file mode 100755
index 0000000..06b277c
--- /dev/null
+++ b/package/base-files/files/etc/init.d/done
@@ -0,0 +1,17 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2006 OpenWrt.org
+
+START=95
+boot() {
+ # mount_root done
+ rm -f /sysupgrade.tgz && sync
+
+ # process user commands
+ [ -f /etc/rc.local ] && {
+ sh /etc/rc.local
+ }
+
+ # set leds to normal state
+ . /etc/diag.sh
+ set_state done
+}
diff --git a/package/base-files/files/etc/init.d/gpio_switch b/package/base-files/files/etc/init.d/gpio_switch
new file mode 100755
index 0000000..24d790b
--- /dev/null
+++ b/package/base-files/files/etc/init.d/gpio_switch
@@ -0,0 +1,66 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2015 OpenWrt.org
+
+START=94
+STOP=10
+USE_PROCD=1
+
+
+load_gpio_switch()
+{
+ local name
+ local gpio_pin
+ local value
+
+ config_get gpio_pin "$1" gpio_pin
+ config_get name "$1" name
+ config_get value "$1" value 0
+
+ [ -z "$gpio_pin" ] && {
+ echo >&2 "Skipping gpio_switch '$name' due to missing gpio_pin"
+ return 1
+ }
+
+ local gpio_path
+ if [ -n "$(echo "$gpio_pin" | grep -E "^[0-9]+$")" ]; then
+ gpio_path="/sys/class/gpio/gpio${gpio_pin}"
+
+ # export GPIO pin for access
+ [ -d "$gpio_path" ] || {
+ echo "$gpio_pin" >/sys/class/gpio/export
+ # we need to wait a bit until the GPIO appears
+ [ -d "$gpio_path" ] || sleep 1
+ }
+
+ # direction attribute only exists if the kernel supports changing the
+ # direction of a GPIO
+ if [ -e "${gpio_path}/direction" ]; then
+ # set the pin to output with high or low pin value
+ { [ "$value" = "0" ] && echo "low" || echo "high"; } \
+ >"$gpio_path/direction"
+ else
+ { [ "$value" = "0" ] && echo "0" || echo "1"; } \
+ >"$gpio_path/value"
+ fi
+ else
+ gpio_path="/sys/class/gpio/${gpio_pin}"
+
+ [ -d "$gpio_path" ] && {
+ { [ "$value" = "0" ] && echo "0" || echo "1"; } \
+ >"$gpio_path/value"
+ }
+ fi
+}
+
+service_triggers()
+{
+ procd_add_reload_trigger "system"
+}
+
+start_service()
+{
+ [ -e /sys/class/gpio/ ] && {
+ config_load system
+ config_foreach load_gpio_switch gpio_switch
+ }
+}
diff --git a/package/base-files/files/etc/init.d/led b/package/base-files/files/etc/init.d/led
new file mode 100755
index 0000000..7f05254
--- /dev/null
+++ b/package/base-files/files/etc/init.d/led
@@ -0,0 +1,198 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2008 OpenWrt.org
+
+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
+ local trigger
+ local dev
+ local ports
+ local mode
+ local default
+ local delayon
+ local delayoff
+ local interval
+
+ config_get sysfs $1 sysfs
+ config_get name $1 name "$sysfs"
+ config_get trigger $1 trigger "none"
+ config_get dev $1 dev
+ config_get ports $1 port
+ config_get mode $1 mode
+ config_get_bool default $1 default "0"
+ config_get delayon $1 delayon
+ config_get delayoff $1 delayoff
+ config_get interval $1 interval "50"
+ config_get port_state $1 port_state
+ config_get delay $1 delay "150"
+ config_get message $1 message ""
+ config_get gpio $1 gpio "0"
+ config_get_bool inverted $1 inverted "0"
+
+ [ "$2" ] && [ "$sysfs" != "$2" ] && return
+
+ # execute application led trigger
+ [ -f "/usr/libexec/led-trigger/${trigger}" ] && {
+ . "/usr/libexec/led-trigger/${trigger}"
+ return 0
+ }
+
+ [ "$trigger" = "usbdev" ] && {
+ # Backward compatibility: translate to the new trigger
+ trigger="usbport"
+ # Translate port of root hub, e.g. 4-1 -> usb4-port1
+ ports=$(echo "$dev" | sed -n 's/^\([0-9]*\)-\([0-9]*\)$/usb\1-port\2/p')
+ # Translate port of extra hub, e.g. 2-2.4 -> 2-2-port4
+ [ -z "$ports" ] && ports=$(echo "$dev" | sed -n 's/\./-port/p')
+ }
+
+ [ -e /sys/class/leds/${sysfs}/brightness ] && {
+ echo "setting up led ${name}"
+
+ 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
+
+ [ $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
+ for m in $mode; do
+ [ -e "/sys/class/leds/${sysfs}/$m" ] && \
+ echo 1 > /sys/class/leds/${sysfs}/$m
+ done
+ echo $interval > /sys/class/leds/${sysfs}/interval 2>/dev/null
+ }
+ ;;
+
+ "timer"|"oneshot")
+ [ -n "$delayon" ] && \
+ echo $delayon > /sys/class/leds/${sysfs}/delay_on
+ [ -n "$delayoff" ] && \
+ echo $delayoff > /sys/class/leds/${sysfs}/delay_off
+ ;;
+
+ "usbport")
+ local p
+
+ for p in $ports; do
+ echo 1 > /sys/class/leds/${sysfs}/ports/$p
+ done
+ ;;
+
+ "port_state")
+ [ -n "$port_state" ] && \
+ echo $port_state > /sys/class/leds/${sysfs}/port_state
+ ;;
+
+ "gpio")
+ echo $gpio > /sys/class/leds/${sysfs}/gpio
+ echo $inverted > /sys/class/leds/${sysfs}/inverted
+ ;;
+
+ switch[0-9]*)
+ local port_mask speed_mask
+
+ config_get port_mask $1 port_mask
+ [ -n "$port_mask" ] && \
+ echo $port_mask > /sys/class/leds/${sysfs}/port_mask
+ config_get speed_mask $1 speed_mask
+ [ -n "$speed_mask" ] && \
+ echo $speed_mask > /sys/class/leds/${sysfs}/speed_mask
+ [ -n "$mode" ] && \
+ echo "$mode" > /sys/class/leds/${sysfs}/mode
+ ;;
+ esac
+ }
+}
+
+start() {
+ [ -e /sys/class/leds/ ] && {
+ [ -s /var/run/led.state ] && {
+ local led trigger brightness color
+ while read led trigger brightness color; do
+ [ "$1" ] && [ "$1" != "$led" ] && continue
+ [ -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
+ if [ "$1" ]; then
+ grep -v "^$1 " /var/run/led.state > /var/run/led.state.new
+ mv /var/run/led.state.new /var/run/led.state
+ else
+ rm /var/run/led.state
+ fi
+ }
+
+ config_load system
+ config_foreach load_led led "$1"
+ }
+}
diff --git a/package/base-files/files/etc/init.d/sysctl b/package/base-files/files/etc/init.d/sysctl
new file mode 100755
index 0000000..88c822b
--- /dev/null
+++ b/package/base-files/files/etc/init.d/sysctl
@@ -0,0 +1,44 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2006 OpenWrt.org
+
+START=11
+
+apply_defaults() {
+ local mem="$(awk '/^MemTotal:/ {print $2}' /proc/meminfo)"
+ local min_free frag_low_thresh frag_high_thresh
+
+ if [ "$mem" -gt 131072 ]; then # >=256M DDR device
+ min_free=8192
+ elif [ "$mem" -gt 65536 ]; then # 128M DDR device
+ min_free=4196
+ else
+ min_free=1024
+ frag_low_thresh=393216
+ frag_high_thresh=524288
+ fi
+
+ sysctl -qw vm.min_free_kbytes="$min_free"
+
+ [ "$frag_low_thresh" ] && sysctl -qw \
+ net.ipv4.ipfrag_low_thresh="$frag_low_thresh" \
+ net.ipv4.ipfrag_high_thresh="$frag_high_thresh" \
+ net.ipv6.ip6frag_low_thresh="$frag_low_thresh" \
+ net.ipv6.ip6frag_high_thresh="$frag_high_thresh" \
+ net.netfilter.nf_conntrack_frag6_low_thresh="$frag_low_thresh" \
+ net.netfilter.nf_conntrack_frag6_high_thresh="$frag_high_thresh"
+
+ # first set default, then all interfaces to avoid races with appearing interfaces
+ if [ -d /proc/sys/net/ipv6/conf ]; then
+ echo 0 > /proc/sys/net/ipv6/conf/default/accept_ra
+ for iface in /proc/sys/net/ipv6/conf/*/accept_ra; do
+ echo 0 > "$iface"
+ done
+ fi
+}
+
+start() {
+ apply_defaults
+ for CONF in /etc/sysctl.d/*.conf /etc/sysctl.conf; do
+ [ -f "$CONF" ] && sysctl -e -p "$CONF" >&-
+ done
+}
diff --git a/package/base-files/files/etc/init.d/sysfixtime b/package/base-files/files/etc/init.d/sysfixtime
new file mode 100755
index 0000000..93f7922
--- /dev/null
+++ b/package/base-files/files/etc/init.d/sysfixtime
@@ -0,0 +1,44 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2013-2014 OpenWrt.org
+
+START=00
+STOP=90
+
+RTC_DEV=/dev/rtc0
+HWCLOCK=/sbin/hwclock
+
+boot() {
+ hwclock_load
+ local maxtime="$(find_max_time)"
+ local curtime="$(date +%s)"
+ if [ $curtime -lt $maxtime ]; then
+ date -s @$maxtime
+ hwclock_save
+ fi
+}
+
+start() {
+ 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"
+}
+
+find_max_time() {
+ local file newest
+
+ for file in $( find /etc -type f ) ; do
+ [ -z "$newest" -o "$newest" -ot "$file" ] && newest=$file
+ done
+ [ "$newest" ] && date -r "$newest" +%s
+}
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 0000000..042e018
--- /dev/null
+++ b/package/base-files/files/etc/init.d/system
@@ -0,0 +1,45 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2014 OpenWrt.org
+
+START=11
+USE_PROCD=1
+
+validate_system_section() {
+ uci_load_validate system system "$1" "$2" \
+ 'hostname:string:OpenWrt' \
+ 'conloglevel:uinteger' \
+ 'buffersize:uinteger' \
+ 'timezone:string:UTC' \
+ 'zonename:string'
+}
+
+system_config() {
+ [ "$2" = 0 ] || {
+ 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 -sf "/usr/share/zoneinfo/${zonename// /_}" /tmp/localtime \
+ && rm -f /tmp/TZ
+
+ # apply timezone to kernel
+ hwclock -u --systz
+}
+
+reload_service() {
+ config_load system
+ config_foreach validate_system_section system system_config
+}
+
+service_triggers() {
+ procd_add_reload_trigger "system"
+ procd_add_validation validate_system_section
+}
+
+start_service() {
+ reload_service
+}
diff --git a/package/base-files/files/etc/init.d/umount b/package/base-files/files/etc/init.d/umount
new file mode 100755
index 0000000..5dd9acc
--- /dev/null
+++ b/package/base-files/files/etc/init.d/umount
@@ -0,0 +1,22 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2006 OpenWrt.org
+
+STOP=90
+
+restart() {
+ :
+}
+
+revert_overlay() {
+ #kill all process to release mnt/
+ kill -9 -1
+
+ /bin/umount /overlay/etc
+ /bin/umount /overlay/nvm
+}
+
+stop() {
+ sync
+ revert_overlay
+ /bin/umount -a -d -r
+}