/*
 * Device1273.h
 *
 * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved.      
 * All rights reserved.                                                  
 *                                                                       
 * Redistribution and use in source and binary forms, with or without    
 * modification, are permitted provided that the following conditions    
 * are met:                                                              
 *                                                                       
 *  * Redistributions of source code must retain the above copyright     
 *    notice, this list of conditions and the following disclaimer.      
 *  * Redistributions in binary form must reproduce the above copyright  
 *    notice, this list of conditions and the following disclaimer in    
 *    the documentation and/or other materials provided with the         
 *    distribution.                                                      
 *  * Neither the name Texas Instruments nor the names of its            
 *    contributors may be used to endorse or promote products derived    
 *    from this software without specific prior written permission.      
 *                                                                       
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS   
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT     
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT  
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT      
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT   
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */


/**********************************************************************************************************************

  FILENAME:       Device1273.h

  DESCRIPTION:    TNETW1273 Registes addresses/defintion



***********************************************************************************************************************/

#ifndef DEVICE1273_H
#define DEVICE1273_H


/* Base addresses*/
/* They are not used inside registers definition in purpose to allow this header file*/
/* to be used as an easy reference to register -> address date base. Keep this as it*/
/* is very powerful for debugging purpose.*/
#define REGISTERS_BASE	0x00300000
#define INT_BASE		0x00300400
#define REG_CONFIG_BASE	0x00300800
#define CLK_BASE		0x00300C00
#define SDMA_BASE		0x00301000
#define AES_BASE		0x00301400
#define WEP_BASE		0x00301800
#define TKIP_BASE		0x00301C00
#define SEEPROM_BASE	0x00302000
#define PAR_HOST_BASE	0x00302400
#define SDIO_BASE		0x00302800
#define UART_BASE		0x00302C00
#define USB11_BASE		0x00304000
#define LDMA_BASE		0x00304400
#define RX_BASE			0x00304800
#define ACCESS_BASE		0x00304c00
#define TX_BASE			0x00305000
#define RMAC_CSR_BASE	0x00305400
#define AFE_PM			0x00305800
#define VLYNQ_BASE		0x00308000
#define PCI_BASE		0x00308400
#define USB20_BASE		0x0030A000
#define DRPW_BASE		0x00310000
#define PHY_BASE		0x003C0000

/* DRPw init scratch register */
#define DRPW_SCRATCH_START             (DRPW_BASE + 0x002C)

/* System DMA registers*/
/* Order of registers was changed*/
#define DMA_GLB_CFG                    (REGISTERS_BASE + 0x1000)
#define DMA_HDESC_OFFSET               (REGISTERS_BASE + 0x1004)
#define DMA_HDATA_OFFSET               (REGISTERS_BASE + 0x1008)
#define DMA_CFG0                       (REGISTERS_BASE + 0x100C) /* SDMA_HOST_CFG0 changed*/
#define DMA_CTL0                       (REGISTERS_BASE + 0x1010) /* SDMA_CTRL0 changed*/
#define DMA_LENGTH0                    (REGISTERS_BASE + 0x1014)
#define DMA_L_ADDR0                    (REGISTERS_BASE + 0x1018) /* SDMA_RD_ADDR ?*/
#define DMA_L_PTR0                     (REGISTERS_BASE + 0x101C) /* SDMA_RD_OFFSET ?*/
#define DMA_H_ADDR0                    (REGISTERS_BASE + 0x1020) /* SDMA_WR_ADDR ?*/
#define DMA_H_PTR0                     (REGISTERS_BASE + 0x1024) /* SDMA_WR_OFFSET ?*/
#define DMA_STS0                       (REGISTERS_BASE + 0x1028) /* Changed*/
#define DMA_CFG1                       (REGISTERS_BASE + 0x1030) /* SDMA_HOST_CFG1 changed*/
#define DMA_CTL1                       (REGISTERS_BASE + 0x1034) /* SDMA_CTRL1 changed*/
#define DMA_LENGTH1                    (REGISTERS_BASE + 0x1038)
#define DMA_L_ADDR1                    (REGISTERS_BASE + 0x103C)
#define DMA_L_PTR1                     (REGISTERS_BASE + 0x1040)
#define DMA_H_ADDR1                    (REGISTERS_BASE + 0x1044)
#define DMA_H_PTR1                     (REGISTERS_BASE + 0x1048)
#define DMA_STS1                       (REGISTERS_BASE + 0x104C)
#define DMA_HFRM_PTR                   (REGISTERS_BASE + 0x1050) /* New ?*/
#define DMA_DEBUG                      (REGISTERS_BASE + 0x1054) /* Changed*/

/* Local DMA registers*/
/* number changed from 4 to 2*/
#define LDMA_DEBUG                     (REGISTERS_BASE + 0x4400)
#define LDMA_CTL0                      (REGISTERS_BASE + 0x4404) /* Add 2 bits to support fix address (FIFO)*/
#define LDMA_STATUS0                   (REGISTERS_BASE + 0x4408)
#define LDMA_LENGTH0                   (REGISTERS_BASE + 0x440c)
#define LDMA_RD_ADDR0                  (REGISTERS_BASE + 0x4410)
#define LDMA_RD_OFFSET0                (REGISTERS_BASE + 0x4414)
#define LDMA_WR_ADDR0                  (REGISTERS_BASE + 0x4418)
#define LDMA_WR_OFFSET0                (REGISTERS_BASE + 0x441c)
#define LDMA_CTL1                      (REGISTERS_BASE + 0x4428) /* Add 2 bits to support fix address (FIFO)*/
#define LDMA_STATUS1                   (REGISTERS_BASE + 0x442c)
#define LDMA_LENGTH1                   (REGISTERS_BASE + 0x4430)
#define LDMA_RD_ADDR1                  (REGISTERS_BASE + 0x4434)
#define LDMA_RD_OFFSET1                (REGISTERS_BASE + 0x4438)
#define LDMA_WR_ADDR1                  (REGISTERS_BASE + 0x443c)
#define LDMA_WR_OFFSET1                (REGISTERS_BASE + 0x4440)
/* For TNETW compatability (if willbe )*/
#define LDMA_CUR_RD_PTR0               LDMA_RD_ADDR0
#define LDMA_CUR_WR_PTR0               LDMA_WR_ADDR0
#define LDMA_CUR_RD_PTR1               LDMA_RD_ADDR1
#define LDMA_CUR_WR_PTR1               LDMA_WR_ADDR1

/* Host Slave registers*/
#define SLV_SOFT_RESET                 (REGISTERS_BASE + 0x0000) /* self clearing*/
#define SLV_REG_ADDR                   (REGISTERS_BASE + 0x0004)
#define SLV_REG_DATA                   (REGISTERS_BASE + 0x0008)
#define SLV_REG_ADATA                  (REGISTERS_BASE + 0x000c)
#define SLV_MEM_CP                     (REGISTERS_BASE + 0x0010)
#define SLV_MEM_ADDR                   (REGISTERS_BASE + 0x0014)
#define SLV_MEM_DATA                   (REGISTERS_BASE + 0x0018)
#define SLV_MEM_CTL                    (REGISTERS_BASE + 0x001c) /* bit 19 moved to PCMCIA_CTL*/
#define SLV_END_CTL                    (REGISTERS_BASE + 0x0020) /* 2 bits moved to ENDIAN_CTL*/

/* Timer registers*/
/* Timer1/2 count MAC clocks*/
/* Timer3/4/5 count usec*/
#define TIM1_CTRL                      (REGISTERS_BASE + 0x0918)
#define TIM1_LOAD                      (REGISTERS_BASE + 0x091C)
#define TIM1_CNT                       (REGISTERS_BASE + 0x0920)
#define TIM2_CTRL                      (REGISTERS_BASE + 0x0924)
#define TIM2_LOAD                      (REGISTERS_BASE + 0x0928)
#define TIM2_CNT                       (REGISTERS_BASE + 0x092C)
#define TIM3_CTRL                      (REGISTERS_BASE + 0x0930)
#define TIM3_LOAD                      (REGISTERS_BASE + 0x0934)
#define TIM3_CNT                       (REGISTERS_BASE + 0x0938)
#define TIM4_CTRL                      (REGISTERS_BASE + 0x093C)
#define TIM4_LOAD                      (REGISTERS_BASE + 0x0940)
#define TIM4_CNT                       (REGISTERS_BASE + 0x0944)
#define TIM5_CTRL                      (REGISTERS_BASE + 0x0948)
#define TIM5_LOAD                      (REGISTERS_BASE + 0x094C)
#define TIM5_CNT                       (REGISTERS_BASE + 0x0950)

