Home | History | Annotate | Line # | Download | only in usb
if_urtwnvar.h revision 1.8.4.4
      1  1.8.4.4     skrll /*	$NetBSD: if_urtwnvar.h,v 1.8.4.4 2016/12/05 10:55:18 skrll Exp $	*/
      2      1.1    nonaka /*	$OpenBSD: if_urtwnreg.h,v 1.3 2010/11/16 18:02:59 damien Exp $	*/
      3      1.1    nonaka 
      4      1.1    nonaka /*-
      5      1.1    nonaka  * Copyright (c) 2010 Damien Bergamini <damien.bergamini (at) free.fr>
      6      1.1    nonaka  *
      7      1.1    nonaka  * Permission to use, copy, modify, and distribute this software for any
      8      1.1    nonaka  * purpose with or without fee is hereby granted, provided that the above
      9      1.1    nonaka  * copyright notice and this permission notice appear in all copies.
     10      1.1    nonaka  *
     11      1.1    nonaka  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
     12      1.1    nonaka  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
     13      1.1    nonaka  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
     14      1.1    nonaka  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
     15      1.1    nonaka  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
     16      1.1    nonaka  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
     17      1.1    nonaka  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
     18      1.1    nonaka  */
     19      1.4  christos #ifndef _IF_URTWNVAR_H_
     20      1.4  christos #define _IF_URTWNVAR_H_
     21      1.1    nonaka 
     22      1.1    nonaka /*
     23      1.1    nonaka  * Driver definitions.
     24      1.1    nonaka  */
     25      1.1    nonaka #define URTWN_RX_LIST_COUNT		1
     26      1.1    nonaka #define URTWN_TX_LIST_COUNT		8
     27      1.6     skrll 
     28      1.1    nonaka #define URTWN_HOST_CMD_RING_COUNT	32
     29      1.1    nonaka 
     30      1.1    nonaka #define URTWN_RXBUFSZ	(16 * 1024)
     31      1.1    nonaka #define URTWN_TXBUFSZ	(sizeof(struct r92c_tx_desc) + IEEE80211_MAX_LEN + 8)
     32      1.1    nonaka 
     33      1.1    nonaka #define URTWN_RIDX_COUNT	28
     34      1.1    nonaka 
     35      1.1    nonaka #define URTWN_TX_TIMEOUT	5000	/* ms */
     36      1.1    nonaka 
     37      1.1    nonaka #define URTWN_LED_LINK	0
     38      1.1    nonaka #define URTWN_LED_DATA	1
     39      1.1    nonaka 
     40      1.1    nonaka struct urtwn_rx_radiotap_header {
     41      1.1    nonaka 	struct ieee80211_radiotap_header wr_ihdr;
     42      1.1    nonaka 	uint8_t		wr_flags;
     43      1.1    nonaka 	uint8_t		wr_rate;
     44      1.1    nonaka 	uint16_t	wr_chan_freq;
     45      1.1    nonaka 	uint16_t	wr_chan_flags;
     46      1.1    nonaka 	uint8_t		wr_dbm_antsignal;
     47      1.1    nonaka } __packed;
     48      1.1    nonaka 
     49      1.1    nonaka #define URTWN_RX_RADIOTAP_PRESENT			\
     50      1.1    nonaka 	(1 << IEEE80211_RADIOTAP_FLAGS |		\
     51      1.1    nonaka 	 1 << IEEE80211_RADIOTAP_RATE |			\
     52      1.1    nonaka 	 1 << IEEE80211_RADIOTAP_CHANNEL |		\
     53      1.1    nonaka 	 1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL)
     54      1.1    nonaka 
     55      1.1    nonaka struct urtwn_tx_radiotap_header {
     56      1.1    nonaka 	struct ieee80211_radiotap_header wt_ihdr;
     57      1.1    nonaka 	uint8_t		wt_flags;
     58      1.1    nonaka 	uint16_t	wt_chan_freq;
     59      1.1    nonaka 	uint16_t	wt_chan_flags;
     60      1.1    nonaka } __packed;
     61      1.1    nonaka 
     62      1.1    nonaka #define URTWN_TX_RADIOTAP_PRESENT			\
     63      1.1    nonaka 	(1 << IEEE80211_RADIOTAP_FLAGS |		\
     64      1.1    nonaka 	 1 << IEEE80211_RADIOTAP_CHANNEL)
     65      1.1    nonaka 
     66      1.1    nonaka struct urtwn_softc;
     67      1.1    nonaka 
     68      1.1    nonaka struct urtwn_rx_data {
     69  1.8.4.4     skrll 	struct urtwn_softc		*sc;
     70  1.8.4.4     skrll 	size_t				pidx;
     71  1.8.4.4     skrll 	struct usbd_xfer		*xfer;
     72  1.8.4.4     skrll 	uint8_t				*buf;
     73  1.8.4.4     skrll 	TAILQ_ENTRY(urtwn_rx_data)	next;
     74      1.1    nonaka };
     75      1.1    nonaka 
     76      1.1    nonaka struct urtwn_tx_data {
     77      1.1    nonaka 	struct urtwn_softc		*sc;
     78  1.8.4.2     skrll 	size_t				pidx;
     79  1.8.4.3     skrll 	struct usbd_xfer		*xfer;
     80      1.1    nonaka 	uint8_t				*buf;
     81      1.1    nonaka 	TAILQ_ENTRY(urtwn_tx_data)	next;
     82      1.1    nonaka };
     83      1.1    nonaka 
     84      1.1    nonaka struct urtwn_host_cmd {
     85      1.1    nonaka 	void	(*cb)(struct urtwn_softc *, void *);
     86      1.1    nonaka 	uint8_t	data[256];
     87      1.1    nonaka };
     88      1.1    nonaka 
     89      1.1    nonaka struct urtwn_cmd_newstate {
     90      1.1    nonaka 	enum ieee80211_state	state;
     91      1.1    nonaka 	int			arg;
     92      1.1    nonaka };
     93      1.1    nonaka 
     94      1.1    nonaka struct urtwn_host_cmd_ring {
     95      1.1    nonaka 	struct urtwn_host_cmd	cmd[URTWN_HOST_CMD_RING_COUNT];
     96      1.1    nonaka 	int			cur;
     97      1.1    nonaka 	int			next;
     98      1.1    nonaka 	int			queued;
     99      1.1    nonaka };
    100      1.1    nonaka 
    101      1.1    nonaka #if 1	/* XXX: sys/net80211/ieee80211.h */
    102      1.1    nonaka 
    103      1.1    nonaka #define	IEEE80211_HTINFO_2NDCHAN	0x03	/* secondary/ext chan offset */
    104      1.1    nonaka #define	IEEE80211_HTINFO_2NDCHAN_S	0
    105      1.1    nonaka #define	IEEE80211_HTINFO_2NDCHAN_NONE	0x00	/* no secondary/ext channel */
    106      1.1    nonaka #define	IEEE80211_HTINFO_2NDCHAN_ABOVE	0x01	/* above private channel */
    107      1.1    nonaka /* NB: 2 is reserved */
    108      1.1    nonaka #define	IEEE80211_HTINFO_2NDCHAN_BELOW	0x03	/* below primary channel */
    109      1.1    nonaka #endif	/* XXX: 1 */
    110      1.1    nonaka 
    111      1.1    nonaka struct urtwn_softc {
    112      1.1    nonaka 	device_t			sc_dev;
    113      1.1    nonaka 	struct ieee80211com		sc_ic;
    114      1.1    nonaka 	struct ethercom			sc_ec;
    115      1.1    nonaka #define sc_if   sc_ec.ec_if
    116      1.1    nonaka 	int				(*sc_newstate)(struct ieee80211com *,
    117      1.1    nonaka 					    enum ieee80211_state, int);
    118      1.1    nonaka 
    119  1.8.4.1     skrll 	struct usbd_device *		sc_udev;
    120  1.8.4.1     skrll 	struct usbd_interface *		sc_iface;
    121      1.1    nonaka 	u_int				sc_flags;
    122      1.1    nonaka #define URTWN_FLAG_CCK_HIPWR	__BIT(0)
    123      1.1    nonaka #define	URTWN_FLAG_ATTACHED	__BIT(1)
    124      1.1    nonaka #define	URTWN_FLAG_FWREADY	__BIT(2)
    125      1.1    nonaka 	int				sc_dying;
    126      1.1    nonaka 
    127      1.1    nonaka 	struct usb_task			sc_task;
    128      1.1    nonaka 	callout_t			sc_scan_to;
    129      1.1    nonaka 	callout_t			sc_calib_to;
    130      1.1    nonaka 
    131      1.1    nonaka 	kmutex_t			sc_task_mtx;
    132      1.1    nonaka 	kmutex_t			sc_fwcmd_mtx;
    133      1.1    nonaka 	kmutex_t			sc_tx_mtx;
    134  1.8.4.4     skrll 	kmutex_t			sc_rx_mtx;
    135      1.4  christos 	kmutex_t			sc_write_mtx;
    136      1.1    nonaka 
    137  1.8.4.4     skrll 	struct usbd_pipe *		rx_pipe[R92C_MAX_EPIN];
    138      1.1    nonaka 	int				rx_npipe;
    139  1.8.4.1     skrll 	struct usbd_pipe *		tx_pipe[R92C_MAX_EPOUT];
    140      1.1    nonaka 	int				tx_npipe;
    141      1.1    nonaka 	int				ac2idx[WME_NUM_AC];
    142      1.1    nonaka 
    143      1.1    nonaka 	u_int				chip;
    144      1.1    nonaka #define URTWN_CHIP_92C		0x01
    145      1.1    nonaka #define URTWN_CHIP_92C_1T2R	0x02
    146      1.1    nonaka #define URTWN_CHIP_UMC		0x04
    147      1.1    nonaka #define URTWN_CHIP_UMC_A_CUT	0x08
    148      1.8    nonaka #define URTWN_CHIP_88E		0x10
    149  1.8.4.4     skrll #define URTWN_CHIP_92EU		0x20
    150      1.8    nonaka 
    151      1.8    nonaka 	void				(*sc_rf_write)(struct urtwn_softc *,
    152      1.8    nonaka 					    int, uint8_t, uint32_t);
    153      1.8    nonaka 	int				(*sc_power_on)(struct urtwn_softc *);
    154      1.8    nonaka 	int				(*sc_dma_init)(struct urtwn_softc *);
    155      1.1    nonaka 
    156      1.1    nonaka 	uint8_t				board_type;
    157      1.1    nonaka 	uint8_t				regulatory;
    158      1.1    nonaka 	uint8_t				pa_setting;
    159      1.1    nonaka 	int				avg_pwdb;
    160      1.1    nonaka 	int				thcal_state;
    161      1.1    nonaka 	int				thcal_lctemp;
    162      1.5  christos 	size_t				ntxchains;
    163      1.5  christos 	size_t				nrxchains;
    164      1.1    nonaka 	int				ledlink;
    165      1.1    nonaka 	bool				iqk_inited;
    166      1.1    nonaka 
    167      1.1    nonaka 	int				tx_timer;
    168      1.1    nonaka 
    169      1.1    nonaka 	struct urtwn_host_cmd_ring	cmdq;
    170      1.1    nonaka 	int				fwcur;
    171  1.8.4.4     skrll 	struct urtwn_rx_data		rx_data[R92C_MAX_EPIN][URTWN_RX_LIST_COUNT];
    172  1.8.4.2     skrll 	struct urtwn_tx_data		tx_data[R92C_MAX_EPOUT][URTWN_TX_LIST_COUNT];
    173  1.8.4.2     skrll 	TAILQ_HEAD(, urtwn_tx_data)	tx_free_list[R92C_MAX_EPOUT];
    174  1.8.4.4     skrll 	TAILQ_HEAD(, urtwn_rx_data)	rx_free_list[R92C_MAX_EPIN];
    175      1.1    nonaka 
    176      1.1    nonaka 	struct r92c_rom			rom;
    177  1.8.4.4     skrll 	uint8_t				r88e_rom[4096];
    178      1.8    nonaka 	uint8_t				cck_tx_pwr[6];
    179      1.8    nonaka 	uint8_t				ht40_tx_pwr[5];
    180      1.8    nonaka 	int8_t				bw20_tx_pwr_diff;
    181      1.8    nonaka 	int8_t				ofdm_tx_pwr_diff;
    182      1.1    nonaka 
    183      1.1    nonaka 	uint32_t			rf_chnlbw[R92C_MAX_CHAINS];
    184      1.1    nonaka 
    185      1.1    nonaka 	struct bpf_if *			sc_drvbpf;
    186      1.1    nonaka 	union {
    187      1.1    nonaka 		struct urtwn_rx_radiotap_header th;
    188      1.1    nonaka 		uint8_t	pad[64];
    189      1.1    nonaka 	}				sc_rxtapu;
    190      1.1    nonaka #define sc_rxtap	sc_rxtapu.th
    191      1.1    nonaka 	int				sc_rxtap_len;
    192      1.1    nonaka 	union {
    193      1.1    nonaka 		struct urtwn_tx_radiotap_header th;
    194      1.1    nonaka 		uint8_t	pad[64];
    195      1.1    nonaka 	}				sc_txtapu;
    196      1.1    nonaka #define sc_txtap	sc_txtapu.th
    197      1.1    nonaka 	int				sc_txtap_len;
    198  1.8.4.4     skrll 	bool				sc_running;
    199      1.1    nonaka };
    200      1.4  christos 
    201      1.4  christos #endif /* _IF_URTWNVAR_H_ */
    202