X-Git-Url: http://git.rohieb.name/openwrt.git/blobdiff_plain/d62e77d17efa6e3105f52411e13fdc3e3d8787a4..ab09debb66b84bcf763fa475feb80420232df791:/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 3a8bebd17..2e6f2e8e4 100644 --- a/package/broadcom-wl/files/lib/wifi/broadcom.sh +++ b/package/broadcom-wl/files/lib/wifi/broadcom.sh @@ -52,7 +52,7 @@ scan_broadcom() { case "$adhoc:$sta:$apmode" in 1*) ap=0 - mssid=0 + mssid= infra=0 ;; :1:1) @@ -62,7 +62,7 @@ scan_broadcom() { :1:) wet=1 ap=0 - mssid=0 + mssid= ;; ::) radio=0 @@ -71,6 +71,7 @@ scan_broadcom() { } disable_broadcom() { + set_wifi_down "$1" wlc down ( include /lib/network @@ -96,6 +97,8 @@ enable_broadcom() { config_get slottime "$device" slottime config_get rxant "$device" rxant config_get txant "$device" txant + config_get macfilter "$device" macfilter + config_get maclist "$device" maclist local vif_pre_up vif_post_up vif_do_up _c=0 @@ -111,6 +114,18 @@ enable_broadcom() { } || { slottime="${slottime:--1}" } + + case "$macfilter" in + allow|2) + macfilter=2; + ;; + deny|1) + macfilter=1; + ;; + disable|none|0) + macfilter=0; + ;; + esac for vif in $vifs; do config_get mode "$vif" mode @@ -143,11 +158,11 @@ enable_broadcom() { config_get k "$vif" key$knr [ -n "$k" ] || continue [ "$defkey" = "$knr" ] && def="=" || def="" - append vif_pre_up "wepkey $def$knr,$k" "$N" + append vif_do_up "wepkey $def$knr,$k" "$N" done ;; "");; - *) append vif_pre_up "wepkey =1,$key" "$N";; + *) append vif_do_up "wepkey =1,$key" "$N";; esac ;; *psk*|*PSK*) @@ -176,17 +191,15 @@ enable_broadcom() { nasopts="-r \"\$${vif}_key\" -h $server -p $port" ;; esac - append vif_post_up "wsec $wsec" "$N" - append vif_post_up "wpa_auth $auth" "$N" - append vif_post_up "wsec_restrict $wsec_r" "$N" - append vif_post_up "eap_restrict $eap_r" "$N" + append vif_do_up "wsec $wsec" "$N" + append vif_do_up "wpa_auth $auth" "$N" + append vif_do_up "wsec_restrict $wsec_r" "$N" + append vif_do_up "eap_restrict $eap_r" "$N" config_get ssid "$vif" ssid append vif_post_up "vlan_mode 0" "$N" append vif_post_up "ssid $ssid" "$N" - case "$mode" in - sta|adhoc) append vif_do_up "ssid $ssid" "$N";; - esac + append vif_do_up "ssid $ssid" "$N" append vif_post_up "enabled 1" "$N" @@ -197,6 +210,7 @@ enable_broadcom() { [ -z "$net_cfg" ] || { bridge="$(bridge_interface "$net_cfg")" append if_up "start_net '$ifname' '$net_cfg'" ";$N" + append if_up "set_wifi_up '$vif' '$ifname'" ";$N" } [ -z "$nasopts" ] || { eval "${vif}_ssid=\"\$ssid\"" @@ -205,8 +219,8 @@ enable_broadcom() { [ "$mode" = "sta" ] && { nas_mode="-S" [ -z "$bridge" ] || { - append vif_pre_up "supplicant 1" "$N" - append vif_pre_up "passphrase $key" "$N" + append vif_post_up "supplicant 1" "$N" + append vif_post_up "passphrase $key" "$N" use_nas=0 } @@ -220,7 +234,7 @@ enable_broadcom() { $ifdown ap $ap -mssid $mssid +${mssid:+mssid $mssid} apsta $apsta infra $infra ${wet:+wet 1} @@ -230,12 +244,12 @@ rxant ${rxant:-3} txant ${txant:-3} radio ${radio:-1} -macfilter 0 -maclist none +macfilter ${macfilter:-0} +maclist ${maclist:-none} wds none ${wds:+wds $wds} -${channel:+channel $channel} country ${country:-IL0} +${channel:+channel $channel} maxassoc ${maxassoc:-128} slottime ${slottime:--1}