wivar.h revision 1.19 1 /* $NetBSD: wivar.h,v 1.19 2002/09/23 14:31:28 thorpej Exp $ */
2
3 /*
4 * Copyright (c) 1997, 1998, 1999
5 * Bill Paul <wpaul (at) ctr.columbia.edu>. All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. All advertising materials mentioning features or use of this software
16 * must display the following acknowledgement:
17 * This product includes software developed by Bill Paul.
18 * 4. Neither the name of the author nor the names of any co-contributors
19 * may be used to endorse or promote products derived from this software
20 * without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND
23 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 * ARE DISCLAIMED. IN NO EVENT SHALL Bill Paul OR THE VOICES IN HIS HEAD
26 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
32 * THE POSSIBILITY OF SUCH DAMAGE.
33 */
34
35 /*
36 * FreeBSD driver ported to NetBSD by Bill Sommerfeld in the back of the
37 * Oslo IETF plenary meeting.
38 */
39
40 #include <dev/ic/wi_hostap.h>
41
42 struct wi_softc {
43 struct device sc_dev;
44 struct ethercom sc_ethercom;
45 struct ifnet *sc_ifp;
46 void *sc_ih; /* interrupt handler */
47 int (*sc_enable) __P((struct wi_softc *));
48 void (*sc_disable) __P((struct wi_softc *));
49
50 int sc_attached;
51 int sc_enabled;
52 int sc_firmware_type;
53 #define WI_NOTYPE 0
54 #define WI_LUCENT 1
55 #define WI_INTERSIL 2
56 #define WI_SYMBOL 3
57 int sc_pri_firmware_ver; /* Primary firmware version */
58 int sc_sta_firmware_ver; /* Station firmware version */
59 int sc_pci; /* attach to PCI-Bus */
60
61 bus_space_tag_t sc_iot; /* bus cookie */
62 bus_space_handle_t sc_ioh; /* bus i/o handle */
63
64 struct callout wi_inquire_ch;
65 struct callout wi_scan_sh;
66
67 u_int8_t sc_macaddr[ETHER_ADDR_LEN];
68
69 u_int16_t wi_txbuf[(sizeof(struct wi_frame) + 2312) / 2];
70
71 struct ifmedia sc_media;
72 int wi_flags;
73 int wi_tx_data_id;
74 int wi_tx_mgmt_id;
75 int wi_if_flags;
76 u_int16_t wi_ptype;
77 u_int16_t wi_portnum;
78 u_int16_t wi_max_data_len;
79 u_int16_t wi_rts_thresh;
80 u_int16_t wi_ap_density;
81 u_int16_t wi_tx_rate;
82 u_int16_t wi_create_ibss;
83 u_int16_t wi_channels;
84 u_int16_t wi_pm_enabled;
85 u_int16_t wi_mor_enabled;
86 u_int16_t wi_max_sleep;
87 u_int16_t wi_authtype;
88 u_int16_t wi_roaming;
89 u_int16_t wi_supprates;
90
91 struct ieee80211_nwid wi_nodeid;
92 struct ieee80211_nwid wi_netid;
93 struct ieee80211_nwid wi_ibssid;
94
95 int wi_use_wep;
96 int wi_do_host_encrypt;
97 int wi_tx_key;
98 struct wi_ltv_keys wi_keys;
99 struct wi_counters wi_stats;
100 u_int16_t wi_ibss_port;
101
102 u_int8_t wi_current_bssid[IEEE80211_ADDR_LEN];
103 u_int16_t wi_current_channel; /* current BSS channel */
104
105 u_int8_t wi_join_bssid[IEEE80211_ADDR_LEN];
106 u_int16_t wi_join_channel; /* channel of BSS to join */
107
108 u_int16_t wi_create_channel;/* channel of BSS to create */
109
110 struct wi_apinfo wi_aps[MAXAPINFO];
111 int wi_naps;
112 int wi_scanning; /* scan mode */
113
114 struct wihap_info wi_hostap_info;
115 u_int32_t wi_icv;
116 int wi_icv_flag;
117
118 caddr_t sc_bpf80211;
119 caddr_t sc_bpf80211plus;
120 };
121
122 /* Values for wi_flags. */
123 #define WI_FLAGS_ATTACHED 0x0001
124 #define WI_FLAGS_INITIALIZED 0x0002
125 #define WI_FLAGS_HAS_WEP 0x0004
126 #define WI_FLAGS_HAS_IBSS 0x0008
127 #define WI_FLAGS_HAS_CREATE_IBSS 0x0010
128 #define WI_FLAGS_HAS_MOR 0x0020
129 #define WI_FLAGS_HAS_ROAMING 0x0040
130 #define WI_FLAGS_HAS_DIVERSITY 0x0080
131 #define WI_FLAGS_HAS_HOSTAP 0x0100
132 #define WI_FLAGS_CONNECTED 0x0200
133 #define WI_FLAGS_AP_IN_RANGE 0x0400
134 #define WI_FLAGS_JOINING 0x0800
135
136 struct wi_card_ident {
137 u_int16_t card_id;
138 char *card_name;
139 u_int8_t firm_type;
140 };
141
142 int wi_attach __P((struct wi_softc *));
143 int wi_detach __P((struct wi_softc *));
144 int wi_activate __P((struct device *, enum devact));
145 int wi_intr __P((void *arg));
146 void wi_power __P((struct wi_softc *, int));
147 void wi_shutdown __P((struct wi_softc *));
148
149 int wi_mgmt_xmit(struct wi_softc *, caddr_t, int);
150