Lines Matching refs:vif
19 qtnf_event_handle_sta_assoc(struct qtnf_wmac *mac, struct qtnf_vif *vif,
34 mac->macid, vif->vifid, len, sizeof(*sta_assoc));
38 if (vif->wdev.iftype != NL80211_IFTYPE_AP) {
40 mac->macid, vif->vifid);
51 pr_debug("VIF%u.%u: MAC:%pM FC:%x\n", mac->macid, vif->vifid, sta_addr,
54 qtnf_sta_list_add(vif, sta_addr);
58 sinfo->generation = vif->generation;
93 cfg80211_new_sta(vif->netdev, sta_assoc->sta_addr, sinfo,
102 qtnf_event_handle_sta_deauth(struct qtnf_wmac *mac, struct qtnf_vif *vif,
111 mac->macid, vif->vifid, len,
116 if (vif->wdev.iftype != NL80211_IFTYPE_AP) {
118 mac->macid, vif->vifid);
125 pr_debug("VIF%u.%u: MAC:%pM reason:%x\n", mac->macid, vif->vifid,
128 if (qtnf_sta_list_del(vif, sta_addr))
129 cfg80211_del_sta(vif->netdev, sta_deauth->sta_addr,
136 qtnf_event_handle_bss_join(struct qtnf_vif *vif,
140 struct wiphy *wiphy = priv_to_wiphy(vif->mac);
154 vif->mac->macid, vif->vifid, len,
159 if (vif->wdev.iftype != NL80211_IFTYPE_STATION) {
161 vif->mac->macid, vif->vifid);
166 vif->mac->macid, vif->vifid, join_info->bssid,
175 vif->mac->macid, vif->vifid,
189 vif->mac->macid, vif->vifid,
192 if (!vif->wdev.ssid_len) {
194 vif->mac->macid, vif->vifid,
200 ie = kzalloc(2 + vif->wdev.ssid_len, GFP_KERNEL);
203 vif->mac->macid, vif->vifid,
210 ie[1] = vif->wdev.ssid_len;
211 memcpy(ie + 2, vif->wdev.ssid, vif->wdev.ssid_len);
217 ie, 2 + vif->wdev.ssid_len,
221 vif->mac->macid, vif->vifid,
267 cfg80211_connect_result(vif->netdev, join_info->bssid, NULL, 0, rsp_ies,
270 if (!ether_addr_equal(vif->bssid, join_info->bssid))
271 ether_addr_copy(vif->bssid, join_info->bssid);
276 netif_carrier_on(vif->netdev);
283 qtnf_event_handle_bss_leave(struct qtnf_vif *vif,
289 vif->mac->macid, vif->vifid, len,
294 if (vif->wdev.iftype != NL80211_IFTYPE_STATION) {
296 vif->mac->macid, vif->vifid);
300 pr_debug("VIF%u.%u: disconnected\n", vif->mac->macid, vif->vifid);
302 cfg80211_disconnected(vif->netdev, le16_to_cpu(leave_info->reason),
304 netif_carrier_off(vif->netdev);
310 qtnf_event_handle_mgmt_received(struct qtnf_vif *vif,
322 vif->mac->macid, vif->vifid, len, min_len);
329 pr_debug("%s LEN:%u FC:%.4X SA:%pM\n", vif->netdev->name, frame_len,
332 cfg80211_rx_mgmt(&vif->wdev, le32_to_cpu(rxmgmt->freq), rxmgmt->sig_dbm,
339 qtnf_event_handle_scan_results(struct qtnf_vif *vif,
345 struct wiphy *wiphy = priv_to_wiphy(vif->mac);
355 pr_err("VIF%u.%u: payload is too short\n", vif->mac->macid,
356 vif->vifid);
363 vif->mac->macid, vif->vifid, le16_to_cpu(sr->freq));
441 struct qtnf_vif *vif;
467 vif = &mac->iflist[i];
469 if (vif->wdev.iftype == NL80211_IFTYPE_UNSPECIFIED)
472 if (vif->wdev.iftype == NL80211_IFTYPE_STATION &&
473 !vif->wdev.current_bss)
476 if (!vif->netdev)
479 mutex_lock(&vif->wdev.mtx);
480 cfg80211_ch_switch_notify(vif->netdev, &chandef);
481 mutex_unlock(&vif->wdev.mtx);
487 static int qtnf_event_handle_radar(struct qtnf_vif *vif,
491 struct wiphy *wiphy = priv_to_wiphy(vif->mac);
495 pr_err("MAC%u: payload is too short\n", vif->mac->macid);
499 if (!wiphy->registered || !vif->netdev)
506 vif->mac->macid,
513 vif->netdev->name, ev->event,
522 if (!vif->wdev.cac_started)
525 cfg80211_cac_event(vif->netdev, &chandef,
529 if (!vif->wdev.cac_started)
532 cfg80211_cac_event(vif->netdev, &chandef,
536 if (vif->wdev.cac_started)
543 cfg80211_cac_event(vif->netdev, &chandef,
548 vif->netdev->name, ev->event);
556 qtnf_event_handle_external_auth(struct qtnf_vif *vif,
561 struct wiphy *wiphy = priv_to_wiphy(vif->mac);
565 pr_err("MAC%u: payload is too short\n", vif->mac->macid);
569 if (!wiphy->registered || !vif->netdev)
584 vif->netdev->name, auth.bssid, auth.action,
587 ret = cfg80211_external_auth_request(vif->netdev, &auth, GFP_KERNEL);
595 qtnf_event_handle_mic_failure(struct qtnf_vif *vif,
599 struct wiphy *wiphy = priv_to_wiphy(vif->mac);
604 vif->mac->macid, vif->vifid, len,
609 if (!wiphy->registered || !vif->netdev)
612 if (vif->wdev.iftype != NL80211_IFTYPE_STATION) {
614 vif->mac->macid, vif->vifid);
622 vif->netdev->name, mic_ev->src, mic_ev->key_index, pairwise);
624 cfg80211_michael_mic_failure(vif->netdev, mic_ev->src, pairwise,
631 qtnf_event_handle_update_owe(struct qtnf_vif *vif,
635 struct wiphy *wiphy = priv_to_wiphy(vif->mac);
642 vif->mac->macid, vif->vifid, len,
647 if (!wiphy->registered || !vif->netdev)
650 if (vif->wdev.iftype != NL80211_IFTYPE_AP) {
652 vif->mac->macid, vif->vifid);
666 vif->netdev->name, owe_ev->peer);
668 cfg80211_update_owe_info_event(vif->netdev, &owe_info, GFP_KERNEL);
678 struct qtnf_vif *vif = NULL;
689 pr_err("invalid vif(%u)\n", event->vifid);
694 vif = &mac->iflist[vifid];
698 ret = qtnf_event_handle_sta_assoc(mac, vif, (const void *)event,
702 ret = qtnf_event_handle_sta_deauth(mac, vif,
707 ret = qtnf_event_handle_mgmt_received(vif, (const void *)event,
711 ret = qtnf_event_handle_scan_results(vif, (const void *)event,
719 ret = qtnf_event_handle_bss_join(vif, (const void *)event,
723 ret = qtnf_event_handle_bss_leave(vif, (const void *)event,
731 ret = qtnf_event_handle_radar(vif, (const void *)event,
735 ret = qtnf_event_handle_external_auth(vif, (const void *)event,
739 ret = qtnf_event_handle_mic_failure(vif, (const void *)event,
743 ret = qtnf_event_handle_update_owe(vif, (const void *)event,
770 pr_debug("new event id:%x len:%u mac:%u vif:%u\n",