wl12xx is a driver for TI wl1251 802.11 chipset designed for embedded devices, supporting both SDIO and SPI busses. Currently the driver supports only SPI. Adding support 1253 (the 5 GHz version) should be relatively easy. More information here: http://focus.ti.com/general/docs/wtbu/wtbuproductcontent.tsp?contentId=4711&navigationId=12494&templateId=6123 (Collapsed original sequence of pre-merge patches into single commit for initial merge. -- JWL) Signed-off-by: Kalle Valo <kalle.valo@nokia.com> Signed-off-by: Bob Copeland <me@bobcopeland.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
		
			
				
	
	
		
			746 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			746 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * This file is part of wl12xx
 | |
|  *
 | |
|  * Copyright (c) 1998-2007 Texas Instruments Incorporated
 | |
|  * Copyright (C) 2008 Nokia Corporation
 | |
|  *
 | |
|  * Contact: Kalle Valo <kalle.valo@nokia.com>
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU General Public License
 | |
|  * version 2 as published by the Free Software Foundation.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful, but
 | |
|  * WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 | |
|  * 02110-1301 USA
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #ifndef __REG_H__
 | |
| #define __REG_H__
 | |
| 
 | |
| #include <linux/bitops.h>
 | |
| #include "wl12xx.h"
 | |
| 
 | |
| #define REGISTERS_BASE 0x00300000
 | |
| #define DRPW_BASE      0x00310000
 | |
| 
 | |
| #define REGISTERS_DOWN_SIZE 0x00008800
 | |
| #define REGISTERS_WORK_SIZE 0x0000b000
 | |
| 
 | |
| #define HW_ACCESS_ELP_CTRL_REG_ADDR         0x1FFFC
 | |
| 
 | |
| /* ELP register commands */
 | |
| #define ELPCTRL_WAKE_UP             0x1
 | |
| #define ELPCTRL_WAKE_UP_WLAN_READY  0x5
 | |
| #define ELPCTRL_SLEEP               0x0
 | |
| /* ELP WLAN_READY bit */
 | |
| #define ELPCTRL_WLAN_READY          0x2
 | |
| 
 | |
| /*
 | |
|  * Interrupt registers.
 | |
|  * 64 bit interrupt sources registers ws ced.
 | |
|  * sme interupts were removed and new ones were added.
 | |
|  * Order was changed.
 | |
|  */
 | |
| #define FIQ_MASK                       (REGISTERS_BASE + 0x0400)
 | |
| #define FIQ_MASK_L                     (REGISTERS_BASE + 0x0400)
 | |
| #define FIQ_MASK_H                     (REGISTERS_BASE + 0x0404)
 | |
| #define FIQ_MASK_SET                   (REGISTERS_BASE + 0x0408)
 | |
| #define FIQ_MASK_SET_L                 (REGISTERS_BASE + 0x0408)
 | |
| #define FIQ_MASK_SET_H                 (REGISTERS_BASE + 0x040C)
 | |
| #define FIQ_MASK_CLR                   (REGISTERS_BASE + 0x0410)
 | |
| #define FIQ_MASK_CLR_L                 (REGISTERS_BASE + 0x0410)
 | |
| #define FIQ_MASK_CLR_H                 (REGISTERS_BASE + 0x0414)
 | |
| #define IRQ_MASK                       (REGISTERS_BASE + 0x0418)
 | |
| #define IRQ_MASK_L                     (REGISTERS_BASE + 0x0418)
 | |
| #define IRQ_MASK_H                     (REGISTERS_BASE + 0x041C)
 | |
| #define IRQ_MASK_SET                   (REGISTERS_BASE + 0x0420)
 | |
| #define IRQ_MASK_SET_L                 (REGISTERS_BASE + 0x0420)
 | |
| #define IRQ_MASK_SET_H                 (REGISTERS_BASE + 0x0424)
 | |
| #define IRQ_MASK_CLR                   (REGISTERS_BASE + 0x0428)
 | |
| #define IRQ_MASK_CLR_L                 (REGISTERS_BASE + 0x0428)
 | |
| #define IRQ_MASK_CLR_H                 (REGISTERS_BASE + 0x042C)
 | |
| #define ECPU_MASK                      (REGISTERS_BASE + 0x0448)
 | |
| #define FIQ_STS_L                      (REGISTERS_BASE + 0x044C)
 | |
| #define FIQ_STS_H                      (REGISTERS_BASE + 0x0450)
 | |
| #define IRQ_STS_L                      (REGISTERS_BASE + 0x0454)
 | |
| #define IRQ_STS_H                      (REGISTERS_BASE + 0x0458)
 | |
| #define INT_STS_ND                     (REGISTERS_BASE + 0x0464)
 | |
| #define INT_STS_RAW_L                  (REGISTERS_BASE + 0x0464)
 | |
| #define INT_STS_RAW_H                  (REGISTERS_BASE + 0x0468)
 | |
| #define INT_STS_CLR                    (REGISTERS_BASE + 0x04B4)
 | |
| #define INT_STS_CLR_L                  (REGISTERS_BASE + 0x04B4)
 | |
| #define INT_STS_CLR_H                  (REGISTERS_BASE + 0x04B8)
 | |
| #define INT_ACK                        (REGISTERS_BASE + 0x046C)
 | |
| #define INT_ACK_L                      (REGISTERS_BASE + 0x046C)
 | |
