]> Pileus Git - ~andy/linux/blob - drivers/staging/vt6655/tether.h
Staging: vt6655: use ETH_DATA_LEN macro instead of custom one
[~andy/linux] / drivers / staging / vt6655 / tether.h
1 /*
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: tether.h
20  *
21  * Purpose:
22  *
23  * Author: Tevin Chen
24  *
25  * Date: Jan. 28, 1997
26  *
27  */
28
29 #ifndef __TETHER_H__
30 #define __TETHER_H__
31
32 #include <linux/if_ether.h>
33 #include "ttype.h"
34
35 /*---------------------  Export Definitions -------------------------*/
36 //
37 // constants
38 //
39 #define U_ETHER_ADDR_STR_LEN (ETH_ALEN * 2 + 1)
40                                         // Ethernet address string length
41
42 #define MIN_DATA_LEN        46          // min data length
43
44 #define MIN_PACKET_LEN      (MIN_DATA_LEN + ETH_HLEN)
45                                         // 60
46                                         // min total packet length (tx)
47 #define MAX_PACKET_LEN      (ETH_DATA_LEN + ETH_HLEN)
48                                         // 1514
49                                         // max total packet length (tx)
50
51 #define MAX_LOOKAHEAD_SIZE  MAX_PACKET_LEN
52
53 #define U_MULTI_ADDR_LEN    8           // multicast address length
54
55
56 #ifdef __BIG_ENDIAN
57
58 #define TYPE_PKT_IP         0x0800      //
59 #define TYPE_PKT_ARP        0x0806      //
60 #define TYPE_PKT_RARP       0x8035      //
61 #define TYPE_PKT_IPX        0x8137          //
62 #define TYPE_PKT_802_1x     0x888e
63 #define TYPE_PKT_PreAuth    0x88C7
64
65 #define TYPE_PKT_PING_M_REQ 0x8011      // master reguest
66 #define TYPE_PKT_PING_S_GNT 0x8022      // slave grant
67 #define TYPE_PKT_PING_M     0x8077      // pingpong master packet
68 #define TYPE_PKT_PING_S     0x8088      // pingpong slave packet
69 #define TYPE_PKT_WOL_M_REQ  0x8033      // WOL waker request
70 #define TYPE_PKT_WOL_S_GNT  0x8044      // WOL sleeper grant
71 #define TYPE_MGMT_PROBE_RSP 0x5000
72 #define TYPE_PKT_VNT_DIAG   0x8011      // Diag Pkt
73 #define TYPE_PKT_VNT_PER    0x8888      // Diag PER Pkt
74 //
75 // wFrameCtl field in the S802_11Header
76 //
77 // NOTE....
78 //   in network byte order, high byte is going first
79 #define FC_TODS             0x0001
80 #define FC_FROMDS           0x0002
81 #define FC_MOREFRAG         0x0004
82 #define FC_RETRY            0x0008
83 #define FC_POWERMGT         0x0010
84 #define FC_MOREDATA         0x0020
85 #define FC_WEP              0x0040
86 #define TYPE_802_11_ATIM    0x9000
87
88 #define TYPE_802_11_DATA    0x0800
89 #define TYPE_802_11_CTL     0x0400
90 #define TYPE_802_11_MGMT    0x0000
91 #define TYPE_802_11_MASK    0x0C00
92 #define TYPE_SUBTYPE_MASK   0xFC00
93 #define TYPE_802_11_NODATA  0x4000
94 #define TYPE_DATE_NULL      0x4800
95
96 #define TYPE_CTL_PSPOLL     0xa400
97 #define TYPE_CTL_RTS        0xb400
98 #define TYPE_CTL_CTS        0xc400
99 #define TYPE_CTL_ACK        0xd400
100
101
102 //#define WEP_IV_MASK         0xFFFFFF00
103
104 #else //if LITTLE_ENDIAN
105 //
106 // wType field in the SEthernetHeader
107 //
108 // NOTE....
109 //   in network byte order, high byte is going first
110 #define TYPE_PKT_IP         0x0008      //
111 #define TYPE_PKT_ARP        0x0608      //
112 #define TYPE_PKT_RARP       0x3580      //
113 #define TYPE_PKT_IPX        0x3781          //
114
115 #define TYPE_PKT_802_1x     0x8e88
116 #define TYPE_PKT_PreAuth    0xC788
117
118 #define TYPE_PKT_PING_M_REQ 0x1180      // master reguest
119 #define TYPE_PKT_PING_S_GNT 0x2280      // slave grant
120 #define TYPE_PKT_PING_M     0x7780      // pingpong master packet
121 #define TYPE_PKT_PING_S     0x8880      // pingpong slave packet
122 #define TYPE_PKT_WOL_M_REQ  0x3380      // WOL waker request
123 #define TYPE_PKT_WOL_S_GNT  0x4480      // WOL sleeper grant
124 #define TYPE_MGMT_PROBE_RSP 0x0050
125 #define TYPE_PKT_VNT_DIAG   0x1180      // Diag Pkt
126 #define TYPE_PKT_VNT_PER    0x8888      // Diag PER Pkt
127 //
128 // wFrameCtl field in the S802_11Header
129 //
130 // NOTE....
131 //   in network byte order, high byte is going first
132 #define FC_TODS             0x0100
133 #define FC_FROMDS           0x0200
134 #define FC_MOREFRAG         0x0400
135 #define FC_RETRY            0x0800
136 #define FC_POWERMGT         0x1000
137 #define FC_MOREDATA         0x2000
138 #define FC_WEP              0x4000
139 #define TYPE_802_11_ATIM    0x0090
140
141 #define TYPE_802_11_DATA    0x0008
142 #define TYPE_802_11_CTL     0x0004
143 #define TYPE_802_11_MGMT    0x0000
144 #define TYPE_802_11_MASK    0x000C
145 #define TYPE_SUBTYPE_MASK   0x00FC
146 #define TYPE_802_11_NODATA  0x0040
147 #define TYPE_DATE_NULL      0x0048
148
149 #define TYPE_CTL_PSPOLL     0x00a4
150 #define TYPE_CTL_RTS        0x00b4
151 #define TYPE_CTL_CTS        0x00c4
152 #define TYPE_CTL_ACK        0x00d4
153
154
155 //#define WEP_IV_MASK         0x00FFFFFF
156
157 #endif //#ifdef __BIG_ENDIAN
158
159 #define WEP_IV_MASK         0x00FFFFFF
160
161 /*---------------------  Export Types  ------------------------------*/
162 //
163 // Ethernet packet
164 //
165 typedef struct tagSEthernetHeader {
166     BYTE    abyDstAddr[ETH_ALEN];
167     BYTE    abySrcAddr[ETH_ALEN];
168     WORD    wType;
169 }__attribute__ ((__packed__))
170 SEthernetHeader, *PSEthernetHeader;
171
172
173 //
174 // 802_3 packet
175 //
176 typedef struct tagS802_3Header {
177     BYTE    abyDstAddr[ETH_ALEN];
178     BYTE    abySrcAddr[ETH_ALEN];
179     WORD    wLen;
180 }__attribute__ ((__packed__))
181 S802_3Header, *PS802_3Header;
182
183 //
184 // 802_11 packet
185 //
186 typedef struct tagS802_11Header {
187     WORD    wFrameCtl;
188     WORD    wDurationID;
189     BYTE    abyAddr1[ETH_ALEN];
190     BYTE    abyAddr2[ETH_ALEN];
191     BYTE    abyAddr3[ETH_ALEN];
192     WORD    wSeqCtl;
193     BYTE    abyAddr4[ETH_ALEN];
194 }__attribute__ ((__packed__))
195 S802_11Header, *PS802_11Header;
196
197 /*---------------------  Export Macros ------------------------------*/
198 // Frame type macro
199
200 #define IS_MULTICAST_ADDRESS(pbyEtherAddr)          \
201     ((*(PBYTE)(pbyEtherAddr) & 0x01) == 1)
202
203 #define IS_BROADCAST_ADDRESS(pbyEtherAddr) (        \
204     (*(PDWORD)(pbyEtherAddr) == 0xFFFFFFFFL) &&     \
205     (*(PWORD)((PBYTE)(pbyEtherAddr) + 4) == 0xFFFF) \
206 )
207
208 #define IS_NULL_ADDRESS(pbyEtherAddr) (             \
209     (*(PDWORD)(pbyEtherAddr) == 0L) &&              \
210     (*(PWORD)((PBYTE)(pbyEtherAddr) + 4) == 0)      \
211 )
212
213 #define IS_ETH_ADDRESS_EQUAL(pbyAddr1, pbyAddr2) (  \
214     (*(PDWORD)(pbyAddr1) == *(PDWORD)(pbyAddr2)) && \
215     (*(PWORD)((PBYTE)(pbyAddr1) + 4) ==             \
216     *(PWORD)((PBYTE)(pbyAddr2) + 4))                \
217 )
218
219 /*---------------------  Export Classes  ----------------------------*/
220
221 /*---------------------  Export Variables  --------------------------*/
222
223 /*---------------------  Export Functions  --------------------------*/
224
225 BYTE ETHbyGetHashIndexByCrc32(PBYTE pbyMultiAddr);
226 //BYTE ETHbyGetHashIndexByCrc(PBYTE pbyMultiAddr);
227 BOOL ETHbIsBufferCrc32Ok(PBYTE pbyBuffer, UINT cbFrameLength);
228
229 #endif // __TETHER_H__
230
231
232