1 /******************************************************************************
3 * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 ******************************************************************************/
17 #include <osdep_service.h>
18 #include <drv_types.h>
20 #include <osdep_intf.h>
23 #include <rtl8723a_xmit.h>
25 static u8 P802_1H_OUI[P80211_OUI_LEN] = { 0x00, 0x00, 0xf8 };
26 static u8 RFC1042_OUI[P80211_OUI_LEN] = { 0x00, 0x00, 0x00 };
28 static void _init_txservq(struct tx_servq *ptxservq)
31 INIT_LIST_HEAD(&ptxservq->tx_pending);
32 _rtw_init_queue23a(&ptxservq->sta_pending);
37 void _rtw_init_sta_xmit_priv23a(struct sta_xmit_priv *psta_xmitpriv)
40 spin_lock_init(&psta_xmitpriv->lock);
42 /* for (i = 0 ; i < MAX_NUMBLKS; i++) */
43 /* _init_txservq(&psta_xmitpriv->blk_q[i]); */
45 _init_txservq(&psta_xmitpriv->be_q);
46 _init_txservq(&psta_xmitpriv->bk_q);
47 _init_txservq(&psta_xmitpriv->vi_q);
48 _init_txservq(&psta_xmitpriv->vo_q);
49 INIT_LIST_HEAD(&psta_xmitpriv->legacy_dz);
50 INIT_LIST_HEAD(&psta_xmitpriv->apsd);
54 int _rtw_init_xmit_priv23a(struct xmit_priv *pxmitpriv,
55 struct rtw_adapter *padapter)
58 struct xmit_buf *pxmitbuf;
59 struct xmit_frame *pxframe;
61 u32 max_xmit_extbuf_size = MAX_XMIT_EXTBUF_SZ;
62 u32 num_xmit_extbuf = NR_XMIT_EXTBUFF;
64 spin_lock_init(&pxmitpriv->lock);
65 spin_lock_init(&pxmitpriv->lock_sctx);
66 sema_init(&pxmitpriv->xmit_sema, 0);
67 sema_init(&pxmitpriv->terminate_xmitthread_sema, 0);
69 pxmitpriv->adapter = padapter;
71 _rtw_init_queue23a(&pxmitpriv->be_pending);
72 _rtw_init_queue23a(&pxmitpriv->bk_pending);
73 _rtw_init_queue23a(&pxmitpriv->vi_pending);
74 _rtw_init_queue23a(&pxmitpriv->vo_pending);
75 _rtw_init_queue23a(&pxmitpriv->bm_pending);
77 _rtw_init_queue23a(&pxmitpriv->free_xmit_queue);
79 for (i = 0; i < NR_XMITFRAME; i++) {
80 pxframe = kzalloc(sizeof(struct xmit_frame), GFP_KERNEL);
83 INIT_LIST_HEAD(&pxframe->list);
85 pxframe->padapter = padapter;
86 pxframe->frame_tag = NULL_FRAMETAG;
88 list_add_tail(&pxframe->list,
89 &pxmitpriv->free_xmit_queue.queue);
92 pxmitpriv->free_xmitframe_cnt = i;
94 pxmitpriv->frag_len = MAX_FRAG_THRESHOLD;
97 _rtw_init_queue23a(&pxmitpriv->free_xmitbuf_queue);
98 INIT_LIST_HEAD(&pxmitpriv->xmitbuf_list);
99 _rtw_init_queue23a(&pxmitpriv->pending_xmitbuf_queue);
101 for (i = 0; i < NR_XMITBUFF; i++) {
102 pxmitbuf = kzalloc(sizeof(struct xmit_buf), GFP_KERNEL);
105 INIT_LIST_HEAD(&pxmitbuf->list);
106 INIT_LIST_HEAD(&pxmitbuf->list2);
108 pxmitbuf->padapter = padapter;
110 /* Tx buf allocation may fail sometimes, so sleep and retry. */
111 res = rtw_os_xmit_resource_alloc23a(padapter, pxmitbuf,
112 (MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ));
117 list_add_tail(&pxmitbuf->list,
118 &pxmitpriv->free_xmitbuf_queue.queue);
119 list_add_tail(&pxmitbuf->list2,
120 &pxmitpriv->xmitbuf_list);
123 pxmitpriv->free_xmitbuf_cnt = NR_XMITBUFF;
125 /* init xframe_ext queue, the same count as extbuf */
126 _rtw_init_queue23a(&pxmitpriv->free_xframe_ext_queue);
128 for (i = 0; i < num_xmit_extbuf; i++) {
129 pxframe = kzalloc(sizeof(struct xmit_frame), GFP_KERNEL);
132 INIT_LIST_HEAD(&pxframe->list);
134 pxframe->padapter = padapter;
135 pxframe->frame_tag = NULL_FRAMETAG;
139 pxframe->buf_addr = NULL;
140 pxframe->pxmitbuf = NULL;
142 pxframe->ext_tag = 1;
144 list_add_tail(&pxframe->list,
145 &pxmitpriv->free_xframe_ext_queue.queue);
147 pxmitpriv->free_xframe_ext_cnt = i;
149 /* Init xmit extension buff */
150 _rtw_init_queue23a(&pxmitpriv->free_xmit_extbuf_queue);
151 INIT_LIST_HEAD(&pxmitpriv->xmitextbuf_list);
153 for (i = 0; i < num_xmit_extbuf; i++) {
154 pxmitbuf = kzalloc(sizeof(struct xmit_buf), GFP_KERNEL);
157 INIT_LIST_HEAD(&pxmitbuf->list);
158 INIT_LIST_HEAD(&pxmitbuf->list2);
160 pxmitbuf->padapter = padapter;
162 /* Tx buf allocation may fail sometimes, so sleep and retry. */
163 res = rtw_os_xmit_resource_alloc23a(padapter, pxmitbuf,
164 max_xmit_extbuf_size + XMITBUF_ALIGN_SZ);
169 list_add_tail(&pxmitbuf->list,
170 &pxmitpriv->free_xmit_extbuf_queue.queue);
171 list_add_tail(&pxmitbuf->list2,
172 &pxmitpriv->xmitextbuf_list);
175 pxmitpriv->free_xmit_extbuf_cnt = num_xmit_extbuf;
177 rtw_alloc_hwxmits23a(padapter);
178 rtw_init_hwxmits23a(pxmitpriv->hwxmits, pxmitpriv->hwxmit_entry);
180 for (i = 0; i < 4; i ++)
181 pxmitpriv->wmm_para_seq[i] = i;
183 sema_init(&pxmitpriv->tx_retevt, 0);
185 pxmitpriv->ack_tx = false;
186 mutex_init(&pxmitpriv->ack_tx_mutex);
187 rtw_sctx_init23a(&pxmitpriv->ack_tx_ops, 0);
188 tasklet_init(&padapter->xmitpriv.xmit_tasklet,
189 (void(*)(unsigned long))rtl8723au_xmit_tasklet,
190 (unsigned long)padapter);
199 void _rtw_free_xmit_priv23a (struct xmit_priv *pxmitpriv)
201 struct rtw_adapter *padapter = pxmitpriv->adapter;
202 struct xmit_frame *pxframe;
203 struct xmit_buf *pxmitbuf;
204 struct list_head *plist, *ptmp;
206 list_for_each_safe(plist, ptmp, &pxmitpriv->free_xmit_queue.queue) {
207 pxframe = container_of(plist, struct xmit_frame, list);
208 list_del_init(&pxframe->list);
209 rtw_os_xmit_complete23a(padapter, pxframe);
213 list_for_each_safe(plist, ptmp, &pxmitpriv->xmitbuf_list) {
214 pxmitbuf = container_of(plist, struct xmit_buf, list2);
215 list_del_init(&pxmitbuf->list2);
216 rtw_os_xmit_resource_free23a(padapter, pxmitbuf);
220 /* free xframe_ext queue, the same count as extbuf */
221 list_for_each_safe(plist, ptmp,
222 &pxmitpriv->free_xframe_ext_queue.queue) {
223 pxframe = container_of(plist, struct xmit_frame, list);
224 list_del_init(&pxframe->list);
225 rtw_os_xmit_complete23a(padapter, pxframe);
229 /* free xmit extension buff */
230 list_for_each_safe(plist, ptmp, &pxmitpriv->xmitextbuf_list) {
231 pxmitbuf = container_of(plist, struct xmit_buf, list2);
232 list_del_init(&pxmitbuf->list2);
233 rtw_os_xmit_resource_free23a(padapter, pxmitbuf);
237 rtw_free_hwxmits23a(padapter);
238 mutex_destroy(&pxmitpriv->ack_tx_mutex);
241 static void update_attrib_vcs_info(struct rtw_adapter *padapter, struct xmit_frame *pxmitframe)
244 struct pkt_attrib *pattrib = &pxmitframe->attrib;
245 struct sta_info *psta = pattrib->psta;
246 struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
247 struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
250 psta = pattrib->psta;
252 DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
253 psta = rtw_get_stainfo23a(&padapter->stapriv, &pattrib->ra[0]);
257 DBG_8723A("%s, psta == NUL\n", __func__);
261 if (!(psta->state &_FW_LINKED)) {
262 DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
266 if (pattrib->nr_frags != 1)
267 sz = padapter->xmitpriv.frag_len;
269 sz = pattrib->last_txcmdsz;
271 /* (1) RTS_Threshold is compared to the MPDU, not MSDU. */
272 /* (2) If there are more than one frag in this MSDU, only the first frag uses protection frame. */
273 /* Other fragments are protected by previous fragment. */
274 /* So we only need to check the length of first fragment. */
275 if (pmlmeext->cur_wireless_mode < WIRELESS_11_24N || padapter->registrypriv.wifi_spec) {
276 if (sz > padapter->registrypriv.rts_thresh) {
277 pattrib->vcs_mode = RTS_CTS;
280 pattrib->vcs_mode = RTS_CTS;
281 else if (psta->cts2self)
282 pattrib->vcs_mode = CTS_TO_SELF;
284 pattrib->vcs_mode = NONE_VCS;
289 if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_ATHEROS &&
291 padapter->securitypriv.dot11PrivacyAlgrthm ==
292 WLAN_CIPHER_SUITE_CCMP) {
293 pattrib->vcs_mode = CTS_TO_SELF;
297 /* check ERP protection */
298 if (psta->rtsen || psta->cts2self) {
300 pattrib->vcs_mode = RTS_CTS;
301 else if (psta->cts2self)
302 pattrib->vcs_mode = CTS_TO_SELF;
307 /* check HT op mode */
308 if (pattrib->ht_en) {
309 u8 HTOpMode = pmlmeinfo->HT_protection;
311 if ((pmlmeext->cur_bwmode && (HTOpMode == 2 || HTOpMode == 3)) ||
312 (!pmlmeext->cur_bwmode && HTOpMode == 3)) {
313 pattrib->vcs_mode = RTS_CTS;
319 if (sz > padapter->registrypriv.rts_thresh) {
320 pattrib->vcs_mode = RTS_CTS;
324 /* to do list: check MIMO power save condition. */
326 /* check AMPDU aggregation for TXOP */
327 if (pattrib->ampdu_en) {
328 pattrib->vcs_mode = RTS_CTS;
332 pattrib->vcs_mode = NONE_VCS;
338 static void update_attrib_phy_info(struct pkt_attrib *pattrib, struct sta_info *psta)
341 pattrib->vcs_mode = RTS_CTS;
342 else if (psta->cts2self)
343 pattrib->vcs_mode = CTS_TO_SELF;
345 pattrib->vcs_mode = NONE_VCS;*/
349 pattrib->triggered = 0;
351 /* qos_en, ht_en, init rate, , bw, ch_offset, sgi */
352 pattrib->qos_en = psta->qos_option;
354 pattrib->raid = psta->raid;
355 pattrib->ht_en = psta->htpriv.ht_option;
356 pattrib->bwmode = psta->htpriv.bwmode;
357 pattrib->ch_offset = psta->htpriv.ch_offset;
358 pattrib->sgi = psta->htpriv.sgi;
359 pattrib->ampdu_en = false;
361 pattrib->retry_ctrl = false;
364 u8 qos_acm23a(u8 acm_mask, u8 priority)
366 u8 change_priority = priority;
371 if (acm_mask & BIT(1))
379 if (acm_mask & BIT(2))
384 if (acm_mask & BIT(3))
388 DBG_8723A("qos_acm23a(): invalid pattrib->priority: %d!!!\n",
394 return change_priority;
397 static void set_qos(struct sk_buff *skb, struct pkt_attrib *pattrib)
399 u8 *pframe = skb->data;
400 struct iphdr *ip_hdr;
403 /* get UserPriority from IP hdr */
404 if (pattrib->ether_type == ETH_P_IP) {
405 ip_hdr = (struct iphdr *)(pframe + ETH_HLEN);
406 UserPriority = ip_hdr->tos >> 5;
407 } else if (pattrib->ether_type == ETH_P_PAE) {
408 /* "When priority processing of data frames is supported, */
409 /* a STA's SME should send EAPOL-Key frames at the highest
414 pattrib->priority = UserPriority;
415 pattrib->hdrlen = sizeof(struct ieee80211_qos_hdr);
416 pattrib->type = IEEE80211_FTYPE_DATA | IEEE80211_STYPE_QOS_DATA;
419 static int update_attrib(struct rtw_adapter *padapter,
420 struct sk_buff *skb, struct pkt_attrib *pattrib)
422 struct sta_info *psta = NULL;
424 struct sta_priv *pstapriv = &padapter->stapriv;
425 struct security_priv *psecuritypriv = &padapter->securitypriv;
426 struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
428 struct ethhdr *ehdr = (struct ethhdr *) skb->data;
430 pattrib->ether_type = ntohs(ehdr->h_proto);
432 ether_addr_copy(pattrib->dst, ehdr->h_dest);
433 ether_addr_copy(pattrib->src, ehdr->h_source);
437 if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) ||
438 check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
439 ether_addr_copy(pattrib->ra, pattrib->dst);
440 ether_addr_copy(pattrib->ta, pattrib->src);
441 } else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
442 ether_addr_copy(pattrib->ra, get_bssid(pmlmepriv));
443 ether_addr_copy(pattrib->ta, pattrib->src);
444 } else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
445 ether_addr_copy(pattrib->ra, pattrib->dst);
446 ether_addr_copy(pattrib->ta, get_bssid(pmlmepriv));
449 pattrib->pktlen = skb->len - ETH_HLEN;
451 if (pattrib->ether_type == ETH_P_IP) {
452 /* The following is for DHCP and ARP packet, we use cck1M
453 to tx these packets and let LPS awake some time */
454 /* to prevent DHCP protocol fail */
455 pattrib->dhcp_pkt = 0;
456 /* MINIMUM_DHCP_PACKET_SIZE) { */
457 if (pattrib->pktlen > 282 + 24) {
458 if (pattrib->ether_type == ETH_P_IP) {/* IP header */
459 u8 *pframe = skb->data;
463 if ((pframe[21] == 68 && pframe[23] == 67) ||
464 (pframe[21] == 67 && pframe[23] == 68)) {
465 /* 68 : UDP BOOTP client */
466 /* 67 : UDP BOOTP server */
467 RT_TRACE(_module_rtl871x_xmit_c_,
469 ("======================"
470 "update_attrib: get DHCP "
472 pattrib->dhcp_pkt = 1;
476 } else if (pattrib->ether_type == ETH_P_PAE) {
477 DBG_8723A_LEVEL(_drv_always_, "send eapol packet\n");
480 if ((pattrib->ether_type == ETH_P_PAE) || (pattrib->dhcp_pkt == 1)) {
481 rtw_set_scan_deny(padapter, 3000);
484 /* If EAPOL , ARP , OR DHCP packet, driver must be in active mode. */
485 if ((pattrib->ether_type == ETH_P_ARP) ||
486 (pattrib->ether_type == ETH_P_PAE) || (pattrib->dhcp_pkt == 1)) {
487 rtw_lps_ctrl_wk_cmd23a(padapter, LPS_CTRL_SPECIAL_PACKET, 1);
490 bmcast = is_multicast_ether_addr(pattrib->ra);
494 psta = rtw_get_bcmc_stainfo23a(padapter);
496 psta = rtw_get_stainfo23a(pstapriv, pattrib->ra);
497 if (psta == NULL) { /* if we cannot get psta => drrp the pkt */
498 RT_TRACE(_module_rtl871x_xmit_c_, _drv_alert_,
499 ("\nupdate_attrib => get sta_info fail, ra:"
500 MAC_FMT"\n", MAC_ARG(pattrib->ra)));
503 } else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) &&
504 (!(psta->state & _FW_LINKED))) {
511 pattrib->mac_id = psta->mac_id;
512 /* DBG_8723A("%s ==> mac_id(%d)\n", __func__, pattrib->mac_id); */
513 pattrib->psta = psta;
515 /* if we cannot get psta => drop the pkt */
516 RT_TRACE(_module_rtl871x_xmit_c_, _drv_alert_,
517 ("\nupdate_attrib => get sta_info fail, ra:" MAC_FMT
518 "\n", MAC_ARG(pattrib->ra)));
523 pattrib->ack_policy = 0;
524 /* get ether_hdr_len */
526 /* pattrib->ether_type == 0x8100) ? (14 + 4): 14; vlan tag */
527 pattrib->pkt_hdrlen = ETH_HLEN;
529 pattrib->hdrlen = sizeof(struct ieee80211_hdr_3addr);
530 pattrib->type = IEEE80211_FTYPE_DATA;
531 pattrib->priority = 0;
533 if (check_fwstate(pmlmepriv, WIFI_AP_STATE | WIFI_ADHOC_STATE |
534 WIFI_ADHOC_MASTER_STATE)) {
535 if (psta->qos_option)
536 set_qos(skb, pattrib);
538 if (pmlmepriv->qos_option) {
539 set_qos(skb, pattrib);
541 if (pmlmepriv->acm_mask != 0) {
542 pattrib->priority = qos_acm23a(pmlmepriv->acm_mask,
548 if (psta->ieee8021x_blocked == true) {
549 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
550 ("\n psta->ieee8021x_blocked == true\n"));
552 pattrib->encrypt = 0;
554 if ((pattrib->ether_type != ETH_P_PAE) &&
555 !check_fwstate(pmlmepriv, WIFI_MP_STATE)) {
556 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
557 ("\npsta->ieee8021x_blocked == true, "
558 "pattrib->ether_type(%.4x) != 0x888e\n",
559 pattrib->ether_type));
564 GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt, bmcast);
566 switch (psecuritypriv->dot11AuthAlgrthm) {
567 case dot11AuthAlgrthm_Open:
568 case dot11AuthAlgrthm_Shared:
569 case dot11AuthAlgrthm_Auto:
571 (u8)psecuritypriv->dot11PrivacyKeyIndex;
573 case dot11AuthAlgrthm_8021X:
576 (u8)psecuritypriv->dot118021XGrpKeyid;
578 pattrib->key_idx = 0;
581 pattrib->key_idx = 0;
587 switch (pattrib->encrypt) {
588 case WLAN_CIPHER_SUITE_WEP40:
589 case WLAN_CIPHER_SUITE_WEP104:
590 pattrib->iv_len = IEEE80211_WEP_IV_LEN;
591 pattrib->icv_len = IEEE80211_WEP_ICV_LEN;
594 case WLAN_CIPHER_SUITE_TKIP:
595 pattrib->iv_len = IEEE80211_TKIP_IV_LEN;
596 pattrib->icv_len = IEEE80211_TKIP_ICV_LEN;
598 if (!padapter->securitypriv.busetkipkey) {
599 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
600 ("\npadapter->securitypriv.busetkip"
601 "key(%d) == false drop packet\n",
602 padapter->securitypriv.busetkipkey));
608 case WLAN_CIPHER_SUITE_CCMP:
609 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
610 ("pattrib->encrypt =%d (WLAN_CIPHER_SUITE_CCMP)\n",
612 pattrib->iv_len = IEEE80211_CCMP_HDR_LEN;
613 pattrib->icv_len = IEEE80211_CCMP_MIC_LEN;
618 pattrib->icv_len = 0;
622 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
623 ("update_attrib: encrypt =%d\n", pattrib->encrypt));
625 if (pattrib->encrypt && !psecuritypriv->hw_decrypted) {
626 pattrib->bswenc = true;
627 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
628 ("update_attrib: encrypt =%d bswenc = true\n",
631 pattrib->bswenc = false;
632 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
633 ("update_attrib: bswenc = false\n"));
635 update_attrib_phy_info(pattrib, psta);
642 static int xmitframe_addmic(struct rtw_adapter *padapter,
643 struct xmit_frame *pxmitframe) {
644 struct mic_data micdata;
645 struct sta_info *stainfo;
646 struct pkt_attrib *pattrib = &pxmitframe->attrib;
647 struct security_priv *psecuritypriv = &padapter->securitypriv;
648 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
649 int curfragnum, length;
650 u8 *pframe, *payload, mic[8];
651 u8 priority[4]= {0x0, 0x0, 0x0, 0x0};
652 u8 hw_hdr_offset = 0;
653 int bmcst = is_multicast_ether_addr(pattrib->ra);
656 stainfo = pattrib->psta;
658 DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
659 stainfo = rtw_get_stainfo23a(&padapter->stapriv, &pattrib->ra[0]);
663 DBG_8723A("%s, psta == NUL\n", __func__);
667 if (!(stainfo->state &_FW_LINKED)) {
668 DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n",
669 __func__, stainfo->state);
673 hw_hdr_offset = TXDESC_OFFSET;
675 if (pattrib->encrypt == WLAN_CIPHER_SUITE_TKIP) {
676 /* encode mic code */
678 u8 null_key[16]={0x0, 0x0, 0x0, 0x0,
683 pframe = pxmitframe->buf_addr + hw_hdr_offset;
686 if (!memcmp(psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey, null_key, 16)) {
689 /* start to calculate the mic code */
690 rtw_secmicsetkey23a(&micdata, psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey);
692 if (!memcmp(&stainfo->dot11tkiptxmickey.skey[0],
696 /* start to calculate the mic code */
697 rtw_secmicsetkey23a(&micdata, &stainfo->dot11tkiptxmickey.skey[0]);
700 if (pframe[1] & 1) { /* ToDS == 1 */
702 rtw_secmicappend23a(&micdata, &pframe[16], 6);
703 if (pframe[1] & 2) /* From Ds == 1 */
704 rtw_secmicappend23a(&micdata,
707 rtw_secmicappend23a(&micdata,
709 } else { /* ToDS == 0 */
711 rtw_secmicappend23a(&micdata, &pframe[4], 6);
712 if (pframe[1] & 2) /* From Ds == 1 */
713 rtw_secmicappend23a(&micdata,
716 rtw_secmicappend23a(&micdata,
720 /* if (pmlmepriv->qos_option == 1) */
722 priority[0] = (u8)pxmitframe->attrib.priority;
724 rtw_secmicappend23a(&micdata, &priority[0], 4);
728 for (curfragnum = 0; curfragnum < pattrib->nr_frags;
730 payload = PTR_ALIGN(payload, 4);
731 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
732 ("=== curfragnum =%d, pframe = 0x%.2x, "
733 "0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x, 0x"
734 "%.2x, 0x%.2x, 0x%.2x,!!!\n",
735 curfragnum, *payload, *(payload + 1),
736 *(payload + 2), *(payload + 3),
737 *(payload + 4), *(payload + 5),
738 *(payload + 6), *(payload + 7)));
740 payload = payload + pattrib->hdrlen +
742 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
743 ("curfragnum =%d pattrib->hdrlen =%d "
744 "pattrib->iv_len =%d", curfragnum,
745 pattrib->hdrlen, pattrib->iv_len));
746 if ((curfragnum + 1) == pattrib->nr_frags) {
747 length = pattrib->last_txcmdsz -
751 pattrib->icv_len : 0);
752 rtw_secmicappend23a(&micdata, payload,
754 payload = payload + length;
756 length = pxmitpriv->frag_len -
760 pattrib->icv_len : 0);
761 rtw_secmicappend23a(&micdata, payload,
763 payload = payload + length +
765 RT_TRACE(_module_rtl871x_xmit_c_,
767 ("curfragnum =%d length =%d "
768 "pattrib->icv_len =%d",
773 rtw_secgetmic23a(&micdata, &mic[0]);
774 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
775 ("xmitframe_addmic: before add mic code!!\n"));
776 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
777 ("xmitframe_addmic: pattrib->last_txcmdsz ="
778 "%d!!!\n", pattrib->last_txcmdsz));
779 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
780 ("xmitframe_addmic: mic[0]= 0x%.2x , mic[1]="
781 "0x%.2x , mic[2]= 0x%.2x , mic[3]= 0x%.2x\n"
782 "mic[4]= 0x%.2x , mic[5]= 0x%.2x , mic[6]= 0x%.2x "
783 ", mic[7]= 0x%.2x !!!!\n", mic[0], mic[1],
784 mic[2], mic[3], mic[4], mic[5], mic[6],
786 /* add mic code and add the mic code length
789 memcpy(payload, &mic[0], 8);
790 pattrib->last_txcmdsz += 8;
792 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
793 ("\n ======== last pkt ========\n"));
794 payload = payload - pattrib->last_txcmdsz + 8;
795 for (curfragnum = 0; curfragnum < pattrib->last_txcmdsz;
796 curfragnum = curfragnum + 8)
797 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
798 (" %.2x, %.2x, %.2x, %.2x, %.2x, "
799 " %.2x, %.2x, %.2x ",
800 *(payload + curfragnum),
801 *(payload + curfragnum + 1),
802 *(payload + curfragnum + 2),
803 *(payload + curfragnum + 3),
804 *(payload + curfragnum + 4),
805 *(payload + curfragnum + 5),
806 *(payload + curfragnum + 6),
807 *(payload + curfragnum + 7)));
809 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
810 ("xmitframe_addmic: rtw_get_stainfo23a =="
818 static int xmitframe_swencrypt(struct rtw_adapter *padapter,
819 struct xmit_frame *pxmitframe)
821 struct pkt_attrib *pattrib = &pxmitframe->attrib;
823 /* if ((psecuritypriv->sw_encrypt)||(pattrib->bswenc)) */
824 if (pattrib->bswenc) {
825 /* DBG_8723A("start xmitframe_swencrypt\n"); */
826 RT_TRACE(_module_rtl871x_xmit_c_, _drv_alert_,
827 ("### xmitframe_swencrypt\n"));
828 switch (pattrib->encrypt) {
829 case WLAN_CIPHER_SUITE_WEP40:
830 case WLAN_CIPHER_SUITE_WEP104:
831 rtw_wep_encrypt23a(padapter, pxmitframe);
833 case WLAN_CIPHER_SUITE_TKIP:
834 rtw_tkip_encrypt23a(padapter, pxmitframe);
836 case WLAN_CIPHER_SUITE_CCMP:
837 rtw_aes_encrypt23a(padapter, pxmitframe);
844 RT_TRACE(_module_rtl871x_xmit_c_, _drv_notice_,
845 ("### xmitframe_hwencrypt\n"));
851 static int rtw_make_wlanhdr(struct rtw_adapter *padapter, u8 *hdr,
852 struct pkt_attrib *pattrib)
854 struct ieee80211_hdr *pwlanhdr = (struct ieee80211_hdr *)hdr;
855 struct ieee80211_qos_hdr *qoshdr;
856 struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
857 u8 qos_option = false;
860 struct sta_info *psta;
862 int bmcst = is_multicast_ether_addr(pattrib->ra);
865 psta = pattrib->psta;
867 DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
869 psta = rtw_get_bcmc_stainfo23a(padapter);
871 psta = rtw_get_stainfo23a(&padapter->stapriv, pattrib->ra);
876 DBG_8723A("%s, psta == NUL\n", __func__);
880 if (!(psta->state &_FW_LINKED)) {
881 DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
885 memset(hdr, 0, WLANHDR_OFFSET);
887 pwlanhdr->frame_control = cpu_to_le16(pattrib->type);
889 if (pattrib->type & IEEE80211_FTYPE_DATA) {
890 if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
891 /* to_ds = 1, fr_ds = 0; */
892 /* Data transfer to AP */
893 pwlanhdr->frame_control |=
894 cpu_to_le16(IEEE80211_FCTL_TODS);
895 ether_addr_copy(pwlanhdr->addr1, get_bssid(pmlmepriv));
896 ether_addr_copy(pwlanhdr->addr2, pattrib->src);
897 ether_addr_copy(pwlanhdr->addr3, pattrib->dst);
899 if (pmlmepriv->qos_option)
902 } else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
903 /* to_ds = 0, fr_ds = 1; */
904 pwlanhdr->frame_control |=
905 cpu_to_le16(IEEE80211_FCTL_FROMDS);
906 ether_addr_copy(pwlanhdr->addr1, pattrib->dst);
907 ether_addr_copy(pwlanhdr->addr2, get_bssid(pmlmepriv));
908 ether_addr_copy(pwlanhdr->addr3, pattrib->src);
910 if (psta->qos_option)
912 } else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) ||
913 check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
914 ether_addr_copy(pwlanhdr->addr1, pattrib->dst);
915 ether_addr_copy(pwlanhdr->addr2, pattrib->src);
916 ether_addr_copy(pwlanhdr->addr3, get_bssid(pmlmepriv));
918 if (psta->qos_option)
922 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("fw_state:%x is not allowed to xmit frame\n", get_fwstate(pmlmepriv)));
927 pwlanhdr->frame_control |=
928 cpu_to_le16(IEEE80211_FCTL_MOREDATA);
929 if (pattrib->encrypt)
930 pwlanhdr->frame_control |=
931 cpu_to_le16(IEEE80211_FCTL_PROTECTED);
933 qoshdr = (struct ieee80211_qos_hdr *)hdr;
935 qoshdr->qos_ctrl = cpu_to_le16(
936 pattrib->priority & IEEE80211_QOS_CTL_TID_MASK);
938 qoshdr->qos_ctrl |= cpu_to_le16(
939 (pattrib->ack_policy << 5) &
940 IEEE80211_QOS_CTL_ACK_POLICY_MASK);
944 cpu_to_le16(IEEE80211_QOS_CTL_EOSP);
946 /* TODO: fill HT Control Field */
948 /* Update Seq Num will be handled by f/w */
950 psta->sta_xmitpriv.txseq_tid[pattrib->priority]++;
951 psta->sta_xmitpriv.txseq_tid[pattrib->priority] &= 0xFFF;
952 pattrib->seqnum = psta->sta_xmitpriv.txseq_tid[pattrib->priority];
953 /* We dont need to worry about frag bits here */
954 pwlanhdr->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(
956 /* check if enable ampdu */
957 if (pattrib->ht_en && psta->htpriv.ampdu_enable) {
958 if (pattrib->priority >= 16)
959 printk(KERN_WARNING "%s: Invalid "
960 "pattrib->priority %i\n",
961 __func__, pattrib->priority);
962 if (psta->htpriv.agg_enable_bitmap &
963 BIT(pattrib->priority))
964 pattrib->ampdu_en = true;
966 /* re-check if enable ampdu by BA_starting_seqctrl */
967 if (pattrib->ampdu_en) {
970 tx_seq = psta->BA_starting_seqctrl[pattrib->priority & 0x0f];
972 /* check BA_starting_seqctrl */
973 if (SN_LESS(pattrib->seqnum, tx_seq)) {
974 /* DBG_8723A("tx ampdu seqnum(%d) < tx_seq(%d)\n", pattrib->seqnum, tx_seq); */
975 pattrib->ampdu_en = false;/* AGG BK */
976 } else if (SN_EQUAL(pattrib->seqnum, tx_seq)) {
977 psta->BA_starting_seqctrl[pattrib->priority & 0x0f] = (tx_seq+1)&0xfff;
978 pattrib->ampdu_en = true;/* AGG EN */
980 /* DBG_8723A("tx ampdu over run\n"); */
981 psta->BA_starting_seqctrl[pattrib->priority & 0x0f] = (pattrib->seqnum+1)&0xfff;
982 pattrib->ampdu_en = true;/* AGG EN */
991 s32 rtw_txframes_pending23a(struct rtw_adapter *padapter)
993 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
995 return (!list_empty(&pxmitpriv->be_pending.queue)) ||
996 (!list_empty(&pxmitpriv->bk_pending.queue)) ||
997 (!list_empty(&pxmitpriv->vi_pending.queue)) ||
998 (!list_empty(&pxmitpriv->vo_pending.queue));
1001 s32 rtw_txframes_sta_ac_pending23a(struct rtw_adapter *padapter,
1002 struct pkt_attrib *pattrib)
1004 struct sta_info *psta;
1005 struct tx_servq *ptxservq;
1006 int priority = pattrib->priority;
1008 if (pattrib->psta) {
1009 psta = pattrib->psta;
1011 DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
1012 psta = rtw_get_stainfo23a(&padapter->stapriv, &pattrib->ra[0]);
1015 DBG_8723A("%s, psta == NUL\n", __func__);
1018 if (!(psta->state &_FW_LINKED)) {
1019 DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__,
1026 ptxservq = &psta->sta_xmitpriv.bk_q;
1030 ptxservq = &psta->sta_xmitpriv.vi_q;
1034 ptxservq = &psta->sta_xmitpriv.vo_q;
1039 ptxservq = &psta->sta_xmitpriv.be_q;
1042 return ptxservq->qcnt;
1047 This sub-routine will perform all the following:
1049 1. remove 802.3 header.
1050 2. create wlan_header, based on the info in pxmitframe
1051 3. append sta's iv/ext-iv
1053 5. move frag chunk from pframe to pxmitframe->mem
1054 6. apply sw-encrypt, if necessary.
1057 int rtw_xmitframe_coalesce23a(struct rtw_adapter *padapter, struct sk_buff *skb,
1058 struct xmit_frame *pxmitframe)
1060 struct sta_info *psta;
1061 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
1062 struct pkt_attrib *pattrib = &pxmitframe->attrib;
1063 struct ieee80211_hdr *hdr;
1064 s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
1065 u8 *pframe, *mem_start;
1068 u8 *pdata = skb->data;
1069 int data_len = skb->len;
1070 s32 bmcst = is_multicast_ether_addr(pattrib->ra);
1074 psta = pattrib->psta;
1076 DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
1077 psta = rtw_get_stainfo23a(&padapter->stapriv, pattrib->ra);
1081 DBG_8723A("%s, psta == NUL\n", __func__);
1085 if (!(psta->state &_FW_LINKED)) {
1086 DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n",
1087 __func__, psta->state);
1091 if (!pxmitframe->buf_addr) {
1092 DBG_8723A("==> %s buf_addr == NULL\n", __func__);
1096 pbuf_start = pxmitframe->buf_addr;
1098 hw_hdr_offset = TXDESC_OFFSET;
1100 mem_start = pbuf_start + hw_hdr_offset;
1102 if (rtw_make_wlanhdr(padapter, mem_start, pattrib) == _FAIL) {
1103 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
1104 ("%s: rtw_make_wlanhdr fail; drop pkt\n", __func__));
1109 pdata += pattrib->pkt_hdrlen;
1110 data_len -= pattrib->pkt_hdrlen;
1113 frg_len = pxmitpriv->frag_len - 4;/* 2346-4 = 2342 */
1121 hdr = (struct ieee80211_hdr *)mem_start;
1123 pframe += pattrib->hdrlen;
1124 mpdu_len -= pattrib->hdrlen;
1126 /* adding icv, if necessary... */
1127 if (pattrib->iv_len) {
1129 switch (pattrib->encrypt) {
1130 case WLAN_CIPHER_SUITE_WEP40:
1131 case WLAN_CIPHER_SUITE_WEP104:
1132 WEP_IV(pattrib->iv, psta->dot11txpn,
1135 case WLAN_CIPHER_SUITE_TKIP:
1137 TKIP_IV(pattrib->iv,
1141 TKIP_IV(pattrib->iv,
1142 psta->dot11txpn, 0);
1144 case WLAN_CIPHER_SUITE_CCMP:
1151 psta->dot11txpn, 0);
1156 memcpy(pframe, pattrib->iv, pattrib->iv_len);
1158 RT_TRACE(_module_rtl871x_xmit_c_, _drv_notice_,
1159 ("rtw_xmiaframe_coalesce23a: keyid =%d pattrib"
1160 "->iv[3]=%.2x pframe =%.2x %.2x %.2x %.2x\n",
1161 padapter->securitypriv.dot11PrivacyKeyIndex,
1162 pattrib->iv[3], *pframe, *(pframe+1),
1163 *(pframe+2), *(pframe+3)));
1164 pframe += pattrib->iv_len;
1165 mpdu_len -= pattrib->iv_len;
1168 llc_sz = rtw_put_snap23a(pframe, pattrib->ether_type);
1173 if (pattrib->icv_len > 0 && pattrib->bswenc)
1174 mpdu_len -= pattrib->icv_len;
1177 /* don't do fragment to broadcast/multicast packets */
1178 mem_sz = min_t(s32, data_len, pattrib->pktlen);
1180 mem_sz = min_t(s32, data_len, mpdu_len);
1182 memcpy(pframe, pdata, mem_sz);
1188 if ((pattrib->icv_len >0) && (pattrib->bswenc)) {
1189 memcpy(pframe, pattrib->icv, pattrib->icv_len);
1190 pframe += pattrib->icv_len;
1195 if (bmcst || data_len <= 0) {
1196 pattrib->nr_frags = frg_inx;
1198 pattrib->last_txcmdsz = pattrib->hdrlen +
1200 ((pattrib->nr_frags == 1) ?
1202 ((pattrib->bswenc) ?
1203 pattrib->icv_len : 0) + mem_sz;
1204 hdr->frame_control &=
1205 ~cpu_to_le16(IEEE80211_FCTL_MOREFRAGS);
1209 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
1210 ("%s: There're still something in packet!\n",
1213 hdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_MOREFRAGS);
1215 mem_start = PTR_ALIGN(pframe, 4) + hw_hdr_offset;
1216 memcpy(mem_start, pbuf_start + hw_hdr_offset, pattrib->hdrlen);
1219 if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
1220 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
1221 ("xmitframe_addmic(padapter, pxmitframe) == _FAIL\n"));
1222 DBG_8723A("xmitframe_addmic(padapter, pxmitframe) == _FAIL\n");
1227 xmitframe_swencrypt(padapter, pxmitframe);
1230 update_attrib_vcs_info(padapter, pxmitframe);
1232 pattrib->vcs_mode = NONE_VCS;
1238 /* Logical Link Control(LLC) SubNetwork Attachment Point(SNAP) header
1239 * IEEE LLC/SNAP header contains 8 octets
1240 * First 3 octets comprise the LLC portion
1241 * SNAP portion, 5 octets, is divided into two fields:
1242 * Organizationally Unique Identifier(OUI), 3 octets,
1243 * type, defined by that organization, 2 octets.
1245 s32 rtw_put_snap23a(u8 *data, u16 h_proto)
1247 struct ieee80211_snap_hdr *snap;
1250 snap = (struct ieee80211_snap_hdr *)data;
1255 if (h_proto == 0x8137 || h_proto == 0x80f3)
1259 snap->oui[0] = oui[0];
1260 snap->oui[1] = oui[1];
1261 snap->oui[2] = oui[2];
1262 *(u16 *)(data + SNAP_SIZE) = htons(h_proto);
1263 return SNAP_SIZE + sizeof(u16);
1266 void rtw_update_protection23a(struct rtw_adapter *padapter, u8 *ie, uint ie_len)
1268 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
1269 struct registry_priv *pregistrypriv = &padapter->registrypriv;
1273 switch (pregistrypriv->vrtl_carrier_sense) {
1275 pxmitpriv->vcs = NONE_VCS;
1281 p = cfg80211_find_ie(WLAN_EID_ERP_INFO, ie, ie_len);
1283 pxmitpriv->vcs = NONE_VCS;
1285 protection = (*(p + 2)) & BIT(1);
1287 if (pregistrypriv->vcs_type == RTS_CTS)
1288 pxmitpriv->vcs = RTS_CTS;
1290 pxmitpriv->vcs = CTS_TO_SELF;
1292 pxmitpriv->vcs = NONE_VCS;
1299 void rtw_count_tx_stats23a(struct rtw_adapter *padapter, struct xmit_frame *pxmitframe, int sz)
1301 struct sta_info *psta = NULL;
1302 struct stainfo_stats *pstats = NULL;
1303 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
1304 struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
1306 if ((pxmitframe->frame_tag&0x0f) == DATA_FRAMETAG) {
1307 pxmitpriv->tx_bytes += sz;
1308 pmlmepriv->LinkDetectInfo.NumTxOkInPeriod++;
1310 psta = pxmitframe->attrib.psta;
1312 pstats = &psta->sta_stats;
1314 pstats->tx_bytes += sz;
1319 struct xmit_buf *rtw_alloc_xmitbuf23a_ext(struct xmit_priv *pxmitpriv)
1322 struct xmit_buf *pxmitbuf = NULL;
1323 struct list_head *phead;
1324 struct rtw_queue *pfree_queue = &pxmitpriv->free_xmit_extbuf_queue;
1326 spin_lock_irqsave(&pfree_queue->lock, irqL);
1328 phead = get_list_head(pfree_queue);
1330 if (!list_empty(phead)) {
1331 pxmitbuf = list_first_entry(phead, struct xmit_buf, list);
1333 list_del_init(&pxmitbuf->list);
1335 pxmitpriv->free_xmit_extbuf_cnt--;
1336 pxmitbuf->priv_data = NULL;
1337 pxmitbuf->ext_tag = true;
1339 if (pxmitbuf->sctx) {
1340 DBG_8723A("%s pxmitbuf->sctx is not NULL\n", __func__);
1341 rtw23a_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
1345 spin_unlock_irqrestore(&pfree_queue->lock, irqL);
1350 int rtw_free_xmitbuf_ext23a(struct xmit_priv *pxmitpriv,
1351 struct xmit_buf *pxmitbuf)
1354 struct rtw_queue *pfree_queue = &pxmitpriv->free_xmit_extbuf_queue;
1356 if (pxmitbuf == NULL)
1359 spin_lock_irqsave(&pfree_queue->lock, irqL);
1361 list_del_init(&pxmitbuf->list);
1363 list_add_tail(&pxmitbuf->list, get_list_head(pfree_queue));
1364 pxmitpriv->free_xmit_extbuf_cnt++;
1366 spin_unlock_irqrestore(&pfree_queue->lock, irqL);
1371 struct xmit_buf *rtw_alloc_xmitbuf23a(struct xmit_priv *pxmitpriv)
1374 struct xmit_buf *pxmitbuf = NULL;
1375 struct list_head *phead;
1376 struct rtw_queue *pfree_xmitbuf_queue = &pxmitpriv->free_xmitbuf_queue;
1378 /* DBG_8723A("+rtw_alloc_xmitbuf23a\n"); */
1380 spin_lock_irqsave(&pfree_xmitbuf_queue->lock, irqL);
1382 phead = get_list_head(pfree_xmitbuf_queue);
1384 if (!list_empty(phead)) {
1385 pxmitbuf = list_first_entry(phead, struct xmit_buf, list);
1387 list_del_init(&pxmitbuf->list);
1389 pxmitpriv->free_xmitbuf_cnt--;
1390 pxmitbuf->priv_data = NULL;
1391 pxmitbuf->ext_tag = false;
1392 pxmitbuf->flags = XMIT_VO_QUEUE;
1394 if (pxmitbuf->sctx) {
1395 DBG_8723A("%s pxmitbuf->sctx is not NULL\n", __func__);
1396 rtw23a_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
1400 spin_unlock_irqrestore(&pfree_xmitbuf_queue->lock, irqL);
1405 int rtw_free_xmitbuf23a(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
1408 struct rtw_queue *pfree_xmitbuf_queue = &pxmitpriv->free_xmitbuf_queue;
1410 /* DBG_8723A("+rtw_free_xmitbuf23a\n"); */
1412 if (pxmitbuf == NULL)
1415 if (pxmitbuf->sctx) {
1416 DBG_8723A("%s pxmitbuf->sctx is not NULL\n", __func__);
1417 rtw23a_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_FREE);
1420 if (pxmitbuf->ext_tag) {
1421 rtw_free_xmitbuf_ext23a(pxmitpriv, pxmitbuf);
1423 spin_lock_irqsave(&pfree_xmitbuf_queue->lock, irqL);
1425 list_del_init(&pxmitbuf->list);
1427 list_add_tail(&pxmitbuf->list,
1428 get_list_head(pfree_xmitbuf_queue));
1430 pxmitpriv->free_xmitbuf_cnt++;
1431 spin_unlock_irqrestore(&pfree_xmitbuf_queue->lock, irqL);
1437 static void rtw_init_xmitframe(struct xmit_frame *pxframe)
1439 if (pxframe != NULL) {
1440 /* default value setting */
1441 pxframe->buf_addr = NULL;
1442 pxframe->pxmitbuf = NULL;
1444 memset(&pxframe->attrib, 0, sizeof(struct pkt_attrib));
1445 /* pxframe->attrib.psta = NULL; */
1447 pxframe->frame_tag = DATA_FRAMETAG;
1449 pxframe->pkt = NULL;
1450 pxframe->pkt_offset = 1;/* default use pkt_offset to fill tx desc */
1452 pxframe->ack_report = 0;
1459 2. RXENTRY (rx_thread or RX_ISR/RX_CallBack)
1461 If we turn on USE_RXTHREAD, then, no need for critical section.
1462 Otherwise, we must use _enter/_exit critical to protect free_xmit_queue...
1464 Must be very very cautious...
1467 static struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv)
1469 struct xmit_frame *pxframe = NULL;
1470 struct list_head *plist, *phead;
1471 struct rtw_queue *pfree_xmit_queue = &pxmitpriv->free_xmit_queue;
1473 spin_lock_bh(&pfree_xmit_queue->lock);
1475 if (list_empty(&pfree_xmit_queue->queue)) {
1476 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
1477 ("rtw_alloc_xmitframe:%d\n",
1478 pxmitpriv->free_xmitframe_cnt));
1481 phead = get_list_head(pfree_xmit_queue);
1483 plist = phead->next;
1485 pxframe = container_of(plist, struct xmit_frame, list);
1487 list_del_init(&pxframe->list);
1488 pxmitpriv->free_xmitframe_cnt--;
1489 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
1490 ("rtw_alloc_xmitframe():free_xmitframe_cnt =%d\n",
1491 pxmitpriv->free_xmitframe_cnt));
1494 spin_unlock_bh(&pfree_xmit_queue->lock);
1496 rtw_init_xmitframe(pxframe);
1501 struct xmit_frame *rtw_alloc_xmitframe23a_ext(struct xmit_priv *pxmitpriv)
1503 struct xmit_frame *pxframe = NULL;
1504 struct list_head *plist, *phead;
1505 struct rtw_queue *queue = &pxmitpriv->free_xframe_ext_queue;
1507 spin_lock_bh(&queue->lock);
1509 if (list_empty(&queue->queue)) {
1510 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, ("rtw_alloc_xmitframe23a_ext:%d\n", pxmitpriv->free_xframe_ext_cnt));
1513 phead = get_list_head(queue);
1514 plist = phead->next;
1515 pxframe = container_of(plist, struct xmit_frame, list);
1517 list_del_init(&pxframe->list);
1518 pxmitpriv->free_xframe_ext_cnt--;
1519 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, ("rtw_alloc_xmitframe23a_ext():free_xmitframe_cnt =%d\n", pxmitpriv->free_xframe_ext_cnt));
1522 spin_unlock_bh(&queue->lock);
1524 rtw_init_xmitframe(pxframe);
1529 s32 rtw_free_xmitframe23a(struct xmit_priv *pxmitpriv, struct xmit_frame *pxmitframe)
1531 struct rtw_queue *queue = NULL;
1532 struct rtw_adapter *padapter = pxmitpriv->adapter;
1533 struct sk_buff *pndis_pkt = NULL;
1535 if (pxmitframe == NULL) {
1536 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("====== rtw_free_xmitframe23a():pxmitframe == NULL!!!!!!!!!!\n"));
1540 if (pxmitframe->pkt) {
1541 pndis_pkt = pxmitframe->pkt;
1542 pxmitframe->pkt = NULL;
1545 if (pxmitframe->ext_tag == 0)
1546 queue = &pxmitpriv->free_xmit_queue;
1547 else if (pxmitframe->ext_tag == 1)
1548 queue = &pxmitpriv->free_xframe_ext_queue;
1551 goto check_pkt_complete;
1552 spin_lock_bh(&queue->lock);
1554 list_del_init(&pxmitframe->list);
1555 list_add_tail(&pxmitframe->list, get_list_head(queue));
1556 if (pxmitframe->ext_tag == 0) {
1557 pxmitpriv->free_xmitframe_cnt++;
1558 RT_TRACE(_module_rtl871x_xmit_c_, _drv_debug_, ("rtw_free_xmitframe23a():free_xmitframe_cnt =%d\n", pxmitpriv->free_xmitframe_cnt));
1559 } else if (pxmitframe->ext_tag == 1) {
1560 pxmitpriv->free_xframe_ext_cnt++;
1561 RT_TRACE(_module_rtl871x_xmit_c_, _drv_debug_, ("rtw_free_xmitframe23a():free_xframe_ext_cnt =%d\n", pxmitpriv->free_xframe_ext_cnt));
1564 spin_unlock_bh(&queue->lock);
1569 rtw_os_pkt_complete23a(padapter, pndis_pkt);
1576 void rtw_free_xmitframe_queue23a(struct xmit_priv *pxmitpriv,
1577 struct rtw_queue *pframequeue)
1579 struct list_head *plist, *phead, *ptmp;
1580 struct xmit_frame *pxmitframe;
1582 spin_lock_bh(&pframequeue->lock);
1584 phead = get_list_head(pframequeue);
1586 list_for_each_safe(plist, ptmp, phead) {
1587 pxmitframe = container_of(plist, struct xmit_frame, list);
1589 rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
1591 spin_unlock_bh(&pframequeue->lock);
1595 int rtw_xmitframe_enqueue23a(struct rtw_adapter *padapter,
1596 struct xmit_frame *pxmitframe)
1598 if (rtw_xmit23a_classifier(padapter, pxmitframe) == _FAIL) {
1599 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
1600 ("rtw_xmitframe_enqueue23a: drop xmit pkt for "
1601 "classifier fail\n"));
1608 static struct xmit_frame *
1609 dequeue_one_xmitframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit,
1610 struct tx_servq *ptxservq, struct rtw_queue *pframe_queue)
1612 struct list_head *phead;
1613 struct xmit_frame *pxmitframe = NULL;
1615 phead = get_list_head(pframe_queue);
1617 if (!list_empty(phead)) {
1618 pxmitframe = list_first_entry(phead, struct xmit_frame, list);
1619 list_del_init(&pxmitframe->list);
1626 rtw_dequeue_xframe23a(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i,
1629 struct list_head *sta_plist, *sta_phead, *ptmp;
1630 struct hw_xmit *phwxmit;
1631 struct tx_servq *ptxservq = NULL;
1632 struct rtw_queue *pframe_queue = NULL;
1633 struct xmit_frame *pxmitframe = NULL;
1634 struct rtw_adapter *padapter = pxmitpriv->adapter;
1635 struct registry_priv *pregpriv = &padapter->registrypriv;
1642 if (pregpriv->wifi_spec == 1) {
1645 for (j = 0; j < 4; j++)
1646 inx[j] = pxmitpriv->wmm_para_seq[j];
1649 spin_lock_bh(&pxmitpriv->lock);
1651 for (i = 0; i < entry; i++) {
1652 phwxmit = phwxmit_i + inx[i];
1654 sta_phead = get_list_head(phwxmit->sta_queue);
1656 list_for_each_safe(sta_plist, ptmp, sta_phead) {
1657 ptxservq = container_of(sta_plist, struct tx_servq,
1660 pframe_queue = &ptxservq->sta_pending;
1662 pxmitframe = dequeue_one_xmitframe(pxmitpriv, phwxmit, ptxservq, pframe_queue);
1667 /* Remove sta node when there is no pending packets. */
1668 /* must be done after get_next and
1670 if (list_empty(&pframe_queue->queue))
1671 list_del_init(&ptxservq->tx_pending);
1677 spin_unlock_bh(&pxmitpriv->lock);
1681 struct tx_servq *rtw_get_sta_pending23a(struct rtw_adapter *padapter, struct sta_info *psta, int up, u8 *ac)
1683 struct tx_servq *ptxservq = NULL;
1688 ptxservq = &psta->sta_xmitpriv.bk_q;
1690 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, ("rtw_get_sta_pending23a : BK\n"));
1694 ptxservq = &psta->sta_xmitpriv.vi_q;
1696 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, ("rtw_get_sta_pending23a : VI\n"));
1700 ptxservq = &psta->sta_xmitpriv.vo_q;
1702 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, ("rtw_get_sta_pending23a : VO\n"));
1707 ptxservq = &psta->sta_xmitpriv.be_q;
1709 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, ("rtw_get_sta_pending23a : BE\n"));
1716 * Will enqueue pxmitframe to the proper queue,
1717 * and indicate it to xx_pending list.....
1719 int rtw_xmit23a_classifier(struct rtw_adapter *padapter,
1720 struct xmit_frame *pxmitframe)
1722 struct sta_info *psta;
1723 struct tx_servq *ptxservq;
1724 struct pkt_attrib *pattrib = &pxmitframe->attrib;
1725 struct sta_priv *pstapriv = &padapter->stapriv;
1726 struct hw_xmit *phwxmits = padapter->xmitpriv.hwxmits;
1730 if (pattrib->psta) {
1731 psta = pattrib->psta;
1733 DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
1734 psta = rtw_get_stainfo23a(pstapriv, pattrib->ra);
1738 DBG_8723A("rtw_xmit23a_classifier: psta == NULL\n");
1739 RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
1740 ("rtw_xmit23a_classifier: psta == NULL\n"));
1743 if (!(psta->state & _FW_LINKED)) {
1744 DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__,
1748 ptxservq = rtw_get_sta_pending23a(padapter, psta, pattrib->priority,
1751 if (list_empty(&ptxservq->tx_pending)) {
1752 list_add_tail(&ptxservq->tx_pending,
1753 get_list_head(phwxmits[ac_index].sta_queue));
1756 list_add_tail(&pxmitframe->list, get_list_head(&ptxservq->sta_pending));
1758 phwxmits[ac_index].accnt++;
1763 void rtw_alloc_hwxmits23a(struct rtw_adapter *padapter)
1765 struct hw_xmit *hwxmits;
1766 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
1769 pxmitpriv->hwxmit_entry = HWXMIT_ENTRY;
1771 size = sizeof(struct hw_xmit) * (pxmitpriv->hwxmit_entry + 1);
1772 pxmitpriv->hwxmits = kzalloc(size, GFP_KERNEL);
1774 hwxmits = pxmitpriv->hwxmits;
1776 if (pxmitpriv->hwxmit_entry == 5) {
1777 /* pxmitpriv->bmc_txqueue.head = 0; */
1778 /* hwxmits[0] .phwtxqueue = &pxmitpriv->bmc_txqueue; */
1779 hwxmits[0] .sta_queue = &pxmitpriv->bm_pending;
1781 /* pxmitpriv->vo_txqueue.head = 0; */
1782 /* hwxmits[1] .phwtxqueue = &pxmitpriv->vo_txqueue; */
1783 hwxmits[1] .sta_queue = &pxmitpriv->vo_pending;
1785 /* pxmitpriv->vi_txqueue.head = 0; */
1786 /* hwxmits[2] .phwtxqueue = &pxmitpriv->vi_txqueue; */
1787 hwxmits[2] .sta_queue = &pxmitpriv->vi_pending;
1789 /* pxmitpriv->bk_txqueue.head = 0; */
1790 /* hwxmits[3] .phwtxqueue = &pxmitpriv->bk_txqueue; */
1791 hwxmits[3] .sta_queue = &pxmitpriv->bk_pending;
1793 /* pxmitpriv->be_txqueue.head = 0; */
1794 /* hwxmits[4] .phwtxqueue = &pxmitpriv->be_txqueue; */
1795 hwxmits[4] .sta_queue = &pxmitpriv->be_pending;
1797 } else if (pxmitpriv->hwxmit_entry == 4) {
1799 /* pxmitpriv->vo_txqueue.head = 0; */
1800 /* hwxmits[0] .phwtxqueue = &pxmitpriv->vo_txqueue; */
1801 hwxmits[0] .sta_queue = &pxmitpriv->vo_pending;
1803 /* pxmitpriv->vi_txqueue.head = 0; */
1804 /* hwxmits[1] .phwtxqueue = &pxmitpriv->vi_txqueue; */
1805 hwxmits[1] .sta_queue = &pxmitpriv->vi_pending;
1807 /* pxmitpriv->be_txqueue.head = 0; */
1808 /* hwxmits[2] .phwtxqueue = &pxmitpriv->be_txqueue; */
1809 hwxmits[2] .sta_queue = &pxmitpriv->be_pending;
1811 /* pxmitpriv->bk_txqueue.head = 0; */
1812 /* hwxmits[3] .phwtxqueue = &pxmitpriv->bk_txqueue; */
1813 hwxmits[3] .sta_queue = &pxmitpriv->bk_pending;
1819 void rtw_free_hwxmits23a(struct rtw_adapter *padapter)
1821 struct hw_xmit *hwxmits;
1822 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
1824 hwxmits = pxmitpriv->hwxmits;
1828 void rtw_init_hwxmits23a(struct hw_xmit *phwxmit, int entry)
1832 for (i = 0; i < entry; i++, phwxmit++)
1836 u32 rtw_get_ff_hwaddr23a(struct xmit_frame *pxmitframe)
1839 struct pkt_attrib *pattrib = &pxmitframe->attrib;
1841 switch (pattrib->qsel) {
1844 addr = BE_QUEUE_INX;
1848 addr = BK_QUEUE_INX;
1852 addr = VI_QUEUE_INX;
1856 addr = VO_QUEUE_INX;
1859 addr = BCN_QUEUE_INX;
1861 case 0x11:/* BC/MC in PS (HIQ) */
1862 addr = HIGH_QUEUE_INX;
1866 addr = MGT_QUEUE_INX;
1873 static void do_queue_select(struct rtw_adapter *padapter, struct pkt_attrib *pattrib)
1877 qsel = pattrib->priority;
1878 RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
1879 ("### do_queue_select priority =%d , qsel = %d\n",
1880 pattrib->priority, qsel));
1882 pattrib->qsel = qsel;
1886 * The main transmit(tx) entry
1890 * 0 success, hardware will handle this xmit frame(packet)
1893 int rtw_xmit23a(struct rtw_adapter *padapter, struct sk_buff *skb)
1895 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
1896 struct xmit_frame *pxmitframe = NULL;
1899 pxmitframe = rtw_alloc_xmitframe(pxmitpriv);
1901 if (pxmitframe == NULL) {
1902 RT_TRACE(_module_xmit_osdep_c_, _drv_err_,
1903 ("rtw_xmit23a: no more pxmitframe\n"));
1907 res = update_attrib(padapter, skb, &pxmitframe->attrib);
1910 RT_TRACE(_module_xmit_osdep_c_, _drv_err_, ("rtw_xmit23a: update attrib fail\n"));
1911 rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
1914 pxmitframe->pkt = skb;
1916 rtw_led_control(padapter, LED_CTL_TX);
1918 do_queue_select(padapter, &pxmitframe->attrib);
1920 #ifdef CONFIG_8723AU_AP_MODE
1921 spin_lock_bh(&pxmitpriv->lock);
1922 if (xmitframe_enqueue_for_sleeping_sta23a(padapter, pxmitframe)) {
1923 spin_unlock_bh(&pxmitpriv->lock);
1926 spin_unlock_bh(&pxmitpriv->lock);
1929 if (rtl8723au_hal_xmit(padapter, pxmitframe) == false)
1935 #if defined(CONFIG_8723AU_AP_MODE)
1937 int xmitframe_enqueue_for_sleeping_sta23a(struct rtw_adapter *padapter, struct xmit_frame *pxmitframe)
1940 struct sta_info *psta = NULL;
1941 struct sta_priv *pstapriv = &padapter->stapriv;
1942 struct pkt_attrib *pattrib = &pxmitframe->attrib;
1943 struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
1944 int bmcst = is_multicast_ether_addr(pattrib->ra);
1946 if (!check_fwstate(pmlmepriv, WIFI_AP_STATE))
1949 if (pattrib->psta) {
1950 psta = pattrib->psta;
1952 DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
1953 psta = rtw_get_stainfo23a(pstapriv, pattrib->ra);
1957 DBG_8723A("%s, psta == NUL\n", __func__);
1961 if (!(psta->state & _FW_LINKED)) {
1962 DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__,
1967 if (pattrib->triggered == 1) {
1969 pattrib->qsel = 0x11;/* HIQ */
1974 spin_lock_bh(&psta->sleep_q.lock);
1976 if (pstapriv->sta_dz_bitmap) {
1977 /* if anyone sta is in ps mode */
1978 list_del_init(&pxmitframe->list);
1980 /* spin_lock_bh(&psta->sleep_q.lock); */
1982 list_add_tail(&pxmitframe->list, get_list_head(&psta->sleep_q));
1986 pstapriv->tim_bitmap |= BIT(0);/* */
1987 pstapriv->sta_dz_bitmap |= BIT(0);
1989 /* DBG_8723A("enqueue, sq_len =%d, tim =%x\n", psta->sleepq_len, pstapriv->tim_bitmap); */
1991 /* tx bc/mc packets after update bcn */
1992 update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
1994 /* spin_unlock_bh(&psta->sleep_q.lock); */
2000 spin_unlock_bh(&psta->sleep_q.lock);
2006 spin_lock_bh(&psta->sleep_q.lock);
2008 if (psta->state&WIFI_SLEEP_STATE) {
2011 if (pstapriv->sta_dz_bitmap & CHKBIT(psta->aid)) {
2012 list_del_init(&pxmitframe->list);
2014 /* spin_lock_bh(&psta->sleep_q.lock); */
2016 list_add_tail(&pxmitframe->list, get_list_head(&psta->sleep_q));
2020 switch (pattrib->priority) {
2023 wmmps_ac = psta->uapsd_bk & BIT(0);
2027 wmmps_ac = psta->uapsd_vi & BIT(0);
2031 wmmps_ac = psta->uapsd_vo & BIT(0);
2036 wmmps_ac = psta->uapsd_be & BIT(0);
2041 psta->sleepq_ac_len++;
2043 if (((psta->has_legacy_ac) && (!wmmps_ac)) ||
2044 ((!psta->has_legacy_ac) && (wmmps_ac))) {
2045 pstapriv->tim_bitmap |= CHKBIT(psta->aid);
2047 if (psta->sleepq_len == 1) {
2048 /* update BCN for TIM IE */
2049 update_beacon23a(padapter, WLAN_EID_TIM,
2054 /* spin_unlock_bh(&psta->sleep_q.lock); */
2056 /* if (psta->sleepq_len > (NR_XMITFRAME>>3)) */
2058 /* wakeup_sta_to_xmit23a(padapter, psta); */
2067 spin_unlock_bh(&psta->sleep_q.lock);
2073 dequeue_xmitframes_to_sleeping_queue(struct rtw_adapter *padapter,
2074 struct sta_info *psta,
2075 struct rtw_queue *pframequeue)
2078 struct list_head *plist, *phead, *ptmp;
2080 struct tx_servq *ptxservq;
2081 struct pkt_attrib *pattrib;
2082 struct xmit_frame *pxmitframe;
2083 struct hw_xmit *phwxmits = padapter->xmitpriv.hwxmits;
2085 phead = get_list_head(pframequeue);
2087 list_for_each_safe(plist, ptmp, phead) {
2088 pxmitframe = container_of(plist, struct xmit_frame, list);
2090 ret = xmitframe_enqueue_for_sleeping_sta23a(padapter, pxmitframe);
2093 pattrib = &pxmitframe->attrib;
2095 ptxservq = rtw_get_sta_pending23a(padapter, psta, pattrib->priority, (u8 *)(&ac_index));
2098 phwxmits[ac_index].accnt--;
2100 /* DBG_8723A("xmitframe_enqueue_for_sleeping_sta23a return false\n"); */
2105 void stop_sta_xmit23a(struct rtw_adapter *padapter, struct sta_info *psta)
2107 struct sta_info *psta_bmc;
2108 struct sta_xmit_priv *pstaxmitpriv;
2109 struct sta_priv *pstapriv = &padapter->stapriv;
2110 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
2112 pstaxmitpriv = &psta->sta_xmitpriv;
2114 /* for BC/MC Frames */
2115 psta_bmc = rtw_get_bcmc_stainfo23a(padapter);
2117 spin_lock_bh(&pxmitpriv->lock);
2119 psta->state |= WIFI_SLEEP_STATE;
2121 pstapriv->sta_dz_bitmap |= CHKBIT(psta->aid);
2123 dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vo_q.sta_pending);
2124 list_del_init(&pstaxmitpriv->vo_q.tx_pending);
2126 dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vi_q.sta_pending);
2127 list_del_init(&pstaxmitpriv->vi_q.tx_pending);
2129 dequeue_xmitframes_to_sleeping_queue(padapter, psta,
2130 &pstaxmitpriv->be_q.sta_pending);
2131 list_del_init(&pstaxmitpriv->be_q.tx_pending);
2133 dequeue_xmitframes_to_sleeping_queue(padapter, psta,
2134 &pstaxmitpriv->bk_q.sta_pending);
2135 list_del_init(&pstaxmitpriv->bk_q.tx_pending);
2137 /* for BC/MC Frames */
2138 pstaxmitpriv = &psta_bmc->sta_xmitpriv;
2139 dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc,
2140 &pstaxmitpriv->be_q.sta_pending);
2141 list_del_init(&pstaxmitpriv->be_q.tx_pending);
2143 spin_unlock_bh(&pxmitpriv->lock);
2146 void wakeup_sta_to_xmit23a(struct rtw_adapter *padapter, struct sta_info *psta)
2148 u8 update_mask = 0, wmmps_ac = 0;
2149 struct sta_info *psta_bmc;
2150 struct list_head *plist, *phead, *ptmp;
2151 struct xmit_frame *pxmitframe = NULL;
2152 struct sta_priv *pstapriv = &padapter->stapriv;
2153 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
2155 spin_lock_bh(&pxmitpriv->lock);
2157 phead = get_list_head(&psta->sleep_q);
2159 list_for_each_safe(plist, ptmp, phead) {
2160 pxmitframe = container_of(plist, struct xmit_frame, list);
2161 list_del_init(&pxmitframe->list);
2163 switch (pxmitframe->attrib.priority) {
2166 wmmps_ac = psta->uapsd_bk & BIT(1);
2170 wmmps_ac = psta->uapsd_vi & BIT(1);
2174 wmmps_ac = psta->uapsd_vo & BIT(1);
2179 wmmps_ac = psta->uapsd_be & BIT(1);
2184 if (psta->sleepq_len > 0)
2185 pxmitframe->attrib.mdata = 1;
2187 pxmitframe->attrib.mdata = 0;
2190 psta->sleepq_ac_len--;
2191 if (psta->sleepq_ac_len > 0) {
2192 pxmitframe->attrib.mdata = 1;
2193 pxmitframe->attrib.eosp = 0;
2195 pxmitframe->attrib.mdata = 0;
2196 pxmitframe->attrib.eosp = 1;
2200 pxmitframe->attrib.triggered = 1;
2201 rtl8723au_hal_xmitframe_enqueue(padapter, pxmitframe);
2204 if (psta->sleepq_len == 0) {
2205 pstapriv->tim_bitmap &= ~CHKBIT(psta->aid);
2207 /* update BCN for TIM IE */
2208 update_mask = BIT(0);
2210 if (psta->state&WIFI_SLEEP_STATE)
2211 psta->state ^= WIFI_SLEEP_STATE;
2213 if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
2214 psta->expire_to = pstapriv->expire_to;
2215 psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
2218 pstapriv->sta_dz_bitmap &= ~CHKBIT(psta->aid);
2221 /* spin_unlock_bh(&psta->sleep_q.lock); */
2222 spin_unlock_bh(&pxmitpriv->lock);
2224 /* for BC/MC Frames */
2225 psta_bmc = rtw_get_bcmc_stainfo23a(padapter);
2229 if ((pstapriv->sta_dz_bitmap&0xfffe) == 0x0) {
2230 /* no any sta in ps mode */
2231 spin_lock_bh(&pxmitpriv->lock);
2233 phead = get_list_head(&psta_bmc->sleep_q);
2235 list_for_each_safe(plist, ptmp, phead) {
2236 pxmitframe = container_of(plist, struct xmit_frame,
2239 list_del_init(&pxmitframe->list);
2241 psta_bmc->sleepq_len--;
2242 if (psta_bmc->sleepq_len > 0)
2243 pxmitframe->attrib.mdata = 1;
2245 pxmitframe->attrib.mdata = 0;
2247 pxmitframe->attrib.triggered = 1;
2248 rtl8723au_hal_xmitframe_enqueue(padapter, pxmitframe);
2250 if (psta_bmc->sleepq_len == 0) {
2251 pstapriv->tim_bitmap &= ~BIT(0);
2252 pstapriv->sta_dz_bitmap &= ~BIT(0);
2254 /* update BCN for TIM IE */
2255 /* update_BCNTIM(padapter); */
2256 update_mask |= BIT(1);
2259 /* spin_unlock_bh(&psta_bmc->sleep_q.lock); */
2260 spin_unlock_bh(&pxmitpriv->lock);
2264 update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
2267 void xmit_delivery_enabled_frames23a(struct rtw_adapter *padapter,
2268 struct sta_info *psta)
2271 struct list_head *plist, *phead, *ptmp;
2272 struct xmit_frame *pxmitframe;
2273 struct sta_priv *pstapriv = &padapter->stapriv;
2274 struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
2276 /* spin_lock_bh(&psta->sleep_q.lock); */
2277 spin_lock_bh(&pxmitpriv->lock);
2279 phead = get_list_head(&psta->sleep_q);
2281 list_for_each_safe(plist, ptmp, phead) {
2282 pxmitframe = container_of(plist, struct xmit_frame, list);
2284 switch (pxmitframe->attrib.priority) {
2287 wmmps_ac = psta->uapsd_bk & BIT(1);
2291 wmmps_ac = psta->uapsd_vi & BIT(1);
2295 wmmps_ac = psta->uapsd_vo & BIT(1);
2300 wmmps_ac = psta->uapsd_be & BIT(1);
2307 list_del_init(&pxmitframe->list);
2310 psta->sleepq_ac_len--;
2312 if (psta->sleepq_ac_len > 0) {
2313 pxmitframe->attrib.mdata = 1;
2314 pxmitframe->attrib.eosp = 0;
2316 pxmitframe->attrib.mdata = 0;
2317 pxmitframe->attrib.eosp = 1;
2320 pxmitframe->attrib.triggered = 1;
2322 rtl8723au_hal_xmitframe_enqueue(padapter, pxmitframe);
2324 if ((psta->sleepq_ac_len == 0) && (!psta->has_legacy_ac) &&
2326 pstapriv->tim_bitmap &= ~CHKBIT(psta->aid);
2328 /* update BCN for TIM IE */
2329 update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
2332 spin_unlock_bh(&pxmitpriv->lock);
2337 void rtw_sctx_init23a(struct submit_ctx *sctx, int timeout_ms)
2339 sctx->timeout_ms = timeout_ms;
2340 init_completion(&sctx->done);
2341 sctx->status = RTW_SCTX_SUBMITTED;
2344 int rtw_sctx_wait23a(struct submit_ctx *sctx)
2347 unsigned long expire;
2350 expire = sctx->timeout_ms ? msecs_to_jiffies(sctx->timeout_ms) :
2351 MAX_SCHEDULE_TIMEOUT;
2352 if (!wait_for_completion_timeout(&sctx->done, expire)) {
2353 /* timeout, do something?? */
2354 status = RTW_SCTX_DONE_TIMEOUT;
2355 DBG_8723A("%s timeout\n", __func__);
2357 status = sctx->status;
2360 if (status == RTW_SCTX_DONE_SUCCESS)
2366 static bool rtw_sctx_chk_waring_status(int status)
2369 case RTW_SCTX_DONE_UNKNOWN:
2370 case RTW_SCTX_DONE_BUF_ALLOC:
2371 case RTW_SCTX_DONE_BUF_FREE:
2372 case RTW_SCTX_DONE_DRV_STOP:
2373 case RTW_SCTX_DONE_DEV_REMOVE:
2380 void rtw23a_sctx_done_err(struct submit_ctx **sctx, int status)
2383 if (rtw_sctx_chk_waring_status(status))
2384 DBG_8723A("%s status:%d\n", __func__, status);
2385 (*sctx)->status = status;
2386 complete(&(*sctx)->done);
2391 void rtw_sctx_done23a(struct submit_ctx **sctx)
2393 rtw23a_sctx_done_err(sctx, RTW_SCTX_DONE_SUCCESS);
2396 int rtw_ack_tx_wait23a(struct xmit_priv *pxmitpriv, u32 timeout_ms)
2398 struct submit_ctx *pack_tx_ops = &pxmitpriv->ack_tx_ops;
2400 pack_tx_ops->timeout_ms = timeout_ms;
2401 pack_tx_ops->status = RTW_SCTX_SUBMITTED;
2403 return rtw_sctx_wait23a(pack_tx_ops);
2406 void rtw_ack_tx_done23a(struct xmit_priv *pxmitpriv, int status)
2408 struct submit_ctx *pack_tx_ops = &pxmitpriv->ack_tx_ops;
2410 if (pxmitpriv->ack_tx)
2411 rtw23a_sctx_done_err(&pack_tx_ops, status);
2413 DBG_8723A("%s ack_tx not set\n", __func__);