| #define INT_ACK_H                      (REGISTERS_BASE + 0x0470)
 | |
| #define INT_TRIG                       (REGISTERS_BASE + 0x0474)
 | |
| #define INT_TRIG_L                     (REGISTERS_BASE + 0x0474)
 | |
| #define INT_TRIG_H                     (REGISTERS_BASE + 0x0478)
 | |
| #define HOST_STS_L                     (REGISTERS_BASE + 0x045C)
 | |
| #define HOST_STS_H                     (REGISTERS_BASE + 0x0460)
 | |
| #define HOST_MASK                      (REGISTERS_BASE + 0x0430)
 | |
| #define HOST_MASK_L                    (REGISTERS_BASE + 0x0430)
 | |
| #define HOST_MASK_H                    (REGISTERS_BASE + 0x0434)
 | |
| #define HOST_MASK_SET                  (REGISTERS_BASE + 0x0438)
 | |
| #define HOST_MASK_SET_L                (REGISTERS_BASE + 0x0438)
 | |
| #define HOST_MASK_SET_H                (REGISTERS_BASE + 0x043C)
 | |
| #define HOST_MASK_CLR                  (REGISTERS_BASE + 0x0440)
 | |
| #define HOST_MASK_CLR_L                (REGISTERS_BASE + 0x0440)
 | |
| #define HOST_MASK_CLR_H                (REGISTERS_BASE + 0x0444)
 | |
| 
 | |
| /* Host Interrupts*/
 | |
| #define HINT_MASK                      (REGISTERS_BASE + 0x0494)
 | |
| #define HINT_MASK_SET                  (REGISTERS_BASE + 0x0498)
 | |
| #define HINT_MASK_CLR                  (REGISTERS_BASE + 0x049C)
 | |
| #define HINT_STS_ND_MASKED             (REGISTERS_BASE + 0x04A0)
 | |
| /*1150 spec calls this HINT_STS_RAW*/
 | |
| #define HINT_STS_ND		       (REGISTERS_BASE + 0x04B0)
 | |
| #define HINT_STS_CLR                   (REGISTERS_BASE + 0x04A4)
 | |
| #define HINT_ACK                       (REGISTERS_BASE + 0x04A8)
 | |
| #define HINT_TRIG                      (REGISTERS_BASE + 0x04AC)
 | |
| 
 | |
| /* Device Configuration registers*/
 | |
| #define SOR_CFG                        (REGISTERS_BASE + 0x0800)
 | |
| #define ECPU_CTRL                      (REGISTERS_BASE + 0x0804)
 | |
| #define HI_CFG                         (REGISTERS_BASE + 0x0808)
 | |
| #define EE_START                       (REGISTERS_BASE + 0x080C)
 | |
| 
 | |
| #define CHIP_ID_B                      (REGISTERS_BASE + 0x5674)
 | |
| 
 | |
| #define CHIP_ID_1251_PG10	           (0x7010101)
 | |
| #define CHIP_ID_1251_PG11	           (0x7020101)
 | |
| #define CHIP_ID_1251_PG12	           (0x7030101)
 | |
| 
 | |
| #define ENABLE                         (REGISTERS_BASE + 0x5450)
 | |
| 
 | |
| /* Power Management registers */
 | |
| #define ELP_CFG_MODE                   (REGISTERS_BASE + 0x5804)
 | |
| #define ELP_CMD                        (REGISTERS_BASE + 0x5808)
 | |
| #define PLL_CAL_TIME                   (REGISTERS_BASE + 0x5810)
 | |
| #define CLK_REQ_TIME                   (REGISTERS_BASE + 0x5814)
 | |
| #define CLK_BUF_TIME                   (REGISTERS_BASE + 0x5818)
 | |
| 
 | |
| #define CFG_PLL_SYNC_CNT               (REGISTERS_BASE + 0x5820)
 | |
| 
 | |
| /* Scratch Pad registers*/
 | |
| #define SCR_PAD0                       (REGISTERS_BASE + 0x5608)
 | |
| #define SCR_PAD1                       (REGISTERS_BASE + 0x560C)
 | |
| #define SCR_PAD2                       (REGISTERS_BASE + 0x5610)
 | |
| #define SCR_PAD3                       (REGISTERS_BASE + 0x5614)
 | |
| #define SCR_PAD4                       (REGISTERS_BASE + 0x5618)
 | |
| #define SCR_PAD4_SET                   (REGISTERS_BASE + 0x561C)
 | |
| #define SCR_PAD4_CLR                   (REGISTERS_BASE + 0x5620)
 | |
| #define SCR_PAD5                       (REGISTERS_BASE + 0x5624)
 | |
| #define SCR_PAD5_SET                   (REGISTERS_BASE + 0x5628)
 | |
| #define SCR_PAD5_CLR                   (REGISTERS_BASE + 0x562C)
 | |
| #define SCR_PAD6                       (REGISTERS_BASE + 0x5630)
 | |
| #define SCR_PAD7                       (REGISTERS_BASE + 0x5634)
 | |
| #define SCR_PAD8                       (REGISTERS_BASE + 0x5638)
 | |
| #define SCR_PAD9                       (REGISTERS_BASE + 0x563C)
 | |
| 
 | |
| /* Spare registers*/
 | |
| #define SPARE_A1                       (REGISTERS_BASE + 0x0994)
 | |
