broadcom.sh 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  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=0
  51. infra=0
  52. ;;
  53. :1:1)
  54. apsta=1
  55. wet=1
  56. ;;
  57. :1:)
  58. wet=1
  59. ap=0
  60. mssid=0
  61. ;;
  62. ::)
  63. radio=0
  64. ;;
  65. esac
  66. }
  67. disable_broadcom() {
  68. wlc down
  69. (
  70. include /lib/network
  71. # make sure the interfaces are down and removed from all bridges
  72. for dev in wl0 wl0.1 wl0.2 wl0.3; do
  73. ifconfig "$dev" down 2>/dev/null >/dev/null && {
  74. unbridge "$dev"
  75. }
  76. done
  77. )
  78. true
  79. }
  80. enable_broadcom() {
  81. local _c
  82. config_get channel "$device" channel
  83. config_get country "$device" country
  84. config_get maxassoc "$device" maxassoc
  85. config_get wds "$device" wds
  86. config_get vifs "$device" vifs
  87. local vif_pre_up vif_post_up vif_do_up
  88. _c=0
  89. nas="$(which nas)"
  90. nas_cmd=
  91. if_up=
  92. for vif in $vifs; do
  93. append vif_pre_up "vif $_c" "$N"
  94. append vif_post_up "vif $_c" "$N"
  95. [ "$vif" = "$sta_if" ] || {
  96. config_get_bool hidden "$vif" hidden 1
  97. append vif_pre_up "closed $hidden" "$N"
  98. config_get_bool isolate "$vif" isolate
  99. append vif_pre_up "ap_isolate $hidden" "$N"
  100. }
  101. wsec_r=0
  102. eap_r=0
  103. wsec=0
  104. auth=0
  105. nasopts=
  106. config_get enc "$vif" encryption
  107. case "$enc" in
  108. WEP|wep)
  109. wsec_r=0
  110. wsec=1
  111. defkey=1
  112. config_get key "$vif" key
  113. case "$key" in
  114. [1234])
  115. defkey="$key"
  116. for knr in 1 2 3 4; do
  117. config_get k "$vif" key$knr
  118. [ -n "$k" ] || continue
  119. [ "$defkey" = "$knr" ] && def="=" || def=""
  120. append vif_pre_up "wepkey $def$knr,$k" "$N"
  121. done
  122. ;;
  123. "");;
  124. *) append vif_pre_up "wepkey 1,$key" "$N";;
  125. esac
  126. ;;
  127. *psk*|*PSK*)
  128. wsec_r=1
  129. config_get key "$vif" key
  130. case "$enc" in
  131. wpa2*|WPA2*|PSK2*|psk2*) auth=128; wsec=4;;
  132. *) auth=4; crypto=2;;
  133. esac
  134. eval "${vif}_key=\"\$key\""
  135. nasopts="-k \"\$${vif}_key\""
  136. ;;
  137. *wpa*|*WPA*)
  138. wsec_r=1
  139. eap_r=1
  140. config_get key "$vif" key
  141. config_get server "$vif" server
  142. config_get port "$vif" port
  143. case "$enc" in
  144. wpa2*|WPA2*) auth=64; wsec=4;;
  145. *) auth=2; crypto=2;;
  146. esac
  147. eval "${vif}_key=\"\$key\""
  148. nasopts="-r \"\$${vif}_key\" -h $server -p $port"
  149. ;;
  150. esac
  151. append vif_post_up "wsec $wsec" "$N"
  152. append vif_post_up "wpa_auth $auth" "$N"
  153. append vif_post_up "wsec_restrict $wsec_r" "$N"
  154. append vif_post_up "eap_restrict $eap_r" "$N"
  155. config_get ssid "$vif" ssid
  156. append vif_post_up "vlan_mode 0"
  157. append vif_post_up "ssid $ssid" "$N"
  158. [ "$vif" = "$sta_if" -o "$vif" = "$adhoc_if" ] && \
  159. append vif_do_up "ssid $ssid" "$N"
  160. append vif_post_up "enabled 1" "$N"
  161. config_get ifname "$vif" ifname
  162. append if_up "ifconfig $ifname up" ";$N"
  163. net_cfg="$(find_net_config "$vif")"
  164. [ -z "$net_cfg" ] || {
  165. bridge="$(bridge_interface "$net_cfg")"
  166. append if_up "start_net '$ifname' '$net_cfg'" ";$N"
  167. }
  168. [ -z "$nasopts" ] || {
  169. eval "${vif}_ssid=\"\$ssid\""
  170. mode="-A"
  171. [ "$vif" = "$sta_if" ] && mode="-S"
  172. [ -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 &"
  173. }
  174. _c=$(($_c + 1))
  175. done
  176. killall -KILL nas >&- 2>&-
  177. wlc stdin <<EOF
  178. $ifdown
  179. ap $ap
  180. mssid $mssid
  181. apsta $apsta
  182. infra $infra
  183. ${wet:+wet 1}
  184. radio ${radio:-1}
  185. macfilter 0
  186. maclist none
  187. wds ${wds:-none}
  188. channel ${channel:-0}
  189. country ${country:-IL0}
  190. maxassoc ${maxassoc:-128}
  191. $vif_pre_up
  192. up
  193. $vif_post_up
  194. EOF
  195. eval "$if_up"
  196. wlc stdin <<EOF
  197. $vif_do_up
  198. EOF
  199. eval "$nas_cmd"
  200. }
  201. detect_broadcom() {
  202. [ -f /proc/net/wl0 ] || return
  203. config_get type wl0 type
  204. [ "$type" = broadcom ] && return
  205. cat <<EOF
  206. config wifi-device wl0
  207. option type broadcom
  208. option channel 5
  209. config wifi-iface
  210. option device wl0
  211. option mode ap
  212. option ssid OpenWrt
  213. option hidden 0
  214. option encryption none
  215. EOF
  216. }