1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Copyright (c) 2015 Realtek Semiconductor Corp. All rights reserved. 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * SPDX-License-Identifier: GPL-2.0 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun */ 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #ifndef _RTL8152_ETH_H 9*4882a593Smuzhiyun #define _RTL8152_ETH_H 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #define R8152_BASE_NAME "r8152" 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun #define PLA_IDR 0xc000 14*4882a593Smuzhiyun #define PLA_RCR 0xc010 15*4882a593Smuzhiyun #define PLA_RMS 0xc016 16*4882a593Smuzhiyun #define PLA_RXFIFO_CTRL0 0xc0a0 17*4882a593Smuzhiyun #define PLA_RXFIFO_CTRL1 0xc0a4 18*4882a593Smuzhiyun #define PLA_RXFIFO_CTRL2 0xc0a8 19*4882a593Smuzhiyun #define PLA_DMY_REG0 0xc0b0 20*4882a593Smuzhiyun #define PLA_FMC 0xc0b4 21*4882a593Smuzhiyun #define PLA_CFG_WOL 0xc0b6 22*4882a593Smuzhiyun #define PLA_TEREDO_CFG 0xc0bc 23*4882a593Smuzhiyun #define PLA_MAR 0xcd00 24*4882a593Smuzhiyun #define PLA_BACKUP 0xd000 25*4882a593Smuzhiyun #define PAL_BDC_CR 0xd1a0 26*4882a593Smuzhiyun #define PLA_TEREDO_TIMER 0xd2cc 27*4882a593Smuzhiyun #define PLA_REALWOW_TIMER 0xd2e8 28*4882a593Smuzhiyun #define PLA_LEDSEL 0xdd90 29*4882a593Smuzhiyun #define PLA_LED_FEATURE 0xdd92 30*4882a593Smuzhiyun #define PLA_PHYAR 0xde00 31*4882a593Smuzhiyun #define PLA_BOOT_CTRL 0xe004 32*4882a593Smuzhiyun #define PLA_GPHY_INTR_IMR 0xe022 33*4882a593Smuzhiyun #define PLA_EEE_CR 0xe040 34*4882a593Smuzhiyun #define PLA_EEEP_CR 0xe080 35*4882a593Smuzhiyun #define PLA_MAC_PWR_CTRL 0xe0c0 36*4882a593Smuzhiyun #define PLA_MAC_PWR_CTRL2 0xe0ca 37*4882a593Smuzhiyun #define PLA_MAC_PWR_CTRL3 0xe0cc 38*4882a593Smuzhiyun #define PLA_MAC_PWR_CTRL4 0xe0ce 39*4882a593Smuzhiyun #define PLA_WDT6_CTRL 0xe428 40*4882a593Smuzhiyun #define PLA_TCR0 0xe610 41*4882a593Smuzhiyun #define PLA_TCR1 0xe612 42*4882a593Smuzhiyun #define PLA_MTPS 0xe615 43*4882a593Smuzhiyun #define PLA_TXFIFO_CTRL 0xe618 44*4882a593Smuzhiyun #define PLA_RSTTALLY 0xe800 45*4882a593Smuzhiyun #define BIST_CTRL 0xe810 46*4882a593Smuzhiyun #define PLA_CR 0xe813 47*4882a593Smuzhiyun #define PLA_CRWECR 0xe81c 48*4882a593Smuzhiyun #define PLA_CONFIG12 0xe81e /* CONFIG1, CONFIG2 */ 49*4882a593Smuzhiyun #define PLA_CONFIG34 0xe820 /* CONFIG3, CONFIG4 */ 50*4882a593Smuzhiyun #define PLA_CONFIG5 0xe822 51*4882a593Smuzhiyun #define PLA_PHY_PWR 0xe84c 52*4882a593Smuzhiyun #define PLA_OOB_CTRL 0xe84f 53*4882a593Smuzhiyun #define PLA_CPCR 0xe854 54*4882a593Smuzhiyun #define PLA_MISC_0 0xe858 55*4882a593Smuzhiyun #define PLA_MISC_1 0xe85a 56*4882a593Smuzhiyun #define PLA_OCP_GPHY_BASE 0xe86c 57*4882a593Smuzhiyun #define PLA_TALLYCNT 0xe890 58*4882a593Smuzhiyun #define PLA_SFF_STS_7 0xe8de 59*4882a593Smuzhiyun #define PLA_PHYSTATUS 0xe908 60*4882a593Smuzhiyun #define PLA_BP_BA 0xfc26 61*4882a593Smuzhiyun #define PLA_BP_0 0xfc28 62*4882a593Smuzhiyun #define PLA_BP_1 0xfc2a 63*4882a593Smuzhiyun #define PLA_BP_2 0xfc2c 64*4882a593Smuzhiyun #define PLA_BP_3 0xfc2e 65*4882a593Smuzhiyun #define PLA_BP_4 0xfc30 66*4882a593Smuzhiyun #define PLA_BP_5 0xfc32 67*4882a593Smuzhiyun #define PLA_BP_6 0xfc34 68*4882a593Smuzhiyun #define PLA_BP_7 0xfc36 69*4882a593Smuzhiyun #define PLA_BP_EN 0xfc38 70*4882a593Smuzhiyun 71*4882a593Smuzhiyun #define USB_USB2PHY 0xb41e 72*4882a593Smuzhiyun #define USB_SSPHYLINK2 0xb428 73*4882a593Smuzhiyun #define USB_U2P3_CTRL 0xb460 74*4882a593Smuzhiyun #define USB_CSR_DUMMY1 0xb464 75*4882a593Smuzhiyun #define USB_CSR_DUMMY2 0xb466 76*4882a593Smuzhiyun #define USB_DEV_STAT 0xb808 77*4882a593Smuzhiyun #define USB_CONNECT_TIMER 0xcbf8 78*4882a593Smuzhiyun #define USB_BURST_SIZE 0xcfc0 79*4882a593Smuzhiyun #define USB_USB_CTRL 0xd406 80*4882a593Smuzhiyun #define USB_PHY_CTRL 0xd408 81*4882a593Smuzhiyun #define USB_TX_AGG 0xd40a 82*4882a593Smuzhiyun #define USB_RX_BUF_TH 0xd40c 83*4882a593Smuzhiyun #define USB_USB_TIMER 0xd428 84*4882a593Smuzhiyun #define USB_RX_EARLY_TIMEOUT 0xd42c 85*4882a593Smuzhiyun #define USB_RX_EARLY_SIZE 0xd42e 86*4882a593Smuzhiyun #define USB_PM_CTRL_STATUS 0xd432 87*4882a593Smuzhiyun #define USB_TX_DMA 0xd434 88*4882a593Smuzhiyun #define USB_TOLERANCE 0xd490 89*4882a593Smuzhiyun #define USB_LPM_CTRL 0xd41a 90*4882a593Smuzhiyun #define USB_UPS_CTRL 0xd800 91*4882a593Smuzhiyun #define USB_MISC_0 0xd81a 92*4882a593Smuzhiyun #define USB_POWER_CUT 0xd80a 93*4882a593Smuzhiyun #define USB_AFE_CTRL2 0xd824 94*4882a593Smuzhiyun #define USB_WDT11_CTRL 0xe43c 95*4882a593Smuzhiyun #define USB_BP_BA 0xfc26 96*4882a593Smuzhiyun #define USB_BP_0 0xfc28 97*4882a593Smuzhiyun #define USB_BP_1 0xfc2a 98*4882a593Smuzhiyun #define USB_BP_2 0xfc2c 99*4882a593Smuzhiyun #define USB_BP_3 0xfc2e 100*4882a593Smuzhiyun #define USB_BP_4 0xfc30 101*4882a593Smuzhiyun #define USB_BP_5 0xfc32 102*4882a593Smuzhiyun #define USB_BP_6 0xfc34 103*4882a593Smuzhiyun #define USB_BP_7 0xfc36 104*4882a593Smuzhiyun #define USB_BP_EN 0xfc38 105*4882a593Smuzhiyun 106*4882a593Smuzhiyun /* OCP Registers */ 107*4882a593Smuzhiyun #define OCP_ALDPS_CONFIG 0x2010 108*4882a593Smuzhiyun #define OCP_EEE_CONFIG1 0x2080 109*4882a593Smuzhiyun #define OCP_EEE_CONFIG2 0x2092 110*4882a593Smuzhiyun #define OCP_EEE_CONFIG3 0x2094 111*4882a593Smuzhiyun #define OCP_BASE_MII 0xa400 112*4882a593Smuzhiyun #define OCP_EEE_AR 0xa41a 113*4882a593Smuzhiyun #define OCP_EEE_DATA 0xa41c 114*4882a593Smuzhiyun #define OCP_PHY_STATUS 0xa420 115*4882a593Smuzhiyun #define OCP_POWER_CFG 0xa430 116*4882a593Smuzhiyun #define OCP_EEE_CFG 0xa432 117*4882a593Smuzhiyun #define OCP_SRAM_ADDR 0xa436 118*4882a593Smuzhiyun #define OCP_SRAM_DATA 0xa438 119*4882a593Smuzhiyun #define OCP_DOWN_SPEED 0xa442 120*4882a593Smuzhiyun #define OCP_EEE_ABLE 0xa5c4 121*4882a593Smuzhiyun #define OCP_EEE_ADV 0xa5d0 122*4882a593Smuzhiyun #define OCP_EEE_LPABLE 0xa5d2 123*4882a593Smuzhiyun #define OCP_PHY_STATE 0xa708 /* nway state for 8153 */ 124*4882a593Smuzhiyun #define OCP_ADC_CFG 0xbc06 125*4882a593Smuzhiyun 126*4882a593Smuzhiyun /* SRAM Register */ 127*4882a593Smuzhiyun #define SRAM_LPF_CFG 0x8012 128*4882a593Smuzhiyun #define SRAM_10M_AMP1 0x8080 129*4882a593Smuzhiyun #define SRAM_10M_AMP2 0x8082 130*4882a593Smuzhiyun #define SRAM_IMPEDANCE 0x8084 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun /* PLA_RCR */ 133*4882a593Smuzhiyun #define RCR_AAP 0x00000001 134*4882a593Smuzhiyun #define RCR_APM 0x00000002 135*4882a593Smuzhiyun #define RCR_AM 0x00000004 136*4882a593Smuzhiyun #define RCR_AB 0x00000008 137*4882a593Smuzhiyun #define RCR_ACPT_ALL (RCR_AAP | RCR_APM | RCR_AM | RCR_AB) 138*4882a593Smuzhiyun 139*4882a593Smuzhiyun /* PLA_RXFIFO_CTRL0 */ 140*4882a593Smuzhiyun #define RXFIFO_THR1_NORMAL 0x00080002 141*4882a593Smuzhiyun #define RXFIFO_THR1_OOB 0x01800003 142*4882a593Smuzhiyun 143*4882a593Smuzhiyun /* PLA_RXFIFO_CTRL1 */ 144*4882a593Smuzhiyun #define RXFIFO_THR2_FULL 0x00000060 145*4882a593Smuzhiyun #define RXFIFO_THR2_HIGH 0x00000038 146*4882a593Smuzhiyun #define RXFIFO_THR2_OOB 0x0000004a 147*4882a593Smuzhiyun #define RXFIFO_THR2_NORMAL 0x00a0 148*4882a593Smuzhiyun 149*4882a593Smuzhiyun /* PLA_RXFIFO_CTRL2 */ 150*4882a593Smuzhiyun #define RXFIFO_THR3_FULL 0x00000078 151*4882a593Smuzhiyun #define RXFIFO_THR3_HIGH 0x00000048 152*4882a593Smuzhiyun #define RXFIFO_THR3_OOB 0x0000005a 153*4882a593Smuzhiyun #define RXFIFO_THR3_NORMAL 0x0110 154*4882a593Smuzhiyun 155*4882a593Smuzhiyun /* PLA_TXFIFO_CTRL */ 156*4882a593Smuzhiyun #define TXFIFO_THR_NORMAL 0x00400008 157*4882a593Smuzhiyun #define TXFIFO_THR_NORMAL2 0x01000008 158*4882a593Smuzhiyun 159*4882a593Smuzhiyun /* PLA_DMY_REG0 */ 160*4882a593Smuzhiyun #define ECM_ALDPS 0x0002 161*4882a593Smuzhiyun 162*4882a593Smuzhiyun /* PLA_FMC */ 163*4882a593Smuzhiyun #define FMC_FCR_MCU_EN 0x0001 164*4882a593Smuzhiyun 165*4882a593Smuzhiyun /* PLA_EEEP_CR */ 166*4882a593Smuzhiyun #define EEEP_CR_EEEP_TX 0x0002 167*4882a593Smuzhiyun 168*4882a593Smuzhiyun /* PLA_WDT6_CTRL */ 169*4882a593Smuzhiyun #define WDT6_SET_MODE 0x0010 170*4882a593Smuzhiyun 171*4882a593Smuzhiyun /* PLA_TCR0 */ 172*4882a593Smuzhiyun #define TCR0_TX_EMPTY 0x0800 173*4882a593Smuzhiyun #define TCR0_AUTO_FIFO 0x0080 174*4882a593Smuzhiyun 175*4882a593Smuzhiyun /* PLA_TCR1 */ 176*4882a593Smuzhiyun #define VERSION_MASK 0x7cf0 177*4882a593Smuzhiyun 178*4882a593Smuzhiyun /* PLA_MTPS */ 179*4882a593Smuzhiyun #define MTPS_JUMBO (12 * 1024 / 64) 180*4882a593Smuzhiyun #define MTPS_DEFAULT (6 * 1024 / 64) 181*4882a593Smuzhiyun 182*4882a593Smuzhiyun /* PLA_RSTTALLY */ 183*4882a593Smuzhiyun #define TALLY_RESET 0x0001 184*4882a593Smuzhiyun 185*4882a593Smuzhiyun /* PLA_CR */ 186*4882a593Smuzhiyun #define PLA_CR_RST 0x10 187*4882a593Smuzhiyun #define PLA_CR_RE 0x08 188*4882a593Smuzhiyun #define PLA_CR_TE 0x04 189*4882a593Smuzhiyun 190*4882a593Smuzhiyun /* PLA_BIST_CTRL */ 191*4882a593Smuzhiyun #define BIST_CTRL_SW_RESET (0x10 << 24) 192*4882a593Smuzhiyun 193*4882a593Smuzhiyun /* PLA_CRWECR */ 194*4882a593Smuzhiyun #define CRWECR_NORAML 0x00 195*4882a593Smuzhiyun #define CRWECR_CONFIG 0xc0 196*4882a593Smuzhiyun 197*4882a593Smuzhiyun /* PLA_OOB_CTRL */ 198*4882a593Smuzhiyun #define NOW_IS_OOB 0x80 199*4882a593Smuzhiyun #define TXFIFO_EMPTY 0x20 200*4882a593Smuzhiyun #define RXFIFO_EMPTY 0x10 201*4882a593Smuzhiyun #define LINK_LIST_READY 0x02 202*4882a593Smuzhiyun #define DIS_MCU_CLROOB 0x01 203*4882a593Smuzhiyun #define FIFO_EMPTY (TXFIFO_EMPTY | RXFIFO_EMPTY) 204*4882a593Smuzhiyun 205*4882a593Smuzhiyun /* PLA_PHY_PWR */ 206*4882a593Smuzhiyun #define PLA_PHY_PWR_LLR (LINK_LIST_READY << 24) 207*4882a593Smuzhiyun #define PLA_PHY_PWR_TXEMP (TXFIFO_EMPTY << 24) 208*4882a593Smuzhiyun 209*4882a593Smuzhiyun /* PLA_MISC_1 */ 210*4882a593Smuzhiyun #define RXDY_GATED_EN 0x0008 211*4882a593Smuzhiyun 212*4882a593Smuzhiyun /* PLA_SFF_STS_7 */ 213*4882a593Smuzhiyun #define RE_INIT_LL 0x8000 214*4882a593Smuzhiyun #define MCU_BORW_EN 0x4000 215*4882a593Smuzhiyun 216*4882a593Smuzhiyun /* PLA_CPCR */ 217*4882a593Smuzhiyun #define CPCR_RX_VLAN 0x0040 218*4882a593Smuzhiyun 219*4882a593Smuzhiyun /* PLA_CFG_WOL */ 220*4882a593Smuzhiyun #define MAGIC_EN 0x0001 221*4882a593Smuzhiyun 222*4882a593Smuzhiyun /* PLA_TEREDO_CFG */ 223*4882a593Smuzhiyun #define TEREDO_SEL 0x8000 224*4882a593Smuzhiyun #define TEREDO_WAKE_MASK 0x7f00 225*4882a593Smuzhiyun #define TEREDO_RS_EVENT_MASK 0x00fe 226*4882a593Smuzhiyun #define OOB_TEREDO_EN 0x0001 227*4882a593Smuzhiyun 228*4882a593Smuzhiyun /* PAL_BDC_CR */ 229*4882a593Smuzhiyun #define ALDPS_PROXY_MODE 0x0001 230*4882a593Smuzhiyun 231*4882a593Smuzhiyun /* PLA_CONFIG34 */ 232*4882a593Smuzhiyun #define LINK_ON_WAKE_EN 0x0010 233*4882a593Smuzhiyun #define LINK_OFF_WAKE_EN 0x0008 234*4882a593Smuzhiyun 235*4882a593Smuzhiyun /* PLA_CONFIG5 */ 236*4882a593Smuzhiyun #define BWF_EN 0x0040 237*4882a593Smuzhiyun #define MWF_EN 0x0020 238*4882a593Smuzhiyun #define UWF_EN 0x0010 239*4882a593Smuzhiyun #define LAN_WAKE_EN 0x0002 240*4882a593Smuzhiyun 241*4882a593Smuzhiyun /* PLA_LED_FEATURE */ 242*4882a593Smuzhiyun #define LED_MODE_MASK 0x0700 243*4882a593Smuzhiyun 244*4882a593Smuzhiyun /* PLA_PHY_PWR */ 245*4882a593Smuzhiyun #define TX_10M_IDLE_EN 0x0080 246*4882a593Smuzhiyun #define PFM_PWM_SWITCH 0x0040 247*4882a593Smuzhiyun 248*4882a593Smuzhiyun /* PLA_MAC_PWR_CTRL */ 249*4882a593Smuzhiyun #define D3_CLK_GATED_EN 0x00004000 250*4882a593Smuzhiyun #define MCU_CLK_RATIO 0x07010f07 251*4882a593Smuzhiyun #define MCU_CLK_RATIO_MASK 0x0f0f0f0f 252*4882a593Smuzhiyun #define ALDPS_SPDWN_RATIO 0x0f87 253*4882a593Smuzhiyun 254*4882a593Smuzhiyun /* PLA_MAC_PWR_CTRL2 */ 255*4882a593Smuzhiyun #define EEE_SPDWN_RATIO 0x8007 256*4882a593Smuzhiyun 257*4882a593Smuzhiyun /* PLA_MAC_PWR_CTRL3 */ 258*4882a593Smuzhiyun #define PKT_AVAIL_SPDWN_EN 0x0100 259*4882a593Smuzhiyun #define SUSPEND_SPDWN_EN 0x0004 260*4882a593Smuzhiyun #define U1U2_SPDWN_EN 0x0002 261*4882a593Smuzhiyun #define L1_SPDWN_EN 0x0001 262*4882a593Smuzhiyun 263*4882a593Smuzhiyun /* PLA_MAC_PWR_CTRL4 */ 264*4882a593Smuzhiyun #define PWRSAVE_SPDWN_EN 0x1000 265*4882a593Smuzhiyun #define RXDV_SPDWN_EN 0x0800 266*4882a593Smuzhiyun #define TX10MIDLE_EN 0x0100 267*4882a593Smuzhiyun #define TP100_SPDWN_EN 0x0020 268*4882a593Smuzhiyun #define TP500_SPDWN_EN 0x0010 269*4882a593Smuzhiyun #define TP1000_SPDWN_EN 0x0008 270*4882a593Smuzhiyun #define EEE_SPDWN_EN 0x0001 271*4882a593Smuzhiyun 272*4882a593Smuzhiyun /* PLA_GPHY_INTR_IMR */ 273*4882a593Smuzhiyun #define GPHY_STS_MSK 0x0001 274*4882a593Smuzhiyun #define SPEED_DOWN_MSK 0x0002 275*4882a593Smuzhiyun #define SPDWN_RXDV_MSK 0x0004 276*4882a593Smuzhiyun #define SPDWN_LINKCHG_MSK 0x0008 277*4882a593Smuzhiyun 278*4882a593Smuzhiyun /* PLA_PHYAR */ 279*4882a593Smuzhiyun #define PHYAR_FLAG 0x80000000 280*4882a593Smuzhiyun 281*4882a593Smuzhiyun /* PLA_EEE_CR */ 282*4882a593Smuzhiyun #define EEE_RX_EN 0x0001 283*4882a593Smuzhiyun #define EEE_TX_EN 0x0002 284*4882a593Smuzhiyun 285*4882a593Smuzhiyun /* PLA_BOOT_CTRL */ 286*4882a593Smuzhiyun #define AUTOLOAD_DONE 0x0002 287*4882a593Smuzhiyun 288*4882a593Smuzhiyun /* USB_USB2PHY */ 289*4882a593Smuzhiyun #define USB2PHY_SUSPEND 0x0001 290*4882a593Smuzhiyun #define USB2PHY_L1 0x0002 291*4882a593Smuzhiyun 292*4882a593Smuzhiyun /* USB_SSPHYLINK2 */ 293*4882a593Smuzhiyun #define pwd_dn_scale_mask 0x3ffe 294*4882a593Smuzhiyun #define pwd_dn_scale(x) ((x) << 1) 295*4882a593Smuzhiyun 296*4882a593Smuzhiyun /* USB_CSR_DUMMY1 */ 297*4882a593Smuzhiyun #define DYNAMIC_BURST 0x0001 298*4882a593Smuzhiyun 299*4882a593Smuzhiyun /* USB_CSR_DUMMY2 */ 300*4882a593Smuzhiyun #define EP4_FULL_FC 0x0001 301*4882a593Smuzhiyun 302*4882a593Smuzhiyun /* USB_DEV_STAT */ 303*4882a593Smuzhiyun #define STAT_SPEED_MASK 0x0006 304*4882a593Smuzhiyun #define STAT_SPEED_HIGH 0x0000 305*4882a593Smuzhiyun #define STAT_SPEED_FULL 0x0002 306*4882a593Smuzhiyun 307*4882a593Smuzhiyun /* USB_TX_AGG */ 308*4882a593Smuzhiyun #define TX_AGG_MAX_THRESHOLD 0x03 309*4882a593Smuzhiyun 310*4882a593Smuzhiyun /* USB_RX_BUF_TH */ 311*4882a593Smuzhiyun #define RX_THR_SUPPER 0x0c350180 312*4882a593Smuzhiyun #define RX_THR_HIGH 0x7a120180 313*4882a593Smuzhiyun #define RX_THR_SLOW 0xffff0180 314*4882a593Smuzhiyun 315*4882a593Smuzhiyun /* USB_TX_DMA */ 316*4882a593Smuzhiyun #define TEST_MODE_DISABLE 0x00000001 317*4882a593Smuzhiyun #define TX_SIZE_ADJUST1 0x00000100 318*4882a593Smuzhiyun 319*4882a593Smuzhiyun /* USB_UPS_CTRL */ 320*4882a593Smuzhiyun #define POWER_CUT 0x0100 321*4882a593Smuzhiyun 322*4882a593Smuzhiyun /* USB_PM_CTRL_STATUS */ 323*4882a593Smuzhiyun #define RESUME_INDICATE 0x0001 324*4882a593Smuzhiyun 325*4882a593Smuzhiyun /* USB_USB_CTRL */ 326*4882a593Smuzhiyun #define RX_AGG_DISABLE 0x0010 327*4882a593Smuzhiyun #define RX_ZERO_EN 0x0080 328*4882a593Smuzhiyun 329*4882a593Smuzhiyun /* USB_U2P3_CTRL */ 330*4882a593Smuzhiyun #define U2P3_ENABLE 0x0001 331*4882a593Smuzhiyun 332*4882a593Smuzhiyun /* USB_POWER_CUT */ 333*4882a593Smuzhiyun #define PWR_EN 0x0001 334*4882a593Smuzhiyun #define PHASE2_EN 0x0008 335*4882a593Smuzhiyun 336*4882a593Smuzhiyun /* USB_MISC_0 */ 337*4882a593Smuzhiyun #define PCUT_STATUS 0x0001 338*4882a593Smuzhiyun 339*4882a593Smuzhiyun /* USB_RX_EARLY_TIMEOUT */ 340*4882a593Smuzhiyun #define COALESCE_SUPER 85000U 341*4882a593Smuzhiyun #define COALESCE_HIGH 250000U 342*4882a593Smuzhiyun #define COALESCE_SLOW 524280U 343*4882a593Smuzhiyun 344*4882a593Smuzhiyun /* USB_WDT11_CTRL */ 345*4882a593Smuzhiyun #define TIMER11_EN 0x0001 346*4882a593Smuzhiyun 347*4882a593Smuzhiyun /* USB_LPM_CTRL */ 348*4882a593Smuzhiyun /* bit 4 ~ 5: fifo empty boundary */ 349*4882a593Smuzhiyun #define FIFO_EMPTY_1FB 0x30 /* 0x1fb * 64 = 32448 bytes */ 350*4882a593Smuzhiyun /* bit 2 ~ 3: LMP timer */ 351*4882a593Smuzhiyun #define LPM_TIMER_MASK 0x0c 352*4882a593Smuzhiyun #define LPM_TIMER_500MS 0x04 /* 500 ms */ 353*4882a593Smuzhiyun #define LPM_TIMER_500US 0x0c /* 500 us */ 354*4882a593Smuzhiyun #define ROK_EXIT_LPM 0x02 355*4882a593Smuzhiyun 356*4882a593Smuzhiyun /* USB_AFE_CTRL2 */ 357*4882a593Smuzhiyun #define SEN_VAL_MASK 0xf800 358*4882a593Smuzhiyun #define SEN_VAL_NORMAL 0xa000 359*4882a593Smuzhiyun #define SEL_RXIDLE 0x0100 360*4882a593Smuzhiyun 361*4882a593Smuzhiyun /* OCP_ALDPS_CONFIG */ 362*4882a593Smuzhiyun #define ENPWRSAVE 0x8000 363*4882a593Smuzhiyun #define ENPDNPS 0x0200 364*4882a593Smuzhiyun #define LINKENA 0x0100 365*4882a593Smuzhiyun #define DIS_SDSAVE 0x0010 366*4882a593Smuzhiyun 367*4882a593Smuzhiyun /* OCP_PHY_STATUS */ 368*4882a593Smuzhiyun #define PHY_STAT_MASK 0x0007 369*4882a593Smuzhiyun #define PHY_STAT_LAN_ON 3 370*4882a593Smuzhiyun #define PHY_STAT_PWRDN 5 371*4882a593Smuzhiyun 372*4882a593Smuzhiyun /* OCP_POWER_CFG */ 373*4882a593Smuzhiyun #define EEE_CLKDIV_EN 0x8000 374*4882a593Smuzhiyun #define EN_ALDPS 0x0004 375*4882a593Smuzhiyun #define EN_10M_PLLOFF 0x0001 376*4882a593Smuzhiyun 377*4882a593Smuzhiyun /* OCP_EEE_CONFIG1 */ 378*4882a593Smuzhiyun #define RG_TXLPI_MSK_HFDUP 0x8000 379*4882a593Smuzhiyun #define RG_MATCLR_EN 0x4000 380*4882a593Smuzhiyun #define EEE_10_CAP 0x2000 381*4882a593Smuzhiyun #define EEE_NWAY_EN 0x1000 382*4882a593Smuzhiyun #define TX_QUIET_EN 0x0200 383*4882a593Smuzhiyun #define RX_QUIET_EN 0x0100 384*4882a593Smuzhiyun #define sd_rise_time_mask 0x0070 385*4882a593Smuzhiyun #define sd_rise_time(x) (min((x), 7) << 4) /* bit 4 ~ 6 */ 386*4882a593Smuzhiyun #define RG_RXLPI_MSK_HFDUP 0x0008 387*4882a593Smuzhiyun #define SDFALLTIME 0x0007 /* bit 0 ~ 2 */ 388*4882a593Smuzhiyun 389*4882a593Smuzhiyun /* OCP_EEE_CONFIG2 */ 390*4882a593Smuzhiyun #define RG_LPIHYS_NUM 0x7000 /* bit 12 ~ 15 */ 391*4882a593Smuzhiyun #define RG_DACQUIET_EN 0x0400 392*4882a593Smuzhiyun #define RG_LDVQUIET_EN 0x0200 393*4882a593Smuzhiyun #define RG_CKRSEL 0x0020 394*4882a593Smuzhiyun #define RG_EEEPRG_EN 0x0010 395*4882a593Smuzhiyun 396*4882a593Smuzhiyun /* OCP_EEE_CONFIG3 */ 397*4882a593Smuzhiyun #define fast_snr_mask 0xff80 398*4882a593Smuzhiyun #define fast_snr(x) (min((x), 0x1ff) << 7) /* bit 7 ~ 15 */ 399*4882a593Smuzhiyun #define RG_LFS_SEL 0x0060 /* bit 6 ~ 5 */ 400*4882a593Smuzhiyun #define MSK_PH 0x0006 /* bit 0 ~ 3 */ 401*4882a593Smuzhiyun 402*4882a593Smuzhiyun /* OCP_EEE_AR */ 403*4882a593Smuzhiyun /* bit[15:14] function */ 404*4882a593Smuzhiyun #define FUN_ADDR 0x0000 405*4882a593Smuzhiyun #define FUN_DATA 0x4000 406*4882a593Smuzhiyun /* bit[4:0] device addr */ 407*4882a593Smuzhiyun 408*4882a593Smuzhiyun /* OCP_EEE_CFG */ 409*4882a593Smuzhiyun #define CTAP_SHORT_EN 0x0040 410*4882a593Smuzhiyun #define EEE10_EN 0x0010 411*4882a593Smuzhiyun 412*4882a593Smuzhiyun /* OCP_DOWN_SPEED */ 413*4882a593Smuzhiyun #define EN_10M_BGOFF 0x0080 414*4882a593Smuzhiyun 415*4882a593Smuzhiyun /* OCP_PHY_STATE */ 416*4882a593Smuzhiyun #define TXDIS_STATE 0x01 417*4882a593Smuzhiyun #define ABD_STATE 0x02 418*4882a593Smuzhiyun 419*4882a593Smuzhiyun /* OCP_ADC_CFG */ 420*4882a593Smuzhiyun #define CKADSEL_L 0x0100 421*4882a593Smuzhiyun #define ADC_EN 0x0080 422*4882a593Smuzhiyun #define EN_EMI_L 0x0040 423*4882a593Smuzhiyun 424*4882a593Smuzhiyun /* SRAM_LPF_CFG */ 425*4882a593Smuzhiyun #define LPF_AUTO_TUNE 0x8000 426*4882a593Smuzhiyun 427*4882a593Smuzhiyun /* SRAM_10M_AMP1 */ 428*4882a593Smuzhiyun #define GDAC_IB_UPALL 0x0008 429*4882a593Smuzhiyun 430*4882a593Smuzhiyun /* SRAM_10M_AMP2 */ 431*4882a593Smuzhiyun #define AMP_DN 0x0200 432*4882a593Smuzhiyun 433*4882a593Smuzhiyun /* SRAM_IMPEDANCE */ 434*4882a593Smuzhiyun #define RX_DRIVING_MASK 0x6000 435*4882a593Smuzhiyun 436*4882a593Smuzhiyun #define RTL8152_MAX_TX 4 437*4882a593Smuzhiyun #define RTL8152_MAX_RX 10 438*4882a593Smuzhiyun #define INTBUFSIZE 2 439*4882a593Smuzhiyun #define CRC_SIZE 4 440*4882a593Smuzhiyun #define TX_ALIGN 4 441*4882a593Smuzhiyun #define RX_ALIGN 8 442*4882a593Smuzhiyun 443*4882a593Smuzhiyun #define INTR_LINK 0x0004 444*4882a593Smuzhiyun 445*4882a593Smuzhiyun #define RTL8152_REQT_READ 0xc0 446*4882a593Smuzhiyun #define RTL8152_REQT_WRITE 0x40 447*4882a593Smuzhiyun #define RTL8152_REQ_GET_REGS 0x05 448*4882a593Smuzhiyun #define RTL8152_REQ_SET_REGS 0x05 449*4882a593Smuzhiyun 450*4882a593Smuzhiyun #define BYTE_EN_DWORD 0xff 451*4882a593Smuzhiyun #define BYTE_EN_WORD 0x33 452*4882a593Smuzhiyun #define BYTE_EN_BYTE 0x11 453*4882a593Smuzhiyun #define BYTE_EN_SIX_BYTES 0x3f 454*4882a593Smuzhiyun #define BYTE_EN_START_MASK 0x0f 455*4882a593Smuzhiyun #define BYTE_EN_END_MASK 0xf0 456*4882a593Smuzhiyun 457*4882a593Smuzhiyun #define RTL8152_ETH_FRAME_LEN 1514 458*4882a593Smuzhiyun #define RTL8152_AGG_BUF_SZ 2048 459*4882a593Smuzhiyun 460*4882a593Smuzhiyun #define RTL8152_RMS (RTL8152_ETH_FRAME_LEN + CRC_SIZE) 461*4882a593Smuzhiyun #define RTL8153_RMS (RTL8152_ETH_FRAME_LEN + CRC_SIZE) 462*4882a593Smuzhiyun #define RTL8152_TX_TIMEOUT (5 * HZ) 463*4882a593Smuzhiyun 464*4882a593Smuzhiyun #define MCU_TYPE_PLA 0x0100 465*4882a593Smuzhiyun #define MCU_TYPE_USB 0x0000 466*4882a593Smuzhiyun 467*4882a593Smuzhiyun /* The forced speed, 10Mb, 100Mb, gigabit. */ 468*4882a593Smuzhiyun #define SPEED_10 10 469*4882a593Smuzhiyun #define SPEED_100 100 470*4882a593Smuzhiyun #define SPEED_1000 1000 471*4882a593Smuzhiyun 472*4882a593Smuzhiyun #define SPEED_UNKNOWN -1 473*4882a593Smuzhiyun 474*4882a593Smuzhiyun /* Duplex, half or full. */ 475*4882a593Smuzhiyun #define DUPLEX_HALF 0x00 476*4882a593Smuzhiyun #define DUPLEX_FULL 0x01 477*4882a593Smuzhiyun #define DUPLEX_UNKNOWN 0xff 478*4882a593Smuzhiyun 479*4882a593Smuzhiyun /* Enable or disable autonegotiation. */ 480*4882a593Smuzhiyun #define AUTONEG_DISABLE 0x00 481*4882a593Smuzhiyun #define AUTONEG_ENABLE 0x01 482*4882a593Smuzhiyun 483*4882a593Smuzhiyun /* Generic MII registers. */ 484*4882a593Smuzhiyun #define MII_BMCR 0x00 /* Basic mode control register */ 485*4882a593Smuzhiyun #define MII_BMSR 0x01 /* Basic mode status register */ 486*4882a593Smuzhiyun #define MII_PHYSID1 0x02 /* PHYS ID 1 */ 487*4882a593Smuzhiyun #define MII_PHYSID2 0x03 /* PHYS ID 2 */ 488*4882a593Smuzhiyun #define MII_ADVERTISE 0x04 /* Advertisement control reg */ 489*4882a593Smuzhiyun #define MII_LPA 0x05 /* Link partner ability reg */ 490*4882a593Smuzhiyun #define MII_EXPANSION 0x06 /* Expansion register */ 491*4882a593Smuzhiyun #define MII_CTRL1000 0x09 /* 1000BASE-T control */ 492*4882a593Smuzhiyun #define MII_STAT1000 0x0a /* 1000BASE-T status */ 493*4882a593Smuzhiyun #define MII_MMD_CTRL 0x0d /* MMD Access Control Register */ 494*4882a593Smuzhiyun #define MII_MMD_DATA 0x0e /* MMD Access Data Register */ 495*4882a593Smuzhiyun #define MII_ESTATUS 0x0f /* Extended Status */ 496*4882a593Smuzhiyun #define MII_DCOUNTER 0x12 /* Disconnect counter */ 497*4882a593Smuzhiyun #define MII_FCSCOUNTER 0x13 /* False carrier counter */ 498*4882a593Smuzhiyun #define MII_NWAYTEST 0x14 /* N-way auto-neg test reg */ 499*4882a593Smuzhiyun #define MII_RERRCOUNTER 0x15 /* Receive error counter */ 500*4882a593Smuzhiyun #define MII_SREVISION 0x16 /* Silicon revision */ 501*4882a593Smuzhiyun #define MII_RESV1 0x17 /* Reserved... */ 502*4882a593Smuzhiyun #define MII_LBRERROR 0x18 /* Lpback, rx, bypass error */ 503*4882a593Smuzhiyun #define MII_PHYADDR 0x19 /* PHY address */ 504*4882a593Smuzhiyun #define MII_RESV2 0x1a /* Reserved... */ 505*4882a593Smuzhiyun #define MII_TPISTATUS 0x1b /* TPI status for 10mbps */ 506*4882a593Smuzhiyun #define MII_NCONFIG 0x1c /* Network interface config */ 507*4882a593Smuzhiyun 508*4882a593Smuzhiyun #define TIMEOUT_RESOLUTION 50 509*4882a593Smuzhiyun #define PHY_CONNECT_TIMEOUT 5000 510*4882a593Smuzhiyun #define USB_BULK_SEND_TIMEOUT 5000 511*4882a593Smuzhiyun #define USB_BULK_RECV_TIMEOUT 5000 512*4882a593Smuzhiyun #define R8152_WAIT_TIMEOUT 2000 513*4882a593Smuzhiyun 514*4882a593Smuzhiyun struct rx_desc { 515*4882a593Smuzhiyun __le32 opts1; 516*4882a593Smuzhiyun #define RD_CRC BIT(15) 517*4882a593Smuzhiyun #define RX_LEN_MASK 0x7fff 518*4882a593Smuzhiyun 519*4882a593Smuzhiyun __le32 opts2; 520*4882a593Smuzhiyun #define RD_UDP_CS BIT(23) 521*4882a593Smuzhiyun #define RD_TCP_CS BIT(22) 522*4882a593Smuzhiyun #define RD_IPV6_CS BIT(20) 523*4882a593Smuzhiyun #define RD_IPV4_CS BIT(19) 524*4882a593Smuzhiyun 525*4882a593Smuzhiyun __le32 opts3; 526*4882a593Smuzhiyun #define IPF BIT(23) /* IP checksum fail */ 527*4882a593Smuzhiyun #define UDPF BIT(22) /* UDP checksum fail */ 528*4882a593Smuzhiyun #define TCPF BIT(21) /* TCP checksum fail */ 529*4882a593Smuzhiyun #define RX_VLAN_TAG BIT(16) 530*4882a593Smuzhiyun 531*4882a593Smuzhiyun __le32 opts4; 532*4882a593Smuzhiyun __le32 opts5; 533*4882a593Smuzhiyun __le32 opts6; 534*4882a593Smuzhiyun }; 535*4882a593Smuzhiyun 536*4882a593Smuzhiyun struct tx_desc { 537*4882a593Smuzhiyun __le32 opts1; 538*4882a593Smuzhiyun #define TX_FS BIT(31) /* First segment of a packet */ 539*4882a593Smuzhiyun #define TX_LS BIT(30) /* Final segment of a packet */ 540*4882a593Smuzhiyun #define LGSEND BIT(29) 541*4882a593Smuzhiyun #define GTSENDV4 BIT(28) 542*4882a593Smuzhiyun #define GTSENDV6 BIT(27) 543*4882a593Smuzhiyun #define GTTCPHO_SHIFT 18 544*4882a593Smuzhiyun #define GTTCPHO_MAX 0x7fU 545*4882a593Smuzhiyun #define TX_LEN_MAX 0x3ffffU 546*4882a593Smuzhiyun 547*4882a593Smuzhiyun __le32 opts2; 548*4882a593Smuzhiyun #define UDP_CS BIT(31) /* Calculate UDP/IP checksum */ 549*4882a593Smuzhiyun #define TCP_CS BIT(30) /* Calculate TCP/IP checksum */ 550*4882a593Smuzhiyun #define IPV4_CS BIT(29) /* Calculate IPv4 checksum */ 551*4882a593Smuzhiyun #define IPV6_CS BIT(28) /* Calculate IPv6 checksum */ 552*4882a593Smuzhiyun #define MSS_SHIFT 17 553*4882a593Smuzhiyun #define MSS_MAX 0x7ffU 554*4882a593Smuzhiyun #define TCPHO_SHIFT 17 555*4882a593Smuzhiyun #define TCPHO_MAX 0x7ffU 556*4882a593Smuzhiyun #define TX_VLAN_TAG BIT(16) 557*4882a593Smuzhiyun }; 558*4882a593Smuzhiyun 559*4882a593Smuzhiyun enum rtl_version { 560*4882a593Smuzhiyun RTL_VER_UNKNOWN = 0, 561*4882a593Smuzhiyun RTL_VER_01, 562*4882a593Smuzhiyun RTL_VER_02, 563*4882a593Smuzhiyun RTL_VER_03, 564*4882a593Smuzhiyun RTL_VER_04, 565*4882a593Smuzhiyun RTL_VER_05, 566*4882a593Smuzhiyun RTL_VER_06, 567*4882a593Smuzhiyun RTL_VER_07, 568*4882a593Smuzhiyun RTL_VER_MAX 569*4882a593Smuzhiyun }; 570*4882a593Smuzhiyun 571*4882a593Smuzhiyun enum rtl_register_content { 572*4882a593Smuzhiyun _1000bps = 0x10, 573*4882a593Smuzhiyun _100bps = 0x08, 574*4882a593Smuzhiyun _10bps = 0x04, 575*4882a593Smuzhiyun LINK_STATUS = 0x02, 576*4882a593Smuzhiyun FULL_DUP = 0x01, 577*4882a593Smuzhiyun }; 578*4882a593Smuzhiyun 579*4882a593Smuzhiyun struct r8152 { 580*4882a593Smuzhiyun struct usb_device *udev; 581*4882a593Smuzhiyun struct usb_interface *intf; 582*4882a593Smuzhiyun bool supports_gmii; 583*4882a593Smuzhiyun 584*4882a593Smuzhiyun struct rtl_ops { 585*4882a593Smuzhiyun void (*init)(struct r8152 *); 586*4882a593Smuzhiyun int (*enable)(struct r8152 *); 587*4882a593Smuzhiyun void (*disable)(struct r8152 *); 588*4882a593Smuzhiyun void (*up)(struct r8152 *); 589*4882a593Smuzhiyun void (*down)(struct r8152 *); 590*4882a593Smuzhiyun void (*unload)(struct r8152 *); 591*4882a593Smuzhiyun } rtl_ops; 592*4882a593Smuzhiyun 593*4882a593Smuzhiyun u32 coalesce; 594*4882a593Smuzhiyun u16 ocp_base; 595*4882a593Smuzhiyun 596*4882a593Smuzhiyun u8 version; 597*4882a593Smuzhiyun 598*4882a593Smuzhiyun #ifdef CONFIG_DM_ETH 599*4882a593Smuzhiyun struct ueth_data ueth; 600*4882a593Smuzhiyun #endif 601*4882a593Smuzhiyun }; 602*4882a593Smuzhiyun 603*4882a593Smuzhiyun int generic_ocp_write(struct r8152 *tp, u16 index, u16 byteen, 604*4882a593Smuzhiyun u16 size, void *data, u16 type); 605*4882a593Smuzhiyun int generic_ocp_read(struct r8152 *tp, u16 index, u16 size, 606*4882a593Smuzhiyun void *data, u16 type); 607*4882a593Smuzhiyun 608*4882a593Smuzhiyun int pla_ocp_read(struct r8152 *tp, u16 index, u16 size, void *data); 609*4882a593Smuzhiyun int pla_ocp_write(struct r8152 *tp, u16 index, u16 byteen, 610*4882a593Smuzhiyun u16 size, void *data); 611*4882a593Smuzhiyun 612*4882a593Smuzhiyun int usb_ocp_read(struct r8152 *tp, u16 index, u16 size, void *data); 613*4882a593Smuzhiyun int usb_ocp_write(struct r8152 *tp, u16 index, u16 byteen, 614*4882a593Smuzhiyun u16 size, void *data); 615*4882a593Smuzhiyun 616*4882a593Smuzhiyun u32 ocp_read_dword(struct r8152 *tp, u16 type, u16 index); 617*4882a593Smuzhiyun void ocp_write_dword(struct r8152 *tp, u16 type, u16 index, u32 data); 618*4882a593Smuzhiyun 619*4882a593Smuzhiyun u16 ocp_read_word(struct r8152 *tp, u16 type, u16 index); 620*4882a593Smuzhiyun void ocp_write_word(struct r8152 *tp, u16 type, u16 index, u32 data); 621*4882a593Smuzhiyun 622*4882a593Smuzhiyun u8 ocp_read_byte(struct r8152 *tp, u16 type, u16 index); 623*4882a593Smuzhiyun void ocp_write_byte(struct r8152 *tp, u16 type, u16 index, u32 data); 624*4882a593Smuzhiyun 625*4882a593Smuzhiyun u16 ocp_reg_read(struct r8152 *tp, u16 addr); 626*4882a593Smuzhiyun void ocp_reg_write(struct r8152 *tp, u16 addr, u16 data); 627*4882a593Smuzhiyun 628*4882a593Smuzhiyun void sram_write(struct r8152 *tp, u16 addr, u16 data); 629*4882a593Smuzhiyun 630*4882a593Smuzhiyun int r8152_wait_for_bit(struct r8152 *tp, bool ocp_reg, u16 type, u16 index, 631*4882a593Smuzhiyun const u32 mask, bool set, unsigned int timeout); 632*4882a593Smuzhiyun 633*4882a593Smuzhiyun void r8152b_firmware(struct r8152 *tp); 634*4882a593Smuzhiyun void r8153_firmware(struct r8152 *tp); 635*4882a593Smuzhiyun #endif 636