eabe30fc9c
that includes significant features and SMP safety. This commit includes a more or less complete rewrite of the *BSD USB stack, including Host Controller and Device Controller drivers and updating all existing USB drivers to use the new USB API: 1) A brief feature list: - A new and mutex enabled USB API. - Many USB drivers are now running Giant free. - Linux USB kernel compatibility layer. - New UGEN backend and libusb library, finally solves the "driver unloading" problem. The new BSD licensed libusb20 library is fully compatible with libusb-0.1.12 from sourceforge. - New "usbconfig" utility, for easy configuration of USB. - Full support for Split transactions, which means you can use your full speed USB audio device on a high speed USB HUB. - Full support for HS ISOC transactions, which makes writing drivers for various HS webcams possible, for example. - Full support for USB on embedded platforms, mostly cache flushing and buffer invalidating stuff. - Safer parsing of USB descriptors. - Autodetect of annoying USB install disks. - Support for USB device side mode, also called USB gadget mode, using the same API like the USB host side. In other words the new USB stack is symmetric with regard to host and device side. - Support for USB transfers like I/O vectors, means more throughput and less interrupts. - ... see the FreeBSD quarterly status reports under "USB project" 2) To enable the driver in the default kernel build: 2.a) Remove all existing USB device options from your kernel config file. 2.b) Add the following USB device options to your kernel configuration file: # USB core support device usb2_core # USB controller support device usb2_controller device usb2_controller_ehci device usb2_controller_ohci device usb2_controller_uhci # USB mass storage support device usb2_storage device usb2_storage_mass # USB ethernet support, requires miibus device usb2_ethernet device usb2_ethernet_aue device usb2_ethernet_axe device usb2_ethernet_cdce device usb2_ethernet_cue device usb2_ethernet_kue device usb2_ethernet_rue device usb2_ethernet_dav # USB wireless LAN support device usb2_wlan device usb2_wlan_rum device usb2_wlan_ral device usb2_wlan_zyd # USB serial device support device usb2_serial device usb2_serial_ark device usb2_serial_bsa device usb2_serial_bser device usb2_serial_chcom device usb2_serial_cycom device usb2_serial_foma device usb2_serial_ftdi device usb2_serial_gensa device usb2_serial_ipaq device usb2_serial_lpt device usb2_serial_mct device usb2_serial_modem device usb2_serial_moscom device usb2_serial_plcom device usb2_serial_visor device usb2_serial_vscom # USB bluetooth support device usb2_bluetooth device usb2_bluetooth_ng # USB input device support device usb2_input device usb2_input_hid device usb2_input_kbd device usb2_input_ms # USB sound and MIDI device support device usb2_sound 2) To enable the driver at runtime: 2.a) Unload all existing USB modules. If USB is compiled into the kernel then you might have to build a new kernel. 2.b) Load the "usb2_xxx.ko" modules under /boot/kernel having the same base name like the kernel device option. Submitted by: Hans Petter Selasky hselasky at c2i dot net Reviewed by: imp, alfred
236 lines
6.7 KiB
C
236 lines
6.7 KiB
C
/* $FreeBSD$ */
|
|
|
|
/*-
|
|
* Copyright (c) 2005, 2006 Damien Bergamini <damien.bergamini@free.fr>
|
|
* Copyright (c) 2006 Niall O'Higgins <niallo@openbsd.org>
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#define RT2573_NOISE_FLOOR -95
|
|
|
|
#define RT2573_TX_DESC_SIZE (sizeof (struct rum_tx_desc))
|
|
#define RT2573_RX_DESC_SIZE (sizeof (struct rum_rx_desc))
|
|
|
|
#define RT2573_CONFIG_NO 1
|
|
#define RT2573_IFACE_INDEX 0
|
|
|
|
#define RT2573_MCU_CNTL 0x01
|
|
#define RT2573_WRITE_MAC 0x02
|
|
#define RT2573_READ_MAC 0x03
|
|
#define RT2573_WRITE_MULTI_MAC 0x06
|
|
#define RT2573_READ_MULTI_MAC 0x07
|
|
#define RT2573_READ_EEPROM 0x09
|
|
#define RT2573_WRITE_LED 0x0a
|
|
|
|
/*
|
|
* Control and status registers.
|
|
*/
|
|
#define RT2573_AIFSN_CSR 0x0400
|
|
#define RT2573_CWMIN_CSR 0x0404
|
|
#define RT2573_CWMAX_CSR 0x0408
|
|
#define RT2573_MCU_CODE_BASE 0x0800
|
|
#define RT2573_HW_BEACON_BASE0 0x2400
|
|
#define RT2573_MAC_CSR0 0x3000
|
|
#define RT2573_MAC_CSR1 0x3004
|
|
#define RT2573_MAC_CSR2 0x3008
|
|
#define RT2573_MAC_CSR3 0x300c
|
|
#define RT2573_MAC_CSR4 0x3010
|
|
#define RT2573_MAC_CSR5 0x3014
|
|
#define RT2573_MAC_CSR6 0x3018
|
|
#define RT2573_MAC_CSR7 0x301c
|
|
#define RT2573_MAC_CSR8 0x3020
|
|
#define RT2573_MAC_CSR9 0x3024
|
|
#define RT2573_MAC_CSR10 0x3028
|
|
#define RT2573_MAC_CSR11 0x302c
|
|
#define RT2573_MAC_CSR12 0x3030
|
|
#define RT2573_MAC_CSR13 0x3034
|
|
#define RT2573_MAC_CSR14 0x3038
|
|
#define RT2573_MAC_CSR15 0x303c
|
|
#define RT2573_TXRX_CSR0 0x3040
|
|
#define RT2573_TXRX_CSR1 0x3044
|
|
#define RT2573_TXRX_CSR2 0x3048
|
|
#define RT2573_TXRX_CSR3 0x304c
|
|
#define RT2573_TXRX_CSR4 0x3050
|
|
#define RT2573_TXRX_CSR5 0x3054
|
|
#define RT2573_TXRX_CSR6 0x3058
|
|
#define RT2573_TXRX_CSR7 0x305c
|
|
#define RT2573_TXRX_CSR8 0x3060
|
|
#define RT2573_TXRX_CSR9 0x3064
|
|
#define RT2573_TXRX_CSR10 0x3068
|
|
#define RT2573_TXRX_CSR11 0x306c
|
|
#define RT2573_TXRX_CSR12 0x3070
|
|
#define RT2573_TXRX_CSR13 0x3074
|
|
#define RT2573_TXRX_CSR14 0x3078
|
|
#define RT2573_TXRX_CSR15 0x307c
|
|
#define RT2573_PHY_CSR0 0x3080
|
|
#define RT2573_PHY_CSR1 0x3084
|
|
#define RT2573_PHY_CSR2 0x3088
|
|
#define RT2573_PHY_CSR3 0x308c
|
|
#define RT2573_PHY_CSR4 0x3090
|
|
#define RT2573_PHY_CSR5 0x3094
|
|
#define RT2573_PHY_CSR6 0x3098
|
|
#define RT2573_PHY_CSR7 0x309c
|
|
#define RT2573_SEC_CSR0 0x30a0
|
|
#define RT2573_SEC_CSR1 0x30a4
|
|
#define RT2573_SEC_CSR2 0x30a8
|
|
#define RT2573_SEC_CSR3 0x30ac
|
|
#define RT2573_SEC_CSR4 0x30b0
|
|
#define RT2573_SEC_CSR5 0x30b4
|
|
#define RT2573_STA_CSR0 0x30c0
|
|
#define RT2573_STA_CSR1 0x30c4
|
|
#define RT2573_STA_CSR2 0x30c8
|
|
#define RT2573_STA_CSR3 0x30cc
|
|
#define RT2573_STA_CSR4 0x30d0
|
|
#define RT2573_STA_CSR5 0x30d4
|
|
|
|
|
|
/* possible flags for register RT2573_MAC_CSR1 */
|
|
#define RT2573_RESET_ASIC (1 << 0)
|
|
#define RT2573_RESET_BBP (1 << 1)
|
|
#define RT2573_HOST_READY (1 << 2)
|
|
|
|
/* possible flags for register MAC_CSR5 */
|
|
#define RT2573_ONE_BSSID 3
|
|
|
|
/* possible flags for register TXRX_CSR0 */
|
|
/* Tx filter flags are in the low 16 bits */
|
|
#define RT2573_AUTO_TX_SEQ (1 << 15)
|
|
/* Rx filter flags are in the high 16 bits */
|
|
#define RT2573_DISABLE_RX (1 << 16)
|
|
#define RT2573_DROP_CRC_ERROR (1 << 17)
|
|
#define RT2573_DROP_PHY_ERROR (1 << 18)
|
|
#define RT2573_DROP_CTL (1 << 19)
|
|
#define RT2573_DROP_NOT_TO_ME (1 << 20)
|
|
#define RT2573_DROP_TODS (1 << 21)
|
|
#define RT2573_DROP_VER_ERROR (1 << 22)
|
|
#define RT2573_DROP_MULTICAST (1 << 23)
|
|
#define RT2573_DROP_BROADCAST (1 << 24)
|
|
#define RT2573_DROP_ACKCTS (1 << 25)
|
|
|
|
/* possible flags for register TXRX_CSR4 */
|
|
#define RT2573_SHORT_PREAMBLE (1 << 18)
|
|
#define RT2573_MRR_ENABLED (1 << 19)
|
|
#define RT2573_MRR_CCK_FALLBACK (1 << 22)
|
|
|
|
/* possible flags for register TXRX_CSR9 */
|
|
#define RT2573_TSF_TICKING (1 << 16)
|
|
#define RT2573_TSF_MODE(x) (((x) & 0x3) << 17)
|
|
/* TBTT stands for Target Beacon Transmission Time */
|
|
#define RT2573_ENABLE_TBTT (1 << 19)
|
|
#define RT2573_GENERATE_BEACON (1 << 20)
|
|
|
|
/* possible flags for register PHY_CSR0 */
|
|
#define RT2573_PA_PE_2GHZ (1 << 16)
|
|
#define RT2573_PA_PE_5GHZ (1 << 17)
|
|
|
|
/* possible flags for register PHY_CSR3 */
|
|
#define RT2573_BBP_READ (1 << 15)
|
|
#define RT2573_BBP_BUSY (1 << 16)
|
|
/* possible flags for register PHY_CSR4 */
|
|
#define RT2573_RF_20BIT (20 << 24)
|
|
#define RT2573_RF_BUSY (1 << 31)
|
|
|
|
/* LED values */
|
|
#define RT2573_LED_RADIO (1 << 8)
|
|
#define RT2573_LED_G (1 << 9)
|
|
#define RT2573_LED_A (1 << 10)
|
|
#define RT2573_LED_ON 0x1e1e
|
|
#define RT2573_LED_OFF 0x0
|
|
|
|
#define RT2573_MCU_RUN (1 << 3)
|
|
|
|
#define RT2573_SMART_MODE (1 << 0)
|
|
|
|
#define RT2573_BBPR94_DEFAULT 6
|
|
|
|
#define RT2573_BBP_WRITE (1 << 15)
|
|
|
|
/* dual-band RF */
|
|
#define RT2573_RF_5226 1
|
|
#define RT2573_RF_5225 3
|
|
/* single-band RF */
|
|
#define RT2573_RF_2528 2
|
|
#define RT2573_RF_2527 4
|
|
|
|
#define RT2573_BBP_VERSION 0
|
|
|
|
struct rum_tx_desc {
|
|
uint32_t flags;
|
|
#define RT2573_TX_BURST (1 << 0)
|
|
#define RT2573_TX_VALID (1 << 1)
|
|
#define RT2573_TX_MORE_FRAG (1 << 2)
|
|
#define RT2573_TX_NEED_ACK (1 << 3)
|
|
#define RT2573_TX_TIMESTAMP (1 << 4)
|
|
#define RT2573_TX_OFDM (1 << 5)
|
|
#define RT2573_TX_IFS_SIFS (1 << 6)
|
|
#define RT2573_TX_LONG_RETRY (1 << 7)
|
|
uint16_t wme;
|
|
#define RT2573_QID(v) (v)
|
|
#define RT2573_AIFSN(v) ((v) << 4)
|
|
#define RT2573_LOGCWMIN(v) ((v) << 8)
|
|
#define RT2573_LOGCWMAX(v) ((v) << 12)
|
|
|
|
uint16_t xflags;
|
|
#define RT2573_TX_HWSEQ (1 << 12)
|
|
#define RT2573_TX_BEACON (1 << 15) /* Internal flag only! */
|
|
|
|
uint8_t plcp_signal;
|
|
uint8_t plcp_service;
|
|
#define RT2573_PLCP_LENGEXT 0x80
|
|
|
|
uint8_t plcp_length_lo;
|
|
uint8_t plcp_length_hi;
|
|
|
|
uint32_t iv;
|
|
uint32_t eiv;
|
|
|
|
uint8_t offset;
|
|
uint8_t qid;
|
|
uint8_t txpower;
|
|
#define RT2573_DEFAULT_TXPOWER 0
|
|
|
|
uint8_t reserved;
|
|
} __packed;
|
|
|
|
struct rum_rx_desc {
|
|
uint32_t flags;
|
|
#define RT2573_RX_BUSY (1 << 0)
|
|
#define RT2573_RX_DROP (1 << 1)
|
|
#define RT2573_RX_CRC_ERROR (1 << 6)
|
|
#define RT2573_RX_OFDM (1 << 7)
|
|
|
|
uint8_t rate;
|
|
uint8_t rssi;
|
|
uint8_t reserved1;
|
|
uint8_t offset;
|
|
uint32_t iv;
|
|
uint32_t eiv;
|
|
uint32_t reserved2[2];
|
|
} __packed;
|
|
|
|
#define RT2573_RF1 0
|
|
#define RT2573_RF2 2
|
|
#define RT2573_RF3 1
|
|
#define RT2573_RF4 3
|
|
|
|
#define RT2573_EEPROM_MACBBP 0x0000
|
|
#define RT2573_EEPROM_ADDRESS 0x0004
|
|
#define RT2573_EEPROM_ANTENNA 0x0020
|
|
#define RT2573_EEPROM_CONFIG2 0x0022
|
|
#define RT2573_EEPROM_BBP_BASE 0x0026
|
|
#define RT2573_EEPROM_TXPOWER 0x0046
|
|
#define RT2573_EEPROM_FREQ_OFFSET 0x005e
|
|
#define RT2573_EEPROM_RSSI_2GHZ_OFFSET 0x009a
|
|
#define RT2573_EEPROM_RSSI_5GHZ_OFFSET 0x009c
|