Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: GPL-2.0+ */
0002 /*
0003  * Copyright (C) 2015 Microchip Technology
0004  */
0005 #ifndef _LAN78XX_H
0006 #define _LAN78XX_H
0007 
0008 /* USB Vendor Requests */
0009 #define USB_VENDOR_REQUEST_WRITE_REGISTER   0xA0
0010 #define USB_VENDOR_REQUEST_READ_REGISTER    0xA1
0011 #define USB_VENDOR_REQUEST_GET_STATS        0xA2
0012 
0013 /* Interrupt Endpoint status word bitfields */
0014 #define INT_ENP_EEE_START_TX_LPI_INT        BIT(26)
0015 #define INT_ENP_EEE_STOP_TX_LPI_INT     BIT(25)
0016 #define INT_ENP_EEE_RX_LPI_INT          BIT(24)
0017 #define INT_ENP_RDFO_INT            BIT(22)
0018 #define INT_ENP_TXE_INT             BIT(21)
0019 #define INT_ENP_TX_DIS_INT          BIT(19)
0020 #define INT_ENP_RX_DIS_INT          BIT(18)
0021 #define INT_ENP_PHY_INT             BIT(17)
0022 #define INT_ENP_DP_INT              BIT(16)
0023 #define INT_ENP_MAC_ERR_INT         BIT(15)
0024 #define INT_ENP_TDFU_INT            BIT(14)
0025 #define INT_ENP_TDFO_INT            BIT(13)
0026 #define INT_ENP_UTX_FP_INT          BIT(12)
0027 
0028 #define TX_PKT_ALIGNMENT            4
0029 #define RX_PKT_ALIGNMENT            4
0030 
0031 /* Tx Command A */
0032 #define TX_CMD_A_IGE_           (0x20000000)
0033 #define TX_CMD_A_ICE_           (0x10000000)
0034 #define TX_CMD_A_LSO_           (0x08000000)
0035 #define TX_CMD_A_IPE_           (0x04000000)
0036 #define TX_CMD_A_TPE_           (0x02000000)
0037 #define TX_CMD_A_IVTG_          (0x01000000)
0038 #define TX_CMD_A_RVTG_          (0x00800000)
0039 #define TX_CMD_A_FCS_           (0x00400000)
0040 #define TX_CMD_A_LEN_MASK_      (0x000FFFFF)
0041 
0042 /* Tx Command B */
0043 #define TX_CMD_B_MSS_SHIFT_     (16)
0044 #define TX_CMD_B_MSS_MASK_      (0x3FFF0000)
0045 #define TX_CMD_B_MSS_MIN_       ((unsigned short)8)
0046 #define TX_CMD_B_VTAG_MASK_     (0x0000FFFF)
0047 #define TX_CMD_B_VTAG_PRI_MASK_     (0x0000E000)
0048 #define TX_CMD_B_VTAG_CFI_MASK_     (0x00001000)
0049 #define TX_CMD_B_VTAG_VID_MASK_     (0x00000FFF)
0050 
0051 /* Rx Command A */
0052 #define RX_CMD_A_ICE_           (0x80000000)
0053 #define RX_CMD_A_TCE_           (0x40000000)
0054 #define RX_CMD_A_CSE_MASK_      (0xC0000000)
0055 #define RX_CMD_A_IPV_           (0x20000000)
0056 #define RX_CMD_A_PID_MASK_      (0x18000000)
0057 #define RX_CMD_A_PID_NONE_IP_       (0x00000000)
0058 #define RX_CMD_A_PID_TCP_IP_        (0x08000000)
0059 #define RX_CMD_A_PID_UDP_IP_        (0x10000000)
0060 #define RX_CMD_A_PID_IP_        (0x18000000)
0061 #define RX_CMD_A_PFF_           (0x04000000)
0062 #define RX_CMD_A_BAM_           (0x02000000)
0063 #define RX_CMD_A_MAM_           (0x01000000)
0064 #define RX_CMD_A_FVTG_          (0x00800000)
0065 #define RX_CMD_A_RED_           (0x00400000)
0066 #define RX_CMD_A_RX_ERRS_MASK_      (0xC03F0000)
0067 #define RX_CMD_A_RWT_           (0x00200000)
0068 #define RX_CMD_A_RUNT_          (0x00100000)
0069 #define RX_CMD_A_LONG_          (0x00080000)
0070 #define RX_CMD_A_RXE_           (0x00040000)
0071 #define RX_CMD_A_DRB_           (0x00020000)
0072 #define RX_CMD_A_FCS_           (0x00010000)
0073 #define RX_CMD_A_UAM_           (0x00008000)
0074 #define RX_CMD_A_ICSM_          (0x00004000)
0075 #define RX_CMD_A_LEN_MASK_      (0x00003FFF)
0076 
0077 /* Rx Command B */
0078 #define RX_CMD_B_CSUM_SHIFT_        (16)
0079 #define RX_CMD_B_CSUM_MASK_     (0xFFFF0000)
0080 #define RX_CMD_B_VTAG_MASK_     (0x0000FFFF)
0081 #define RX_CMD_B_VTAG_PRI_MASK_     (0x0000E000)
0082 #define RX_CMD_B_VTAG_CFI_MASK_     (0x00001000)
0083 #define RX_CMD_B_VTAG_VID_MASK_     (0x00000FFF)
0084 
0085 /* Rx Command C */
0086 #define RX_CMD_C_WAKE_SHIFT_        (15)
0087 #define RX_CMD_C_WAKE_          (0x8000)
0088 #define RX_CMD_C_REF_FAIL_SHIFT_    (14)
0089 #define RX_CMD_C_REF_FAIL_      (0x4000)
0090 
0091 /* SCSRs */
0092 #define NUMBER_OF_REGS          (193)
0093 
0094 #define ID_REV              (0x00)
0095 #define ID_REV_CHIP_ID_MASK_        (0xFFFF0000)
0096 #define ID_REV_CHIP_REV_MASK_       (0x0000FFFF)
0097 #define ID_REV_CHIP_ID_7800_        (0x7800)
0098 #define ID_REV_CHIP_ID_7850_        (0x7850)
0099 #define ID_REV_CHIP_ID_7801_        (0x7801)
0100 
0101 #define FPGA_REV            (0x04)
0102 #define FPGA_REV_MINOR_MASK_        (0x0000FF00)
0103 #define FPGA_REV_MAJOR_MASK_        (0x000000FF)
0104 
0105 #define INT_STS             (0x0C)
0106 #define INT_STS_CLEAR_ALL_      (0xFFFFFFFF)
0107 #define INT_STS_EEE_TX_LPI_STRT_    (0x04000000)
0108 #define INT_STS_EEE_TX_LPI_STOP_    (0x02000000)
0109 #define INT_STS_EEE_RX_LPI_     (0x01000000)
0110 #define INT_STS_RDFO_           (0x00400000)
0111 #define INT_STS_TXE_            (0x00200000)
0112 #define INT_STS_TX_DIS_         (0x00080000)
0113 #define INT_STS_RX_DIS_         (0x00040000)
0114 #define INT_STS_PHY_INT_        (0x00020000)
0115 #define INT_STS_DP_INT_         (0x00010000)
0116 #define INT_STS_MAC_ERR_        (0x00008000)
0117 #define INT_STS_TDFU_           (0x00004000)
0118 #define INT_STS_TDFO_           (0x00002000)
0119 #define INT_STS_UFX_FP_         (0x00001000)
0120 #define INT_STS_GPIO_MASK_      (0x00000FFF)
0121 #define INT_STS_GPIO11_         (0x00000800)
0122 #define INT_STS_GPIO10_         (0x00000400)
0123 #define INT_STS_GPIO9_          (0x00000200)
0124 #define INT_STS_GPIO8_          (0x00000100)
0125 #define INT_STS_GPIO7_          (0x00000080)
0126 #define INT_STS_GPIO6_          (0x00000040)
0127 #define INT_STS_GPIO5_          (0x00000020)
0128 #define INT_STS_GPIO4_          (0x00000010)
0129 #define INT_STS_GPIO3_          (0x00000008)
0130 #define INT_STS_GPIO2_          (0x00000004)
0131 #define INT_STS_GPIO1_          (0x00000002)
0132 #define INT_STS_GPIO0_          (0x00000001)
0133 
0134 #define HW_CFG              (0x010)
0135 #define HW_CFG_CLK125_EN_       (0x02000000)
0136 #define HW_CFG_REFCLK25_EN_     (0x01000000)
0137 #define HW_CFG_LED3_EN_         (0x00800000)
0138 #define HW_CFG_LED2_EN_         (0x00400000)
0139 #define HW_CFG_LED1_EN_         (0x00200000)
0140 #define HW_CFG_LED0_EN_         (0x00100000)
0141 #define HW_CFG_EEE_PHY_LUSU_        (0x00020000)
0142 #define HW_CFG_EEE_TSU_         (0x00010000)
0143 #define HW_CFG_NETDET_STS_      (0x00008000)
0144 #define HW_CFG_NETDET_EN_       (0x00004000)
0145 #define HW_CFG_EEM_         (0x00002000)
0146 #define HW_CFG_RST_PROTECT_     (0x00001000)
0147 #define HW_CFG_CONNECT_BUF_     (0x00000400)
0148 #define HW_CFG_CONNECT_EN_      (0x00000200)
0149 #define HW_CFG_CONNECT_POL_     (0x00000100)
0150 #define HW_CFG_SUSPEND_N_SEL_MASK_  (0x000000C0)
0151 #define HW_CFG_SUSPEND_N_SEL_2      (0x00000000)
0152 #define HW_CFG_SUSPEND_N_SEL_12N    (0x00000040)
0153 #define HW_CFG_SUSPEND_N_SEL_012N   (0x00000080)
0154 #define HW_CFG_SUSPEND_N_SEL_0123N  (0x000000C0)
0155 #define HW_CFG_SUSPEND_N_POL_       (0x00000020)
0156 #define HW_CFG_MEF_         (0x00000010)
0157 #define HW_CFG_ETC_         (0x00000008)
0158 #define HW_CFG_LRST_            (0x00000002)
0159 #define HW_CFG_SRST_            (0x00000001)
0160 
0161 #define PMT_CTL             (0x014)
0162 #define PMT_CTL_EEE_WAKEUP_EN_      (0x00002000)
0163 #define PMT_CTL_EEE_WUPS_       (0x00001000)
0164 #define PMT_CTL_MAC_SRST_       (0x00000800)
0165 #define PMT_CTL_PHY_PWRUP_      (0x00000400)
0166 #define PMT_CTL_RES_CLR_WKP_MASK_   (0x00000300)
0167 #define PMT_CTL_RES_CLR_WKP_STS_    (0x00000200)
0168 #define PMT_CTL_RES_CLR_WKP_EN_     (0x00000100)
0169 #define PMT_CTL_READY_          (0x00000080)
0170 #define PMT_CTL_SUS_MODE_MASK_      (0x00000060)
0171 #define PMT_CTL_SUS_MODE_0_     (0x00000000)
0172 #define PMT_CTL_SUS_MODE_1_     (0x00000020)
0173 #define PMT_CTL_SUS_MODE_2_     (0x00000040)
0174 #define PMT_CTL_SUS_MODE_3_     (0x00000060)
0175 #define PMT_CTL_PHY_RST_        (0x00000010)
0176 #define PMT_CTL_WOL_EN_         (0x00000008)
0177 #define PMT_CTL_PHY_WAKE_EN_        (0x00000004)
0178 #define PMT_CTL_WUPS_MASK_      (0x00000003)
0179 #define PMT_CTL_WUPS_MLT_       (0x00000003)
0180 #define PMT_CTL_WUPS_MAC_       (0x00000002)
0181 #define PMT_CTL_WUPS_PHY_       (0x00000001)
0182 
0183 #define GPIO_CFG0           (0x018)
0184 #define GPIO_CFG0_GPIOEN_MASK_      (0x0000F000)
0185 #define GPIO_CFG0_GPIOEN3_      (0x00008000)
0186 #define GPIO_CFG0_GPIOEN2_      (0x00004000)
0187 #define GPIO_CFG0_GPIOEN1_      (0x00002000)
0188 #define GPIO_CFG0_GPIOEN0_      (0x00001000)
0189 #define GPIO_CFG0_GPIOBUF_MASK_     (0x00000F00)
0190 #define GPIO_CFG0_GPIOBUF3_     (0x00000800)
0191 #define GPIO_CFG0_GPIOBUF2_     (0x00000400)
0192 #define GPIO_CFG0_GPIOBUF1_     (0x00000200)
0193 #define GPIO_CFG0_GPIOBUF0_     (0x00000100)
0194 #define GPIO_CFG0_GPIODIR_MASK_     (0x000000F0)
0195 #define GPIO_CFG0_GPIODIR3_     (0x00000080)
0196 #define GPIO_CFG0_GPIODIR2_     (0x00000040)
0197 #define GPIO_CFG0_GPIODIR1_     (0x00000020)
0198 #define GPIO_CFG0_GPIODIR0_     (0x00000010)
0199 #define GPIO_CFG0_GPIOD_MASK_       (0x0000000F)
0200 #define GPIO_CFG0_GPIOD3_       (0x00000008)
0201 #define GPIO_CFG0_GPIOD2_       (0x00000004)
0202 #define GPIO_CFG0_GPIOD1_       (0x00000002)
0203 #define GPIO_CFG0_GPIOD0_       (0x00000001)
0204 
0205 #define GPIO_CFG1           (0x01C)
0206 #define GPIO_CFG1_GPIOEN_MASK_      (0xFF000000)
0207 #define GPIO_CFG1_GPIOEN11_     (0x80000000)
0208 #define GPIO_CFG1_GPIOEN10_     (0x40000000)
0209 #define GPIO_CFG1_GPIOEN9_      (0x20000000)
0210 #define GPIO_CFG1_GPIOEN8_      (0x10000000)
0211 #define GPIO_CFG1_GPIOEN7_      (0x08000000)
0212 #define GPIO_CFG1_GPIOEN6_      (0x04000000)
0213 #define GPIO_CFG1_GPIOEN5_      (0x02000000)
0214 #define GPIO_CFG1_GPIOEN4_      (0x01000000)
0215 #define GPIO_CFG1_GPIOBUF_MASK_     (0x00FF0000)
0216 #define GPIO_CFG1_GPIOBUF11_        (0x00800000)
0217 #define GPIO_CFG1_GPIOBUF10_        (0x00400000)
0218 #define GPIO_CFG1_GPIOBUF9_     (0x00200000)
0219 #define GPIO_CFG1_GPIOBUF8_     (0x00100000)
0220 #define GPIO_CFG1_GPIOBUF7_     (0x00080000)
0221 #define GPIO_CFG1_GPIOBUF6_     (0x00040000)
0222 #define GPIO_CFG1_GPIOBUF5_     (0x00020000)
0223 #define GPIO_CFG1_GPIOBUF4_     (0x00010000)
0224 #define GPIO_CFG1_GPIODIR_MASK_     (0x0000FF00)
0225 #define GPIO_CFG1_GPIODIR11_        (0x00008000)
0226 #define GPIO_CFG1_GPIODIR10_        (0x00004000)
0227 #define GPIO_CFG1_GPIODIR9_     (0x00002000)
0228 #define GPIO_CFG1_GPIODIR8_     (0x00001000)
0229 #define GPIO_CFG1_GPIODIR7_     (0x00000800)
0230 #define GPIO_CFG1_GPIODIR6_     (0x00000400)
0231 #define GPIO_CFG1_GPIODIR5_     (0x00000200)
0232 #define GPIO_CFG1_GPIODIR4_     (0x00000100)
0233 #define GPIO_CFG1_GPIOD_MASK_       (0x000000FF)
0234 #define GPIO_CFG1_GPIOD11_      (0x00000080)
0235 #define GPIO_CFG1_GPIOD10_      (0x00000040)
0236 #define GPIO_CFG1_GPIOD9_       (0x00000020)
0237 #define GPIO_CFG1_GPIOD8_       (0x00000010)
0238 #define GPIO_CFG1_GPIOD7_       (0x00000008)
0239 #define GPIO_CFG1_GPIOD6_       (0x00000004)
0240 #define GPIO_CFG1_GPIOD6_       (0x00000004)
0241 #define GPIO_CFG1_GPIOD5_       (0x00000002)
0242 #define GPIO_CFG1_GPIOD4_       (0x00000001)
0243 
0244 #define GPIO_WAKE           (0x020)
0245 #define GPIO_WAKE_GPIOPOL_MASK_     (0x0FFF0000)
0246 #define GPIO_WAKE_GPIOPOL11_        (0x08000000)
0247 #define GPIO_WAKE_GPIOPOL10_        (0x04000000)
0248 #define GPIO_WAKE_GPIOPOL9_     (0x02000000)
0249 #define GPIO_WAKE_GPIOPOL8_     (0x01000000)
0250 #define GPIO_WAKE_GPIOPOL7_     (0x00800000)
0251 #define GPIO_WAKE_GPIOPOL6_     (0x00400000)
0252 #define GPIO_WAKE_GPIOPOL5_     (0x00200000)
0253 #define GPIO_WAKE_GPIOPOL4_     (0x00100000)
0254 #define GPIO_WAKE_GPIOPOL3_     (0x00080000)
0255 #define GPIO_WAKE_GPIOPOL2_     (0x00040000)
0256 #define GPIO_WAKE_GPIOPOL1_     (0x00020000)
0257 #define GPIO_WAKE_GPIOPOL0_     (0x00010000)
0258 #define GPIO_WAKE_GPIOWK_MASK_      (0x00000FFF)
0259 #define GPIO_WAKE_GPIOWK11_     (0x00000800)
0260 #define GPIO_WAKE_GPIOWK10_     (0x00000400)
0261 #define GPIO_WAKE_GPIOWK9_      (0x00000200)
0262 #define GPIO_WAKE_GPIOWK8_      (0x00000100)
0263 #define GPIO_WAKE_GPIOWK7_      (0x00000080)
0264 #define GPIO_WAKE_GPIOWK6_      (0x00000040)
0265 #define GPIO_WAKE_GPIOWK5_      (0x00000020)
0266 #define GPIO_WAKE_GPIOWK4_      (0x00000010)
0267 #define GPIO_WAKE_GPIOWK3_      (0x00000008)
0268 #define GPIO_WAKE_GPIOWK2_      (0x00000004)
0269 #define GPIO_WAKE_GPIOWK1_      (0x00000002)
0270 #define GPIO_WAKE_GPIOWK0_      (0x00000001)
0271 
0272 #define DP_SEL              (0x024)
0273 #define DP_SEL_DPRDY_           (0x80000000)
0274 #define DP_SEL_RSEL_MASK_       (0x0000000F)
0275 #define DP_SEL_RSEL_USB_PHY_CSRS_   (0x0000000F)
0276 #define DP_SEL_RSEL_OTP_64BIT_      (0x00000009)
0277 #define DP_SEL_RSEL_OTP_8BIT_       (0x00000008)
0278 #define DP_SEL_RSEL_UTX_BUF_RAM_    (0x00000007)
0279 #define DP_SEL_RSEL_DESC_RAM_       (0x00000005)
0280 #define DP_SEL_RSEL_TXFIFO_     (0x00000004)
0281 #define DP_SEL_RSEL_RXFIFO_     (0x00000003)
0282 #define DP_SEL_RSEL_LSO_        (0x00000002)
0283 #define DP_SEL_RSEL_VLAN_DA_        (0x00000001)
0284 #define DP_SEL_RSEL_URXBUF_     (0x00000000)
0285 #define DP_SEL_VHF_HASH_LEN     (16)
0286 #define DP_SEL_VHF_VLAN_LEN     (128)
0287 
0288 #define DP_CMD              (0x028)
0289 #define DP_CMD_WRITE_           (0x00000001)
0290 #define DP_CMD_READ_            (0x00000000)
0291 
0292 #define DP_ADDR             (0x02C)
0293 #define DP_ADDR_MASK_           (0x00003FFF)
0294 
0295 #define DP_DATA             (0x030)
0296 
0297 #define E2P_CMD             (0x040)
0298 #define E2P_CMD_EPC_BUSY_       (0x80000000)
0299 #define E2P_CMD_EPC_CMD_MASK_       (0x70000000)
0300 #define E2P_CMD_EPC_CMD_RELOAD_     (0x70000000)
0301 #define E2P_CMD_EPC_CMD_ERAL_       (0x60000000)
0302 #define E2P_CMD_EPC_CMD_ERASE_      (0x50000000)
0303 #define E2P_CMD_EPC_CMD_WRAL_       (0x40000000)
0304 #define E2P_CMD_EPC_CMD_WRITE_      (0x30000000)
0305 #define E2P_CMD_EPC_CMD_EWEN_       (0x20000000)
0306 #define E2P_CMD_EPC_CMD_EWDS_       (0x10000000)
0307 #define E2P_CMD_EPC_CMD_READ_       (0x00000000)
0308 #define E2P_CMD_EPC_TIMEOUT_        (0x00000400)
0309 #define E2P_CMD_EPC_DL_         (0x00000200)
0310 #define E2P_CMD_EPC_ADDR_MASK_      (0x000001FF)
0311 
0312 #define E2P_DATA            (0x044)
0313 #define E2P_DATA_EEPROM_DATA_MASK_  (0x000000FF)
0314 
0315 #define BOS_ATTR            (0x050)
0316 #define BOS_ATTR_BLOCK_SIZE_MASK_   (0x000000FF)
0317 
0318 #define SS_ATTR             (0x054)
0319 #define SS_ATTR_POLL_INT_MASK_      (0x00FF0000)
0320 #define SS_ATTR_DEV_DESC_SIZE_MASK_ (0x0000FF00)
0321 #define SS_ATTR_CFG_BLK_SIZE_MASK_  (0x000000FF)
0322 
0323 #define HS_ATTR             (0x058)
0324 #define HS_ATTR_POLL_INT_MASK_      (0x00FF0000)
0325 #define HS_ATTR_DEV_DESC_SIZE_MASK_ (0x0000FF00)
0326 #define HS_ATTR_CFG_BLK_SIZE_MASK_  (0x000000FF)
0327 
0328 #define FS_ATTR             (0x05C)
0329 #define FS_ATTR_POLL_INT_MASK_      (0x00FF0000)
0330 #define FS_ATTR_DEV_DESC_SIZE_MASK_ (0x0000FF00)
0331 #define FS_ATTR_CFG_BLK_SIZE_MASK_  (0x000000FF)
0332 
0333 #define STR_ATTR0               (0x060)
0334 #define STR_ATTR0_CFGSTR_DESC_SIZE_MASK_    (0xFF000000)
0335 #define STR_ATTR0_SERSTR_DESC_SIZE_MASK_    (0x00FF0000)
0336 #define STR_ATTR0_PRODSTR_DESC_SIZE_MASK_   (0x0000FF00)
0337 #define STR_ATTR0_MANUF_DESC_SIZE_MASK_     (0x000000FF)
0338 
0339 #define STR_ATTR1               (0x064)
0340 #define STR_ATTR1_INTSTR_DESC_SIZE_MASK_    (0x000000FF)
0341 
0342 #define STR_FLAG_ATTR               (0x068)
0343 #define STR_FLAG_ATTR_PME_FLAGS_MASK_       (0x000000FF)
0344 
0345 #define USB_CFG0            (0x080)
0346 #define USB_CFG_LPM_RESPONSE_       (0x80000000)
0347 #define USB_CFG_LPM_CAPABILITY_     (0x40000000)
0348 #define USB_CFG_LPM_ENBL_SLPM_      (0x20000000)
0349 #define USB_CFG_HIRD_THR_MASK_      (0x1F000000)
0350 #define USB_CFG_HIRD_THR_960_       (0x1C000000)
0351 #define USB_CFG_HIRD_THR_885_       (0x1B000000)
0352 #define USB_CFG_HIRD_THR_810_       (0x1A000000)
0353 #define USB_CFG_HIRD_THR_735_       (0x19000000)
0354 #define USB_CFG_HIRD_THR_660_       (0x18000000)
0355 #define USB_CFG_HIRD_THR_585_       (0x17000000)
0356 #define USB_CFG_HIRD_THR_510_       (0x16000000)
0357 #define USB_CFG_HIRD_THR_435_       (0x15000000)
0358 #define USB_CFG_HIRD_THR_360_       (0x14000000)
0359 #define USB_CFG_HIRD_THR_285_       (0x13000000)
0360 #define USB_CFG_HIRD_THR_210_       (0x12000000)
0361 #define USB_CFG_HIRD_THR_135_       (0x11000000)
0362 #define USB_CFG_HIRD_THR_60_        (0x10000000)
0363 #define USB_CFG_MAX_BURST_BI_MASK_  (0x00F00000)
0364 #define USB_CFG_MAX_BURST_BO_MASK_  (0x000F0000)
0365 #define USB_CFG_MAX_DEV_SPEED_MASK_ (0x0000E000)
0366 #define USB_CFG_MAX_DEV_SPEED_SS_   (0x00008000)
0367 #define USB_CFG_MAX_DEV_SPEED_HS_   (0x00000000)
0368 #define USB_CFG_MAX_DEV_SPEED_FS_   (0x00002000)
0369 #define USB_CFG_PHY_BOOST_MASK_     (0x00000180)
0370 #define USB_CFG_PHY_BOOST_PLUS_12_  (0x00000180)
0371 #define USB_CFG_PHY_BOOST_PLUS_8_   (0x00000100)
0372 #define USB_CFG_PHY_BOOST_PLUS_4_   (0x00000080)
0373 #define USB_CFG_PHY_BOOST_NORMAL_   (0x00000000)
0374 #define USB_CFG_BIR_            (0x00000040)
0375 #define USB_CFG_BCE_            (0x00000020)
0376 #define USB_CFG_PORT_SWAP_      (0x00000010)
0377 #define USB_CFG_LPM_EN_         (0x00000008)
0378 #define USB_CFG_RMT_WKP_        (0x00000004)
0379 #define USB_CFG_PWR_SEL_        (0x00000002)
0380 #define USB_CFG_STALL_BO_DIS_       (0x00000001)
0381 
0382 #define USB_CFG1            (0x084)
0383 #define USB_CFG1_U1_TIMEOUT_MASK_   (0xFF000000)
0384 #define USB_CFG1_U2_TIMEOUT_MASK_   (0x00FF0000)
0385 #define USB_CFG1_HS_TOUT_CAL_MASK_  (0x0000E000)
0386 #define USB_CFG1_DEV_U2_INIT_EN_    (0x00001000)
0387 #define USB_CFG1_DEV_U2_EN_     (0x00000800)
0388 #define USB_CFG1_DEV_U1_INIT_EN_    (0x00000400)
0389 #define USB_CFG1_DEV_U1_EN_     (0x00000200)
0390 #define USB_CFG1_LTM_ENABLE_        (0x00000100)
0391 #define USB_CFG1_FS_TOUT_CAL_MASK_  (0x00000070)
0392 #define USB_CFG1_SCALE_DOWN_MASK_   (0x00000003)
0393 #define USB_CFG1_SCALE_DOWN_MODE3_  (0x00000003)
0394 #define USB_CFG1_SCALE_DOWN_MODE2_  (0x00000002)
0395 #define USB_CFG1_SCALE_DOWN_MODE1_  (0x00000001)
0396 #define USB_CFG1_SCALE_DOWN_MODE0_  (0x00000000)
0397 
0398 #define USB_CFG2                (0x088)
0399 #define USB_CFG2_SS_DETACH_TIME_MASK_       (0xFFFF0000)
0400 #define USB_CFG2_HS_DETACH_TIME_MASK_       (0x0000FFFF)
0401 
0402 #define BURST_CAP           (0x090)
0403 #define BURST_CAP_SIZE_MASK_        (0x000000FF)
0404 
0405 #define BULK_IN_DLY         (0x094)
0406 #define BULK_IN_DLY_MASK_       (0x0000FFFF)
0407 
0408 #define INT_EP_CTL          (0x098)
0409 #define INT_EP_INTEP_ON_        (0x80000000)
0410 #define INT_STS_EEE_TX_LPI_STRT_EN_ (0x04000000)
0411 #define INT_STS_EEE_TX_LPI_STOP_EN_ (0x02000000)
0412 #define INT_STS_EEE_RX_LPI_EN_      (0x01000000)
0413 #define INT_EP_RDFO_EN_         (0x00400000)
0414 #define INT_EP_TXE_EN_          (0x00200000)
0415 #define INT_EP_TX_DIS_EN_       (0x00080000)
0416 #define INT_EP_RX_DIS_EN_       (0x00040000)
0417 #define INT_EP_PHY_INT_EN_      (0x00020000)
0418 #define INT_EP_DP_INT_EN_       (0x00010000)
0419 #define INT_EP_MAC_ERR_EN_      (0x00008000)
0420 #define INT_EP_TDFU_EN_         (0x00004000)
0421 #define INT_EP_TDFO_EN_         (0x00002000)
0422 #define INT_EP_UTX_FP_EN_       (0x00001000)
0423 #define INT_EP_GPIO_EN_MASK_        (0x00000FFF)
0424 
0425 #define PIPE_CTL            (0x09C)
0426 #define PIPE_CTL_TXSWING_       (0x00000040)
0427 #define PIPE_CTL_TXMARGIN_MASK_     (0x00000038)
0428 #define PIPE_CTL_TXDEEMPHASIS_MASK_ (0x00000006)
0429 #define PIPE_CTL_ELASTICITYBUFFERMODE_  (0x00000001)
0430 
0431 #define U1_LATENCY          (0xA0)
0432 #define U2_LATENCY          (0xA4)
0433 
0434 #define USB_STATUS          (0x0A8)
0435 #define USB_STATUS_REMOTE_WK_       (0x00100000)
0436 #define USB_STATUS_FUNC_REMOTE_WK_  (0x00080000)
0437 #define USB_STATUS_LTM_ENABLE_      (0x00040000)
0438 #define USB_STATUS_U2_ENABLE_       (0x00020000)
0439 #define USB_STATUS_U1_ENABLE_       (0x00010000)
0440 #define USB_STATUS_SET_SEL_     (0x00000020)
0441 #define USB_STATUS_REMOTE_WK_STS_   (0x00000010)
0442 #define USB_STATUS_FUNC_REMOTE_WK_STS_  (0x00000008)
0443 #define USB_STATUS_LTM_ENABLE_STS_  (0x00000004)
0444 #define USB_STATUS_U2_ENABLE_STS_   (0x00000002)
0445 #define USB_STATUS_U1_ENABLE_STS_   (0x00000001)
0446 
0447 #define USB_CFG3            (0x0AC)
0448 #define USB_CFG3_EN_U2_LTM_     (0x40000000)
0449 #define USB_CFG3_BULK_OUT_NUMP_OVR_ (0x20000000)
0450 #define USB_CFG3_DIS_FAST_U1_EXIT_  (0x10000000)
0451 #define USB_CFG3_LPM_NYET_THR_      (0x0F000000)
0452 #define USB_CFG3_RX_DET_2_POL_LFPS_ (0x00800000)
0453 #define USB_CFG3_LFPS_FILT_     (0x00400000)
0454 #define USB_CFG3_SKIP_RX_DET_       (0x00200000)
0455 #define USB_CFG3_DELAY_P1P2P3_      (0x001C0000)
0456 #define USB_CFG3_DELAY_PHY_PWR_CHG_ (0x00020000)
0457 #define USB_CFG3_U1U2_EXIT_FR_      (0x00010000)
0458 #define USB_CFG3_REQ_P1P2P3     (0x00008000)
0459 #define USB_CFG3_HST_PRT_CMPL_      (0x00004000)
0460 #define USB_CFG3_DIS_SCRAMB_        (0x00002000)
0461 #define USB_CFG3_PWR_DN_SCALE_      (0x00001FFF)
0462 
0463 #define RFE_CTL             (0x0B0)
0464 #define RFE_CTL_IGMP_COE_       (0x00004000)
0465 #define RFE_CTL_ICMP_COE_       (0x00002000)
0466 #define RFE_CTL_TCPUDP_COE_     (0x00001000)
0467 #define RFE_CTL_IP_COE_         (0x00000800)
0468 #define RFE_CTL_BCAST_EN_       (0x00000400)
0469 #define RFE_CTL_MCAST_EN_       (0x00000200)
0470 #define RFE_CTL_UCAST_EN_       (0x00000100)
0471 #define RFE_CTL_VLAN_STRIP_     (0x00000080)
0472 #define RFE_CTL_DISCARD_UNTAGGED_   (0x00000040)
0473 #define RFE_CTL_VLAN_FILTER_        (0x00000020)
0474 #define RFE_CTL_SA_FILTER_      (0x00000010)
0475 #define RFE_CTL_MCAST_HASH_     (0x00000008)
0476 #define RFE_CTL_DA_HASH_        (0x00000004)
0477 #define RFE_CTL_DA_PERFECT_     (0x00000002)
0478 #define RFE_CTL_RST_            (0x00000001)
0479 
0480 #define VLAN_TYPE           (0x0B4)
0481 #define VLAN_TYPE_MASK_         (0x0000FFFF)
0482 
0483 #define FCT_RX_CTL          (0x0C0)
0484 #define FCT_RX_CTL_EN_          (0x80000000)
0485 #define FCT_RX_CTL_RST_         (0x40000000)
0486 #define FCT_RX_CTL_SBF_         (0x02000000)
0487 #define FCT_RX_CTL_OVFL_        (0x01000000)
0488 #define FCT_RX_CTL_DROP_        (0x00800000)
0489 #define FCT_RX_CTL_NOT_EMPTY_       (0x00400000)
0490 #define FCT_RX_CTL_EMPTY_       (0x00200000)
0491 #define FCT_RX_CTL_DIS_         (0x00100000)
0492 #define FCT_RX_CTL_USED_MASK_       (0x0000FFFF)
0493 
0494 #define FCT_TX_CTL          (0x0C4)
0495 #define FCT_TX_CTL_EN_          (0x80000000)
0496 #define FCT_TX_CTL_RST_         (0x40000000)
0497 #define FCT_TX_CTL_NOT_EMPTY_       (0x00400000)
0498 #define FCT_TX_CTL_EMPTY_       (0x00200000)
0499 #define FCT_TX_CTL_DIS_         (0x00100000)
0500 #define FCT_TX_CTL_USED_MASK_       (0x0000FFFF)
0501 
0502 #define FCT_RX_FIFO_END         (0x0C8)
0503 #define FCT_RX_FIFO_END_MASK_       (0x0000007F)
0504 
0505 #define FCT_TX_FIFO_END         (0x0CC)
0506 #define FCT_TX_FIFO_END_MASK_       (0x0000003F)
0507 
0508 #define FCT_FLOW            (0x0D0)
0509 #define FCT_FLOW_OFF_MASK_      (0x00007F00)
0510 #define FCT_FLOW_ON_MASK_       (0x0000007F)
0511 
0512 #define RX_DP_STOR          (0x0D4)
0513 #define RX_DP_STORE_TOT_RXUSED_MASK_    (0xFFFF0000)
0514 #define RX_DP_STORE_UTX_RXUSED_MASK_    (0x0000FFFF)
0515 
0516 #define TX_DP_STOR          (0x0D8)
0517 #define TX_DP_STORE_TOT_TXUSED_MASK_    (0xFFFF0000)
0518 #define TX_DP_STORE_URX_TXUSED_MASK_    (0x0000FFFF)
0519 
0520 #define LTM_BELT_IDLE0          (0x0E0)
0521 #define LTM_BELT_IDLE0_IDLE1000_    (0x0FFF0000)
0522 #define LTM_BELT_IDLE0_IDLE100_     (0x00000FFF)
0523 
0524 #define LTM_BELT_IDLE1          (0x0E4)
0525 #define LTM_BELT_IDLE1_IDLE10_      (0x00000FFF)
0526 
0527 #define LTM_BELT_ACT0           (0x0E8)
0528 #define LTM_BELT_ACT0_ACT1000_      (0x0FFF0000)
0529 #define LTM_BELT_ACT0_ACT100_       (0x00000FFF)
0530 
0531 #define LTM_BELT_ACT1           (0x0EC)
0532 #define LTM_BELT_ACT1_ACT10_        (0x00000FFF)
0533 
0534 #define LTM_INACTIVE0           (0x0F0)
0535 #define LTM_INACTIVE0_TIMER1000_    (0xFFFF0000)
0536 #define LTM_INACTIVE0_TIMER100_     (0x0000FFFF)
0537 
0538 #define LTM_INACTIVE1           (0x0F4)
0539 #define LTM_INACTIVE1_TIMER10_      (0x0000FFFF)
0540 
0541 #define MAC_CR              (0x100)
0542 #define MAC_CR_GMII_EN_         (0x00080000)
0543 #define MAC_CR_EEE_TX_CLK_STOP_EN_  (0x00040000)
0544 #define MAC_CR_EEE_EN_          (0x00020000)
0545 #define MAC_CR_EEE_TLAR_EN_     (0x00010000)
0546 #define MAC_CR_ADP_         (0x00002000)
0547 #define MAC_CR_AUTO_DUPLEX_     (0x00001000)
0548 #define MAC_CR_AUTO_SPEED_      (0x00000800)
0549 #define MAC_CR_LOOPBACK_        (0x00000400)
0550 #define MAC_CR_BOLMT_MASK_      (0x000000C0)
0551 #define MAC_CR_FULL_DUPLEX_     (0x00000008)
0552 #define MAC_CR_SPEED_MASK_      (0x00000006)
0553 #define MAC_CR_SPEED_1000_      (0x00000004)
0554 #define MAC_CR_SPEED_100_       (0x00000002)
0555 #define MAC_CR_SPEED_10_        (0x00000000)
0556 #define MAC_CR_RST_         (0x00000001)
0557 
0558 #define MAC_RX              (0x104)
0559 #define MAC_RX_MAX_SIZE_SHIFT_      (16)
0560 #define MAC_RX_MAX_SIZE_MASK_       (0x3FFF0000)
0561 #define MAC_RX_FCS_STRIP_       (0x00000010)
0562 #define MAC_RX_VLAN_FSE_        (0x00000004)
0563 #define MAC_RX_RXD_         (0x00000002)
0564 #define MAC_RX_RXEN_            (0x00000001)
0565 
0566 #define MAC_TX              (0x108)
0567 #define MAC_TX_BAD_FCS_         (0x00000004)
0568 #define MAC_TX_TXD_         (0x00000002)
0569 #define MAC_TX_TXEN_            (0x00000001)
0570 
0571 #define FLOW                (0x10C)
0572 #define FLOW_CR_FORCE_FC_       (0x80000000)
0573 #define FLOW_CR_TX_FCEN_        (0x40000000)
0574 #define FLOW_CR_RX_FCEN_        (0x20000000)
0575 #define FLOW_CR_FPF_            (0x10000000)
0576 #define FLOW_CR_FCPT_MASK_      (0x0000FFFF)
0577 
0578 #define RAND_SEED           (0x110)
0579 #define RAND_SEED_MASK_         (0x0000FFFF)
0580 
0581 #define ERR_STS             (0x114)
0582 #define ERR_STS_FERR_           (0x00000100)
0583 #define ERR_STS_LERR_           (0x00000080)
0584 #define ERR_STS_RFERR_          (0x00000040)
0585 #define ERR_STS_ECERR_          (0x00000010)
0586 #define ERR_STS_ALERR_          (0x00000008)
0587 #define ERR_STS_URERR_          (0x00000004)
0588 
0589 #define RX_ADDRH            (0x118)
0590 #define RX_ADDRH_MASK_          (0x0000FFFF)
0591 
0592 #define RX_ADDRL            (0x11C)
0593 #define RX_ADDRL_MASK_          (0xFFFFFFFF)
0594 
0595 #define MII_ACC             (0x120)
0596 #define MII_ACC_PHY_ADDR_SHIFT_     (11)
0597 #define MII_ACC_PHY_ADDR_MASK_      (0x0000F800)
0598 #define MII_ACC_MIIRINDA_SHIFT_     (6)
0599 #define MII_ACC_MIIRINDA_MASK_      (0x000007C0)
0600 #define MII_ACC_MII_READ_       (0x00000000)
0601 #define MII_ACC_MII_WRITE_      (0x00000002)
0602 #define MII_ACC_MII_BUSY_       (0x00000001)
0603 
0604 #define MII_DATA            (0x124)
0605 #define MII_DATA_MASK_          (0x0000FFFF)
0606 
0607 #define MAC_RGMII_ID            (0x128)
0608 #define MAC_RGMII_ID_TXC_DELAY_EN_  (0x00000002)
0609 #define MAC_RGMII_ID_RXC_DELAY_EN_  (0x00000001)
0610 
0611 #define EEE_TX_LPI_REQ_DLY      (0x130)
0612 #define EEE_TX_LPI_REQ_DLY_CNT_MASK_    (0xFFFFFFFF)
0613 
0614 #define EEE_TW_TX_SYS           (0x134)
0615 #define EEE_TW_TX_SYS_CNT1G_MASK_   (0xFFFF0000)
0616 #define EEE_TW_TX_SYS_CNT100M_MASK_ (0x0000FFFF)
0617 
0618 #define EEE_TX_LPI_REM_DLY      (0x138)
0619 #define EEE_TX_LPI_REM_DLY_CNT_     (0x00FFFFFF)
0620 
0621 #define WUCSR               (0x140)
0622 #define WUCSR_TESTMODE_         (0x80000000)
0623 #define WUCSR_RFE_WAKE_EN_      (0x00004000)
0624 #define WUCSR_EEE_TX_WAKE_      (0x00002000)
0625 #define WUCSR_EEE_TX_WAKE_EN_       (0x00001000)
0626 #define WUCSR_EEE_RX_WAKE_      (0x00000800)
0627 #define WUCSR_EEE_RX_WAKE_EN_       (0x00000400)
0628 #define WUCSR_RFE_WAKE_FR_      (0x00000200)
0629 #define WUCSR_STORE_WAKE_       (0x00000100)
0630 #define WUCSR_PFDA_FR_          (0x00000080)
0631 #define WUCSR_WUFR_         (0x00000040)
0632 #define WUCSR_MPR_          (0x00000020)
0633 #define WUCSR_BCST_FR_          (0x00000010)
0634 #define WUCSR_PFDA_EN_          (0x00000008)
0635 #define WUCSR_WAKE_EN_          (0x00000004)
0636 #define WUCSR_MPEN_         (0x00000002)
0637 #define WUCSR_BCST_EN_          (0x00000001)
0638 
0639 #define WK_SRC              (0x144)
0640 #define WK_SRC_GPIOX_INT_WK_SHIFT_  (20)
0641 #define WK_SRC_GPIOX_INT_WK_MASK_   (0xFFF00000)
0642 #define WK_SRC_IPV6_TCPSYN_RCD_WK_  (0x00010000)
0643 #define WK_SRC_IPV4_TCPSYN_RCD_WK_  (0x00008000)
0644 #define WK_SRC_EEE_TX_WK_       (0x00004000)
0645 #define WK_SRC_EEE_RX_WK_       (0x00002000)
0646 #define WK_SRC_GOOD_FR_WK_      (0x00001000)
0647 #define WK_SRC_PFDA_FR_WK_      (0x00000800)
0648 #define WK_SRC_MP_FR_WK_        (0x00000400)
0649 #define WK_SRC_BCAST_FR_WK_     (0x00000200)
0650 #define WK_SRC_WU_FR_WK_        (0x00000100)
0651 #define WK_SRC_WUFF_MATCH_MASK_     (0x0000001F)
0652 
0653 #define WUF_CFG0            (0x150)
0654 #define NUM_OF_WUF_CFG          (32)
0655 #define WUF_CFG_BEGIN           (WUF_CFG0)
0656 #define WUF_CFG(index)          (WUF_CFG_BEGIN + (4 * (index)))
0657 #define WUF_CFGX_EN_            (0x80000000)
0658 #define WUF_CFGX_TYPE_MASK_     (0x03000000)
0659 #define WUF_CFGX_TYPE_MCAST_        (0x02000000)
0660 #define WUF_CFGX_TYPE_ALL_      (0x01000000)
0661 #define WUF_CFGX_TYPE_UCAST_        (0x00000000)
0662 #define WUF_CFGX_OFFSET_SHIFT_      (16)
0663 #define WUF_CFGX_OFFSET_MASK_       (0x00FF0000)
0664 #define WUF_CFGX_CRC16_MASK_        (0x0000FFFF)
0665 
0666 #define WUF_MASK0_0         (0x200)
0667 #define WUF_MASK0_1         (0x204)
0668 #define WUF_MASK0_2         (0x208)
0669 #define WUF_MASK0_3         (0x20C)
0670 #define NUM_OF_WUF_MASK         (32)
0671 #define WUF_MASK0_BEGIN         (WUF_MASK0_0)
0672 #define WUF_MASK1_BEGIN         (WUF_MASK0_1)
0673 #define WUF_MASK2_BEGIN         (WUF_MASK0_2)
0674 #define WUF_MASK3_BEGIN         (WUF_MASK0_3)
0675 #define WUF_MASK0(index)        (WUF_MASK0_BEGIN + (0x10 * (index)))
0676 #define WUF_MASK1(index)        (WUF_MASK1_BEGIN + (0x10 * (index)))
0677 #define WUF_MASK2(index)        (WUF_MASK2_BEGIN + (0x10 * (index)))
0678 #define WUF_MASK3(index)        (WUF_MASK3_BEGIN + (0x10 * (index)))
0679 
0680 #define MAF_BASE            (0x400)
0681 #define MAF_HIX             (0x00)
0682 #define MAF_LOX             (0x04)
0683 #define NUM_OF_MAF          (33)
0684 #define MAF_HI_BEGIN            (MAF_BASE + MAF_HIX)
0685 #define MAF_LO_BEGIN            (MAF_BASE + MAF_LOX)
0686 #define MAF_HI(index)           (MAF_BASE + (8 * (index)) + (MAF_HIX))
0687 #define MAF_LO(index)           (MAF_BASE + (8 * (index)) + (MAF_LOX))
0688 #define MAF_HI_VALID_           (0x80000000)
0689 #define MAF_HI_TYPE_MASK_       (0x40000000)
0690 #define MAF_HI_TYPE_SRC_        (0x40000000)
0691 #define MAF_HI_TYPE_DST_        (0x00000000)
0692 #define MAF_HI_ADDR_MASK        (0x0000FFFF)
0693 #define MAF_LO_ADDR_MASK        (0xFFFFFFFF)
0694 
0695 #define WUCSR2              (0x600)
0696 #define WUCSR2_CSUM_DISABLE_        (0x80000000)
0697 #define WUCSR2_NA_SA_SEL_       (0x00000100)
0698 #define WUCSR2_NS_RCD_          (0x00000080)
0699 #define WUCSR2_ARP_RCD_         (0x00000040)
0700 #define WUCSR2_IPV6_TCPSYN_RCD_     (0x00000020)
0701 #define WUCSR2_IPV4_TCPSYN_RCD_     (0x00000010)
0702 #define WUCSR2_NS_OFFLOAD_EN_       (0x00000008)
0703 #define WUCSR2_ARP_OFFLOAD_EN_      (0x00000004)
0704 #define WUCSR2_IPV6_TCPSYN_WAKE_EN_ (0x00000002)
0705 #define WUCSR2_IPV4_TCPSYN_WAKE_EN_ (0x00000001)
0706 
0707 #define NS1_IPV6_ADDR_DEST0     (0x610)
0708 #define NS1_IPV6_ADDR_DEST1     (0x614)
0709 #define NS1_IPV6_ADDR_DEST2     (0x618)
0710 #define NS1_IPV6_ADDR_DEST3     (0x61C)
0711 
0712 #define NS1_IPV6_ADDR_SRC0      (0x620)
0713 #define NS1_IPV6_ADDR_SRC1      (0x624)
0714 #define NS1_IPV6_ADDR_SRC2      (0x628)
0715 #define NS1_IPV6_ADDR_SRC3      (0x62C)
0716 
0717 #define NS1_ICMPV6_ADDR0_0      (0x630)
0718 #define NS1_ICMPV6_ADDR0_1      (0x634)
0719 #define NS1_ICMPV6_ADDR0_2      (0x638)
0720 #define NS1_ICMPV6_ADDR0_3      (0x63C)
0721 
0722 #define NS1_ICMPV6_ADDR1_0      (0x640)
0723 #define NS1_ICMPV6_ADDR1_1      (0x644)
0724 #define NS1_ICMPV6_ADDR1_2      (0x648)
0725 #define NS1_ICMPV6_ADDR1_3      (0x64C)
0726 
0727 #define NS2_IPV6_ADDR_DEST0     (0x650)
0728 #define NS2_IPV6_ADDR_DEST1     (0x654)
0729 #define NS2_IPV6_ADDR_DEST2     (0x658)
0730 #define NS2_IPV6_ADDR_DEST3     (0x65C)
0731 
0732 #define NS2_IPV6_ADDR_SRC0      (0x660)
0733 #define NS2_IPV6_ADDR_SRC1      (0x664)
0734 #define NS2_IPV6_ADDR_SRC2      (0x668)
0735 #define NS2_IPV6_ADDR_SRC3      (0x66C)
0736 
0737 #define NS2_ICMPV6_ADDR0_0      (0x670)
0738 #define NS2_ICMPV6_ADDR0_1      (0x674)
0739 #define NS2_ICMPV6_ADDR0_2      (0x678)
0740 #define NS2_ICMPV6_ADDR0_3      (0x67C)
0741 
0742 #define NS2_ICMPV6_ADDR1_0      (0x680)
0743 #define NS2_ICMPV6_ADDR1_1      (0x684)
0744 #define NS2_ICMPV6_ADDR1_2      (0x688)
0745 #define NS2_ICMPV6_ADDR1_3      (0x68C)
0746 
0747 #define SYN_IPV4_ADDR_SRC       (0x690)
0748 #define SYN_IPV4_ADDR_DEST      (0x694)
0749 #define SYN_IPV4_TCP_PORTS      (0x698)
0750 #define SYN_IPV4_TCP_PORTS_IPV4_DEST_PORT_SHIFT_    (16)
0751 #define SYN_IPV4_TCP_PORTS_IPV4_DEST_PORT_MASK_     (0xFFFF0000)
0752 #define SYN_IPV4_TCP_PORTS_IPV4_SRC_PORT_MASK_      (0x0000FFFF)
0753 
0754 #define SYN_IPV6_ADDR_SRC0      (0x69C)
0755 #define SYN_IPV6_ADDR_SRC1      (0x6A0)
0756 #define SYN_IPV6_ADDR_SRC2      (0x6A4)
0757 #define SYN_IPV6_ADDR_SRC3      (0x6A8)
0758 
0759 #define SYN_IPV6_ADDR_DEST0     (0x6AC)
0760 #define SYN_IPV6_ADDR_DEST1     (0x6B0)
0761 #define SYN_IPV6_ADDR_DEST2     (0x6B4)
0762 #define SYN_IPV6_ADDR_DEST3     (0x6B8)
0763 
0764 #define SYN_IPV6_TCP_PORTS      (0x6BC)
0765 #define SYN_IPV6_TCP_PORTS_IPV6_DEST_PORT_SHIFT_    (16)
0766 #define SYN_IPV6_TCP_PORTS_IPV6_DEST_PORT_MASK_     (0xFFFF0000)
0767 #define SYN_IPV6_TCP_PORTS_IPV6_SRC_PORT_MASK_      (0x0000FFFF)
0768 
0769 #define ARP_SPA             (0x6C0)
0770 #define ARP_TPA             (0x6C4)
0771 
0772 #define PHY_DEV_ID          (0x700)
0773 #define PHY_DEV_ID_REV_SHIFT_       (28)
0774 #define PHY_DEV_ID_REV_SHIFT_       (28)
0775 #define PHY_DEV_ID_REV_MASK_        (0xF0000000)
0776 #define PHY_DEV_ID_MODEL_SHIFT_     (22)
0777 #define PHY_DEV_ID_MODEL_MASK_      (0x0FC00000)
0778 #define PHY_DEV_ID_OUI_MASK_        (0x003FFFFF)
0779 
0780 #define RGMII_TX_BYP_DLL        (0x708)
0781 #define RGMII_TX_BYP_DLL_TX_TUNE_ADJ_MASK_  (0x000FC00)
0782 #define RGMII_TX_BYP_DLL_TX_TUNE_SEL_MASK_  (0x00003F0)
0783 #define RGMII_TX_BYP_DLL_TX_DLL_RESET_      (0x0000002)
0784 #define RGMII_TX_BYP_DLL_TX_DLL_BYPASS_     (0x0000001)
0785 
0786 #define RGMII_RX_BYP_DLL        (0x70C)
0787 #define RGMII_RX_BYP_DLL_RX_TUNE_ADJ_MASK_  (0x000FC00)
0788 #define RGMII_RX_BYP_DLL_RX_TUNE_SEL_MASK_  (0x00003F0)
0789 #define RGMII_RX_BYP_DLL_RX_DLL_RESET_      (0x0000002)
0790 #define RGMII_RX_BYP_DLL_RX_DLL_BYPASS_     (0x0000001)
0791 
0792 #define OTP_BASE_ADDR           (0x00001000)
0793 #define OTP_ADDR_RANGE_         (0x1FF)
0794 
0795 #define OTP_PWR_DN          (OTP_BASE_ADDR + 4 * 0x00)
0796 #define OTP_PWR_DN_PWRDN_N_     (0x01)
0797 
0798 #define OTP_ADDR1           (OTP_BASE_ADDR + 4 * 0x01)
0799 #define OTP_ADDR1_15_11         (0x1F)
0800 
0801 #define OTP_ADDR2           (OTP_BASE_ADDR + 4 * 0x02)
0802 #define OTP_ADDR2_10_3          (0xFF)
0803 
0804 #define OTP_ADDR3           (OTP_BASE_ADDR + 4 * 0x03)
0805 #define OTP_ADDR3_2_0           (0x03)
0806 
0807 #define OTP_PRGM_DATA           (OTP_BASE_ADDR + 4 * 0x04)
0808 
0809 #define OTP_PRGM_MODE           (OTP_BASE_ADDR + 4 * 0x05)
0810 #define OTP_PRGM_MODE_BYTE_     (0x01)
0811 
0812 #define OTP_RD_DATA         (OTP_BASE_ADDR + 4 * 0x06)
0813 
0814 #define OTP_FUNC_CMD            (OTP_BASE_ADDR + 4 * 0x08)
0815 #define OTP_FUNC_CMD_RESET_     (0x04)
0816 #define OTP_FUNC_CMD_PROGRAM_       (0x02)
0817 #define OTP_FUNC_CMD_READ_      (0x01)
0818 
0819 #define OTP_TST_CMD         (OTP_BASE_ADDR + 4 * 0x09)
0820 #define OTP_TST_CMD_TEST_DEC_SEL_   (0x10)
0821 #define OTP_TST_CMD_PRGVRFY_        (0x08)
0822 #define OTP_TST_CMD_WRTEST_     (0x04)
0823 #define OTP_TST_CMD_TESTDEC_        (0x02)
0824 #define OTP_TST_CMD_BLANKCHECK_     (0x01)
0825 
0826 #define OTP_CMD_GO          (OTP_BASE_ADDR + 4 * 0x0A)
0827 #define OTP_CMD_GO_GO_          (0x01)
0828 
0829 #define OTP_PASS_FAIL           (OTP_BASE_ADDR + 4 * 0x0B)
0830 #define OTP_PASS_FAIL_PASS_     (0x02)
0831 #define OTP_PASS_FAIL_FAIL_     (0x01)
0832 
0833 #define OTP_STATUS          (OTP_BASE_ADDR + 4 * 0x0C)
0834 #define OTP_STATUS_OTP_LOCK_        (0x10)
0835 #define OTP_STATUS_WEB_         (0x08)
0836 #define OTP_STATUS_PGMEN        (0x04)
0837 #define OTP_STATUS_CPUMPEN_     (0x02)
0838 #define OTP_STATUS_BUSY_        (0x01)
0839 
0840 #define OTP_MAX_PRG         (OTP_BASE_ADDR + 4 * 0x0D)
0841 #define OTP_MAX_PRG_MAX_PROG        (0x1F)
0842 
0843 #define OTP_INTR_STATUS         (OTP_BASE_ADDR + 4 * 0x10)
0844 #define OTP_INTR_STATUS_READY_      (0x01)
0845 
0846 #define OTP_INTR_MASK           (OTP_BASE_ADDR + 4 * 0x11)
0847 #define OTP_INTR_MASK_READY_        (0x01)
0848 
0849 #define OTP_RSTB_PW1            (OTP_BASE_ADDR + 4 * 0x14)
0850 #define OTP_RSTB_PW2            (OTP_BASE_ADDR + 4 * 0x15)
0851 #define OTP_PGM_PW1         (OTP_BASE_ADDR + 4 * 0x18)
0852 #define OTP_PGM_PW2         (OTP_BASE_ADDR + 4 * 0x19)
0853 #define OTP_READ_PW1            (OTP_BASE_ADDR + 4 * 0x1C)
0854 #define OTP_READ_PW2            (OTP_BASE_ADDR + 4 * 0x1D)
0855 #define OTP_TCRST           (OTP_BASE_ADDR + 4 * 0x20)
0856 #define OTP_RSRD            (OTP_BASE_ADDR + 4 * 0x21)
0857 #define OTP_TREADEN_VAL         (OTP_BASE_ADDR + 4 * 0x22)
0858 #define OTP_TDLES_VAL           (OTP_BASE_ADDR + 4 * 0x23)
0859 #define OTP_TWWL_VAL            (OTP_BASE_ADDR + 4 * 0x24)
0860 #define OTP_TDLEH_VAL           (OTP_BASE_ADDR + 4 * 0x25)
0861 #define OTP_TWPED_VAL           (OTP_BASE_ADDR + 4 * 0x26)
0862 #define OTP_TPES_VAL            (OTP_BASE_ADDR + 4 * 0x27)
0863 #define OTP_TCPS_VAL            (OTP_BASE_ADDR + 4 * 0x28)
0864 #define OTP_TCPH_VAL            (OTP_BASE_ADDR + 4 * 0x29)
0865 #define OTP_TPGMVFY_VAL         (OTP_BASE_ADDR + 4 * 0x2A)
0866 #define OTP_TPEH_VAL            (OTP_BASE_ADDR + 4 * 0x2B)
0867 #define OTP_TPGRST_VAL          (OTP_BASE_ADDR + 4 * 0x2C)
0868 #define OTP_TCLES_VAL           (OTP_BASE_ADDR + 4 * 0x2D)
0869 #define OTP_TCLEH_VAL           (OTP_BASE_ADDR + 4 * 0x2E)
0870 #define OTP_TRDES_VAL           (OTP_BASE_ADDR + 4 * 0x2F)
0871 #define OTP_TBCACC_VAL          (OTP_BASE_ADDR + 4 * 0x30)
0872 #define OTP_TAAC_VAL            (OTP_BASE_ADDR + 4 * 0x31)
0873 #define OTP_TACCT_VAL           (OTP_BASE_ADDR + 4 * 0x32)
0874 #define OTP_TRDEP_VAL           (OTP_BASE_ADDR + 4 * 0x38)
0875 #define OTP_TPGSV_VAL           (OTP_BASE_ADDR + 4 * 0x39)
0876 #define OTP_TPVSR_VAL           (OTP_BASE_ADDR + 4 * 0x3A)
0877 #define OTP_TPVHR_VAL           (OTP_BASE_ADDR + 4 * 0x3B)
0878 #define OTP_TPVSA_VAL           (OTP_BASE_ADDR + 4 * 0x3C)
0879 #endif /* _LAN78XX_H */