X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/2cb5343fc18be5153b476147c0f3fd142cb36cba..4822dacdd483b62f17d487f3c6f8b1bed2fcdeba:/package/broadcom-wl/files/lib/wifi/broadcom.sh diff --git a/package/broadcom-wl/files/lib/wifi/broadcom.sh b/package/broadcom-wl/files/lib/wifi/broadcom.sh index 6cac60c0b..397932e2a 100644 --- a/package/broadcom-wl/files/lib/wifi/broadcom.sh +++ b/package/broadcom-wl/files/lib/wifi/broadcom.sh @@ -1,5 +1,10 @@ +append DRIVERS "broadcom" + scan_broadcom() { local device="$1" + local wds + local adhoc sta apmode + local adhoc_if sta_if ap_if config_get vifs "$device" vifs for vif in $vifs; do @@ -14,12 +19,17 @@ scan_broadcom() { sta_if="$vif" ;; ap) - ap=1 + apmode=1 ap_if="${ap_if:+$ap_if }$vif" ;; + wds) + config_get addr "$vif" bssid + [ -z "$addr" ] || append wds "$addr" + ;; *) echo "$device($vif): Invalid mode";; esac done + config_set "$device" wds "$wds" local _c= for vif in ${adhoc_if:-$sta_if $ap_if}; do @@ -38,7 +48,7 @@ scan_broadcom() { mssid=1 apsta=0 radio=1 - case "$adhoc:$sta:$ap" in + case "$adhoc:$sta:$apmode" in 1*) ap=0 mssid=0 @@ -59,12 +69,27 @@ scan_broadcom() { esac } +disable_broadcom() { + wlc down + ( + include /lib/network + + # make sure the interfaces are down and removed from all bridges + for dev in wl0 wl0.1 wl0.2 wl0.3; do + ifconfig "$dev" down 2>/dev/null >/dev/null && { + unbridge "$dev" + } + done + ) + true +} -setup_broadcom() { +enable_broadcom() { local _c config_get channel "$device" channel config_get country "$device" country config_get maxassoc "$device" maxassoc + config_get wds "$device" wds _c=0 nas="$(which nas)" @@ -121,13 +146,18 @@ setup_broadcom() { append vif_post_up "eap_restrict $eap_r" "$N" config_get ssid "$vif" ssid + append vif_post_up "vlan_mode 0" append vif_post_up "ssid $ssid" "$N" append vif_post_up "enabled 1" "$N" config_get ifname "$vif" ifname append if_up "ifconfig $ifname up" ";$N" + net_cfg="$(find_net_config "$vif")" + [ -z "$net_cfg" ] || { + bridge="$(bridge_interface "$net_cfg")" + append if_up "start_net '$ifname' '$net_cfg'" ";$N" + } [ -z "$nasopts" ] || { - config_get bridge "$vif" bridge # XXX: integrate with /etc/config/network later eval "${vif}_ssid=\"\$ssid\"" mode="-A" [ "$vif" = "$sta_if" ] && mode="-S" @@ -139,8 +169,8 @@ setup_broadcom() { wlc stdin <