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