1 append DRIVERS
"broadcom"
7 local adhoc_if sta_if ap_if
10 config_get vifs
"$device" vifs
12 config_get mode
"$vif" mode
24 ap_if
="${ap_if:+$ap_if }$vif"
27 config_get addr
"$vif" bssid
28 [ -z "$addr" ] || append wds
"$addr"
30 *) echo "$device($vif): Invalid mode";;
33 config_set
"$device" wds
"$wds"
36 for vif
in ${adhoc_if:-$sta_if $ap_if}; do
37 config_set
"$vif" ifname
"wl0${_c:+.$_c}"
40 config_set
"$device" vifs
"${adhoc_if:-$sta_if $ap_if}"
43 for vif
in 0 1 2 3; do
44 append ifdown
"vif $vif" "$N"
45 append ifdown
"enabled 0" "$N"
53 case "$adhoc:$sta:$apmode" in
92 # make sure the interfaces are down and removed from all bridges
93 for dev
in wl0 wl0.1 wl0.2 wl0.3
; do
94 ifconfig
"$dev" down
2>/dev
/null
>/dev
/null
&& {
104 config_get channel
"$device" channel
105 config_get country
"$device" country
106 config_get maxassoc
"$device" maxassoc
107 config_get wds
"$device" wds
108 config_get vifs
"$device" vifs
109 config_get distance
"$device" distance
110 config_get slottime
"$device" slottime
111 config_get rxant
"$device" rxant
112 config_get txant
"$device" txant
113 config_get macfilter
"$device" macfilter
114 config_get maclist
"$device" maclist
115 local vif_pre_up vif_post_up vif_do_up
122 [ -z "$slottime" ] && {
123 [ -n "$distance" ] && {
124 # slottime = 9 + (distance / 150) + (distance % 150 ? 1 : 0)
125 slottime
="$((9 + ($distance / 150) + 1 - (150 - ($distance % 150)) / 150 ))"
128 slottime
="${slottime:--1}"
132 config_get mode
"$vif" mode
133 append vif_pre_up
"vif $_c" "$N"
134 append vif_post_up
"vif $_c" "$N"
136 [ "$mode" = "sta" ] ||
{
137 config_get_bool hidden
"$vif" hidden
0
138 append vif_pre_up
"closed $hidden" "$N"
139 config_get_bool isolate
"$vif" isolate
0
140 append vif_pre_up
"ap_isolate $isolate" "$N"
148 config_get enc
"$vif" encryption
154 config_get key
"$vif" key
158 for knr
in 1 2 3 4; do
159 config_get k
"$vif" key
$knr
160 [ -n "$k" ] ||
continue
161 [ "$defkey" = "$knr" ] && def
="=" || def
=""
162 append vif_pre_up
"wepkey $def$knr,$k" "$N"
166 *) append vif_pre_up
"wepkey =1,$key" "$N";;
171 config_get key
"$vif" key
173 wpa
*+wpa2
*|WPA
*+WPA2
*|
*psk
+*psk2|
*PSK
+*PSK2
) auth
=132; wsec
=6;;
174 wpa2
*|WPA2
*|
*PSK2|
*psk2
) auth
=128; wsec
=4;;
177 eval "${vif}_key=\"\$key\""
178 nasopts
="-k \"\$${vif}_key\""
183 config_get key
"$vif" key
184 config_get server
"$vif" server
185 config_get port
"$vif" port
187 wpa
*+wpa2
*|WPA
*+WPA2
*) auth
=66; wsec
=6;;
188 wpa2
*|WPA2
*) auth
=64; wsec
=4;;
191 eval "${vif}_key=\"\$key\""
192 nasopts
="-r \"\$${vif}_key\" -h $server -p $port"
195 append vif_post_up
"wsec $wsec" "$N"
196 append vif_post_up
"wpa_auth $auth" "$N"
197 append vif_post_up
"wsec_restrict $wsec_r" "$N"
198 append vif_post_up
"eap_restrict $eap_r" "$N"
200 config_get ssid
"$vif" ssid
201 append vif_post_up
"vlan_mode 0" "$N"
202 append vif_post_up
"ssid $ssid" "$N"
204 sta|adhoc
) append vif_do_up
"ssid $ssid" "$N";;
207 append vif_post_up
"enabled 1" "$N"
209 config_get ifname
"$vif" ifname
210 #append if_up "ifconfig $ifname up" ";$N"
212 net_cfg
="$(find_net_config "$vif")"
213 [ -z "$net_cfg" ] ||
{
214 bridge
="$(bridge_interface "$net_cfg")"
215 append if_up
"start_net '$ifname' '$net_cfg'" ";$N"
216 append if_up
"set_wifi_up '$vif' '$ifname'" ";$N"
218 [ -z "$nasopts" ] ||
{
219 eval "${vif}_ssid=\"\$ssid\""
222 [ "$mode" = "sta" ] && {
224 [ -z "$bridge" ] ||
{
225 append vif_pre_up
"supplicant 1" "$N"
226 append vif_pre_up
"passphrase $key" "$N"
231 [ -z "$nas" -o "$use_nas" = "0" ] || nas_cmd
="${nas_cmd:+$nas_cmd$N}$nas -P /var/run/nas.$ifname.pid -H 34954 ${bridge:+ -l $bridge} -i $ifname $nas_mode -m $auth -w $wsec -s \"\$${vif}_ssid\" -g 3600 $nasopts &"
235 killall
-KILL nas
>&- 2>&-
250 macfilter ${macfilter:-disabled}
251 maclist ${maclist:-none}
254 ${channel:+channel $channel}
255 country ${country:-IL0}
256 maxassoc ${maxassoc:-128}
257 slottime ${slottime:--1}
272 [ -f /proc
/net
/wl0
] ||
return
273 config_get
type wl0
type
274 [ "$type" = broadcom
] && return
276 config wifi-device wl0
280 # REMOVE THIS LINE TO ENABLE WIFI:
288 option encryption none