/* Watchdog registers*/
#define WDOG_CTRL                      (REGISTERS_BASE + 0x0954)
#define WDOG_LOAD                      (REGISTERS_BASE + 0x0958)
#define WDOG_CNT                       (REGISTERS_BASE + 0x095C)
#define WDOG_STS                       (REGISTERS_BASE + 0x0960)
#define WDOG_FEED                      (REGISTERS_BASE + 0x0964)

/* 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)

/* GPIO Interrupts*/
#define GPIO_INT_STS                   (REGISTERS_BASE + 0x0484) /* 22 GPIOs*/
#define GPIO_INT_ACK                   (REGISTERS_BASE + 0x047C)
#define GPIO_INT_MASK                  (REGISTERS_BASE + 0x0480)
#define GPIO_POS_MASK                  (REGISTERS_BASE + 0x04BC) /* New*/
#define GPIO_NEG_MASK                  (REGISTERS_BASE + 0x04C0) /* New*/

/* Protocol Interrupts*/
#define PROTO_INT_STS                  (REGISTERS_BASE + 0x0490) /* Add 2 PHY->MAC source interrupts*/
#define PROTO_INT_ACK                  (REGISTERS_BASE + 0x0488)
#define PROTO_INT_MASK                 (REGISTERS_BASE + 0x048C)

/* Host Interrupts - The following Addresses are for 1273 */
#define HINT_MASK                      (REGISTERS_BASE + 0x04DC)
#define HINT_MASK_SET                  (REGISTERS_BASE + 0x04E0)
#define HINT_MASK_CLR                  (REGISTERS_BASE + 0x04E4)
#define HINT_STS_ND_MASKED             (REGISTERS_BASE + 0x04EC)
#define HINT_STS_ND  		           (REGISTERS_BASE + 0x04E8)	/* 1150 spec calls this HINT_STS_RAW*/
#define HINT_STS_CLR                   (REGISTERS_BASE + 0x04F8)
#define HINT_ACK                       (REGISTERS_BASE + 0x04F0)
#define HINT_TRIG                      (REGISTERS_BASE + 0x04F4)

/* Clock registers*/
#define CLK_CFG                        (REGISTERS_BASE + 0x0C00) /* new ARM clock bit */
#define CLK_CTRL                       (REGISTERS_BASE + 0x0C04) /* changed*/
#define BLK_RST                        (REGISTERS_BASE + 0x0C08) /* changed*/
#define CFG_USEC_STB                   (REGISTERS_BASE + 0x0C0C)
#define ARM_GATE_CLK_REG               (REGISTERS_BASE + 0x0C10) /* new*/
#define BUSY_STAT_REG                  (REGISTERS_BASE + 0x0C14) /* new*/
#define CFG_PHY_CLK88                  (REGISTERS_BASE + 0x0C18)
#define DYNAMIC_CLKGATE                (REGISTERS_BASE + 0x0C1C) /* new*/

/* AES registers*/
/* Major changes to this module*/
#define AES_START                      (REGISTERS_BASE + 0x1400)
#define AES_CFG                        (REGISTERS_BASE + 0x1404)
#define AES_CTL                        (REGISTERS_BASE + 0x1408)
#define AES_STATUS                     (REGISTERS_BASE + 0x140C)
#define AES_LENGTH                     (REGISTERS_BASE + 0x1410)
#define AES_RD_ADDR                    (REGISTERS_BASE + 0x1414)
#define AES_RD_OFFSET                  (REGISTERS_BASE + 0x1418)
#define AES_WR_ADDR                    (REGISTERS_BASE + 0x141C)
#define AES_WR_OFFSET                  (REGISTERS_BASE + 0x1420)
#define AES_CUR_RD_PTR                 (REGISTERS_BASE + 0x1424)
#define AES_CUR_WR_PTR                 (REGISTERS_BASE + 0x1428)
#define AES_KEY_0                      (REGISTERS_BASE + 0x142C)
#define AES_KEY_1                      (REGISTERS_BASE + 0x1430)
#define AES_KEY_2                      (REGISTERS_BASE + 0x1434)
#define AES_KEY_3                      (REGISTERS_BASE + 0x1438)
#define AES_NONCE_0                    (REGISTERS_BASE + 0x143C)
#define AES_NONCE_1                    (REGISTERS_BASE + 0x1440)
#define AES_NONCE_2                    (REGISTERS_BASE + 0x1444)
#define AES_NONCE_3                    (REGISTERS_BASE + 0x1448)
#define AES_MIC_0                      (REGISTERS_BASE + 0x144C)
#define AES_MIC_1                      (REGISTERS_BASE + 0x1450)
#define AES_MIC_2                      (REGISTERS_BASE + 0x1454)
#define AES_MIC_3                      (REGISTERS_BASE + 0x1458)
#define AES_ASSO_DATA_0                (REGISTERS_BASE + 0x145C)
#define AES_ASSO_DATA_1                (REGISTERS_BASE + 0x1460)
#define AES_ASSO_DATA_2                (REGISTERS_BASE + 0x1464)
#define AES_ASSO_DATA_3                (REGISTERS_BASE + 0x1468)
#define AES_NUM_OF_ROUNDS              (REGISTERS_BASE + 0x146C)
#define AES_TX_QUEUE_PTR               (REGISTERS_BASE + 0x1470)
#define AES_RX_QUEUE_PTR               (REGISTERS_BASE + 0x1474)
#define AES_STACK                      (REGISTERS_BASE + 0x1478)
#define AES_INT_RAW                    (REGISTERS_BASE + 0x147C)
#define AES_INT_MASK                   (REGISTERS_BASE + 0x1480)
#define AES_INT_STS                    (REGISTERS_BASE + 0x1484)

/* WEP registers*/
/* Order was changed*/
#define DEC_CTL                        (REGISTERS_BASE + 0x1800)
#define DEC_STATUS                     (REGISTERS_BASE + 0x1804)
#define DEC_MBLK                       (REGISTERS_BASE + 0x1808)
#define DEC_KEY_ADDR                   (REGISTERS_BASE + 0x180C)
#define DEC_KEY_LEN                    (REGISTERS_BASE + 0x1810)
#define DEC_ADDR_UPPER_BYTE            (REGISTERS_BASE + 0x1814) /* new*/
#define DEC_LEN                        (REGISTERS_BASE + 0x1818)
#define DEC_OFFSET                     (REGISTERS_BASE + 0x181C)
#define DEC_WR_MBLK                    (REGISTERS_BASE + 0x1820)
#define DEC_WR_OFFSET                  (REGISTERS_BASE + 0x1824)