| #define SPARE_A2                       (REGISTERS_BASE + 0x0998)
 | |
| #define SPARE_A3                       (REGISTERS_BASE + 0x099C)
 | |
| #define SPARE_A4                       (REGISTERS_BASE + 0x09A0)
 | |
| #define SPARE_A5                       (REGISTERS_BASE + 0x09A4)
 | |
| #define SPARE_A6                       (REGISTERS_BASE + 0x09A8)
 | |
| #define SPARE_A7                       (REGISTERS_BASE + 0x09AC)
 | |
| #define SPARE_A8                       (REGISTERS_BASE + 0x09B0)
 | |
| #define SPARE_B1                       (REGISTERS_BASE + 0x5420)
 | |
| #define SPARE_B2                       (REGISTERS_BASE + 0x5424)
 | |
| #define SPARE_B3                       (REGISTERS_BASE + 0x5428)
 | |
| #define SPARE_B4                       (REGISTERS_BASE + 0x542C)
 | |
| #define SPARE_B5                       (REGISTERS_BASE + 0x5430)
 | |
| #define SPARE_B6                       (REGISTERS_BASE + 0x5434)
 | |
| #define SPARE_B7                       (REGISTERS_BASE + 0x5438)
 | |
| #define SPARE_B8                       (REGISTERS_BASE + 0x543C)
 | |
| 
 | |
| enum wl12xx_acx_int_reg {
 | |
| 	ACX_REG_INTERRUPT_TRIG,
 | |
| 	ACX_REG_INTERRUPT_TRIG_H,
 | |
| 
 | |
| /*=============================================
 | |
|   Host Interrupt Mask Register - 32bit (RW)
 | |
|   ------------------------------------------
 | |
|   Setting a bit in this register masks the
 | |
|   corresponding interrupt to the host.
 | |
|   0 - RX0		- Rx first dubble buffer Data Interrupt
 | |
|   1 - TXD		- Tx Data Interrupt
 | |
|   2 - TXXFR		- Tx Transfer Interrupt
 | |
|   3 - RX1		- Rx second dubble buffer Data Interrupt
 | |
|   4 - RXXFR		- Rx Transfer Interrupt
 | |
|   5 - EVENT_A	- Event Mailbox interrupt
 | |
|   6 - EVENT_B	- Event Mailbox interrupt
 | |
|   7 - WNONHST	- Wake On Host Interrupt
 | |
|   8 - TRACE_A	- Debug Trace interrupt
 | |
|   9 - TRACE_B	- Debug Trace interrupt
 | |
|  10 - CDCMP		- Command Complete Interrupt
 | |
|  11 -
 | |
|  12 -
 | |
|  13 -
 | |
|  14 - ICOMP		- Initialization Complete Interrupt
 | |
|  16 - SG SE		- Soft Gemini - Sense enable interrupt
 | |
|  17 - SG SD		- Soft Gemini - Sense disable interrupt
 | |
|  18 -			-
 | |
|  19 -			-
 | |
|  20 -			-
 | |
|  21-			-
 | |
|  Default: 0x0001
 | |
| *==============================================*/
 | |
| 	ACX_REG_INTERRUPT_MASK,
 | |
| 
 | |
| /*=============================================
 | |
|   Host Interrupt Mask Set 16bit, (Write only)
 | |
|   ------------------------------------------
 | |
|  Setting a bit in this register sets
 | |
|  the corresponding bin in ACX_HINT_MASK register
 | |
|  without effecting the mask
 | |
|  state of other bits (0 = no effect).
 | |
| ==============================================*/
 | |
| 	ACX_REG_HINT_MASK_SET,
 | |
| 
 | |
| /*=============================================
 | |
|   Host Interrupt Mask Clear 16bit,(Write only)
 | |
|   ------------------------------------------
 | |
|  Setting a bit in this register clears
 | |
|  the corresponding bin in ACX_HINT_MASK register
 | |
|  without effecting the mask
 | |
|  state of other bits (0 = no effect).
 | |
| =============================================*/
 | |
| 	ACX_REG_HINT_MASK_CLR,
 | |
| 
 | |
| /*=============================================
 | |
|   Host Interrupt Status Nondestructive Read
 | |
|   16bit,(Read only)
 | |
|   ------------------------------------------
 | |
|  The host can read this register to determine
 | |
|  which interrupts are active.
 | |
|  Reading this register doesn't
 | |
|  effect its content.
 | |
| =============================================*/
 | |
| 	ACX_REG_INTERRUPT_NO_CLEAR,
 | |
| 
 | |
| /*=============================================
 | |
|   Host Interrupt Status Clear on Read  Register
 | |
|   16bit,(Read only)
 | |
|   ------------------------------------------
 | |
|  The host can read this register to determine
 | |
|  which interrupts are active.
 | |
|  Reading this register clears it,
 | |
|  thus making all interrupts inactive.
 | |
| ==============================================*/
 | |
| 	ACX_REG_INTERRUPT_CLEAR,
 | |
| 
 | |
| /*=============================================
 | |
|   Host Interrupt Acknowledge Register
 | |
|   16bit,(Write only)
 | |
|   ------------------------------------------
 | |
|  The host can set individual bits in this
 | |
|  register to clear (acknowledge) the corresp.
 | |
|  interrupt status bits in the HINT_STS_CLR and
 | |
|  HINT_STS_ND registers, thus making the
 | |
|  assotiated interrupt inactive. (0-no effect)
 | |
| ==============================================*/
 | |
| 	ACX_REG_INTERRUPT_ACK,
 | |
| 
 | |
| /*===============================================
 | |
|    Host Software Reset - 32bit RW
 | |
|  ------------------------------------------
 | |
|     [31:1] Reserved
 | |
|     0  SOFT_RESET Soft Reset  - When this bit is set,
 | |
|     it holds the Wlan hardware in a soft reset state.
 | |
|     This reset disables all MAC and baseband processor
 | |
|     clocks except the CardBus/PCI interface clock.
 | |
|     It also initializes all MAC state machines except
 | |
|     the host interface. It does not reload the
 | |
|     contents of the EEPROM. When this bit is cleared
 | |
|     (not self-clearing), the Wlan hardware
 | |
|     exits the software reset state.
 | |
| ===============================================*/
 | |
| 	ACX_REG_SLV_SOFT_RESET,
 | |
| 
 | |
| /*===============================================
 | |
|  EEPROM Burst Read Start  - 32bit RW
 | |
|  ------------------------------------------
 | |
|  [31:1] Reserved
 | |
|  0  ACX_EE_START -  EEPROM Burst Read Start 0
 | |
|  Setting this bit starts a burst read from
 | |
|  the external EEPROM.
 | |
|  If this bit is set (after reset) before an EEPROM read/write,
 | |
|  the burst read starts at EEPROM address 0.
 | |
|  Otherwise, it starts at the address
 | |
|  following the address of the previous access.
 | |
|  TheWlan hardware hardware clears this bit automatically.
 | |
| 
 | |
|  Default: 0x00000000
 | |
| *================================================*/
 | |
| 	ACX_REG_EE_START,
 | |
| 
 | |
| /* Embedded ARM CPU Control */
 | |
| 
 | |
| /*===============================================
 | |
|  Halt eCPU   - 32bit RW
 | |
|  ------------------------------------------
 | |
|  0 HALT_ECPU Halt Embedded CPU - This bit is the
 | |
|  compliment of bit 1 (MDATA2) in the SOR_CFG register.
 | |
|  During a hardware reset, this bit holds
 | |
|  the inverse of MDATA2.
 | |
|  When downloading firmware from the host,
 | |
|  set this bit (pull down MDATA2).
 | |
|  The host clears this bit after downloading the firmware into
 | |
|  zero-wait-state SSRAM.
 | |
|  When loading firmware from Flash, clear this bit (pull up MDATA2)
 | |
|  so that the eCPU can run the bootloader code in Flash
 | |
|  HALT_ECPU eCPU State
 | |
|  --------------------
 | |
|  1 halt eCPU
 | |
|  0 enable eCPU
 | |
|  ===============================================*/
 | |
| 	ACX_REG_ECPU_CONTROL,
 | |
| 
 | |
| 	ACX_REG_TABLE_LEN
 | |
| };
 | |
