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