summaryrefslogtreecommitdiffstats
path: root/target
diff options
context:
space:
mode:
authorJohn Crispin <john@openwrt.org>2012-12-21 13:47:50 +0000
committerJohn Crispin <john@openwrt.org>2012-12-21 13:47:50 +0000
commit59cc6d9dddcead0f72277d0d13eb0dd773741349 (patch)
tree32d725466a0ca8fec260b2a460e9d2172aa0578d /target
parent7ce4c81647c98eb8105486b17f599b6933b22b63 (diff)
downloadmaster-31e0f0ae-59cc6d9dddcead0f72277d0d13eb0dd773741349.tar.gz
master-31e0f0ae-59cc6d9dddcead0f72277d0d13eb0dd773741349.tar.bz2
master-31e0f0ae-59cc6d9dddcead0f72277d0d13eb0dd773741349.zip
improve button handling
SVN-Revision: 34823
Diffstat (limited to 'target')
-rw-r--r--target/linux/lantiq/base-files/etc/hotplug.d/button/10-generic.sh50
1 files changed, 39 insertions, 11 deletions
diff --git a/target/linux/lantiq/base-files/etc/hotplug.d/button/10-generic.sh b/target/linux/lantiq/base-files/etc/hotplug.d/button/10-generic.sh
index e6dcb347f1..4b305fbdfb 100644
--- a/target/linux/lantiq/base-files/etc/hotplug.d/button/10-generic.sh
+++ b/target/linux/lantiq/base-files/etc/hotplug.d/button/10-generic.sh
@@ -4,21 +4,49 @@
. /lib/functions.sh
+logger "$BUTTON pressed for $SEEN seconds"
+
+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
+}
+
case "${BUTTON}" in
reset)
- logger "reset pressed"
- echo "REBOOT" > /dev/console
- sleep 3
- sync
- reboot
+ if [ "$SEEN" -lt 1 ]
+ then
+ echo "REBOOT" > /dev/console
+ sync
+ reboot
+ elif [ "$SEEN" -gt 5 ]
+ then
+ echo "FACTORY RESET" > /dev/console
+ firstboot && reboot &
+ fi
;;
- BTN_1)
- logger "factory pressed"
- echo "FACTORY RESET" > /dev/console
- jffs2_mark_erase "rootfs_data"
- sync
- reboot
+
+ wps)
+ for dir in /var/run/hostapd-*; do
+ [ -d "$dir" ] || continue
+ hostapd_cli -p "$dir" wps_pbc
+ done
+ ;;
+
+ rfkill)
+ config_load wireless
+ config_foreach wifi_rfkill_check wifi-device
+ config_foreach wifi_rfkill_set wifi-device
+ uci commit wireless
+ wifi up
;;
+
*)
logger "unknown button ${BUTTON}"
;;