| 
 | |
| #define ACX_SLV_SOFT_RESET_BIT   BIT(1)
 | |
| #define ACX_REG_EEPROM_START_BIT BIT(1)
 | |
| 
 | |
| /* Command/Information Mailbox Pointers */
 | |
| 
 | |
| /*===============================================
 | |
|   Command Mailbox Pointer - 32bit RW
 | |
|  ------------------------------------------
 | |
|  This register holds the start address of
 | |
|  the command mailbox located in the Wlan hardware memory.
 | |
|  The host must read this pointer after a reset to
 | |
|  find the location of the command mailbox.
 | |
|  The Wlan hardware initializes the command mailbox
 | |
|  pointer with the default address of the command mailbox.
 | |
|  The command mailbox pointer is not valid until after
 | |
|  the host receives the Init Complete interrupt from
 | |
|  the Wlan hardware.
 | |
|  ===============================================*/
 | |
| #define REG_COMMAND_MAILBOX_PTR				(SCR_PAD0)
 | |
| 
 | |
| /*===============================================
 | |
|   Information Mailbox Pointer - 32bit RW
 | |
|  ------------------------------------------
 | |
|  This register holds the start address of
 | |
|  the information mailbox located in the Wlan hardware memory.
 | |
|  The host must read this pointer after a reset to find
 | |
|  the location of the information mailbox.
 | |
|  The Wlan hardware initializes the information mailbox pointer
 | |
|  with the default address of the information mailbox.
 | |
|  The information mailbox pointer is not valid
 | |
|  until after the host receives the Init Complete interrupt from
 | |
|  the Wlan hardware.
 | |
|  ===============================================*/
 | |
| #define REG_EVENT_MAILBOX_PTR				(SCR_PAD1)
 | |
| 
 | |
| 
 | |
| /* Misc */
 | |
| 
 | |
| #define REG_ENABLE_TX_RX				(ENABLE)
 | |
| /*
 | |
|  * Rx configuration (filter) information element
 | |
|  * ---------------------------------------------
 | |
|  */
 | |
| #define REG_RX_CONFIG				(RX_CFG)
 | |
| #define REG_RX_FILTER				(RX_FILTER_CFG)
 | |
| 
 | |
| 
 | |
| #define RX_CFG_ENABLE_PHY_HEADER_PLCP	 0x0002
 | |
| 
 | |
| /* promiscuous - receives all valid frames */
 | |