/* TKIP MICHAEL reisters*/
/* order changed*/
#define MCHL_START0                    (REGISTERS_BASE + 0x1C00)
#define MCHL_DMV_START_MBLK0           (REGISTERS_BASE + 0x1C04) /* Changed to 23:5 format*/
#define MCHL_DMV_CUR_MBLK0             (REGISTERS_BASE + 0x1C10)
#define MCHL_DMV_OFFSET0               (REGISTERS_BASE + 0x1C08)
#define MCHL_DMV_LENGTH0               (REGISTERS_BASE + 0x1C0C)
#define MCHL_DMV_CFG0                  (REGISTERS_BASE + 0x1C14)
#define MCHL_KEY_L0                    (REGISTERS_BASE + 0x1C18)
#define MCHL_KEY_H0                    (REGISTERS_BASE + 0x1C1C)
#define MCHL_MIC_L0                    (REGISTERS_BASE + 0x1C20)
#define MCHL_MIC_H0                    (REGISTERS_BASE + 0x1C24)
#define MCHL_START1                    (REGISTERS_BASE + 0x1C28)
#define MCHL_DMV_START_MBLK1           (REGISTERS_BASE + 0x1C2C) /* Changed to 23:5 format*/
#define MCHL_DMV_CUR_MBLK1             (REGISTERS_BASE + 0x1C38)
#define MCHL_DMV_OFFSET1               (REGISTERS_BASE + 0x1C30)
#define MCHL_DMV_LENGTH1               (REGISTERS_BASE + 0x1C34)
#define MCHL_DMV_CFG1                  (REGISTERS_BASE + 0x1C3C)
#define MCHL_KEY_L1                    (REGISTERS_BASE + 0x1C40)
#define MCHL_KEY_H1                    (REGISTERS_BASE + 0x1C44)
#define MCHL_MIC_L1                    (REGISTERS_BASE + 0x1C48)
#define MCHL_MIC_H1                    (REGISTERS_BASE + 0x1C4C)
#define MCHL_CTL0                      (REGISTERS_BASE + 0x1C50) /* new name MCHL_CTRL0*/
#define MCHL_CTL1                      (REGISTERS_BASE + 0x1C54) /* new name MCHL_CTRL1*/
#define MCHL_UPPER_BYTE_ADDR0          (REGISTERS_BASE + 0x1C58) /* new*/
#define MCHL_UPPER_BYTE_ADDR1          (REGISTERS_BASE + 0x1C5C) /* new*/

/* SEEPROM registers*/
#define EE_CFG                         (REGISTERS_BASE + 0x0820)
#define EE_CTL                         (REGISTERS_BASE + 0x2000)
#define EE_DATA                        (REGISTERS_BASE + 0x2004)
#define EE_ADDR                        (REGISTERS_BASE + 0x2008)

/* Parallel Host (PCI/CARDBUS/PCMCIA/GS*/
#define CIS_LADDR                      (REGISTERS_BASE + 0x2400)
#define HI_CTL                         (REGISTERS_BASE + 0x2404)
#define LPWR_MGT                       (REGISTERS_BASE + 0x2408)
/*#define PDR0                         (REGISTERS_BASE + 0x04ec)*/
/*#define PDR1                         (REGISTERS_BASE + 0x04f0)*/
/*#define PDR2                         (REGISTERS_BASE + 0x04f4)*/
/*#define PDR3                         (REGISTERS_BASE + 0x04f8)*/
/*#define BAR2_ENABLE                  (REGISTERS_BASE + 0x04fc)*/
/*#define BAR2_TRANS                   (REGISTERS_BASE + 0x0500)*/
/*#define BAR2_MASK                    (REGISTERS_BASE + 0x0504)*/
#define PCI_MEM_SIZE1                  (REGISTERS_BASE + 0x2428)
#define PCI_MEM_OFFSET1                (REGISTERS_BASE + 0x242C)
#define PCI_MEM_OFFSET2                (REGISTERS_BASE + 0x2430)
/*#define PCI_IO_SIZE1                 (REGISTERS_BASE + 0x0514)*/
/*#define PCI_IO_OFFSET1               (REGISTERS_BASE + 0x0518)*/
/*#define PCI_IO_OFFSET2               (REGISTERS_BASE + 0x051c)*/
/*#define PCI_CFG_OFFSET               (REGISTERS_BASE + 0x0520)*/
#define PCMCIA_CFG                     (REGISTERS_BASE + 0x2444)
#define PCMCIA_CTL                     (REGISTERS_BASE + 0x2448)
#define PCMCIA_CFG2                    (REGISTERS_BASE + 0x244C) /* new*/
#define SRAM_PAGE                      (REGISTERS_BASE + 0x2450)
#define CFG_PULLUPDN                   (REGISTERS_BASE + 0x2454)
#define CIS_MAP                        (REGISTERS_BASE + 0x2458) /* new*/
#define ENDIAN_CTRL                    (REGISTERS_BASE + 0x245C) /* new*/
#define GS_SLEEP_ACCESS                (REGISTERS_BASE + 0x2480) /* new*/
#define PCMCIA_PWR_DN                  (REGISTERS_BASE + 0x04C4) 
#define PCI_OUTPUT_DLY_CFG             (REGISTERS_BASE + 0x2464) /* new*/

/* VLYNQ registers*/
/* VLYNQ2 was removed from hardware*/
#define VL1_REV_ID                     (REGISTERS_BASE + 0x8000) /* VLYNQ_REVISION*/
#define VL1_CTL                        (REGISTERS_BASE + 0x8004) /* VLYNQ_ CONTROL*/
#define VL1_STS                        (REGISTERS_BASE + 0x8008) /* VLYNQ_STATUS*/
#define VLYNQ_INTVEC                   (REGISTERS_BASE + 0x800C)
#define VL1_INT_STS                    (REGISTERS_BASE + 0x8010) /* VLYNQ_INTCR*/
#define VL1_INT_PEND                   (REGISTERS_BASE + 0x8014) /* VLYNQ_INTSR*/
#define VL1_INT_PTR                    (REGISTERS_BASE + 0x8018) /* VLYNQ_INTPTR*/
#define VL1_TX_ADDR                    (REGISTERS_BASE + 0x801C) /* VLYNQ_TX_MAP_ADDR*/
#define VL1_RX_SIZE1                   (REGISTERS_BASE + 0x8020) /* VLYNQ_RX_MAP_SIZE1*/
#define VL1_RX_OFF1                    (REGISTERS_BASE + 0x8024) /* VLYNQ_RX_MAP_OFFSET1*/
#define VL1_RX_SIZE2                   (REGISTERS_BASE + 0x8028) /* VLYNQ_RX_MAP_SIZE2*/
#define VL1_RX_OFF2                    (REGISTERS_BASE + 0x802C) /* VLYNQ_RX_MAP_OFFSET2*/
#define VL1_RX_SIZE3                   (REGISTERS_BASE + 0x8030) /* VLYNQ_RX_MAP_SIZE3*/
#define VL1_RX_OFF3                    (REGISTERS_BASE + 0x8034) /* VLYNQ_RX_MAP_OFFSET3*/
#define VL1_RX_SIZE4                   (REGISTERS_BASE + 0x8038) /* VLYNQ_RX_MAP_SIZE4*/
#define VL1_RX_OFF4                    (REGISTERS_BASE + 0x803C) /* VLYNQ_RX_MAP_OFFSET4*/
#define VL1_CHIP_VER                   (REGISTERS_BASE + 0x8040) /* VLYNQ_CHIP_VER*/
#define VLYNQ_AUTONEG                  (REGISTERS_BASE + 0x8044)
#define VLYNQ_MANNEG                   (REGISTERS_BASE + 0x8048)
#define VLYNQ_NEGSTAT                  (REGISTERS_BASE + 0x804C)
#define VLYNQ_ENDIAN                   (REGISTERS_BASE + 0x805C)
#define VL1_INT_VEC3_0                 (REGISTERS_BASE + 0x8060) /* VLYNQ_HW_INT3TO0_CFG*/
#define VL1_INT_VEC7_4                 (REGISTERS_BASE + 0x8064) /* VLYNQ_HW_INT7TO4_CFG*/
/* VLYNQ Remote configuration registers*/
#define VL1_REM_REV_ID                 (REGISTERS_BASE + 0x8080) /* VLYNQ_REM_REVISION*/
#define VL1_REM_CTL                    (REGISTERS_BASE + 0x8084) /* VLYNQ_REM_ CONTROL*/
#define VL1_REM_STS                    (REGISTERS_BASE + 0x8088) /* VLYNQ_REM_STATUS*/
#define VLYNQ_REM_INTVEC               (REGISTERS_BASE + 0x808C)
#define VL1_REM_INT_STS                (REGISTERS_BASE + 0x8090) /* VLYNQ_REM_INTCR*/
#define VL1_REM_INT_PEND               (REGISTERS_BASE + 0x8094) /* VLYNQ_REM_INTSR*/
#define VL1_REM_INT_PTR                (REGISTERS_BASE + 0x8098) /* VLYNQ_REM_INTPTR*/
#define VL1_REM_TX_ADDR                (REGISTERS_BASE + 0x809C) /* VLYNQ_REM_TX_MAP_ADDR*/
#define VL1_REM_RX_SIZE1               (REGISTERS_BASE + 0x80A0) /* VLYNQ_REM_RX_MAP_SIZE1*/
#define VL1_REM_RX_OFF1                (REGISTERS_BASE + 0x80A4) /* VLYNQ_REM_RX_MAP_OFFSET1*/
#define VL1_REM_RX_SIZE2               (REGISTERS_BASE + 0x80A8) /* VLYNQ_REM_RX_MAP_SIZE2*/
#define VL1_REM_RX_OFF2                (REGISTERS_BASE + 0x80AC) /* VLYNQ_REM_RX_MAP_OFFSET2*/
#define VL1_REM_RX_SIZE3               (REGISTERS_BASE + 0x80B0) /* VLYNQ_REM_RX_MAP_SIZE3*/
#define VL1_REM_RX_OFF3                (REGISTERS_BASE + 0x80B4) /* VLYNQ_REM_RX_MAP_OFFSET3*/
#define VL1_REM_RX_SIZE4               (REGISTERS_BASE + 0x80B8) /* VLYNQ_REM_RX_MAP_SIZE4*/
#define VL1_REM_RX_OFF4                (REGISTERS_BASE + 0x80BC) /* VLYNQ_REM_RX_MAP_OFFSET4*/
#define VL1_REM_CHIP_VER               (REGISTERS_BASE + 0x80C0) /* VLYNQ_REM_CHIP_VER*/
#define VLYNQ_REM_AUTONEG              (REGISTERS_BASE + 0x80C4)
#define VLYNQ_REM_MANNEG               (REGISTERS_BASE + 0x80C8)
#define VLYNQ_REM_NEGSTAT              (REGISTERS_BASE + 0x80CC)
#define VLYNQ_REM_ENDIAN               (REGISTERS_BASE + 0x80DC)
#define VL1_REM_INT_VEC3_0             (REGISTERS_BASE + 0x80E0) /* VLYNQ_REM_HW_INT3TO0_CFG*/
#define VL1_REM_INT_VEC7_4             (REGISTERS_BASE + 0x80E4) /* VLYNQ_REM_HW_INT7TO4_CFG*/

