blob: d8f25d19030ccc76a63eece1e59600b3613f75b9 [file] [log] [blame]
Forest Bond92b96792009-06-13 07:38:31 -04001/*
2 * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc.
3 * All rights reserved.
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * File: rxtx.h
20 *
21 * Purpose:
22 *
23 * Author: Jerry Chen
24 *
25 * Date: Jun. 27, 2002
26 *
27 */
28
Forest Bond92b96792009-06-13 07:38:31 -040029#ifndef __RXTX_H__
30#define __RXTX_H__
31
Forest Bond92b96792009-06-13 07:38:31 -040032#include "device.h"
Forest Bond92b96792009-06-13 07:38:31 -040033#include "wcmd.h"
Malcolm Priestleyaed387c2013-08-20 22:52:30 +010034#include "baseband.h"
Forest Bond92b96792009-06-13 07:38:31 -040035
Malcolm Priestley5a5d6a82013-08-23 14:33:55 +010036/* MIC HDR data header */
37struct vnt_mic_hdr {
38 u8 id;
39 u8 tx_priority;
40 u8 mic_addr2[6];
41 __be32 tsc_47_16;
42 __be16 tsc_15_0;
43 __be16 payload_len;
44 __be16 hlen;
45 __le16 frame_control;
46 u8 addr1[6];
47 u8 addr2[6];
48 u8 addr3[6];
49 __le16 seq_ctrl;
50 u8 addr4[6];
51 u16 packing; /* packing to 48 bytes */
52} __packed;
53
Malcolm Priestley6398a592013-08-16 21:26:55 +010054/* RsvTime buffer header */
55struct vnt_rrv_time_rts {
56 u16 wRTSTxRrvTime_ba;
57 u16 wRTSTxRrvTime_aa;
58 u16 wRTSTxRrvTime_bb;
59 u16 wReserved;
60 u16 wTxRrvTime_b;
61 u16 wTxRrvTime_a;
62} __packed;
63
Malcolm Priestley4f990052013-08-16 23:38:57 +010064struct vnt_rrv_time_cts {
65 u16 wCTSTxRrvTime_ba;
66 u16 wReserved;
67 u16 wTxRrvTime_b;
68 u16 wTxRrvTime_a;
69} __packed;
70
Malcolm Priestley976467d2013-08-16 23:44:04 +010071struct vnt_rrv_time_ab {
72 u16 wRTSTxRrvTime;
73 u16 wTxRrvTime;
74} __packed;
75
Malcolm Priestley7e60a3de2013-08-16 23:48:03 +010076/* TX data header */
77struct vnt_tx_datahead_g {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +010078 struct vnt_phy_field b;
79 struct vnt_phy_field a;
Malcolm Priestley7e60a3de2013-08-16 23:48:03 +010080 u16 wDuration_b;
81 u16 wDuration_a;
82 u16 wTimeStampOff_b;
83 u16 wTimeStampOff_a;
84} __packed;
85
Malcolm Priestley7c05c542013-08-16 23:49:15 +010086struct vnt_tx_datahead_g_fb {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +010087 struct vnt_phy_field b;
88 struct vnt_phy_field a;
Malcolm Priestley7c05c542013-08-16 23:49:15 +010089 u16 wDuration_b;
90 u16 wDuration_a;
91 u16 wDuration_a_f0;
92 u16 wDuration_a_f1;
93 u16 wTimeStampOff_b;
94 u16 wTimeStampOff_a;
95} __packed;
96
Malcolm Priestley558becf2013-08-16 23:50:32 +010097struct vnt_tx_datahead_ab {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +010098 struct vnt_phy_field ab;
Malcolm Priestley558becf2013-08-16 23:50:32 +010099 u16 wDuration;
100 u16 wTimeStampOff;
101} __packed;
102
Malcolm Priestley1da4ee22013-08-16 23:51:38 +0100103struct vnt_tx_datahead_a_fb {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +0100104 struct vnt_phy_field a;
Malcolm Priestley1da4ee22013-08-16 23:51:38 +0100105 u16 wDuration;
106 u16 wTimeStampOff;
107 u16 wDuration_f0;
108 u16 wDuration_f1;
109} __packed;
110
Malcolm Priestleyc521cb52013-08-15 21:23:25 +0100111/* RTS buffer header */
112struct vnt_rts_g {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +0100113 struct vnt_phy_field b;
114 struct vnt_phy_field a;
Malcolm Priestleyc521cb52013-08-15 21:23:25 +0100115 u16 wDuration_ba;
116 u16 wDuration_aa;
117 u16 wDuration_bb;
118 u16 wReserved;
119 struct ieee80211_rts data;
Malcolm Priestley78363fd2013-10-01 15:52:16 +0100120 struct vnt_tx_datahead_g data_head;
Malcolm Priestleyc521cb52013-08-15 21:23:25 +0100121} __packed;
122
123struct vnt_rts_g_fb {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +0100124 struct vnt_phy_field b;
125 struct vnt_phy_field a;
Malcolm Priestleyc521cb52013-08-15 21:23:25 +0100126 u16 wDuration_ba;
127 u16 wDuration_aa;
128 u16 wDuration_bb;
129 u16 wReserved;
130 u16 wRTSDuration_ba_f0;
131 u16 wRTSDuration_aa_f0;
132 u16 wRTSDuration_ba_f1;
133 u16 wRTSDuration_aa_f1;
134 struct ieee80211_rts data;
Malcolm Priestley5b852f52013-10-01 15:54:56 +0100135 struct vnt_tx_datahead_g_fb data_head;
Malcolm Priestleyc521cb52013-08-15 21:23:25 +0100136} __packed;
137
138struct vnt_rts_ab {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +0100139 struct vnt_phy_field ab;
Malcolm Priestleyc521cb52013-08-15 21:23:25 +0100140 u16 wDuration;
141 u16 wReserved;
142 struct ieee80211_rts data;
143} __packed;
144
145struct vnt_rts_a_fb {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +0100146 struct vnt_phy_field a;
Malcolm Priestleyc521cb52013-08-15 21:23:25 +0100147 u16 wDuration;
148 u16 wReserved;
149 u16 wRTSDuration_f0;
150 u16 wRTSDuration_f1;
151 struct ieee80211_rts data;
Malcolm Priestleybd3f51f2013-10-01 15:56:48 +0100152 struct vnt_tx_datahead_a_fb data_head;
Malcolm Priestleyc521cb52013-08-15 21:23:25 +0100153} __packed;
154
Malcolm Priestleyf0c5ba22013-08-15 21:27:22 +0100155/* CTS buffer header */
156struct vnt_cts {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +0100157 struct vnt_phy_field b;
Malcolm Priestleyf0c5ba22013-08-15 21:27:22 +0100158 u16 wDuration_ba;
159 u16 wReserved;
160 struct ieee80211_cts data;
161 u16 reserved2;
Malcolm Priestley78363fd2013-10-01 15:52:16 +0100162 struct vnt_tx_datahead_g data_head;
Malcolm Priestleyf0c5ba22013-08-15 21:27:22 +0100163} __packed;
164
165struct vnt_cts_fb {
Malcolm Priestleyaed387c2013-08-20 22:52:30 +0100166 struct vnt_phy_field b;
Malcolm Priestleyf0c5ba22013-08-15 21:27:22 +0100167 u16 wDuration_ba;
168 u16 wReserved;
169 u16 wCTSDuration_ba_f0;
170 u16 wCTSDuration_ba_f1;
171 struct ieee80211_cts data;
172 u16 reserved2;
Malcolm Priestley5b852f52013-10-01 15:54:56 +0100173 struct vnt_tx_datahead_g_fb data_head;
Malcolm Priestleyf0c5ba22013-08-15 21:27:22 +0100174} __packed;
175
Malcolm Priestley13fe62a2013-08-26 11:17:52 +0100176union vnt_tx_data_head {
177 /* rts g */
178 struct vnt_rts_g rts_g;
179 struct vnt_rts_g_fb rts_g_fb;
180 /* rts a/b */
181 struct vnt_rts_ab rts_ab;
182 struct vnt_rts_a_fb rts_a_fb;
183 /* cts g */
184 struct vnt_cts cts_g;
185 struct vnt_cts_fb cts_g_fb;
Malcolm Priestleya90186e2013-10-01 15:58:54 +0100186 /* no rts/cts */
187 struct vnt_tx_datahead_a_fb data_head_a_fb;
Malcolm Priestley13fe62a2013-08-26 11:17:52 +0100188};
189
Malcolm Priestley56c60e42013-09-26 18:49:44 +0100190struct vnt_tx_mic_hdr {
191 struct vnt_mic_hdr hdr;
192 union vnt_tx_data_head head;
193} __packed;
194
195union vnt_tx {
196 struct vnt_tx_mic_hdr mic;
197 union vnt_tx_data_head head;
198};
199
Malcolm Priestley9e38a5c2013-09-26 18:47:25 +0100200union vnt_tx_head {
Malcolm Priestley56c60e42013-09-26 18:49:44 +0100201 struct {
202 struct vnt_rrv_time_rts rts;
203 union vnt_tx tx;
204 } __packed tx_rts;
205 struct {
206 struct vnt_rrv_time_cts cts;
207 union vnt_tx tx;
208 } __packed tx_cts;
209 struct {
210 struct vnt_rrv_time_ab ab;
211 union vnt_tx tx;
212 } __packed tx_ab;
Malcolm Priestley9e38a5c2013-09-26 18:47:25 +0100213};
214
Malcolm Priestleyd66caad2013-09-17 19:54:35 +0100215struct vnt_tx_fifo_head {
Malcolm Priestleyed743952012-11-11 15:34:51 +0000216 u32 adwTxKey[4];
Malcolm Priestleyf39c0d82013-08-15 19:34:37 +0100217 u16 wFIFOCtl;
218 u16 wTimeStamp;
219 u16 wFragCtl;
220 u16 wReserved;
221} __packed;
Forest Bond92b96792009-06-13 07:38:31 -0400222
Malcolm Priestleyd66caad2013-09-17 19:54:35 +0100223struct vnt_tx_buffer {
224 u8 byType;
225 u8 byPKTNO;
226 u16 wTxByteCount;
227 struct vnt_tx_fifo_head fifo_head;
Malcolm Priestley9e38a5c2013-09-26 18:47:25 +0100228 union vnt_tx_head tx_head;
Malcolm Priestleyd66caad2013-09-17 19:54:35 +0100229} __packed;
230
Malcolm Priestley01f865b2013-08-15 19:40:08 +0100231struct vnt_beacon_buffer {
232 u8 byType;
233 u8 byPKTNO;
234 u16 wTxByteCount;
235 u16 wFIFOCtl;
236 u16 wTimeStamp;
237} __packed;
Forest Bond92b96792009-06-13 07:38:31 -0400238
Malcolm Priestleyd56131d2013-01-17 23:15:22 +0000239void vDMA0_tx_80211(struct vnt_private *, struct sk_buff *skb);
240int nsDMA_tx_packet(struct vnt_private *, u32 uDMAIdx, struct sk_buff *skb);
241CMD_STATUS csMgmt_xmit(struct vnt_private *, struct vnt_tx_mgmt *);
242CMD_STATUS csBeacon_xmit(struct vnt_private *, struct vnt_tx_mgmt *);
243int bRelayPacketSend(struct vnt_private *, u8 *pbySkbData, u32 uDataLen,
244 u32 uNodeIndex);
Forest Bond92b96792009-06-13 07:38:31 -0400245
Andres Moree7b07d12010-05-01 19:12:26 -0300246#endif /* __RXTX_H__ */