4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
22 * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
26 #ifndef _SYS_MAC_WIFI_H
27 #define _SYS_MAC_WIFI_H
30 * WiFi MAC-Type Plugin
37 #include <sys/types.h>
38 #include <sys/net80211_proto.h>
42 #define MAC_PLUGIN_IDENT_WIFI "mac_wifi"
45 * Maximum size of a WiFi header based on current implementation.
46 * May change in the future as new features are added.
48 #define WIFI_HDRSIZE (sizeof (struct ieee80211_qosframe_addr4) + \
49 IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN + IEEE80211_WEP_EXTIVLEN + \
50 sizeof (struct ieee80211_llc))
53 /* statistics described in ieee802.11(5) */
54 WIFI_STAT_TX_FRAGS
= MACTYPE_STAT_MIN
,
58 WIFI_STAT_TX_RERETRANS
,
59 WIFI_STAT_RTS_SUCCESS
,
60 WIFI_STAT_RTS_FAILURE
,
61 WIFI_STAT_ACK_FAILURE
,
70 * WiFi security modes recognized by the plugin.
79 * WiFi data passed between the drivers and the plugin.
83 * wd_opts Currently set to 0. If new features require the
84 * introduction of new wifi_data_t fields, then the
85 * presence of those fields must be indicated to the
86 * plugin via wd_opts flags. This allows the drivers
87 * and the plugin to evolve independently.
89 * wd_bssid Current associated BSSID (or IBSSID), used when
90 * generating data packet headers for transmission.
92 * wd_opmode Current operation mode; any ieee80211_opmode is
95 * wd_secalloc Current allocation policy for security-related
96 * WiFi headers, used when generating packets for
97 * transmission. The plugin will allocate header
98 * space for the security portion, and fill in any
99 * fixed-contents fields.
101 * wd_qospad Generally, QoS data field takes 2 bytes, but
102 * some special hardwares, such as Atheros, will need the
103 * 802.11 header padded to a 32-bit boundary for 4-address
104 * and QoS frames, at this time, it's 4 bytes.
106 typedef struct wifi_data
{
108 uint8_t wd_bssid
[IEEE80211_ADDR_LEN
];
109 enum ieee80211_opmode wd_opmode
;
110 enum wifi_secmode wd_secalloc
;
114 extern uint8_t wifi_bcastaddr
[];
122 #endif /* _SYS_MAC_WIFI_H */