forked from ~ljy/RK356X_SDK_RELEASE

hc
2023-12-06 d38611ca164021d018c1b23eee65bbebc09c63e0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
/* SPDX-License-Identifier: GPL-2.0 */
/******************************************************************************
 *
 * Copyright(c) 2013 - 2017 Realtek Corporation.
 *
 * 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.
 *
 *****************************************************************************/
#ifndef __RTL8821A_XMIT_H__
#define __RTL8821A_XMIT_H__
 
#include <drv_types.h>
 
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__ */