staging:rtl8192u: Rename EEPROM_Default_CrystalCap - Style
[linux-2.6-block.git] / drivers / staging / rtl8192u / r8192U_hw.h
index 00a123d44207b54c35a8eaaea4d330c9a1eaba9e..923d8ab5939d6f0131e1987ca1270944c3ed7eaf 100644 (file)
 #ifndef R8192_HW
 #define R8192_HW
 
-typedef enum _VERSION_819xU {
-       VERSION_819xU_A, // A-cut
-       VERSION_819xU_B, // B-cut
-       VERSION_819xU_C,// C-cut
-} VERSION_819xU, *PVERSION_819xU;
-//added for different RF type
-typedef enum _RT_RF_TYPE_DEF {
-       RF_1T2R = 0,
-       RF_2T4R,
-
-       RF_819X_MAX_TYPE
-} RT_RF_TYPE_DEF;
-
-
-typedef enum _BaseBand_Config_Type {
-       BaseBand_Config_PHY_REG = 0,                    //Radio Path A
-       BaseBand_Config_AGC_TAB = 1,                    //Radio Path B
-} BaseBand_Config_Type, *PBaseBand_Config_Type;
 #define        RTL8187_REQT_READ       0xc0
 #define        RTL8187_REQT_WRITE      0x40
 #define        RTL8187_REQ_GET_REGS    0x05
