/****************************************************************************** * * Copyright(c) 2013 Realtek Corporation. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms of version 2 of the GNU General Public License as * published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along with * this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA * * ******************************************************************************/ #ifndef __RTL8821A_XMIT_H__ #define __RTL8821A_XMIT_H__ #include typedef struct txdescriptor_8821a { // Offset 0 u32 pktlen:16; u32 offset:8; u32 bmc:1; u32 htc:1; u32 rsvd0026:1; u32 rsvd0027:1; u32 linip:1; u32 noacm:1; u32 gf:1; u32 rsvd0031:1; // Offset 4 u32 macid:7; u32 rsvd0407:1; u32 qsel:5; u32 rdg_nav_ext:1; u32 lsig_txop_en:1; u32 pifs:1; u32 rate_id:5; u32 en_desc_id:1; u32 sectype:2; u32 pkt_offset:5; // unit: 8 bytes u32 moredata:1; u32 txop_ps_cap:1; u32 txop_ps_mode:1; // Offset 8 u32 p_aid:9; u32 rsvd0809:1; u32 cca_rts:2; u32 agg_en:1; u32 rdg_en:1; u32 null_0:1; u32 null_1:1; u32 bk:1; u32 morefrag:1; u32 raw:1; u32 spe_rpt:1; u32 ampdu_density:3; u32 bt_null:1; u32 g_id:6; u32 rsvd0830:2; // Offset 12 u32 wheader_len:4; u32 chk_en:1; u32 early_rate:1; u32 hw_ssn_sel:2; u32 userate:1; u32 disrtsfb:1; u32 disdatafb:1; u32 cts2self:1; u32 rtsen:1; u32 hw_rts_en:1; u32 port_id:1; u32 navusehdr:1; u32 use_max_len:1; u32 max_agg_num:5; u32 ndpa:2; u32 ampdu_max_time:8; // Offset 16 u32 datarate:7; u32 try_rate:1; u32 data_ratefb_lmt:5; u32 rts_ratefb_lmt:4; u32 rty_lmt_en:1; u32 data_rt_lmt:6; u32 rtsrate:5; u32 pcts_en:1; u32 pcts_mask_idx:2; // Offset 20 u32 data_sc:4; u32 data_short:1; u32 data_bw:2; u32 data_ldpc:1; u32 data_stbc:2; u32 vcs_stbc:2; u32 rts_short:1; u32 rts_sc:4; u32 rsvd2016:7; u32 tx_ant:4; u32 txpwr_offset:3; u32 rsvd2031:1; // Offset 24 u32 sw_define:12; u32 mbssid:4; u32 antsel_A:3; u32 antsel_B:3; u32 antsel_C:3; u32 antsel_D:3; u32 rsvd2428:4; // Offset 28 u32 checksum:16; u32 rsvd2816:8; u32 usb_txagg_num:8; // Offset 32 u32 rts_rc:6; u32 bar_rty_th:2; u32 data_rc:6; u32 rsvd3214:1; u32 en_hwseq:1; u32 nextneadpage:8; u32 tailpage:8; // Offset 36 u32 padding_len:11; u32 txbf_path:1; u32 seq:12; u32 final_data_rate:8; }TXDESC_8821A, *PTXDESC_8821A; #ifdef CONFIG_SDIO_HCI s32 InitXmitPriv8821AS(PADAPTER padapter); void FreeXmitPriv8821AS(PADAPTER padapter); s32 XmitBufHandler8821AS(PADAPTER padapter); s32 MgntXmit8821AS(PADAPTER padapter, struct xmit_frame *pmgntframe); s32 HalXmitNoLock8821AS(PADAPTER padapter, struct xmit_frame *pxmitframe); s32 HalXmit8821AS(PADAPTER padapter, struct xmit_frame *pxmitframe); #ifndef CONFIG_SDIO_TX_TASKLET thread_return XmitThread8821AS(thread_context context); #endif // !CONFIG_SDIO_TX_TASKLET #endif // CONFIG_SDIO_HCI #if 0 #ifdef CONFIG_USB_HCI s32 rtl8821au_init_xmit_priv(PADAPTER padapter); void rtl8821au_free_xmit_priv(PADAPTER padapter); s32 rtl8821au_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe); s32 rtl8821au_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe); s32 rtl8821au_hal_xmitframe_enqueue(PADAPTER padapter, struct xmit_frame *pxmitframe); s32 rtl8821au_xmit_buf_handler(PADAPTER padapter); void rtl8821au_xmit_tasklet(void *priv); s32 rtl8821au_xmitframe_complete(PADAPTER padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf); #endif // CONFIG_USB_HCI #ifdef CONFIG_PCI_HCI s32 rtl8821e_init_xmit_priv(PADAPTER padapter); void rtl8821e_free_xmit_priv(PADAPTER padapter); struct xmit_buf* rtl8821e_dequeue_xmitbuf(struct rtw_tx_ring *ring); void rtl8821e_xmitframe_resume(PADAPTER padapter); s32 rtl8821e_hal_xmit(PADAPTER padapter, struct xmit_frame *pxmitframe); s32 rtl8821e_mgnt_xmit(PADAPTER padapter, struct xmit_frame *pmgntframe); void rtl8821e_xmit_tasklet(void *priv); #endif // CONFIG_PCI_HCI #endif #endif //__RTL8821_XMIT_H__