/* PCIIF*/
/**/
#define PCI_ID_REG                     (REGISTERS_BASE + 0x8400)
#define PCI_STATUS_SET_REG             (REGISTERS_BASE + 0x8410)
#define PCI_STATUS_CLR_REG             (REGISTERS_BASE + 0x8414)
#define PCI_HIMASK_SET_REG             (REGISTERS_BASE + 0x8420)
#define PCI_HIMASK_CLR_REG             (REGISTERS_BASE + 0x8424)
#define PCI_AMASK_SET_REG              (REGISTERS_BASE + 0x8430)
#define PCI_AMASK_CLR_REG              (REGISTERS_BASE + 0x8434)
#define PCI_CLKRUN_REG                 (REGISTERS_BASE + 0x8438)
#define PCI_BE_VENDOR_ID_REG           (REGISTERS_BASE + 0x8500)
#define PCI_BE_COMMAND_REG             (REGISTERS_BASE + 0x8504)
#define PCI_BE_REVISION_REG            (REGISTERS_BASE + 0x8508)
#define PCI_BE_CL_SIZE_REG             (REGISTERS_BASE + 0x850C)
#define PCI_BE_BAR0_MASK_REG           (REGISTERS_BASE + 0x8510)
#define PCI_BE_BAR1_MASK_REG           (REGISTERS_BASE + 0x8514)
#define PCI_BE_BAR2_MASK_REG           (REGISTERS_BASE + 0x8518)
#define PCI_BE_BAR3_MASK_REG           (REGISTERS_BASE + 0x851C)
#define PCI_BE_CIS_PTR_REG             (REGISTERS_BASE + 0x8528)
#define PCI_BE_SUBSYS_ID_REG           (REGISTERS_BASE + 0x852C)
#define PCI_BE_CAP_PTR_REG             (REGISTERS_BASE + 0x8534)
#define PCI_BE_INTR_LINE_REG           (REGISTERS_BASE + 0x853C)
#define PCI_BE_PM_CAP_REG              (REGISTERS_BASE + 0x8540)
#define PCI_BE_PM_CTRL_REG             (REGISTERS_BASE + 0x8544)
#define PCI_BE_PM_D0_CTRL_REG          (REGISTERS_BASE + 0x8560)
#define PCI_BE_PM_D1_CTRL_REG          (REGISTERS_BASE + 0x8564)
#define PCI_BE_PM_D2_CTRL_REG          (REGISTERS_BASE + 0x8568)
#define PCI_BE_PM_D3_CTRL_REG          (REGISTERS_BASE + 0x856C)
#define PCI_BE_SLV_CFG_REG             (REGISTERS_BASE + 0x8580)
#define PCI_BE_ARB_CTRL_REG            (REGISTERS_BASE + 0x8584)
                                       
#define FER                            (REGISTERS_BASE + 0x85A0) /* PCI_BE_STSCHG_FE_REG*/
#define FEMR                           (REGISTERS_BASE + 0x85A4) /* PCI_BE_STSCHG_FEM_REG*/
#define FPSR                           (REGISTERS_BASE + 0x85A8) /* PCI_BE_STSCHG_FPS_REG*/
#define FFER                           (REGISTERS_BASE + 0x85AC) /* PCI_BE_STSCHG_FFE_REG*/

#define PCI_BE_BAR0_TRANS_REG          (REGISTERS_BASE + 0x85C0)
#define PCI_BE_BAR1_TRANS_REG          (REGISTERS_BASE + 0x85C4)
#define PCI_BE_BAR2_TRANS_REG          (REGISTERS_BASE + 0x85C8)
#define PCI_BE_BAR3_TRANS_REG          (REGISTERS_BASE + 0x85CC)
#define PCI_BE_BAR4_TRANS_REG          (REGISTERS_BASE + 0x85D0)
#define PCI_BE_BAR5_TRANS_REG          (REGISTERS_BASE + 0x85D4)
#define PCI_BE_BAR0_REG                (REGISTERS_BASE + 0x85E0)
#define PCI_BE_BAR1_REG                (REGISTERS_BASE + 0x85E4)
#define PCI_BE_BAR2_REG                (REGISTERS_BASE + 0x85E8)
#define PCI_BE_BAR3_REG                (REGISTERS_BASE + 0x85EC)

#define PCI_PROXY_DATA                 (REGISTERS_BASE + 0x8700)
#define PCI_PROXY_ADDR                 (REGISTERS_BASE + 0x8704)
#define PCI_PROXY_CMD                  (REGISTERS_BASE + 0x8708)
#define PCI_CONTROL                    (REGISTERS_BASE + 0x8710)

/* USB1.1 registers*/
/**/
#define USB_STS_CLR                    (REGISTERS_BASE + 0x4000)
#define USB_STS_ND                     (REGISTERS_BASE + 0x4004)
#define USB_INT_ACK                    (REGISTERS_BASE + 0x4008)
#define USB_MASK                       (REGISTERS_BASE + 0x400c)
#define USB_MASK_SET                   (REGISTERS_BASE + 0x4010)
#define USB_MASK_CLR                   (REGISTERS_BASE + 0x4014)
#define USB_WU                         (REGISTERS_BASE + 0x4018)
#define USB_EP0_OUT_PTR                (REGISTERS_BASE + 0x401c)
#define USB_EP0_OUT_VLD                (REGISTERS_BASE + 0x4020)
#define USB_EP0_OUT_LEN                (REGISTERS_BASE + 0x4024)
#define USB_EP0_IN_PTR                 (REGISTERS_BASE + 0x4028)
#define USB_EP0_IN_VLD                 (REGISTERS_BASE + 0x402c)
#define USB_EP0_IN_LEN                 (REGISTERS_BASE + 0x4030)
#define USB_EP1_CFG                    (REGISTERS_BASE + 0x4034)
#define USB_EP1_OUT_INT_CFG            (REGISTERS_BASE + 0x4038)
#define USB_EP1_OUT_PTR                (REGISTERS_BASE + 0x403c)
#define USB_EP1_OUT_VLD                (REGISTERS_BASE + 0x4040)
#define USB_EP1_OUT_CUR_MBLK           (REGISTERS_BASE + 0x4044)
#define USB_EP1_OUT_LEN                (REGISTERS_BASE + 0x4048)
#define USB_EP1_IN_START_MBLK          (REGISTERS_BASE + 0x404c)
#define USB_EP1_IN_LAST_MBLK           (REGISTERS_BASE + 0x4050)
#define USB_EP1_IN_VLD                 (REGISTERS_BASE + 0x4054)

