1#ifndef R819XUSB_CMDPKT_H
2#define R819XUSB_CMDPKT_H
3
4#define CMPK_RX_TX_FB_SIZE sizeof(cmpk_txfb_t)
5#define CMPK_TX_SET_CONFIG_SIZE sizeof(cmpk_set_cfg_t)
6#define CMPK_BOTH_QUERY_CONFIG_SIZE sizeof(cmpk_set_cfg_t)
7#define CMPK_RX_TX_STS_SIZE sizeof(cmpk_tx_status_t)
8#define CMPK_RX_DBG_MSG_SIZE sizeof(cmpk_rx_dbginfo_t)
9#define CMPK_TX_RAHIS_SIZE sizeof(cmpk_tx_rahis_t)
10
11
12#define ISR_TxBcnOk BIT27
13#define ISR_TxBcnErr BIT26
14#define ISR_BcnTimerIntr BIT13
15
16
17
18
19
20
21
22typedef struct tag_cmd_pkt_tx_feedback {
23
24 u8 element_id;
25 u8 length;
26
27
28 u8 TID:4;
29 u8 fail_reason:3;
30 u8 tok:1;
31 u8 reserve1:4;
32 u8 pkt_type:2;
33 u8 bandwidth:1;
34 u8 qos_pkt:1;
35
36
37 u8 reserve2;
38
39 u8 retry_cnt;
40 u16 pkt_id;
41
42
43 u16 seq_num;
44 u8 s_rate;
45 u8 f_rate;
46
47
48 u8 s_rts_rate;
49 u8 f_rts_rate;
50 u16 pkt_length;
51
52
53 u16 reserve3;
54 u16 duration;
55}cmpk_txfb_t;
56
57
58
59typedef struct tag_cmd_pkt_interrupt_status {
60 u8 element_id;
61 u8 length;
62 u16 reserve;
63 u32 interrupt_status;
64}cmpk_intr_sta_t;
65
66
67
68typedef struct tag_cmd_pkt_set_configuration {
69 u8 element_id;
70 u8 length;
71 u16 reserve1;
72 u8 cfg_reserve1:3;
73 u8 cfg_size:2;
74 u8 cfg_type:2;
75 u8 cfg_action:1;
76 u8 cfg_reserve2;
77 u8 cfg_page:4;
78 u8 cfg_reserve3:4;
79 u8 cfg_offset;
80 u32 value;
81 u32 mask;
82}cmpk_set_cfg_t;
83
84
85
86#define cmpk_query_cfg_t cmpk_set_cfg_t
87
88
89typedef struct tag_tx_stats_feedback {
90
91
92 u16 reserve1;
93 u8 length;
94 u8 element_id;
95
96
97 u16 txfail;
98 u16 txok;
99
100
101 u16 txmcok;
102 u16 txretry;
103
104
105 u16 txucok;
106 u16 txbcok;
107
108
109 u16 txbcfail;
110 u16 txmcfail;
111
112
113 u16 reserve2;
114 u16 txucfail;
115
116
117 u32 txmclength;
118 u32 txbclength;
119 u32 txuclength;
120
121
122 u16 reserve3_23;
123 u8 reserve3_1;
124 u8 rate;
125}__attribute__((packed)) cmpk_tx_status_t;
126
127
128
129typedef struct tag_rx_debug_message_feedback {
130
131
132 u16 reserve1;
133 u8 length;
134 u8 element_id;
135
136
137
138
139}cmpk_rx_dbginfo_t;
140
141
142typedef struct tag_tx_rate_history {
143
144
145 u8 element_id;
146 u8 length;
147 u16 reserved1;
148
149
150 u16 cck[4];
151
152
153 u16 ofdm[8];
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171 u16 ht_mcs[4][16];
172
173}__attribute__((packed)) cmpk_tx_rahis_t;
174
175typedef enum tag_command_packet_directories
176{
177 RX_TX_FEEDBACK = 0,
178 RX_INTERRUPT_STATUS = 1,
179 TX_SET_CONFIG = 2,
180 BOTH_QUERY_CONFIG = 3,
181 RX_TX_STATUS = 4,
182 RX_DBGINFO_FEEDBACK = 5,
183 RX_TX_PER_PKT_FEEDBACK = 6,
184 RX_TX_RATE_HISTORY = 7,
185 RX_CMD_ELE_MAX
186}cmpk_element_e;
187
188typedef enum _rt_status{
189 RT_STATUS_SUCCESS,
190 RT_STATUS_FAILURE,
191 RT_STATUS_PENDING,
192 RT_STATUS_RESOURCE
193}rt_status,*prt_status;
194
195extern rt_status cmpk_message_handle_tx(struct net_device *dev, u8 *codevirtualaddress, u32 packettype, u32 buffer_len);
196
197extern u32 cmpk_message_handle_rx(struct net_device *dev, struct ieee80211_rx_stats *pstats);
198extern rt_status SendTxCommandPacket( struct net_device *dev, void *pData, u32 DataLen);
199
200
201#endif
202