| #define RX_CFG_PROMISCUOUS		 0x0008
 | |
| 
 | |
| /* receives frames from any BSSID */
 | |
| #define RX_CFG_BSSID			 0x0020
 | |
| 
 | |
| /* receives frames destined to any MAC address */
 | |
| #define RX_CFG_MAC			 0x0010
 | |
| 
 | |
| #define RX_CFG_ENABLE_ONLY_MY_DEST_MAC	 0x0010
 | |
| #define RX_CFG_ENABLE_ANY_DEST_MAC	 0x0000
 | |
| #define RX_CFG_ENABLE_ONLY_MY_BSSID	 0x0020
 | |
| #define RX_CFG_ENABLE_ANY_BSSID		 0x0000
 | |
| 
 | |
| /* discards all broadcast frames */
 | |
| #define RX_CFG_DISABLE_BCAST		 0x0200
 | |
| 
 | |
| #define RX_CFG_ENABLE_ONLY_MY_SSID	 0x0400
 | |
| #define RX_CFG_ENABLE_RX_CMPLT_FCS_ERROR 0x0800
 | |
| #define RX_CFG_COPY_RX_STATUS		 0x2000
 | |
| #define RX_CFG_TSF			 0x10000
 | |
| 
 | |
| #define RX_CONFIG_OPTION_ANY_DST_MY_BSS	 (RX_CFG_ENABLE_ANY_DEST_MAC | \
 | |
| 					  RX_CFG_ENABLE_ONLY_MY_BSSID)
 | |
| 
 | |
| #define RX_CONFIG_OPTION_MY_DST_ANY_BSS	 (RX_CFG_ENABLE_ONLY_MY_DEST_MAC\
 | |
| 					  | RX_CFG_ENABLE_ANY_BSSID)
 | |
| 
 | |
| #define RX_CONFIG_OPTION_ANY_DST_ANY_BSS (RX_CFG_ENABLE_ANY_DEST_MAC | \
 | |
| 					  RX_CFG_ENABLE_ANY_BSSID)
 | |
| 
 | |
| #define RX_CONFIG_OPTION_MY_DST_MY_BSS	 (RX_CFG_ENABLE_ONLY_MY_DEST_MAC\
 | |
| 					  | RX_CFG_ENABLE_ONLY_MY_BSSID)
 | |
| 
 | |
| #define RX_CONFIG_OPTION_FOR_SCAN  (RX_CFG_ENABLE_PHY_HEADER_PLCP \
 | |
| 				    | RX_CFG_ENABLE_RX_CMPLT_FCS_ERROR \
 | |
| 				    | RX_CFG_COPY_RX_STATUS | RX_CFG_TSF)
 | |
| 
 | |
| #define RX_CONFIG_OPTION_FOR_MEASUREMENT (RX_CFG_ENABLE_ANY_DEST_MAC)
 | |
| 
 | |
| #define RX_CONFIG_OPTION_FOR_JOIN	 (RX_CFG_ENABLE_ONLY_MY_BSSID | \
 | |
| 					  RX_CFG_ENABLE_ONLY_MY_DEST_MAC)
 | |
| 
 | |
| #define RX_CONFIG_OPTION_FOR_IBSS_JOIN   (RX_CFG_ENABLE_ONLY_MY_SSID | \
 | |
| 					  RX_CFG_ENABLE_ONLY_MY_DEST_MAC)
 | |
| 
 | |
| #define RX_FILTER_OPTION_DEF	      (CFG_RX_MGMT_EN | CFG_RX_DATA_EN\
 | |
| 				       | CFG_RX_CTL_EN | CFG_RX_BCN_EN\
 | |
| 				       | CFG_RX_AUTH_EN | CFG_RX_ASSOC_EN)
 | |
| 
 | |
| #define RX_FILTER_OPTION_FILTER_ALL	 0
 | |
| 
 | |
| #define RX_FILTER_OPTION_DEF_PRSP_BCN  (CFG_RX_PRSP_EN | CFG_RX_MGMT_EN\
 | |
| 					| CFG_RX_RCTS_ACK | CFG_RX_BCN_EN)
 | |
| 
 | |
| #define RX_FILTER_OPTION_JOIN	     (CFG_RX_MGMT_EN | CFG_RX_DATA_EN\
 | |
| 				      | CFG_RX_BCN_EN | CFG_RX_AUTH_EN\
 | |
| 				      | CFG_RX_ASSOC_EN | CFG_RX_RCTS_ACK\
 | |
| 				      | CFG_RX_PRSP_EN)
 | |
| 
 | |
| 
 | |
| /*===============================================
 | |
|   Phy regs
 | |
|  ===============================================*/
 | |
| #define ACX_PHY_ADDR_REG                SBB_ADDR
 | |
| #define ACX_PHY_DATA_REG                SBB_DATA
 | |
| #define ACX_PHY_CTRL_REG                SBB_CTL
 | |
| #define ACX_PHY_REG_WR_MASK             0x00000001ul
 | |
| #define ACX_PHY_REG_RD_MASK             0x00000002ul
 | |
| 
 | |
| 
 | |
