Merge from vendor branch DHCP:
[dragonfly.git] / sys / dev / netif / wi / if_wivar.h
1 /*
2  * Copyright (c) 2002
3  *      M Warner Losh <imp@freebsd.org>.  All rights reserved.
4  * Copyright (c) 1997, 1998, 1999
5  *      Bill Paul <wpaul@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  * $FreeBSD: src/sys/dev/wi/if_wivar.h,v 1.22 2004/04/01 00:38:45 sam Exp $
35  * $DragonFly: src/sys/dev/netif/wi/if_wivar.h,v 1.5 2004/09/06 13:52:24 joerg Exp $
36  */
37
38 #if 0
39 #define WICACHE                 /* turn on signal strength cache code */  
40 #define MAXWICACHE      10
41 #endif
42
43 /*
44  * Encryption controls. We can enable or disable encryption as
45  * well as specify up to 4 encryption keys. We can also specify
46  * which of the four keys will be used for transmit encryption.
47  */
48 #define WI_RID_ENCRYPTION       0xFC20
49 #define WI_RID_AUTHTYPE         0xFC21
50 #define WI_RID_DEFLT_CRYPT_KEYS 0xFCB0
51 #define WI_RID_TX_CRYPT_KEY     0xFCB1
52 #define WI_RID_WEP_AVAIL        0xFD4F
53 #define WI_RID_P2_TX_CRYPT_KEY  0xFC23
54 #define WI_RID_P2_CRYPT_KEY0    0xFC24
55 #define WI_RID_P2_CRYPT_KEY1    0xFC25
56 #define WI_RID_MICROWAVE_OVEN   0xFC25
57 #define WI_RID_P2_CRYPT_KEY2    0xFC26
58 #define WI_RID_P2_CRYPT_KEY3    0xFC27
59 #define WI_RID_P2_ENCRYPTION    0xFC28
60 #define WI_RID_ROAMING_MODE     0xFC2D
61 #define WI_RID_CUR_TX_RATE      0xFD44 /* current TX rate */
62
63 struct wi_softc {
64         struct ieee80211com     sc_ic;
65         int                     (*sc_newstate)(struct ieee80211com *,
66                                         enum ieee80211_state, int);
67         device_t                sc_dev;
68         int                     sc_unit;
69         int                     wi_gone;
70         int                     sc_enabled;
71         int                     sc_reset;
72         int                     sc_firmware_type;
73 #define WI_NOTYPE       0
74 #define WI_LUCENT       1
75 #define WI_INTERSIL     2
76 #define WI_SYMBOL       3
77         int                     sc_pri_firmware_ver;    /* Primary firmware */
78         int                     sc_sta_firmware_ver;    /* Station firmware */
79
80         int                     wi_bus_type;    /* Bus attachment type */
81         struct resource *       local;
82         int                     local_rid;
83         struct resource *       iobase;
84         int                     iobase_rid;
85         struct resource *       irq;
86         int                     irq_rid;
87         struct resource *       mem;
88         int                     mem_rid;
89         bus_space_handle_t      wi_localhandle;
90         bus_space_tag_t         wi_localtag;
91         bus_space_handle_t      wi_bhandle;
92         bus_space_tag_t         wi_btag;
93         bus_space_handle_t      wi_bmemhandle;
94         bus_space_tag_t         wi_bmemtag;
95         void *                  wi_intrhand;
96         int                     wi_io_addr;
97         int                     wi_cmd_count;
98
99         struct bpf_if           *sc_drvbpf;
100         int                     sc_flags;
101         int                     sc_if_flags;
102         int                     sc_bap_id;
103         int                     sc_bap_off;
104
105         u_int16_t               sc_procframe;
106         u_int16_t               sc_portnum;
107
108         /* RSSI interpretation */
109         u_int16_t               sc_min_rssi;    /* clamp sc_min_rssi < RSSI */
110         u_int16_t               sc_max_rssi;    /* clamp RSSI < sc_max_rssi */
111         u_int16_t               sc_dbm_offset;  /* dBm ~ RSSI - sc_dbm_offset */
112
113         u_int16_t               sc_max_datalen;
114         u_int16_t               sc_system_scale;
115         u_int16_t               sc_cnfauthmode;
116         u_int16_t               sc_roaming_mode;
117         u_int16_t               sc_microwave_oven;
118         u_int16_t               sc_authtype;
119
120         int                     sc_nodelen;
121         char                    sc_nodename[IEEE80211_NWID_LEN];
122         char                    sc_net_name[IEEE80211_NWID_LEN];
123
124         int                     sc_buflen;              /* TX buffer size */
125         int                     sc_ntxbuf;
126 #define WI_NTXBUF       3
127         struct {
128                 int             d_fid;
129                 int             d_len;
130         }                       sc_txd[WI_NTXBUF];      /* TX buffers */
131         int                     sc_txnext;              /* index of next TX */
132         int                     sc_txcur;               /* index of current TX*/
133         int                     sc_tx_timer;
134         int                     sc_scan_timer;
135         int                     sc_syn_timer;
136
137         struct wi_counters      sc_stats;
138         u_int16_t               sc_ibss_port;
139
140 #define WI_MAXAPINFO            30
141         struct wi_apinfo        sc_aps[WI_MAXAPINFO];
142         int                     sc_naps;
143
144         struct {
145                 u_int16_t               wi_sleep;
146                 u_int16_t               wi_delaysupp;
147                 u_int16_t               wi_txsupp;
148                 u_int16_t               wi_monitor;
149                 u_int16_t               wi_ledtest;
150                 u_int16_t               wi_ledtest_param0;
151                 u_int16_t               wi_ledtest_param1;
152                 u_int16_t               wi_conttx;
153                 u_int16_t               wi_conttx_param0;
154                 u_int16_t               wi_contrx;
155                 u_int16_t               wi_sigstate;
156                 u_int16_t               wi_sigstate_param0;
157                 u_int16_t               wi_confbits;
158                 u_int16_t               wi_confbits_param0;
159         } wi_debug;
160
161         int                     sc_false_syns;
162
163         u_int16_t               sc_txbuf[IEEE80211_MAX_LEN/2];
164
165         union {
166                 struct wi_tx_radiotap_header th;
167                 u_int8_t        pad[64];
168         } u_tx_rt;
169         int                     sc_tx_th_len;
170         union {
171                 struct wi_rx_radiotap_header th;
172                 u_int8_t        pad[64];
173         } u_rx_rt;
174         int                     sc_rx_th_len;
175 };
176 #define sc_if                   sc_ic.ic_if
177 #define sc_tx_th                u_tx_rt.th
178 #define sc_rx_th                u_rx_rt.th
179
180 /* maximum consecutive false change-of-BSSID indications */
181 #define WI_MAX_FALSE_SYNS               10      
182
183 #define WI_SCAN_INQWAIT                 3       /* wait sec before inquire */
184 #define WI_SCAN_WAIT                    5       /* maximum scan wait */
185
186 #define WI_FLAGS_ATTACHED               0x0001
187 #define WI_FLAGS_INITIALIZED            0x0002
188 #define WI_FLAGS_OUTRANGE               0x0004
189 #define WI_FLAGS_HAS_MOR                0x0010
190 #define WI_FLAGS_HAS_ROAMING            0x0020
191 #define WI_FLAGS_HAS_DIVERSITY          0x0040
192 #define WI_FLAGS_HAS_SYSSCALE           0x0080
193 #define WI_FLAGS_BUG_AUTOINC            0x0100
194 #define WI_FLAGS_HAS_FRAGTHR            0x0200
195 #define WI_FLAGS_HAS_DBMADJUST          0x0400
196
197 struct wi_card_ident {
198         u_int16_t       card_id;
199         char            *card_name;
200         u_int8_t        firm_type;
201 };
202
203 #define WI_PRISM_MIN_RSSI       0x1b
204 #define WI_PRISM_MAX_RSSI       0x9a
205 #define WI_PRISM_DBM_OFFSET     100 /* XXX */
206
207 #define WI_LUCENT_MIN_RSSI      47
208 #define WI_LUCENT_MAX_RSSI      138
209 #define WI_LUCENT_DBM_OFFSET    149
210
211 #define WI_RSSI_TO_DBM(sc, rssi) (MIN((sc)->sc_max_rssi, \
212     MAX((sc)->sc_min_rssi, (rssi))) - (sc)->sc_dbm_offset)
213
214 /*
215  * Various compat hacks/kludges
216  */
217 #define ifaddr_byindex(idx) ifnet_addrs[(idx) - 1];
218 #define WI_LOCK_DECL()          int s
219 #define WI_LOCK(_sc)            s = splimp()
220 #define WI_UNLOCK(_sc)          splx(s)
221
222 int     wi_attach(device_t);
223 int     wi_detach(device_t);
224 void    wi_shutdown(device_t);
225 int     wi_alloc(device_t, int);
226 void    wi_free(device_t);
227 extern devclass_t wi_devclass;
228 void    wi_init(void *);
229 void    wi_intr(void *);
230 int     wi_mgmt_xmit(struct wi_softc *, caddr_t, int);
231 void    wi_stop(struct ifnet *, int);
232 int     wi_symbol_load_firm(struct wi_softc *, const void *, int, const void *, int);