#define USB_EP2_PTR                    (REGISTERS_BASE + 0x405c)
#define USB_EP2_VLD                    (REGISTERS_BASE + 0x4060)
#define USB_EP2_LEN                    (REGISTERS_BASE + 0x4064)
#define USB_EP3_OUT_PTR0               (REGISTERS_BASE + 0x4068)
#define USB_EP3_OUT_VLD0               (REGISTERS_BASE + 0x406c)
#define USB_EP3_OUT_LEN0               (REGISTERS_BASE + 0x4070)
#define USB_EP3_OUT_PTR1               (REGISTERS_BASE + 0x4074)
#define USB_EP3_OUT_VLD1               (REGISTERS_BASE + 0x4078)
#define USB_EP3_OUT_LEN1               (REGISTERS_BASE + 0x407c)
#define USB_EP3_IN_PTR0                (REGISTERS_BASE + 0x4080)
#define USB_EP3_IN_VLD0                (REGISTERS_BASE + 0x4084)
#define USB_EP3_IN_LEN0                (REGISTERS_BASE + 0x4088)
#define USB_EP3_IN_PTR1                (REGISTERS_BASE + 0x408c)
#define USB_EP3_IN_VLD1                (REGISTERS_BASE + 0x4090)
#define USB_EP3_IN_LEN1                (REGISTERS_BASE + 0x4094)
#define USB_EP1_OUT_END_MBLK           (REGISTERS_BASE + 0x4098)
#define USB_EP0_OUT_SETUP              (REGISTERS_BASE + 0x409c)
#define USB_EP0_STALL                  (REGISTERS_BASE + 0x40a0)
#define USB_EP1_IN_OFFSET              (REGISTERS_BASE + 0x40a4)

/* 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)

/* IO Control registers*/
#define SERIAL_HOST_IOCFG0             (REGISTERS_BASE + 0x0894) /* new*/
#define SERIAL_HOST_IOCFG1             (REGISTERS_BASE + 0x0898) /* new*/
#define SERIAL_HOST_IOCFG2             (REGISTERS_BASE + 0x089C) /* new*/
#define SERIAL_HOST_IOCFG3             (REGISTERS_BASE + 0x08A0) /* new*/
#define GPIO_IOCFG0                    (REGISTERS_BASE + 0x08F4) /* new*/
#define GPIO_IOCFG1                    (REGISTERS_BASE + 0x08F8) /* new*/
#define GPIO_IOCFG2                    (REGISTERS_BASE + 0x08FC) /* new*/
#define GPIO_IOCFG3                    (REGISTERS_BASE + 0x0900) /* new*/
#define CHIP_ID_B                      (REGISTERS_BASE + 0x5674) /* new*/
#define CHIP_ID                        CHIP_ID_B/* Leave for TNETW compatability*/
#define CHIP_ID_1273_PG10              (0x04030101)
#define CHIP_ID_1273_PG20              (0x04030111)

#define SYSTEM                         (REGISTERS_BASE + 0x0810)
#define PCI_ARB_CFG                    (REGISTERS_BASE + 0x0814)
#define BOOT_IRAM_CFG                  (REGISTERS_BASE + 0x0818)
#define IO_CONTROL_ENABLE              (REGISTERS_BASE + 0x5450)
#define MBLK_CFG                       (REGISTERS_BASE + 0x5460)
#define RS232_BITINTERVAL              (REGISTERS_BASE + 0x0824)
#define TEST_PORT                      (REGISTERS_BASE + 0x096C)
#define DEBUG_PORT                     (REGISTERS_BASE + 0x0970)
#define HOST_WR_ACCESS_REG             (REGISTERS_BASE + 0x09F8)

/* GPIO registers*/
#define GPIO_OE                        (REGISTERS_BASE + 0x082C) /* 22 GPIOs*/
#define GPIO_OUT                       (REGISTERS_BASE + 0x0834)
#define GPIO_IN                        (REGISTERS_BASE + 0x0830)
#define GPO_CFG                        (REGISTERS_BASE + 0x083C)
#define GPIO_SELECT                    (REGISTERS_BASE + 0x614C)
#define GPIO_OE_RADIO                  (REGISTERS_BASE + 0x6140)
#define PWRDN_BUS_L                    (REGISTERS_BASE + 0x0844)
#define PWRDN_BUS_H                    (REGISTERS_BASE + 0x0848)
#define DIE_ID_L                       (REGISTERS_BASE + 0x088C)
#define DIE_ID_H                       (REGISTERS_BASE + 0x0890)

/* Power Management registers*/
/* */
#define ELP_START                      (REGISTERS_BASE + 0x5800)
#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) /* Points to the CFG_PLL_SYNC_CNT_xx registers set*/
#define CFG_PLL_SYNC_CNT_I             (REGISTERS_BASE + 0x5820)
#define CFG_PLL_SYNC_CNT_II            (REGISTERS_BASE + 0x5824)
#define CFG_PLL_SYNC_CNT_III           (REGISTERS_BASE + 0x5828)

#define CFG_ELP_SLEEP_CNT              (REGISTERS_BASE + 0x5830) /* Points to the CFG_ELP_SLEEP_CNT_xx registers set*/
#define CFG_ELP_SLEEP_CNT_I            (REGISTERS_BASE + 0x5830)
#define CFG_ELP_SLEEP_CNT_II           (REGISTERS_BASE + 0x5834)
#define CFG_ELP_SLEEP_CNT_III          (REGISTERS_BASE + 0x5838)
#define CFG_ELP_SLEEP_CNT_IV           (REGISTERS_BASE + 0x583c)

#define ELP_SLEEP_CNT                  (REGISTERS_BASE + 0x5840) /* Points to the ELP_SLEEP_CNT_xx registers set*/
#define ELP_SLEEP_CNT_I                (REGISTERS_BASE + 0x5840)
#define ELP_SLEEP_CNT_II               (REGISTERS_BASE + 0x5844)
#define ELP_SLEEP_CNT_III              (REGISTERS_BASE + 0x5848)
#define ELP_SLEEP_CNT_IV               (REGISTERS_BASE + 0x584c)

#define ELP_WAKE_UP_STS                (REGISTERS_BASE + 0x5850)
#define CFG_SLP_CLK_SEL                (REGISTERS_BASE + 0x5860)
#define CFG_SLP_CLK_EN                 (REGISTERS_BASE + 0x5870)

#define CFG_WAKE_UP_EN_I               (REGISTERS_BASE + 0x5880)
#define CFG_WAKE_UP_EN_II              (REGISTERS_BASE + 0x5884)
#define CFG_WAKE_UP_EN_III             (REGISTERS_BASE + 0x5888)

#define CFG_ELP_PWRDN_I                (REGISTERS_BASE + 0x5890)
#define CFG_ELP_PWRDN_II               (REGISTERS_BASE + 0x5894)
#define CFG_ELP_PWRDN_III              (REGISTERS_BASE + 0x5898)

#define CFG_POWER_DOWN_I               (REGISTERS_BASE + 0x58a0)
#define CFG_POWER_DOWN_II              (REGISTERS_BASE + 0x58a4)
#define CFG_POWER_DOWN_III             (REGISTERS_BASE + 0x58a8)

#define CFG_BUCK_TESTMODE_I            (REGISTERS_BASE + 0x58b0)
#define CFG_BUCK_TESTMODE_II           (REGISTERS_BASE + 0x58b4)

#define POWER_STATUS_I                 (REGISTERS_BASE + 0x58C0)
#define POWER_STATUS_II                (REGISTERS_BASE + 0x58C4)

#define DIGLDO_BIAS_PROG_I             (REGISTERS_BASE + 0x58d0)
#define DIGLDO_BIAS_PROG_II            (REGISTERS_BASE + 0x58d4)

