diff options
author | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2010-06-14 11:00:30 +0000 |
---|---|---|
committer | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2010-06-14 11:00:30 +0000 |
commit | 96465c018c224cfd5d82f91215c5c2fbd0b746d3 (patch) | |
tree | cb96e071aad517955a9451f62f215a53f7d98a70 /package/broadcom-wl-old/files/etc/hotplug.d | |
parent | 878b1f5b6aaaabd89c7ab389aece703486ee95aa (diff) |
rename broadcom-wl to broadcom-wl-old
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@21794 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/broadcom-wl-old/files/etc/hotplug.d')
-rw-r--r-- | package/broadcom-wl-old/files/etc/hotplug.d/net/20-broadcom_wds | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/package/broadcom-wl-old/files/etc/hotplug.d/net/20-broadcom_wds b/package/broadcom-wl-old/files/etc/hotplug.d/net/20-broadcom_wds new file mode 100644 index 000000000..f314a2527 --- /dev/null +++ b/package/broadcom-wl-old/files/etc/hotplug.d/net/20-broadcom_wds @@ -0,0 +1,59 @@ +include /lib/wifi + +setup_broadcom_wds() { + local iface="$1" + local remote="$(wlc ifname "$iface" wdsmac)" + + [ -z "$remote" ] && return + + config_cb() { + [ -z "$CONFIG_SECTION" ] && return + + config_get type "$CONFIG_SECTION" TYPE + [ "$type" = "wifi-iface" ] || return + + config_get network "$CONFIG_SECTION" network + [ -z "$network" ] && return + + config_get addr "$CONFIG_SECTION" bssid + addr=$(echo "$addr" | tr 'A-F' 'a-f') + [ "$addr" = "$remote" ] && { + local cfg="$CONFIG_SECTION" + + include /lib/network + scan_interfaces + + setup_interface "$iface" "$network" + + config_get encryption "$cfg" encryption + config_get key "$cfg" key + config_get ssid "$cfg" ssid + + [ "$encryption" != "none" ] && { + sleep 5 + case "$encryption" in + psk|PSK) + nas4not "$network" "$iface" up auto tkip psk "$key" "$ssid" + ;; + psk2|PSK2) + nas4not "$network" "$iface" up auto aes psk "$key" "$ssid" + ;; + psk+psk2|psk2+psk|PSK+PSK2|PSK2+PSK) + nas4not "$network" "$iface" up auto aes+tkip psk "$key" "$ssid" + ;; + *) + nas4not lan "$iface" up auto aes "$encryption" "$key" "$ssid" + ;; + esac + } + } + } + + config_load wireless +} + +case "$ACTION" in + add|register) + [ "${INTERFACE%%0.*}" = wds ] && setup_broadcom_wds "$INTERFACE" + ;; +esac |