FreeBSD kernel usb device Code
if_rumvar.h
Go to the documentation of this file.
1/* $FreeBSD$ */
3/*-
4 * Copyright (c) 2005, 2006 Damien Bergamini <damien.bergamini@free.fr>
5 * Copyright (c) 2006 Niall O'Higgins <niallo@openbsd.org>
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#define RUM_TX_LIST_COUNT 8
21#define RUM_TX_MINFREE 2
22
24 struct ieee80211_radiotap_header wr_ihdr;
25 uint64_t wr_tsf;
26 uint8_t wr_flags;
27 uint8_t wr_rate;
28 uint16_t wr_chan_freq;
29 uint16_t wr_chan_flags;
32 uint8_t wr_antenna;
34
35#define RT2573_RX_RADIOTAP_PRESENT \
36 ((1 << IEEE80211_RADIOTAP_TSFT) | \
37 (1 << IEEE80211_RADIOTAP_FLAGS) | \
38 (1 << IEEE80211_RADIOTAP_RATE) | \
39 (1 << IEEE80211_RADIOTAP_CHANNEL) | \
40 (1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL) | \
41 (1 << IEEE80211_RADIOTAP_DBM_ANTNOISE) | \
42 (1 << IEEE80211_RADIOTAP_ANTENNA) | \
43 0)
44
46 struct ieee80211_radiotap_header wt_ihdr;
47 uint8_t wt_flags;
48 uint8_t wt_rate;
49 uint16_t wt_chan_freq;
50 uint16_t wt_chan_flags;
51 uint8_t wt_antenna;
53
54#define RT2573_TX_RADIOTAP_PRESENT \
55 ((1 << IEEE80211_RADIOTAP_FLAGS) | \
56 (1 << IEEE80211_RADIOTAP_RATE) | \
57 (1 << IEEE80211_RADIOTAP_CHANNEL) | \
58 (1 << IEEE80211_RADIOTAP_ANTENNA))
59
60struct rum_softc;
61
64 struct rum_softc *sc;
66 struct mbuf *m;
67 struct ieee80211_node *ni;
68 int rate;
69};
70typedef STAILQ_HEAD(, rum_tx_data) rum_txdhead;
71
72union sec_param {
73 struct ieee80211_key key;
74 uint8_t macaddr[IEEE80211_ADDR_LEN];
75 struct ieee80211vap *vap;
76};
77#define CMD_FUNC_PROTO void (*func)(struct rum_softc *, \
78 union sec_param *, uint8_t)
79
80struct rum_cmdq {
82 uint8_t rvp_id;
83
85};
86#define RUM_CMDQ_SIZE 16
87
88struct rum_vap {
89 struct ieee80211vap vap;
90 struct mbuf *bcn_mbuf;
92 struct task ratectl_task;
93 uint8_t maxretry;
94
95 int (*newstate)(struct ieee80211vap *,
96 enum ieee80211_state, int);
97 void (*bmiss)(struct ieee80211vap *);
98 void (*recv_mgmt)(struct ieee80211_node *,
99 struct mbuf *, int,
100 const struct ieee80211_rx_stats *,
101 int, int);
102};
103#define RUM_VAP(vap) ((struct rum_vap *)(vap))
104
105enum {
109};
110
111struct rum_softc {
112 struct ieee80211com sc_ic;
113 struct ieee80211_ratectl_tx_stats sc_txs;
114 struct mbufq sc_snd;
115 device_t sc_dev;
117
119
120 uint8_t rf_rev;
121 uint8_t rffreq;
122
124 rum_txdhead tx_q;
125 rum_txdhead tx_free;
128
129 struct mtx sc_mtx;
130
134
136 struct mtx cmdq_mtx;
137 struct task cmdq_task;
138 uint8_t cmdq_first;
139 uint8_t cmdq_last;
140
141 uint32_t sta[6];
142 uint32_t rf_regs[4];
143 uint8_t txpow[44];
144 u_int sc_detached:1,
148
149 uint8_t sc_bssid[IEEE80211_ADDR_LEN];
150 struct wmeParams wme_params[WME_NUM_AC];
151
152 uint8_t vap_key_count[1];
153 uint64_t keys_bmap;
154
155 struct {
156 uint8_t val;
157 uint8_t reg;
159
168 uint8_t bbp17;
169
172};
173
174#define RUM_LOCK_INIT(sc) \
175 mtx_init(&(sc)->sc_mtx, device_get_nameunit((sc)->sc_dev), \
176 MTX_NETWORK_LOCK, MTX_DEF);
177#define RUM_LOCK(sc) mtx_lock(&(sc)->sc_mtx)
178#define RUM_UNLOCK(sc) mtx_unlock(&(sc)->sc_mtx)
179#define RUM_LOCK_ASSERT(sc) mtx_assert(&(sc)->sc_mtx, MA_OWNED)
180#define RUM_LOCK_DESTROY(sc) mtx_destroy(&(sc)->sc_mtx)
181
182#define RUM_CMDQ_LOCK_INIT(sc) \
183 mtx_init(&(sc)->cmdq_mtx, "cmdq lock", NULL, MTX_DEF)
184#define RUM_CMDQ_LOCK(sc) mtx_lock(&(sc)->cmdq_mtx)
185#define RUM_CMDQ_UNLOCK(sc) mtx_unlock(&(sc)->cmdq_mtx)
186#define RUM_CMDQ_LOCK_DESTROY(sc) mtx_destroy(&(sc)->cmdq_mtx)
struct ehci_itd * next
Definition: ehci.h:29
struct rum_tx_radiotap_header __packed
@ RUM_BULK_RD
Definition: if_rumvar.h:107
@ RUM_BULK_WR
Definition: if_rumvar.h:106
@ RUM_N_TRANSFER
Definition: if_rumvar.h:108
typedef STAILQ_HEAD(, rum_tx_data) rum_txdhead
#define RUM_CMDQ_SIZE
Definition: if_rumvar.h:86
struct rum_rx_radiotap_header __aligned(8)
#define RUM_TX_LIST_COUNT
Definition: if_rumvar.h:20
CMD_FUNC_PROTO
Definition: if_rumvar.h:84
uint8_t rvp_id
Definition: if_rumvar.h:82
union sec_param data
Definition: if_rumvar.h:81
struct ieee80211_radiotap_header wr_ihdr
Definition: if_rumvar.h:24
uint16_t wr_chan_flags
Definition: if_rumvar.h:29
struct ieee80211_ratectl_tx_stats sc_txs
Definition: if_rumvar.h:113
struct wmeParams wme_params[WME_NUM_AC]
Definition: if_rumvar.h:150
uint8_t val
Definition: if_rumvar.h:156
struct mbufq sc_snd
Definition: if_rumvar.h:114
uint8_t last_rx_flags
Definition: if_rumvar.h:133
u_int sc_detached
Definition: if_rumvar.h:144
struct rum_rx_desc sc_rx_desc
Definition: if_rumvar.h:127
rum_txdhead tx_free
Definition: if_rumvar.h:125
struct rum_rx_radiotap_header sc_rxtap
Definition: if_rumvar.h:170
int sc_sleep_end
Definition: if_rumvar.h:131
uint8_t txpow[44]
Definition: if_rumvar.h:143
uint8_t cmdq_first
Definition: if_rumvar.h:138
struct rum_tx_data tx_data[RUM_TX_LIST_COUNT]
Definition: if_rumvar.h:123
int hw_radio
Definition: if_rumvar.h:160
int rx_ant
Definition: if_rumvar.h:161
int nb_ant
Definition: if_rumvar.h:163
int tx_nfree
Definition: if_rumvar.h:126
int tx_ant
Definition: if_rumvar.h:162
u_int sc_sleeping
Definition: if_rumvar.h:146
struct mtx sc_mtx
Definition: if_rumvar.h:129
struct rum_cmdq cmdq[RUM_CMDQ_SIZE]
Definition: if_rumvar.h:135
uint8_t cmdq_last
Definition: if_rumvar.h:139
struct ieee80211com sc_ic
Definition: if_rumvar.h:112
int rssi_5ghz_corr
Definition: if_rumvar.h:167
struct usb_device * sc_udev
Definition: if_rumvar.h:116
uint32_t rf_regs[4]
Definition: if_rumvar.h:142
u_int sc_clr_shkeys
Definition: if_rumvar.h:147
uint8_t rf_rev
Definition: if_rumvar.h:120
struct rum_softc::@101 bbp_prom[16]
int sc_sleep_time
Definition: if_rumvar.h:132
u_int sc_running
Definition: if_rumvar.h:145
int ext_2ghz_lna
Definition: if_rumvar.h:164
uint32_t sta[6]
Definition: if_rumvar.h:141
uint64_t keys_bmap
Definition: if_rumvar.h:153
struct rum_tx_radiotap_header sc_txtap
Definition: if_rumvar.h:171
uint8_t vap_key_count[1]
Definition: if_rumvar.h:152
rum_txdhead tx_q
Definition: if_rumvar.h:124
uint8_t sc_bssid[IEEE80211_ADDR_LEN]
Definition: if_rumvar.h:149
uint8_t rffreq
Definition: if_rumvar.h:121
uint8_t reg
Definition: if_rumvar.h:157
struct task cmdq_task
Definition: if_rumvar.h:137
struct usb_xfer * sc_xfer[RUM_N_TRANSFER]
Definition: if_rumvar.h:118
int rssi_2ghz_corr
Definition: if_rumvar.h:166
device_t sc_dev
Definition: if_rumvar.h:115
uint8_t bbp17
Definition: if_rumvar.h:168
struct mtx cmdq_mtx
Definition: if_rumvar.h:136
int ext_5ghz_lna
Definition: if_rumvar.h:165
struct rum_tx_desc desc
Definition: if_rumvar.h:65
STAILQ_ENTRY(rum_tx_data) next
struct mbuf * m
Definition: if_rumvar.h:66
struct ieee80211_node * ni
Definition: if_rumvar.h:67
struct rum_softc * sc
Definition: if_rumvar.h:64
uint16_t wt_chan_flags
Definition: if_rumvar.h:50
struct ieee80211_radiotap_header wt_ihdr
Definition: if_rumvar.h:46
struct usb_callout ratectl_ch
Definition: if_rumvar.h:91
uint8_t maxretry
Definition: if_rumvar.h:93
struct ieee80211vap vap
Definition: if_rumvar.h:89
void(* recv_mgmt)(struct ieee80211_node *, struct mbuf *, int, const struct ieee80211_rx_stats *, int, int)
Definition: if_rumvar.h:98
struct task ratectl_task
Definition: if_rumvar.h:92
void(* bmiss)(struct ieee80211vap *)
Definition: if_rumvar.h:97
struct mbuf * bcn_mbuf
Definition: if_rumvar.h:90
int(* newstate)(struct ieee80211vap *, enum ieee80211_state, int)
Definition: if_rumvar.h:95
struct ieee80211_key key
Definition: if_rumvar.h:73
struct ieee80211vap * vap
Definition: if_rumvar.h:75
uint8_t macaddr[IEEE80211_ADDR_LEN]
Definition: if_rumvar.h:74