#define LDO2P8_BIAS_PROG_I             (REGISTERS_BASE + 0x58e0)
#define LDO2P8_BIAS_PROG_II            (REGISTERS_BASE + 0x58e4)

#define ADCLDO_BIAS_PROG               (REGISTERS_BASE + 0x58f0)

#define REFSYS_PROG_I                  (REGISTERS_BASE + 0x5910)
#define REFSYS_PROG_II                 (REGISTERS_BASE + 0x5914)

#define PM_TEST_I                      (REGISTERS_BASE + 0x5920)
#define PM_TEST_II                     (REGISTERS_BASE + 0x5924)

#define POR_PROG                       (REGISTERS_BASE + 0x5930)

#define TEST_PIN_DIR_I                 (REGISTERS_BASE + 0x5940)
#define TEST_PIN_DIR_II                (REGISTERS_BASE + 0x5944)

#define PROC_CTL                       (REGISTERS_BASE + 0x5950)

#define ADC_REF_WAKEUP_I               (REGISTERS_BASE + 0x5960)
#define ADC_REF_WAKEUP_II              (REGISTERS_BASE + 0x5964)
#define ADC_REF_WAKEUP_III             (REGISTERS_BASE + 0x5968)
#define ADC_REF_WAKEUP_IV              (REGISTERS_BASE + 0x596C)

#define VREG_WAKEUP_I                  (REGISTERS_BASE + 0x5970)
#define VREG_WAKEUP_II                 (REGISTERS_BASE + 0x5974)
#define VREG_WAKEUP_III                (REGISTERS_BASE + 0x5978)
#define VREG_WAKEUP_IV                 (REGISTERS_BASE + 0x597C)

#define PLL_WAKEUP_I                   (REGISTERS_BASE + 0x5980)
#define PLL_WAKEUP_II                  (REGISTERS_BASE + 0x5984)
#define PLL_WAKEUP_III                 (REGISTERS_BASE + 0x5988)
#define PLL_WAKEUP_IV                  (REGISTERS_BASE + 0x598C)

#define XTALOSC_WAKEUP_I               (REGISTERS_BASE + 0x5990)
#define XTALOSC_WAKEUP_II              (REGISTERS_BASE + 0x5994)
#define XTALOSC_WAKEUP_III             (REGISTERS_BASE + 0x5998)
#define XTALOSC_WAKEUP_IV              (REGISTERS_BASE + 0x599C)

/* ----------*/

#define PLL_PARAMETERS                 (REGISTERS_BASE + 0x6040)
#define WU_COUNTER_PAUSE               (REGISTERS_BASE + 0x6008)
#define WELP_ARM_COMMAND               (REGISTERS_BASE + 0x6100)

/* ----------*/

#define POWER_MGMT2                    (REGISTERS_BASE + 0x0840)
#define POWER_MGMT                     (REGISTERS_BASE + 0x5098)
#define MAC_HW_DOZE                    (REGISTERS_BASE + 0x090c)
#define ECPU_SLEEP                     (REGISTERS_BASE + 0x0840)
#define DOZE_CFG                       (REGISTERS_BASE + 0x54bc)
#define DOZE2_CFG                      (REGISTERS_BASE + 0x081c)
#define WAKEUP_CFG                     (REGISTERS_BASE + 0x54c0)
#define WAKEUP_TIME_L                  (REGISTERS_BASE + 0x54c8)
#define WAKEUP_TIME_H                  (REGISTERS_BASE + 0x54c4)

/**/

/*#define CPU_WAIT_CFG                 (f0020)*/
/*#define CFG_QOS_ACM                  (f0046)*/

/* 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)

/* RMAC registers (Raleigh MAC)*/

/* Station registers*/
#define DEV_MODE                       (REGISTERS_BASE + 0x5464)
#define STA_ADDR_L                     (REGISTERS_BASE + 0x546C)
#define STA_ADDR_H                     (REGISTERS_BASE + 0x5470)
#define BSSID_L                        (REGISTERS_BASE + 0x5474)
#define BSSID_H                        (REGISTERS_BASE + 0x5478)
#define AID_CFG                        (REGISTERS_BASE + 0x547C)
#define BASIC_RATE_CFG                 (REGISTERS_BASE + 0x4C6C)
#define BASIC_RATE_TX_CFG              (REGISTERS_BASE + 0x55F0)

/* Protocol timers registers*/
#define IFS_CFG0                       (REGISTERS_BASE + 0x5494)
#define IFS_CFG1                       (REGISTERS_BASE + 0x5498)
#define TIMEOUT_CFG                    (REGISTERS_BASE + 0x549C)
#define CONT_WIND_CFG                  (REGISTERS_BASE + 0x54A0)
#define BCN_INT_CFG                    (REGISTERS_BASE + 0x54A4)
#define RETRY_CFG                      (REGISTERS_BASE + 0x54A8)
#define DELAY_CFG                      (REGISTERS_BASE + 0x54B0)

/* Hardware Override registers*/
#define CCA_CFG                        (REGISTERS_BASE + 0x54CC)
#define CCA_FILTER_CFG                 (REGISTERS_BASE + 0x5480)
#define RADIO_PLL_CFG                  (REGISTERS_BASE + 0x555C)
#define CCA_MON                        (REGISTERS_BASE + 0x54D0)
#define TX_FRM_CTL                     (REGISTERS_BASE + 0x54D4)
#define CONT_TX_EN                     (REGISTERS_BASE + 0x50EC)
#define PHY_STANDBY_EN                 (REGISTERS_BASE + 0x5668)

/* Transmit Setup registers*/
#define TX_PING_PONG                   (REGISTERS_BASE + 0x5090)
#define TX_CFG0                        (REGISTERS_BASE + 0x5000)
#define TX_CFG1                        (REGISTERS_BASE + 0x5004)
#define TX_CFG2                        (REGISTERS_BASE + 0x5008)
#define MAX_LIFETIME                   (REGISTERS_BASE + 0x50FC)
#define TX_PANG_SEL                    (REGISTERS_BASE + 0x50E0)
#define TX_PANG0                       (REGISTERS_BASE + 0x50A0)
#define TX_PING0                       (REGISTERS_BASE + 0x5010)
#define TX_PONG0                       (REGISTERS_BASE + 0x5050)
#define TX_PANG1                       (REGISTERS_BASE + 0x50A4)
#define TX_PING1                       (REGISTERS_BASE + 0x5014)
#define TX_PONG1                       (REGISTERS_BASE + 0x5054)
#define TX_PANG2                       (REGISTERS_BASE + 0x50A8)
#define TX_PING2                       (REGISTERS_BASE + 0x5018)
#define TX_PONG2                       (REGISTERS_BASE + 0x5058)
#define TX_PANG3                       (REGISTERS_BASE + 0x50AC)
#define TX_PING3                       (REGISTERS_BASE + 0x501C)
#define TX_PONG3                       (REGISTERS_BASE + 0x505C)
#define TX_PANG4                       (REGISTERS_BASE + 0x50B0)
#define TX_PING4                       (REGISTERS_BASE + 0x5020)
#define TX_PONG4                       (REGISTERS_BASE + 0x5060)
#define TX_PANG5                       (REGISTERS_BASE + 0x50B4)
#define TX_PING5                       (REGISTERS_BASE + 0x5024)
#define TX_PONG5                       (REGISTERS_BASE + 0x5064)
#define TX_PANG6                       (REGISTERS_BASE + 0x50B8)
#define TX_PING6                       (REGISTERS_BASE + 0x5028)
#define TX_PONG6                       (REGISTERS_BASE + 0x5068)
#define TX_PANG7                       (REGISTERS_BASE + 0x50BC)
#define TX_PING7                       (REGISTERS_BASE + 0x502C)
#define TX_PONG7                       (REGISTERS_BASE + 0x506C)
#define TX_PANG8                       (REGISTERS_BASE + 0x50C0)
#define TX_PING8                       (REGISTERS_BASE + 0x5030)
#define TX_PONG8                       (REGISTERS_BASE + 0x5070)
#define TX_PANG9                       (REGISTERS_BASE + 0x50C4)
#define TX_PING9                       (REGISTERS_BASE + 0x5034)
#define TX_PONG9                       (REGISTERS_BASE + 0x5074)
#define TX_PANG10                      (REGISTERS_BASE + 0x50C8)
#define TX_PING10                      (REGISTERS_BASE + 0x5038)
#define TX_PONG10                      (REGISTERS_BASE + 0x5078)
#define TX_PANG11                      (REGISTERS_BASE + 0x50CC)
#define TX_PING11                      (REGISTERS_BASE + 0x503C)
#define TX_PONG11                      (REGISTERS_BASE + 0x507C)

