blob: e3278434b1f1f0e25b1c64a5cf3b82d502f6f92d [file] [log] [blame]
Larry Finger94a79942011-08-23 19:00:42 -05001/******************************************************************************
2 * Copyright(c) 2008 - 2010 Realtek Corporation. All rights reserved.
3 *
4 * This program is distributed in the hope that it will be useful, but WITHOUT
5 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
6 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
7 * more details.
8 *
9 * You should have received a copy of the GNU General Public License along with
10 * this program; if not, write to the Free Software Foundation, Inc.,
11 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
12 *
13 * The full GNU General Public License is included in this distribution in the
14 * file called LICENSE.
15 *
16 * Contact Information:
17 * wlanfae <wlanfae@realtek.com>
18******************************************************************************/
19#ifndef R819XUSB_CMDPKT_H
20#define R819XUSB_CMDPKT_H
Larry Fingerd3ab7212011-07-18 22:59:06 -050021#define CMPK_RX_TX_FB_SIZE sizeof(struct cmpk_txfb)
Larry Finger94a79942011-08-23 19:00:42 -050022#define CMPK_TX_SET_CONFIG_SIZE sizeof(cmpk_set_cfg_t)
23#define CMPK_BOTH_QUERY_CONFIG_SIZE sizeof(cmpk_set_cfg_t)
24#define CMPK_RX_TX_STS_SIZE sizeof(cmpk_tx_status_t)
25#define CMPK_RX_DBG_MSG_SIZE sizeof(cmpk_rx_dbginfo_t)
26#define CMPK_TX_RAHIS_SIZE sizeof(cmpk_tx_rahis_t)
27
28#define ISR_TxBcnOk BIT27
29#define ISR_TxBcnErr BIT26
30#define ISR_BcnTimerIntr BIT13
31
32
Larry Fingerd3ab7212011-07-18 22:59:06 -050033struct cmpk_txfb {
Larry Finger94a79942011-08-23 19:00:42 -050034 u8 element_id;
35 u8 length;
36 u8 TID:4; /* */
37 u8 fail_reason:3; /* */
38 u8 tok:1;
39 u8 reserve1:4; /* */
40 u8 pkt_type:2; /* */
41 u8 bandwidth:1; /* */
42 u8 qos_pkt:1; /* */
43
44 u8 reserve2; /* */
45 u8 retry_cnt; /* */
46 u16 pkt_id; /* */
47
48 u16 seq_num; /* */
49 u8 s_rate;
50 u8 f_rate;
51
52 u8 s_rts_rate; /* */
53 u8 f_rts_rate; /* */
54 u16 pkt_length; /* */
55
56 u16 reserve3; /* */
57 u16 duration; /* */
Larry Fingerd3ab7212011-07-18 22:59:06 -050058};//;
Larry Finger94a79942011-08-23 19:00:42 -050059
60typedef struct tag_cmd_pkt_interrupt_status
61{
62 u8 element_id;
63 u8 length;
64 u16 reserve;
65 u32 interrupt_status;
66}cmpk_intr_sta_t;
67
68
69typedef struct tag_cmd_pkt_set_configuration
70{
71 u8 element_id;
72 u8 length;
73 u16 reserve1;
74 u8 cfg_reserve1:3;
75 u8 cfg_size:2;
76 u8 cfg_type:2;
77 u8 cfg_action:1;
78 u8 cfg_reserve2;
79 u8 cfg_page:4;
80 u8 cfg_reserve3:4;
81 u8 cfg_offset;
82 u32 value;
83 u32 mask;
84}cmpk_set_cfg_t;
85
86#define cmpk_query_cfg_t cmpk_set_cfg_t
87
88typedef struct tag_tx_stats_feedback
89{
90 u16 reserve1;
91 u8 length;
92 u8 element_id;
93
94 u16 txfail;
95 u16 txok;
96
97 u16 txmcok;
98 u16 txretry;
99
100 u16 txucok;
101 u16 txbcok;
102
103 u16 txbcfail;
104 u16 txmcfail;
105
106 u16 reserve2;
107 u16 txucfail;
108
109 u32 txmclength;
110 u32 txbclength;
111 u32 txuclength;
112
113 u16 reserve3_23;
114 u8 reserve3_1;
115 u8 rate;
116}__attribute__((packed)) cmpk_tx_status_t;
117
118typedef struct tag_rx_debug_message_feedback
119{
120 u16 reserve1;
121 u8 length;
122 u8 element_id;
123
124
125}cmpk_rx_dbginfo_t;
126
127typedef struct tag_tx_rate_history
128{
129 u8 element_id;
130 u8 length;
131 u16 reserved1;
132
133 u16 cck[4];
134
135 u16 ofdm[8];
136
137
138
139
140
141 u16 ht_mcs[4][16];
142
143}__attribute__((packed)) cmpk_tx_rahis_t;
144
145typedef enum tag_command_packet_directories
146{
147 RX_TX_FEEDBACK = 0,
148 RX_INTERRUPT_STATUS = 1,
149 TX_SET_CONFIG = 2,
150 BOTH_QUERY_CONFIG = 3,
151 RX_TX_STATUS = 4,
152 RX_DBGINFO_FEEDBACK = 5,
153 RX_TX_PER_PKT_FEEDBACK = 6,
154 RX_TX_RATE_HISTORY = 7,
155 RX_CMD_ELE_MAX
156}cmpk_element_e;
157
158extern u32 cmpk_message_handle_rx(struct net_device *dev, struct rtllib_rx_stats * pstats);
159extern bool cmpk_message_handle_tx(struct net_device *dev, u8* codevirtualaddress, u32 packettype, u32 buffer_len);
160
161
162#endif