diff options
author | Damien Bergamini <damien@cvs.openbsd.org> | 2006-01-09 20:03:44 +0000 |
---|---|---|
committer | Damien Bergamini <damien@cvs.openbsd.org> | 2006-01-09 20:03:44 +0000 |
commit | fd1c57dff66bd1a5c15150eb5982eb43d7363489 (patch) | |
tree | cb23372a53dee810b81e0d9fc409926f5c368175 /sys/dev/ic/rt2560var.h | |
parent | 1e61e4aa57c4a95a949051b5a4b82b10de73d92c (diff) |
- add preliminary support for Ralink Technology RT2561, RT2561S and RT2661
chipsets in ral(4).
- restructure the code a bit; split ic/ral.c into ic/rt2560.c and ic/rt2661.c
- import the 8051 microcode files required by these chipsets.
- more to come; there is currently no automatic rate control and some
features are untested (hostap and ibss modes for instance). most of
the pre-802.11n capabilities of the RT2661 chipset are not supported
(like frame aggregation, piggy-back). MIMO should work though the
performance/range gain has not been measured.
Diffstat (limited to 'sys/dev/ic/rt2560var.h')
-rw-r--r-- | sys/dev/ic/rt2560var.h | 163 |
1 files changed, 163 insertions, 0 deletions
diff --git a/sys/dev/ic/rt2560var.h b/sys/dev/ic/rt2560var.h new file mode 100644 index 00000000000..0f117f608bd --- /dev/null +++ b/sys/dev/ic/rt2560var.h @@ -0,0 +1,163 @@ +/* $OpenBSD: rt2560var.h,v 1.1 2006/01/09 20:03:34 damien Exp $ */ + +/*- + * Copyright (c) 2005, 2006 + * Damien Bergamini <damien.bergamini@free.fr> + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +struct rt2560_rx_radiotap_header { + struct ieee80211_radiotap_header wr_ihdr; + uint64_t wr_tsf; + uint8_t wr_flags; + uint16_t wr_chan_freq; + uint16_t wr_chan_flags; + uint8_t wr_antenna; + uint8_t wr_antsignal; +} __packed; + +#define RT2560_RX_RADIOTAP_PRESENT \ + ((1 << IEEE80211_RADIOTAP_TSFT) | \ + (1 << IEEE80211_RADIOTAP_FLAGS) | \ + (1 << IEEE80211_RADIOTAP_CHANNEL) | \ + (1 << IEEE80211_RADIOTAP_ANTENNA) | \ + (1 << IEEE80211_RADIOTAP_DB_ANTSIGNAL)) + +struct rt2560_tx_radiotap_header { + struct ieee80211_radiotap_header wt_ihdr; + uint8_t wt_flags; + uint8_t wt_rate; + uint16_t wt_chan_freq; + uint16_t wt_chan_flags; + uint8_t wt_antenna; +} __packed; + +#define RT2560_TX_RADIOTAP_PRESENT \ + ((1 << IEEE80211_RADIOTAP_FLAGS) | \ + (1 << IEEE80211_RADIOTAP_RATE) | \ + (1 << IEEE80211_RADIOTAP_CHANNEL) | \ + (1 << IEEE80211_RADIOTAP_ANTENNA)) + +struct rt2560_tx_data { + bus_dmamap_t map; + struct mbuf *m; + struct ieee80211_node *ni; + struct ieee80211_rssdesc id; +}; + +struct rt2560_tx_ring { + bus_dmamap_t map; + bus_dma_segment_t seg; + bus_addr_t physaddr; + struct rt2560_tx_desc *desc; + struct rt2560_tx_data *data; + int count; + int queued; + int cur; + int next; + int cur_encrypt; + int next_encrypt; +}; + +struct rt2560_rx_data { + bus_dmamap_t map; + struct mbuf *m; + int drop; +}; + +struct rt2560_rx_ring { + bus_dmamap_t map; + bus_dma_segment_t seg; + bus_addr_t physaddr; + struct rt2560_rx_desc *desc; + struct rt2560_rx_data *data; + int count; + int cur; + int next; + int cur_decrypt; +}; + +struct rt2560_node { + struct ieee80211_node ni; + struct ieee80211_rssadapt rssadapt; +}; + +struct rt2560_softc { + struct device sc_dev; + + struct ieee80211com sc_ic; + int (*sc_newstate)(struct ieee80211com *, + enum ieee80211_state, int); + + int (*sc_enable)(struct rt2560_softc *); + void (*sc_disable)(struct rt2560_softc *); + void (*sc_power)(struct rt2560_softc *, int); + + bus_dma_tag_t sc_dmat; + bus_space_tag_t sc_st; + bus_space_handle_t sc_sh; + + struct timeout scan_ch; + struct timeout rssadapt_ch; + + int sc_flags; +#define RT2560_ENABLED (1 << 0) + + int sc_tx_timer; + + uint32_t asic_rev; + uint8_t rf_rev; + + struct rt2560_tx_ring txq; + struct rt2560_tx_ring prioq; + struct rt2560_tx_ring atimq; + struct rt2560_tx_ring bcnq; + struct rt2560_rx_ring rxq; + + uint32_t rf_regs[4]; + uint8_t txpow[14]; + + struct { + uint8_t reg; + uint8_t val; + } bbp_prom[16]; + + int led_mode; + int hw_radio; + int rx_ant; + int tx_ant; + int nb_ant; + +#if NBPFILTER > 0 + caddr_t sc_drvbpf; + + union { + struct rt2560_rx_radiotap_header th; + uint8_t pad[64]; + } sc_rxtapu; +#define sc_rxtap sc_rxtapu.th + int sc_rxtap_len; + + union { + struct rt2560_tx_radiotap_header th; + uint8_t pad[64]; + } sc_txtapu; +#define sc_txtap sc_txtapu.th + int sc_txtap_len; +#endif +}; + +int rt2560_attach(void *, int); +int rt2560_detach(void *); +int rt2560_intr(void *); |