1*81779117SImre Vadász /* $FreeBSD: head/sys/dev/usb/wlan/if_rumvar.h 297171 2016-03-21 22:29:24Z avos $ */ 212bd3c8bSSascha Wildner 312bd3c8bSSascha Wildner /*- 412bd3c8bSSascha Wildner * Copyright (c) 2005, 2006 Damien Bergamini <damien.bergamini@free.fr> 512bd3c8bSSascha Wildner * Copyright (c) 2006 Niall O'Higgins <niallo@openbsd.org> 612bd3c8bSSascha Wildner * 712bd3c8bSSascha Wildner * Permission to use, copy, modify, and distribute this software for any 812bd3c8bSSascha Wildner * purpose with or without fee is hereby granted, provided that the above 912bd3c8bSSascha Wildner * copyright notice and this permission notice appear in all copies. 1012bd3c8bSSascha Wildner * 1112bd3c8bSSascha Wildner * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 1212bd3c8bSSascha Wildner * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 1312bd3c8bSSascha Wildner * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 1412bd3c8bSSascha Wildner * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 1512bd3c8bSSascha Wildner * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 1612bd3c8bSSascha Wildner * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 1712bd3c8bSSascha Wildner * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 1812bd3c8bSSascha Wildner */ 1912bd3c8bSSascha Wildner 2012bd3c8bSSascha Wildner #define RUM_TX_LIST_COUNT 8 2112bd3c8bSSascha Wildner #define RUM_TX_MINFREE 2 2212bd3c8bSSascha Wildner 2312bd3c8bSSascha Wildner struct rum_rx_radiotap_header { 2412bd3c8bSSascha Wildner struct ieee80211_radiotap_header wr_ihdr; 25*81779117SImre Vadász uint64_t wr_tsf; 2612bd3c8bSSascha Wildner uint8_t wr_flags; 2712bd3c8bSSascha Wildner uint8_t wr_rate; 2812bd3c8bSSascha Wildner uint16_t wr_chan_freq; 2912bd3c8bSSascha Wildner uint16_t wr_chan_flags; 3012bd3c8bSSascha Wildner int8_t wr_antsignal; 3112bd3c8bSSascha Wildner int8_t wr_antnoise; 3212bd3c8bSSascha Wildner uint8_t wr_antenna; 332e0c716dSMarkus Pfeiffer } __packed __aligned(8); 3412bd3c8bSSascha Wildner 3512bd3c8bSSascha Wildner #define RT2573_RX_RADIOTAP_PRESENT \ 36*81779117SImre Vadász ((1 << IEEE80211_RADIOTAP_TSFT) | \ 37*81779117SImre Vadász (1 << IEEE80211_RADIOTAP_FLAGS) | \ 3812bd3c8bSSascha Wildner (1 << IEEE80211_RADIOTAP_RATE) | \ 3912bd3c8bSSascha Wildner (1 << IEEE80211_RADIOTAP_CHANNEL) | \ 4012bd3c8bSSascha Wildner (1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL) | \ 4112bd3c8bSSascha Wildner (1 << IEEE80211_RADIOTAP_DBM_ANTNOISE) | \ 4212bd3c8bSSascha Wildner (1 << IEEE80211_RADIOTAP_ANTENNA) | \ 4312bd3c8bSSascha Wildner 0) 4412bd3c8bSSascha Wildner 4512bd3c8bSSascha Wildner struct rum_tx_radiotap_header { 4612bd3c8bSSascha Wildner struct ieee80211_radiotap_header wt_ihdr; 47*81779117SImre Vadász uint64_t wt_tsf; 4812bd3c8bSSascha Wildner uint8_t wt_flags; 4912bd3c8bSSascha Wildner uint8_t wt_rate; 5012bd3c8bSSascha Wildner uint16_t wt_chan_freq; 5112bd3c8bSSascha Wildner uint16_t wt_chan_flags; 5212bd3c8bSSascha Wildner uint8_t wt_antenna; 532e0c716dSMarkus Pfeiffer } __packed __aligned(8); 5412bd3c8bSSascha Wildner 5512bd3c8bSSascha Wildner #define RT2573_TX_RADIOTAP_PRESENT \ 56*81779117SImre Vadász ((1 << IEEE80211_RADIOTAP_TSFT) | \ 57*81779117SImre Vadász (1 << IEEE80211_RADIOTAP_FLAGS) | \ 5812bd3c8bSSascha Wildner (1 << IEEE80211_RADIOTAP_RATE) | \ 5912bd3c8bSSascha Wildner (1 << IEEE80211_RADIOTAP_CHANNEL) | \ 6012bd3c8bSSascha Wildner (1 << IEEE80211_RADIOTAP_ANTENNA)) 6112bd3c8bSSascha Wildner 6212bd3c8bSSascha Wildner struct rum_softc; 6312bd3c8bSSascha Wildner 6412bd3c8bSSascha Wildner struct rum_tx_data { 6512bd3c8bSSascha Wildner STAILQ_ENTRY(rum_tx_data) next; 6612bd3c8bSSascha Wildner struct rum_softc *sc; 6712bd3c8bSSascha Wildner struct rum_tx_desc desc; 6812bd3c8bSSascha Wildner struct mbuf *m; 6912bd3c8bSSascha Wildner struct ieee80211_node *ni; 7012bd3c8bSSascha Wildner int rate; 7112bd3c8bSSascha Wildner }; 7212bd3c8bSSascha Wildner typedef STAILQ_HEAD(, rum_tx_data) rum_txdhead; 7312bd3c8bSSascha Wildner 74*81779117SImre Vadász union sec_param { 75*81779117SImre Vadász struct ieee80211_key key; 76*81779117SImre Vadász uint8_t macaddr[IEEE80211_ADDR_LEN]; 77*81779117SImre Vadász struct ieee80211vap *vap; 78*81779117SImre Vadász }; 79*81779117SImre Vadász #define CMD_FUNC_PROTO void (*func)(struct rum_softc *, \ 80*81779117SImre Vadász union sec_param *, uint8_t) 81*81779117SImre Vadász 82*81779117SImre Vadász struct rum_cmdq { 83*81779117SImre Vadász union sec_param data; 84*81779117SImre Vadász uint8_t rvp_id; 85*81779117SImre Vadász 86*81779117SImre Vadász CMD_FUNC_PROTO; 87*81779117SImre Vadász }; 88*81779117SImre Vadász #define RUM_CMDQ_SIZE 16 89*81779117SImre Vadász 9012bd3c8bSSascha Wildner struct rum_vap { 9112bd3c8bSSascha Wildner struct ieee80211vap vap; 92*81779117SImre Vadász struct mbuf *bcn_mbuf; 9312bd3c8bSSascha Wildner struct usb_callout ratectl_ch; 9412bd3c8bSSascha Wildner struct task ratectl_task; 95*81779117SImre Vadász uint8_t maxretry; 9612bd3c8bSSascha Wildner 9712bd3c8bSSascha Wildner int (*newstate)(struct ieee80211vap *, 9812bd3c8bSSascha Wildner enum ieee80211_state, int); 99*81779117SImre Vadász void (*bmiss)(struct ieee80211vap *); 100*81779117SImre Vadász void (*recv_mgmt)(struct ieee80211_node *, 101*81779117SImre Vadász struct mbuf *, int, 102*81779117SImre Vadász const struct ieee80211_rx_stats *, 103*81779117SImre Vadász int, int); 10412bd3c8bSSascha Wildner }; 10512bd3c8bSSascha Wildner #define RUM_VAP(vap) ((struct rum_vap *)(vap)) 10612bd3c8bSSascha Wildner 10712bd3c8bSSascha Wildner enum { 10812bd3c8bSSascha Wildner RUM_BULK_WR, 10912bd3c8bSSascha Wildner RUM_BULK_RD, 11012bd3c8bSSascha Wildner RUM_N_TRANSFER = 2, 11112bd3c8bSSascha Wildner }; 11212bd3c8bSSascha Wildner 11312bd3c8bSSascha Wildner struct rum_softc { 114*81779117SImre Vadász struct ieee80211com sc_ic; 115*81779117SImre Vadász struct mbufq sc_snd; 11612bd3c8bSSascha Wildner device_t sc_dev; 11712bd3c8bSSascha Wildner struct usb_device *sc_udev; 11812bd3c8bSSascha Wildner 11912bd3c8bSSascha Wildner struct usb_xfer *sc_xfer[RUM_N_TRANSFER]; 12012bd3c8bSSascha Wildner 12112bd3c8bSSascha Wildner uint8_t rf_rev; 12212bd3c8bSSascha Wildner uint8_t rffreq; 12312bd3c8bSSascha Wildner 12412bd3c8bSSascha Wildner struct rum_tx_data tx_data[RUM_TX_LIST_COUNT]; 12512bd3c8bSSascha Wildner rum_txdhead tx_q; 12612bd3c8bSSascha Wildner rum_txdhead tx_free; 12712bd3c8bSSascha Wildner int tx_nfree; 12812bd3c8bSSascha Wildner struct rum_rx_desc sc_rx_desc; 12912bd3c8bSSascha Wildner 130f794c13fSSascha Wildner struct lock sc_lock; 13112bd3c8bSSascha Wildner 132*81779117SImre Vadász int sc_sleep_end; 133*81779117SImre Vadász int sc_sleep_time; 134*81779117SImre Vadász uint8_t last_rx_flags; 135*81779117SImre Vadász 136*81779117SImre Vadász struct rum_cmdq cmdq[RUM_CMDQ_SIZE]; 137*81779117SImre Vadász struct lock cmdq_lock; 138*81779117SImre Vadász struct task cmdq_task; 139*81779117SImre Vadász uint8_t cmdq_first; 140*81779117SImre Vadász uint8_t cmdq_last; 141*81779117SImre Vadász 14212bd3c8bSSascha Wildner uint32_t sta[6]; 14312bd3c8bSSascha Wildner uint32_t rf_regs[4]; 14412bd3c8bSSascha Wildner uint8_t txpow[44]; 145*81779117SImre Vadász u_int sc_detached:1, 146*81779117SImre Vadász sc_running:1, 147*81779117SImre Vadász sc_sleeping:1, 148*81779117SImre Vadász sc_clr_shkeys:1; 149*81779117SImre Vadász 150*81779117SImre Vadász uint8_t sc_bssid[IEEE80211_ADDR_LEN]; 151*81779117SImre Vadász struct wmeParams wme_params[WME_NUM_AC]; 152*81779117SImre Vadász 153*81779117SImre Vadász uint8_t vap_key_count[1]; 154*81779117SImre Vadász uint64_t keys_bmap; 15512bd3c8bSSascha Wildner 15612bd3c8bSSascha Wildner struct { 15712bd3c8bSSascha Wildner uint8_t val; 15812bd3c8bSSascha Wildner uint8_t reg; 15912bd3c8bSSascha Wildner } __packed bbp_prom[16]; 16012bd3c8bSSascha Wildner 16112bd3c8bSSascha Wildner int hw_radio; 16212bd3c8bSSascha Wildner int rx_ant; 16312bd3c8bSSascha Wildner int tx_ant; 16412bd3c8bSSascha Wildner int nb_ant; 16512bd3c8bSSascha Wildner int ext_2ghz_lna; 16612bd3c8bSSascha Wildner int ext_5ghz_lna; 16712bd3c8bSSascha Wildner int rssi_2ghz_corr; 16812bd3c8bSSascha Wildner int rssi_5ghz_corr; 16912bd3c8bSSascha Wildner uint8_t bbp17; 17012bd3c8bSSascha Wildner 17112bd3c8bSSascha Wildner struct rum_rx_radiotap_header sc_rxtap; 17212bd3c8bSSascha Wildner struct rum_tx_radiotap_header sc_txtap; 17312bd3c8bSSascha Wildner }; 17412bd3c8bSSascha Wildner 175*81779117SImre Vadász #define RUM_LOCK_INIT(sc) \ 176*81779117SImre Vadász lockinit(&(sc)->sc_lock, device_get_nameunit((sc)->sc_dev), \ 177*81779117SImre Vadász 0, LK_CANRECURSE) 178f794c13fSSascha Wildner #define RUM_LOCK(sc) lockmgr(&(sc)->sc_lock, LK_EXCLUSIVE) 179f794c13fSSascha Wildner #define RUM_UNLOCK(sc) lockmgr(&(sc)->sc_lock, LK_RELEASE) 180*81779117SImre Vadász #define RUM_LOCK_ASSERT(sc) KKASSERT(lockstatus(&(sc)->sc_lock, curthread) == LK_EXCLUSIVE) 181*81779117SImre Vadász #define RUM_LOCK_DESTROY(sc) lockuninit(&(sc)->sc_lock) 182*81779117SImre Vadász 183*81779117SImre Vadász #define RUM_CMDQ_LOCK_INIT(sc) \ 184*81779117SImre Vadász lockinit(&(sc)->cmdq_lock, "cmdq lock", 0, LK_CANRECURSE) 185*81779117SImre Vadász #define RUM_CMDQ_LOCK(sc) lockmgr(&(sc)->cmdq_lock, LK_EXCLUSIVE) 186*81779117SImre Vadász #define RUM_CMDQ_UNLOCK(sc) lockmgr(&(sc)->cmdq_lock, LK_RELEASE) 187*81779117SImre Vadász #define RUM_CMDQ_LOCK_DESTROY(sc) lockuninit(&(sc)->cmdq_lock) 188