Lines Matching full:local
71 ieee80211_hw_config(sdata->local, 0); in __ieee80211_recalc_txpower()
86 static u32 __ieee80211_idle_off(struct ieee80211_local *local) in __ieee80211_idle_off() argument
88 if (!(local->hw.conf.flags & IEEE80211_CONF_IDLE)) in __ieee80211_idle_off()
91 local->hw.conf.flags &= ~IEEE80211_CONF_IDLE; in __ieee80211_idle_off()
95 static u32 __ieee80211_idle_on(struct ieee80211_local *local) in __ieee80211_idle_on() argument
97 if (local->hw.conf.flags & IEEE80211_CONF_IDLE) in __ieee80211_idle_on()
100 ieee80211_flush_queues(local, NULL, false); in __ieee80211_idle_on()
102 local->hw.conf.flags |= IEEE80211_CONF_IDLE; in __ieee80211_idle_on()
106 static u32 __ieee80211_recalc_idle(struct ieee80211_local *local, in __ieee80211_recalc_idle() argument
112 lockdep_assert_held(&local->mtx); in __ieee80211_recalc_idle()
115 !list_empty(&local->chanctx_list) || in __ieee80211_recalc_idle()
116 local->monitors; in __ieee80211_recalc_idle()
118 working = !local->ops->remain_on_channel && in __ieee80211_recalc_idle()
119 !list_empty(&local->roc_list); in __ieee80211_recalc_idle()
121 scanning = test_bit(SCAN_SW_SCANNING, &local->scanning) || in __ieee80211_recalc_idle()
122 test_bit(SCAN_ONCHANNEL_SCANNING, &local->scanning); in __ieee80211_recalc_idle()
134 ieee80211_mod_tpt_led_trig(local, led_trig_start, led_trig_stop); in __ieee80211_recalc_idle()
137 return __ieee80211_idle_off(local); in __ieee80211_recalc_idle()
138 return __ieee80211_idle_on(local); in __ieee80211_recalc_idle()
141 u32 ieee80211_idle_off(struct ieee80211_local *local) in ieee80211_idle_off() argument
143 return __ieee80211_recalc_idle(local, true); in ieee80211_idle_off()
146 void ieee80211_recalc_idle(struct ieee80211_local *local) in ieee80211_recalc_idle() argument
148 u32 change = __ieee80211_recalc_idle(local, false); in ieee80211_recalc_idle()
150 ieee80211_hw_config(local, change); in ieee80211_recalc_idle()
156 struct ieee80211_local *local = sdata->local; in ieee80211_verify_mac() local
162 if (is_zero_ether_addr(local->hw.wiphy->addr_mask)) in ieee80211_verify_mac()
170 m = local->hw.wiphy->addr_mask; in ieee80211_verify_mac()
178 mutex_lock(&local->iflist_mtx); in ieee80211_verify_mac()
179 list_for_each_entry(iter, &local->interfaces, list) { in ieee80211_verify_mac()
197 mutex_unlock(&local->iflist_mtx); in ieee80211_verify_mac()
243 struct ieee80211_local *local = sdata->local; in ieee80211_check_concurrent_iface() local
250 list_for_each_entry(nsdata, &local->interfaces, list) { in ieee80211_check_concurrent_iface()
305 mutex_lock(&local->chanctx_mtx); in ieee80211_check_concurrent_iface()
307 mutex_unlock(&local->chanctx_mtx); in ieee80211_check_concurrent_iface()
314 int n_queues = sdata->local->hw.queues; in ieee80211_check_queues()
334 !ieee80211_hw_check(&sdata->local->hw, QUEUE_CONTROL)) { in ieee80211_check_queues()
361 wiphy_lock(sdata->local->hw.wiphy); in ieee80211_open()
363 wiphy_unlock(sdata->local->hw.wiphy); in ieee80211_open()
370 struct ieee80211_local *local = sdata->local; in ieee80211_do_stop() local
382 cancel_scan = rcu_access_pointer(local->scan_sdata) == sdata; in ieee80211_do_stop()
384 ieee80211_scan_cancel(local); in ieee80211_do_stop()
392 ieee80211_roc_purge(local, sdata); in ieee80211_do_stop()
429 atomic_dec(&local->iff_allmultis); in ieee80211_do_stop()
432 local->fif_pspoll--; in ieee80211_do_stop()
433 local->fif_probe_req--; in ieee80211_do_stop()
435 local->fif_probe_req--; in ieee80211_do_stop()
440 spin_lock_bh(&local->filter_lock); in ieee80211_do_stop()
441 __hw_addr_unsync(&local->mc_list, &sdata->dev->mc, in ieee80211_do_stop()
443 spin_unlock_bh(&local->filter_lock); in ieee80211_do_stop()
447 del_timer_sync(&local->dynamic_ps_timer); in ieee80211_do_stop()
448 cancel_work_sync(&local->dynamic_ps_enable_work); in ieee80211_do_stop()
452 mutex_lock(&local->mtx); in ieee80211_do_stop()
457 ieee80211_wake_vif_queues(local, sdata, in ieee80211_do_stop()
461 mutex_unlock(&local->mtx); in ieee80211_do_stop()
471 WARN_ON(local->suspended); in ieee80211_do_stop()
472 mutex_lock(&local->mtx); in ieee80211_do_stop()
474 mutex_unlock(&local->mtx); in ieee80211_do_stop()
490 local->total_ps_buffered--; in ieee80211_do_stop()
491 ieee80211_free_txskb(&local->hw, skb); in ieee80211_do_stop()
498 local->open_count--; in ieee80211_do_stop()
502 mutex_lock(&local->mtx); in ieee80211_do_stop()
504 mutex_unlock(&local->mtx); in ieee80211_do_stop()
512 local->cooked_mntrs--; in ieee80211_do_stop()
516 local->monitors--; in ieee80211_do_stop()
517 if (local->monitors == 0) { in ieee80211_do_stop()
518 local->hw.conf.flags &= ~IEEE80211_CONF_MONITOR; in ieee80211_do_stop()
538 RCU_INIT_POINTER(local->p2p_sdata, NULL); in ieee80211_do_stop()
558 spin_lock_irqsave(&local->queue_stop_reason_lock, flags); in ieee80211_do_stop()
560 skb_queue_walk_safe(&local->pending[i], skb, tmp) { in ieee80211_do_stop()
563 __skb_unlink(skb, &local->pending[i]); in ieee80211_do_stop()
564 ieee80211_free_txskb(&local->hw, skb); in ieee80211_do_stop()
568 spin_unlock_irqrestore(&local->queue_stop_reason_lock, flags); in ieee80211_do_stop()
571 ieee80211_txq_remove_vlan(local, sdata); in ieee80211_do_stop()
575 if (local->open_count == 0) in ieee80211_do_stop()
576 ieee80211_clear_tx_pending(local); in ieee80211_do_stop()
589 if (local->suspended) { in ieee80211_do_stop()
590 WARN_ON(local->wowlan); in ieee80211_do_stop()
591 WARN_ON(rtnl_dereference(local->monitor_sdata)); in ieee80211_do_stop()
599 if (local->monitors == 0) in ieee80211_do_stop()
600 ieee80211_del_virtual_monitor(local); in ieee80211_do_stop()
602 mutex_lock(&local->mtx); in ieee80211_do_stop()
603 ieee80211_recalc_idle(local); in ieee80211_do_stop()
604 mutex_unlock(&local->mtx); in ieee80211_do_stop()
612 drv_remove_interface(local, sdata); in ieee80211_do_stop()
615 ieee80211_recalc_ps(local); in ieee80211_do_stop()
618 flush_delayed_work(&local->scan_work); in ieee80211_do_stop()
620 if (local->open_count == 0) { in ieee80211_do_stop()
621 ieee80211_stop_device(local); in ieee80211_do_stop()
628 ieee80211_configure_filter(local); in ieee80211_do_stop()
629 ieee80211_hw_config(local, hw_reconf_flags); in ieee80211_do_stop()
631 if (local->monitors == local->open_count) in ieee80211_do_stop()
632 ieee80211_add_virtual_monitor(local); in ieee80211_do_stop()
648 wiphy_lock(sdata->local->hw.wiphy); in ieee80211_stop()
650 wiphy_unlock(sdata->local->hw.wiphy); in ieee80211_stop()
658 struct ieee80211_local *local = sdata->local; in ieee80211_set_multicast_list() local
666 atomic_inc(&local->iff_allmultis); in ieee80211_set_multicast_list()
668 atomic_dec(&local->iff_allmultis); in ieee80211_set_multicast_list()
672 spin_lock_bh(&local->filter_lock); in ieee80211_set_multicast_list()
673 __hw_addr_sync(&local->mc_list, &dev->mc, dev->addr_len); in ieee80211_set_multicast_list()
674 spin_unlock_bh(&local->filter_lock); in ieee80211_set_multicast_list()
675 ieee80211_queue_work(&local->hw, &local->reconfig_filter); in ieee80211_set_multicast_list()
729 struct ieee80211_local *local = sdata->local; in ieee80211_monitor_select_queue() local
734 if (local->hw.queues < IEEE80211_NUM_ACS) in ieee80211_monitor_select_queue()
788 struct ieee80211_local *local = sdata->local; in ieee80211_set_sdata_offload_flags() local
793 if (ieee80211_hw_check(&local->hw, SUPPORTS_TX_ENCAP_OFFLOAD) && in ieee80211_set_sdata_offload_flags()
797 if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_FRAG) && in ieee80211_set_sdata_offload_flags()
798 local->hw.wiphy->frag_threshold != (u32)-1) in ieee80211_set_sdata_offload_flags()
801 if (local->monitors) in ieee80211_set_sdata_offload_flags()
807 if (ieee80211_hw_check(&local->hw, SUPPORTS_RX_DECAP_OFFLOAD) && in ieee80211_set_sdata_offload_flags()
811 if (local->monitors && in ieee80211_set_sdata_offload_flags()
812 !ieee80211_hw_check(&local->hw, SUPPORTS_CONC_MON_RX_DECAP)) in ieee80211_set_sdata_offload_flags()
828 struct ieee80211_local *local = sdata->local; in ieee80211_set_vif_encap_ops() local
839 if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_ENCAP_OFFLOAD) || in ieee80211_set_vif_encap_ops()
854 struct ieee80211_local *local = sdata->local; in ieee80211_recalc_sdata_offload() local
858 drv_update_vif_offload(local, sdata); in ieee80211_recalc_sdata_offload()
862 list_for_each_entry(vsdata, &local->interfaces, list) { in ieee80211_recalc_sdata_offload()
871 void ieee80211_recalc_offload(struct ieee80211_local *local) in ieee80211_recalc_offload() argument
875 if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_ENCAP_OFFLOAD)) in ieee80211_recalc_offload()
878 mutex_lock(&local->iflist_mtx); in ieee80211_recalc_offload()
880 list_for_each_entry(sdata, &local->interfaces, list) { in ieee80211_recalc_offload()
887 mutex_unlock(&local->iflist_mtx); in ieee80211_recalc_offload()
893 struct ieee80211_local *local = sdata->local; in ieee80211_adjust_monitor_flags() local
898 local->fif_##_s += offset; \ in ieee80211_adjust_monitor_flags()
912 struct ieee80211_local *local = sdata->local; in ieee80211_set_default_queues() local
916 if (ieee80211_hw_check(&local->hw, QUEUE_CONTROL)) in ieee80211_set_default_queues()
918 else if (local->hw.queues >= IEEE80211_NUM_ACS) in ieee80211_set_default_queues()
926 int ieee80211_add_virtual_monitor(struct ieee80211_local *local) in ieee80211_add_virtual_monitor() argument
931 if (!ieee80211_hw_check(&local->hw, WANT_MONITOR_VIF)) in ieee80211_add_virtual_monitor()
936 if (local->monitor_sdata) in ieee80211_add_virtual_monitor()
939 sdata = kzalloc(sizeof(*sdata) + local->hw.vif_data_size, GFP_KERNEL); in ieee80211_add_virtual_monitor()
944 sdata->local = local; in ieee80211_add_virtual_monitor()
947 wiphy_name(local->hw.wiphy)); in ieee80211_add_virtual_monitor()
954 ret = drv_add_interface(local, sdata); in ieee80211_add_virtual_monitor()
969 mutex_lock(&local->iflist_mtx); in ieee80211_add_virtual_monitor()
970 rcu_assign_pointer(local->monitor_sdata, sdata); in ieee80211_add_virtual_monitor()
971 mutex_unlock(&local->iflist_mtx); in ieee80211_add_virtual_monitor()
973 mutex_lock(&local->mtx); in ieee80211_add_virtual_monitor()
974 ret = ieee80211_vif_use_channel(sdata, &local->monitor_chandef, in ieee80211_add_virtual_monitor()
976 mutex_unlock(&local->mtx); in ieee80211_add_virtual_monitor()
978 mutex_lock(&local->iflist_mtx); in ieee80211_add_virtual_monitor()
979 RCU_INIT_POINTER(local->monitor_sdata, NULL); in ieee80211_add_virtual_monitor()
980 mutex_unlock(&local->iflist_mtx); in ieee80211_add_virtual_monitor()
982 drv_remove_interface(local, sdata); in ieee80211_add_virtual_monitor()
994 void ieee80211_del_virtual_monitor(struct ieee80211_local *local) in ieee80211_del_virtual_monitor() argument
998 if (!ieee80211_hw_check(&local->hw, WANT_MONITOR_VIF)) in ieee80211_del_virtual_monitor()
1003 mutex_lock(&local->iflist_mtx); in ieee80211_del_virtual_monitor()
1005 sdata = rcu_dereference_protected(local->monitor_sdata, in ieee80211_del_virtual_monitor()
1006 lockdep_is_held(&local->iflist_mtx)); in ieee80211_del_virtual_monitor()
1008 mutex_unlock(&local->iflist_mtx); in ieee80211_del_virtual_monitor()
1012 RCU_INIT_POINTER(local->monitor_sdata, NULL); in ieee80211_del_virtual_monitor()
1013 mutex_unlock(&local->iflist_mtx); in ieee80211_del_virtual_monitor()
1017 mutex_lock(&local->mtx); in ieee80211_del_virtual_monitor()
1019 mutex_unlock(&local->mtx); in ieee80211_del_virtual_monitor()
1021 drv_remove_interface(local, sdata); in ieee80211_del_virtual_monitor()
1035 struct ieee80211_local *local = sdata->local; in ieee80211_do_open() local
1047 mutex_lock(&local->mtx); in ieee80211_do_open()
1049 mutex_unlock(&local->mtx); in ieee80211_do_open()
1066 mutex_lock(&local->key_mtx); in ieee80211_do_open()
1069 mutex_unlock(&local->key_mtx); in ieee80211_do_open()
1095 if (local->open_count == 0) { in ieee80211_do_open()
1096 res = drv_start(local); in ieee80211_do_open()
1101 ieee80211_led_radio(local, true); in ieee80211_do_open()
1102 ieee80211_mod_tpt_led_trig(local, in ieee80211_do_open()
1112 local->hw.wiphy->perm_addr, in ieee80211_do_open()
1135 local->cooked_mntrs++; in ieee80211_do_open()
1140 res = drv_add_interface(local, sdata); in ieee80211_do_open()
1143 } else if (local->monitors == 0 && local->open_count == 0) { in ieee80211_do_open()
1144 res = ieee80211_add_virtual_monitor(local); in ieee80211_do_open()
1150 local->monitors++; in ieee80211_do_open()
1151 if (local->monitors == 1) { in ieee80211_do_open()
1152 local->hw.conf.flags |= IEEE80211_CONF_MONITOR; in ieee80211_do_open()
1157 ieee80211_configure_filter(local); in ieee80211_do_open()
1158 ieee80211_recalc_offload(local); in ieee80211_do_open()
1159 mutex_lock(&local->mtx); in ieee80211_do_open()
1160 ieee80211_recalc_idle(local); in ieee80211_do_open()
1161 mutex_unlock(&local->mtx); in ieee80211_do_open()
1167 ieee80211_del_virtual_monitor(local); in ieee80211_do_open()
1170 res = drv_add_interface(local, sdata); in ieee80211_do_open()
1182 local->fif_pspoll++; in ieee80211_do_open()
1183 local->fif_probe_req++; in ieee80211_do_open()
1185 ieee80211_configure_filter(local); in ieee80211_do_open()
1187 local->fif_probe_req++; in ieee80211_do_open()
1191 drv_config_iface_filter(local, sdata, in ieee80211_do_open()
1230 rcu_assign_pointer(local->p2p_sdata, sdata); in ieee80211_do_open()
1235 list_add_tail_rcu(&sdata->u.mntr.list, &local->mon_list); in ieee80211_do_open()
1247 atomic_inc(&local->iff_allmultis); in ieee80211_do_open()
1250 local->open_count++; in ieee80211_do_open()
1253 ieee80211_hw_config(local, hw_reconf_flags); in ieee80211_do_open()
1255 ieee80211_recalc_ps(local); in ieee80211_do_open()
1259 local->ops->wake_tx_queue) { in ieee80211_do_open()
1268 if (local->hw.queues < IEEE80211_NUM_ACS) in ieee80211_do_open()
1271 spin_lock_irqsave(&local->queue_stop_reason_lock, flags); in ieee80211_do_open()
1273 (local->queue_stop_reasons[sdata->vif.cab_queue] == 0 && in ieee80211_do_open()
1274 skb_queue_empty(&local->pending[sdata->vif.cab_queue]))) { in ieee80211_do_open()
1278 if (local->queue_stop_reasons[ac_queue] == 0 && in ieee80211_do_open()
1279 skb_queue_empty(&local->pending[ac_queue])) in ieee80211_do_open()
1283 spin_unlock_irqrestore(&local->queue_stop_reason_lock, flags); in ieee80211_do_open()
1288 drv_remove_interface(local, sdata); in ieee80211_do_open()
1290 if (!local->open_count) in ieee80211_do_open()
1291 drv_stop(local); in ieee80211_do_open()
1295 mutex_lock(&local->mtx); in ieee80211_do_open()
1297 mutex_unlock(&local->mtx); in ieee80211_do_open()
1324 static void ieee80211_iface_process_skb(struct ieee80211_local *local, in ieee80211_iface_process_skb() argument
1335 mutex_lock(&local->sta_mtx); in ieee80211_iface_process_skb()
1340 ieee80211_process_addba_request(local, sta, in ieee80211_iface_process_skb()
1344 ieee80211_process_addba_resp(local, sta, in ieee80211_iface_process_skb()
1356 mutex_unlock(&local->sta_mtx); in ieee80211_iface_process_skb()
1370 mutex_lock(&local->sta_mtx); in ieee80211_iface_process_skb()
1377 mutex_unlock(&local->sta_mtx); in ieee80211_iface_process_skb()
1423 mutex_lock(&local->sta_mtx); in ieee80211_iface_process_skb()
1433 mutex_unlock(&local->sta_mtx); in ieee80211_iface_process_skb()
1474 struct ieee80211_local *local = sdata->local; in ieee80211_iface_work() local
1480 if (test_bit(SCAN_SW_SCANNING, &local->scanning)) in ieee80211_iface_work()
1483 if (!ieee80211_can_run_worker(local)) in ieee80211_iface_work()
1493 ieee80211_iface_process_skb(local, sdata, skb); in ieee80211_iface_work()
1640 struct ieee80211_local *local = sdata->local; in ieee80211_runtime_change_iftype() local
1647 if (!local->ops->change_interface) in ieee80211_runtime_change_iftype()
1695 ieee80211_stop_vif_queues(local, sdata, in ieee80211_runtime_change_iftype()
1704 ret = drv_change_interface(local, sdata, internal_type, p2p); in ieee80211_runtime_change_iftype()
1721 ieee80211_wake_vif_queues(local, sdata, in ieee80211_runtime_change_iftype()
1753 static void ieee80211_assign_perm_addr(struct ieee80211_local *local, in ieee80211_assign_perm_addr() argument
1763 memcpy(perm_addr, local->hw.wiphy->perm_addr, ETH_ALEN); in ieee80211_assign_perm_addr()
1765 if (is_zero_ether_addr(local->hw.wiphy->addr_mask) && in ieee80211_assign_perm_addr()
1766 local->hw.wiphy->n_addresses <= 1) in ieee80211_assign_perm_addr()
1769 mutex_lock(&local->iflist_mtx); in ieee80211_assign_perm_addr()
1777 list_for_each_entry(sdata, &local->interfaces, list) { in ieee80211_assign_perm_addr()
1787 if (ieee80211_hw_check(&local->hw, P2P_DEV_ADDR_FOR_INTF)) { in ieee80211_assign_perm_addr()
1788 list_for_each_entry(sdata, &local->interfaces, list) { in ieee80211_assign_perm_addr()
1800 for (i = 0; i < local->hw.wiphy->n_addresses; i++) { in ieee80211_assign_perm_addr()
1803 list_for_each_entry(sdata, &local->interfaces, list) { in ieee80211_assign_perm_addr()
1804 if (ether_addr_equal(local->hw.wiphy->addresses[i].addr, in ieee80211_assign_perm_addr()
1813 local->hw.wiphy->addresses[i].addr, in ieee80211_assign_perm_addr()
1820 if (is_zero_ether_addr(local->hw.wiphy->addr_mask)) in ieee80211_assign_perm_addr()
1823 m = local->hw.wiphy->addr_mask; in ieee80211_assign_perm_addr()
1838 m = local->hw.wiphy->perm_addr; in ieee80211_assign_perm_addr()
1839 list_for_each_entry(sdata, &local->interfaces, list) { in ieee80211_assign_perm_addr()
1864 list_for_each_entry(sdata, &local->interfaces, list) { in ieee80211_assign_perm_addr()
1882 mutex_unlock(&local->iflist_mtx); in ieee80211_assign_perm_addr()
1885 int ieee80211_if_add(struct ieee80211_local *local, const char *name, in ieee80211_if_add() argument
1902 sdata = kzalloc(sizeof(*sdata) + local->hw.vif_data_size, in ieee80211_if_add()
1910 ieee80211_assign_perm_addr(local, wdev->address, type); in ieee80211_if_add()
1913 int size = ALIGN(sizeof(*sdata) + local->hw.vif_data_size, in ieee80211_if_add()
1917 if (local->ops->wake_tx_queue && in ieee80211_if_add()
1922 local->hw.txq_data_size; in ieee80211_if_add()
1924 if (local->ops->wake_tx_queue) { in ieee80211_if_add()
1928 if (local->hw.queues >= IEEE80211_NUM_ACS) in ieee80211_if_add()
1938 if (!local->ops->wake_tx_queue && local->hw.wiphy->tx_queue_len) in ieee80211_if_add()
1939 ndev->tx_queue_len = local->hw.wiphy->tx_queue_len; in ieee80211_if_add()
1941 dev_net_set(ndev, wiphy_net(local->hw.wiphy)); in ieee80211_if_add()
1949 ndev->needed_headroom = local->tx_headroom + in ieee80211_if_add()
1965 ieee80211_assign_perm_addr(local, ndev->perm_addr, type); in ieee80211_if_add()
1970 SET_NETDEV_DEV(ndev, wiphy_dev(local->hw.wiphy)); in ieee80211_if_add()
1987 sdata->wdev.wiphy = local->hw.wiphy; in ieee80211_if_add()
1988 sdata->local = local; in ieee80211_if_add()
2001 sband = local->hw.wiphy->bands[i]; in ieee80211_if_add()
2024 init_airtime_info(&sdata->airtime[i], &local->airtime[i]); in ieee80211_if_add()
2029 sdata->user_power_level = local->user_power_level; in ieee80211_if_add()
2041 ndev->features |= local->hw.netdev_features; in ieee80211_if_add()
2056 ndev->max_mtu = local->hw.max_mtu; in ieee80211_if_add()
2065 mutex_lock(&local->iflist_mtx); in ieee80211_if_add()
2066 list_add_tail_rcu(&sdata->list, &local->interfaces); in ieee80211_if_add()
2067 mutex_unlock(&local->iflist_mtx); in ieee80211_if_add()
2079 mutex_lock(&sdata->local->iflist_mtx); in ieee80211_if_remove()
2081 mutex_unlock(&sdata->local->iflist_mtx); in ieee80211_if_remove()
2084 ieee80211_txq_purge(sdata->local, to_txq_info(sdata->vif.txq)); in ieee80211_if_remove()
2103 void ieee80211_remove_interfaces(struct ieee80211_local *local) in ieee80211_remove_interfaces() argument
2122 cfg80211_shutdown_all_interfaces(local->hw.wiphy); in ieee80211_remove_interfaces()
2124 WARN(local->open_count, "%s: open count remains %d\n", in ieee80211_remove_interfaces()
2125 wiphy_name(local->hw.wiphy), local->open_count); in ieee80211_remove_interfaces()
2127 ieee80211_txq_teardown_flows(local); in ieee80211_remove_interfaces()
2129 mutex_lock(&local->iflist_mtx); in ieee80211_remove_interfaces()
2130 list_for_each_entry_safe(sdata, tmp, &local->interfaces, list) { in ieee80211_remove_interfaces()
2138 mutex_unlock(&local->iflist_mtx); in ieee80211_remove_interfaces()
2142 wiphy_lock(local->hw.wiphy); in ieee80211_remove_interfaces()
2148 wiphy_unlock(local->hw.wiphy); in ieee80211_remove_interfaces()