broadcom.sh 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. append DRIVERS "broadcom"
  2. scan_broadcom() {
  3. local device="$1"
  4. local wds
  5. local adhoc sta apmode
  6. local adhoc_if sta_if ap_if
  7. config_get vifs "$device" vifs
  8. for vif in $vifs; do
  9. config_get mode "$vif" mode
  10. case "$mode" in
  11. adhoc)
  12. adhoc=1
  13. adhoc_if="$vif"
  14. ;;
  15. sta)
  16. sta=1
  17. sta_if="$vif"
  18. ;;
  19. ap)
  20. apmode=1
  21. ap_if="${ap_if:+$ap_if }$vif"
  22. ;;
  23. wds)
  24. config_get addr "$vif" bssid
  25. [ -z "$addr" ] || append wds "$addr"
  26. ;;
  27. *) echo "$device($vif): Invalid mode";;
  28. esac
  29. done
  30. config_set "$device" wds "$wds"
  31. local _c=
  32. for vif in ${adhoc_if:-$sta_if $ap_if}; do
  33. config_set "$vif" ifname "wl0${_c:+.$_c}"
  34. _c=$((${_c:-0} + 1))
  35. done
  36. config_set "$device" vifs "${adhoc_if:-$sta_if $ap_if}"
  37. ifdown="down"
  38. for vif in 0 1 2 3; do
  39. append ifdown "vif $vif" "$N"
  40. append ifdown "enabled 0" "$N"
  41. done
  42. ap=1
  43. infra=1
  44. mssid=1
  45. apsta=0
  46. radio=1
  47. case "$adhoc:$sta:$apmode" in
  48. 1*)
  49. ap=0
  50. mssid=
  51. infra=0
  52. ;;
  53. :1:1)
  54. apsta=1
  55. wet=1
  56. ;;
  57. :1:)
  58. wet=1
  59. ap=0
  60. mssid=
  61. ;;
  62. ::)
  63. radio=0
  64. ;;
  65. esac
  66. }
  67. disable_broadcom() {
  68. set_wifi_down "$1"
  69. wlc down
  70. (
  71. include /lib/network
  72. # make sure the interfaces are down and removed from all bridges
  73. for dev in wl0 wl0.1 wl0.2 wl0.3; do
  74. ifconfig "$dev" down 2>/dev/null >/dev/null && {
  75. unbridge "$dev"
  76. }
  77. done
  78. )
  79. true
  80. }
  81. enable_broadcom() {
  82. local _c
  83. config_get channel "$device" channel
  84. config_get country "$device" country
  85. config_get maxassoc "$device" maxassoc
  86. config_get wds "$device" wds
  87. config_get vifs "$device" vifs
  88. config_get distance "$device" distance
  89. config_get slottime "$device" slottime
  90. config_get rxant "$device" rxant
  91. config_get txant "$device" txant
  92. config_get_bool frameburst "$device" frameburst
  93. config_get macfilter "$device" macfilter
  94. config_get maclist "$device" maclist
  95. local vif_pre_up vif_post_up vif_do_up
  96. _c=0
  97. nas="$(which nas)"
  98. nas_cmd=
  99. if_up=
  100. [ -z "$slottime" ] && {
  101. [ -n "$distance" ] && {
  102. # slottime = 9 + (distance / 150) + (distance % 150 ? 1 : 0)
  103. slottime="$((9 + ($distance / 150) + 1 - (150 - ($distance % 150)) / 150 ))"
  104. }
  105. } || {
  106. slottime="${slottime:--1}"
  107. }
  108. case "$macfilter" in
  109. allow|2)
  110. macfilter=2;
  111. ;;
  112. deny|1)
  113. macfilter=1;
  114. ;;
  115. disable|none|0)
  116. macfilter=0;
  117. ;;
  118. esac
  119. for vif in $vifs; do
  120. config_get mode "$vif" mode
  121. append vif_pre_up "vif $_c" "$N"
  122. append vif_post_up "vif $_c" "$N"
  123. [ "$mode" = "sta" ] || {
  124. config_get_bool hidden "$vif" hidden 0
  125. append vif_pre_up "closed $hidden" "$N"
  126. config_get_bool isolate "$vif" isolate 0
  127. append vif_pre_up "ap_isolate $isolate" "$N"
  128. }
  129. wsec_r=0
  130. eap_r=0
  131. wsec=0
  132. auth=0
  133. nasopts=
  134. config_get enc "$vif" encryption
  135. case "$enc" in
  136. WEP|wep)
  137. wsec_r=1
  138. wsec=1
  139. defkey=1
  140. config_get key "$vif" key
  141. case "$key" in
  142. [1234])
  143. defkey="$key"
  144. for knr in 1 2 3 4; do
  145. config_get k "$vif" key$knr
  146. [ -n "$k" ] || continue
  147. [ "$defkey" = "$knr" ] && def="=" || def=""
  148. append vif_do_up "wepkey $def$knr,$k" "$N"
  149. done
  150. ;;
  151. "");;
  152. *) append vif_do_up "wepkey =1,$key" "$N";;
  153. esac
  154. ;;
  155. *psk*|*PSK*)
  156. wsec_r=1
  157. config_get key "$vif" key
  158. case "$enc" in
  159. wpa*+wpa2*|WPA*+WPA2*|*psk+*psk2|*PSK+*PSK2) auth=132; wsec=6;;
  160. wpa2*|WPA2*|*PSK2|*psk2) auth=128; wsec=4;;
  161. *) auth=4; wsec=2;;
  162. esac
  163. eval "${vif}_key=\"\$key\""
  164. nasopts="-k \"\$${vif}_key\""
  165. ;;
  166. *wpa*|*WPA*)
  167. wsec_r=1
  168. eap_r=1
  169. config_get key "$vif" key
  170. config_get server "$vif" server
  171. config_get port "$vif" port
  172. case "$enc" in
  173. wpa*+wpa2*|WPA*+WPA2*) auth=66; wsec=6;;
  174. wpa2*|WPA2*) auth=64; wsec=4;;
  175. *) auth=2; wsec=2;;
  176. esac
  177. eval "${vif}_key=\"\$key\""
  178. nasopts="-r \"\$${vif}_key\" -h $server -p $port"
  179. ;;
  180. esac
  181. append vif_do_up "wsec $wsec" "$N"
  182. append vif_do_up "wpa_auth $auth" "$N"
  183. append vif_do_up "wsec_restrict $wsec_r" "$N"
  184. append vif_do_up "eap_restrict $eap_r" "$N"
  185. config_get ssid "$vif" ssid
  186. append vif_post_up "vlan_mode 0" "$N"
  187. append vif_post_up "ssid $ssid" "$N"
  188. append vif_do_up "ssid $ssid" "$N"
  189. append vif_post_up "enabled 1" "$N"
  190. config_get ifname "$vif" ifname
  191. #append if_up "ifconfig $ifname up" ";$N"
  192. local net_cfg bridge
  193. net_cfg="$(find_net_config "$vif")"
  194. [ -z "$net_cfg" ] || {
  195. bridge="$(bridge_interface "$net_cfg")"
  196. append if_up "start_net '$ifname' '$net_cfg'" ";$N"
  197. append if_up "set_wifi_up '$vif' '$ifname'" ";$N"
  198. }
  199. [ -z "$nasopts" ] || {
  200. eval "${vif}_ssid=\"\$ssid\""
  201. nas_mode="-A"
  202. use_nas=1
  203. [ "$mode" = "sta" ] && {
  204. nas_mode="-S"
  205. [ -z "$bridge" ] || {
  206. append vif_post_up "supplicant 1" "$N"
  207. append vif_post_up "passphrase $key" "$N"
  208. use_nas=0
  209. }
  210. }
  211. [ -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 &"
  212. }
  213. _c=$(($_c + 1))
  214. done
  215. killall -KILL nas >&- 2>&-
  216. wlc stdin <<EOF
  217. $ifdown
  218. ap $ap
  219. ${mssid:+mssid $mssid}
  220. apsta $apsta
  221. infra $infra
  222. ${wet:+wet 1}
  223. 802.11d 0
  224. 802.11h 0
  225. rxant ${rxant:-3}
  226. txant ${txant:-3}
  227. radio ${radio:-1}
  228. macfilter ${macfilter:-0}
  229. maclist ${maclist:-none}
  230. wds none
  231. ${wds:+wds $wds}
  232. country ${country:-IL0}
  233. ${channel:+channel $channel}
  234. maxassoc ${maxassoc:-128}
  235. slottime ${slottime:--1}
  236. ${frameburst:+frameburst $frameburst}
  237. $vif_pre_up
  238. up
  239. $vif_post_up
  240. EOF
  241. eval "$if_up"
  242. wlc stdin <<EOF
  243. $vif_do_up
  244. EOF
  245. eval "$nas_cmd"
  246. }
  247. detect_broadcom() {
  248. [ -f /proc/net/wl0 ] || return
  249. config_get type wl0 type
  250. [ "$type" = broadcom ] && return
  251. cat <<EOF
  252. config wifi-device wl0
  253. option type broadcom
  254. option channel 5
  255. # REMOVE THIS LINE TO ENABLE WIFI:
  256. option disabled 1
  257. config wifi-iface
  258. option device wl0
  259. option network lan
  260. option mode ap
  261. option ssid OpenWrt
  262. option encryption none
  263. EOF
  264. }