/* Transmit Status registers*/
#define TX_STATUS                      (REGISTERS_BASE + 0x509C)
#define TX_PANG_EXCH                   (REGISTERS_BASE + 0x50D0)
#define TX_PING_EXCH                   (REGISTERS_BASE + 0x5040)
#define TX_PONG_EXCH                   (REGISTERS_BASE + 0x5080)
#define TX_PANG_ATT                    (REGISTERS_BASE + 0x50D4)
#define TX_PING_ATT                    (REGISTERS_BASE + 0x5044)
#define TX_PONG_ATT                    (REGISTERS_BASE + 0x5084)
#define TX_PANG_TIMESTAMP              (REGISTERS_BASE + 0x50DC)
#define TX_PING_TIMESTAMP              (REGISTERS_BASE + 0x504C)
#define TX_PONG_TIMESTAMP              (REGISTERS_BASE + 0x508C)

/* Transmit State registers*/
#define TX_STATE                       (REGISTERS_BASE + 0x5094)
#define TX_PANG_OVRD_CFG               (REGISTERS_BASE + 0x50D8)
#define TX_PING_OVRD_CFG               (REGISTERS_BASE + 0x5048)
#define TX_PONG_OVRD_CFG               (REGISTERS_BASE + 0x5088)
#define TX_HOLD_CFG                    (REGISTERS_BASE + 0x54D8)
#define TSF_ADJ_CFG1                   (REGISTERS_BASE + 0x54DC)
#define TSF_ADJ_CFG2                   (REGISTERS_BASE + 0x54E0)
#define TSF_ADJ_CFG3                   (REGISTERS_BASE + 0x54E4)
#define TSF_ADJ_CFG4                   (REGISTERS_BASE + 0x54E8)
#define CFG_OFDM_TIMES0                (REGISTERS_BASE + 0x5648)
#define CFG_OFDM_TIMES1                (REGISTERS_BASE + 0x564C)

/* Beacon/Probe Response registers*/
#define PRB_ADDR                       (REGISTERS_BASE + 0x54EC)
#define PRB_LENGTH                     (REGISTERS_BASE + 0x54F0)
#define BCN_ADDR                       (REGISTERS_BASE + 0x54F4)
#define BCN_LENGTH                     (REGISTERS_BASE + 0x54F8)
#define TIM_VALID0                     (REGISTERS_BASE + 0x54FC)
#define TIM_ADDR0                      (REGISTERS_BASE + 0x5500)
#define TIM_LENGTH0                    (REGISTERS_BASE + 0x5504)
#define TIM_VALID1                     (REGISTERS_BASE + 0x5654)
#define TIM_ADDR1                      (REGISTERS_BASE + 0x5658)
#define TIM_LENGTH1                    (REGISTERS_BASE + 0x565C)
#define TIM_SELECT                     (REGISTERS_BASE + 0x5660)
#define TSF_CFG                        (REGISTERS_BASE + 0x5508)

/* Other Hardware Generated Frames regi*/
#define CTL_FRM_CFG                    (REGISTERS_BASE + 0x550C)
#define MGMT_FRM_CFG                   (REGISTERS_BASE + 0x5510)
#define CFG_ANT_SEL                    (REGISTERS_BASE + 0x5664)
#define RMAC_ADDR_BASE                 (REGISTERS_BASE + 0x5680) /* new*/

/* Protocol Interface Read Write Interf*/
#define TXSIFS_TIMER                   (REGISTERS_BASE + 0x4C00)
#define TXPIFS_TIMER                   (REGISTERS_BASE + 0x4C04)
#define TXDIFS_TIMER                   (REGISTERS_BASE + 0x4C08)
#define SLOT_TIMER                     (REGISTERS_BASE + 0x4C0C)
#define BACKOFF_TIMER                  (REGISTERS_BASE + 0x4C10)
#define BCN_PSP_TIMER                  (REGISTERS_BASE + 0x4C14)
#define NAV                            (REGISTERS_BASE + 0x4C18)
#define TSF_L                          (REGISTERS_BASE + 0x4C1C)
#define TSF_H                          (REGISTERS_BASE + 0x4C20)
#define TSF_PREV_L                     (REGISTERS_BASE + 0x4CC4) /* new */
#define TSF_PREV_H                     (REGISTERS_BASE + 0x4CC8) /* new */
#define TOUT_TIMER                     (REGISTERS_BASE + 0x4C2C)
#define NEXT_TBTT_L                    (REGISTERS_BASE + 0x4C30)
#define NEXT_TBTT_H                    (REGISTERS_BASE + 0x4C34)
#define DTIM_CNT                       (REGISTERS_BASE + 0x4C38)
#define CONT_WIND                      (REGISTERS_BASE + 0x4C3C)
#define PRSP_REQ                       (REGISTERS_BASE + 0x4C40)
#define PRSP_DA_L                      (REGISTERS_BASE + 0x4C44)
#define PRSP_DA_H                      (REGISTERS_BASE + 0x4C48)
#define PRSP_RETRY                     (REGISTERS_BASE + 0x4C4C)
#define PSPOLL_REQ                     (REGISTERS_BASE + 0x4C50)
#define NEXT_SEQ_NUM                   (REGISTERS_BASE + 0x4C54)
#define PRSP_SEQ_NUM                   (REGISTERS_BASE + 0x4C58)
#define BCN_SEQ_NUM                    (REGISTERS_BASE + 0x4C5C)
#define MED_USAGE                      (REGISTERS_BASE + 0x4C24)
#define MED_USAGE_TM                   (REGISTERS_BASE + 0x4C28)
#define PRB_DLY                        (REGISTERS_BASE + 0x4C60)
#define STA_SRC                        (REGISTERS_BASE + 0x4C64)
#define STA_LRC                        (REGISTERS_BASE + 0x4C68)
#define CFG_ACM                        (REGISTERS_BASE + 0x4C70)
#define RAND_NUMB                      (REGISTERS_BASE + 0x4C6C)
#define CFG_ACK_CTS_DOT11A             (REGISTERS_BASE + 0x4C74)
#define CFG_ACK_CTS_DOT11B             (REGISTERS_BASE + 0x4C78)
#define ACM_IFS_CFG0                   (REGISTERS_BASE + 0x4C7C)
#define ACM_IFS_CFG1                   (REGISTERS_BASE + 0x4C80)
#define ACM_IFS_CFG2                   (REGISTERS_BASE + 0x4C84)
#define ACM_IFS_CFG3                   (REGISTERS_BASE + 0x4C88)
#define ACK_CTS_FRM_CFG                (REGISTERS_BASE + 0x4C8C)
#define CFG_RX_TSTMP_DLY0              (REGISTERS_BASE + 0x4C90)
#define CFG_RX_TSTMP_DLY1              (REGISTERS_BASE + 0x4C94)
#define CFG_RX_TSTMP_DLY2              (REGISTERS_BASE + 0x4C98)
#define CFG_RX_TSTMP_DLY3              (REGISTERS_BASE + 0x4C9C)
#define CCA_BUSY                       (REGISTERS_BASE + 0x4CA0)
#define CCA_BUSY_CLR                   (REGISTERS_BASE + 0x4CA4)
#define CCA_IDLE                       (REGISTERS_BASE + 0x4CA8)
#define CCA_IDLE_CLR                   (REGISTERS_BASE + 0x4CAC)

