more mssid fixes
[openwrt/openwrt.git] / package / broadcom-wl / files / lib / wifi / broadcom.sh
1 append DRIVERS "broadcom"
2
3 scan_broadcom() {
4 local device="$1"
5 local wds
6 local adhoc sta apmode
7 local adhoc_if sta_if ap_if
8
9 config_get vifs "$device" vifs
10 for vif in $vifs; do
11 config_get mode "$vif" mode
12 case "$mode" in
13 adhoc)
14 adhoc=1
15 adhoc_if="$vif"
16 ;;
17 sta)
18 sta=1
19 sta_if="$vif"
20 ;;
21 ap)
22 apmode=1
23 ap_if="${ap_if:+$ap_if }$vif"
24 ;;
25 wds)
26 config_get addr "$vif" bssid
27 [ -z "$addr" ] || append wds "$addr"
28 ;;
29 *) echo "$device($vif): Invalid mode";;
30 esac
31 done
32 config_set "$device" wds "$wds"
33
34 local _c=
35 for vif in ${adhoc_if:-$sta_if $ap_if}; do
36 config_set "$vif" ifname "wl0${_c:+.$_c}"
37 _c=$((${_c:-0} + 1))
38 done
39 config_set "$device" vifs "${adhoc_if:-$sta_if $ap_if}"
40
41 ifdown="down"
42 for vif in 0 1 2 3; do
43 append ifdown "vif $vif" "$N"
44 append ifdown "enabled 0" "$N"
45 done
46
47 ap=1
48 infra=1
49 mssid=1
50 apsta=0
51 radio=1
52 case "$adhoc:$sta:$apmode" in
53 1*)
54 ap=0
55 mssid=0
56 infra=0
57 ;;
58 :1:1)
59 apsta=1
60 wet=1
61 ;;
62 :1:)
63 wet=1
64 ap=0
65 mssid=0
66 ;;
67 ::)
68 radio=0
69 ;;
70 esac
71 }
72
73 disable_broadcom() {
74 wlc down
75 (
76 include /lib/network
77
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 && {
81 unbridge "$dev"
82 }
83 done
84 )
85 true
86 }
87
88 enable_broadcom() {
89 local _c
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
96
97 _c=0
98 nas="$(which nas)"
99 nas_cmd=
100 if_up=
101 for vif in $vifs; do
102 config_get mode "$vif" mode
103 append vif_pre_up "vif $_c" "$N"
104 append vif_post_up "vif $_c" "$N"
105
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"
111 }
112
113 wsec_r=0
114 eap_r=0
115 wsec=0
116 auth=0
117 nasopts=
118 config_get enc "$vif" encryption
119 case "$enc" in
120 WEP|wep)
121 wsec_r=0
122 wsec=1
123 defkey=1
124 config_get key "$vif" key
125 case "$key" in
126 [1234])
127 defkey="$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"
133 done
134 ;;
135 "");;
136 *) append vif_pre_up "wepkey 1,$key" "$N";;
137 esac
138 ;;
139 *psk*|*PSK*)
140 wsec_r=1
141 config_get key "$vif" key
142 case "$enc" in
143 wpa2*|WPA2*|PSK2*|psk2*) auth=128; wsec=4;;
144 *) auth=4; crypto=2;;
145 esac
146 eval "${vif}_key=\"\$key\""
147 nasopts="-k \"\$${vif}_key\""
148 ;;
149 *wpa*|*WPA*)
150 wsec_r=1
151 eap_r=1
152 config_get key "$vif" key
153 config_get server "$vif" server
154 config_get port "$vif" port
155 case "$enc" in
156 wpa2*|WPA2*) auth=64; wsec=4;;
157 *) auth=2; crypto=2;;
158 esac
159 eval "${vif}_key=\"\$key\""
160 nasopts="-r \"\$${vif}_key\" -h $server -p $port"
161 ;;
162 esac
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"
167
168 config_get ssid "$vif" ssid
169 append vif_post_up "vlan_mode 0"
170 append vif_post_up "ssid $ssid" "$N"
171 case "$mode" in
172 sta|adhoc) append vif_do_up "ssid $ssid" "$N";;
173 esac
174
175 append vif_post_up "enabled 1" "$N"
176
177 config_get ifname "$vif" ifname
178 append if_up "ifconfig $ifname up" ";$N"
179 local net_cfg bridge
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"
184 }
185 [ -z "$nasopts" ] || {
186 eval "${vif}_ssid=\"\$ssid\""
187 mode="-A"
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 &"
190 }
191 _c=$(($_c + 1))
192 done
193 killall -KILL nas >&- 2>&-
194 wlc stdin <<EOF
195 $ifdown
196
197 ap $ap
198 mssid $mssid
199 apsta $apsta
200 infra $infra
201 ${wet:+wet 1}
202
203 radio ${radio:-1}
204 macfilter 0
205 maclist none
206 wds ${wds:-none}
207 channel ${channel:-0}
208 country ${country:-IL0}
209 maxassoc ${maxassoc:-128}
210
211 $vif_pre_up
212 up
213 $vif_post_up
214 EOF
215 eval "$if_up"
216 wlc stdin <<EOF
217 $vif_do_up
218 EOF
219 eval "$nas_cmd"
220 }
221
222
223 detect_broadcom() {
224 [ -f /proc/net/wl0 ] || return
225 config_get type wl0 type
226 [ "$type" = broadcom ] && return
227 cat <<EOF
228 config wifi-device wl0
229 option type broadcom
230 option channel 5
231
232 config wifi-iface
233 option device wl0
234 option mode ap
235 option ssid OpenWrt
236 option hidden 0
237 option encryption none
238
239 EOF
240 }