1 append DRIVERS
"broadcom"
7 local adhoc_if sta_if ap_if
9 config_get vifs
"$device" vifs
11 config_get mode
"$vif" mode
23 ap_if
="${ap_if:+$ap_if }$vif"
26 config_get addr
"$vif" bssid
27 [ -z "$addr" ] || append wds
"$addr"
29 *) echo "$device($vif): Invalid mode";;
32 config_set
"$device" wds
"$wds"
35 for vif
in ${adhoc_if:-$sta_if $ap_if}; do
36 config_set
"$vif" ifname
"wl0${_c:+.$_c}"
39 config_set
"$device" vifs
"${adhoc_if:-$sta_if $ap_if}"
42 for vif
in 0 1 2 3; do
43 append ifdown
"vif $vif" "$N"
44 append ifdown
"enabled 0" "$N"
52 case "$adhoc:$sta:$apmode" in
78 # make sure the interfaces are down and removed from all bridges
79 for dev
in wl0 wl0.1 wl0.2 wl0.3
; do
80 ifconfig
"$dev" down
2>/dev
/null
>/dev
/null
&& {
90 config_get channel
"$device" channel
91 config_get country
"$device" country
92 config_get maxassoc
"$device" maxassoc
93 config_get wds
"$device" wds
94 config_get vifs
"$device" vifs
95 local vif_pre_up vif_post_up vif_do_up
102 config_get mode
"$vif" mode
103 append vif_pre_up
"vif $_c" "$N"
104 append vif_post_up
"vif $_c" "$N"
106 [ "$mode" = "sta" ] ||
{
107 config_get_bool hidden
"$vif" hidden
1
108 append vif_pre_up
"closed $hidden" "$N"
109 config_get_bool isolate
"$vif" isolate
110 append vif_pre_up
"ap_isolate $hidden" "$N"
118 config_get enc
"$vif" encryption
124 config_get key
"$vif" key
128 for knr
in 1 2 3 4; do
129 config_get k
"$vif" key
$knr
130 [ -n "$k" ] ||
continue
131 [ "$defkey" = "$knr" ] && def
="=" || def
=""
132 append vif_pre_up
"wepkey $def$knr,$k" "$N"
136 *) append vif_pre_up
"wepkey 1,$key" "$N";;
141 config_get key
"$vif" key
143 wpa2
*|WPA2
*|PSK2
*|psk2
*) auth
=128; wsec
=4;;
144 *) auth
=4; crypto
=2;;
146 eval "${vif}_key=\"\$key\""
147 nasopts
="-k \"\$${vif}_key\""
152 config_get key
"$vif" key
153 config_get server
"$vif" server
154 config_get port
"$vif" port
156 wpa2
*|WPA2
*) auth
=64; wsec
=4;;
157 *) auth
=2; crypto
=2;;
159 eval "${vif}_key=\"\$key\""
160 nasopts
="-r \"\$${vif}_key\" -h $server -p $port"
163 append vif_post_up
"wsec $wsec" "$N"
164 append vif_post_up
"wpa_auth $auth" "$N"
165 append vif_post_up
"wsec_restrict $wsec_r" "$N"
166 append vif_post_up
"eap_restrict $eap_r" "$N"
168 config_get ssid
"$vif" ssid
169 append vif_post_up
"vlan_mode 0"
170 append vif_post_up
"ssid $ssid" "$N"
172 sta|adhoc
) append vif_do_up
"ssid $ssid" "$N";;
175 append vif_post_up
"enabled 1" "$N"
177 config_get ifname
"$vif" ifname
178 append if_up
"ifconfig $ifname up" ";$N"
180 net_cfg
="$(find_net_config "$vif")"
181 [ -z "$net_cfg" ] ||
{
182 bridge
="$(bridge_interface "$net_cfg")"
183 append if_up
"start_net '$ifname' '$net_cfg'" ";$N"
185 [ -z "$nasopts" ] ||
{
186 eval "${vif}_ssid=\"\$ssid\""
188 [ "$vif" = "$sta_if" ] && mode
="-S"
189 [ -z "$nas" ] || nas_cmd
="${nas_cmd:+$nas_cmd$N}$nas -P /var/run/nas.$ifname.pid -H 34954 ${bridge:+ -l $bridge} -i $ifname $mode -m $auth -w $crypto -s \"\$${vif}_ssid\" -g 3600 $nasopts &"
193 killall
-KILL nas
>&- 2>&-
207 channel ${channel:-0}
208 country ${country:-IL0}
209 maxassoc ${maxassoc:-128}
224 [ -f /proc
/net
/wl0
] ||
return
225 config_get
type wl0
type
226 [ "$type" = broadcom
] && return
228 config wifi-device wl0
237 option encryption none