/* Receive Manager registers*/
#define RX_HEAD_PTR                    (REGISTERS_BASE + 0x567C) /* new*/
#define RX_TAIL_PTR                    (REGISTERS_BASE + 0x4898) /* new*/
#define RX_CURR_PTR                    (REGISTERS_BASE + 0x5678) /* new*/
#define RX_RESET                       (REGISTERS_BASE + 0x4800)
#define RX_MODMODE                     (REGISTERS_BASE + 0x4838) /* new*/
#define MAC_HEADER_BYTECNT             (REGISTERS_BASE + 0x4890)
#define RX_MAC_BYTECNT_INT             (REGISTERS_BASE + 0x489C)
#define MAC_HEADER_WORD0               (REGISTERS_BASE + 0x4868)
#define MAC_HEADER_WORD1               (REGISTERS_BASE + 0x486C)
#define MAC_HEADER_WORD2               (REGISTERS_BASE + 0x4870)
#define MAC_HEADER_WORD3               (REGISTERS_BASE + 0x4874)
#define MAC_HEADER_WORD4               (REGISTERS_BASE + 0x4878)
#define MAC_HEADER_WORD5               (REGISTERS_BASE + 0x487C)
#define MAC_HEADER_WORD6               (REGISTERS_BASE + 0x4880)
#define MAC_HEADER_WORD7               (REGISTERS_BASE + 0x4884)
#define MAC_HEADER_WORD8               (REGISTERS_BASE + 0x4888)
#define MAC_HEADER_WORD9               (REGISTERS_BASE + 0x488C)
#define RX_CFG                         (REGISTERS_BASE + 0x5514)
#define RX_FILTER_CFG                  (REGISTERS_BASE + 0x55B4)
#define RX_MC0_L                       (REGISTERS_BASE + 0x5518)
#define RX_MC0_H                       (REGISTERS_BASE + 0x551C)
#define RX_MC1_L                       (REGISTERS_BASE + 0x5520)
#define RX_MC1_H                       (REGISTERS_BASE + 0x5524)
#define STA_SSID0                      (REGISTERS_BASE + 0x4804)
#define STA_SSID1                      (REGISTERS_BASE + 0x4808)
#define STA_SSID2                      (REGISTERS_BASE + 0x480C)
#define STA_SSID3                      (REGISTERS_BASE + 0x4810)
#define STA_SSID4                      (REGISTERS_BASE + 0x4814)
#define STA_SSID5                      (REGISTERS_BASE + 0x4818)
#define STA_SSID6                      (REGISTERS_BASE + 0x481C)
#define STA_SSID7                      (REGISTERS_BASE + 0x4820)
#define SSID_LEN                       (REGISTERS_BASE + 0x4824)
#define RX_FREE_MEM                    (REGISTERS_BASE + 0x5528)
#define RX_CURR_MEM                    (REGISTERS_BASE + 0x552C)
#define MAC_TIMESTAMP                  (REGISTERS_BASE + 0x5560) /* Check place*/
#define RX_TIMESTAMP                   (REGISTERS_BASE + 0x5564)
#define RX_FRM_PTR                     (REGISTERS_BASE + 0x5568)
#define RX_FRM_LEN                     (REGISTERS_BASE + 0x556C)
#define RX_PLCP_HDR                    (REGISTERS_BASE + 0x5570)
#define RX_PLCP_SIGNAL                 (REGISTERS_BASE + 0x5574)
#define RX_PLCP_SERVICE                (REGISTERS_BASE + 0x5578) /* 16 bits ?*/
#define RX_PLCP_LENGTH                 (REGISTERS_BASE + 0x557C)
#define RX_FRM_CTL                     (REGISTERS_BASE + 0x5580)
#define RX_DUR_ID                      (REGISTERS_BASE + 0x5584)
#define RX_ADDR1_L                     (REGISTERS_BASE + 0x5588)
#define RX_ADDR1_H                     (REGISTERS_BASE + 0x558C)
#define RX_ADDR2_L                     (REGISTERS_BASE + 0x5590)
#define RX_ADDR2_H                     (REGISTERS_BASE + 0x5594)
#define RX_ADDR3_L                     (REGISTERS_BASE + 0x5598)
#define RX_ADDR3_H                     (REGISTERS_BASE + 0x559C)
#define RX_SEQ_CTL                     (REGISTERS_BASE + 0x55A0)
#define RX_WEP_IV                      (REGISTERS_BASE + 0x55A4)
#define RX_TIME_L                      (REGISTERS_BASE + 0x55A8)
#define RX_TIME_H                      (REGISTERS_BASE + 0x55AC)
#define RX_STATUS                      (REGISTERS_BASE + 0x55B0)
#define PLCP_ERR_CNT                   (REGISTERS_BASE + 0x4828)
#define FCS_ERR_CNT                    (REGISTERS_BASE + 0x482C)
#define RX_OVERFLOW_CNT                (REGISTERS_BASE + 0x4830)
#define RX_DEBUG1                      (REGISTERS_BASE + 0x4858)
#define RX_DEBUG2                      (REGISTERS_BASE + 0x485C)
#define RX_QOS_CFG                     (REGISTERS_BASE + 0x4848)
#define RX_QOS_CTL                     (REGISTERS_BASE + 0x4844)
#define RX_QOS_STATUS                  (REGISTERS_BASE + 0x4854) /* new name RX_QOS_STS*/
#define RX_TXOP_HOLDER_L               (REGISTERS_BASE + 0x484C)
#define RX_TXOP_HOLDER_H               (REGISTERS_BASE + 0x4850)
#define RX_FRM_CNT                     (REGISTERS_BASE + 0x4834) /* what is RX_FRM_CTR*/
#define CONS_FCS_ERR_CNT               (REGISTERS_BASE + 0x483C)
#define CONS_FCS_ERR_CFG               (REGISTERS_BASE + 0x4840)
#define RX_QOS_CTL_MASK                (REGISTERS_BASE + 0x48A0) /* new*/
#define RX_QOS_ACK_EN                  (REGISTERS_BASE + 0x48A4) /* new*/
#define RX_QOS_NOACK_EN                (REGISTERS_BASE + 0x48A8) /* new*/
#define RX_QOS_ACK_BITMAP              (REGISTERS_BASE + 0x48AC) /* new*/

/* Baseband Processor registers*/
#define SBB_CFG                        (REGISTERS_BASE + 0x55C8)
#define SBB_ADDR                       (REGISTERS_BASE + 0x55D0)
#define SBB_DATA                       (REGISTERS_BASE + 0x55D4)
#define SBB_CTL                        (REGISTERS_BASE + 0x55D8)

/* Radio Control Interface registers*/
#define RCI_CTL                        (REGISTERS_BASE + 0x55DC)
#define RCI_DATA                       (REGISTERS_BASE + 0x55E0)
#define RCI_CFG1                       (REGISTERS_BASE + 0x55E4)
#define RCI_CFG2                       (REGISTERS_BASE + 0x55E8)
#define RCI_CFG3                       (REGISTERS_BASE + 0x55EC)

#define TNET1150_LAST_REG_ADDR			PCI_CONTROL

#define ECPU_CONTROL_HALT			   0x00000101				

/*0x03bc00 address is 1KB from end of FW RAM in 125x chip*/
#define FW_STATIC_NVS_TRAGET_ADDRESS   0x03bc00

/* Command mail box address */
#define CMD_MBOX_ADDRESS               0x407B4

/* Top Register */
#define INDIRECT_REG1                  (REGISTERS_BASE + 0x9B0)
#define OCP_POR_CTR                    (REGISTERS_BASE + 0x9B4)
#define OCP_POR_WDATA                  (REGISTERS_BASE + 0x9B8)
#define OCP_DATA_RD                    (REGISTERS_BASE + 0x9BC)
#define OCP_CMD                        (REGISTERS_BASE + 0x9C0)
#define FUNC7_SEL                      0xC8C
#define FUNC7_PULL                     0xCB0
#define FN0_CCCR_REG_32                0x64  

#define PLL_PARAMETERS_CLK_VAL_19_2M   0x01			
#define PLL_PARAMETERS_CLK_VAL_26M     0x02				
#define PLL_PARAMETERS_CLK_VAL_38_4M   0x03				
#define PLL_PARAMETERS_CLK_VAL_52M     0x04				

#define WU_COUNTER_PAUSE_VAL           0x3FF

/* Base band clocker register */
#define WELP_ARM_COMMAND_VAL           0x4

/* Command mail box address */
#define CMD_MBOX_ADDRESS               0x407B4

#endif