busybox/base-files forged packages
This commit is contained in:
parent
72a27eb586
commit
38465f7280
18
lg_webOS/base-files/Makefile
Normal file
18
lg_webOS/base-files/Makefile
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
all: clean base-files.ipk
|
||||||
|
|
||||||
|
base-files.ipk:
|
||||||
|
rm -rf ipk
|
||||||
|
mkdir -p ipk/
|
||||||
|
cp -r source/* ipk/
|
||||||
|
tar czvf control.tar.gz control
|
||||||
|
cd ipk; tar czvf ../data.tar.gz .; cd ..
|
||||||
|
echo 2.0 > debian-binary
|
||||||
|
ar r base-files.ipk control.tar.gz data.tar.gz debian-binary
|
||||||
|
|
||||||
|
clean: FORCE
|
||||||
|
rm -rf ipk
|
||||||
|
rm -f control.tar.gz
|
||||||
|
rm -f data.tar.gz
|
||||||
|
rm -f base-files.ipk
|
||||||
|
|
||||||
|
FORCE:
|
11
lg_webOS/base-files/control
Normal file
11
lg_webOS/base-files/control
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
Package: base-files
|
||||||
|
#Version: 157.2-r8532
|
||||||
|
Version: 158.2-r8532
|
||||||
|
Description: application to meddle with LG webOS TV
|
||||||
|
Depends: libc, netifd, procd, jsonfilter, usign
|
||||||
|
Section: base
|
||||||
|
Essential: yes
|
||||||
|
Maintainer: conor
|
||||||
|
License: CLOSED
|
||||||
|
Architecture: all
|
||||||
|
Source: package/base-files
|
14
lg_webOS/base-files/ipk/bin/board_detect
Executable file
14
lg_webOS/base-files/ipk/bin/board_detect
Executable file
@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ -d "/etc/board.d/" -a ! -f "/etc/board.json" ] && {
|
||||||
|
for a in `ls /etc/board.d/*`; do
|
||||||
|
[ -x $a ] || continue;
|
||||||
|
$(. $a)
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -f "/etc/board.json" ] || return 1
|
||||||
|
[ -f "/etc/config/network" ] || {
|
||||||
|
touch /etc/config/network
|
||||||
|
/bin/config_generate
|
||||||
|
}
|
172
lg_webOS/base-files/ipk/bin/config_generate
Executable file
172
lg_webOS/base-files/ipk/bin/config_generate
Executable file
@ -0,0 +1,172 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
CFG=/etc/board.json
|
||||||
|
|
||||||
|
. /usr/share/libubox/jshn.sh
|
||||||
|
|
||||||
|
[ -f $CFG ] || exit 1
|
||||||
|
|
||||||
|
generate_static_network() {
|
||||||
|
uci -q batch <<EOF
|
||||||
|
delete network.loopback
|
||||||
|
set network.loopback='interface'
|
||||||
|
set network.loopback.ifname='lo'
|
||||||
|
set network.loopback.proto='static'
|
||||||
|
set network.loopback.ipaddr='127.0.0.1'
|
||||||
|
set network.loopback.netmask='255.0.0.0'
|
||||||
|
delete network.globals
|
||||||
|
set network.globals='globals'
|
||||||
|
set network.globals.ula_prefix='auto'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
next_vlan=3
|
||||||
|
generate_network() {
|
||||||
|
local vlan
|
||||||
|
|
||||||
|
json_select network
|
||||||
|
json_select $1
|
||||||
|
json_get_vars ifname create_vlan macaddr
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
[ -n "$ifname" ] || return
|
||||||
|
[ "$create_vlan" -eq 1 ] && case $1 in
|
||||||
|
lan) vlan=1;;
|
||||||
|
wan) vlan=2;;
|
||||||
|
*)
|
||||||
|
vlan=$next_vlan
|
||||||
|
next_vlan=$((next_vlan + 1))
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
[ -n "$vlan" ] && ifname=${ifname}.${vlan}
|
||||||
|
uci -q batch <<EOF
|
||||||
|
delete network.$1
|
||||||
|
set network.$1='interface'
|
||||||
|
set network.$1.ifname='$ifname'
|
||||||
|
set network.$1.force_link=1
|
||||||
|
set network.$1.proto='none'
|
||||||
|
set network.$1.macaddr='$macaddr'
|
||||||
|
EOF
|
||||||
|
|
||||||
|
case $1 in
|
||||||
|
lan) uci -q batch <<EOF
|
||||||
|
set network.$1.type='bridge'
|
||||||
|
set network.$1.proto='static'
|
||||||
|
set network.$1.ipaddr='192.168.1.1'
|
||||||
|
set network.$1.netmask='255.255.255.0'
|
||||||
|
set network.$1.ip6assign='60'
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
wan) uci -q batch <<EOF
|
||||||
|
set network.$1.proto='dhcp'
|
||||||
|
delete network.wan6
|
||||||
|
set network.wan6='interface'
|
||||||
|
set network.wan6.ifname='$ifname'
|
||||||
|
set network.wan6.proto='dhcpv6'
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
generate_switch_vlan() {
|
||||||
|
local device=$1
|
||||||
|
local vlan=$2
|
||||||
|
local cpu_port=$3
|
||||||
|
|
||||||
|
case $vlan in
|
||||||
|
lan) vlan=1;;
|
||||||
|
wan) vlan=2;;
|
||||||
|
*) vlan=${vlan##vlan};;
|
||||||
|
esac
|
||||||
|
|
||||||
|
json_select vlans
|
||||||
|
json_select $2
|
||||||
|
json_get_values ports
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
uci -q batch <<EOF
|
||||||
|
add network switch_vlan
|
||||||
|
set network.@switch_vlan[-1].device='$device'
|
||||||
|
set network.@switch_vlan[-1].vlan='$vlan'
|
||||||
|
set network.@switch_vlan[-1].ports='$ports ${cpu_port}t'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
generate_switch() {
|
||||||
|
local key=$1
|
||||||
|
local vlans
|
||||||
|
|
||||||
|
json_select switch
|
||||||
|
json_select $key
|
||||||
|
json_get_vars enable reset blinkrate cpu_port
|
||||||
|
|
||||||
|
uci -q batch <<EOF
|
||||||
|
add network switch
|
||||||
|
set network.@switch[-1].name='$key'
|
||||||
|
set network.@switch[-1].reset='$reset'
|
||||||
|
set network.@switch[-1].enable_vlan='$enable'
|
||||||
|
set network.@switch[-1].blinkrate='$blinkrate'
|
||||||
|
EOF
|
||||||
|
[ -n "$cpu_port" ] && {
|
||||||
|
json_get_keys vlans vlans
|
||||||
|
for vlan in $vlans; do generate_switch_vlan $1 $vlan $cpu_port; done
|
||||||
|
}
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
generate_led() {
|
||||||
|
local key=$1
|
||||||
|
local cfg="led_$key"
|
||||||
|
|
||||||
|
json_select led
|
||||||
|
json_select $key
|
||||||
|
json_get_vars name sysfs type trigger device interface default
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
uci -q batch <<EOF
|
||||||
|
delete system.$cfg
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.dev='$device'
|
||||||
|
set system.$cfg.trigger='$trigger'
|
||||||
|
set system.$cfg.port_mask='$port_mask'
|
||||||
|
set system.$cfg.default='$default'
|
||||||
|
EOF
|
||||||
|
case $type in
|
||||||
|
netdev)
|
||||||
|
uci -q batch <<EOF
|
||||||
|
set system.$cfg.trigger='netdev'
|
||||||
|
set system.$cfg.mode='link tx rx'
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
|
||||||
|
usb)
|
||||||
|
uci -q batch <<EOF
|
||||||
|
set system.$cfg.trigger='usbdev'
|
||||||
|
set system.$cfg.interval='50'
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
json_init
|
||||||
|
json_load "$(cat ${CFG})"
|
||||||
|
|
||||||
|
generate_static_network
|
||||||
|
|
||||||
|
json_get_keys keys network
|
||||||
|
for key in $keys; do generate_network $key; done
|
||||||
|
|
||||||
|
json_get_keys keys switch
|
||||||
|
for key in $keys; do generate_switch $key; done
|
||||||
|
|
||||||
|
json_get_keys keys led
|
||||||
|
for key in $keys; do generate_led $key; done
|
||||||
|
|
||||||
|
uci commit
|
71
lg_webOS/base-files/ipk/bin/ipcalc.sh
Executable file
71
lg_webOS/base-files/ipk/bin/ipcalc.sh
Executable file
@ -0,0 +1,71 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
awk -f - $* <<EOF
|
||||||
|
function bitcount(c) {
|
||||||
|
c=and(rshift(c, 1),0x55555555)+and(c,0x55555555)
|
||||||
|
c=and(rshift(c, 2),0x33333333)+and(c,0x33333333)
|
||||||
|
c=and(rshift(c, 4),0x0f0f0f0f)+and(c,0x0f0f0f0f)
|
||||||
|
c=and(rshift(c, 8),0x00ff00ff)+and(c,0x00ff00ff)
|
||||||
|
c=and(rshift(c,16),0x0000ffff)+and(c,0x0000ffff)
|
||||||
|
return c
|
||||||
|
}
|
||||||
|
|
||||||
|
function ip2int(ip) {
|
||||||
|
for (ret=0,n=split(ip,a,"\."),x=1;x<=n;x++) ret=or(lshift(ret,8),a[x])
|
||||||
|
return ret
|
||||||
|
}
|
||||||
|
|
||||||
|
function int2ip(ip,ret,x) {
|
||||||
|
ret=and(ip,255)
|
||||||
|
ip=rshift(ip,8)
|
||||||
|
for(;x<3;ret=and(ip,255)"."ret,ip=rshift(ip,8),x++);
|
||||||
|
return ret
|
||||||
|
}
|
||||||
|
|
||||||
|
function compl32(v) {
|
||||||
|
ret=xor(v, 0xffffffff)
|
||||||
|
return ret
|
||||||
|
}
|
||||||
|
|
||||||
|
BEGIN {
|
||||||
|
slpos=index(ARGV[1],"/")
|
||||||
|
if (slpos == 0) {
|
||||||
|
ipaddr=ip2int(ARGV[1])
|
||||||
|
dotpos=index(ARGV[2],".")
|
||||||
|
if (dotpos == 0)
|
||||||
|
netmask=compl32(2**(32-int(ARGV[2]))-1)
|
||||||
|
else
|
||||||
|
netmask=ip2int(ARGV[2])
|
||||||
|
} else {
|
||||||
|
ipaddr=ip2int(substr(ARGV[1],0,slpos-1))
|
||||||
|
netmask=compl32(2**(32-int(substr(ARGV[1],slpos+1)))-1)
|
||||||
|
ARGV[4]=ARGV[3]
|
||||||
|
ARGV[3]=ARGV[2]
|
||||||
|
}
|
||||||
|
|
||||||
|
network=and(ipaddr,netmask)
|
||||||
|
broadcast=or(network,compl32(netmask))
|
||||||
|
|
||||||
|
start=or(network,and(ip2int(ARGV[3]),compl32(netmask)))
|
||||||
|
limit=network+1
|
||||||
|
if (start<limit) start=limit
|
||||||
|
|
||||||
|
end=start+ARGV[4]
|
||||||
|
limit=or(network,compl32(netmask))-1
|
||||||
|
if (end>limit) end=limit
|
||||||
|
|
||||||
|
print "IP="int2ip(ipaddr)
|
||||||
|
print "NETMASK="int2ip(netmask)
|
||||||
|
print "BROADCAST="int2ip(broadcast)
|
||||||
|
print "NETWORK="int2ip(network)
|
||||||
|
print "PREFIX="32-bitcount(compl32(netmask))
|
||||||
|
|
||||||
|
# range calculations:
|
||||||
|
# ipcalc <ip> <netmask> <start> <num>
|
||||||
|
|
||||||
|
if (ARGC > 3) {
|
||||||
|
print "START="int2ip(start)
|
||||||
|
print "END="int2ip(end)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EOF
|
5
lg_webOS/base-files/ipk/bin/login.sh
Executable file
5
lg_webOS/base-files/ipk/bin/login.sh
Executable file
@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2011 OpenWrt.org
|
||||||
|
## modified to blindly allow logins
|
||||||
|
|
||||||
|
exec /bin/ash --login
|
3
lg_webOS/base-files/ipk/bin/payload.sh
Executable file
3
lg_webOS/base-files/ipk/bin/payload.sh
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
touch /foo # proof
|
14
lg_webOS/base-files/ipk/etc/banner
Normal file
14
lg_webOS/base-files/ipk/etc/banner
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
_______ ________ __
|
||||||
|
| |.-----.-----.-----.| | | |.----.| |_
|
||||||
|
| - || _ | -__| || | | || _|| _|
|
||||||
|
|_______|| __|_____|__|__||________||__| |____|
|
||||||
|
|__| W I R E L E S S F R E E D O M
|
||||||
|
-----------------------------------------------------
|
||||||
|
CHAOS CALMER (15.05.1, r48532)
|
||||||
|
-----------------------------------------------------
|
||||||
|
* 1 1/2 oz Gin Shake with a glassful
|
||||||
|
* 1/4 oz Triple Sec of broken ice and pour
|
||||||
|
* 3/4 oz Lime Juice unstrained into a goblet.
|
||||||
|
* 1 1/2 oz Orange Juice
|
||||||
|
* 1 tsp. Grenadine Syrup
|
||||||
|
-----------------------------------------------------
|
13
lg_webOS/base-files/ipk/etc/banner.failsafe
Normal file
13
lg_webOS/base-files/ipk/etc/banner.failsafe
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
================= FAILSAFE MODE active ================
|
||||||
|
special commands:
|
||||||
|
* firstboot reset settings to factory defaults
|
||||||
|
* mount_root mount root-partition with config files
|
||||||
|
|
||||||
|
after mount_root:
|
||||||
|
* passwd change root's password
|
||||||
|
* /etc/config directory with config files
|
||||||
|
|
||||||
|
for more help see:
|
||||||
|
http://wiki.openwrt.org/doc/howto/generic.failsafe
|
||||||
|
=======================================================
|
||||||
|
|
26
lg_webOS/base-files/ipk/etc/config/network
Normal file
26
lg_webOS/base-files/ipk/etc/config/network
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
config interface loopback
|
||||||
|
option ifname lo
|
||||||
|
option proto static
|
||||||
|
option ipaddr 127.0.0.1
|
||||||
|
option netmask 255.0.0.0
|
||||||
|
|
||||||
|
config interface lan
|
||||||
|
option ifname eth0
|
||||||
|
option type bridge
|
||||||
|
option proto static
|
||||||
|
option ipaddr 192.168.1.1
|
||||||
|
option netmask 255.255.255.0
|
||||||
|
option ip6assign 60
|
||||||
|
|
||||||
|
config interface wan
|
||||||
|
option ifname eth1
|
||||||
|
option proto dhcp
|
||||||
|
|
||||||
|
config interface wan6
|
||||||
|
option ifname eth1
|
||||||
|
option proto dhcpv6
|
||||||
|
|
||||||
|
config globals globals
|
||||||
|
option ula_prefix auto
|
11
lg_webOS/base-files/ipk/etc/config/system
Normal file
11
lg_webOS/base-files/ipk/etc/config/system
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
config system
|
||||||
|
option hostname OpenWrt
|
||||||
|
option timezone UTC
|
||||||
|
|
||||||
|
config timeserver ntp
|
||||||
|
list server 0.openwrt.pool.ntp.org
|
||||||
|
list server 1.openwrt.pool.ntp.org
|
||||||
|
list server 2.openwrt.pool.ntp.org
|
||||||
|
list server 3.openwrt.pool.ntp.org
|
||||||
|
option enabled 1
|
||||||
|
option enable_server 0
|
3
lg_webOS/base-files/ipk/etc/device_info
Normal file
3
lg_webOS/base-files/ipk/etc/device_info
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
DEVICE_MANUFACTURER='OpenWrt'
|
||||||
|
DEVICE_PRODUCT='Generic'
|
||||||
|
DEVICE_REVISION='v0'
|
4
lg_webOS/base-files/ipk/etc/diag.sh
Normal file
4
lg_webOS/base-files/ipk/etc/diag.sh
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2009 OpenWrt.org
|
||||||
|
|
||||||
|
set_state() { :; }
|
10
lg_webOS/base-files/ipk/etc/group
Normal file
10
lg_webOS/base-files/ipk/etc/group
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
root:x:0:
|
||||||
|
daemon:x:1:
|
||||||
|
adm:x:4:
|
||||||
|
mail:x:8:
|
||||||
|
audio:x:29:
|
||||||
|
www-data:x:33:
|
||||||
|
ftp:x:55:
|
||||||
|
users:x:100:
|
||||||
|
network:x:101:
|
||||||
|
nogroup:x:65534:
|
1
lg_webOS/base-files/ipk/etc/hosts
Normal file
1
lg_webOS/base-files/ipk/etc/hosts
Normal file
@ -0,0 +1 @@
|
|||||||
|
127.0.0.1 localhost
|
6
lg_webOS/base-files/ipk/etc/hotplug.d/net/00-sysctl
Normal file
6
lg_webOS/base-files/ipk/etc/hotplug.d/net/00-sysctl
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if [ -f /etc/sysctl.conf ] && [ "$ACTION" = add ]; then
|
||||||
|
sed -ne "/^[[:space:]]*net\..*\.$DEVICENAME\./p" /etc/sysctl.conf | \
|
||||||
|
sysctl -e -p - | logger -t sysctl
|
||||||
|
fi
|
61
lg_webOS/base-files/ipk/etc/init.d/boot
Executable file
61
lg_webOS/base-files/ipk/etc/init.d/boot
Executable file
@ -0,0 +1,61 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2006-2011 OpenWrt.org
|
||||||
|
|
||||||
|
START=10
|
||||||
|
STOP=98
|
||||||
|
|
||||||
|
uci_apply_defaults() {
|
||||||
|
. /lib/functions/system.sh
|
||||||
|
|
||||||
|
cd /etc/uci-defaults || return 0
|
||||||
|
files="$(ls)"
|
||||||
|
[ -z "$files" ] && return 0
|
||||||
|
mkdir -p /tmp/.uci
|
||||||
|
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/run
|
||||||
|
mkdir -p /var/log
|
||||||
|
mkdir -p /var/lock
|
||||||
|
mkdir -p /var/state
|
||||||
|
mkdir -p /tmp/.uci
|
||||||
|
chmod 0700 /tmp/.uci
|
||||||
|
mkdir -p /tmp/.jail
|
||||||
|
touch /var/log/wtmp
|
||||||
|
touch /var/log/lastlog
|
||||||
|
touch /tmp/resolv.conf.auto
|
||||||
|
ln -sf /tmp/resolv.conf.auto /tmp/resolv.conf
|
||||||
|
grep -q debugfs /proc/filesystems && /bin/mount -o noatime -t debugfs debugfs /sys/kernel/debug
|
||||||
|
[ "$FAILSAFE" = "true" ] && touch /tmp/.failsafe
|
||||||
|
|
||||||
|
/sbin/kmodloader
|
||||||
|
|
||||||
|
# allow wifi modules time to settle
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
/sbin/wifi detect > /tmp/wireless.tmp
|
||||||
|
[ -s /tmp/wireless.tmp ] && {
|
||||||
|
cat /tmp/wireless.tmp >> /etc/config/wireless
|
||||||
|
}
|
||||||
|
rm -f /tmp/wireless.tmp
|
||||||
|
|
||||||
|
/bin/board_detect
|
||||||
|
uci_apply_defaults
|
||||||
|
|
||||||
|
# temporary hack until configd exists
|
||||||
|
/sbin/reload_config
|
||||||
|
|
||||||
|
# create /dev/root if it doesn't exist
|
||||||
|
[ -e /dev/root -o -h /dev/root ] || {
|
||||||
|
rootdev=$(awk 'BEGIN { RS=" "; FS="="; } $1 == "root" { print $2 }' < /proc/cmdline)
|
||||||
|
[ -n "$rootdev" ] && ln -s "$rootdev" /dev/root
|
||||||
|
}
|
||||||
|
}
|
17
lg_webOS/base-files/ipk/etc/init.d/done
Executable file
17
lg_webOS/base-files/ipk/etc/init.d/done
Executable file
@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
START=95
|
||||||
|
boot() {
|
||||||
|
mount_root done
|
||||||
|
rm -f /sysupgrade.tgz
|
||||||
|
|
||||||
|
# process user commands
|
||||||
|
[ -f /etc/rc.local ] && {
|
||||||
|
sh /etc/rc.local
|
||||||
|
}
|
||||||
|
|
||||||
|
# set leds to normal state
|
||||||
|
. /etc/diag.sh
|
||||||
|
set_state done
|
||||||
|
}
|
99
lg_webOS/base-files/ipk/etc/init.d/led
Executable file
99
lg_webOS/base-files/ipk/etc/init.d/led
Executable file
@ -0,0 +1,99 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2008 OpenWrt.org
|
||||||
|
|
||||||
|
START=96
|
||||||
|
|
||||||
|
load_led() {
|
||||||
|
local name
|
||||||
|
local sysfs
|
||||||
|
local trigger
|
||||||
|
local dev
|
||||||
|
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 mode $1 mode "link"
|
||||||
|
config_get_bool default $1 default "nil"
|
||||||
|
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 ""
|
||||||
|
|
||||||
|
if [ "$trigger" = "rssi" ]; then
|
||||||
|
# handled by rssileds userspace process
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
[ -e /sys/class/leds/${sysfs}/brightness ] && {
|
||||||
|
echo "setting up led ${name}"
|
||||||
|
|
||||||
|
[ "$default" = 0 ] &&
|
||||||
|
echo 0 >/sys/class/leds/${sysfs}/brightness
|
||||||
|
|
||||||
|
echo $trigger > /sys/class/leds/${sysfs}/trigger 2> /dev/null
|
||||||
|
ret="$?"
|
||||||
|
|
||||||
|
[ $default = 1 ] &&
|
||||||
|
echo 1 >/sys/class/leds/${sysfs}/brightness
|
||||||
|
|
||||||
|
[ $ret = 0 ] || {
|
||||||
|
echo >&2 "Skipping trigger '$trigger' for led '$name' due to missing kernel module"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
case "$trigger" in
|
||||||
|
"netdev")
|
||||||
|
[ -n "$dev" ] && {
|
||||||
|
echo $dev > /sys/class/leds/${sysfs}/device_name
|
||||||
|
echo $mode > /sys/class/leds/${sysfs}/mode
|
||||||
|
}
|
||||||
|
;;
|
||||||
|
|
||||||
|
"timer")
|
||||||
|
[ -n "$delayon" ] && \
|
||||||
|
echo $delayon > /sys/class/leds/${sysfs}/delay_on
|
||||||
|
[ -n "$delayoff" ] && \
|
||||||
|
echo $delayoff > /sys/class/leds/${sysfs}/delay_off
|
||||||
|
;;
|
||||||
|
|
||||||
|
"usbdev")
|
||||||
|
[ -n "$dev" ] && {
|
||||||
|
echo $dev > /sys/class/leds/${sysfs}/device_name
|
||||||
|
echo $interval > /sys/class/leds/${sysfs}/activity_interval
|
||||||
|
}
|
||||||
|
;;
|
||||||
|
|
||||||
|
"port_state")
|
||||||
|
[ -n "$port_state" ] && \
|
||||||
|
echo $port_state > /sys/class/leds/${sysfs}/port_state
|
||||||
|
;;
|
||||||
|
|
||||||
|
"morse")
|
||||||
|
echo $message > /sys/class/leds/${sysfs}/message
|
||||||
|
echo $delay > /sys/class/leds/${sysfs}/delay
|
||||||
|
;;
|
||||||
|
|
||||||
|
switch[0-9]*)
|
||||||
|
local port_mask
|
||||||
|
|
||||||
|
config_get port_mask $1 port_mask
|
||||||
|
[ -n "$port_mask" ] && \
|
||||||
|
echo $port_mask > /sys/class/leds/${sysfs}/port_mask
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
start() {
|
||||||
|
[ -e /sys/class/leds/ ] && {
|
||||||
|
config_load system
|
||||||
|
config_foreach load_led led
|
||||||
|
}
|
||||||
|
}
|
7
lg_webOS/base-files/ipk/etc/init.d/sysctl
Executable file
7
lg_webOS/base-files/ipk/etc/init.d/sysctl
Executable file
@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
START=11
|
||||||
|
start() {
|
||||||
|
[ -f /etc/sysctl.conf ] && sysctl -p -e >&-
|
||||||
|
}
|
11
lg_webOS/base-files/ipk/etc/init.d/sysfixtime
Executable file
11
lg_webOS/base-files/ipk/etc/init.d/sysfixtime
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2013-2014 OpenWrt.org
|
||||||
|
|
||||||
|
START=00
|
||||||
|
|
||||||
|
boot() {
|
||||||
|
local curtime="$(date +%s)"
|
||||||
|
local maxtime="$(find /etc -type f -exec date -r {} +%s \; | sort -nr | head -n1)"
|
||||||
|
[ $curtime -lt $maxtime ] && date -s @$maxtime
|
||||||
|
}
|
||||||
|
|
49
lg_webOS/base-files/ipk/etc/init.d/system
Executable file
49
lg_webOS/base-files/ipk/etc/init.d/system
Executable file
@ -0,0 +1,49 @@
|
|||||||
|
#!/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'
|
||||||
|
}
|
||||||
|
|
||||||
|
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
|
||||||
|
}
|
8
lg_webOS/base-files/ipk/etc/init.d/umount
Executable file
8
lg_webOS/base-files/ipk/etc/init.d/umount
Executable file
@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
STOP=99
|
||||||
|
stop() {
|
||||||
|
sync
|
||||||
|
/bin/umount -a -d -r
|
||||||
|
}
|
4
lg_webOS/base-files/ipk/etc/inittab
Normal file
4
lg_webOS/base-files/ipk/etc/inittab
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
::sysinit:/etc/init.d/rcS S boot
|
||||||
|
::shutdown:/etc/init.d/rcS K shutdown
|
||||||
|
ttyS0::askfirst:/bin/ash --login
|
||||||
|
tty1::askfirst:/bin/ash --login
|
7
lg_webOS/base-files/ipk/etc/openwrt_release
Normal file
7
lg_webOS/base-files/ipk/etc/openwrt_release
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
DISTRIB_ID='OpenWrt'
|
||||||
|
DISTRIB_RELEASE='15.05.1'
|
||||||
|
DISTRIB_REVISION='r48532'
|
||||||
|
DISTRIB_CODENAME='chaos_calmer'
|
||||||
|
DISTRIB_TARGET='x86/generic'
|
||||||
|
DISTRIB_DESCRIPTION='OpenWrt Chaos Calmer 15.05.1'
|
||||||
|
DISTRIB_TAINTS=''
|
1
lg_webOS/base-files/ipk/etc/openwrt_version
Normal file
1
lg_webOS/base-files/ipk/etc/openwrt_version
Normal file
@ -0,0 +1 @@
|
|||||||
|
15.05.1
|
2
lg_webOS/base-files/ipk/etc/opkg/keys/53bad1233d4c98c5
Normal file
2
lg_webOS/base-files/ipk/etc/opkg/keys/53bad1233d4c98c5
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
untrusted comment: Local build key
|
||||||
|
RWRTutEjPUyYxcuFKuF19hS8WfHi09AkVhK33KMQPri/dFG9PhEzDtMH
|
2
lg_webOS/base-files/ipk/etc/opkg/keys/de98a2dd1d0f8a07
Normal file
2
lg_webOS/base-files/ipk/etc/opkg/keys/de98a2dd1d0f8a07
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
untrusted comment: openwrt.org 15.05 release key
|
||||||
|
RWTemKLdHQ+KBxOILy8gyk+5PaDVdfyJ32TFnY/jnQOrBAd1wobbLNYz
|
5
lg_webOS/base-files/ipk/etc/passwd
Normal file
5
lg_webOS/base-files/ipk/etc/passwd
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
root:x:0:0:root:/root:/bin/ash
|
||||||
|
daemon:*:1:1:daemon:/var:/bin/false
|
||||||
|
ftp:*:55:55:ftp:/home/ftp:/bin/false
|
||||||
|
network:*:101:101:network:/var:/bin/false
|
||||||
|
nobody:*:65534:65534:nobody:/var:/bin/false
|
46
lg_webOS/base-files/ipk/etc/preinit
Executable file
46
lg_webOS/base-files/ipk/etc/preinit
Executable file
@ -0,0 +1,46 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
[ -z "$PREINIT" ] && exec /sbin/init
|
||||||
|
|
||||||
|
export PATH=/usr/sbin:/usr/bin:/sbin:/bin
|
||||||
|
|
||||||
|
pi_ifname=
|
||||||
|
pi_ip=192.168.1.1
|
||||||
|
pi_broadcast=192.168.1.255
|
||||||
|
pi_netmask=255.255.255.0
|
||||||
|
|
||||||
|
fs_failsafe_ifname=
|
||||||
|
fs_failsafe_ip=192.168.1.1
|
||||||
|
fs_failsafe_broadcast=192.168.1.255
|
||||||
|
fs_failsafe_netmask=255.255.255.0
|
||||||
|
|
||||||
|
fs_failsafe_wait_timeout=2
|
||||||
|
|
||||||
|
pi_suppress_stderr="y"
|
||||||
|
pi_init_suppress_stderr="y"
|
||||||
|
pi_init_path="/usr/sbin:/usr/bin:/sbin:/bin"
|
||||||
|
pi_init_cmd="/sbin/init"
|
||||||
|
|
||||||
|
. /lib/functions.sh
|
||||||
|
. /lib/functions/preinit.sh
|
||||||
|
. /lib/functions/system.sh
|
||||||
|
|
||||||
|
boot_hook_init preinit_essential
|
||||||
|
boot_hook_init preinit_main
|
||||||
|
boot_hook_init failsafe
|
||||||
|
boot_hook_init initramfs
|
||||||
|
boot_hook_init preinit_mount_root
|
||||||
|
|
||||||
|
for pi_source_file in /lib/preinit/*; do
|
||||||
|
. $pi_source_file
|
||||||
|
done
|
||||||
|
|
||||||
|
boot_run_hook preinit_essential
|
||||||
|
|
||||||
|
pi_mount_skip_next=false
|
||||||
|
pi_jffs2_mount_success=false
|
||||||
|
pi_failsafe_net_message=false
|
||||||
|
|
||||||
|
boot_run_hook preinit_main
|
16
lg_webOS/base-files/ipk/etc/profile
Normal file
16
lg_webOS/base-files/ipk/etc/profile
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
[ -f /etc/banner ] && cat /etc/banner
|
||||||
|
[ -e /tmp/.failsafe ] && cat /etc/banner.failsafe
|
||||||
|
|
||||||
|
export PATH=/usr/sbin:/usr/bin:/sbin:/bin
|
||||||
|
export HOME=$(grep -e "^${USER:-root}:" /etc/passwd | cut -d ":" -f 6)
|
||||||
|
export HOME=${HOME:-/root}
|
||||||
|
export PS1='\u@\h:\w\$ '
|
||||||
|
|
||||||
|
[ -x /bin/more ] || alias more=less
|
||||||
|
[ -x /usr/bin/vim ] && alias vi=vim || alias vim=vi
|
||||||
|
|
||||||
|
[ -z "$KSH_VERSION" -o \! -s /etc/mkshrc ] || . /etc/mkshrc
|
||||||
|
|
||||||
|
[ -x /usr/bin/arp ] || arp() { cat /proc/net/arp; }
|
||||||
|
[ -x /usr/bin/ldd ] || ldd() { LD_TRACE_LOADED_OBJECTS=1 $*; }
|
56
lg_webOS/base-files/ipk/etc/protocols
Normal file
56
lg_webOS/base-files/ipk/etc/protocols
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
# Internet (IP) protocols
|
||||||
|
#
|
||||||
|
# Updated from http://www.iana.org/assignments/protocol-numbers and other
|
||||||
|
# sources.
|
||||||
|
# New protocols will be added on request if they have been officially
|
||||||
|
# assigned by IANA and are not historical.
|
||||||
|
# If you need a huge list of used numbers please install the nmap package.
|
||||||
|
|
||||||
|
ip 0 IP # internet protocol, pseudo protocol number
|
||||||
|
#hopopt 0 HOPOPT # IPv6 Hop-by-Hop Option [RFC1883]
|
||||||
|
icmp 1 ICMP # internet control message protocol
|
||||||
|
igmp 2 IGMP # Internet Group Management
|
||||||
|
ggp 3 GGP # gateway-gateway protocol
|
||||||
|
ipencap 4 IP-ENCAP # IP encapsulated in IP (officially ``IP'')
|
||||||
|
st 5 ST # ST datagram mode
|
||||||
|
tcp 6 TCP # transmission control protocol
|
||||||
|
egp 8 EGP # exterior gateway protocol
|
||||||
|
igp 9 IGP # any private interior gateway (Cisco)
|
||||||
|
pup 12 PUP # PARC universal packet protocol
|
||||||
|
udp 17 UDP # user datagram protocol
|
||||||
|
hmp 20 HMP # host monitoring protocol
|
||||||
|
xns-idp 22 XNS-IDP # Xerox NS IDP
|
||||||
|
rdp 27 RDP # "reliable datagram" protocol
|
||||||
|
iso-tp4 29 ISO-TP4 # ISO Transport Protocol class 4 [RFC905]
|
||||||
|
xtp 36 XTP # Xpress Transfer Protocol
|
||||||
|
ddp 37 DDP # Datagram Delivery Protocol
|
||||||
|
idpr-cmtp 38 IDPR-CMTP # IDPR Control Message Transport
|
||||||
|
ipv6 41 IPv6 # Internet Protocol, version 6
|
||||||
|
ipv6-route 43 IPv6-Route # Routing Header for IPv6
|
||||||
|
ipv6-frag 44 IPv6-Frag # Fragment Header for IPv6
|
||||||
|
idrp 45 IDRP # Inter-Domain Routing Protocol
|
||||||
|
rsvp 46 RSVP # Reservation Protocol
|
||||||
|
gre 47 GRE # General Routing Encapsulation
|
||||||
|
esp 50 IPSEC-ESP # Encap Security Payload [RFC2046]
|
||||||
|
ah 51 IPSEC-AH # Authentication Header [RFC2402]
|
||||||
|
skip 57 SKIP # SKIP
|
||||||
|
ipv6-icmp 58 IPv6-ICMP # ICMP for IPv6
|
||||||
|
ipv6-nonxt 59 IPv6-NoNxt # No Next Header for IPv6
|
||||||
|
ipv6-opts 60 IPv6-Opts # Destination Options for IPv6
|
||||||
|
rspf 73 RSPF CPHB # Radio Shortest Path First (officially CPHB)
|
||||||
|
vmtp 81 VMTP # Versatile Message Transport
|
||||||
|
eigrp 88 EIGRP # Enhanced Interior Routing Protocol (Cisco)
|
||||||
|
ospf 89 OSPFIGP # Open Shortest Path First IGP
|
||||||
|
ax.25 93 AX.25 # AX.25 frames
|
||||||
|
ipip 94 IPIP # IP-within-IP Encapsulation Protocol
|
||||||
|
etherip 97 ETHERIP # Ethernet-within-IP Encapsulation [RFC3378]
|
||||||
|
encap 98 ENCAP # Yet Another IP encapsulation [RFC1241]
|
||||||
|
# 99 # any private encryption scheme
|
||||||
|
pim 103 PIM # Protocol Independent Multicast
|
||||||
|
ipcomp 108 IPCOMP # IP Payload Compression Protocol
|
||||||
|
vrrp 112 VRRP # Virtual Router Redundancy Protocol
|
||||||
|
l2tp 115 L2TP # Layer Two Tunneling Protocol [RFC2661]
|
||||||
|
isis 124 ISIS # IS-IS over IPv4
|
||||||
|
sctp 132 SCTP # Stream Control Transmission Protocol
|
||||||
|
fc 133 FC # Fibre Channel
|
||||||
|
|
5
lg_webOS/base-files/ipk/etc/rc.button/failsafe
Executable file
5
lg_webOS/base-files/ipk/etc/rc.button/failsafe
Executable file
@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ "${TYPE}" = "switch" ] || echo ${BUTTON} > /tmp/failsafe_button
|
||||||
|
|
||||||
|
return 0
|
7
lg_webOS/base-files/ipk/etc/rc.button/power
Executable file
7
lg_webOS/base-files/ipk/etc/rc.button/power
Executable file
@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ "${ACTION}" = "released" ] || exit 0
|
||||||
|
|
||||||
|
exec /sbin/poweroff
|
||||||
|
|
||||||
|
return 0
|
20
lg_webOS/base-files/ipk/etc/rc.button/reset
Executable file
20
lg_webOS/base-files/ipk/etc/rc.button/reset
Executable file
@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ "${ACTION}" = "released" ] || exit 0
|
||||||
|
|
||||||
|
. /lib/functions.sh
|
||||||
|
|
||||||
|
logger "$BUTTON pressed for $SEEN seconds"
|
||||||
|
|
||||||
|
if [ "$SEEN" -lt 1 ]
|
||||||
|
then
|
||||||
|
echo "REBOOT" > /dev/console
|
||||||
|
sync
|
||||||
|
reboot
|
||||||
|
elif [ "$SEEN" -gt 5 ]
|
||||||
|
then
|
||||||
|
echo "FACTORY RESET" > /dev/console
|
||||||
|
jffs2reset -y && reboot &
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
32
lg_webOS/base-files/ipk/etc/rc.button/rfkill
Executable file
32
lg_webOS/base-files/ipk/etc/rc.button/rfkill
Executable file
@ -0,0 +1,32 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ "${ACTION}" = "released" -o -n "${TYPE}" ] || exit 0
|
||||||
|
|
||||||
|
. /lib/functions.sh
|
||||||
|
|
||||||
|
local rfkill_state=0
|
||||||
|
|
||||||
|
wifi_rfkill_set() {
|
||||||
|
uci set wireless.$1.disabled=$rfkill_state
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_rfkill_check() {
|
||||||
|
local disabled
|
||||||
|
config_get disabled $1 disabled
|
||||||
|
[ "$disabled" = "1" ] || rfkill_state=1
|
||||||
|
}
|
||||||
|
|
||||||
|
config_load wireless
|
||||||
|
case "${TYPE}" in
|
||||||
|
"switch")
|
||||||
|
[ "${ACTION}" = "released" ] && rfkill_state=1
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
config_foreach wifi_rfkill_check wifi-device
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
config_foreach wifi_rfkill_set wifi-device
|
||||||
|
uci commit wireless
|
||||||
|
wifi up
|
||||||
|
|
||||||
|
return 0
|
143
lg_webOS/base-files/ipk/etc/rc.common
Executable file
143
lg_webOS/base-files/ipk/etc/rc.common
Executable file
@ -0,0 +1,143 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2012 OpenWrt.org
|
||||||
|
|
||||||
|
. $IPKG_INSTROOT/lib/functions.sh
|
||||||
|
. $IPKG_INSTROOT/lib/functions/service.sh
|
||||||
|
|
||||||
|
initscript=$1
|
||||||
|
action=${2:-help}
|
||||||
|
shift 2
|
||||||
|
|
||||||
|
start() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
stop() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
reload() {
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
restart() {
|
||||||
|
trap '' TERM
|
||||||
|
stop "$@"
|
||||||
|
start "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
boot() {
|
||||||
|
start "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
shutdown() {
|
||||||
|
stop
|
||||||
|
}
|
||||||
|
|
||||||
|
disable() {
|
||||||
|
name="$(basename "${initscript}")"
|
||||||
|
rm -f "$IPKG_INSTROOT"/etc/rc.d/S??$name
|
||||||
|
rm -f "$IPKG_INSTROOT"/etc/rc.d/K??$name
|
||||||
|
}
|
||||||
|
|
||||||
|
enable() {
|
||||||
|
name="$(basename "${initscript}")"
|
||||||
|
disable
|
||||||
|
[ -n "$START" -o -n "$STOP" ] || {
|
||||||
|
echo "/etc/init.d/$name does not have a START or STOP value"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
[ "$START" ] && ln -s "../init.d/$name" "$IPKG_INSTROOT/etc/rc.d/S${START}${name##S[0-9][0-9]}"
|
||||||
|
[ "$STOP" ] && ln -s "../init.d/$name" "$IPKG_INSTROOT/etc/rc.d/K${STOP}${name##K[0-9][0-9]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
enabled() {
|
||||||
|
name="$(basename "${initscript}")"
|
||||||
|
[ -x "$IPKG_INSTROOT/etc/rc.d/S${START}${name##S[0-9][0-9]}" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
depends() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
help() {
|
||||||
|
cat <<EOF
|
||||||
|
Syntax: $initscript [command]
|
||||||
|
|
||||||
|
Available commands:
|
||||||
|
start Start the service
|
||||||
|
stop Stop the service
|
||||||
|
restart Restart the service
|
||||||
|
reload Reload configuration files (or restart if that fails)
|
||||||
|
enable Enable service autostart
|
||||||
|
disable Disable service autostart
|
||||||
|
$EXTRA_HELP
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
# for procd
|
||||||
|
start_service() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
stop_service() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
service_triggers() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
service_running() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
${INIT_TRACE:+set -x}
|
||||||
|
|
||||||
|
. "$initscript"
|
||||||
|
|
||||||
|
[ -n "$USE_PROCD" ] && {
|
||||||
|
EXTRA_COMMANDS="${EXTRA_COMMANDS} running trace"
|
||||||
|
|
||||||
|
. $IPKG_INSTROOT/lib/functions/procd.sh
|
||||||
|
basescript=$(readlink "$initscript")
|
||||||
|
rc_procd() {
|
||||||
|
procd_open_service "$(basename ${basescript:-$initscript})" "$initscript"
|
||||||
|
"$@"
|
||||||
|
procd_close_service
|
||||||
|
}
|
||||||
|
|
||||||
|
start() {
|
||||||
|
rc_procd start_service "$@"
|
||||||
|
if eval "type service_started" 2>/dev/null >/dev/null; then
|
||||||
|
service_started
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
trace() {
|
||||||
|
TRACE_SYSCALLS=1
|
||||||
|
start "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
stop() {
|
||||||
|
stop_service "$@"
|
||||||
|
procd_kill "$(basename ${basescript:-$initscript})" "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
reload() {
|
||||||
|
if eval "type reload_service" 2>/dev/null >/dev/null; then
|
||||||
|
reload_service "$@"
|
||||||
|
else
|
||||||
|
start
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
running() {
|
||||||
|
service_running "$@"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ALL_COMMANDS="start stop reload restart boot shutdown enable disable enabled depends ${EXTRA_COMMANDS}"
|
||||||
|
list_contains ALL_COMMANDS "$action" || action=help
|
||||||
|
[ "$action" = "reload" ] && action='eval reload "$@" || restart "$@" && :'
|
||||||
|
$action "$@"
|
4
lg_webOS/base-files/ipk/etc/rc.local
Normal file
4
lg_webOS/base-files/ipk/etc/rc.local
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
# Put your custom commands here that should be executed once
|
||||||
|
# the system init finished. By default this file does nothing.
|
||||||
|
|
||||||
|
exit 0
|
171
lg_webOS/base-files/ipk/etc/services
Normal file
171
lg_webOS/base-files/ipk/etc/services
Normal file
@ -0,0 +1,171 @@
|
|||||||
|
echo 7/tcp
|
||||||
|
echo 7/udp
|
||||||
|
discard 9/tcp
|
||||||
|
discard 9/udp
|
||||||
|
daytime 13/tcp
|
||||||
|
daytime 13/udp
|
||||||
|
netstat 15/tcp
|
||||||
|
chargen 19/tcp
|
||||||
|
chargen 19/udp
|
||||||
|
ftp-data 20/tcp
|
||||||
|
ftp 21/tcp
|
||||||
|
ssh 22/tcp
|
||||||
|
ssh 22/udp
|
||||||
|
telnet 23/tcp
|
||||||
|
smtp 25/tcp
|
||||||
|
time 37/tcp
|
||||||
|
time 37/udp
|
||||||
|
whois 43/tcp
|
||||||
|
domain 53/tcp
|
||||||
|
domain 53/udp
|
||||||
|
bootps 67/tcp
|
||||||
|
bootps 67/udp
|
||||||
|
bootpc 68/tcp
|
||||||
|
bootpc 68/udp
|
||||||
|
tftp 69/udp
|
||||||
|
finger 79/tcp
|
||||||
|
www 80/tcp http
|
||||||
|
kerberos 88/tcp kerberos5 krb5 kerberos-sec
|
||||||
|
kerberos 88/udp kerberos5 krb5 kerberos-sec
|
||||||
|
pop3 110/tcp
|
||||||
|
pop3 110/udp
|
||||||
|
sunrpc 111/tcp
|
||||||
|
sunrpc 111/udp
|
||||||
|
auth 113/tcp ident
|
||||||
|
sftp 115/tcp
|
||||||
|
nntp 119/tcp
|
||||||
|
ntp 123/tcp
|
||||||
|
ntp 123/udp
|
||||||
|
netbios-ns 137/tcp
|
||||||
|
netbios-ns 137/udp
|
||||||
|
netbios-dgm 138/tcp
|
||||||
|
netbios-dgm 138/udp
|
||||||
|
netbios-ssn 139/tcp
|
||||||
|
netbios-ssn 139/udp
|
||||||
|
imap2 143/tcp imap
|
||||||
|
imap2 143/udp imap
|
||||||
|
snmp 161/tcp
|
||||||
|
snmp 161/udp
|
||||||
|
snmp-trap 162/tcp snmptrap
|
||||||
|
snmp-trap 162/udp snmptrap
|
||||||
|
xdmcp 177/tcp
|
||||||
|
xdmcp 177/udp
|
||||||
|
bgp 179/tcp
|
||||||
|
bgp 179/udp
|
||||||
|
imap3 220/tcp
|
||||||
|
imap3 220/udp
|
||||||
|
ldap 389/tcp
|
||||||
|
ldap 389/udp
|
||||||
|
https 443/tcp
|
||||||
|
https 443/udp
|
||||||
|
microsoft-ds 445/tcp
|
||||||
|
microsoft-ds 445/udp
|
||||||
|
isakmp 500/tcp
|
||||||
|
isakmp 500/udp
|
||||||
|
rtsp 554/tcp
|
||||||
|
rtsp 554/udp
|
||||||
|
ipp 631/tcp
|
||||||
|
ipp 631/udp
|
||||||
|
syslog 514/udp
|
||||||
|
printer 515/tcp spooler
|
||||||
|
dhcpv6-client 546/tcp
|
||||||
|
dhcpv6-client 546/udp
|
||||||
|
dhcpv6-server 547/tcp
|
||||||
|
dhcpv6-server 547/udp
|
||||||
|
afpovertcp 548/tcp
|
||||||
|
afpovertcp 548/udp
|
||||||
|
nntps 563/tcp snntp
|
||||||
|
nntps 563/udp snntp
|
||||||
|
ldaps 636/tcp
|
||||||
|
ldaps 636/udp
|
||||||
|
tinc 655/tcp
|
||||||
|
tinc 655/udp
|
||||||
|
rsync 873/tcp
|
||||||
|
rsync 873/udp
|
||||||
|
ftps-data 989/tcp
|
||||||
|
ftps 990/tcp
|
||||||
|
imaps 993/tcp
|
||||||
|
imaps 993/udp
|
||||||
|
ircs 994/tcp
|
||||||
|
ircs 994/udp
|
||||||
|
pop3s 995/tcp
|
||||||
|
pop3s 995/udp
|
||||||
|
socks 1080/tcp
|
||||||
|
socks 1080/udp
|
||||||
|
openvpn 1194/tcp
|
||||||
|
openvpn 1194/udp
|
||||||
|
l2f 1701/tcp l2tp
|
||||||
|
l2f 1701/udp l2tp
|
||||||
|
radius 1812/tcp
|
||||||
|
radius 1812/udp
|
||||||
|
radius-acct 1813/tcp radacct
|
||||||
|
radius-acct 1813/udp radacct
|
||||||
|
nfs 2049/tcp
|
||||||
|
nfs 2049/udp
|
||||||
|
dict 2628/tcp
|
||||||
|
dict 2628/udp
|
||||||
|
gpsd 2947/tcp
|
||||||
|
gpsd 2947/udp
|
||||||
|
icpv2 3130/tcp icp
|
||||||
|
icpv2 3130/udp icp
|
||||||
|
mysql 3306/tcp
|
||||||
|
mysql 3306/udp
|
||||||
|
nut 3493/tcp
|
||||||
|
nut 3493/udp
|
||||||
|
distcc 3632/tcp
|
||||||
|
distcc 3632/udp
|
||||||
|
daap 3689/tcp
|
||||||
|
daap 3689/udp
|
||||||
|
svn 3690/tcp subversion
|
||||||
|
svn 3690/udp subversion
|
||||||
|
epmd 4369/tcp
|
||||||
|
epmd 4369/udp
|
||||||
|
iax 4569/tcp
|
||||||
|
iax 4569/udp
|
||||||
|
mtn 4691/tcp
|
||||||
|
mtn 4691/udp
|
||||||
|
munin 4949/tcp
|
||||||
|
sip 5060/tcp
|
||||||
|
sip 5060/udp
|
||||||
|
sip-tls 5061/tcp
|
||||||
|
sip-tls 5061/udp
|
||||||
|
xmpp-client 5222/tcp jabber-client
|
||||||
|
xmpp-client 5222/udp jabber-client
|
||||||
|
xmpp-server 5269/tcp jabber-server
|
||||||
|
xmpp-server 5269/udp jabber-server
|
||||||
|
mdns 5353/tcp
|
||||||
|
mdns 5353/udp
|
||||||
|
postgresql 5432/tcp postgres
|
||||||
|
postgresql 5432/udp postgres
|
||||||
|
x11 6000/tcp
|
||||||
|
x11 6000/udp
|
||||||
|
mysql-proxy 6446/tcp
|
||||||
|
mysql-proxy 6446/udp
|
||||||
|
bacula-dir 9101/tcp
|
||||||
|
bacula-dir 9101/udp
|
||||||
|
bacula-fd 9102/tcp
|
||||||
|
bacula-fd 9102/udp
|
||||||
|
bacula-sd 9103/tcp
|
||||||
|
bacula-sd 9103/udp
|
||||||
|
nbd 10809/tcp
|
||||||
|
zabbix-agent 10050/tcp
|
||||||
|
zabbix-agent 10050/udp
|
||||||
|
zabbix-trapper 10051/tcp
|
||||||
|
zabbix-trapper 10051/udp
|
||||||
|
hkp 11371/tcp
|
||||||
|
hkp 11371/udp
|
||||||
|
ssmtp 465/tcp smtps
|
||||||
|
spamd 783/tcp
|
||||||
|
zebrasrv 2600/tcp
|
||||||
|
zebra 2601/tcp
|
||||||
|
ripd 2602/tcp
|
||||||
|
ripngd 2603/tcp
|
||||||
|
ospfd 2604/tcp
|
||||||
|
bgpd 2605/tcp
|
||||||
|
ospf6d 2606/tcp
|
||||||
|
ospfapi 2607/tcp
|
||||||
|
isisd 2608/tcp
|
||||||
|
sane-port 6566/tcp sane saned
|
||||||
|
ircd 6667/tcp
|
||||||
|
git 9418/tcp
|
||||||
|
|
5
lg_webOS/base-files/ipk/etc/shadow
Normal file
5
lg_webOS/base-files/ipk/etc/shadow
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
root::0:0:99999:7:::
|
||||||
|
daemon:*:0:0:99999:7:::
|
||||||
|
ftp:*:0:0:99999:7:::
|
||||||
|
network:*:0:0:99999:7:::
|
||||||
|
nobody:*:0:0:99999:7:::
|
1
lg_webOS/base-files/ipk/etc/shells
Normal file
1
lg_webOS/base-files/ipk/etc/shells
Normal file
@ -0,0 +1 @@
|
|||||||
|
/bin/ash
|
29
lg_webOS/base-files/ipk/etc/sysctl.conf
Normal file
29
lg_webOS/base-files/ipk/etc/sysctl.conf
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
kernel.panic=3
|
||||||
|
net.ipv4.conf.default.arp_ignore=1
|
||||||
|
net.ipv4.conf.all.arp_ignore=1
|
||||||
|
net.ipv4.ip_forward=1
|
||||||
|
net.ipv4.icmp_echo_ignore_broadcasts=1
|
||||||
|
net.ipv4.icmp_ignore_bogus_error_responses=1
|
||||||
|
net.ipv4.igmp_max_memberships=100
|
||||||
|
net.ipv4.tcp_ecn=0
|
||||||
|
net.ipv4.tcp_fin_timeout=30
|
||||||
|
net.ipv4.tcp_keepalive_time=120
|
||||||
|
net.ipv4.tcp_syncookies=1
|
||||||
|
net.ipv4.tcp_timestamps=1
|
||||||
|
net.ipv4.tcp_sack=1
|
||||||
|
net.ipv4.tcp_dsack=1
|
||||||
|
|
||||||
|
net.ipv6.conf.default.forwarding=1
|
||||||
|
net.ipv6.conf.all.forwarding=1
|
||||||
|
|
||||||
|
net.netfilter.nf_conntrack_acct=1
|
||||||
|
net.netfilter.nf_conntrack_checksum=0
|
||||||
|
net.netfilter.nf_conntrack_max=16384
|
||||||
|
net.netfilter.nf_conntrack_tcp_timeout_established=7440
|
||||||
|
net.netfilter.nf_conntrack_udp_timeout=60
|
||||||
|
net.netfilter.nf_conntrack_udp_timeout_stream=180
|
||||||
|
|
||||||
|
# disable bridge firewalling by default
|
||||||
|
net.bridge.bridge-nf-call-arptables=0
|
||||||
|
net.bridge.bridge-nf-call-ip6tables=0
|
||||||
|
net.bridge.bridge-nf-call-iptables=0
|
5
lg_webOS/base-files/ipk/etc/sysupgrade.conf
Normal file
5
lg_webOS/base-files/ipk/etc/sysupgrade.conf
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
## This file contains files and directories that should
|
||||||
|
## be preserved during an upgrade.
|
||||||
|
|
||||||
|
# /etc/example.conf
|
||||||
|
# /etc/openvpn/
|
12
lg_webOS/base-files/ipk/etc/uci-defaults/10_migrate-shadow
Normal file
12
lg_webOS/base-files/ipk/etc/uci-defaults/10_migrate-shadow
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
local ppwd="$(sed -ne '/^root:/s/^root:\([^:]*\):.*$/\1/p' /etc/passwd)"
|
||||||
|
local spwd="$(sed -ne '/^root:/s/^root:\([^:]*\):.*$/\1/p' /etc/shadow)"
|
||||||
|
|
||||||
|
if [ -n "${ppwd#[\!x]}" ] && [ -z "${spwd#[\!x]}" ]; then
|
||||||
|
logger -t migrate-shadow "Moving root password hash into shadow database"
|
||||||
|
sed -i -e "s:^root\:[^\:]*\::root\:x\::" /etc/passwd
|
||||||
|
sed -i -e "s:^root\:[^\:]*\::root\:$ppwd\::" /etc/shadow
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
16
lg_webOS/base-files/ipk/etc/uci-defaults/11_migrate-sysctl
Normal file
16
lg_webOS/base-files/ipk/etc/uci-defaults/11_migrate-sysctl
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if [ ! -f "/rom/etc/sysctl.conf" ] || cmp -s "/rom/etc/sysctl.conf" "/etc/sysctl.conf"; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
fingerprint="$(md5sum /etc/sysctl.conf)"
|
||||||
|
fingerprint="${fingerprint%% *}"
|
||||||
|
|
||||||
|
if [ "$fingerprint" = "1b05ebb41f72cb84e5510573cd4aca26" ] || \
|
||||||
|
[ "$fingerprint" = "62deb895be1a7f496040187b7c930e4e" ]; then
|
||||||
|
logger -t migrate-sysctl "Updating sysctl.conf to use current defaults"
|
||||||
|
cp "/rom/etc/sysctl.conf" "/etc/sysctl.conf"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ "$(uci -q get network.globals.ula_prefix)" != "auto" ] && exit 0
|
||||||
|
|
||||||
|
r1=$(dd if=/dev/urandom bs=1 count=1 |hexdump -e '1/1 "%02x"')
|
||||||
|
r2=$(dd if=/dev/urandom bs=2 count=1 |hexdump -e '2/1 "%02x"')
|
||||||
|
r3=$(dd if=/dev/urandom bs=2 count=1 |hexdump -e '2/1 "%02x"')
|
||||||
|
|
||||||
|
uci -q batch <<-EOF >/dev/null
|
||||||
|
set network.globals.ula_prefix=fd$r1:$r2:$r3::/48
|
||||||
|
commit network
|
||||||
|
EOF
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
4
lg_webOS/base-files/ipk/init
Executable file
4
lg_webOS/base-files/ipk/init
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
export INITRAMFS=1
|
||||||
|
exec /sbin/init
|
322
lg_webOS/base-files/ipk/lib/functions.sh
Executable file
322
lg_webOS/base-files/ipk/lib/functions.sh
Executable file
@ -0,0 +1,322 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2014 OpenWrt.org
|
||||||
|
# Copyright (C) 2006 Fokus Fraunhofer <carsten.tittel@fokus.fraunhofer.de>
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
|
||||||
|
debug () {
|
||||||
|
${DEBUG:-:} "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
# newline
|
||||||
|
N="
|
||||||
|
"
|
||||||
|
|
||||||
|
_C=0
|
||||||
|
NO_EXPORT=1
|
||||||
|
LOAD_STATE=1
|
||||||
|
LIST_SEP=" "
|
||||||
|
|
||||||
|
append() {
|
||||||
|
local var="$1"
|
||||||
|
local value="$2"
|
||||||
|
local sep="${3:- }"
|
||||||
|
|
||||||
|
eval "export ${NO_EXPORT:+-n} -- \"$var=\${$var:+\${$var}\${value:+\$sep}}\$value\""
|
||||||
|
}
|
||||||
|
|
||||||
|
list_contains() {
|
||||||
|
local var="$1"
|
||||||
|
local str="$2"
|
||||||
|
local val
|
||||||
|
|
||||||
|
eval "val=\" \${$var} \""
|
||||||
|
[ "${val%% $str *}" != "$val" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
config_load() {
|
||||||
|
[ -n "$IPKG_INSTROOT" ] && return 0
|
||||||
|
uci_load "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
reset_cb() {
|
||||||
|
config_cb() { return 0; }
|
||||||
|
option_cb() { return 0; }
|
||||||
|
list_cb() { return 0; }
|
||||||
|
}
|
||||||
|
reset_cb
|
||||||
|
|
||||||
|
package() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
config () {
|
||||||
|
local cfgtype="$1"
|
||||||
|
local name="$2"
|
||||||
|
|
||||||
|
export ${NO_EXPORT:+-n} CONFIG_NUM_SECTIONS=$(($CONFIG_NUM_SECTIONS + 1))
|
||||||
|
name="${name:-cfg$CONFIG_NUM_SECTIONS}"
|
||||||
|
append CONFIG_SECTIONS "$name"
|
||||||
|
[ -n "$NO_CALLBACK" ] || config_cb "$cfgtype" "$name"
|
||||||
|
export ${NO_EXPORT:+-n} CONFIG_SECTION="$name"
|
||||||
|
export ${NO_EXPORT:+-n} "CONFIG_${CONFIG_SECTION}_TYPE=$cfgtype"
|
||||||
|
}
|
||||||
|
|
||||||
|
option () {
|
||||||
|
local varname="$1"; shift
|
||||||
|
local value="$*"
|
||||||
|
|
||||||
|
export ${NO_EXPORT:+-n} "CONFIG_${CONFIG_SECTION}_${varname}=$value"
|
||||||
|
[ -n "$NO_CALLBACK" ] || option_cb "$varname" "$*"
|
||||||
|
}
|
||||||
|
|
||||||
|
list() {
|
||||||
|
local varname="$1"; shift
|
||||||
|
local value="$*"
|
||||||
|
local len
|
||||||
|
|
||||||
|
config_get len "$CONFIG_SECTION" "${varname}_LENGTH" 0
|
||||||
|
[ $len = 0 ] && append CONFIG_LIST_STATE "${CONFIG_SECTION}_${varname}"
|
||||||
|
len=$(($len + 1))
|
||||||
|
config_set "$CONFIG_SECTION" "${varname}_ITEM$len" "$value"
|
||||||
|
config_set "$CONFIG_SECTION" "${varname}_LENGTH" "$len"
|
||||||
|
append "CONFIG_${CONFIG_SECTION}_${varname}" "$value" "$LIST_SEP"
|
||||||
|
list_cb "$varname" "$*"
|
||||||
|
}
|
||||||
|
|
||||||
|
config_unset() {
|
||||||
|
config_set "$1" "$2" ""
|
||||||
|
}
|
||||||
|
|
||||||
|
# config_get <variable> <section> <option> [<default>]
|
||||||
|
# config_get <section> <option>
|
||||||
|
config_get() {
|
||||||
|
case "$3" in
|
||||||
|
"") eval echo "\${CONFIG_${1}_${2}:-\${4}}";;
|
||||||
|
*) eval export ${NO_EXPORT:+-n} -- "${1}=\${CONFIG_${2}_${3}:-\${4}}";;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# config_get_bool <variable> <section> <option> [<default>]
|
||||||
|
config_get_bool() {
|
||||||
|
local _tmp
|
||||||
|
config_get _tmp "$2" "$3" "$4"
|
||||||
|
case "$_tmp" in
|
||||||
|
1|on|true|yes|enabled) _tmp=1;;
|
||||||
|
0|off|false|no|disabled) _tmp=0;;
|
||||||
|
*) _tmp="$4";;
|
||||||
|
esac
|
||||||
|
export ${NO_EXPORT:+-n} "$1=$_tmp"
|
||||||
|
}
|
||||||
|
|
||||||
|
config_set() {
|
||||||
|
local section="$1"
|
||||||
|
local option="$2"
|
||||||
|
local value="$3"
|
||||||
|
local old_section="$CONFIG_SECTION"
|
||||||
|
|
||||||
|
CONFIG_SECTION="$section"
|
||||||
|
option "$option" "$value"
|
||||||
|
CONFIG_SECTION="$old_section"
|
||||||
|
}
|
||||||
|
|
||||||
|
config_foreach() {
|
||||||
|
local ___function="$1"
|
||||||
|
[ "$#" -ge 1 ] && shift
|
||||||
|
local ___type="$1"
|
||||||
|
[ "$#" -ge 1 ] && shift
|
||||||
|
local section cfgtype
|
||||||
|
|
||||||
|
[ -z "$CONFIG_SECTIONS" ] && return 0
|
||||||
|
for section in ${CONFIG_SECTIONS}; do
|
||||||
|
config_get cfgtype "$section" TYPE
|
||||||
|
[ -n "$___type" -a "x$cfgtype" != "x$___type" ] && continue
|
||||||
|
eval "$___function \"\$section\" \"\$@\""
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
config_list_foreach() {
|
||||||
|
[ "$#" -ge 3 ] || return 0
|
||||||
|
local section="$1"; shift
|
||||||
|
local option="$1"; shift
|
||||||
|
local function="$1"; shift
|
||||||
|
local val
|
||||||
|
local len
|
||||||
|
local c=1
|
||||||
|
|
||||||
|
config_get len "${section}" "${option}_LENGTH"
|
||||||
|
[ -z "$len" ] && return 0
|
||||||
|
while [ $c -le "$len" ]; do
|
||||||
|
config_get val "${section}" "${option}_ITEM$c"
|
||||||
|
eval "$function \"\$val\" \"\$@\""
|
||||||
|
c="$(($c + 1))"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
insert_modules() {
|
||||||
|
for m in $*; do
|
||||||
|
if [ -f /etc/modules.d/$m ]; then
|
||||||
|
sed 's/^[^#]/insmod &/' /etc/modules.d/$m | ash 2>&- || :
|
||||||
|
else
|
||||||
|
modprobe $m
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
default_prerm() {
|
||||||
|
local name
|
||||||
|
name=$(basename ${1%.*})
|
||||||
|
[ -f /usr/lib/opkg/info/${name}.prerm-pkg ] && . /usr/lib/opkg/info/${name}.prerm-pkg
|
||||||
|
for i in `cat /usr/lib/opkg/info/${name}.list | grep "^/etc/init.d/"`; do
|
||||||
|
$i disable
|
||||||
|
$i stop
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
default_postinst() {
|
||||||
|
local pkgname rusers
|
||||||
|
pkgname=$(basename ${1%.*})
|
||||||
|
rusers=$(grep "Require-User:" ${IPKG_INSTROOT}/usr/lib/opkg/info/${pkgname}.control)
|
||||||
|
[ -n "$rusers" ] && {
|
||||||
|
local user group uid gid
|
||||||
|
for a in $(echo $rusers | sed "s/Require-User://g"); do
|
||||||
|
user=""
|
||||||
|
group=""
|
||||||
|
for b in $(echo $a | sed "s/:/ /g"); do
|
||||||
|
local ugname ugid
|
||||||
|
|
||||||
|
ugname=$(echo $b | cut -d= -f1)
|
||||||
|
ugid=$(echo $b | cut -d= -f2)
|
||||||
|
|
||||||
|
[ -z "$user" ] && {
|
||||||
|
user=$ugname
|
||||||
|
uid=$ugid
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
gid=$ugid
|
||||||
|
[ -n "$gid" ] && {
|
||||||
|
group_exists $ugname || group_add $ugname $gid
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -z "$gid" ] && {
|
||||||
|
group_add_next $ugname
|
||||||
|
gid=$?
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -z "$group" ] && {
|
||||||
|
user_exists $user || user_add $user "$uid" $gid
|
||||||
|
group=$ugname
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
group_add_user $ugname $user
|
||||||
|
done
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -f ${IPKG_INSTROOT}/usr/lib/opkg/info/${pkgname}.postinst-pkg ] && ( . ${IPKG_INSTROOT}/usr/lib/opkg/info/${pkgname}.postinst-pkg )
|
||||||
|
[ -n "${IPKG_INSTROOT}" ] || rm -f /tmp/luci-indexcache 2>/dev/null
|
||||||
|
|
||||||
|
[ "$PKG_UPGRADE" = "1" ] || for i in `cat ${IPKG_INSTROOT}/usr/lib/opkg/info/${pkgname}.list | grep "^/etc/init.d/"`; do
|
||||||
|
[ -n "${IPKG_INSTROOT}" ] && $(which bash) ${IPKG_INSTROOT}/etc/rc.common ${IPKG_INSTROOT}$i enable; \
|
||||||
|
[ -n "${IPKG_INSTROOT}" ] || {
|
||||||
|
$i enable
|
||||||
|
$i start
|
||||||
|
}
|
||||||
|
done
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
include() {
|
||||||
|
local file
|
||||||
|
|
||||||
|
for file in $(ls $1/*.sh 2>/dev/null); do
|
||||||
|
. $file
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
find_mtd_index() {
|
||||||
|
local PART="$(grep "\"$1\"" /proc/mtd | awk -F: '{print $1}')"
|
||||||
|
local INDEX="${PART##mtd}"
|
||||||
|
|
||||||
|
echo ${INDEX}
|
||||||
|
}
|
||||||
|
|
||||||
|
find_mtd_part() {
|
||||||
|
local INDEX=$(find_mtd_index "$1")
|
||||||
|
local PREFIX=/dev/mtdblock
|
||||||
|
|
||||||
|
[ -d /dev/mtdblock ] && PREFIX=/dev/mtdblock/
|
||||||
|
echo "${INDEX:+$PREFIX$INDEX}"
|
||||||
|
}
|
||||||
|
|
||||||
|
group_add() {
|
||||||
|
local name="$1"
|
||||||
|
local gid="$2"
|
||||||
|
local rc
|
||||||
|
[ -f "${IPKG_INSTROOT}/etc/group" ] || return 1
|
||||||
|
[ -n "$IPKG_INSTROOT" ] || lock /var/lock/group
|
||||||
|
echo "${name}:x:${gid}:" >> ${IPKG_INSTROOT}/etc/group
|
||||||
|
rc=$?
|
||||||
|
[ -n "$IPKG_INSTROOT" ] || lock -u /var/lock/group
|
||||||
|
return $rc
|
||||||
|
}
|
||||||
|
|
||||||
|
group_exists() {
|
||||||
|
grep -qs "^${1}:" ${IPKG_INSTROOT}/etc/group
|
||||||
|
}
|
||||||
|
|
||||||
|
group_add_next() {
|
||||||
|
local gid gids
|
||||||
|
gid=$(grep -s "^${1}:" ${IPKG_INSTROOT}/etc/group | cut -d: -f3)
|
||||||
|
[ -n "$gid" ] && return $gid
|
||||||
|
gids=$(cat ${IPKG_INSTROOT}/etc/group | cut -d: -f3)
|
||||||
|
gid=100
|
||||||
|
while [ -n "$(echo $gids | grep $gid)" ] ; do
|
||||||
|
gid=$((gid + 1))
|
||||||
|
done
|
||||||
|
group_add $1 $gid
|
||||||
|
return $gid
|
||||||
|
}
|
||||||
|
|
||||||
|
group_add_user() {
|
||||||
|
local grp delim=","
|
||||||
|
grp=$(grep -s "^${1}:" ${IPKG_INSTROOT}/etc/group)
|
||||||
|
[ -z "$(echo $grp | cut -d: -f4 | grep $2)" ] || return
|
||||||
|
[ -n "$(echo $grp | grep ":$")" ] && delim=""
|
||||||
|
[ -n "$IPKG_INSTROOT" ] || lock /var/lock/passwd
|
||||||
|
sed -i "s/$grp/$grp$delim$2/g" ${IPKG_INSTROOT}/etc/group
|
||||||
|
[ -n "$IPKG_INSTROOT" ] || lock -u /var/lock/passwd
|
||||||
|
}
|
||||||
|
|
||||||
|
user_add() {
|
||||||
|
local name="${1}"
|
||||||
|
local uid="${2}"
|
||||||
|
local gid="${3}"
|
||||||
|
local desc="${4:-$1}"
|
||||||
|
local home="${5:-/var/run/$1}"
|
||||||
|
local shell="${6:-/bin/false}"
|
||||||
|
local rc
|
||||||
|
[ -z "$uid" ] && {
|
||||||
|
uids=$(cat ${IPKG_INSTROOT}/etc/passwd | cut -d: -f3)
|
||||||
|
uid=100
|
||||||
|
while [ -n "$(echo $uids | grep $uid)" ] ; do
|
||||||
|
uid=$((uid + 1))
|
||||||
|
done
|
||||||
|
}
|
||||||
|
[ -z "$gid" ] && gid=$uid
|
||||||
|
[ -f "${IPKG_INSTROOT}/etc/passwd" ] || return 1
|
||||||
|
[ -n "$IPKG_INSTROOT" ] || lock /var/lock/passwd
|
||||||
|
echo "${name}:x:${uid}:${gid}:${desc}:${home}:${shell}" >> ${IPKG_INSTROOT}/etc/passwd
|
||||||
|
echo "${name}:x:0:0:99999:7:::" >> ${IPKG_INSTROOT}/etc/shadow
|
||||||
|
rc=$?
|
||||||
|
[ -n "$IPKG_INSTROOT" ] || lock -u /var/lock/passwd
|
||||||
|
return $rc
|
||||||
|
}
|
||||||
|
|
||||||
|
user_exists() {
|
||||||
|
grep -qs "^${1}:" ${IPKG_INSTROOT}/etc/passwd
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -z "$IPKG_INSTROOT" -a -f /lib/config/uci.sh ] && . /lib/config/uci.sh
|
72
lg_webOS/base-files/ipk/lib/functions/leds.sh
Normal file
72
lg_webOS/base-files/ipk/lib/functions/leds.sh
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2013 OpenWrt.org
|
||||||
|
|
||||||
|
led_set_attr() {
|
||||||
|
[ -f "/sys/class/leds/$1/$2" ] && echo "$3" > "/sys/class/leds/$1/$2"
|
||||||
|
}
|
||||||
|
|
||||||
|
led_timer() {
|
||||||
|
led_set_attr $1 "trigger" "timer"
|
||||||
|
led_set_attr $1 "delay_on" "$2"
|
||||||
|
led_set_attr $1 "delay_off" "$3"
|
||||||
|
}
|
||||||
|
|
||||||
|
led_on() {
|
||||||
|
led_set_attr $1 "trigger" "none"
|
||||||
|
led_set_attr $1 "brightness" 255
|
||||||
|
}
|
||||||
|
|
||||||
|
led_off() {
|
||||||
|
led_set_attr $1 "trigger" "none"
|
||||||
|
led_set_attr $1 "brightness" 0
|
||||||
|
}
|
||||||
|
|
||||||
|
led_morse() {
|
||||||
|
led_set_attr $1 "trigger" "morse"
|
||||||
|
led_set_attr $1 "delay" "$2"
|
||||||
|
led_set_attr $1 "message" "$3"
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_set_timer() {
|
||||||
|
led_timer $status_led "$1" "$2"
|
||||||
|
[ -n "$status_led2" ] && led_timer $status_led2 "$1" "$2"
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_set_heartbeat() {
|
||||||
|
led_set_attr $status_led "trigger" "heartbeat"
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_set_morse() {
|
||||||
|
led_morse $status_led "$1" "$2"
|
||||||
|
[ -n "$status_led2" ] && led_morse $status_led2 "$1" "$2"
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_on() {
|
||||||
|
led_on $status_led
|
||||||
|
[ -n "$status_led2" ] && led_on $status_led2
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_off() {
|
||||||
|
led_off $status_led
|
||||||
|
[ -n "$status_led2" ] && led_off $status_led2
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_blink_slow() {
|
||||||
|
led_timer $status_led 1000 1000
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_blink_fast() {
|
||||||
|
led_timer $status_led 100 100
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_blink_preinit() {
|
||||||
|
led_timer $status_led 100 100
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_blink_failsafe() {
|
||||||
|
led_timer $status_led 50 50
|
||||||
|
}
|
||||||
|
|
||||||
|
status_led_blink_preinit_regular() {
|
||||||
|
led_timer $status_led 200 200
|
||||||
|
}
|
268
lg_webOS/base-files/ipk/lib/functions/network.sh
Normal file
268
lg_webOS/base-files/ipk/lib/functions/network.sh
Normal file
@ -0,0 +1,268 @@
|
|||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
# 3: path
|
||||||
|
# 4: separator
|
||||||
|
# 5: limit
|
||||||
|
__network_ifstatus() {
|
||||||
|
local __tmp
|
||||||
|
|
||||||
|
[ -z "$__NETWORK_CACHE" ] && \
|
||||||
|
export __NETWORK_CACHE="$(ubus call network.interface dump)"
|
||||||
|
|
||||||
|
__tmp="$(jsonfilter ${4:+-F "$4"} ${5:+-l "$5"} -s "$__NETWORK_CACHE" -e "$1=@.interface${2:+[@.interface='$2']}$3")"
|
||||||
|
|
||||||
|
[ -z "$__tmp" ] && \
|
||||||
|
unset "$1" && \
|
||||||
|
return 1
|
||||||
|
|
||||||
|
eval "$__tmp"
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine first IPv4 address of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_ipaddr() {
|
||||||
|
__network_ifstatus "$1" "$2" "['ipv4-address'][0].address";
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine first IPv6 address of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_ipaddr6() {
|
||||||
|
local __addr
|
||||||
|
|
||||||
|
if __network_ifstatus "__addr" "$2" "['ipv6-address','ipv6-prefix-assignment'][0].address"; then
|
||||||
|
case "$__addr" in
|
||||||
|
*:) export "$1=${__addr}1" ;;
|
||||||
|
*) export "$1=${__addr}" ;;
|
||||||
|
esac
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
unset $1
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine first IPv4 subnet of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_subnet() {
|
||||||
|
__network_ifstatus "$1" "$2" "['ipv4-address'][0]['address','mask']" "/"
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine first IPv6 subnet of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_subnet6() {
|
||||||
|
__network_ifstatus "$1" "$2" "['ipv6-address'][0]['address','mask']" "/"
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine first IPv6 prefix of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_prefix6() {
|
||||||
|
__network_ifstatus "$1" "$2" "['ipv6-prefix'][0]['address','mask']" "/"
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine all IPv4 addresses of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_ipaddrs() {
|
||||||
|
__network_ifstatus "$1" "$2" "['ipv4-address'][*].address"
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine all IPv6 addresses of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_ipaddrs6() {
|
||||||
|
local __addr
|
||||||
|
local __list=""
|
||||||
|
|
||||||
|
if __network_ifstatus "__addr" "$2" "['ipv6-address','ipv6-prefix-assignment'][*].address"; then
|
||||||
|
for __addr in $__addr; do
|
||||||
|
case "$__addr" in
|
||||||
|
*:) __list="${__list:+$__list }${__addr}1" ;;
|
||||||
|
*) __list="${__list:+$__list }${__addr}" ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
export "$1=$__list"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
unset "$1"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine all IP addresses of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_ipaddrs_all() {
|
||||||
|
local __addr
|
||||||
|
local __list=""
|
||||||
|
|
||||||
|
if __network_ifstatus "__addr" "$2" "['ipv4-address','ipv6-address','ipv6-prefix-assignment'][*].address"; then
|
||||||
|
for __addr in $__addr; do
|
||||||
|
case "$__addr" in
|
||||||
|
*:) __list="${__list:+$__list }${__addr}1" ;;
|
||||||
|
*) __list="${__list:+$__list }${__addr}" ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
export "$1=$__list"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
unset "$1"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine all IPv4 subnets of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_subnets() {
|
||||||
|
__network_ifstatus "$1" "$2" "['ipv4-address'][*]['address','mask']" "/ "
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine all IPv6 subnets of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_subnets6() {
|
||||||
|
local __addr
|
||||||
|
local __list=""
|
||||||
|
|
||||||
|
if __network_ifstatus "__addr" "$2" "['ipv6-address','ipv6-prefix-assignment'][*]['address','mask']" "/ "; then
|
||||||
|
for __addr in $__addr; do
|
||||||
|
case "$__addr" in
|
||||||
|
*:/*) __list="${__list:+$__list }${__addr%/*}1/${__addr##*/}" ;;
|
||||||
|
*) __list="${__list:+$__list }${__addr}" ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
export "$1=$__list"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
unset "$1"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine all IPv6 prefixes of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_prefixes6() {
|
||||||
|
__network_ifstatus "$1" "$2" "['ipv6-prefix'][*]['address','mask']" "/ "
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine IPv4 gateway of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
# 3: consider inactive gateway if "true" (optional)
|
||||||
|
network_get_gateway() {
|
||||||
|
__network_ifstatus "$1" "$2" ".route[@.target='0.0.0.0' && !@.table].nexthop" "" 1 && \
|
||||||
|
return 0
|
||||||
|
|
||||||
|
[ "$3" = 1 -o "$3" = "true" ] && \
|
||||||
|
__network_ifstatus "$1" "$2" ".inactive.route[@.target='0.0.0.0' && !@.table].nexthop" "" 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine IPv6 gateway of given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
# 3: consider inactive gateway if "true" (optional)
|
||||||
|
network_get_gateway6() {
|
||||||
|
__network_ifstatus "$1" "$2" ".route[@.target='::' && !@.table].nexthop" "" 1 && \
|
||||||
|
return 0
|
||||||
|
|
||||||
|
[ "$3" = 1 -o "$3" = "true" ] && \
|
||||||
|
__network_ifstatus "$1" "$2" ".inactive.route[@.target='::' && !@.table].nexthop" "" 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine the DNS servers of the given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
# 3: consider inactive servers if "true" (optional)
|
||||||
|
network_get_dnsserver() {
|
||||||
|
__network_ifstatus "$1" "$2" "['dns-server'][*]" && return 0
|
||||||
|
|
||||||
|
[ "$3" = 1 -o "$3" = "true" ] && \
|
||||||
|
__network_ifstatus "$1" "$2" ".inactive['dns-server'][*]"
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine the domains of the given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
# 3: consider inactive domains if "true" (optional)
|
||||||
|
network_get_dnssearch() {
|
||||||
|
__network_ifstatus "$1" "$2" "['dns-search'][*]" && return 0
|
||||||
|
|
||||||
|
[ "$3" = 1 -o "$3" = "true" ] && \
|
||||||
|
__network_ifstatus "$1" "$2" ".inactive['dns-search'][*]"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: addr
|
||||||
|
# 3: inactive
|
||||||
|
__network_wan()
|
||||||
|
{
|
||||||
|
__network_ifstatus "$1" "" \
|
||||||
|
"[@.route[@.target='$2' && !@.table]].interface" "" 1 && \
|
||||||
|
return 0
|
||||||
|
|
||||||
|
[ "$3" = 1 -o "$3" = "true" ] && \
|
||||||
|
__network_ifstatus "$1" "" \
|
||||||
|
"[@.inactive.route[@.target='$2' && !@.table]].interface" "" 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# find the logical interface which holds the current IPv4 default route
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: consider inactive default routes if "true" (optional)
|
||||||
|
network_find_wan() { __network_wan "$1" "0.0.0.0" "$2"; }
|
||||||
|
|
||||||
|
# find the logical interface which holds the current IPv6 default route
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: consider inactive dafault routes if "true" (optional)
|
||||||
|
network_find_wan6() { __network_wan "$1" "::" "$2"; }
|
||||||
|
|
||||||
|
# test whether the given logical interface is running
|
||||||
|
# 1: interface
|
||||||
|
network_is_up()
|
||||||
|
{
|
||||||
|
local __up
|
||||||
|
__network_ifstatus "__up" "$1" ".up" && [ "$__up" = 1 ]
|
||||||
|
}
|
||||||
|
|
||||||
|
# determine the protocol of the given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_protocol() { __network_ifstatus "$1" "$2" ".proto"; }
|
||||||
|
|
||||||
|
# determine the layer 3 linux network device of the given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_device() { __network_ifstatus "$1" "$2" ".l3_device"; }
|
||||||
|
|
||||||
|
# determine the layer 2 linux network device of the given logical interface
|
||||||
|
# 1: destination variable
|
||||||
|
# 2: interface
|
||||||
|
network_get_physdev() { __network_ifstatus "$1" "$2" ".device"; }
|
||||||
|
|
||||||
|
# defer netifd actions on the given linux network device
|
||||||
|
# 1: device name
|
||||||
|
network_defer_device()
|
||||||
|
{
|
||||||
|
ubus call network.device set_state \
|
||||||
|
"$(printf '{ "name": "%s", "defer": true }' "$1")" 2>/dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
# continue netifd actions on the given linux network device
|
||||||
|
# 1: device name
|
||||||
|
network_ready_device()
|
||||||
|
{
|
||||||
|
ubus call network.device set_state \
|
||||||
|
"$(printf '{ "name": "%s", "defer": false }' "$1")" 2>/dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
# flush the internal value cache to force re-reading values from ubus
|
||||||
|
network_flush_cache() { unset __NETWORK_CACHE; }
|
88
lg_webOS/base-files/ipk/lib/functions/preinit.sh
Normal file
88
lg_webOS/base-files/ipk/lib/functions/preinit.sh
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2013 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
boot_hook_splice_start() {
|
||||||
|
export -n PI_HOOK_SPLICE=1
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_splice_finish() {
|
||||||
|
local hook
|
||||||
|
for hook in $PI_STACK_LIST; do
|
||||||
|
local v; eval "v=\${${hook}_splice:+\$${hook}_splice }$hook"
|
||||||
|
export -n "${hook}=${v% }"
|
||||||
|
export -n "${hook}_splice="
|
||||||
|
done
|
||||||
|
export -n PI_HOOK_SPLICE=
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_init() {
|
||||||
|
local hook="${1}_hook"
|
||||||
|
export -n "PI_STACK_LIST=${PI_STACK_LIST:+$PI_STACK_LIST }$hook"
|
||||||
|
export -n "$hook="
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add() {
|
||||||
|
local hook="${1}_hook${PI_HOOK_SPLICE:+_splice}"
|
||||||
|
local func="${2}"
|
||||||
|
|
||||||
|
[ -n "$func" ] && {
|
||||||
|
local v; eval "v=\$$hook"
|
||||||
|
export -n "$hook=${v:+$v }$func"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_shift() {
|
||||||
|
local hook="${1}_hook"
|
||||||
|
local rvar="${2}"
|
||||||
|
|
||||||
|
local v; eval "v=\$$hook"
|
||||||
|
[ -n "$v" ] && {
|
||||||
|
local first="${v%% *}"
|
||||||
|
|
||||||
|
[ "$v" != "${v#* }" ] && \
|
||||||
|
export -n "$hook=${v#* }" || \
|
||||||
|
export -n "$hook="
|
||||||
|
|
||||||
|
export -n "$rvar=$first"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_run_hook() {
|
||||||
|
local hook="$1"
|
||||||
|
local func
|
||||||
|
|
||||||
|
while boot_hook_shift "$hook" func; do
|
||||||
|
local ran; eval "ran=\$PI_RAN_$func"
|
||||||
|
[ -n "$ran" ] || {
|
||||||
|
export -n "PI_RAN_$func=1"
|
||||||
|
$func "$1" "$2"
|
||||||
|
}
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
pivot() { # <new_root> <old_root>
|
||||||
|
/bin/mount -o noatime,move /proc $1/proc && \
|
||||||
|
pivot_root $1 $1$2 && {
|
||||||
|
/bin/mount -o noatime,move $2/dev /dev
|
||||||
|
/bin/mount -o noatime,move $2/tmp /tmp
|
||||||
|
/bin/mount -o noatime,move $2/sys /sys 2>&-
|
||||||
|
/bin/mount -o noatime,move $2/overlay /overlay 2>&-
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fopivot() { # <rw_root> <work_dir> <ro_root> <dupe?>
|
||||||
|
/bin/mount -o noatime,lowerdir=/,upperdir=$1,workdir=$2 -t overlay "overlayfs:$1" /mnt
|
||||||
|
pivot /mnt $3
|
||||||
|
}
|
||||||
|
|
||||||
|
ramoverlay() {
|
||||||
|
mkdir -p /tmp/root
|
||||||
|
/bin/mount -t tmpfs -o noatime,mode=0755 root /tmp/root
|
||||||
|
mkdir -p /tmp/root/root /tmp/root/work
|
||||||
|
fopivot /tmp/root/root /tmp/root/work /rom 1
|
||||||
|
}
|
103
lg_webOS/base-files/ipk/lib/functions/service.sh
Normal file
103
lg_webOS/base-files/ipk/lib/functions/service.sh
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
#
|
||||||
|
# service: simple wrapper around start-stop-daemon
|
||||||
|
#
|
||||||
|
# Usage: service ACTION EXEC ARGS...
|
||||||
|
#
|
||||||
|
# Action:
|
||||||
|
# -C check if EXEC is alive
|
||||||
|
# -S start EXEC, passing it ARGS as its arguments
|
||||||
|
# -K kill EXEC, sending it a TERM signal if not specified otherwise
|
||||||
|
#
|
||||||
|
# Environment variables exposed:
|
||||||
|
# SERVICE_DAEMONIZE run EXEC in background
|
||||||
|
# SERVICE_WRITE_PID create a pid-file and use it for matching
|
||||||
|
# SERVICE_MATCH_EXEC use EXEC command-line for matching (default)
|
||||||
|
# SERVICE_MATCH_NAME use EXEC process name for matching
|
||||||
|
# SERVICE_USE_PID assume EXEC create its own pid-file and use it for matching
|
||||||
|
# SERVICE_NAME process name to use (default to EXEC file part)
|
||||||
|
# SERVICE_PID_FILE pid file to use (default to /var/run/$SERVICE_NAME.pid)
|
||||||
|
# SERVICE_SIG signal to send when using -K
|
||||||
|
# SERVICE_SIG_RELOAD default signal used when reloading
|
||||||
|
# SERVICE_SIG_STOP default signal used when stopping
|
||||||
|
# SERVICE_STOP_TIME time to wait for a process to stop gracefully before killing it
|
||||||
|
# SERVICE_UID user EXEC should be run as
|
||||||
|
# SERVICE_GID group EXEC should be run as
|
||||||
|
#
|
||||||
|
# SERVICE_DEBUG don't do anything, but show what would be done
|
||||||
|
# SERVICE_QUIET don't print anything
|
||||||
|
#
|
||||||
|
|
||||||
|
SERVICE_QUIET=1
|
||||||
|
SERVICE_SIG_RELOAD="HUP"
|
||||||
|
SERVICE_SIG_STOP="TERM"
|
||||||
|
SERVICE_STOP_TIME=5
|
||||||
|
SERVICE_MATCH_EXEC=1
|
||||||
|
|
||||||
|
service() {
|
||||||
|
local ssd
|
||||||
|
local exec
|
||||||
|
local name
|
||||||
|
local start
|
||||||
|
ssd="${SERVICE_DEBUG:+echo }start-stop-daemon${SERVICE_QUIET:+ -q}"
|
||||||
|
case "$1" in
|
||||||
|
-C)
|
||||||
|
ssd="$ssd -K -t"
|
||||||
|
;;
|
||||||
|
-S)
|
||||||
|
ssd="$ssd -S${SERVICE_DAEMONIZE:+ -b}${SERVICE_WRITE_PID:+ -m}"
|
||||||
|
start=1
|
||||||
|
;;
|
||||||
|
-K)
|
||||||
|
ssd="$ssd -K${SERVICE_SIG:+ -s $SERVICE_SIG}"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "service: unknown ACTION '$1'" 1>&2
|
||||||
|
return 1
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
exec="$1"
|
||||||
|
[ -n "$exec" ] || {
|
||||||
|
echo "service: missing argument" 1>&2
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
[ -x "$exec" ] || {
|
||||||
|
echo "service: file '$exec' is not executable" 1>&2
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
name="${SERVICE_NAME:-${exec##*/}}"
|
||||||
|
[ -z "$SERVICE_USE_PID$SERVICE_WRITE_PID$SERVICE_PID_FILE" ] \
|
||||||
|
|| ssd="$ssd -p ${SERVICE_PID_FILE:-/var/run/$name.pid}"
|
||||||
|
[ -z "$SERVICE_MATCH_NAME" ] || ssd="$ssd -n $name"
|
||||||
|
ssd="$ssd${SERVICE_UID:+ -c $SERVICE_UID${SERVICE_GID:+:$SERVICE_GID}}"
|
||||||
|
[ -z "$SERVICE_MATCH_EXEC$start" ] || ssd="$ssd -x $exec"
|
||||||
|
shift
|
||||||
|
$ssd${1:+ -- "$@"}
|
||||||
|
}
|
||||||
|
|
||||||
|
service_check() {
|
||||||
|
service -C "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
service_signal() {
|
||||||
|
SERVICE_SIG="${SERVICE_SIG:-USR1}" service -K "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
service_start() {
|
||||||
|
service -S "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
service_stop() {
|
||||||
|
local try
|
||||||
|
SERVICE_SIG="${SERVICE_SIG:-$SERVICE_SIG_STOP}" service -K "$@" || return 1
|
||||||
|
while [ $((try++)) -lt $SERVICE_STOP_TIME ]; do
|
||||||
|
service -C "$@" || return 0
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
SERVICE_SIG="KILL" service -K "$@"
|
||||||
|
sleep 1
|
||||||
|
! service -C "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
service_reload() {
|
||||||
|
SERVICE_SIG="${SERVICE_SIG:-$SERVICE_SIG_RELOAD}" service -K "$@"
|
||||||
|
}
|
112
lg_webOS/base-files/ipk/lib/functions/system.sh
Normal file
112
lg_webOS/base-files/ipk/lib/functions/system.sh
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
# Copyright (C) 2006-2013 OpenWrt.org
|
||||||
|
|
||||||
|
find_mtd_chardev() {
|
||||||
|
local INDEX=$(find_mtd_index "$1")
|
||||||
|
local PREFIX=/dev/mtd
|
||||||
|
|
||||||
|
[ -d /dev/mtd ] && PREFIX=/dev/mtd/
|
||||||
|
echo "${INDEX:+$PREFIX$INDEX}"
|
||||||
|
}
|
||||||
|
|
||||||
|
mtd_get_mac_ascii()
|
||||||
|
{
|
||||||
|
local mtdname="$1"
|
||||||
|
local key="$2"
|
||||||
|
local part
|
||||||
|
local mac_dirty
|
||||||
|
|
||||||
|
part=$(find_mtd_part "$mtdname")
|
||||||
|
if [ -z "$part" ]; then
|
||||||
|
echo "mtd_get_mac_ascii: partition $mtdname not found!" >&2
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
mac_dirty=$(strings "$part" | sed -n 's/^'"$key"'=//p')
|
||||||
|
|
||||||
|
# "canonicalize" mac
|
||||||
|
[ -n "$mac_dirty" ] && macaddr_canonicalize "$mac_dirty"
|
||||||
|
}
|
||||||
|
|
||||||
|
mtd_get_mac_binary() {
|
||||||
|
local mtdname="$1"
|
||||||
|
local offset="$2"
|
||||||
|
local part
|
||||||
|
|
||||||
|
part=$(find_mtd_part "$mtdname")
|
||||||
|
if [ -z "$part" ]; then
|
||||||
|
echo "mtd_get_mac_binary: partition $mtdname not found!" >&2
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
dd bs=1 skip=$offset count=6 if=$part 2>/dev/null | hexdump -v -n 6 -e '5/1 "%02x:" 1/1 "%02x"'
|
||||||
|
}
|
||||||
|
|
||||||
|
mtd_get_part_size() {
|
||||||
|
local part_name=$1
|
||||||
|
local first dev size erasesize name
|
||||||
|
while read dev size erasesize name; do
|
||||||
|
name=${name#'"'}; name=${name%'"'}
|
||||||
|
if [ "$name" = "$part_name" ]; then
|
||||||
|
echo $((0x$size))
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done < /proc/mtd
|
||||||
|
}
|
||||||
|
|
||||||
|
macaddr_add() {
|
||||||
|
local mac=$1
|
||||||
|
local val=$2
|
||||||
|
local oui=${mac%:*:*:*}
|
||||||
|
local nic=${mac#*:*:*:}
|
||||||
|
|
||||||
|
nic=$(printf "%06x" $((0x${nic//:/} + $val & 0xffffff)) | sed 's/^\(.\{2\}\)\(.\{2\}\)\(.\{2\}\)/\1:\2:\3/')
|
||||||
|
echo $oui:$nic
|
||||||
|
}
|
||||||
|
|
||||||
|
macaddr_setbit_la()
|
||||||
|
{
|
||||||
|
local mac=$1
|
||||||
|
|
||||||
|
printf "%02x:%s" $((0x${mac%%:*} | 0x02)) ${mac#*:}
|
||||||
|
}
|
||||||
|
|
||||||
|
macaddr_2bin()
|
||||||
|
{
|
||||||
|
local mac=$1
|
||||||
|
|
||||||
|
echo -ne \\x${mac//:/\\x}
|
||||||
|
}
|
||||||
|
|
||||||
|
macaddr_canonicalize()
|
||||||
|
{
|
||||||
|
local mac="$1"
|
||||||
|
local canon=""
|
||||||
|
|
||||||
|
mac=$(echo -n $mac | tr -d \")
|
||||||
|
[ ${#mac} -gt 17 ] && return
|
||||||
|
[ -n "${mac//[a-fA-F0-9\.: -]/}" ] && return
|
||||||
|
|
||||||
|
for octet in ${mac//[\.:-]/ }; do
|
||||||
|
case "${#octet}" in
|
||||||
|
1)
|
||||||
|
octet="0${octet}"
|
||||||
|
;;
|
||||||
|
2)
|
||||||
|
;;
|
||||||
|
4)
|
||||||
|
octet="${octet:0:2} ${octet:2:2}"
|
||||||
|
;;
|
||||||
|
12)
|
||||||
|
octet="${octet:0:2} ${octet:2:2} ${octet:4:2} ${octet:6:2} ${octet:8:2} ${octet:10:2}"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
return
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
canon=${canon}${canon:+ }${octet}
|
||||||
|
done
|
||||||
|
|
||||||
|
[ ${#canon} -ne 17 ] && return
|
||||||
|
|
||||||
|
printf "%02x:%02x:%02x:%02x:%02x:%02x" 0x${canon// / 0x} 2>/dev/null
|
||||||
|
}
|
302
lg_webOS/base-files/ipk/lib/functions/uci-defaults-new.sh
Executable file
302
lg_webOS/base-files/ipk/lib/functions/uci-defaults-new.sh
Executable file
@ -0,0 +1,302 @@
|
|||||||
|
#!/bin/ash
|
||||||
|
|
||||||
|
CFG=/etc/board.json
|
||||||
|
|
||||||
|
. /usr/share/libubox/jshn.sh
|
||||||
|
|
||||||
|
json_select_array() {
|
||||||
|
local _json_no_warning=1
|
||||||
|
|
||||||
|
json_select "$1"
|
||||||
|
[ $? = 0 ] && return
|
||||||
|
|
||||||
|
json_add_array $1
|
||||||
|
json_close_array
|
||||||
|
|
||||||
|
json_select "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
json_select_object() {
|
||||||
|
local _json_no_warning=1
|
||||||
|
|
||||||
|
json_select "$1"
|
||||||
|
[ $? = 0 ] && return
|
||||||
|
|
||||||
|
json_add_object $1
|
||||||
|
json_close_object
|
||||||
|
|
||||||
|
json_select "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
_ucidef_set_interface() {
|
||||||
|
local name=$1
|
||||||
|
local iface=$2
|
||||||
|
|
||||||
|
json_select_object $name
|
||||||
|
json_add_string ifname "${iface%%.*}"
|
||||||
|
[ "$iface" = "${iface%%.*}" ] || json_add_boolean create_vlan 1
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interface_loopback()
|
||||||
|
{
|
||||||
|
# stub
|
||||||
|
local a=$1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interface_lan() {
|
||||||
|
local lan_if=$1
|
||||||
|
|
||||||
|
json_select_object network
|
||||||
|
_ucidef_set_interface lan $lan_if
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interfaces_lan_wan() {
|
||||||
|
local lan_if=$1
|
||||||
|
local wan_if=$2
|
||||||
|
|
||||||
|
json_select_object network
|
||||||
|
_ucidef_set_interface lan $lan_if
|
||||||
|
_ucidef_set_interface wan $wan_if
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_add_switch() {
|
||||||
|
local name=$1
|
||||||
|
local reset=$2
|
||||||
|
local enable=$3
|
||||||
|
|
||||||
|
json_select_object switch
|
||||||
|
|
||||||
|
json_select_object $name
|
||||||
|
json_add_boolean enable $enable
|
||||||
|
json_add_boolean reset $reset
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_add_switch_attr() {
|
||||||
|
local name=$1
|
||||||
|
local key=$2
|
||||||
|
local val=$3
|
||||||
|
|
||||||
|
json_select_object switch
|
||||||
|
|
||||||
|
json_select_object $name
|
||||||
|
json_add_string $key $val
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_add_switch_vlan() {
|
||||||
|
local name=$1
|
||||||
|
local vlan=$2
|
||||||
|
local ports=$3
|
||||||
|
local cpu_port=''
|
||||||
|
|
||||||
|
case $vlan in
|
||||||
|
1) vlan=lan;;
|
||||||
|
2) vlan=wan;;
|
||||||
|
*) vlan=vlan$vlan;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
json_select_object switch
|
||||||
|
json_select_object $name
|
||||||
|
json_select_object vlans
|
||||||
|
|
||||||
|
json_add_array $vlan
|
||||||
|
for p in $ports; do
|
||||||
|
if [ ${p%t} != $p ]; then
|
||||||
|
cpu_port=$p
|
||||||
|
else
|
||||||
|
json_add_int "" $p
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
json_close_array
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
[ -n "$cpu_port" ] && json_add_int cpu_port $cpu_port
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interface_macaddr() {
|
||||||
|
local network=$1
|
||||||
|
local macaddr=$2
|
||||||
|
|
||||||
|
json_select_object network
|
||||||
|
|
||||||
|
json_select $network
|
||||||
|
[ $? -eq 0 ] || {
|
||||||
|
json_select ..
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
json_add_string macaddr $macaddr
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_netdev() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local dev=$4
|
||||||
|
|
||||||
|
json_select_object led
|
||||||
|
|
||||||
|
json_select_object $1
|
||||||
|
json_add_string name $name
|
||||||
|
json_add_string type netdev
|
||||||
|
json_add_string sysfs $sysfs
|
||||||
|
json_add_string device $dev
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_interface() {
|
||||||
|
local name=$1
|
||||||
|
local sysfs=$2
|
||||||
|
|
||||||
|
json_select_object led
|
||||||
|
|
||||||
|
json_select_object $1
|
||||||
|
json_add_string name $name
|
||||||
|
json_add_string type interface
|
||||||
|
json_add_string sysfs $sysfs
|
||||||
|
json_add_string interface $name
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_usbdev() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local dev=$4
|
||||||
|
|
||||||
|
json_select_object led
|
||||||
|
|
||||||
|
json_select_object $1
|
||||||
|
json_add_string name $name
|
||||||
|
json_add_string type usb
|
||||||
|
json_add_string sysfs $sysfs
|
||||||
|
json_add_string device $dev
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_wlan() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local trigger=$4
|
||||||
|
|
||||||
|
json_select_object led
|
||||||
|
|
||||||
|
json_select_object $1
|
||||||
|
json_add_string name $name
|
||||||
|
json_add_string type trigger
|
||||||
|
json_add_string sysfs $sysfs
|
||||||
|
json_add_string trigger $trigger
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_switch() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local trigger=$4
|
||||||
|
local port_mask=$5
|
||||||
|
|
||||||
|
json_select_object led
|
||||||
|
|
||||||
|
json_select_object $1
|
||||||
|
json_add_string name $name
|
||||||
|
json_add_string type switch
|
||||||
|
json_add_string sysfs $sysfs
|
||||||
|
json_add_string trigger $trigger
|
||||||
|
json_add_string port_mask $port_mask
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_default() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local default=$4
|
||||||
|
|
||||||
|
json_select_object led
|
||||||
|
|
||||||
|
json_select_object $1
|
||||||
|
json_add_string name $name
|
||||||
|
json_add_string sysfs $sysfs
|
||||||
|
json_add_string default $default
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_rssi() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local iface=$4
|
||||||
|
local minq=$5
|
||||||
|
local maxq=$6
|
||||||
|
local offset=$7
|
||||||
|
local factor=$8
|
||||||
|
|
||||||
|
json_select_object led
|
||||||
|
|
||||||
|
json_select_object rssi
|
||||||
|
json_select_object $1
|
||||||
|
json_add_string name $name
|
||||||
|
json_add_string sysfs $sysfs
|
||||||
|
json_add_string minq $minq
|
||||||
|
json_add_string maxq $maxq
|
||||||
|
json_add_string offset $offset
|
||||||
|
json_add_string factor $factor
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_rssimon() {
|
||||||
|
local dev="$1"
|
||||||
|
local refresh="$2"
|
||||||
|
local threshold="$3"
|
||||||
|
|
||||||
|
json_select_object led
|
||||||
|
|
||||||
|
json_select_object rssi
|
||||||
|
json_add_string type rssi
|
||||||
|
json_add_string dev $dev
|
||||||
|
json_add_string threshold $threshold
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
board_config_update() {
|
||||||
|
json_init
|
||||||
|
[ -f ${CFG} ] && json_load "$(cat ${CFG})"
|
||||||
|
}
|
||||||
|
|
||||||
|
board_config_flush() {
|
||||||
|
json_dump -i > /tmp/.board.json
|
||||||
|
mv /tmp/.board.json ${CFG}
|
||||||
|
}
|
285
lg_webOS/base-files/ipk/lib/functions/uci-defaults.sh
Normal file
285
lg_webOS/base-files/ipk/lib/functions/uci-defaults.sh
Normal file
@ -0,0 +1,285 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2011 OpenWrt.org
|
||||||
|
|
||||||
|
UCIDEF_LEDS_CHANGED=0
|
||||||
|
|
||||||
|
ucidef_set_led_netdev() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local dev=$4
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.trigger='netdev'
|
||||||
|
set system.$cfg.dev='$dev'
|
||||||
|
set system.$cfg.mode='link tx rx'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_usbdev() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local dev=$4
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.trigger='usbdev'
|
||||||
|
set system.$cfg.dev='$dev'
|
||||||
|
set system.$cfg.interval='50'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_wlan() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local trigger=$4
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.trigger='$trigger'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_switch() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local trigger=$4
|
||||||
|
local port_mask=$5
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.trigger='$trigger'
|
||||||
|
set system.$cfg.port_mask='$port_mask'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_default() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local default=$4
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.default='$default'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_rssi() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local iface=$4
|
||||||
|
local minq=$5
|
||||||
|
local maxq=$6
|
||||||
|
local offset=$7
|
||||||
|
local factor=$8
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.trigger='rssi'
|
||||||
|
set system.$cfg.iface='rssid_$iface'
|
||||||
|
set system.$cfg.minq='$minq'
|
||||||
|
set system.$cfg.maxq='$maxq'
|
||||||
|
set system.$cfg.offset='$offset'
|
||||||
|
set system.$cfg.factor='$factor'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_timer() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local delayon=$4
|
||||||
|
local delayoff=$5
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.trigger='timer'
|
||||||
|
set system.$cfg.delayon='$delayon'
|
||||||
|
set system.$cfg.delayoff='$delayoff'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_led_mmc() {
|
||||||
|
local cfg="led_$1"
|
||||||
|
local name=$2
|
||||||
|
local sysfs=$3
|
||||||
|
local trigger=$4
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.trigger='$trigger'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_rssimon() {
|
||||||
|
local dev="$1"
|
||||||
|
local refresh="$2"
|
||||||
|
local threshold="$3"
|
||||||
|
|
||||||
|
local cfg="rssid_$dev"
|
||||||
|
|
||||||
|
uci -q get system.$cfg && return 0
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set system.$cfg='rssid'
|
||||||
|
set system.$cfg.dev='$dev'
|
||||||
|
set system.$cfg.refresh='$refresh'
|
||||||
|
set system.$cfg.threshold='$threshold'
|
||||||
|
EOF
|
||||||
|
UCIDEF_LEDS_CHANGED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_commit_leds()
|
||||||
|
{
|
||||||
|
[ "$UCIDEF_LEDS_CHANGED" = "1" ] && uci commit system
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interface_loopback() {
|
||||||
|
uci batch <<EOF
|
||||||
|
set network.loopback='interface'
|
||||||
|
set network.loopback.ifname='lo'
|
||||||
|
set network.loopback.proto='static'
|
||||||
|
set network.loopback.ipaddr='127.0.0.1'
|
||||||
|
set network.loopback.netmask='255.0.0.0'
|
||||||
|
set network.globals='globals'
|
||||||
|
set network.globals.ula_prefix='auto'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interface_raw() {
|
||||||
|
local cfg=$1
|
||||||
|
local ifname=$2
|
||||||
|
local proto=${3:-"none"}
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set network.$cfg='interface'
|
||||||
|
set network.$cfg.ifname='$ifname'
|
||||||
|
set network.$cfg.proto='$proto'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interface_lan() {
|
||||||
|
local ifname=$1
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set network.lan='interface'
|
||||||
|
set network.lan.ifname='$ifname'
|
||||||
|
set network.lan.force_link=1
|
||||||
|
set network.lan.type='bridge'
|
||||||
|
set network.lan.proto='static'
|
||||||
|
set network.lan.ipaddr='192.168.1.1'
|
||||||
|
set network.lan.netmask='255.255.255.0'
|
||||||
|
set network.lan.ip6assign='60'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interface_wan() {
|
||||||
|
local ifname=$1
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set network.wan='interface'
|
||||||
|
set network.wan.ifname='$ifname'
|
||||||
|
set network.wan.proto='dhcp'
|
||||||
|
set network.wan6='interface'
|
||||||
|
set network.wan6.ifname='$ifname'
|
||||||
|
set network.wan6.proto='dhcpv6'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interfaces_lan_wan() {
|
||||||
|
local lan_ifname=$1
|
||||||
|
local wan_ifname=$2
|
||||||
|
|
||||||
|
ucidef_set_interface_lan "$lan_ifname"
|
||||||
|
ucidef_set_interface_wan "$wan_ifname"
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_set_interface_macaddr() {
|
||||||
|
local ifname=$1
|
||||||
|
local mac=$2
|
||||||
|
|
||||||
|
uci batch <<EOF
|
||||||
|
set network.$ifname.macaddr='$mac'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_add_switch() {
|
||||||
|
local name=$1
|
||||||
|
local reset=$2
|
||||||
|
local enable=$3
|
||||||
|
uci batch <<EOF
|
||||||
|
add network switch
|
||||||
|
set network.@switch[-1].name='$name'
|
||||||
|
set network.@switch[-1].reset='$reset'
|
||||||
|
set network.@switch[-1].enable_vlan='$enable'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_add_switch_vlan() {
|
||||||
|
local device=$1
|
||||||
|
local vlan=$2
|
||||||
|
local ports=$3
|
||||||
|
uci batch <<EOF
|
||||||
|
add network switch_vlan
|
||||||
|
set network.@switch_vlan[-1].device='$device'
|
||||||
|
set network.@switch_vlan[-1].vlan='$vlan'
|
||||||
|
set network.@switch_vlan[-1].ports='$ports'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
ucidef_add_switch_port() {
|
||||||
|
local device=$1
|
||||||
|
local port=$2
|
||||||
|
uci batch <<EOF
|
||||||
|
add network switch_port
|
||||||
|
set network.@switch_port[-1].device='$device'
|
||||||
|
set network.@switch_port[-1].port='$port'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
7
lg_webOS/base-files/ipk/lib/preinit/02_default_set_state
Normal file
7
lg_webOS/base-files/ipk/lib/preinit/02_default_set_state
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
define_default_set_state() {
|
||||||
|
. /etc/diag.sh
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_main define_default_set_state
|
17
lg_webOS/base-files/ipk/lib/preinit/10_indicate_failsafe
Normal file
17
lg_webOS/base-files/ipk/lib/preinit/10_indicate_failsafe
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
# commands for emitting messages to network in failsafe mode
|
||||||
|
|
||||||
|
indicate_failsafe_led () {
|
||||||
|
set_state failsafe
|
||||||
|
}
|
||||||
|
|
||||||
|
indicate_failsafe() {
|
||||||
|
echo "- failsafe -"
|
||||||
|
preinit_net_echo "Entering Failsafe!\n"
|
||||||
|
indicate_failsafe_led
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add failsafe indicate_failsafe
|
45
lg_webOS/base-files/ipk/lib/preinit/10_indicate_preinit
Normal file
45
lg_webOS/base-files/ipk/lib/preinit/10_indicate_preinit
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
preinit_ip() {
|
||||||
|
# if the preinit interface isn't specified and ifname is set in
|
||||||
|
# preinit.arch use that interface
|
||||||
|
if [ -z "$pi_ifname" ]; then
|
||||||
|
pi_ifname=$ifname
|
||||||
|
fi
|
||||||
|
|
||||||
|
[ -n "$pi_ifname" ] && grep -q "$pi_ifname" /proc/net/dev && {
|
||||||
|
ifconfig $pi_ifname $pi_ip netmask $pi_netmask broadcast $pi_broadcast up
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
preinit_ip_deconfig() {
|
||||||
|
[ -n "$pi_ifname" ] && grep -q "$pi_ifname" /proc/net/dev && {
|
||||||
|
ifconfig $pi_ifname 0.0.0.0 down
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
preinit_net_echo() {
|
||||||
|
[ -n "$pi_ifname" ] && grep -q "$pi_ifname" /proc/net/dev && {
|
||||||
|
{
|
||||||
|
[ "$pi_preinit_net_messages" = "y" ] || {
|
||||||
|
[ "$pi_failsafe_net_message" = "true" ] &&
|
||||||
|
[ "$pi_preinit_no_failsafe_netmsg" != "y" ]
|
||||||
|
}
|
||||||
|
} && netmsg $pi_broadcast "$1"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
preinit_echo() {
|
||||||
|
preinit_net_echo $1
|
||||||
|
echo $1
|
||||||
|
}
|
||||||
|
|
||||||
|
pi_indicate_preinit() {
|
||||||
|
preinit_net_echo "Doing OpenWrt Preinit\n"
|
||||||
|
set_state preinit
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_main preinit_ip
|
||||||
|
boot_hook_add preinit_main pi_indicate_preinit
|
10
lg_webOS/base-files/ipk/lib/preinit/10_sysinfo
Normal file
10
lg_webOS/base-files/ipk/lib/preinit/10_sysinfo
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
do_sysinfo_generic() {
|
||||||
|
[ -d /proc/device-tree ] || return
|
||||||
|
mkdir -p /tmp/sysinfo
|
||||||
|
[ -e /tmp/sysinfo/board_name ] || \
|
||||||
|
echo "$(strings /proc/device-tree/compatible | head -1)" > /tmp/sysinfo/board_name
|
||||||
|
[ -e /tmp/sysinfo/model ] || \
|
||||||
|
echo "$(cat /proc/device-tree/model)" > /tmp/sysinfo/model
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_main do_sysinfo_generic
|
8
lg_webOS/base-files/ipk/lib/preinit/15_essential_fs_x86
Normal file
8
lg_webOS/base-files/ipk/lib/preinit/15_essential_fs_x86
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2010 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
do_mount_procfs() {
|
||||||
|
mount -o noatime -t proc none /proc
|
||||||
|
}
|
||||||
|
|
5
lg_webOS/base-files/ipk/lib/preinit/20_check_iso
Normal file
5
lg_webOS/base-files/ipk/lib/preinit/20_check_iso
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
check_for_iso() {
|
||||||
|
grep -qE '/dev/root.*iso9660' /proc/mounts && ramoverlay
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_mount_root check_for_iso
|
96
lg_webOS/base-files/ipk/lib/preinit/30_failsafe_wait
Normal file
96
lg_webOS/base-files/ipk/lib/preinit/30_failsafe_wait
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2010 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
fs_wait_for_key () {
|
||||||
|
local timeout=$3
|
||||||
|
local timer
|
||||||
|
local do_keypress
|
||||||
|
local keypress_true="$(mktemp)"
|
||||||
|
local keypress_wait="$(mktemp)"
|
||||||
|
local keypress_sec="$(mktemp)"
|
||||||
|
if [ -z "$keypress_wait" ]; then
|
||||||
|
keypress_wait=/tmp/.keypress_wait
|
||||||
|
touch $keypress_wait
|
||||||
|
fi
|
||||||
|
if [ -z "$keypress_true" ]; then
|
||||||
|
keypress_true=/tmp/.keypress_true
|
||||||
|
touch $keypress_true
|
||||||
|
fi
|
||||||
|
if [ -z "$keypress_sec" ]; then
|
||||||
|
keypress_sec=/tmp/.keypress_sec
|
||||||
|
touch $keypress_sec
|
||||||
|
fi
|
||||||
|
|
||||||
|
trap "echo 'true' >$keypress_true; lock -u $keypress_wait ; rm -f $keypress_wait" INT
|
||||||
|
trap "echo 'true' >$keypress_true; lock -u $keypress_wait ; rm -f $keypress_wait" USR1
|
||||||
|
|
||||||
|
[ -n "$timeout" ] || timeout=1
|
||||||
|
[ $timeout -ge 1 ] || timeout=1
|
||||||
|
timer=$timeout
|
||||||
|
lock $keypress_wait
|
||||||
|
{
|
||||||
|
while [ $timer -gt 0 ]; do
|
||||||
|
echo "$timer" >$keypress_sec
|
||||||
|
timer=$(($timer - 1))
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
lock -u $keypress_wait
|
||||||
|
rm -f $keypress_wait
|
||||||
|
} &
|
||||||
|
|
||||||
|
echo "Press the [$1] key and hit [enter] $2"
|
||||||
|
echo "Press the [1], [2], [3] or [4] key and hit [enter] to select the debug level"
|
||||||
|
# if we're on the console we wait for input
|
||||||
|
{
|
||||||
|
while [ -r $keypress_wait ]; do
|
||||||
|
timer="$(cat $keypress_sec)"
|
||||||
|
|
||||||
|
[ -n "$timer" ] || timer=1
|
||||||
|
timer="${timer%%\ *}"
|
||||||
|
[ $timer -ge 1 ] || timer=1
|
||||||
|
do_keypress=""
|
||||||
|
{
|
||||||
|
read -t "$timer" do_keypress
|
||||||
|
case "$do_keypress" in
|
||||||
|
$1)
|
||||||
|
echo "true" >$keypress_true
|
||||||
|
;;
|
||||||
|
1 | 2 | 3 | 4)
|
||||||
|
echo "$do_keypress" >/tmp/debug_level
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
continue;
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
lock -u $keypress_wait
|
||||||
|
rm -f $keypress_wait
|
||||||
|
}
|
||||||
|
done
|
||||||
|
}
|
||||||
|
lock -w $keypress_wait
|
||||||
|
|
||||||
|
keypressed=1
|
||||||
|
[ "$(cat $keypress_true)" = "true" ] && keypressed=0
|
||||||
|
|
||||||
|
rm -f $keypress_true
|
||||||
|
rm -f $keypress_wait
|
||||||
|
rm -f $keypress_sec
|
||||||
|
|
||||||
|
return $keypressed
|
||||||
|
}
|
||||||
|
|
||||||
|
failsafe_wait() {
|
||||||
|
FAILSAFE=
|
||||||
|
grep -q 'failsafe=' /proc/cmdline && FAILSAFE=true && export FAILSAFE
|
||||||
|
if [ "$FAILSAFE" != "true" ]; then
|
||||||
|
pi_failsafe_net_message=true
|
||||||
|
preinit_net_echo "Please press button now to enter failsafe"
|
||||||
|
pi_failsafe_net_message=false
|
||||||
|
fs_wait_for_key f 'to enter failsafe mode' $fs_failsafe_wait_timeout && FAILSAFE=true
|
||||||
|
[ -f "/tmp/failsafe_button" ] && FAILSAFE=true && echo "- failsafe button "`cat /tmp/failsafe_button`" was pressed -"
|
||||||
|
[ "$FAILSAFE" = "true" ] && export FAILSAFE && touch /tmp/failsafe
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_main failsafe_wait
|
12
lg_webOS/base-files/ipk/lib/preinit/40_run_failsafe_hook
Normal file
12
lg_webOS/base-files/ipk/lib/preinit/40_run_failsafe_hook
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2010 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
run_failsafe_hook() {
|
||||||
|
if [ "$FAILSAFE" = "true" ]; then
|
||||||
|
boot_run_hook failsafe
|
||||||
|
lock -w /tmp/.failsafe
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_main run_failsafe_hook
|
@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
indicate_regular_preinit() {
|
||||||
|
preinit_net_echo "Continuing with Regular Preinit\n"
|
||||||
|
set_state preinit_regular
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_main indicate_regular_preinit
|
13
lg_webOS/base-files/ipk/lib/preinit/70_initramfs_test
Normal file
13
lg_webOS/base-files/ipk/lib/preinit/70_initramfs_test
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
initramfs_test() {
|
||||||
|
if [ -n "$INITRAMFS" ]; then
|
||||||
|
boot_run_hook initramfs
|
||||||
|
preinit_ip_deconfig
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_main initramfs_test
|
15
lg_webOS/base-files/ipk/lib/preinit/79_move_config
Normal file
15
lg_webOS/base-files/ipk/lib/preinit/79_move_config
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2012-2015 OpenWrt.org
|
||||||
|
|
||||||
|
move_config() {
|
||||||
|
. /lib/upgrade/platform.sh
|
||||||
|
|
||||||
|
if platform_export_bootpart; then
|
||||||
|
mount -t ext4 -o rw,noatime "$BOOTPART" /mnt
|
||||||
|
mv -f /mnt/sysupgrade.tgz /
|
||||||
|
umount /mnt
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_mount_root move_config
|
||||||
|
|
15
lg_webOS/base-files/ipk/lib/preinit/80_mount_root
Normal file
15
lg_webOS/base-files/ipk/lib/preinit/80_mount_root
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
do_mount_root() {
|
||||||
|
mount_root
|
||||||
|
boot_run_hook preinit_mount_root
|
||||||
|
[ -f /sysupgrade.tgz ] && {
|
||||||
|
echo "- config restore -"
|
||||||
|
cd /
|
||||||
|
tar xzf /sysupgrade.tgz
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[ "$INITRAMFS" = "1" ] || boot_hook_add preinit_main do_mount_root
|
16
lg_webOS/base-files/ipk/lib/preinit/99_10_failsafe_login
Normal file
16
lg_webOS/base-files/ipk/lib/preinit/99_10_failsafe_login
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
failsafe_netlogin () {
|
||||||
|
telnetd -l /bin/login.sh <> /dev/null 2>&1
|
||||||
|
}
|
||||||
|
|
||||||
|
failsafe_shell() {
|
||||||
|
lock /tmp/.failsafe
|
||||||
|
ash --login
|
||||||
|
echo "Please reboot system when done with failsafe network logins"
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add failsafe failsafe_netlogin
|
||||||
|
boot_hook_add failsafe failsafe_shell
|
9
lg_webOS/base-files/ipk/lib/preinit/99_10_run_init
Normal file
9
lg_webOS/base-files/ipk/lib/preinit/99_10_run_init
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
# Copyright (C) 2010 Vertical Communications
|
||||||
|
|
||||||
|
run_init() {
|
||||||
|
preinit_ip_deconfig
|
||||||
|
}
|
||||||
|
|
||||||
|
boot_hook_add preinit_main run_init
|
248
lg_webOS/base-files/ipk/lib/upgrade/common.sh
Normal file
248
lg_webOS/base-files/ipk/lib/upgrade/common.sh
Normal file
@ -0,0 +1,248 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
RAM_ROOT=/tmp/root
|
||||||
|
|
||||||
|
[ -x /usr/bin/ldd ] || ldd() { LD_TRACE_LOADED_OBJECTS=1 $*; }
|
||||||
|
libs() { ldd $* 2>/dev/null | sed -r 's/(.* => )?(.*) .*/\2/'; }
|
||||||
|
|
||||||
|
install_file() { # <file> [ <file> ... ]
|
||||||
|
for file in "$@"; do
|
||||||
|
dest="$RAM_ROOT/$file"
|
||||||
|
[ -f $file -a ! -f $dest ] && {
|
||||||
|
dir="$(dirname $dest)"
|
||||||
|
mkdir -p "$dir"
|
||||||
|
cp $file $dest
|
||||||
|
}
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
install_bin() { # <file> [ <symlink> ... ]
|
||||||
|
src=$1
|
||||||
|
files=$1
|
||||||
|
[ -x "$src" ] && files="$src $(libs $src)"
|
||||||
|
install_file $files
|
||||||
|
shift
|
||||||
|
for link in "$@"; do {
|
||||||
|
dest="$RAM_ROOT/$link"
|
||||||
|
dir="$(dirname $dest)"
|
||||||
|
mkdir -p "$dir"
|
||||||
|
[ -f "$dest" ] || ln -s $src $dest
|
||||||
|
}; done
|
||||||
|
}
|
||||||
|
|
||||||
|
supivot() { # <new_root> <old_root>
|
||||||
|
/bin/mount | grep "on $1 type" 2>&- 1>&- || /bin/mount -o bind $1 $1
|
||||||
|
mkdir -p $1$2 $1/proc $1/sys $1/dev $1/tmp $1/overlay && \
|
||||||
|
/bin/mount -o noatime,move /proc $1/proc && \
|
||||||
|
pivot_root $1 $1$2 || {
|
||||||
|
/bin/umount -l $1 $1
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
/bin/mount -o noatime,move $2/sys /sys
|
||||||
|
/bin/mount -o noatime,move $2/dev /dev
|
||||||
|
/bin/mount -o noatime,move $2/tmp /tmp
|
||||||
|
/bin/mount -o noatime,move $2/overlay /overlay 2>&-
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
run_ramfs() { # <command> [...]
|
||||||
|
install_bin /bin/busybox /bin/ash /bin/sh /bin/mount /bin/umount \
|
||||||
|
/sbin/pivot_root /usr/bin/wget /sbin/reboot /bin/sync /bin/dd \
|
||||||
|
/bin/grep /bin/cp /bin/mv /bin/tar /usr/bin/md5sum "/usr/bin/[" \
|
||||||
|
/bin/dd /bin/vi /bin/ls /bin/cat /usr/bin/awk /usr/bin/hexdump \
|
||||||
|
/bin/sleep /bin/zcat /usr/bin/bzcat /usr/bin/printf /usr/bin/wc \
|
||||||
|
/bin/cut /usr/bin/printf /bin/sync /bin/mkdir /bin/rmdir \
|
||||||
|
/bin/rm /usr/bin/basename /bin/kill /bin/chmod
|
||||||
|
|
||||||
|
install_bin /sbin/mtd
|
||||||
|
install_bin /sbin/mount_root
|
||||||
|
install_bin /sbin/snapshot
|
||||||
|
install_bin /sbin/snapshot_tool
|
||||||
|
install_bin /usr/sbin/ubiupdatevol
|
||||||
|
install_bin /usr/sbin/ubiattach
|
||||||
|
install_bin /usr/sbin/ubiblock
|
||||||
|
install_bin /usr/sbin/ubiformat
|
||||||
|
install_bin /usr/sbin/ubidetach
|
||||||
|
install_bin /usr/sbin/ubirsvol
|
||||||
|
install_bin /usr/sbin/ubirmvol
|
||||||
|
install_bin /usr/sbin/ubimkvol
|
||||||
|
for file in $RAMFS_COPY_BIN; do
|
||||||
|
install_bin ${file//:/ }
|
||||||
|
done
|
||||||
|
install_file /etc/resolv.conf /lib/*.sh /lib/functions/*.sh /lib/upgrade/*.sh $RAMFS_COPY_DATA
|
||||||
|
|
||||||
|
[ -L "/lib64" ] && ln -s /lib $RAM_ROOT/lib64
|
||||||
|
|
||||||
|
supivot $RAM_ROOT /mnt || {
|
||||||
|
echo "Failed to switch over to ramfs. Please reboot."
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
/bin/mount -o remount,ro /mnt
|
||||||
|
/bin/umount -l /mnt
|
||||||
|
|
||||||
|
grep /overlay /proc/mounts > /dev/null && {
|
||||||
|
/bin/mount -o noatime,remount,ro /overlay
|
||||||
|
/bin/umount -l /overlay
|
||||||
|
}
|
||||||
|
|
||||||
|
# spawn a new shell from ramdisk to reduce the probability of cache issues
|
||||||
|
exec /bin/busybox ash -c "$*"
|
||||||
|
}
|
||||||
|
|
||||||
|
kill_remaining() { # [ <signal> ]
|
||||||
|
local sig="${1:-TERM}"
|
||||||
|
echo -n "Sending $sig to remaining processes ... "
|
||||||
|
|
||||||
|
local my_pid=$$
|
||||||
|
local my_ppid=$(cut -d' ' -f4 /proc/$my_pid/stat)
|
||||||
|
local my_ppisupgraded=
|
||||||
|
grep -q upgraded /proc/$my_ppid/cmdline >/dev/null && {
|
||||||
|
local my_ppisupgraded=1
|
||||||
|
}
|
||||||
|
|
||||||
|
local stat
|
||||||
|
for stat in /proc/[0-9]*/stat; do
|
||||||
|
[ -f "$stat" ] || continue
|
||||||
|
|
||||||
|
local pid name state ppid rest
|
||||||
|
read pid name state ppid rest < $stat
|
||||||
|
name="${name#(}"; name="${name%)}"
|
||||||
|
|
||||||
|
local cmdline
|
||||||
|
read cmdline < /proc/$pid/cmdline
|
||||||
|
|
||||||
|
# Skip kernel threads
|
||||||
|
[ -n "$cmdline" ] || continue
|
||||||
|
|
||||||
|
if [ $$ -eq 1 ] || [ $my_ppid -eq 1 ] && [ -n "$my_ppisupgraded" ]; then
|
||||||
|
# Running as init process, kill everything except me
|
||||||
|
if [ $pid -ne $$ ] && [ $pid -ne $my_ppid ]; then
|
||||||
|
echo -n "$name "
|
||||||
|
kill -$sig $pid 2>/dev/null
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
case "$name" in
|
||||||
|
# Skip essential services
|
||||||
|
*procd*|*ash*|*init*|*watchdog*|*ssh*|*dropbear*|*telnet*|*login*|*hostapd*|*wpa_supplicant*|*nas*) : ;;
|
||||||
|
|
||||||
|
# Killable process
|
||||||
|
*)
|
||||||
|
if [ $pid -ne $$ ] && [ $ppid -ne $$ ]; then
|
||||||
|
echo -n "$name "
|
||||||
|
kill -$sig $pid 2>/dev/null
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
run_hooks() {
|
||||||
|
local arg="$1"; shift
|
||||||
|
for func in "$@"; do
|
||||||
|
eval "$func $arg"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
ask_bool() {
|
||||||
|
local default="$1"; shift;
|
||||||
|
local answer="$default"
|
||||||
|
|
||||||
|
[ "$INTERACTIVE" -eq 1 ] && {
|
||||||
|
case "$default" in
|
||||||
|
0) echo -n "$* (y/N): ";;
|
||||||
|
*) echo -n "$* (Y/n): ";;
|
||||||
|
esac
|
||||||
|
read answer
|
||||||
|
case "$answer" in
|
||||||
|
y*) answer=1;;
|
||||||
|
n*) answer=0;;
|
||||||
|
*) answer="$default";;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
[ "$answer" -gt 0 ]
|
||||||
|
}
|
||||||
|
|
||||||
|
v() {
|
||||||
|
[ "$VERBOSE" -ge 1 ] && echo "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
rootfs_type() {
|
||||||
|
/bin/mount | awk '($3 ~ /^\/$/) && ($5 !~ /rootfs/) { print $5 }'
|
||||||
|
}
|
||||||
|
|
||||||
|
get_image() { # <source> [ <command> ]
|
||||||
|
local from="$1"
|
||||||
|
local conc="$2"
|
||||||
|
local cmd
|
||||||
|
|
||||||
|
case "$from" in
|
||||||
|
http://*|ftp://*) cmd="wget -O- -q";;
|
||||||
|
*) cmd="cat";;
|
||||||
|
esac
|
||||||
|
if [ -z "$conc" ]; then
|
||||||
|
local magic="$(eval $cmd \"$from\" 2>/dev/null | dd bs=2 count=1 2>/dev/null | hexdump -n 2 -e '1/1 "%02x"')"
|
||||||
|
case "$magic" in
|
||||||
|
1f8b) conc="zcat";;
|
||||||
|
425a) conc="bzcat";;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
eval "$cmd \"$from\" 2>/dev/null ${conc:+| $conc}"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_magic_word() {
|
||||||
|
(get_image "$@" | dd bs=2 count=1 | hexdump -v -n 2 -e '1/1 "%02x"') 2>/dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
get_magic_long() {
|
||||||
|
(get_image "$@" | dd bs=4 count=1 | hexdump -v -n 4 -e '1/1 "%02x"') 2>/dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
jffs2_copy_config() {
|
||||||
|
if grep rootfs_data /proc/mtd >/dev/null; then
|
||||||
|
# squashfs+jffs2
|
||||||
|
mtd -e rootfs_data jffs2write "$CONF_TAR" rootfs_data
|
||||||
|
else
|
||||||
|
# jffs2
|
||||||
|
mtd jffs2write "$CONF_TAR" rootfs
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Flash firmware to MTD partition
|
||||||
|
#
|
||||||
|
# $(1): path to image
|
||||||
|
# $(2): (optional) pipe command to extract firmware, e.g. dd bs=n skip=m
|
||||||
|
default_do_upgrade() {
|
||||||
|
sync
|
||||||
|
if [ "$SAVE_CONFIG" -eq 1 ]; then
|
||||||
|
get_image "$1" "$2" | mtd $MTD_CONFIG_ARGS -j "$CONF_TAR" write - "${PART_NAME:-image}"
|
||||||
|
else
|
||||||
|
get_image "$1" "$2" | mtd write - "${PART_NAME:-image}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
do_upgrade() {
|
||||||
|
v "Performing system upgrade..."
|
||||||
|
if type 'platform_do_upgrade' >/dev/null 2>/dev/null; then
|
||||||
|
platform_do_upgrade "$ARGV"
|
||||||
|
else
|
||||||
|
default_do_upgrade "$ARGV"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$SAVE_CONFIG" -eq 1 ] && type 'platform_copy_config' >/dev/null 2>/dev/null; then
|
||||||
|
platform_copy_config
|
||||||
|
fi
|
||||||
|
|
||||||
|
v "Upgrade completed"
|
||||||
|
[ -n "$DELAY" ] && sleep "$DELAY"
|
||||||
|
ask_bool 1 "Reboot" && {
|
||||||
|
v "Rebooting system..."
|
||||||
|
reboot -f
|
||||||
|
sleep 5
|
||||||
|
echo b 2>/dev/null >/proc/sysrq-trigger
|
||||||
|
}
|
||||||
|
}
|
3
lg_webOS/base-files/ipk/lib/upgrade/keep.d/base-files
Normal file
3
lg_webOS/base-files/ipk/lib/upgrade/keep.d/base-files
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
/etc/config/
|
||||||
|
/etc/dropbear/
|
||||||
|
/etc/crontabs/
|
@ -0,0 +1,10 @@
|
|||||||
|
# Essential files that will be always kept
|
||||||
|
/etc/hosts
|
||||||
|
/etc/inittab
|
||||||
|
/etc/group
|
||||||
|
/etc/passwd
|
||||||
|
/etc/profile
|
||||||
|
/etc/shadow
|
||||||
|
/etc/shells
|
||||||
|
/etc/sysctl.conf
|
||||||
|
/etc/rc.local
|
66
lg_webOS/base-files/ipk/lib/upgrade/platform.sh
Normal file
66
lg_webOS/base-files/ipk/lib/upgrade/platform.sh
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
platform_export_bootpart() {
|
||||||
|
local cmdline uuid disk
|
||||||
|
|
||||||
|
if read cmdline < /proc/cmdline; then
|
||||||
|
case "$cmdline" in
|
||||||
|
*block2mtd=*)
|
||||||
|
disk="${cmdline##*block2mtd=}"
|
||||||
|
disk="${disk%%,*}"
|
||||||
|
;;
|
||||||
|
*root=*)
|
||||||
|
disk="${cmdline##*root=}"
|
||||||
|
disk="${disk%% *}"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
case "$disk" in
|
||||||
|
PARTUUID=[a-f0-9][a-f0-9][a-f0-9][a-f0-9][a-f0-9][a-f0-9][a-f0-9][a-f0-9]-02)
|
||||||
|
uuid="${disk#PARTUUID=}"
|
||||||
|
uuid="${uuid%-02}"
|
||||||
|
for disk in /dev/[hsv]d[a-z]; do
|
||||||
|
set -- $(dd if=$disk bs=1 skip=440 count=4 2>/dev/null | hexdump -v -e '4/1 "%02x "')
|
||||||
|
if [ "$4$3$2$1" = "$uuid" ]; then
|
||||||
|
export BOOTPART="${disk}1"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
;;
|
||||||
|
/dev/*)
|
||||||
|
export BOOTPART="${disk%[0-9]}1"
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
platform_check_image() {
|
||||||
|
[ "$#" -gt 1 ] && return 1
|
||||||
|
|
||||||
|
case "$(get_magic_word "$1")" in
|
||||||
|
eb48|eb63) return 0;;
|
||||||
|
*)
|
||||||
|
echo "Invalid image type"
|
||||||
|
return 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
platform_copy_config() {
|
||||||
|
if [ -b "$BOOTPART" ]; then
|
||||||
|
mount -t ext4 -o rw,noatime "$BOOTPART" /mnt
|
||||||
|
cp -af "$CONF_TAR" /mnt/
|
||||||
|
umount /mnt
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
platform_do_upgrade() {
|
||||||
|
platform_export_bootpart
|
||||||
|
|
||||||
|
if [ -b "${BOOTPART%[0-9]}" ]; then
|
||||||
|
sync
|
||||||
|
get_image "$@" | dd of="${BOOTPART%[0-9]}" bs=4096 conv=fsync
|
||||||
|
sleep 1
|
||||||
|
fi
|
||||||
|
}
|
3
lg_webOS/base-files/ipk/rom/note
Normal file
3
lg_webOS/base-files/ipk/rom/note
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
SQUASHFS USERS:
|
||||||
|
After firstboot has been run, / will be jffs2 and /rom will be squashfs
|
||||||
|
(* except when in failsafe)
|
3
lg_webOS/base-files/ipk/sbin/firstboot
Executable file
3
lg_webOS/base-files/ipk/sbin/firstboot
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
/sbin/jffs2reset $@
|
18
lg_webOS/base-files/ipk/sbin/hotplug-call
Executable file
18
lg_webOS/base-files/ipk/sbin/hotplug-call
Executable file
@ -0,0 +1,18 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2010 OpenWrt.org
|
||||||
|
|
||||||
|
export HOTPLUG_TYPE="$1"
|
||||||
|
|
||||||
|
. /lib/functions.sh
|
||||||
|
|
||||||
|
PATH=/usr/sbin:/usr/bin:/sbin:/bin
|
||||||
|
LOGNAME=root
|
||||||
|
USER=root
|
||||||
|
export PATH LOGNAME USER
|
||||||
|
export DEVICENAME="${DEVPATH##*/}"
|
||||||
|
|
||||||
|
[ \! -z "$1" -a -d /etc/hotplug.d/$1 ] && {
|
||||||
|
for script in $(ls /etc/hotplug.d/$1/* 2>&-); do (
|
||||||
|
[ -f $script ] && . $script
|
||||||
|
); done
|
||||||
|
}
|
25
lg_webOS/base-files/ipk/sbin/led.sh
Executable file
25
lg_webOS/base-files/ipk/sbin/led.sh
Executable file
@ -0,0 +1,25 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# (C) 2008 openwrt.org
|
||||||
|
|
||||||
|
. /lib/functions.sh
|
||||||
|
ACTION=$1
|
||||||
|
NAME=$2
|
||||||
|
do_led() {
|
||||||
|
local name
|
||||||
|
local sysfs
|
||||||
|
config_get name $1 name
|
||||||
|
config_get sysfs $1 sysfs
|
||||||
|
[ "$name" = "$NAME" -o "$sysfs" = "$NAME" -a -e "/sys/class/leds/${sysfs}" ] && {
|
||||||
|
[ "$ACTION" = "set" ] &&
|
||||||
|
echo 1 >/sys/class/leds/${sysfs}/brightness \
|
||||||
|
|| echo 0 >/sys/class/leds/${sysfs}/brightness
|
||||||
|
exit 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[ "$1" = "clear" -o "$1" = "set" ] &&
|
||||||
|
[ -n "$2" ] &&{
|
||||||
|
config_load system
|
||||||
|
config_foreach do_led
|
||||||
|
exit 1
|
||||||
|
}
|
240
lg_webOS/base-files/ipk/sbin/sysupgrade
Executable file
240
lg_webOS/base-files/ipk/sbin/sysupgrade
Executable file
@ -0,0 +1,240 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
. /lib/functions.sh
|
||||||
|
. /lib/functions/system.sh
|
||||||
|
|
||||||
|
# initialize defaults
|
||||||
|
RAMFS_COPY_BIN="" # extra programs for temporary ramfs root
|
||||||
|
RAMFS_COPY_DATA="" # extra data files
|
||||||
|
export MTD_CONFIG_ARGS=""
|
||||||
|
export INTERACTIVE=0
|
||||||
|
export VERBOSE=1
|
||||||
|
export SAVE_CONFIG=1
|
||||||
|
export SAVE_OVERLAY=0
|
||||||
|
export DELAY=
|
||||||
|
export CONF_IMAGE=
|
||||||
|
export CONF_BACKUP_LIST=0
|
||||||
|
export CONF_BACKUP=
|
||||||
|
export CONF_RESTORE=
|
||||||
|
export NEED_IMAGE=
|
||||||
|
export HELP=0
|
||||||
|
export FORCE=0
|
||||||
|
export TEST=0
|
||||||
|
|
||||||
|
# parse options
|
||||||
|
while [ -n "$1" ]; do
|
||||||
|
case "$1" in
|
||||||
|
-i) export INTERACTIVE=1;;
|
||||||
|
-d) export DELAY="$2"; shift;;
|
||||||
|
-v) export VERBOSE="$(($VERBOSE + 1))";;
|
||||||
|
-q) export VERBOSE="$(($VERBOSE - 1))";;
|
||||||
|
-n) export SAVE_CONFIG=0;;
|
||||||
|
-c) export SAVE_OVERLAY=1;;
|
||||||
|
-b|--create-backup) export CONF_BACKUP="$2" NEED_IMAGE=1; shift;;
|
||||||
|
-r|--restore-backup) export CONF_RESTORE="$2" NEED_IMAGE=1; shift;;
|
||||||
|
-l|--list-backup) export CONF_BACKUP_LIST=1; break;;
|
||||||
|
-f) export CONF_IMAGE="$2"; shift;;
|
||||||
|
-F|--force) export FORCE=1;;
|
||||||
|
-T|--test) export TEST=1;;
|
||||||
|
-h|--help) export HELP=1; break;;
|
||||||
|
-*)
|
||||||
|
echo "Invalid option: $1"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
*) break;;
|
||||||
|
esac
|
||||||
|
shift;
|
||||||
|
done
|
||||||
|
|
||||||
|
export CONFFILES=/tmp/sysupgrade.conffiles
|
||||||
|
export CONF_TAR=/tmp/sysupgrade.tgz
|
||||||
|
|
||||||
|
export ARGV="$*"
|
||||||
|
export ARGC="$#"
|
||||||
|
|
||||||
|
[ -z "$ARGV" -a -z "$NEED_IMAGE" -o $HELP -gt 0 ] && {
|
||||||
|
cat <<EOF
|
||||||
|
Usage: $0 [<upgrade-option>...] <image file or URL>
|
||||||
|
$0 [-q] [-i] <backup-command> <file>
|
||||||
|
|
||||||
|
upgrade-option:
|
||||||
|
-d <delay> add a delay before rebooting
|
||||||
|
-f <config> restore configuration from .tar.gz (file or url)
|
||||||
|
-i interactive mode
|
||||||
|
-c attempt to preserve all changed files in /etc/
|
||||||
|
-n do not save configuration over reflash
|
||||||
|
-T | --test
|
||||||
|
Verify image and config .tar.gz but do not actually flash.
|
||||||
|
-F | --force
|
||||||
|
Flash image even if image checks fail, this is dangerous!
|
||||||
|
-q less verbose
|
||||||
|
-v more verbose
|
||||||
|
-h | --help display this help
|
||||||
|
|
||||||
|
backup-command:
|
||||||
|
-b | --create-backup <file>
|
||||||
|
create .tar.gz of files specified in sysupgrade.conf
|
||||||
|
then exit. Does not flash an image. If file is '-',
|
||||||
|
i.e. stdout, verbosity is set to 0 (i.e. quiet).
|
||||||
|
-r | --restore-backup <file>
|
||||||
|
restore a .tar.gz created with sysupgrade -b
|
||||||
|
then exit. Does not flash an image. If file is '-',
|
||||||
|
the archive is read from stdin.
|
||||||
|
-l | --list-backup
|
||||||
|
list the files that would be backed up when calling
|
||||||
|
sysupgrade -b. Does not create a backup file.
|
||||||
|
|
||||||
|
EOF
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -n "$ARGV" -a -n "$NEED_IMAGE" ] && {
|
||||||
|
cat <<-EOF
|
||||||
|
-b|--create-backup and -r|--restore-backup do not perform a firmware upgrade.
|
||||||
|
Do not specify both -b|-r and a firmware image.
|
||||||
|
EOF
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# prevent messages from clobbering the tarball when using stdout
|
||||||
|
[ "$CONF_BACKUP" = "-" ] && export VERBOSE=0
|
||||||
|
|
||||||
|
add_uci_conffiles() {
|
||||||
|
local file="$1"
|
||||||
|
( find $(sed -ne '/^[[:space:]]*$/d; /^#/d; p' \
|
||||||
|
/etc/sysupgrade.conf /lib/upgrade/keep.d/* 2>/dev/null) \
|
||||||
|
-type f -o -type l 2>/dev/null;
|
||||||
|
opkg list-changed-conffiles ) | sort -u > "$file"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
add_overlayfiles() {
|
||||||
|
local file="$1"
|
||||||
|
if [ -d /overlay/upper ]; then
|
||||||
|
local overlaydir="/overlay/upper"
|
||||||
|
else
|
||||||
|
local overlaydir="/overlay"
|
||||||
|
fi
|
||||||
|
find $overlaydir/etc/ -type f -o -type l | sed \
|
||||||
|
-e 's,^/overlay/,/,' \
|
||||||
|
-e '\,/META_[a-zA-Z0-9]*$,d' \
|
||||||
|
-e '\,/functions.sh$,d' \
|
||||||
|
-e '\,/[^/]*-opkg$,d' \
|
||||||
|
> "$file"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# hooks
|
||||||
|
sysupgrade_image_check="platform_check_image"
|
||||||
|
[ $SAVE_OVERLAY = 0 -o ! -d /overlay/etc ] && \
|
||||||
|
sysupgrade_init_conffiles="add_uci_conffiles" || \
|
||||||
|
sysupgrade_init_conffiles="add_overlayfiles"
|
||||||
|
|
||||||
|
include /lib/upgrade
|
||||||
|
|
||||||
|
[ "$1" = "nand" ] && nand_upgrade_stage2 $@
|
||||||
|
|
||||||
|
do_save_conffiles() {
|
||||||
|
local conf_tar="${1:-$CONF_TAR}"
|
||||||
|
|
||||||
|
[ -z "$(rootfs_type)" ] && {
|
||||||
|
echo "Cannot save config while running from ramdisk."
|
||||||
|
ask_bool 0 "Abort" && exit
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
run_hooks "$CONFFILES" $sysupgrade_init_conffiles
|
||||||
|
ask_bool 0 "Edit config file list" && vi "$CONFFILES"
|
||||||
|
|
||||||
|
v "Saving config files..."
|
||||||
|
[ "$VERBOSE" -gt 1 ] && TAR_V="v" || TAR_V=""
|
||||||
|
tar c${TAR_V}zf "$conf_tar" -T "$CONFFILES" 2>/dev/null
|
||||||
|
|
||||||
|
rm -f "$CONFFILES"
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ $CONF_BACKUP_LIST -eq 1 ]; then
|
||||||
|
add_uci_conffiles "$CONFFILES"
|
||||||
|
cat "$CONFFILES"
|
||||||
|
rm -f "$CONFFILES"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$CONF_BACKUP" ]; then
|
||||||
|
do_save_conffiles "$CONF_BACKUP"
|
||||||
|
exit $?
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$CONF_RESTORE" ]; then
|
||||||
|
if [ "$CONF_RESTORE" != "-" ] && [ ! -f "$CONF_RESTORE" ]; then
|
||||||
|
echo "Backup archive '$CONF_RESTORE' not found."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
[ "$VERBOSE" -gt 1 ] && TAR_V="v" || TAR_V=""
|
||||||
|
tar -C / -x${TAR_V}zf "$CONF_RESTORE"
|
||||||
|
exit $?
|
||||||
|
fi
|
||||||
|
|
||||||
|
type platform_check_image >/dev/null 2>/dev/null || {
|
||||||
|
echo "Firmware upgrade is not implemented for this platform."
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
for check in $sysupgrade_image_check; do
|
||||||
|
( eval "$check \"\$ARGV\"" ) || {
|
||||||
|
if [ $FORCE -eq 1 ]; then
|
||||||
|
echo "Image check '$check' failed but --force given - will update anyway!"
|
||||||
|
break
|
||||||
|
else
|
||||||
|
echo "Image check '$check' failed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ -n "$CONF_IMAGE" ]; then
|
||||||
|
case "$(get_magic_word $CONF_IMAGE cat)" in
|
||||||
|
# .gz files
|
||||||
|
1f8b) ;;
|
||||||
|
*)
|
||||||
|
echo "Invalid config file. Please use only .tar.gz files"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
get_image "$CONF_IMAGE" "cat" > "$CONF_TAR"
|
||||||
|
export SAVE_CONFIG=1
|
||||||
|
elif ask_bool $SAVE_CONFIG "Keep config files over reflash"; then
|
||||||
|
[ $TEST -eq 1 ] || do_save_conffiles
|
||||||
|
export SAVE_CONFIG=1
|
||||||
|
else
|
||||||
|
export SAVE_CONFIG=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $TEST -eq 1 ]; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
run_hooks "" $sysupgrade_pre_upgrade
|
||||||
|
|
||||||
|
# Some platforms/devices may want different sysupgrade process, e.g. without
|
||||||
|
# killing processes yet or calling ubus system upgrade method.
|
||||||
|
# This is needed e.g. on NAND devices where we just want to trigger stage1 at
|
||||||
|
# this point.
|
||||||
|
if type 'platform_pre_upgrade' >/dev/null 2>/dev/null; then
|
||||||
|
platform_pre_upgrade "$ARGV"
|
||||||
|
fi
|
||||||
|
|
||||||
|
ubus call system upgrade
|
||||||
|
touch /tmp/sysupgrade
|
||||||
|
|
||||||
|
if [ ! -f /tmp/failsafe ] ; then
|
||||||
|
kill_remaining TERM
|
||||||
|
sleep 3
|
||||||
|
kill_remaining KILL
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$(rootfs_type)" ]; then
|
||||||
|
v "Switching to ramdisk..."
|
||||||
|
run_ramfs '. /lib/functions.sh; include /lib/upgrade; do_upgrade'
|
||||||
|
else
|
||||||
|
do_upgrade
|
||||||
|
fi
|
236
lg_webOS/base-files/ipk/sbin/wifi
Executable file
236
lg_webOS/base-files/ipk/sbin/wifi
Executable file
@ -0,0 +1,236 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
. /lib/functions.sh
|
||||||
|
. /usr/share/libubox/jshn.sh
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
cat <<EOF
|
||||||
|
Usage: $0 [down|detect|reload|status]
|
||||||
|
enables (default), disables or detects a wifi configuration.
|
||||||
|
EOF
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
ubus_wifi_cmd() {
|
||||||
|
local cmd="$1"
|
||||||
|
local dev="$2"
|
||||||
|
|
||||||
|
json_init
|
||||||
|
[ -n "$2" ] && json_add_string device "$2"
|
||||||
|
ubus call network.wireless "$1" "$(json_dump)"
|
||||||
|
}
|
||||||
|
|
||||||
|
find_net_config() {(
|
||||||
|
local vif="$1"
|
||||||
|
local cfg
|
||||||
|
local ifname
|
||||||
|
|
||||||
|
config_get cfg "$vif" network
|
||||||
|
|
||||||
|
[ -z "$cfg" ] && {
|
||||||
|
include /lib/network
|
||||||
|
scan_interfaces
|
||||||
|
|
||||||
|
config_get ifname "$vif" ifname
|
||||||
|
|
||||||
|
cfg="$(find_config "$ifname")"
|
||||||
|
}
|
||||||
|
[ -z "$cfg" ] && return 0
|
||||||
|
echo "$cfg"
|
||||||
|
)}
|
||||||
|
|
||||||
|
|
||||||
|
bridge_interface() {(
|
||||||
|
local cfg="$1"
|
||||||
|
[ -z "$cfg" ] && return 0
|
||||||
|
|
||||||
|
include /lib/network
|
||||||
|
scan_interfaces
|
||||||
|
|
||||||
|
for cfg in $cfg; do
|
||||||
|
config_get iftype "$cfg" type
|
||||||
|
[ "$iftype" = bridge ] && config_get "$cfg" ifname
|
||||||
|
prepare_interface_bridge "$cfg"
|
||||||
|
return $?
|
||||||
|
done
|
||||||
|
)}
|
||||||
|
|
||||||
|
prepare_key_wep() {
|
||||||
|
local key="$1"
|
||||||
|
local hex=1
|
||||||
|
|
||||||
|
echo -n "$key" | grep -qE "[^a-fA-F0-9]" && hex=0
|
||||||
|
[ "${#key}" -eq 10 -a $hex -eq 1 ] || \
|
||||||
|
[ "${#key}" -eq 26 -a $hex -eq 1 ] || {
|
||||||
|
[ "${key:0:2}" = "s:" ] && key="${key#s:}"
|
||||||
|
key="$(echo -n "$key" | hexdump -ve '1/1 "%02x" ""')"
|
||||||
|
}
|
||||||
|
echo "$key"
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_fixup_hwmode() {
|
||||||
|
local device="$1"
|
||||||
|
local default="$2"
|
||||||
|
local hwmode hwmode_11n
|
||||||
|
|
||||||
|
config_get channel "$device" channel
|
||||||
|
config_get hwmode "$device" hwmode
|
||||||
|
case "$hwmode" in
|
||||||
|
11bg) hwmode=bg;;
|
||||||
|
11a) hwmode=a;;
|
||||||
|
11b) hwmode=b;;
|
||||||
|
11g) hwmode=g;;
|
||||||
|
11n*)
|
||||||
|
hwmode_11n="${hwmode##11n}"
|
||||||
|
case "$hwmode_11n" in
|
||||||
|
a|g) ;;
|
||||||
|
default) hwmode_11n="$default"
|
||||||
|
esac
|
||||||
|
config_set "$device" hwmode_11n "$hwmode_11n"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
hwmode=
|
||||||
|
if [ "${channel:-0}" -gt 0 ]; then
|
||||||
|
if [ "${channel:-0}" -gt 14 ]; then
|
||||||
|
hwmode=a
|
||||||
|
else
|
||||||
|
hwmode=g
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
hwmode="$default"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
config_set "$device" hwmode "$hwmode"
|
||||||
|
}
|
||||||
|
|
||||||
|
_wifi_updown() {
|
||||||
|
for device in ${2:-$DEVICES}; do (
|
||||||
|
config_get disabled "$device" disabled
|
||||||
|
[ "$disabled" = "1" ] && {
|
||||||
|
echo "'$device' is disabled"
|
||||||
|
set disable
|
||||||
|
}
|
||||||
|
config_get iftype "$device" type
|
||||||
|
if eval "type ${1}_$iftype" 2>/dev/null >/dev/null; then
|
||||||
|
eval "scan_$iftype '$device'"
|
||||||
|
eval "${1}_$iftype '$device'" || echo "$device($iftype): ${1} failed"
|
||||||
|
elif [ ! -f /lib/netifd/wireless/$iftype.sh ]; then
|
||||||
|
echo "$device($iftype): Interface type not supported"
|
||||||
|
fi
|
||||||
|
); done
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_updown() {
|
||||||
|
cmd=down
|
||||||
|
[ enable = "$1" ] && {
|
||||||
|
_wifi_updown disable "$2"
|
||||||
|
ubus_wifi_cmd "$cmd" "$2"
|
||||||
|
scan_wifi
|
||||||
|
cmd=up
|
||||||
|
}
|
||||||
|
ubus_wifi_cmd "$cmd" "$2"
|
||||||
|
_wifi_updown "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_reload_legacy() {
|
||||||
|
_wifi_updown "disable" "$1"
|
||||||
|
scan_wifi
|
||||||
|
_wifi_updown "enable" "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_reload() {
|
||||||
|
ubus call network reload
|
||||||
|
wifi_reload_legacy
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_detect() {
|
||||||
|
for driver in ${2:-$DRIVERS}; do (
|
||||||
|
if eval "type detect_$driver" 2>/dev/null >/dev/null; then
|
||||||
|
eval "detect_$driver" || echo "$driver: Detect failed" >&2
|
||||||
|
else
|
||||||
|
echo "$driver: Hardware detection not supported" >&2
|
||||||
|
fi
|
||||||
|
); done
|
||||||
|
}
|
||||||
|
|
||||||
|
start_net() {(
|
||||||
|
local iface="$1"
|
||||||
|
local config="$2"
|
||||||
|
local vifmac="$3"
|
||||||
|
|
||||||
|
[ -f "/var/run/$iface.pid" ] && kill "$(cat /var/run/${iface}.pid)" 2>/dev/null
|
||||||
|
[ -z "$config" ] || {
|
||||||
|
include /lib/network
|
||||||
|
scan_interfaces
|
||||||
|
for config in $config; do
|
||||||
|
setup_interface "$iface" "$config" "" "$vifmac"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
)}
|
||||||
|
|
||||||
|
set_wifi_up() {
|
||||||
|
local cfg="$1"
|
||||||
|
local ifname="$2"
|
||||||
|
uci_set_state wireless "$cfg" up 1
|
||||||
|
uci_set_state wireless "$cfg" ifname "$ifname"
|
||||||
|
}
|
||||||
|
|
||||||
|
set_wifi_down() {
|
||||||
|
local cfg="$1"
|
||||||
|
local vifs vif vifstr
|
||||||
|
|
||||||
|
[ -f "/var/run/wifi-${cfg}.pid" ] &&
|
||||||
|
kill "$(cat "/var/run/wifi-${cfg}.pid")" 2>/dev/null
|
||||||
|
uci_revert_state wireless "$cfg"
|
||||||
|
config_get vifs "$cfg" vifs
|
||||||
|
for vif in $vifs; do
|
||||||
|
uci_revert_state wireless "$vif"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
scan_wifi() {
|
||||||
|
local cfgfile="$1"
|
||||||
|
DEVICES=
|
||||||
|
config_cb() {
|
||||||
|
local type="$1"
|
||||||
|
local section="$2"
|
||||||
|
|
||||||
|
# section start
|
||||||
|
case "$type" in
|
||||||
|
wifi-device)
|
||||||
|
append DEVICES "$section"
|
||||||
|
config_set "$section" vifs ""
|
||||||
|
config_set "$section" ht_capab ""
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# section end
|
||||||
|
config_get TYPE "$CONFIG_SECTION" TYPE
|
||||||
|
case "$TYPE" in
|
||||||
|
wifi-iface)
|
||||||
|
config_get device "$CONFIG_SECTION" device
|
||||||
|
config_get vifs "$device" vifs
|
||||||
|
append vifs "$CONFIG_SECTION"
|
||||||
|
config_set "$device" vifs "$vifs"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
config_load "${cfgfile:-wireless}"
|
||||||
|
}
|
||||||
|
|
||||||
|
DEVICES=
|
||||||
|
DRIVERS=
|
||||||
|
include /lib/wifi
|
||||||
|
scan_wifi
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
down) wifi_updown "disable" "$2";;
|
||||||
|
detect) wifi_detect "$2";;
|
||||||
|
status) ubus_wifi_cmd "status" "$2";;
|
||||||
|
reload) wifi_reload "$2";;
|
||||||
|
reload_legacy) wifi_reload_legacy "$2";;
|
||||||
|
--help|help) usage;;
|
||||||
|
*) ubus call network reload; wifi_updown "enable" "$2";;
|
||||||
|
esac
|
Binary file not shown.
@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ -d "/etc/board.d/" -a ! -f "/etc/board.json" ] && {
|
||||||
|
for a in `ls /etc/board.d/*`; do
|
||||||
|
[ -x $a ] || continue;
|
||||||
|
$(. $a)
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -f "/etc/board.json" ] || return 1
|
||||||
|
[ -f "/etc/config/network" ] || {
|
||||||
|
touch /etc/config/network
|
||||||
|
/bin/config_generate
|
||||||
|
}
|
@ -0,0 +1,172 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
CFG=/etc/board.json
|
||||||
|
|
||||||
|
. /usr/share/libubox/jshn.sh
|
||||||
|
|
||||||
|
[ -f $CFG ] || exit 1
|
||||||
|
|
||||||
|
generate_static_network() {
|
||||||
|
uci -q batch <<EOF
|
||||||
|
delete network.loopback
|
||||||
|
set network.loopback='interface'
|
||||||
|
set network.loopback.ifname='lo'
|
||||||
|
set network.loopback.proto='static'
|
||||||
|
set network.loopback.ipaddr='127.0.0.1'
|
||||||
|
set network.loopback.netmask='255.0.0.0'
|
||||||
|
delete network.globals
|
||||||
|
set network.globals='globals'
|
||||||
|
set network.globals.ula_prefix='auto'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
next_vlan=3
|
||||||
|
generate_network() {
|
||||||
|
local vlan
|
||||||
|
|
||||||
|
json_select network
|
||||||
|
json_select $1
|
||||||
|
json_get_vars ifname create_vlan macaddr
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
[ -n "$ifname" ] || return
|
||||||
|
[ "$create_vlan" -eq 1 ] && case $1 in
|
||||||
|
lan) vlan=1;;
|
||||||
|
wan) vlan=2;;
|
||||||
|
*)
|
||||||
|
vlan=$next_vlan
|
||||||
|
next_vlan=$((next_vlan + 1))
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
[ -n "$vlan" ] && ifname=${ifname}.${vlan}
|
||||||
|
uci -q batch <<EOF
|
||||||
|
delete network.$1
|
||||||
|
set network.$1='interface'
|
||||||
|
set network.$1.ifname='$ifname'
|
||||||
|
set network.$1.force_link=1
|
||||||
|
set network.$1.proto='none'
|
||||||
|
set network.$1.macaddr='$macaddr'
|
||||||
|
EOF
|
||||||
|
|
||||||
|
case $1 in
|
||||||
|
lan) uci -q batch <<EOF
|
||||||
|
set network.$1.type='bridge'
|
||||||
|
set network.$1.proto='static'
|
||||||
|
set network.$1.ipaddr='192.168.1.1'
|
||||||
|
set network.$1.netmask='255.255.255.0'
|
||||||
|
set network.$1.ip6assign='60'
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
wan) uci -q batch <<EOF
|
||||||
|
set network.$1.proto='dhcp'
|
||||||
|
delete network.wan6
|
||||||
|
set network.wan6='interface'
|
||||||
|
set network.wan6.ifname='$ifname'
|
||||||
|
set network.wan6.proto='dhcpv6'
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
generate_switch_vlan() {
|
||||||
|
local device=$1
|
||||||
|
local vlan=$2
|
||||||
|
local cpu_port=$3
|
||||||
|
|
||||||
|
case $vlan in
|
||||||
|
lan) vlan=1;;
|
||||||
|
wan) vlan=2;;
|
||||||
|
*) vlan=${vlan##vlan};;
|
||||||
|
esac
|
||||||
|
|
||||||
|
json_select vlans
|
||||||
|
json_select $2
|
||||||
|
json_get_values ports
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
uci -q batch <<EOF
|
||||||
|
add network switch_vlan
|
||||||
|
set network.@switch_vlan[-1].device='$device'
|
||||||
|
set network.@switch_vlan[-1].vlan='$vlan'
|
||||||
|
set network.@switch_vlan[-1].ports='$ports ${cpu_port}t'
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
generate_switch() {
|
||||||
|
local key=$1
|
||||||
|
local vlans
|
||||||
|
|
||||||
|
json_select switch
|
||||||
|
json_select $key
|
||||||
|
json_get_vars enable reset blinkrate cpu_port
|
||||||
|
|
||||||
|
uci -q batch <<EOF
|
||||||
|
add network switch
|
||||||
|
set network.@switch[-1].name='$key'
|
||||||
|
set network.@switch[-1].reset='$reset'
|
||||||
|
set network.@switch[-1].enable_vlan='$enable'
|
||||||
|
set network.@switch[-1].blinkrate='$blinkrate'
|
||||||
|
EOF
|
||||||
|
[ -n "$cpu_port" ] && {
|
||||||
|
json_get_keys vlans vlans
|
||||||
|
for vlan in $vlans; do generate_switch_vlan $1 $vlan $cpu_port; done
|
||||||
|
}
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
}
|
||||||
|
|
||||||
|
generate_led() {
|
||||||
|
local key=$1
|
||||||
|
local cfg="led_$key"
|
||||||
|
|
||||||
|
json_select led
|
||||||
|
json_select $key
|
||||||
|
json_get_vars name sysfs type trigger device interface default
|
||||||
|
json_select ..
|
||||||
|
json_select ..
|
||||||
|
|
||||||
|
uci -q batch <<EOF
|
||||||
|
delete system.$cfg
|
||||||
|
set system.$cfg='led'
|
||||||
|
set system.$cfg.name='$name'
|
||||||
|
set system.$cfg.sysfs='$sysfs'
|
||||||
|
set system.$cfg.dev='$device'
|
||||||
|
set system.$cfg.trigger='$trigger'
|
||||||
|
set system.$cfg.port_mask='$port_mask'
|
||||||
|
set system.$cfg.default='$default'
|
||||||
|
EOF
|
||||||
|
case $type in
|
||||||
|
netdev)
|
||||||
|
uci -q batch <<EOF
|
||||||
|
set system.$cfg.trigger='netdev'
|
||||||
|
set system.$cfg.mode='link tx rx'
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
|
||||||
|
usb)
|
||||||
|
uci -q batch <<EOF
|
||||||
|
set system.$cfg.trigger='usbdev'
|
||||||
|
set system.$cfg.interval='50'
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
json_init
|
||||||
|
json_load "$(cat ${CFG})"
|
||||||
|
|
||||||
|
generate_static_network
|
||||||
|
|
||||||
|
json_get_keys keys network
|
||||||
|
for key in $keys; do generate_network $key; done
|
||||||
|
|
||||||
|
json_get_keys keys switch
|
||||||
|
for key in $keys; do generate_switch $key; done
|
||||||
|
|
||||||
|
json_get_keys keys led
|
||||||
|
for key in $keys; do generate_led $key; done
|
||||||
|
|
||||||
|
uci commit
|
@ -0,0 +1,71 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
awk -f - $* <<EOF
|
||||||
|
function bitcount(c) {
|
||||||
|
c=and(rshift(c, 1),0x55555555)+and(c,0x55555555)
|
||||||
|
c=and(rshift(c, 2),0x33333333)+and(c,0x33333333)
|
||||||
|
c=and(rshift(c, 4),0x0f0f0f0f)+and(c,0x0f0f0f0f)
|
||||||
|
c=and(rshift(c, 8),0x00ff00ff)+and(c,0x00ff00ff)
|
||||||
|
c=and(rshift(c,16),0x0000ffff)+and(c,0x0000ffff)
|
||||||
|
return c
|
||||||
|
}
|
||||||
|
|
||||||
|
function ip2int(ip) {
|
||||||
|
for (ret=0,n=split(ip,a,"\."),x=1;x<=n;x++) ret=or(lshift(ret,8),a[x])
|
||||||
|
return ret
|
||||||
|
}
|
||||||
|
|
||||||
|
function int2ip(ip,ret,x) {
|
||||||
|
ret=and(ip,255)
|
||||||
|
ip=rshift(ip,8)
|
||||||
|
for(;x<3;ret=and(ip,255)"."ret,ip=rshift(ip,8),x++);
|
||||||
|
return ret
|
||||||
|
}
|
||||||
|
|
||||||
|
function compl32(v) {
|
||||||
|
ret=xor(v, 0xffffffff)
|
||||||
|
return ret
|
||||||
|
}
|
||||||
|
|
||||||
|
BEGIN {
|
||||||
|
slpos=index(ARGV[1],"/")
|
||||||
|
if (slpos == 0) {
|
||||||
|
ipaddr=ip2int(ARGV[1])
|
||||||
|
dotpos=index(ARGV[2],".")
|
||||||
|
if (dotpos == 0)
|
||||||
|
netmask=compl32(2**(32-int(ARGV[2]))-1)
|
||||||
|
else
|
||||||
|
netmask=ip2int(ARGV[2])
|
||||||
|
} else {
|
||||||
|
ipaddr=ip2int(substr(ARGV[1],0,slpos-1))
|
||||||
|
netmask=compl32(2**(32-int(substr(ARGV[1],slpos+1)))-1)
|
||||||
|
ARGV[4]=ARGV[3]
|
||||||
|
ARGV[3]=ARGV[2]
|
||||||
|
}
|
||||||
|
|
||||||
|
network=and(ipaddr,netmask)
|
||||||
|
broadcast=or(network,compl32(netmask))
|
||||||
|
|
||||||
|
start=or(network,and(ip2int(ARGV[3]),compl32(netmask)))
|
||||||
|
limit=network+1
|
||||||
|
if (start<limit) start=limit
|
||||||
|
|
||||||
|
end=start+ARGV[4]
|
||||||
|
limit=or(network,compl32(netmask))-1
|
||||||
|
if (end>limit) end=limit
|
||||||
|
|
||||||
|
print "IP="int2ip(ipaddr)
|
||||||
|
print "NETMASK="int2ip(netmask)
|
||||||
|
print "BROADCAST="int2ip(broadcast)
|
||||||
|
print "NETWORK="int2ip(network)
|
||||||
|
print "PREFIX="32-bitcount(compl32(netmask))
|
||||||
|
|
||||||
|
# range calculations:
|
||||||
|
# ipcalc <ip> <netmask> <start> <num>
|
||||||
|
|
||||||
|
if (ARGC > 3) {
|
||||||
|
print "START="int2ip(start)
|
||||||
|
print "END="int2ip(end)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EOF
|
@ -0,0 +1,19 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2011 OpenWrt.org
|
||||||
|
|
||||||
|
if ( ! grep -qsE '^root:[!x]?:' /etc/shadow || \
|
||||||
|
! grep -qsE '^root:[!x]?:' /etc/passwd ) && \
|
||||||
|
[ -z "$FAILSAFE" ]
|
||||||
|
then
|
||||||
|
echo "Login failed."
|
||||||
|
exit 0
|
||||||
|
else
|
||||||
|
cat << EOF
|
||||||
|
=== IMPORTANT ============================
|
||||||
|
Use 'passwd' to set your login password
|
||||||
|
this will disable telnet and enable SSH
|
||||||
|
------------------------------------------
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec /bin/ash --login
|
Binary file not shown.
@ -0,0 +1 @@
|
|||||||
|
/tmp/TZ
|
@ -0,0 +1,14 @@
|
|||||||
|
_______ ________ __
|
||||||
|
| |.-----.-----.-----.| | | |.----.| |_
|
||||||
|
| - || _ | -__| || | | || _|| _|
|
||||||
|
|_______|| __|_____|__|__||________||__| |____|
|
||||||
|
|__| W I R E L E S S F R E E D O M
|
||||||
|
-----------------------------------------------------
|
||||||
|
CHAOS CALMER (15.05.1, r48532)
|
||||||
|
-----------------------------------------------------
|
||||||
|
* 1 1/2 oz Gin Shake with a glassful
|
||||||
|
* 1/4 oz Triple Sec of broken ice and pour
|
||||||
|
* 3/4 oz Lime Juice unstrained into a goblet.
|
||||||
|
* 1 1/2 oz Orange Juice
|
||||||
|
* 1 tsp. Grenadine Syrup
|
||||||
|
-----------------------------------------------------
|
@ -0,0 +1,13 @@
|
|||||||
|
================= FAILSAFE MODE active ================
|
||||||
|
special commands:
|
||||||
|
* firstboot reset settings to factory defaults
|
||||||
|
* mount_root mount root-partition with config files
|
||||||
|
|
||||||
|
after mount_root:
|
||||||
|
* passwd change root's password
|
||||||
|
* /etc/config directory with config files
|
||||||
|
|
||||||
|
for more help see:
|
||||||
|
http://wiki.openwrt.org/doc/howto/generic.failsafe
|
||||||
|
=======================================================
|
||||||
|
|
@ -0,0 +1,26 @@
|
|||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
config interface loopback
|
||||||
|
option ifname lo
|
||||||
|
option proto static
|
||||||
|
option ipaddr 127.0.0.1
|
||||||
|
option netmask 255.0.0.0
|
||||||
|
|
||||||
|
config interface lan
|
||||||
|
option ifname eth0
|
||||||
|
option type bridge
|
||||||
|
option proto static
|
||||||
|
option ipaddr 192.168.1.1
|
||||||
|
option netmask 255.255.255.0
|
||||||
|
option ip6assign 60
|
||||||
|
|
||||||
|
config interface wan
|
||||||
|
option ifname eth1
|
||||||
|
option proto dhcp
|
||||||
|
|
||||||
|
config interface wan6
|
||||||
|
option ifname eth1
|
||||||
|
option proto dhcpv6
|
||||||
|
|
||||||
|
config globals globals
|
||||||
|
option ula_prefix auto
|
@ -0,0 +1,11 @@
|
|||||||
|
config system
|
||||||
|
option hostname OpenWrt
|
||||||
|
option timezone UTC
|
||||||
|
|
||||||
|
config timeserver ntp
|
||||||
|
list server 0.openwrt.pool.ntp.org
|
||||||
|
list server 1.openwrt.pool.ntp.org
|
||||||
|
list server 2.openwrt.pool.ntp.org
|
||||||
|
list server 3.openwrt.pool.ntp.org
|
||||||
|
option enabled 1
|
||||||
|
option enable_server 0
|
@ -0,0 +1,3 @@
|
|||||||
|
DEVICE_MANUFACTURER='OpenWrt'
|
||||||
|
DEVICE_PRODUCT='Generic'
|
||||||
|
DEVICE_REVISION='v0'
|
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2006-2009 OpenWrt.org
|
||||||
|
|
||||||
|
set_state() { :; }
|
@ -0,0 +1 @@
|
|||||||
|
/tmp/fstab
|
@ -0,0 +1,10 @@
|
|||||||
|
root:x:0:
|
||||||
|
daemon:x:1:
|
||||||
|
adm:x:4:
|
||||||
|
mail:x:8:
|
||||||
|
audio:x:29:
|
||||||
|
www-data:x:33:
|
||||||
|
ftp:x:55:
|
||||||
|
users:x:100:
|
||||||
|
network:x:101:
|
||||||
|
nogroup:x:65534:
|
@ -0,0 +1 @@
|
|||||||
|
127.0.0.1 localhost
|
@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if [ -f /etc/sysctl.conf ] && [ "$ACTION" = add ]; then
|
||||||
|
sed -ne "/^[[:space:]]*net\..*\.$DEVICENAME\./p" /etc/sysctl.conf | \
|
||||||
|
sysctl -e -p - | logger -t sysctl
|
||||||
|
fi
|
@ -0,0 +1,61 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2006-2011 OpenWrt.org
|
||||||
|
|
||||||
|
START=10
|
||||||
|
STOP=98
|
||||||
|
|
||||||
|
uci_apply_defaults() {
|
||||||
|
. /lib/functions/system.sh
|
||||||
|
|
||||||
|
cd /etc/uci-defaults || return 0
|
||||||
|
files="$(ls)"
|
||||||
|
[ -z "$files" ] && return 0
|
||||||
|
mkdir -p /tmp/.uci
|
||||||
|
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/run
|
||||||
|
mkdir -p /var/log
|
||||||
|
mkdir -p /var/lock
|
||||||
|
mkdir -p /var/state
|
||||||
|
mkdir -p /tmp/.uci
|
||||||
|
chmod 0700 /tmp/.uci
|
||||||
|
mkdir -p /tmp/.jail
|
||||||
|
touch /var/log/wtmp
|
||||||
|
touch /var/log/lastlog
|
||||||
|
touch /tmp/resolv.conf.auto
|
||||||
|
ln -sf /tmp/resolv.conf.auto /tmp/resolv.conf
|
||||||
|
grep -q debugfs /proc/filesystems && /bin/mount -o noatime -t debugfs debugfs /sys/kernel/debug
|
||||||
|
[ "$FAILSAFE" = "true" ] && touch /tmp/.failsafe
|
||||||
|
|
||||||
|
/sbin/kmodloader
|
||||||
|
|
||||||
|
# allow wifi modules time to settle
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
/sbin/wifi detect > /tmp/wireless.tmp
|
||||||
|
[ -s /tmp/wireless.tmp ] && {
|
||||||
|
cat /tmp/wireless.tmp >> /etc/config/wireless
|
||||||
|
}
|
||||||
|
rm -f /tmp/wireless.tmp
|
||||||
|
|
||||||
|
/bin/board_detect
|
||||||
|
uci_apply_defaults
|
||||||
|
|
||||||
|
# temporary hack until configd exists
|
||||||
|
/sbin/reload_config
|
||||||
|
|
||||||
|
# create /dev/root if it doesn't exist
|
||||||
|
[ -e /dev/root -o -h /dev/root ] || {
|
||||||
|
rootdev=$(awk 'BEGIN { RS=" "; FS="="; } $1 == "root" { print $2 }' < /proc/cmdline)
|
||||||
|
[ -n "$rootdev" ] && ln -s "$rootdev" /dev/root
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
START=95
|
||||||
|
boot() {
|
||||||
|
mount_root done
|
||||||
|
rm -f /sysupgrade.tgz
|
||||||
|
|
||||||
|
# process user commands
|
||||||
|
[ -f /etc/rc.local ] && {
|
||||||
|
sh /etc/rc.local
|
||||||
|
}
|
||||||
|
|
||||||
|
# set leds to normal state
|
||||||
|
. /etc/diag.sh
|
||||||
|
set_state done
|
||||||
|
}
|
@ -0,0 +1,99 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2008 OpenWrt.org
|
||||||
|
|
||||||
|
START=96
|
||||||
|
|
||||||
|
load_led() {
|
||||||
|
local name
|
||||||
|
local sysfs
|
||||||
|
local trigger
|
||||||
|
local dev
|
||||||
|
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 mode $1 mode "link"
|
||||||
|
config_get_bool default $1 default "nil"
|
||||||
|
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 ""
|
||||||
|
|
||||||
|
if [ "$trigger" = "rssi" ]; then
|
||||||
|
# handled by rssileds userspace process
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
[ -e /sys/class/leds/${sysfs}/brightness ] && {
|
||||||
|
echo "setting up led ${name}"
|
||||||
|
|
||||||
|
[ "$default" = 0 ] &&
|
||||||
|
echo 0 >/sys/class/leds/${sysfs}/brightness
|
||||||
|
|
||||||
|
echo $trigger > /sys/class/leds/${sysfs}/trigger 2> /dev/null
|
||||||
|
ret="$?"
|
||||||
|
|
||||||
|
[ $default = 1 ] &&
|
||||||
|
echo 1 >/sys/class/leds/${sysfs}/brightness
|
||||||
|
|
||||||
|
[ $ret = 0 ] || {
|
||||||
|
echo >&2 "Skipping trigger '$trigger' for led '$name' due to missing kernel module"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
case "$trigger" in
|
||||||
|
"netdev")
|
||||||
|
[ -n "$dev" ] && {
|
||||||
|
echo $dev > /sys/class/leds/${sysfs}/device_name
|
||||||
|
echo $mode > /sys/class/leds/${sysfs}/mode
|
||||||
|
}
|
||||||
|
;;
|
||||||
|
|
||||||
|
"timer")
|
||||||
|
[ -n "$delayon" ] && \
|
||||||
|
echo $delayon > /sys/class/leds/${sysfs}/delay_on
|
||||||
|
[ -n "$delayoff" ] && \
|
||||||
|
echo $delayoff > /sys/class/leds/${sysfs}/delay_off
|
||||||
|
;;
|
||||||
|
|
||||||
|
"usbdev")
|
||||||
|
[ -n "$dev" ] && {
|
||||||
|
echo $dev > /sys/class/leds/${sysfs}/device_name
|
||||||
|
echo $interval > /sys/class/leds/${sysfs}/activity_interval
|
||||||
|
}
|
||||||
|
;;
|
||||||
|
|
||||||
|
"port_state")
|
||||||
|
[ -n "$port_state" ] && \
|
||||||
|
echo $port_state > /sys/class/leds/${sysfs}/port_state
|
||||||
|
;;
|
||||||
|
|
||||||
|
"morse")
|
||||||
|
echo $message > /sys/class/leds/${sysfs}/message
|
||||||
|
echo $delay > /sys/class/leds/${sysfs}/delay
|
||||||
|
;;
|
||||||
|
|
||||||
|
switch[0-9]*)
|
||||||
|
local port_mask
|
||||||
|
|
||||||
|
config_get port_mask $1 port_mask
|
||||||
|
[ -n "$port_mask" ] && \
|
||||||
|
echo $port_mask > /sys/class/leds/${sysfs}/port_mask
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
start() {
|
||||||
|
[ -e /sys/class/leds/ ] && {
|
||||||
|
config_load system
|
||||||
|
config_foreach load_led led
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
START=11
|
||||||
|
start() {
|
||||||
|
[ -f /etc/sysctl.conf ] && sysctl -p -e >&-
|
||||||
|
}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user