xref: /openbsd-src/sys/dev/ic/rt2661var.h (revision d13be5d47e4149db2549a9828e244d59dbc43f15)
1 /*	$OpenBSD: rt2661var.h,v 1.14 2011/03/18 06:05:21 deraadt Exp $	*/
2 
3 /*-
4  * Copyright (c) 2006
5  *	Damien Bergamini <damien.bergamini@free.fr>
6  *
7  * Permission to use, copy, modify, and distribute this software for any
8  * purpose with or without fee is hereby granted, provided that the above
9  * copyright notice and this permission notice appear in all copies.
10  *
11  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18  */
19 
20 struct rt2661_rx_radiotap_header {
21 	struct ieee80211_radiotap_header wr_ihdr;
22 	uint64_t	wr_tsf;
23 	uint8_t		wr_flags;
24 	uint8_t		wr_rate;
25 	uint16_t	wr_chan_freq;
26 	uint16_t	wr_chan_flags;
27 	uint8_t		wr_antsignal;
28 } __packed;
29 
30 #define RT2661_RX_RADIOTAP_PRESENT					\
31 	((1 << IEEE80211_RADIOTAP_TSFT) |				\
32 	 (1 << IEEE80211_RADIOTAP_FLAGS) |				\
33 	 (1 << IEEE80211_RADIOTAP_RATE) |				\
34 	 (1 << IEEE80211_RADIOTAP_CHANNEL) |				\
35 	 (1 << IEEE80211_RADIOTAP_DB_ANTSIGNAL))
36 
37 struct rt2661_tx_radiotap_header {
38 	struct ieee80211_radiotap_header wt_ihdr;
39 	uint8_t		wt_flags;
40 	uint8_t		wt_rate;
41 	uint16_t	wt_chan_freq;
42 	uint16_t	wt_chan_flags;
43 } __packed;
44 
45 #define RT2661_TX_RADIOTAP_PRESENT					\
46 	((1 << IEEE80211_RADIOTAP_FLAGS) |				\
47 	 (1 << IEEE80211_RADIOTAP_RATE) |				\
48 	 (1 << IEEE80211_RADIOTAP_CHANNEL))
49 
50 struct rt2661_tx_data {
51 	bus_dmamap_t			map;
52 	struct mbuf			*m;
53 	struct ieee80211_node		*ni;
54 };
55 
56 struct rt2661_tx_ring {
57 	bus_dmamap_t		map;
58 	bus_dma_segment_t	seg;
59 	bus_addr_t		physaddr;
60 	struct rt2661_tx_desc	*desc;
61 	struct rt2661_tx_data	*data;
62 	int			count;
63 	int			queued;
64 	int			cur;
65 	int			next;
66 	int			stat;
67 };
68 
69 struct rt2661_rx_data {
70 	bus_dmamap_t	map;
71 	struct mbuf	*m;
72 };
73 
74 struct rt2661_rx_ring {
75 	bus_dmamap_t		map;
76 	bus_dma_segment_t	seg;
77 	bus_addr_t		physaddr;
78 	struct rt2661_rx_desc	*desc;
79 	struct rt2661_rx_data	*data;
80 	int			count;
81 	int			cur;
82 	int			next;
83 };
84 
85 struct rt2661_node {
86 	struct ieee80211_node		ni;
87 	struct ieee80211_amrr_node	amn;
88 };
89 
90 struct rt2661_softc {
91 	struct device			sc_dev;
92 
93 	struct ieee80211com		sc_ic;
94 	int				(*sc_newstate)(struct ieee80211com *,
95 					    enum ieee80211_state, int);
96 	struct ieee80211_amrr		amrr;
97 
98 	int				(*sc_enable)(struct rt2661_softc *);
99 	void				(*sc_disable)(struct rt2661_softc *);
100 
101 	bus_dma_tag_t			sc_dmat;
102 	bus_space_tag_t			sc_st;
103 	bus_space_handle_t		sc_sh;
104 
105 	struct timeout			scan_to;
106 	struct timeout			amrr_to;
107 
108 	int				sc_id;
109 	int				sc_flags;
110 #define RT2661_ENABLED		(1 << 0)
111 #define RT2661_UPDATE_SLOT	(1 << 1)
112 #define RT2661_SET_SLOTTIME	(1 << 2)
113 #define RT2661_FWLOADED		(1 << 3)
114 
115 	int				sc_tx_timer;
116 
117 	struct ieee80211_channel	*sc_curchan;
118 
119 	u_char				*ucode;
120 	size_t				ucsize;
121 
122 	uint8_t				rf_rev;
123 
124 	uint8_t				rfprog;
125 	uint8_t				rffreq;
126 
127 	struct rt2661_tx_ring		txq[5];
128 	struct rt2661_tx_ring		mgtq;
129 	struct rt2661_rx_ring		rxq;
130 
131 	uint32_t			rf_regs[4];
132 	int8_t				txpow[38];
133 
134 	struct {
135 		uint8_t	reg;
136 		uint8_t	val;
137 	}				bbp_prom[16];
138 
139 	int				hw_radio;
140 	int				rx_ant;
141 	int				tx_ant;
142 	int				nb_ant;
143 	int				ext_2ghz_lna;
144 	int				ext_5ghz_lna;
145 	int				rssi_2ghz_corr;
146 	int				rssi_5ghz_corr;
147 
148 	int				ncalls;
149 	int				avg_rssi;
150 	int				sifs;
151 
152 	uint32_t			erp_csr;
153 
154 	uint8_t				bbp18;
155 	uint8_t				bbp21;
156 	uint8_t				bbp22;
157 	uint8_t				bbp16;
158 	uint8_t				bbp17;
159 	uint8_t				bbp64;
160 
161 #if NBPFILTER > 0
162 	caddr_t				sc_drvbpf;
163 
164 	union {
165 		struct rt2661_rx_radiotap_header th;
166 		uint8_t	pad[64];
167 	}				sc_rxtapu;
168 #define sc_rxtap			sc_rxtapu.th
169 	int				sc_rxtap_len;
170 
171 	union {
172 		struct rt2661_tx_radiotap_header th;
173 		uint8_t	pad[64];
174 	}				sc_txtapu;
175 #define sc_txtap			sc_txtapu.th
176 	int				sc_txtap_len;
177 #endif
178 };
179 
180 int	rt2661_attach(void *, int);
181 int	rt2661_detach(void *);
182 void	rt2661_suspend(void *);
183 void	rt2661_resume(void *);
184 int	rt2661_intr(void *);
185