Lines Matching refs:wdev

28 	struct wireless_dev *wdev = dev->ieee80211_ptr;  in cfg80211_rx_assoc_resp()  local
29 struct wiphy *wiphy = wdev->wiphy; in cfg80211_rx_assoc_resp()
61 if (cfg80211_sme_rx_assoc_resp(wdev, cr.status)) { in cfg80211_rx_assoc_resp()
74 static void cfg80211_process_auth(struct wireless_dev *wdev, in cfg80211_process_auth() argument
77 struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy); in cfg80211_process_auth()
79 nl80211_send_rx_auth(rdev, wdev->netdev, buf, len, GFP_KERNEL); in cfg80211_process_auth()
80 cfg80211_sme_rx_auth(wdev, buf, len); in cfg80211_process_auth()
83 static void cfg80211_process_deauth(struct wireless_dev *wdev, in cfg80211_process_deauth() argument
87 struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy); in cfg80211_process_deauth()
91 bool from_ap = !ether_addr_equal(mgmt->sa, wdev->netdev->dev_addr); in cfg80211_process_deauth()
93 nl80211_send_deauth(rdev, wdev->netdev, buf, len, reconnect, GFP_KERNEL); in cfg80211_process_deauth()
95 if (!wdev->current_bss || in cfg80211_process_deauth()
96 !ether_addr_equal(wdev->current_bss->pub.bssid, bssid)) in cfg80211_process_deauth()
99 __cfg80211_disconnected(wdev->netdev, NULL, 0, reason_code, from_ap); in cfg80211_process_deauth()
100 cfg80211_sme_deauth(wdev); in cfg80211_process_deauth()
103 static void cfg80211_process_disassoc(struct wireless_dev *wdev, in cfg80211_process_disassoc() argument
107 struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy); in cfg80211_process_disassoc()
111 bool from_ap = !ether_addr_equal(mgmt->sa, wdev->netdev->dev_addr); in cfg80211_process_disassoc()
113 nl80211_send_disassoc(rdev, wdev->netdev, buf, len, reconnect, in cfg80211_process_disassoc()
116 if (WARN_ON(!wdev->current_bss || in cfg80211_process_disassoc()
117 !ether_addr_equal(wdev->current_bss->pub.bssid, bssid))) in cfg80211_process_disassoc()
120 __cfg80211_disconnected(wdev->netdev, NULL, 0, reason_code, from_ap); in cfg80211_process_disassoc()
121 cfg80211_sme_disassoc(wdev); in cfg80211_process_disassoc()
126 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_rx_mlme_mgmt() local
129 ASSERT_WDEV_LOCK(wdev); in cfg80211_rx_mlme_mgmt()
137 cfg80211_process_auth(wdev, buf, len); in cfg80211_rx_mlme_mgmt()
139 cfg80211_process_deauth(wdev, buf, len, false); in cfg80211_rx_mlme_mgmt()
141 cfg80211_process_disassoc(wdev, buf, len, false); in cfg80211_rx_mlme_mgmt()
147 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_auth_timeout() local
148 struct wiphy *wiphy = wdev->wiphy; in cfg80211_auth_timeout()
154 cfg80211_sme_auth_timeout(wdev); in cfg80211_auth_timeout()
160 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_assoc_timeout() local
161 struct wiphy *wiphy = wdev->wiphy; in cfg80211_assoc_timeout()
167 cfg80211_sme_assoc_timeout(wdev); in cfg80211_assoc_timeout()
176 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_abandon_assoc() local
177 struct wiphy *wiphy = wdev->wiphy; in cfg80211_abandon_assoc()
179 cfg80211_sme_abandon_assoc(wdev); in cfg80211_abandon_assoc()
189 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_tx_mlme_mgmt() local
192 ASSERT_WDEV_LOCK(wdev); in cfg80211_tx_mlme_mgmt()
200 cfg80211_process_deauth(wdev, buf, len, reconnect); in cfg80211_tx_mlme_mgmt()
202 cfg80211_process_disassoc(wdev, buf, len, reconnect); in cfg80211_tx_mlme_mgmt()
244 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_mlme_auth() local
257 ASSERT_WDEV_LOCK(wdev); in cfg80211_mlme_auth()
263 if (wdev->current_bss && in cfg80211_mlme_auth()
264 ether_addr_equal(bssid, wdev->current_bss->pub.bssid)) in cfg80211_mlme_auth()
320 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_mlme_assoc() local
323 ASSERT_WDEV_LOCK(wdev); in cfg80211_mlme_assoc()
325 if (wdev->current_bss && in cfg80211_mlme_assoc()
326 (!req->prev_bssid || !ether_addr_equal(wdev->current_bss->pub.bssid, in cfg80211_mlme_assoc()
355 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_mlme_deauth() local
364 ASSERT_WDEV_LOCK(wdev); in cfg80211_mlme_deauth()
367 (!wdev->current_bss || in cfg80211_mlme_deauth()
368 !ether_addr_equal(wdev->current_bss->pub.bssid, bssid))) in cfg80211_mlme_deauth()
371 if (ether_addr_equal(wdev->disconnect_bssid, bssid) || in cfg80211_mlme_deauth()
372 (wdev->current_bss && in cfg80211_mlme_deauth()
373 ether_addr_equal(wdev->current_bss->pub.bssid, bssid))) in cfg80211_mlme_deauth()
374 wdev->conn_owner_nlportid = 0; in cfg80211_mlme_deauth()
384 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_mlme_disassoc() local
393 ASSERT_WDEV_LOCK(wdev); in cfg80211_mlme_disassoc()
395 if (!wdev->current_bss) in cfg80211_mlme_disassoc()
398 if (ether_addr_equal(wdev->current_bss->pub.bssid, bssid)) in cfg80211_mlme_disassoc()
399 req.bss = &wdev->current_bss->pub; in cfg80211_mlme_disassoc()
408 WARN_ON(wdev->current_bss); in cfg80211_mlme_disassoc()
415 struct wireless_dev *wdev = dev->ieee80211_ptr; in cfg80211_mlme_down() local
418 ASSERT_WDEV_LOCK(wdev); in cfg80211_mlme_down()
423 if (!wdev->current_bss) in cfg80211_mlme_down()
426 memcpy(bssid, wdev->current_bss->pub.bssid, ETH_ALEN); in cfg80211_mlme_down()
433 struct wireless_dev *wdev; member
446 static void cfg80211_mgmt_registrations_update(struct wireless_dev *wdev) in cfg80211_mgmt_registrations_update() argument
448 struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy); in cfg80211_mgmt_registrations_update()
456 if (!wdev->mgmt_registrations_need_update) { in cfg80211_mgmt_registrations_update()
473 if (tmp == wdev) { in cfg80211_mgmt_registrations_update()
481 wdev->mgmt_registrations_need_update = 0; in cfg80211_mgmt_registrations_update()
484 rdev_update_mgmt_frame_registrations(rdev, wdev, &upd); in cfg80211_mgmt_registrations_update()
490 struct wireless_dev *wdev; in cfg80211_mgmt_registrations_update_wk() local
496 list_for_each_entry(wdev, &rdev->wiphy.wdev_list, list) in cfg80211_mgmt_registrations_update_wk()
497 cfg80211_mgmt_registrations_update(wdev); in cfg80211_mgmt_registrations_update_wk()
501 int cfg80211_mlme_register_mgmt(struct wireless_dev *wdev, u32 snd_portid, in cfg80211_mlme_register_mgmt() argument
506 struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy); in cfg80211_mlme_register_mgmt()
512 if (!wdev->wiphy->mgmt_stypes) in cfg80211_mlme_register_mgmt()
526 if (!(wdev->wiphy->mgmt_stypes[wdev->iftype].rx & BIT(mgmt_type))) { in cfg80211_mlme_register_mgmt()
540 if (wdev->iftype == NL80211_IFTYPE_STATION && in cfg80211_mlme_register_mgmt()
554 list_for_each_entry(reg, &wdev->mgmt_registrations, list) { in cfg80211_mlme_register_mgmt()
582 nreg->wdev = wdev; in cfg80211_mlme_register_mgmt()
584 list_add(&nreg->list, &wdev->mgmt_registrations); in cfg80211_mlme_register_mgmt()
586 wdev->mgmt_registrations_need_update = 1; in cfg80211_mlme_register_mgmt()
589 cfg80211_mgmt_registrations_update(wdev); in cfg80211_mlme_register_mgmt()
600 void cfg80211_mlme_unregister_socket(struct wireless_dev *wdev, u32 nlportid) in cfg80211_mlme_unregister_socket() argument
602 struct wiphy *wiphy = wdev->wiphy; in cfg80211_mlme_unregister_socket()
608 list_for_each_entry_safe(reg, tmp, &wdev->mgmt_registrations, list) { in cfg80211_mlme_unregister_socket()
615 wdev->mgmt_registrations_need_update = 1; in cfg80211_mlme_unregister_socket()
623 rdev_crit_proto_stop(rdev, wdev); in cfg80211_mlme_unregister_socket()
626 if (nlportid == wdev->ap_unexpected_nlportid) in cfg80211_mlme_unregister_socket()
627 wdev->ap_unexpected_nlportid = 0; in cfg80211_mlme_unregister_socket()
630 void cfg80211_mlme_purge_registrations(struct wireless_dev *wdev) in cfg80211_mlme_purge_registrations() argument
632 struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy); in cfg80211_mlme_purge_registrations()
636 list_for_each_entry_safe(reg, tmp, &wdev->mgmt_registrations, list) { in cfg80211_mlme_purge_registrations()
640 wdev->mgmt_registrations_need_update = 1; in cfg80211_mlme_purge_registrations()
643 cfg80211_mgmt_registrations_update(wdev); in cfg80211_mlme_purge_registrations()
647 struct wireless_dev *wdev, in cfg80211_mlme_mgmt_tx() argument
653 if (!wdev->wiphy->mgmt_stypes) in cfg80211_mlme_mgmt_tx()
668 if (!(wdev->wiphy->mgmt_stypes[wdev->iftype].tx & BIT(stype >> 4))) in cfg80211_mlme_mgmt_tx()
675 wdev_lock(wdev); in cfg80211_mlme_mgmt_tx()
677 switch (wdev->iftype) { in cfg80211_mlme_mgmt_tx()
681 if (!wdev->current_bss) { in cfg80211_mlme_mgmt_tx()
686 if (!ether_addr_equal(wdev->current_bss->pub.bssid, in cfg80211_mlme_mgmt_tx()
696 if (wdev->iftype == NL80211_IFTYPE_ADHOC) in cfg80211_mlme_mgmt_tx()
700 if (!ether_addr_equal(wdev->current_bss->pub.bssid, in cfg80211_mlme_mgmt_tx()
709 if (!ether_addr_equal(mgmt->bssid, wdev_address(wdev))) in cfg80211_mlme_mgmt_tx()
732 wdev_unlock(wdev); in cfg80211_mlme_mgmt_tx()
738 if (!ether_addr_equal(mgmt->sa, wdev_address(wdev))) { in cfg80211_mlme_mgmt_tx()
746 if (!wdev->current_bss && in cfg80211_mlme_mgmt_tx()
751 if (wdev->current_bss && in cfg80211_mlme_mgmt_tx()
759 return rdev_mgmt_tx(rdev, wdev, params, cookie); in cfg80211_mlme_mgmt_tx()
762 bool cfg80211_rx_mgmt_khz(struct wireless_dev *wdev, int freq, int sig_dbm, in cfg80211_rx_mgmt_khz() argument
765 struct wiphy *wiphy = wdev->wiphy; in cfg80211_rx_mgmt_khz()
769 &wiphy->mgmt_stypes[wdev->iftype]; in cfg80211_rx_mgmt_khz()
778 trace_cfg80211_rx_mgmt(wdev, freq, sig_dbm); in cfg80211_rx_mgmt_khz()
791 list_for_each_entry(reg, &wdev->mgmt_registrations, list) { in cfg80211_rx_mgmt_khz()
804 if (nl80211_send_mgmt(rdev, wdev, reg->nlportid, in cfg80211_rx_mgmt_khz()
935 struct wireless_dev *wdev = netdev->ieee80211_ptr; in cfg80211_cac_event() local
936 struct wiphy *wiphy = wdev->wiphy; in cfg80211_cac_event()
942 if (WARN_ON(!wdev->cac_started && event != NL80211_RADAR_CAC_STARTED)) in cfg80211_cac_event()
945 if (WARN_ON(!wdev->chandef.chan)) in cfg80211_cac_event()
950 timeout = wdev->cac_start_time + in cfg80211_cac_event()
951 msecs_to_jiffies(wdev->cac_time_ms); in cfg80211_cac_event()
960 wdev->cac_started = false; in cfg80211_cac_event()
963 wdev->cac_started = true; in cfg80211_cac_event()