ibss.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Some IBSS support code for cfg80211.
  4. *
  5. * Copyright 2009 Johannes Berg <johannes@sipsolutions.net>
  6. */
  7. #include <linux/etherdevice.h>
  8. #include <linux/if_arp.h>
  9. #include <linux/slab.h>
  10. #include <linux/export.h>
  11. #include <net/cfg80211.h>
  12. #include "wext-compat.h"
  13. #include "nl80211.h"
  14. #include "rdev-ops.h"
  15. void __cfg80211_ibss_joined(struct net_device *dev, const u8 *bssid,
  16. struct ieee80211_channel *channel)
  17. {
  18. struct wireless_dev *wdev = dev->ieee80211_ptr;
  19. struct cfg80211_bss *bss;
  20. #ifdef CONFIG_CFG80211_WEXT
  21. union iwreq_data wrqu;
  22. #endif
  23. if (WARN_ON(wdev->iftype != NL80211_IFTYPE_ADHOC))
  24. return;
  25. if (!wdev->ssid_len)
  26. return;
  27. bss = cfg80211_get_bss(wdev->wiphy, channel, bssid, NULL, 0,
  28. IEEE80211_BSS_TYPE_IBSS, IEEE80211_PRIVACY_ANY);
  29. if (WARN_ON(!bss))
  30. return;
  31. if (wdev->current_bss) {
  32. cfg80211_unhold_bss(wdev->current_bss);
  33. cfg80211_put_bss(wdev->wiphy, &wdev->current_bss->pub);
  34. }
  35. cfg80211_hold_bss(bss_from_pub(bss));
  36. wdev->current_bss = bss_from_pub(bss);
  37. if (!(wdev->wiphy->flags & WIPHY_FLAG_HAS_STATIC_WEP))
  38. cfg80211_upload_connect_keys(wdev);
  39. nl80211_send_ibss_bssid(wiphy_to_rdev(wdev->wiphy), dev, bssid,
  40. GFP_KERNEL);
  41. #ifdef CONFIG_CFG80211_WEXT
  42. memset(&wrqu, 0, sizeof(wrqu));
  43. memcpy(wrqu.ap_addr.sa_data, bssid, ETH_ALEN);
  44. wireless_send_event(dev, SIOCGIWAP, &wrqu, NULL);
  45. #endif
  46. }
  47. void cfg80211_ibss_joined(struct net_device *dev, const u8 *bssid,
  48. struct ieee80211_channel *channel, gfp_t gfp)
  49. {
  50. struct wireless_dev *wdev = dev->ieee80211_ptr;
  51. struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy);
  52. struct cfg80211_event *ev;
  53. unsigned long flags;
  54. trace_cfg80211_ibss_joined(dev, bssid, channel);
  55. if (WARN_ON(!channel))
  56. return;
  57. ev = kzalloc(sizeof(*ev), gfp);
  58. if (!ev)
  59. return;
  60. ev->type = EVENT_IBSS_JOINED;
  61. memcpy(ev->ij.bssid, bssid, ETH_ALEN);
  62. ev->ij.channel = channel;
  63. spin_lock_irqsave(&wdev->event_lock, flags);
  64. list_add_tail(&ev->list, &wdev->event_list);
  65. spin_unlock_irqrestore(&wdev->event_lock, flags);
  66. queue_work(cfg80211_wq, &rdev->event_work);
  67. }
  68. EXPORT_SYMBOL(cfg80211_ibss_joined);
  69. int __cfg80211_join_ibss(struct cfg80211_registered_device *rdev,
  70. struct net_device *dev,
  71. struct cfg80211_ibss_params *params,
  72. struct cfg80211_cached_keys *connkeys)
  73. {
  74. struct wireless_dev *wdev = dev->ieee80211_ptr;
  75. int err;
  76. ASSERT_RTNL();
  77. ASSERT_WDEV_LOCK(wdev);
  78. if (wdev->ssid_len)
  79. return -EALREADY;
  80. if (!params->basic_rates) {
  81. /*
  82. * If no rates were explicitly configured,
  83. * use the mandatory rate set for 11b or
  84. * 11a for maximum compatibility.
  85. */
  86. struct ieee80211_supported_band *sband =
  87. rdev->wiphy.bands[params->chandef.chan->band];
  88. int j;
  89. u32 flag = params->chandef.chan->band == NL80211_BAND_5GHZ ?
  90. IEEE80211_RATE_MANDATORY_A :
  91. IEEE80211_RATE_MANDATORY_B;
  92. for (j = 0; j < sband->n_bitrates; j++) {
  93. if (sband->bitrates[j].flags & flag)
  94. params->basic_rates |= BIT(j);
  95. }
  96. }
  97. if (WARN_ON(connkeys && connkeys->def < 0))
  98. return -EINVAL;
  99. if (WARN_ON(wdev->connect_keys))
  100. kzfree(wdev->connect_keys);
  101. wdev->connect_keys = connkeys;
  102. wdev->ibss_fixed = params->channel_fixed;
  103. wdev->ibss_dfs_possible = params->userspace_handles_dfs;
  104. wdev->chandef = params->chandef;
  105. if (connkeys) {
  106. params->wep_keys = connkeys->params;
  107. params->wep_tx_key = connkeys->def;
  108. }
  109. #ifdef CONFIG_CFG80211_WEXT
  110. wdev->wext.ibss.chandef = params->chandef;
  111. #endif
  112. err = rdev_join_ibss(rdev, dev, params);
  113. if (err) {
  114. wdev->connect_keys = NULL;
  115. return err;
  116. }
  117. memcpy(wdev->ssid, params->ssid, params->ssid_len);
  118. wdev->ssid_len = params->ssid_len;
  119. return 0;
  120. }
  121. static void __cfg80211_clear_ibss(struct net_device *dev, bool nowext)
  122. {
  123. struct wireless_dev *wdev = dev->ieee80211_ptr;
  124. struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy);
  125. int i;
  126. ASSERT_WDEV_LOCK(wdev);
  127. kzfree(wdev->connect_keys);
  128. wdev->connect_keys = NULL;
  129. rdev_set_qos_map(rdev, dev, NULL);
  130. /*
  131. * Delete all the keys ... pairwise keys can't really
  132. * exist any more anyway, but default keys might.
  133. */
  134. if (rdev->ops->del_key)
  135. for (i = 0; i < 6; i++)
  136. rdev_del_key(rdev, dev, i, false, NULL);
  137. if (wdev->current_bss) {
  138. cfg80211_unhold_bss(wdev->current_bss);
  139. cfg80211_put_bss(wdev->wiphy, &wdev->current_bss->pub);
  140. }
  141. wdev->current_bss = NULL;
  142. wdev->ssid_len = 0;
  143. memset(&wdev->chandef, 0, sizeof(wdev->chandef));
  144. #ifdef CONFIG_CFG80211_WEXT
  145. if (!nowext)
  146. wdev->wext.ibss.ssid_len = 0;
  147. #endif
  148. cfg80211_sched_dfs_chan_update(rdev);
  149. }
  150. void cfg80211_clear_ibss(struct net_device *dev, bool nowext)
  151. {
  152. struct wireless_dev *wdev = dev->ieee80211_ptr;
  153. wdev_lock(wdev);
  154. __cfg80211_clear_ibss(dev, nowext);
  155. wdev_unlock(wdev);
  156. }
  157. int __cfg80211_leave_ibss(struct cfg80211_registered_device *rdev,
  158. struct net_device *dev, bool nowext)
  159. {
  160. struct wireless_dev *wdev = dev->ieee80211_ptr;
  161. int err;
  162. ASSERT_WDEV_LOCK(wdev);
  163. if (!wdev->ssid_len)
  164. return -ENOLINK;
  165. err = rdev_leave_ibss(rdev, dev);
  166. if (err)
  167. return err;
  168. wdev->conn_owner_nlportid = 0;
  169. __cfg80211_clear_ibss(dev, nowext);
  170. return 0;
  171. }
  172. int cfg80211_leave_ibss(struct cfg80211_registered_device *rdev,
  173. struct net_device *dev, bool nowext)
  174. {
  175. struct wireless_dev *wdev = dev->ieee80211_ptr;
  176. int err;
  177. wdev_lock(wdev);
  178. err = __cfg80211_leave_ibss(rdev, dev, nowext);
  179. wdev_unlock(wdev);
  180. return err;
  181. }
  182. #ifdef CONFIG_CFG80211_WEXT
  183. int cfg80211_ibss_wext_join(struct cfg80211_registered_device *rdev,
  184. struct wireless_dev *wdev)
  185. {
  186. struct cfg80211_cached_keys *ck = NULL;
  187. enum nl80211_band band;
  188. int i, err;
  189. ASSERT_WDEV_LOCK(wdev);
  190. if (!wdev->wext.ibss.beacon_interval)
  191. wdev->wext.ibss.beacon_interval = 100;
  192. /* try to find an IBSS channel if none requested ... */
  193. if (!wdev->wext.ibss.chandef.chan) {
  194. struct ieee80211_channel *new_chan = NULL;
  195. for (band = 0; band < NUM_NL80211_BANDS; band++) {
  196. struct ieee80211_supported_band *sband;
  197. struct ieee80211_channel *chan;
  198. sband = rdev->wiphy.bands[band];
  199. if (!sband)
  200. continue;
  201. for (i = 0; i < sband->n_channels; i++) {
  202. chan = &sband->channels[i];
  203. if (chan->flags & IEEE80211_CHAN_NO_IR)
  204. continue;
  205. if (chan->flags & IEEE80211_CHAN_DISABLED)
  206. continue;
  207. new_chan = chan;
  208. break;
  209. }
  210. if (new_chan)
  211. break;
  212. }
  213. if (!new_chan)
  214. return -EINVAL;
  215. cfg80211_chandef_create(&wdev->wext.ibss.chandef, new_chan,
  216. NL80211_CHAN_NO_HT);
  217. }
  218. /* don't join -- SSID is not there */
  219. if (!wdev->wext.ibss.ssid_len)
  220. return 0;
  221. if (!netif_running(wdev->netdev))
  222. return 0;
  223. if (wdev->wext.keys)
  224. wdev->wext.keys->def = wdev->wext.default_key;
  225. wdev->wext.ibss.privacy = wdev->wext.default_key != -1;
  226. if (wdev->wext.keys && wdev->wext.keys->def != -1) {
  227. ck = kmemdup(wdev->wext.keys, sizeof(*ck), GFP_KERNEL);
  228. if (!ck)
  229. return -ENOMEM;
  230. for (i = 0; i < CFG80211_MAX_WEP_KEYS; i++)
  231. ck->params[i].key = ck->data[i];
  232. }
  233. err = __cfg80211_join_ibss(rdev, wdev->netdev,
  234. &wdev->wext.ibss, ck);
  235. if (err)
  236. kfree(ck);
  237. return err;
  238. }
  239. int cfg80211_ibss_wext_siwfreq(struct net_device *dev,
  240. struct iw_request_info *info,
  241. struct iw_freq *wextfreq, char *extra)
  242. {
  243. struct wireless_dev *wdev = dev->ieee80211_ptr;
  244. struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy);
  245. struct ieee80211_channel *chan = NULL;
  246. int err, freq;
  247. /* call only for ibss! */
  248. if (WARN_ON(wdev->iftype != NL80211_IFTYPE_ADHOC))
  249. return -EINVAL;
  250. if (!rdev->ops->join_ibss)
  251. return -EOPNOTSUPP;
  252. freq = cfg80211_wext_freq(wextfreq);
  253. if (freq < 0)
  254. return freq;
  255. if (freq) {
  256. chan = ieee80211_get_channel(wdev->wiphy, freq);
  257. if (!chan)
  258. return -EINVAL;
  259. if (chan->flags & IEEE80211_CHAN_NO_IR ||
  260. chan->flags & IEEE80211_CHAN_DISABLED)
  261. return -EINVAL;
  262. }
  263. if (wdev->wext.ibss.chandef.chan == chan)
  264. return 0;
  265. wdev_lock(wdev);
  266. err = 0;
  267. if (wdev->ssid_len)
  268. err = __cfg80211_leave_ibss(rdev, dev, true);
  269. wdev_unlock(wdev);
  270. if (err)
  271. return err;
  272. if (chan) {
  273. cfg80211_chandef_create(&wdev->wext.ibss.chandef, chan,
  274. NL80211_CHAN_NO_HT);
  275. wdev->wext.ibss.channel_fixed = true;
  276. } else {
  277. /* cfg80211_ibss_wext_join will pick one if needed */
  278. wdev->wext.ibss.channel_fixed = false;
  279. }
  280. wdev_lock(wdev);
  281. err = cfg80211_ibss_wext_join(rdev, wdev);
  282. wdev_unlock(wdev);
  283. return err;
  284. }
  285. int cfg80211_ibss_wext_giwfreq(struct net_device *dev,
  286. struct iw_request_info *info,
  287. struct iw_freq *freq, char *extra)
  288. {
  289. struct wireless_dev *wdev = dev->ieee80211_ptr;
  290. struct ieee80211_channel *chan = NULL;
  291. /* call only for ibss! */
  292. if (WARN_ON(wdev->iftype != NL80211_IFTYPE_ADHOC))
  293. return -EINVAL;
  294. wdev_lock(wdev);
  295. if (wdev->current_bss)
  296. chan = wdev->current_bss->pub.channel;
  297. else if (wdev->wext.ibss.chandef.chan)
  298. chan = wdev->wext.ibss.chandef.chan;
  299. wdev_unlock(wdev);
  300. if (chan) {
  301. freq->m = chan->center_freq;
  302. freq->e = 6;
  303. return 0;
  304. }
  305. /* no channel if not joining */
  306. return -EINVAL;
  307. }
  308. int cfg80211_ibss_wext_siwessid(struct net_device *dev,
  309. struct iw_request_info *info,
  310. struct iw_point *data, char *ssid)
  311. {
  312. struct wireless_dev *wdev = dev->ieee80211_ptr;
  313. struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy);
  314. size_t len = data->length;
  315. int err;
  316. /* call only for ibss! */
  317. if (WARN_ON(wdev->iftype != NL80211_IFTYPE_ADHOC))
  318. return -EINVAL;
  319. if (!rdev->ops->join_ibss)
  320. return -EOPNOTSUPP;
  321. wdev_lock(wdev);
  322. err = 0;
  323. if (wdev->ssid_len)
  324. err = __cfg80211_leave_ibss(rdev, dev, true);
  325. wdev_unlock(wdev);
  326. if (err)
  327. return err;
  328. /* iwconfig uses nul termination in SSID.. */
  329. if (len > 0 && ssid[len - 1] == '\0')
  330. len--;
  331. memcpy(wdev->ssid, ssid, len);
  332. wdev->wext.ibss.ssid = wdev->ssid;
  333. wdev->wext.ibss.ssid_len = len;
  334. wdev_lock(wdev);
  335. err = cfg80211_ibss_wext_join(rdev, wdev);
  336. wdev_unlock(wdev);
  337. return err;
  338. }
  339. int cfg80211_ibss_wext_giwessid(struct net_device *dev,
  340. struct iw_request_info *info,
  341. struct iw_point *data, char *ssid)
  342. {
  343. struct wireless_dev *wdev = dev->ieee80211_ptr;
  344. /* call only for ibss! */
  345. if (WARN_ON(wdev->iftype != NL80211_IFTYPE_ADHOC))
  346. return -EINVAL;
  347. data->flags = 0;
  348. wdev_lock(wdev);
  349. if (wdev->ssid_len) {
  350. data->flags = 1;
  351. data->length = wdev->ssid_len;
  352. memcpy(ssid, wdev->ssid, data->length);
  353. } else if (wdev->wext.ibss.ssid && wdev->wext.ibss.ssid_len) {
  354. data->flags = 1;
  355. data->length = wdev->wext.ibss.ssid_len;
  356. memcpy(ssid, wdev->wext.ibss.ssid, data->length);
  357. }
  358. wdev_unlock(wdev);
  359. return 0;
  360. }
  361. int cfg80211_ibss_wext_siwap(struct net_device *dev,
  362. struct iw_request_info *info,
  363. struct sockaddr *ap_addr, char *extra)
  364. {
  365. struct wireless_dev *wdev = dev->ieee80211_ptr;
  366. struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy);
  367. u8 *bssid = ap_addr->sa_data;
  368. int err;
  369. /* call only for ibss! */
  370. if (WARN_ON(wdev->iftype != NL80211_IFTYPE_ADHOC))
  371. return -EINVAL;
  372. if (!rdev->ops->join_ibss)
  373. return -EOPNOTSUPP;
  374. if (ap_addr->sa_family != ARPHRD_ETHER)
  375. return -EINVAL;
  376. /* automatic mode */
  377. if (is_zero_ether_addr(bssid) || is_broadcast_ether_addr(bssid))
  378. bssid = NULL;
  379. if (bssid && !is_valid_ether_addr(bssid))
  380. return -EINVAL;
  381. /* both automatic */
  382. if (!bssid && !wdev->wext.ibss.bssid)
  383. return 0;
  384. /* fixed already - and no change */
  385. if (wdev->wext.ibss.bssid && bssid &&
  386. ether_addr_equal(bssid, wdev->wext.ibss.bssid))
  387. return 0;
  388. wdev_lock(wdev);
  389. err = 0;
  390. if (wdev->ssid_len)
  391. err = __cfg80211_leave_ibss(rdev, dev, true);
  392. wdev_unlock(wdev);
  393. if (err)
  394. return err;
  395. if (bssid) {
  396. memcpy(wdev->wext.bssid, bssid, ETH_ALEN);
  397. wdev->wext.ibss.bssid = wdev->wext.bssid;
  398. } else
  399. wdev->wext.ibss.bssid = NULL;
  400. wdev_lock(wdev);
  401. err = cfg80211_ibss_wext_join(rdev, wdev);
  402. wdev_unlock(wdev);
  403. return err;
  404. }
  405. int cfg80211_ibss_wext_giwap(struct net_device *dev,
  406. struct iw_request_info *info,
  407. struct sockaddr *ap_addr, char *extra)
  408. {
  409. struct wireless_dev *wdev = dev->ieee80211_ptr;
  410. /* call only for ibss! */
  411. if (WARN_ON(wdev->iftype != NL80211_IFTYPE_ADHOC))
  412. return -EINVAL;
  413. ap_addr->sa_family = ARPHRD_ETHER;
  414. wdev_lock(wdev);
  415. if (wdev->current_bss)
  416. memcpy(ap_addr->sa_data, wdev->current_bss->pub.bssid, ETH_ALEN);
  417. else if (wdev->wext.ibss.bssid)
  418. memcpy(ap_addr->sa_data, wdev->wext.ibss.bssid, ETH_ALEN);
  419. else
  420. eth_zero_addr(ap_addr->sa_data);
  421. wdev_unlock(wdev);
  422. return 0;
  423. }
  424. #endif