| /drivers/net/wireless/intel/iwlwifi/mvm/ |
| A D | debugfs-vif.c | 76 struct iwl_mvm *mvm = mvmvif->mvm; in iwl_dbgfs_pm_params_write() 208 mvmvif->id, mvmvif->color); in iwl_dbgfs_mac_params_read() 410 if (mvmvif->bf_enabled) in iwl_dbgfs_bf_params_read() 575 !!(mvmvif->low_latency & in iwl_dbgfs_low_latency_read() 682 if (mvmvif->dbgfs_quota_min) in iwl_dbgfs_quota_check() 703 mvmvif->dbgfs_quota_min = 0; in iwl_dbgfs_quota_min_write() 742 mvmvif->max_tx_op = value; in iwl_dbgfs_max_tx_op_write() 949 mvmvif->dbgfs_slink = in iwl_mvm_vif_dbgfs_add_link() 958 mvmvif->dbgfs_slink = NULL; in iwl_mvm_vif_dbgfs_rm_link() 993 WARN_ON(!mvmvif->dbgfs_dir); in iwl_mvm_link_add_debugfs() [all …]
|
| A D | mld-mac80211.c | 19 mvmvif->mvm = mvm; in iwl_mvm_mld_mac_add_interface() 45 mvmvif->deflink.active = 0; in iwl_mvm_mld_mac_add_interface() 58 mvm->bf_allowed_vif = mvmvif; in iwl_mvm_mld_mac_add_interface() 70 mvmvif->link[0] = &mvmvif->deflink; in iwl_mvm_mld_mac_add_interface() 117 mvmvif->link[0] = NULL; in iwl_mvm_mld_mac_add_interface() 193 if (mvmvif->link[i] && mvmvif->link[i]->phy_ctxt) in iwl_mvm_mld_count_active_links() 206 mvmvif->esr_active = true; in iwl_mvm_esr_mode_active() 229 mvmvif->primary_link = mvmvif->link_selection_primary; in iwl_mvm_esr_mode_active() 742 mvmvif->esr_active && in iwl_mvm_mld_link_info_changed_station() 1119 mvmvif->link[0] = NULL; in iwl_mvm_mld_change_vif_links() [all …]
|
| A D | link.c | 73 mvmvif->link[link_conf->link_id]; in iwl_mvm_set_link_fw_id() 76 link_info->fw_link_id = mvmvif->id; in iwl_mvm_set_link_fw_id() 135 mvmvif->link[link_id]; in iwl_mvm_esr_vif_iterator() 852 if (mvmvif->esr_active && in iwl_mvm_get_primary_link() 854 return mvmvif->primary_link; in iwl_mvm_get_primary_link() 885 struct iwl_mvm_vif *mvmvif, in iwl_mvm_check_esr_prevention() argument 889 mvmvif->last_esr_exit.ts + in iwl_mvm_check_esr_prevention() 951 if (!mvmvif->esr_active) in iwl_mvm_exit_esr() 985 &mvmvif->mlo_int_scan_wk, in iwl_mvm_exit_esr() 1054 mvmvif->esr_active) in iwl_mvm_esr_unblocked() [all …]
|
| A D | time-event.c | 67 struct iwl_mvm_vif *mvmvif; in iwl_mvm_cleanup_roc() local 245 mvmvif->csa_failed = true; in iwl_mvm_te_handle_notify_csa() 686 cpu_to_le32(FW_CMD_ID_AND_COLOR(mvmvif->id, mvmvif->color)); in iwl_mvm_protect_session() 736 return mvmvif->id; in iwl_mvm_get_session_prot_id() 795 struct iwl_mvm_vif *mvmvif; in __iwl_mvm_remove_time_event() local 886 cpu_to_le32(FW_CMD_ID_AND_COLOR(mvmvif->id, mvmvif->color)); in iwl_mvm_remove_aux_roc_te() 916 cpu_to_le32(FW_CMD_ID_AND_COLOR(mvmvif->id, mvmvif->color)); in iwl_mvm_remove_time_event() 963 struct iwl_mvm_vif *mvmvif; in iwl_mvm_rx_session_protect_notif() local 977 &mvmvif->time_event_data; in iwl_mvm_rx_session_protect_notif() 1192 cpu_to_le32(FW_CMD_ID_AND_COLOR(mvmvif->id, mvmvif->color)); in iwl_mvm_start_p2p_roc() [all …]
|
| A D | power.c | 145 if (mvmvif->dbgfs_pm.use_ps_poll) { in iwl_mvm_power_configure_uapsd() 355 mvmvif->color)); in iwl_mvm_power_build_cmd() 441 if (mvmvif->dbgfs_pm.lprx_ena) in iwl_mvm_power_build_cmd() 449 if (mvmvif->dbgfs_pm.snooze_ena) in iwl_mvm_power_build_cmd() 577 mvmvif->pm_enabled = false; in iwl_mvm_power_disable_pm_iterator() 586 if (iwl_mvm_vif_is_active(mvmvif)) in iwl_mvm_power_ps_disabled_iterator() 597 if (!mvmvif->uploaded) in iwl_mvm_power_get_vifs_iterator() 840 mvmvif->bf_enabled = true; in _iwl_mvm_enable_beacon_filter() 869 mvmvif->bf_enabled = false; in _iwl_mvm_disable_beacon_filter() 917 if (!mvmvif->bf_enabled) in iwl_mvm_power_set_ba() [all …]
|
| A D | mac-ctxt.c | 296 mvmvif->color = 0; in iwl_mvm_mac_ctxt_init() 548 mvmvif->color)); in iwl_mvm_mac_ctxt_cmd_common() 699 if (!mvmvif->authorized && in iwl_mvm_mac_ctxt_cmd_sta() 804 mvmvif->ap_ibss_active) in iwl_mvm_go_iterator() 888 if (!mvmvif->link[i]) in iwl_mvm_mac_ctxt_get_lowest_rate() 1415 mvmvif->uploaded = true; in iwl_mvm_mac_ctxt_add() 1445 mvmvif->color)); in iwl_mvm_mac_ctxt_remove() 1452 mvmvif->uploaded = false; in iwl_mvm_mac_ctxt_remove() 1466 struct iwl_mvm_vif *mvmvif = in iwl_mvm_csa_count_down() local 1798 struct iwl_mvm_vif *mvmvif; in iwl_mvm_probe_resp_data_notif() local [all …]
|
| A D | mac80211.c | 1100 mvmvif->uploaded = false; in iwl_mvm_cleanup_iterator() 1110 mvmvif->ap_sta = NULL; in iwl_mvm_cleanup_iterator() 1491 u32 mac_id = mvmvif->id; in iwl_mvm_set_tx_power() 1616 if (mvmvif->csa_failed) in iwl_mvm_post_channel_switch() 1631 mvmvif->color)), in iwl_mvm_abort_channel_switch() 1738 guard(mvm)(mvmvif->mvm); in iwl_mvm_mlo_int_scan_wk() 1806 mvmvif->mvm = mvm; in iwl_mvm_mac_add_interface() 1811 mvmvif->link[0] = &mvmvif->deflink; in iwl_mvm_mac_add_interface() 3905 mvmvif->ap_sta = sta; in iwl_mvm_sta_state_notexist_to_none() 5764 mvmvif->id, chsw->count, mvmvif->csa_count, chsw->block_tx); in iwl_mvm_channel_switch_rx_beacon() [all …]
|
| A D | utils.c | 281 struct iwl_mvm_vif *mvmvif; in iwl_mvm_update_smps() local 298 mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_update_smps() 316 if (mvmvif->esr_active) in iwl_mvm_update_smps() 614 if (iwl_mvm_vif_low_latency(mvmvif)) { in iwl_mvm_ll_iter() 617 if (!mvmvif->deflink.phy_ctxt) in iwl_mvm_ll_iter() 693 if (mvmvif->id == data->macid) in iwl_mvm_bss_find_iface_iterator() 866 struct iwl_mvm_vif *mvmvif; in iwl_mvm_tcm_uapsd_nonagg_detected_wk() local 872 mvm = mvmvif->mvm; in iwl_mvm_tcm_uapsd_nonagg_detected_wk() 964 if (!mvmvif->deflink.phy_ctxt) in iwl_mvm_tcm_iterator() 967 band[mvmvif->id] = mvmvif->deflink.phy_ctxt->channel->band; in iwl_mvm_tcm_iterator() [all …]
|
| A D | binding.c | 74 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_iface_iterator() local 79 if (mvmvif->deflink.phy_ctxt != data->phyctxt) in iwl_mvm_iface_iterator() 85 data->ids[data->idx] = mvmvif->id; in iwl_mvm_iface_iterator() 86 data->colors[data->idx] = mvmvif->color; in iwl_mvm_iface_iterator() 95 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_binding_update() local 124 data.ids[data.idx] = mvmvif->id; in iwl_mvm_binding_update() 125 data.colors[data.idx] = mvmvif->color; in iwl_mvm_binding_update() 134 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_binding_add_vif() local 136 if (WARN_ON_ONCE(!mvmvif->deflink.phy_ctxt)) in iwl_mvm_binding_add_vif() 152 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_binding_remove_vif() local [all …]
|
| A D | offloading.c | 90 i < mvmvif->num_target_ipv6_addrs && in iwl_mvm_send_proto_offload() 96 test_bit(i, mvmvif->tentative_addrs)) { in iwl_mvm_send_proto_offload() 109 addrs[i].addr = mvmvif->target_ipv6_addrs[i]; in iwl_mvm_send_proto_offload() 115 if (mvmvif->num_target_ipv6_addrs - num_skipped) in iwl_mvm_send_proto_offload() 128 sizeof(mvmvif->target_ipv6_addrs[0])); in iwl_mvm_send_proto_offload() 130 for (i = 0; i < min(mvmvif->num_target_ipv6_addrs, in iwl_mvm_send_proto_offload() 133 test_bit(i, mvmvif->tentative_addrs)) in iwl_mvm_send_proto_offload() 137 &mvmvif->target_ipv6_addrs[i], in iwl_mvm_send_proto_offload() 149 sizeof(mvmvif->target_ipv6_addrs[0])); in iwl_mvm_send_proto_offload() 154 test_bit(i, mvmvif->tentative_addrs)) in iwl_mvm_send_proto_offload() [all …]
|
| A D | mld-mac.c | 30 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_mac_ctxt_cmd_common() local 40 cmd->id_and_color = cpu_to_le32(mvmvif->id); in iwl_mvm_mld_mac_ctxt_cmd_common() 137 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_mac_ctxt_cmd_sta() local 141 if (!mvmvif->authorized && in iwl_mvm_mld_mac_ctxt_cmd_sta() 241 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_mac_ctxt_cmd_ap_go() local 249 iwl_mvm_mac_ctxt_cmd_ap_set_filter_flags(mvm, mvmvif, in iwl_mvm_mld_mac_ctxt_cmd_ap_go() 282 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_mac_ctxt_add() local 297 mvmvif->uploaded = true; in iwl_mvm_mld_mac_ctxt_add() 305 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_mac_ctxt_changed() local 320 .id_and_color = cpu_to_le32(mvmvif->id), in iwl_mvm_mld_mac_ctxt_remove() [all …]
|
| A D | rx.c | 209 struct iwl_mvm_vif *mvmvif; in iwl_mvm_rx_handle_tcm() local 392 !mvmvif->authorized && in iwl_mvm_rx_rx_mpdu() 425 struct iwl_mvm_vif *mvmvif = in iwl_mvm_rx_rx_mpdu() local 652 u16 vif_id = mvmvif->id; in iwl_mvm_stat_iterator() 663 if (mvmvif->id != id) in iwl_mvm_stat_iterator() 687 u16 vif_id = mvmvif->id; in iwl_mvm_stat_iterator_all_macs() 885 struct iwl_mvm_vif *mvmvif; in iwl_mvm_stat_iterator_all_links() local 935 air_time[mvmvif->id] += in iwl_mvm_stat_iterator_all_links() 937 rx_bytes[mvmvif->id] += in iwl_mvm_stat_iterator_all_links() 969 struct iwl_mvm_vif *mvmvif; in iwl_mvm_update_esr_mode_tpt() local [all …]
|
| A D | coex.c | 307 else if (mvmvif->esr_active) in iwl_mvm_bt_coex_calculate_esr_mode() 359 link_info = mvmvif->link[link_id]; in iwl_mvm_bt_notif_per_link() 411 mvmvif->id, link_info->fw_link_id, in iwl_mvm_bt_notif_per_link() 419 if (iwl_mvm_vif_low_latency(mvmvif)) { in iwl_mvm_bt_notif_per_link() 427 if (!mvmvif->ap_ibss_active) in iwl_mvm_bt_notif_per_link() 447 data->primary_load = mvm->tcm.result.load[mvmvif->id]; in iwl_mvm_bt_notif_per_link() 465 data->primary_load = mvm->tcm.result.load[mvmvif->id]; in iwl_mvm_bt_notif_per_link() 517 if (!mvmvif->ap_ibss_active) in iwl_mvm_bt_notif_iterator() 689 if (mvmvif->deflink.ap_sta_id == IWL_INVALID_STA) in iwl_mvm_bt_rssi_event() 706 mvmvif->deflink.ap_sta_id, in iwl_mvm_bt_rssi_event() [all …]
|
| A D | quota.c | 29 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_quota_iterator() local 36 if (!mvmvif->deflink.phy_ctxt) in iwl_mvm_quota_iterator() 40 id = mvmvif->deflink.phy_ctxt->id; in iwl_mvm_quota_iterator() 55 if (mvmvif->ap_ibss_active) in iwl_mvm_quota_iterator() 59 if (mvmvif->monitor_active) in iwl_mvm_quota_iterator() 70 data->colors[id] = mvmvif->deflink.phy_ctxt->color; in iwl_mvm_quota_iterator() 73 mvmvif->deflink.phy_ctxt->color); in iwl_mvm_quota_iterator() 78 if (mvmvif->dbgfs_quota_min) in iwl_mvm_quota_iterator() 80 mvmvif->dbgfs_quota_min); in iwl_mvm_quota_iterator() 83 if (iwl_mvm_vif_low_latency(mvmvif) && !data->low_latency[id]) { in iwl_mvm_quota_iterator()
|
| A D | d3.c | 33 mvmvif->rekey_data.replay_ctr = in iwl_mvm_set_rekey_data() 35 mvmvif->rekey_data.valid = true; in iwl_mvm_set_rekey_data() 49 memset(mvmvif->tentative_addrs, 0, sizeof(mvmvif->tentative_addrs)); in iwl_mvm_ipv6_addr_change() 71 mvmvif->tx_key_idx = idx; in iwl_mvm_set_default_unicast_key() 128 mvmvif->color)); in iwl_mvm_wowlan_program_keys() 755 mvmvif->uploaded = false; in iwl_mvm_d3_reprogram() 773 mvmvif->color)); in iwl_mvm_d3_reprogram() 833 mvmvif->color)), in iwl_mvm_get_last_nonqos_seq() 869 mvmvif->color)), in iwl_mvm_set_last_nonqos_seq() 874 if (!mvmvif->seqno_valid) in iwl_mvm_set_last_nonqos_seq() [all …]
|
| A D | sta.c | 1755 mvmvif->color); in iwl_mvm_sta_init() 1887 mvmvif->id, mvmvif->color); in iwl_mvm_add_sta() 2057 mvmvif->link[link_sta->link_id]; in iwl_mvm_sta_del() 2291 return iwl_mvm_add_int_sta_with_queue(mvm, mvmvif->id, mvmvif->color, in iwl_mvm_add_snif_sta() 2390 mvmvif->id, mvmvif->color); in iwl_mvm_send_add_bcast_sta() 2595 mvmvif->id, mvmvif->color); in iwl_mvm_add_mcast_sta() 4217 u32 id = FW_CMD_ID_AND_COLOR(mvmvif->id, mvmvif->color); in iwl_mvm_int_sta_modify_disable_tx() 4258 FW_CMD_ID_AND_COLOR(mvmvif->id, mvmvif->color)) in iwl_mvm_modify_all_sta_disable_tx() 4272 &mvmvif->deflink.mcast_sta, in iwl_mvm_modify_all_sta_disable_tx() 4385 if (mvmvif->esr_active) in iwl_mvm_count_mpdu() [all …]
|
| A D | mld-key.c | 16 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_get_sec_sta_mask() local 17 struct iwl_mvm_vif_link_info *link_info = &mvmvif->deflink; in iwl_mvm_get_sec_sta_mask() 22 link_info = mvmvif->link[keyconf->link_id]; in iwl_mvm_get_sec_sta_mask() 39 sta = mvmvif->ap_sta; in iwl_mvm_get_sec_sta_mask() 64 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_get_sec_flags() local 99 sta = mvmvif->ap_sta; in iwl_mvm_get_sec_flags() 251 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_sec_key_add() local 262 mvm_link = mvmvif->link[link_id]; in iwl_mvm_sec_key_add() 304 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in _iwl_mvm_sec_key_del() local 318 mvm_link = mvmvif->link[link_id]; in _iwl_mvm_sec_key_del()
|
| A D | sf.c | 24 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_bound_iface_iterator() local 26 if (vif == data->ignore_vif || !mvmvif->deflink.phy_ctxt || in iwl_mvm_bound_iface_iterator() 33 data->sta_vif_ap_sta = mvmvif->ap_sta; in iwl_mvm_bound_iface_iterator() 228 struct iwl_mvm_vif *mvmvif = NULL; in iwl_mvm_sf_update() local 274 mvmvif = iwl_mvm_vif_from_mac80211(changed_vif); in iwl_mvm_sf_update() 275 sta = mvmvif->ap_sta; in iwl_mvm_sf_update()
|
| A D | mld-sta.c | 216 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_add_bcast_sta() local 218 mvmvif->link[link_conf->link_id]; in iwl_mvm_mld_add_bcast_sta() 255 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_add_mcast_sta() local 257 mvmvif->link[link_conf->link_id]; in iwl_mvm_mld_add_mcast_sta() 289 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_add_snif_sta() local 291 mvmvif->link[link_conf->link_id]; in iwl_mvm_mld_add_snif_sta() 373 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_rm_bcast_sta() local 406 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_mld_rm_mcast_sta() local 660 mvm_link = mvmvif->link[link_conf->link_id]; in iwl_mvm_alloc_sta_after_restart() 919 struct iwl_mvm_vif *mvmvif, in iwl_mvm_mld_modify_all_sta_disable_tx() argument [all …]
|
| A D | ftm-responder.c | 114 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_ftm_responder_cmd() local 126 .sta_id = mvmvif->link[link_conf->link_id]->bcast_sta.sta_id, in iwl_mvm_ftm_responder_cmd() 330 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_ftm_start_responder() local 345 !mvmvif->ap_ibss_active) { in iwl_mvm_ftm_start_responder()
|
| A D | phy-ctxt.c | 387 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in iwl_mvm_binding_iterator() local 389 if (!mvmvif->deflink.phy_ctxt) in iwl_mvm_binding_iterator() 394 __set_bit(mvmvif->deflink.phy_ctxt->id, data); in iwl_mvm_binding_iterator()
|
| A D | mvm.h | 2024 struct iwl_mvm_vif *mvmvif, 2388 static inline bool iwl_mvm_vif_low_latency(struct iwl_mvm_vif *mvmvif) in iwl_mvm_vif_low_latency() argument 2400 return mvmvif->low_latency_actual; in iwl_mvm_vif_low_latency() 2404 void iwl_mvm_vif_set_low_latency(struct iwl_mvm_vif *mvmvif, bool set, in iwl_mvm_vif_set_low_latency() argument 2410 mvmvif->low_latency |= cause; in iwl_mvm_vif_set_low_latency() 2412 mvmvif->low_latency &= ~cause; in iwl_mvm_vif_set_low_latency() 2418 if (mvmvif->low_latency & LOW_LATENCY_DEBUGFS_FORCE_ENABLE && in iwl_mvm_vif_set_low_latency() 2426 new_state = !!(mvmvif->low_latency & in iwl_mvm_vif_set_low_latency() 2432 new_state = !!(mvmvif->low_latency & in iwl_mvm_vif_set_low_latency() 2436 mvmvif->low_latency_actual = new_state; in iwl_mvm_vif_set_low_latency() [all …]
|
| A D | rxmq.c | 330 struct iwl_mvm_vif *mvmvif; in iwl_mvm_rx_mgmt_prot() local 354 mvmvif = iwl_mvm_vif_from_mac80211(mvmsta->vif); in iwl_mvm_rx_mgmt_prot() 371 key = rcu_dereference(mvmvif->bcn_prot.keys[0]); in iwl_mvm_rx_mgmt_prot() 373 key = rcu_dereference(mvmvif->bcn_prot.keys[1]); in iwl_mvm_rx_mgmt_prot() 391 key = rcu_dereference(mvmvif->bcn_prot.keys[keyid - 6]); in iwl_mvm_rx_mgmt_prot() 525 struct iwl_mvm_vif *mvmvif; in iwl_mvm_rx_csum() local 530 mvmvif = iwl_mvm_vif_from_mac80211(mvmsta->vif); in iwl_mvm_rx_csum() 532 if (mvmvif->features & NETIF_F_RXCSUM && in iwl_mvm_rx_csum() 2301 struct iwl_mvm_vif *mvmvif = in iwl_mvm_rx_mpdu_mq() local 2308 if (mvmvif->csa_target_freq == rx_status->freq) in iwl_mvm_rx_mpdu_mq() [all …]
|
| A D | time-event.h | 155 struct iwl_mvm_vif *mvmvif,
|
| /drivers/net/wireless/intel/iwlwifi/mvm/tests/ |
| A D | links.c | 185 struct iwl_mvm_vif *mvmvif; in KUNIT_ARRAY_PARAM_DESC() local 189 mvmvif = iwl_mvm_vif_from_mac80211(vif); in KUNIT_ARRAY_PARAM_DESC() 192 mvmvif->link[0] = &mvm_link; in KUNIT_ARRAY_PARAM_DESC() 374 struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif); in KUNIT_ARRAY_PARAM_DESC() local 400 mvmvif->mvm = &mvm; in KUNIT_ARRAY_PARAM_DESC()
|