| /*===============================================
 | |
|  EEPROM Read/Write Request 32bit RW
 | |
|  ------------------------------------------
 | |
|  1 EE_READ - EEPROM Read Request 1 - Setting this bit
 | |
|  loads a single byte of data into the EE_DATA
 | |
|  register from the EEPROM location specified in
 | |
|  the EE_ADDR register.
 | |
|  The Wlan hardware hardware clears this bit automatically.
 | |
|  EE_DATA is valid when this bit is cleared.
 | |
| 
 | |
|  0 EE_WRITE  - EEPROM Write Request  - Setting this bit
 | |
|  writes a single byte of data from the EE_DATA register into the
 | |
|  EEPROM location specified in the EE_ADDR register.
 | |
|  The Wlan hardware hardware clears this bit automatically.
 | |
| *===============================================*/
 | |
| #define ACX_EE_CTL_REG                      EE_CTL
 | |
| #define EE_WRITE                            0x00000001ul
 | |
| #define EE_READ                             0x00000002ul
 | |
| 
 | |
| /*===============================================
 | |
|   EEPROM Address  - 32bit RW
 | |
|   ------------------------------------------
 | |
|   This register specifies the address
 | |
|   within the EEPROM from/to which to read/write data.
 | |
|   ===============================================*/
 | |
| #define ACX_EE_ADDR_REG                     EE_ADDR
 | |
| 
 | |
| /*===============================================
 | |
|   EEPROM Data  - 32bit RW
 | |
|   ------------------------------------------
 | |
|   This register either holds the read 8 bits of
 | |
|   data from the EEPROM or the write data
 | |
|   to be written to the EEPROM.
 | |
|   ===============================================*/
 | |
| #define ACX_EE_DATA_REG                     EE_DATA
 | |
| 
 | |
| /*===============================================
 | |
|   EEPROM Base Address  - 32bit RW
 | |
|   ------------------------------------------
 | |
|   This register holds the upper nine bits
 | |
|   [23:15] of the 24-bit Wlan hardware memory
 | |
|   address for burst reads from EEPROM accesses.
 | |
|   The EEPROM provides the lower 15 bits of this address.
 | |
|   The MSB of the address from the EEPROM is ignored.
 | |
|   ===============================================*/
 | |
| #define ACX_EE_CFG                          EE_CFG
 | |
| 
 | |
| /*===============================================
 | |
|   GPIO Output Values  -32bit, RW
 | |
|   ------------------------------------------
 | |
|   [31:16]  Reserved
 | |
|   [15: 0]  Specify the output values (at the output driver inputs) for
 | |
|   GPIO[15:0], respectively.
 | |
|   ===============================================*/
 | |
| #define ACX_GPIO_OUT_REG            GPIO_OUT
 | |
| #define ACX_MAX_GPIO_LINES          15
 | |
| 
 | |
| /*===============================================
 | |
|   Contention window  -32bit, RW
 | |
|   ------------------------------------------
 | |
|   [31:26]  Reserved
 | |
|   [25:16]  Max (0x3ff)
 | |
|   [15:07]  Reserved
 | |
|   [06:00]  Current contention window value - default is 0x1F
 | |
|   ===============================================*/
 | |
| #define ACX_CONT_WIND_CFG_REG    CONT_WIND_CFG
 | |
| #define ACX_CONT_WIND_MIN_MASK   0x0000007f
 | |
| #define ACX_CONT_WIND_MAX        0x03ff0000
 | |
| 
 | |
| /*
 | |
|  * Indirect slave register/memory registers
 | |
|  * ----------------------------------------
 | |
|  */
 | |
| #define HW_SLAVE_REG_ADDR_REG		0x00000004
 | |
| #define HW_SLAVE_REG_DATA_REG		0x00000008
 | |
| #define HW_SLAVE_REG_CTRL_REG		0x0000000c
 | |
| 
 | |
| #define SLAVE_AUTO_INC				0x00010000
 | |
| #define SLAVE_NO_AUTO_INC			0x00000000
 | |
| #define SLAVE_HOST_LITTLE_ENDIAN	0x00000000
 | |
| 
 | |
| #define HW_SLAVE_MEM_ADDR_REG		SLV_MEM_ADDR
 | |
| #define HW_SLAVE_MEM_DATA_REG		SLV_MEM_DATA
 | |
| #define HW_SLAVE_MEM_CTRL_REG		SLV_MEM_CTL
 | |
| #define HW_SLAVE_MEM_ENDIAN_REG		SLV_END_CTL
 | |
| 
 | |
| #define HW_FUNC_EVENT_INT_EN		0x8000
 | |
| #define HW_FUNC_EVENT_MASK_REG		0x00000034
 | |
| 
 | |
| #define ACX_MAC_TIMESTAMP_REG	(MAC_TIMESTAMP)
 | |
| 
 | |
| /*===============================================
 | |
|   HI_CFG Interface Configuration Register Values
 | |
|   ------------------------------------------
 | |
|   ===============================================*/
 | |
| #define HI_CFG_UART_ENABLE          0x00000004
 | |
| #define HI_CFG_RST232_ENABLE        0x00000008
 | |
| #define HI_CFG_CLOCK_REQ_SELECT     0x00000010
 | |
| #define HI_CFG_HOST_INT_ENABLE      0x00000020
 | |
| #define HI_CFG_VLYNQ_OUTPUT_ENABLE  0x00000040
 | |
| #define HI_CFG_HOST_INT_ACTIVE_LOW  0x00000080
 | |
| #define HI_CFG_UART_TX_OUT_GPIO_15  0x00000100
 | |
