X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/0150231148dcbf531678285c0397a1612cd1bcde..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 bc90f088b..397932e2a 100644 --- a/package/broadcom-wl/files/lib/wifi/broadcom.sh +++ b/package/broadcom-wl/files/lib/wifi/broadcom.sh @@ -1,19 +1,10 @@ append DRIVERS "broadcom" -bridge_interface() { - ( - . /etc/functions.sh - include network - scan_interfaces - cfg="$(find_config "$1")" - [ -z "$cfg" ] && return 0 - config_get iftype "$cfg" type - [ "$iftype" = bridge ] && config_get "$iftype" bridge - ) -} - 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 @@ -28,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 @@ -52,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 @@ -85,6 +81,7 @@ disable_broadcom() { } done ) + true } enable_broadcom() { @@ -92,6 +89,7 @@ enable_broadcom() { 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)" @@ -154,8 +152,12 @@ enable_broadcom() { 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" ] || { - bridge="$(bridge_interface "$ifname")" eval "${vif}_ssid=\"\$ssid\"" mode="-A" [ "$vif" = "$sta_if" ] && mode="-S" @@ -167,8 +169,8 @@ enable_broadcom() { wlc stdin <