Lines Matching refs:sdata
8 static inline bool check_sdata_in_driver(struct ieee80211_sub_if_data *sdata) in check_sdata_in_driver() argument
10 return !WARN(!(sdata->flags & IEEE80211_SDATA_IN_DRIVER), in check_sdata_in_driver()
12 sdata->dev ? sdata->dev->name : sdata->name, sdata->flags); in check_sdata_in_driver()
16 get_bss_sdata(struct ieee80211_sub_if_data *sdata) in get_bss_sdata() argument
18 if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN) in get_bss_sdata()
19 sdata = container_of(sdata->bss, struct ieee80211_sub_if_data, in get_bss_sdata()
22 return sdata; in get_bss_sdata()
32 static inline void drv_get_et_strings(struct ieee80211_sub_if_data *sdata, in drv_get_et_strings() argument
35 struct ieee80211_local *local = sdata->local; in drv_get_et_strings()
38 local->ops->get_et_strings(&local->hw, &sdata->vif, sset, data); in drv_get_et_strings()
43 static inline void drv_get_et_stats(struct ieee80211_sub_if_data *sdata, in drv_get_et_stats() argument
47 struct ieee80211_local *local = sdata->local; in drv_get_et_stats()
50 local->ops->get_et_stats(&local->hw, &sdata->vif, stats, data); in drv_get_et_stats()
55 static inline int drv_get_et_sset_count(struct ieee80211_sub_if_data *sdata, in drv_get_et_sset_count() argument
58 struct ieee80211_local *local = sdata->local; in drv_get_et_sset_count()
62 rv = local->ops->get_et_sset_count(&local->hw, &sdata->vif, in drv_get_et_sset_count()
141 struct ieee80211_sub_if_data *sdata) in drv_add_interface() argument
147 if (WARN_ON(sdata->vif.type == NL80211_IFTYPE_AP_VLAN || in drv_add_interface()
148 (sdata->vif.type == NL80211_IFTYPE_MONITOR && in drv_add_interface()
150 !(sdata->u.mntr_flags & MONITOR_FLAG_ACTIVE)))) in drv_add_interface()
153 trace_drv_add_interface(local, sdata); in drv_add_interface()
154 ret = local->ops->add_interface(&local->hw, &sdata->vif); in drv_add_interface()
158 sdata->flags |= IEEE80211_SDATA_IN_DRIVER; in drv_add_interface()
164 struct ieee80211_sub_if_data *sdata, in drv_change_interface() argument
171 if (!check_sdata_in_driver(sdata)) in drv_change_interface()
174 trace_drv_change_interface(local, sdata, type, p2p); in drv_change_interface()
175 ret = local->ops->change_interface(&local->hw, &sdata->vif, type, p2p); in drv_change_interface()
181 struct ieee80211_sub_if_data *sdata) in drv_remove_interface() argument
185 if (!check_sdata_in_driver(sdata)) in drv_remove_interface()
188 trace_drv_remove_interface(local, sdata); in drv_remove_interface()
189 local->ops->remove_interface(&local->hw, &sdata->vif); in drv_remove_interface()
190 sdata->flags &= ~IEEE80211_SDATA_IN_DRIVER; in drv_remove_interface()
207 struct ieee80211_sub_if_data *sdata, in drv_bss_info_changed() argument
215 sdata->vif.type != NL80211_IFTYPE_AP && in drv_bss_info_changed()
216 sdata->vif.type != NL80211_IFTYPE_ADHOC && in drv_bss_info_changed()
217 sdata->vif.type != NL80211_IFTYPE_MESH_POINT && in drv_bss_info_changed()
218 sdata->vif.type != NL80211_IFTYPE_OCB)) in drv_bss_info_changed()
221 if (WARN_ON_ONCE(sdata->vif.type == NL80211_IFTYPE_P2P_DEVICE || in drv_bss_info_changed()
222 sdata->vif.type == NL80211_IFTYPE_MONITOR)) in drv_bss_info_changed()
225 if (!check_sdata_in_driver(sdata)) in drv_bss_info_changed()
228 trace_drv_bss_info_changed(local, sdata, info, changed); in drv_bss_info_changed()
230 local->ops->bss_info_changed(&local->hw, &sdata->vif, info, changed); in drv_bss_info_changed()
276 struct ieee80211_sub_if_data *sdata, in drv_set_key() argument
284 sdata = get_bss_sdata(sdata); in drv_set_key()
285 if (!check_sdata_in_driver(sdata)) in drv_set_key()
288 trace_drv_set_key(local, cmd, sdata, sta, key); in drv_set_key()
289 ret = local->ops->set_key(&local->hw, cmd, &sdata->vif, sta, key); in drv_set_key()
295 struct ieee80211_sub_if_data *sdata, in drv_update_tkip_key() argument
305 sdata = get_bss_sdata(sdata); in drv_update_tkip_key()
306 if (!check_sdata_in_driver(sdata)) in drv_update_tkip_key()
309 trace_drv_update_tkip_key(local, sdata, conf, ista, iv32); in drv_update_tkip_key()
311 local->ops->update_tkip_key(&local->hw, &sdata->vif, conf, in drv_update_tkip_key()
317 struct ieee80211_sub_if_data *sdata, in drv_hw_scan() argument
324 if (!check_sdata_in_driver(sdata)) in drv_hw_scan()
327 trace_drv_hw_scan(local, sdata); in drv_hw_scan()
328 ret = local->ops->hw_scan(&local->hw, &sdata->vif, req); in drv_hw_scan()
334 struct ieee80211_sub_if_data *sdata) in drv_cancel_hw_scan() argument
338 if (!check_sdata_in_driver(sdata)) in drv_cancel_hw_scan()
341 trace_drv_cancel_hw_scan(local, sdata); in drv_cancel_hw_scan()
342 local->ops->cancel_hw_scan(&local->hw, &sdata->vif); in drv_cancel_hw_scan()
348 struct ieee80211_sub_if_data *sdata, in drv_sched_scan_start() argument
356 if (!check_sdata_in_driver(sdata)) in drv_sched_scan_start()
359 trace_drv_sched_scan_start(local, sdata); in drv_sched_scan_start()
360 ret = local->ops->sched_scan_start(&local->hw, &sdata->vif, in drv_sched_scan_start()
367 struct ieee80211_sub_if_data *sdata) in drv_sched_scan_stop() argument
373 if (!check_sdata_in_driver(sdata)) in drv_sched_scan_stop()
376 trace_drv_sched_scan_stop(local, sdata); in drv_sched_scan_stop()
377 ret = local->ops->sched_scan_stop(&local->hw, &sdata->vif); in drv_sched_scan_stop()
384 struct ieee80211_sub_if_data *sdata, in drv_sw_scan_start() argument
389 trace_drv_sw_scan_start(local, sdata, mac_addr); in drv_sw_scan_start()
391 local->ops->sw_scan_start(&local->hw, &sdata->vif, mac_addr); in drv_sw_scan_start()
396 struct ieee80211_sub_if_data *sdata) in drv_sw_scan_complete() argument
400 trace_drv_sw_scan_complete(local, sdata); in drv_sw_scan_complete()
402 local->ops->sw_scan_complete(&local->hw, &sdata->vif); in drv_sw_scan_complete()
473 struct ieee80211_sub_if_data *sdata, in drv_sta_notify() argument
477 sdata = get_bss_sdata(sdata); in drv_sta_notify()
478 if (!check_sdata_in_driver(sdata)) in drv_sta_notify()
481 trace_drv_sta_notify(local, sdata, cmd, sta); in drv_sta_notify()
483 local->ops->sta_notify(&local->hw, &sdata->vif, cmd, sta); in drv_sta_notify()
488 struct ieee80211_sub_if_data *sdata, in drv_sta_add() argument
495 sdata = get_bss_sdata(sdata); in drv_sta_add()
496 if (!check_sdata_in_driver(sdata)) in drv_sta_add()
499 trace_drv_sta_add(local, sdata, sta); in drv_sta_add()
501 ret = local->ops->sta_add(&local->hw, &sdata->vif, sta); in drv_sta_add()
509 struct ieee80211_sub_if_data *sdata, in drv_sta_remove() argument
514 sdata = get_bss_sdata(sdata); in drv_sta_remove()
515 if (!check_sdata_in_driver(sdata)) in drv_sta_remove()
518 trace_drv_sta_remove(local, sdata, sta); in drv_sta_remove()
520 local->ops->sta_remove(&local->hw, &sdata->vif, sta); in drv_sta_remove()
527 struct ieee80211_sub_if_data *sdata, in drv_sta_add_debugfs() argument
533 sdata = get_bss_sdata(sdata); in drv_sta_add_debugfs()
534 if (!check_sdata_in_driver(sdata)) in drv_sta_add_debugfs()
538 local->ops->sta_add_debugfs(&local->hw, &sdata->vif, in drv_sta_add_debugfs()
543 struct ieee80211_sub_if_data *sdata, in drv_sta_remove_debugfs() argument
549 sdata = get_bss_sdata(sdata); in drv_sta_remove_debugfs()
550 check_sdata_in_driver(sdata); in drv_sta_remove_debugfs()
553 local->ops->sta_remove_debugfs(&local->hw, &sdata->vif, in drv_sta_remove_debugfs()
559 struct ieee80211_sub_if_data *sdata, in drv_sta_pre_rcu_remove() argument
564 sdata = get_bss_sdata(sdata); in drv_sta_pre_rcu_remove()
565 if (!check_sdata_in_driver(sdata)) in drv_sta_pre_rcu_remove()
568 trace_drv_sta_pre_rcu_remove(local, sdata, &sta->sta); in drv_sta_pre_rcu_remove()
570 local->ops->sta_pre_rcu_remove(&local->hw, &sdata->vif, in drv_sta_pre_rcu_remove()
577 struct ieee80211_sub_if_data *sdata, in drv_sta_state() argument
586 sdata = get_bss_sdata(sdata); in drv_sta_state()
587 if (!check_sdata_in_driver(sdata)) in drv_sta_state()
590 trace_drv_sta_state(local, sdata, &sta->sta, old_state, new_state); in drv_sta_state()
592 ret = local->ops->sta_state(&local->hw, &sdata->vif, &sta->sta, in drv_sta_state()
596 ret = drv_sta_add(local, sdata, &sta->sta); in drv_sta_state()
601 drv_sta_remove(local, sdata, &sta->sta); in drv_sta_state()
608 struct ieee80211_sub_if_data *sdata, in drv_sta_rc_update() argument
611 sdata = get_bss_sdata(sdata); in drv_sta_rc_update()
612 if (!check_sdata_in_driver(sdata)) in drv_sta_rc_update()
616 (sdata->vif.type != NL80211_IFTYPE_ADHOC && in drv_sta_rc_update()
617 sdata->vif.type != NL80211_IFTYPE_MESH_POINT)); in drv_sta_rc_update()
619 trace_drv_sta_rc_update(local, sdata, sta, changed); in drv_sta_rc_update()
621 local->ops->sta_rc_update(&local->hw, &sdata->vif, in drv_sta_rc_update()
628 struct ieee80211_sub_if_data *sdata, in drv_sta_rate_tbl_update() argument
631 sdata = get_bss_sdata(sdata); in drv_sta_rate_tbl_update()
632 if (!check_sdata_in_driver(sdata)) in drv_sta_rate_tbl_update()
635 trace_drv_sta_rate_tbl_update(local, sdata, sta); in drv_sta_rate_tbl_update()
637 local->ops->sta_rate_tbl_update(&local->hw, &sdata->vif, sta); in drv_sta_rate_tbl_update()
643 struct ieee80211_sub_if_data *sdata, in drv_sta_statistics() argument
647 sdata = get_bss_sdata(sdata); in drv_sta_statistics()
648 if (!check_sdata_in_driver(sdata)) in drv_sta_statistics()
651 trace_drv_sta_statistics(local, sdata, sta); in drv_sta_statistics()
653 local->ops->sta_statistics(&local->hw, &sdata->vif, sta, sinfo); in drv_sta_statistics()
658 struct ieee80211_sub_if_data *sdata, u16 ac, in drv_conf_tx() argument
665 if (!check_sdata_in_driver(sdata)) in drv_conf_tx()
671 sdata->name, params->cw_min, params->cw_max)) in drv_conf_tx()
674 trace_drv_conf_tx(local, sdata, ac, params); in drv_conf_tx()
676 ret = local->ops->conf_tx(&local->hw, &sdata->vif, in drv_conf_tx()
683 struct ieee80211_sub_if_data *sdata) in drv_get_tsf() argument
689 if (!check_sdata_in_driver(sdata)) in drv_get_tsf()
692 trace_drv_get_tsf(local, sdata); in drv_get_tsf()
694 ret = local->ops->get_tsf(&local->hw, &sdata->vif); in drv_get_tsf()
700 struct ieee80211_sub_if_data *sdata, in drv_set_tsf() argument
705 if (!check_sdata_in_driver(sdata)) in drv_set_tsf()
708 trace_drv_set_tsf(local, sdata, tsf); in drv_set_tsf()
710 local->ops->set_tsf(&local->hw, &sdata->vif, tsf); in drv_set_tsf()
715 struct ieee80211_sub_if_data *sdata) in drv_reset_tsf() argument
719 if (!check_sdata_in_driver(sdata)) in drv_reset_tsf()
722 trace_drv_reset_tsf(local, sdata); in drv_reset_tsf()
724 local->ops->reset_tsf(&local->hw, &sdata->vif); in drv_reset_tsf()
742 struct ieee80211_sub_if_data *sdata, in drv_ampdu_action() argument
751 sdata = get_bss_sdata(sdata); in drv_ampdu_action()
752 if (!check_sdata_in_driver(sdata)) in drv_ampdu_action()
755 trace_drv_ampdu_action(local, sdata, action, sta, tid, ssn, buf_size); in drv_ampdu_action()
758 ret = local->ops->ampdu_action(&local->hw, &sdata->vif, action, in drv_ampdu_action()
790 struct ieee80211_sub_if_data *sdata, in drv_flush() argument
793 struct ieee80211_vif *vif = sdata ? &sdata->vif : NULL; in drv_flush()
797 if (sdata && !check_sdata_in_driver(sdata)) in drv_flush()
807 struct ieee80211_sub_if_data *sdata, in drv_channel_switch() argument
812 trace_drv_channel_switch(local, sdata, ch_switch); in drv_channel_switch()
813 local->ops->channel_switch(&local->hw, &sdata->vif, ch_switch); in drv_channel_switch()
841 struct ieee80211_sub_if_data *sdata, in drv_remain_on_channel() argument
850 trace_drv_remain_on_channel(local, sdata, chan, duration, type); in drv_remain_on_channel()
851 ret = local->ops->remain_on_channel(&local->hw, &sdata->vif, in drv_remain_on_channel()
912 struct ieee80211_sub_if_data *sdata, in drv_set_bitrate_mask() argument
919 if (!check_sdata_in_driver(sdata)) in drv_set_bitrate_mask()
922 trace_drv_set_bitrate_mask(local, sdata, mask); in drv_set_bitrate_mask()
925 &sdata->vif, mask); in drv_set_bitrate_mask()
932 struct ieee80211_sub_if_data *sdata, in drv_set_rekey_data() argument
935 if (!check_sdata_in_driver(sdata)) in drv_set_rekey_data()
938 trace_drv_set_rekey_data(local, sdata, data); in drv_set_rekey_data()
940 local->ops->set_rekey_data(&local->hw, &sdata->vif, data); in drv_set_rekey_data()
945 struct ieee80211_sub_if_data *sdata, in drv_event_callback() argument
948 trace_drv_event_callback(local, sdata, event); in drv_event_callback()
950 local->ops->event_callback(&local->hw, &sdata->vif, event); in drv_event_callback()
985 struct ieee80211_sub_if_data *sdata) in drv_mgd_prepare_tx() argument
989 if (!check_sdata_in_driver(sdata)) in drv_mgd_prepare_tx()
991 WARN_ON_ONCE(sdata->vif.type != NL80211_IFTYPE_STATION); in drv_mgd_prepare_tx()
993 trace_drv_mgd_prepare_tx(local, sdata); in drv_mgd_prepare_tx()
995 local->ops->mgd_prepare_tx(&local->hw, &sdata->vif); in drv_mgd_prepare_tx()
1001 struct ieee80211_sub_if_data *sdata) in drv_mgd_protect_tdls_discover() argument
1005 if (!check_sdata_in_driver(sdata)) in drv_mgd_protect_tdls_discover()
1007 WARN_ON_ONCE(sdata->vif.type != NL80211_IFTYPE_STATION); in drv_mgd_protect_tdls_discover()
1009 trace_drv_mgd_protect_tdls_discover(local, sdata); in drv_mgd_protect_tdls_discover()
1011 local->ops->mgd_protect_tdls_discover(&local->hw, &sdata->vif); in drv_mgd_protect_tdls_discover()
1056 struct ieee80211_sub_if_data *sdata, in drv_assign_vif_chanctx() argument
1061 if (!check_sdata_in_driver(sdata)) in drv_assign_vif_chanctx()
1064 trace_drv_assign_vif_chanctx(local, sdata, ctx); in drv_assign_vif_chanctx()
1068 &sdata->vif, in drv_assign_vif_chanctx()
1077 struct ieee80211_sub_if_data *sdata, in drv_unassign_vif_chanctx() argument
1080 if (!check_sdata_in_driver(sdata)) in drv_unassign_vif_chanctx()
1083 trace_drv_unassign_vif_chanctx(local, sdata, ctx); in drv_unassign_vif_chanctx()
1087 &sdata->vif, in drv_unassign_vif_chanctx()
1147 struct ieee80211_sub_if_data *sdata) in drv_start_ap() argument
1151 if (!check_sdata_in_driver(sdata)) in drv_start_ap()
1154 trace_drv_start_ap(local, sdata, &sdata->vif.bss_conf); in drv_start_ap()
1156 ret = local->ops->start_ap(&local->hw, &sdata->vif); in drv_start_ap()
1162 struct ieee80211_sub_if_data *sdata) in drv_stop_ap() argument
1164 if (!check_sdata_in_driver(sdata)) in drv_stop_ap()
1167 trace_drv_stop_ap(local, sdata); in drv_stop_ap()
1169 local->ops->stop_ap(&local->hw, &sdata->vif); in drv_stop_ap()
1187 struct ieee80211_sub_if_data *sdata, in drv_set_default_unicast_key() argument
1190 if (!check_sdata_in_driver(sdata)) in drv_set_default_unicast_key()
1195 trace_drv_set_default_unicast_key(local, sdata, key_idx); in drv_set_default_unicast_key()
1197 local->ops->set_default_unicast_key(&local->hw, &sdata->vif, in drv_set_default_unicast_key()
1204 struct ieee80211_sub_if_data *sdata, in drv_ipv6_addr_change() argument
1207 trace_drv_ipv6_addr_change(local, sdata); in drv_ipv6_addr_change()
1209 local->ops->ipv6_addr_change(&local->hw, &sdata->vif, idev); in drv_ipv6_addr_change()
1215 drv_channel_switch_beacon(struct ieee80211_sub_if_data *sdata, in drv_channel_switch_beacon() argument
1218 struct ieee80211_local *local = sdata->local; in drv_channel_switch_beacon()
1221 trace_drv_channel_switch_beacon(local, sdata, chandef); in drv_channel_switch_beacon()
1222 local->ops->channel_switch_beacon(&local->hw, &sdata->vif, in drv_channel_switch_beacon()
1228 drv_pre_channel_switch(struct ieee80211_sub_if_data *sdata, in drv_pre_channel_switch() argument
1231 struct ieee80211_local *local = sdata->local; in drv_pre_channel_switch()
1234 if (!check_sdata_in_driver(sdata)) in drv_pre_channel_switch()
1237 trace_drv_pre_channel_switch(local, sdata, ch_switch); in drv_pre_channel_switch()
1239 ret = local->ops->pre_channel_switch(&local->hw, &sdata->vif, in drv_pre_channel_switch()
1246 drv_post_channel_switch(struct ieee80211_sub_if_data *sdata) in drv_post_channel_switch() argument
1248 struct ieee80211_local *local = sdata->local; in drv_post_channel_switch()
1251 if (!check_sdata_in_driver(sdata)) in drv_post_channel_switch()
1254 trace_drv_post_channel_switch(local, sdata); in drv_post_channel_switch()
1256 ret = local->ops->post_channel_switch(&local->hw, &sdata->vif); in drv_post_channel_switch()
1262 struct ieee80211_sub_if_data *sdata) in drv_join_ibss() argument
1267 if (!check_sdata_in_driver(sdata)) in drv_join_ibss()
1270 trace_drv_join_ibss(local, sdata, &sdata->vif.bss_conf); in drv_join_ibss()
1272 ret = local->ops->join_ibss(&local->hw, &sdata->vif); in drv_join_ibss()
1278 struct ieee80211_sub_if_data *sdata) in drv_leave_ibss() argument
1281 if (!check_sdata_in_driver(sdata)) in drv_leave_ibss()
1284 trace_drv_leave_ibss(local, sdata); in drv_leave_ibss()
1286 local->ops->leave_ibss(&local->hw, &sdata->vif); in drv_leave_ibss()
1304 struct ieee80211_sub_if_data *sdata, int *dbm) in drv_get_txpower() argument
1311 ret = local->ops->get_txpower(&local->hw, &sdata->vif, dbm); in drv_get_txpower()
1312 trace_drv_get_txpower(local, sdata, *dbm, ret); in drv_get_txpower()
1319 struct ieee80211_sub_if_data *sdata, in drv_tdls_channel_switch() argument
1327 if (!check_sdata_in_driver(sdata)) in drv_tdls_channel_switch()
1333 trace_drv_tdls_channel_switch(local, sdata, sta, oper_class, chandef); in drv_tdls_channel_switch()
1334 ret = local->ops->tdls_channel_switch(&local->hw, &sdata->vif, sta, in drv_tdls_channel_switch()
1343 struct ieee80211_sub_if_data *sdata, in drv_tdls_cancel_channel_switch() argument
1347 if (!check_sdata_in_driver(sdata)) in drv_tdls_cancel_channel_switch()
1353 trace_drv_tdls_cancel_channel_switch(local, sdata, sta); in drv_tdls_cancel_channel_switch()
1354 local->ops->tdls_cancel_channel_switch(&local->hw, &sdata->vif, sta); in drv_tdls_cancel_channel_switch()
1360 struct ieee80211_sub_if_data *sdata, in drv_tdls_recv_channel_switch() argument
1363 trace_drv_tdls_recv_channel_switch(local, sdata, params); in drv_tdls_recv_channel_switch()
1365 local->ops->tdls_recv_channel_switch(&local->hw, &sdata->vif, in drv_tdls_recv_channel_switch()
1373 struct ieee80211_sub_if_data *sdata = vif_to_sdata(txq->txq.vif); in drv_wake_tx_queue() local
1375 if (!check_sdata_in_driver(sdata)) in drv_wake_tx_queue()
1378 trace_drv_wake_tx_queue(local, sdata, txq); in drv_wake_tx_queue()