@@ -47,58 +29,33 @@ typedef enum _BaseBand_Config_Type {
 #define MAX_RX_URB 16
 
 #define R8180_MAX_RETRY 255
-//#define MAX_RX_NORMAL_URB 3
-//#define MAX_RX_COMMAND_URB 2
-#define RX_URB_SIZE 9100
-
-#define BB_ANTATTEN_CHAN14     0x0c
-#define BB_ANTENNA_B 0x40
 
-#define BB_HOST_BANG           BIT(30)
-#define BB_HOST_BANG_EN                BIT(2)
-#define BB_HOST_BANG_CLK       BIT(1)
-#define BB_HOST_BANG_RW                BIT(3)
-#define BB_HOST_BANG_DATA       1
+#define RX_URB_SIZE 9100
 
-//#if (RTL819X_FPGA_VER & RTL819X_FPGA_VIVI_070920)
-#define AFR                    0x010
-#define AFR_CardBEn            BIT(0)
-#define AFR_CLKRUN_SEL         BIT(1)
-#define AFR_FuncRegEn          BIT(2)
 #define RTL8190_EEPROM_ID      0x8129
 #define EEPROM_VID             0x02
 #define EEPROM_PID             0x04
 #define EEPROM_NODE_ADDRESS_BYTE_0     0x0C
 
-#define EEPROM_TxPowerDiff     0x1F
-#define EEPROM_ThermalMeter    0x20
-#define EEPROM_PwDiff          0x21    //0x21
-#define EEPROM_CrystalCap      0x22    //0x22
+#define EEPROM_TX_POWER_DIFF   0x1F
+#define EEPROM_THERMAL_METER   0x20
+#define EEPROM_PW_DIFF         0x21    //0x21
+#define EEPROM_CRYSTAL_CAP     0x22    //0x22
 
-#define EEPROM_TxPwIndex_CCK   0x23    //0x23
-#define EEPROM_TxPwIndex_OFDM_24G      0x24    //0x24~0x26
-#define EEPROM_TxPwIndex_CCK_V1                0x29    //0x29~0x2B
-#define EEPROM_TxPwIndex_OFDM_24G_V1   0x2C    //0x2C~0x2E
-#define EEPROM_TxPwIndex_Ver           0x27    //0x27
+#define EEPROM_TX_PW_INDEX_CCK 0x23    //0x23
+#define EEPROM_TX_PW_INDEX_OFDM_24G    0x24    //0x24~0x26
+#define EEPROM_TX_PW_INDEX_CCK_V1      0x29    //0x29~0x2B
+#define EEPROM_TX_PW_INDEX_OFDM_24G_V1 0x2C    //0x2C~0x2E
+#define EEPROM_TX_PW_INDEX_VER         0x27    //0x27
 
-#define EEPROM_Default_TxPowerDiff             0x0
-#define EEPROM_Default_ThermalMeter            0x7
-#define EEPROM_Default_PwDiff                  0x4
-#define EEPROM_Default_CrystalCap              0x5
+#define EEPROM_DEFAULT_THERNAL_METER           0x7
+#define EEPROM_DEFAULT_PW_DIFF                 0x4
+#define EEPROM_DEFAULT_CRYSTAL_CAP             0x5
 #define EEPROM_Default_TxPower                 0x1010
 #define EEPROM_Customer_ID                     0x7B    //0x7B:CustomerID
 #define EEPROM_ChannelPlan                     0x16    //0x7C
-#define EEPROM_IC_VER                          0x7d    //0x7D
-#define EEPROM_CRC                             0x7e    //0x7E~0x7F
 
-#define EEPROM_CID_DEFAULT                     0x0
-#define EEPROM_CID_CAMEO                               0x1
 #define EEPROM_CID_RUNTOP                              0x2
-#define EEPROM_CID_Senao                               0x3
-#define EEPROM_CID_TOSHIBA                             0x4     // Toshiba setting, Merge by Jacken, 2008/01/31
-#define EEPROM_CID_NetCore                             0x5
-#define EEPROM_CID_Nettronix                   0x6
-#define EEPROM_CID_Pronet                              0x7
 #define EEPROM_CID_DLINK                               0x8
 
 #define AC_PARAM_TXOP_LIMIT_OFFSET     16
@@ -108,18 +65,16 @@ typedef enum _BaseBand_Config_Type {
 
 //#endif
 enum _RTL8192Usb_HW {
+       MAC0                    = 0x000,
+       MAC4                    = 0x004,
 
-       PCIF                    = 0x009, // PCI Function Register 0x0009h~0x000bh
 #define        BB_GLOBAL_RESET_BIT     0x1
        BB_GLOBAL_RESET         = 0x020, // BasebandGlobal Reset Register
        BSSIDR                  = 0x02E, // BSSID Register
        CMDR                    = 0x037, // Command register
-#define CR_RST                 0x10
 #define CR_RE                  0x08
 #define CR_TE                  0x04
-#define CR_MulRW               0x01
        SIFS                    = 0x03E, // SIFS register
-       TCR                     = 0x040, // Transmit Configuration Register
 
 #define TCR_MXDMA_2048         7
 #define TCR_LRL_OFFSET         0
@@ -132,26 +87,16 @@ enum _RTL8192Usb_HW {
                         BIT(22) | BIT(23))
 #define RX_FIFO_THRESHOLD_MASK (BIT(13) | BIT(14) | BIT(15))
 #define RX_FIFO_THRESHOLD_SHIFT 13
-#define RX_FIFO_THRESHOLD_128 3
-#define RX_FIFO_THRESHOLD_256 4
-#define RX_FIFO_THRESHOLD_512 5
-#define RX_FIFO_THRESHOLD_1024 6
 #define RX_FIFO_THRESHOLD_NONE 7
 #define MAX_RX_DMA_MASK        (BIT(8) | BIT(9) | BIT(10))
 #define RCR_MXDMA_OFFSET       8
 #define RCR_FIFO_OFFSET                13
 #define RCR_ONLYERLPKT         BIT(31)                 // Early Receiving based on Packet Size.
-#define RCR_ENCS2              BIT(30)                 // Enable Carrier Sense Detection Method 2
-#define RCR_ENCS1              BIT(29)                 // Enable Carrier Sense Detection Method 1
-#define RCR_ENMBID             BIT(27)                 // Enable Multiple BssId.
-#define RCR_ACKTXBW            (BIT(24) | BIT(25))     // TXBW Setting of ACK frames
 #define RCR_CBSSID             BIT(23)                 // Accept BSSID match packet
 #define RCR_APWRMGT            BIT(22)                 // Accept power management packet
-#define        RCR_ADD3                BIT(21)                 // Accept address 3 match packet
 #define RCR_AMF                        BIT(20)                 // Accept management type frame
 #define RCR_ACF                        BIT(19)                 // Accept control type frame
 #define RCR_ADF                        BIT(18)                 // Accept data type frame
-#define RCR_RXFTH              BIT(13)                 // Rx FIFO Threshold
 #define RCR_AICV               BIT(12)                 // Accept ICV error packet
 #define        RCR_ACRC32              BIT(5)                  // Accept CRC32 error packet
 #define        RCR_AB                  BIT(3)                  // Accept broadcast packet
@@ -160,14 +105,10 @@ enum _RTL8192Usb_HW {
 #define        RCR_AAP                 BIT(0)                  // Accept all unicast packet
        SLOT_TIME               = 0x049, // Slot Time Register
        ACK_TIMEOUT             = 0x04c, // Ack Timeout Register
-       PIFS_TIME               = 0x04d, // PIFS time
-       USTIME                  = 0x04e, // Microsecond Tuning Register, Sets the microsecond time unit used by MAC clock.
        EDCAPARA_BE             = 0x050, // EDCA Parameter of AC BE
        EDCAPARA_BK             = 0x054, // EDCA Parameter of AC BK
        EDCAPARA_VO             = 0x058, // EDCA Parameter of AC VO
        EDCAPARA_VI             = 0x05C, // EDCA Parameter of AC VI
-       RFPC                    = 0x05F, // Rx FIFO Packet Count
-       CWRR                    = 0x060, // Contention Window Report Register
        BCN_TCFG                = 0x062, // Beacon Time Configuration
 #define BCN_TCFG_CW_SHIFT              8
 #define BCN_TCFG_IFS                   0
@@ -178,7 +119,6 @@ enum _RTL8192Usb_HW {
        BCN_ERR_THRESH          = 0x078, // Beacon Error Threshold
        RWCAM                   = 0x0A0, //IN 8190 Data Sheet is called CAMcmd
        WCAMI                   = 0x0A4, // Software write CAM input content
-       RCAMO                   = 0x0A8, // Software read/write CAM config
        SECR                    = 0x0B0, //Security Configuration Register
 #define        SCR_TxUseDK             BIT(0)                  //Force Tx Use Default Key
 #define SCR_RxUseDK            BIT(1)                  //Force Rx Use Default Key
@@ -186,21 +126,6 @@ enum _RTL8192Usb_HW {
 #define SCR_RxDecEnable                BIT(3)                  //Enable Rx Decryption
 #define SCR_SKByA2             BIT(4)                  //Search kEY BY A2
 #define SCR_NoSKMC             BIT(5)                  //No Key Search for Multicast
-#define SCR_UseDK              0x01
-#define SCR_TxSecEnable                0x02
-#define SCR_RxSecEnable                0x04
-       TPPoll                  = 0x0fd, // Transmit priority polling register
-       PSR                     = 0x0ff, // Page Select Register
-#define CPU_CCK_LOOPBACK       0x00030000
-#define CPU_GEN_SYSTEM_RESET   0x00000001
-#define CPU_GEN_FIRMWARE_RESET 0x00000008
-#define CPU_GEN_BOOT_RDY       0x00000010
-#define CPU_GEN_FIRM_RDY       0x00000020
-#define CPU_GEN_PUT_CODE_OK    0x00000080
-#define CPU_GEN_BB_RST         0x00000100
-#define CPU_GEN_PWR_STB_CPU    0x00000004
-#define CPU_GEN_NO_LOOPBACK_MSK        0xFFF8FFFF              // Set bit18,17,16 to 0. Set bit19
-#define CPU_GEN_NO_LOOPBACK_SET        0x00080000              // Set BIT19 to 1
 
 //----------------------------------------------------------------------------
 //       8190 CPU General Register             (offset 0x100, 4 byte)
@@ -216,72 +141,20 @@ enum _RTL8192Usb_HW {
 #define CPU_GEN_NO_LOOPBACK_MSK        0xFFF8FFFF // Set bit18,17,16 to 0. Set bit19
 #define CPU_GEN_NO_LOOPBACK_SET        0x00080000 // Set BIT19 to 1
        CPU_GEN                 = 0x100, // CPU Reset Register
-       LED1Cfg                 =               0x154,// LED1 Configuration Register
-       LED0Cfg                 =               0x155,// LED0 Configuration Register
 
-       AcmAvg                  = 0x170, // ACM Average Period Register
        AcmHwCtrl               = 0x171, // ACM Hardware Control Register
 //----------------------------------------------------------------------------
 ////
 ////       8190 AcmHwCtrl bits                                    (offset 0x171, 1 byte)
 ////----------------------------------------------------------------------------
 //
-#define AcmHw_HwEn              BIT(0)
 #define AcmHw_BeqEn             BIT(1)
-#define AcmHw_ViqEn             BIT(2)
-#define AcmHw_VoqEn             BIT(3)
-#define AcmHw_BeqStatus         BIT(4)
-#define AcmHw_ViqStatus         BIT(5)
-#define AcmHw_VoqStatus         BIT(6)
 
-       AcmFwCtrl               = 0x172, // ACM Firmware Control Register
-       AES_11N_FIX             = 0x173,
-       VOAdmTime               = 0x174, // VO Queue Admitted Time Register
-       VIAdmTime               = 0x178, // VI Queue Admitted Time Register
-       BEAdmTime               = 0x17C, // BE Queue Admitted Time Register
        RQPN1                   = 0x180, // Reserved Queue Page Number , Vo Vi, Be, Bk
        RQPN2                   = 0x184, // Reserved Queue Page Number, HCCA, Cmd, Mgnt, High
        RQPN3                   = 0x188, // Reserved Queue Page Number, Bcn, Public,
-//     QPRR                    = 0x1E0, // Queue Page Report per TID
        QPNR                    = 0x1D0, //0x1F0, // Queue Packet Number report per TID
-       BQDA                    = 0x200, // Beacon Queue Descriptor Address
-       HQDA                    = 0x204, // High Priority Queue Descriptor Address
-       CQDA                    = 0x208, // Command Queue Descriptor Address
-       MQDA                    = 0x20C, // Management Queue Descriptor Address
-       HCCAQDA                 = 0x210, // HCCA Queue Descriptor Address
-       VOQDA                   = 0x214, // VO Queue Descriptor Address
-       VIQDA                   = 0x218, // VI Queue Descriptor Address
-       BEQDA                   = 0x21C, // BE Queue Descriptor Address
-       BKQDA                   = 0x220, // BK Queue Descriptor Address
-       RCQDA                   = 0x224, // Receive command Queue Descriptor Address
-       RDQDA                   = 0x228, // Receive Queue Descriptor Start Address
-
-       MAR0                    = 0x240, // Multicast filter.
-       MAR4                    = 0x244,
-
-       CCX_PERIOD              = 0x250, // CCX Measurement Period Register, in unit of TU.
-       CLM_RESULT              = 0x251, // CCA Busy fraction register.
-       NHM_PERIOD              = 0x252, // NHM Measurement Period register, in unit of TU.
 
-       NHM_THRESHOLD0          = 0x253, // Noise Histogram Meashorement0.
-       NHM_THRESHOLD1          = 0x254, // Noise Histogram Meashorement1.
-       NHM_THRESHOLD2          = 0x255, // Noise Histogram Meashorement2.
-       NHM_THRESHOLD3          = 0x256, // Noise Histogram Meashorement3.
-       NHM_THRESHOLD4          = 0x257, // Noise Histogram Meashorement4.
-       NHM_THRESHOLD5          = 0x258, // Noise Histogram Meashorement5.
-       NHM_THRESHOLD6          = 0x259, // Noise Histogram Meashorement6
-
-       MCTRL                   = 0x25A, // Measurement Control
-
-       NHM_RPI_COUNTER0        = 0x264, // Noise Histogram RPI counter0, the fraction of signal strength < NHM_THRESHOLD0.
-       NHM_RPI_COUNTER1        = 0x265, // Noise Histogram RPI counter1, the fraction of signal strength in (NHM_THRESHOLD0, NHM_THRESHOLD1].
-       NHM_RPI_COUNTER2        = 0x266, // Noise Histogram RPI counter2, the fraction of signal strength in (NHM_THRESHOLD1, NHM_THRESHOLD2].
-       NHM_RPI_COUNTER3        = 0x267, // Noise Histogram RPI counter3, the fraction of signal strength in (NHM_THRESHOLD2, NHM_THRESHOLD3].
-       NHM_RPI_COUNTER4        = 0x268, // Noise Histogram RPI counter4, the fraction of signal strength in (NHM_THRESHOLD3, NHM_THRESHOLD4].
-       NHM_RPI_COUNTER5        = 0x269, // Noise Histogram RPI counter5, the fraction of signal strength in (NHM_THRESHOLD4, NHM_THRESHOLD5].
-       NHM_RPI_COUNTER6        = 0x26A, // Noise Histogram RPI counter6, the fraction of signal strength in (NHM_THRESHOLD5, NHM_THRESHOLD6].
-       NHM_RPI_COUNTER7        = 0x26B, // Noise Histogram RPI counter7, the fraction of signal strength in (NHM_THRESHOLD6, NHM_THRESHOLD7].
-#define        BW_OPMODE_11J                   BIT(0)
 #define        BW_OPMODE_5G                    BIT(1)
 #define        BW_OPMODE_20MHZ                 BIT(2)
        BW_OPMODE               = 0x300, // Bandwidth operation mode
@@ -292,18 +165,10 @@ enum _RTL8192Usb_HW {
 #define MSR_LINK_SHIFT     0
 #define MSR_LINK_ADHOC     1
 #define MSR_LINK_MASTER    3
-#define MSR_LINK_ENEDCA           BIT(4)
        RETRY_LIMIT             = 0x304, // Retry Limit [15:8]-short, [7:0]-long
 #define RETRY_LIMIT_SHORT_SHIFT 8
 #define RETRY_LIMIT_LONG_SHIFT 0
-       TSFR                    = 0x308,
        RRSR                    = 0x310, // Response Rate Set
-#define RRSR_RSC_OFFSET                        21
-#define RRSR_SHORT_OFFSET                      23
-#define RRSR_RSC_DUPLICATE                     0x600000
-#define RRSR_RSC_LOWSUBCHNL            0x400000
-#define RRSR_RSC_UPSUBCHANL            0x200000
-#define RRSR_SHORT                                     0x800000
 #define RRSR_1M                                                BIT(0)
 #define RRSR_2M                                                BIT(1)
 #define RRSR_5_5M                                      BIT(2)
@@ -316,17 +181,9 @@ enum _RTL8192Usb_HW {
 #define RRSR_36M                                       BIT(9)
 #define RRSR_48M                                       BIT(10)
 #define RRSR_54M                                       BIT(11)
-#define RRSR_MCS0                                      BIT(12)
-#define RRSR_MCS1                                      BIT(13)
-#define RRSR_MCS2                                      BIT(14)
-#define RRSR_MCS3                                      BIT(15)
-#define RRSR_MCS4                                      BIT(16)
-#define RRSR_MCS5                                      BIT(17)
-#define RRSR_MCS6                                      BIT(18)
-#define RRSR_MCS7                                      BIT(19)
 #define BRSR_AckShortPmb                       BIT(23)         // CCK ACK: use Short Preamble or not.
-       RATR0                   = 0x320, // Rate Adaptive Table register1
        UFWP                    = 0x318,
+       RATR0                   = 0x320, // Rate Adaptive Table register1
        DRIVER_RSSI             = 0x32c,                                        // Driver tell Firmware current RSSI
 //----------------------------------------------------------------------------
 //       8190 Rate Adaptive Table Register     (offset 0x320, 4 byte)
@@ -372,41 +229,18 @@ enum _RTL8192Usb_HW {
 #define RATE_ALL_OFDM_2SS      RATR_MCS8|RATR_MCS9     |RATR_MCS10|RATR_MCS11| \
                                                        RATR_MCS12|RATR_MCS13|RATR_MCS14|RATR_MCS15
 
-       MCS_TXAGC               = 0x340, // MCS AGC
-       CCK_TXAGC               = 0x348, // CCK AGC
-//     ISR                     = 0x350, // Interrupt Status Register
-//     IMR                     = 0x354, // Interrupt Mask Register
-//     IMR_POLL                = 0x360,
-       MacBlkCtrl              = 0x403, // Mac block on/off control register
-
        EPROM_CMD               = 0xfe58,
 #define Cmd9346CR_9356SEL      BIT(4)
-#define EPROM_CMD_RESERVED_MASK BIT(5)
 #define EPROM_CMD_OPERATING_MODE_SHIFT 6
-#define EPROM_CMD_OPERATING_MODE_MASK (BIT(7) | BIT(6))
-#define EPROM_CMD_CONFIG 0x3
 #define EPROM_CMD_NORMAL 0
-#define EPROM_CMD_LOAD 1
 #define EPROM_CMD_PROGRAM 2
 #define EPROM_CS_BIT BIT(3)
 #define EPROM_CK_BIT BIT(2)
 #define EPROM_W_BIT  BIT(1)
 #define EPROM_R_BIT  BIT(0)
-
-       MAC0                    = 0x000,
-       MAC1                    = 0x001,
-       MAC2                    = 0x002,
-       MAC3                    = 0x003,
-       MAC4                    = 0x004,
-       MAC5                    = 0x005,
-
 };
 //----------------------------------------------------------------------------
 //       818xB AnaParm & AnaParm2 Register
 //----------------------------------------------------------------------------
-//#define ANAPARM_ASIC_ON    0x45090658
-//#define ANAPARM2_ASIC_ON   0x727f3f52
 #define GPI 0x108
-#define GPO 0x109
-#define GPE 0x10a
 #endif