| #define HI_CFG_UART_TX_OUT_GPIO_14  0x00000200
 | |
| #define HI_CFG_UART_TX_OUT_GPIO_7   0x00000400
 | |
| 
 | |
| /*
 | |
|  * NOTE: USE_ACTIVE_HIGH compilation flag should be defined in makefile
 | |
|  *       for platforms using active high interrupt level
 | |
|  */
 | |
| #ifdef USE_ACTIVE_HIGH
 | |
| #define HI_CFG_DEF_VAL              \
 | |
| 	(HI_CFG_UART_ENABLE |        \
 | |
| 	HI_CFG_RST232_ENABLE |      \
 | |
| 	HI_CFG_CLOCK_REQ_SELECT |   \
 | |
| 	HI_CFG_HOST_INT_ENABLE)
 | |
| #else
 | |
| #define HI_CFG_DEF_VAL              \
 | |
| 	(HI_CFG_UART_ENABLE |        \
 | |
| 	HI_CFG_RST232_ENABLE |      \
 | |
| 	HI_CFG_CLOCK_REQ_SELECT |   \
 | |
| 	HI_CFG_HOST_INT_ENABLE)
 | |
| 
 | |
| #endif
 | |
| 
 | |
| #define REF_FREQ_19_2                       0
 | |
| #define REF_FREQ_26_0                       1
 | |
| #define REF_FREQ_38_4                       2
 | |
| #define REF_FREQ_40_0                       3
 | |
| #define REF_FREQ_33_6                       4
 | |
| #define REF_FREQ_NUM                        5
 | |
| 
 | |
| #define LUT_PARAM_INTEGER_DIVIDER           0
 | |
| #define LUT_PARAM_FRACTIONAL_DIVIDER        1
 | |
| #define LUT_PARAM_ATTN_BB                   2
 | |
| #define LUT_PARAM_ALPHA_BB                  3
 | |
| #define LUT_PARAM_STOP_TIME_BB              4
 | |
| #define LUT_PARAM_BB_PLL_LOOP_FILTER        5
 | |
| #define LUT_PARAM_NUM                       6
 | |
| 
 | |
| #define ACX_EEPROMLESS_IND_REG              (SCR_PAD4)
 | |
| #define USE_EEPROM                          0
 | |
| #define SOFT_RESET_MAX_TIME                 1000000
 | |
| #define SOFT_RESET_STALL_TIME               1000
 | |
| #define NVS_DATA_BUNDARY_ALIGNMENT          4
 | |
| 
 | |
| 
 | |
| /* Firmware image load chunk size */
 | |
| #define CHUNK_SIZE          512
 | |
| 
 | |
| /* Firmware image header size */
 | |
| #define FW_HDR_SIZE 8
 | |
| 
 | |
| #define ECPU_CONTROL_HALT					0x00000101
 | |
| 
 | |
| 
 | |
| /******************************************************************************
 | |
| 
 | |
|     CHANNELS, BAND & REG DOMAINS definitions
 | |
| 
 | |
| ******************************************************************************/
 | |
| 
 | |
| 
 | |
| enum {
 | |
| 	RADIO_BAND_2_4GHZ = 0,  /* 2.4 Ghz band */
 | |
| 	RADIO_BAND_5GHZ = 1,    /* 5 Ghz band */
 | |
| 	RADIO_BAND_JAPAN_4_9_GHZ = 2,
 | |
| 	DEFAULT_BAND = RADIO_BAND_2_4GHZ,
 | |
| 	INVALID_BAND = 0xFE,
 | |
| 	MAX_RADIO_BANDS = 0xFF
 | |
| };
 | |
| 
 | |
| enum {
 | |
| 	NO_RATE      = 0,
 | |
| 	RATE_1MBPS   = 0x0A,
 | |
| 	RATE_2MBPS   = 0x14,
 | |
| 	RATE_5_5MBPS = 0x37,
 | |
| 	RATE_6MBPS   = 0x0B,
 | |
| 	RATE_9MBPS   = 0x0F,
 | |
| 	RATE_11MBPS  = 0x6E,
 | |
| 	RATE_12MBPS  = 0x0A,
 | |
| 	RATE_18MBPS  = 0x0E,
 | |
| 	RATE_22MBPS  = 0xDC,
 | |
| 	RATE_24MBPS  = 0x09,
 | |
| 	RATE_36MBPS  = 0x0D,
 | |
| 	RATE_48MBPS  = 0x08,
 | |
| 	RATE_54MBPS  = 0x0C
 | |
| };
 | |
| 
 | |
| enum {
 | |
| 	RATE_INDEX_1MBPS   =  0,
 | |
| 	RATE_INDEX_2MBPS   =  1,
 | |
| 	RATE_INDEX_5_5MBPS =  2,
 | |
| 	RATE_INDEX_6MBPS   =  3,
 | |
| 	RATE_INDEX_9MBPS   =  4,
 | |
| 	RATE_INDEX_11MBPS  =  5,
 | |
| 	RATE_INDEX_12MBPS  =  6,
 | |
| 	RATE_INDEX_18MBPS  =  7,
 | |
| 	RATE_INDEX_22MBPS  =  8,
 | |
| 	RATE_INDEX_24MBPS  =  9,
 | |
| 	RATE_INDEX_36MBPS  =  10,
 | |
| 	RATE_INDEX_48MBPS  =  11,
 | |
| 	RATE_INDEX_54MBPS  =  12,
 | |
| 	RATE_INDEX_MAX     =  RATE_INDEX_54MBPS,
 | |
| 	MAX_RATE_INDEX,
 | |
| 	INVALID_RATE_INDEX = MAX_RATE_INDEX,
 | |
| 	RATE_INDEX_ENUM_MAX_SIZE = 0x7FFFFFFF
 | |
| };
 | |
