add protection for bridging interface changes
[openwrt.git] / package / base-files / default / sbin / wifi
index b8b995b..759cfb0 100755 (executable)
@@ -1,6 +1,51 @@
 #!/bin/sh
+# Copyright (C) 2006 OpenWrt.org
+
 . /etc/functions.sh
 
+wifi_up() {
+       for device in ${2:-$DEVICES}; do (
+               config_get iftype "$device" type
+               if eval "type enable_$iftype" 2>/dev/null >/dev/null; then
+                       eval "scan_$iftype '$device'"
+                       eval "enable_$iftype '$device'" || echo "$device($iftype): Setup failed"
+               else
+                       echo "$device($iftype): Interface type not supported"
+               fi
+       ); done
+}
+
+wifi_down() {
+       for device in ${2:-$DEVICES}; do (
+               config_get iftype "$device" type
+               if eval "type disable_$iftype" 2>/dev/null >/dev/null; then
+                       eval "scan_$iftype '$device'"
+                       eval "disable_$iftype '$device'" || echo "$device($iftype): Setup failed"
+               else
+                       echo "$device($iftype): Interface type not supported"
+               fi
+       ); done
+}
+
+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"
+
+       include /lib/network
+       scan_interfaces
+       setup_interface "$1" "$2"
+)}
+
 config_get_bool() {
        local _tmp
        config_get "$1" "$2" "$3"
@@ -27,21 +72,13 @@ config_cb() {
        esac
 }
 
+DEVICES=
+DRIVERS=
 config_load wireless
+include /lib/wifi
 
-[ -d /lib/wifi -a -n "$(ls /lib/wifi/*.sh 2>&-)" ] && {
-       for script in /lib/wifi/*.sh; do
-               . $script
-       done
-}
-
-for device in $DEVICES; do (
-       config_get type "$device" type
-       eval "type setup_$type" 2>/dev/null >/dev/null && {
-               eval "scan_$type '$device'"
-               eval "setup_$type '$device'" && {
-                       # TODO: set up network settings
-                       /bin/true
-               } || echo "$device($type): Setup failed" || true
-       } || echo "$device($type): Interface type not supported"
-); done
+case "$1" in
+       down) wifi_down "$2";;
+       detect) wifi_detect "$2";;
+       *) wifi_up "$2";;
+esac
This page took 0.021516 seconds and 4 git commands to generate.