| 
 | |
| enum {
 | |
| 	RATE_MASK_1MBPS = 0x1,
 | |
| 	RATE_MASK_2MBPS = 0x2,
 | |
| 	RATE_MASK_5_5MBPS = 0x4,
 | |
| 	RATE_MASK_11MBPS = 0x20,
 | |
| };
 | |
| 
 | |
| #define SHORT_PREAMBLE_BIT   BIT(0) /* CCK or Barker depending on the rate */
 | |
| #define OFDM_RATE_BIT        BIT(6)
 | |
| #define PBCC_RATE_BIT        BIT(7)
 | |
| 
 | |
| enum {
 | |
| 	CCK_LONG = 0,
 | |
| 	CCK_SHORT = SHORT_PREAMBLE_BIT,
 | |
| 	PBCC_LONG = PBCC_RATE_BIT,
 | |
| 	PBCC_SHORT = PBCC_RATE_BIT | SHORT_PREAMBLE_BIT,
 | |
| 	OFDM = OFDM_RATE_BIT
 | |
| };
 | |
| 
 | |
| /******************************************************************************
 | |
| 
 | |
| Transmit-Descriptor RATE-SET field definitions...
 | |
| 
 | |
| Define a new "Rate-Set" for TX path that incorporates the
 | |
| Rate & Modulation info into a single 16-bit field.
 | |
| 
 | |
| TxdRateSet_t:
 | |
| b15   - Indicates Preamble type (1=SHORT, 0=LONG).
 | |
| 	Notes:
 | |
| 	Must be LONG (0) for 1Mbps rate.
 | |
| 	Does not apply (set to 0) for RevG-OFDM rates.
 | |
| b14   - Indicates PBCC encoding (1=PBCC, 0=not).
 | |
| 	Notes:
 | |
| 	Does not apply (set to 0) for rates 1 and 2 Mbps.
 | |
| 	Does not apply (set to 0) for RevG-OFDM rates.
 | |
| b13    - Unused (set to 0).
 | |
| b12-b0 - Supported Rate indicator bits as defined below.
 | |
| 
 | |
| ******************************************************************************/
 | |
| 
 | |
| 
 | |
| #define TNETW1251_CHIP_ID_PG1_0         0x07010101
 | |
| #define TNETW1251_CHIP_ID_PG1_1         0x07020101
 | |
| #define TNETW1251_CHIP_ID_PG1_2	        0x07030101
 | |
| 
 | |
| /*************************************************************************
 | |
| 
 | |
|     Interrupt Trigger Register (Host -> WiLink)
 | |
| 
 | |
| **************************************************************************/
 | |
| 
 | |
| /* Hardware to Embedded CPU Interrupts - first 32-bit register set */
 | |
| 
 | |
| /*
 | |
|  * Host Command Interrupt. Setting this bit masks
 | |
|  * the interrupt that the host issues to inform
 | |
|  * the FW that it has sent a command
 | |
|  * to the Wlan hardware Command Mailbox.
 | |
|  */
 | |
| #define INTR_TRIG_CMD       BIT(0)
 | |
| 
 | |
| /*
 | |
|  * Host Event Acknowlegde Interrupt. The host
 | |
|  * sets this bit to acknowledge that it received
 | |
|  * the unsolicited information from the event
 | |
|  * mailbox.
 | |
|  */
 | |
| #define INTR_TRIG_EVENT_ACK BIT(1)
 | |
| 
 | |
| /*
 | |
|  * The host sets this bit to inform the Wlan
 | |
|  * FW that a TX packet is in the XFER
 | |
|  * Buffer #0.
 | |
|  */
 | |
| #define INTR_TRIG_TX_PROC0 BIT(2)
 | |
| 
 | |
| /*
 | |
|  * The host sets this bit to inform the FW
 | |
|  * that it read a packet from RX XFER
 | |
|  * Buffer #0.
 | |
|  */
 | |
| #define INTR_TRIG_RX_PROC0 BIT(3)
 | |
| 
 | |
| #define INTR_TRIG_DEBUG_ACK BIT(4)
 | |
| 
 | |
| #define INTR_TRIG_STATE_CHANGED BIT(5)
 | |
| 
 | |
| 
 | |
| /* Hardware to Embedded CPU Interrupts - second 32-bit register set */
 | |
| 
 | |
| /*
 | |
|  * The host sets this bit to inform the FW
 | |
|  * that it read a packet from RX XFER
 | |
|  * Buffer #1.
 | |
|  */
 | |
| #define INTR_TRIG_RX_PROC1 BIT(17)
 | |
| 
 | |
| /*
 | |
|  * The host sets this bit to inform the Wlan
 | |
|  * hardware that a TX packet is in the XFER
 | |
|  * Buffer #1.
 | |
|  */
 | |
| #define INTR_TRIG_TX_PROC1 BIT(18)
 | |
| 
 | |
| #endif
 |