/* SPDX-License-Identifier: GPL-2.0 */ /* * Copyright (c) 2019 MediaTek Inc. */ #ifdef CONFIG_PROJECT_PHY #ifndef __MTK_PROJECT_PHY__H #define __MTK_PROJECT_PHY__H extern void __iomem *u3_sif2_base; #define SSUSB_SIFSLV_SPLLC_BASE (u3_sif2_base+0x700) #define SSUSB_SIFSLV_U2PHY_COM_BASE (u3_sif2_base+0x300) #define SSUSB_SIFSLV_U3PHYD_BASE (u3_sif2_base+0x900) #define SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE (u3_sif2_base+0x300) #define SSUSB_USB30_PHYA_SIV_B2_BASE (u3_sif2_base+0xA00) #define SSUSB_USB30_PHYA_SIV_B_BASE (u3_sif2_base+0xB00) #define SSUSB_SIFSLV_U3PHYA_DA_BASE (u3_sif2_base+0xC00) #define SSUSB_SIFSLV_CHIP_BASE (u3_sif2_base+0x800) #define SSUSB_SIFSLV_FM_BASE (u3_sif2_base+0x100) /* referenecd from ssusb_USB20_PHY_regmap_com_T28HPM.xls */ #define U3D_USBPHYACR0 (SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE+0x0000) /*2:30 SIV_B */ #define U3D_USBPHYACR1 (SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE+0x0004) /*0:23 SIV_B */ #define U3D_USBPHYACR2 (SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE+0x0008) /*0:15 SIV_B */ #define U3D_USBPHYACR4 (SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE+0x0010) /*0:31 SIV_B */ #define U3D_USBPHYACR5 (SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE+0x0014) /*0:28 SIV_B */ #define U3D_USBPHYACR6 (SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE+0x0018) /*0:31 SIV_B */ #define U3D_U2PHYACR3 (SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE+0x001c) /*0:31 SIV_B */ #define U3D_U2PHYACR4_0 (SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE+0x0020) /*0:5 SIV_B */ #define U3D_USBPHYACR2_0 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0008) /* 16:18 */ #define U3D_U2PHYACR4 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0020) /*8:18 */ #define U3D_U2PHYAMON0 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0024) /*0:1 */ #define U3D_U2PHYDCR0 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0060) /*0:31 */ #define U3D_U2PHYDCR1 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0064) /*0:31 */ #define U3D_U2PHYDTM0 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0068) /*0:31 */ #define U3D_U2PHYDTM1 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x006C) /*0:31 */ #define U3D_U2PHYDMON0 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0070) /*0:7 */ #define U3D_U2PHYDMON1 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0074) /*0:31 */ #define U3D_U2PHYDMON2 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0078) /*0:31 */ #define U3D_U2PHYDMON3 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x007C) /*0:31 */ #define U3D_U2PHYBC12C (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0080) /*0:31 */ #define U3D_U2PHYBC12C1 (SSUSB_SIFSLV_U2PHY_COM_BASE+0x0084) /*0:7 */ #define U3D_U2PHYREGFPPC (SSUSB_SIFSLV_U2PHY_COM_BASE+0x00e0) /*0:4 */ #define U3D_U2PHYVERSIONC (SSUSB_SIFSLV_U2PHY_COM_BASE+0x00f0) /*0:31 */ #define U3D_U2PHYREGFCOM (SSUSB_SIFSLV_U2PHY_COM_BASE+0x00fc) /*16:31 */ #define U3D_USB30_PHYA_REG0 (SSUSB_USB30_PHYA_SIV_B_BASE+0x0000) #define U3D_USB30_PHYA_REG1 (SSUSB_USB30_PHYA_SIV_B_BASE+0x0004) #define U3D_USB30_PHYA_REG6 (SSUSB_USB30_PHYA_SIV_B_BASE+0x0018) #define U3D_PHYD_CDR1 (SSUSB_SIFSLV_U3PHYD_BASE+0x5c) #define U3D_U3PHYA_DA_REG0 (SSUSB_SIFSLV_U3PHYA_DA_BASE+0x0) #define U3D_U3PHYA_DA_REG36 (SSUSB_SIFSLV_U3PHYA_DA_BASE+0x0070) #define U3D_SPLLC_XTALCTL3 (SSUSB_SIFSLV_SPLLC_BASE+0x18) #define U3D_PHYA_REG6 (SSUSB_USB30_PHYA_SIV_B_BASE+0x18) #define U3D_PHYD_RXDET2 (SSUSB_USB30_PHYA_SIV_B2_BASE+0x2c) #define U3D_PHYD_IMPCAL0 (SSUSB_SIFSLV_U3PHYD_BASE+0x10) #define U3D_PHYD_IMPCAL1 (SSUSB_SIFSLV_U3PHYD_BASE+0x14) #define U2_SR_COEF_E60802 28 /* U3D_USB30_PHYA_REG1 */ #define RG_SSUSB_VUSB09_ON (1<<29) #define RG_SSUSB_VUSB09_ON_OFST (29) /* ///////////////////////////////////////////////////////////////////////////// */ struct u2phy_reg_e { /* 0x0 */ PHY_LE32 usbphyacr0; PHY_LE32 usbphyacr1; PHY_LE32 usbphyacr2; PHY_LE32 reserve0; /* 0x10 */ PHY_LE32 usbphyacr4; PHY_LE32 usbphyacr5; PHY_LE32 usbphyacr6; PHY_LE32 u2phyacr3; /* 0x20 */ PHY_LE32 u2phyacr4; PHY_LE32 u2phyamon0; PHY_LE32 reserve1[2]; /* 0x30~0x50 */ PHY_LE32 reserve2[12]; /* 0x60 */ PHY_LE32 u2phydcr0; PHY_LE32 u2phydcr1; PHY_LE32 u2phydtm0; PHY_LE32 u2phydtm1; /* 0x70 */ PHY_LE32 u2phydmon0; PHY_LE32 u2phydmon1; PHY_LE32 u2phydmon2; PHY_LE32 u2phydmon3; /* 0x80 */ PHY_LE32 u2phybc12c; PHY_LE32 u2phybc12c1; PHY_LE32 reserve3[2]; /* 0x90~0xd0 */ PHY_LE32 reserve4[20]; /* 0xe0 */ PHY_LE32 regfppc; PHY_LE32 reserve5[3]; /* 0xf0 */ PHY_LE32 versionc; PHY_LE32 reserve6[2]; PHY_LE32 regfcom; }; /* U3D_USBPHYACR0 */ #define RG_USB20_MPX_OUT_SEL (0x7<<28) /* 30:28 */ #define RG_USB20_TX_PH_ROT_SEL (0x7<<24) /* 26:24 */ #define RG_USB20_PLL_DIVEN (0x7<<20) /* 22:20 */ #define RG_USB20_PLL_BR (0x1<<18) /* 18:18 */ #define RG_USB20_PLL_BP (0x1<<17) /* 17:17 */ #define RG_USB20_PLL_BLP (0x1<<16) /* 16:16 */ #define RG_USB20_USBPLL_FORCE_ON (0x1<<15) /* 15:15 */ #define RG_USB20_PLL_FBDIV (0x7f<<8) /* 14:8 */ #define RG_USB20_PLL_PREDIV (0x3<<6) /* 7:6 */ #define RG_USB20_INTR_EN (0x1<<5) /* 5:5 */ #define RG_USB20_REF_EN (0x1<<4) /* 4:4 */ #define RG_USB20_BGR_DIV (0x3<<2) /* 3:2 */ #define RG_SIFSLV_CHP_EN (0x1<<1) /* 1:1 */ #define RG_SIFSLV_BGR_EN (0x1<<0) /* 0:0 */ /* U3D_USBPHYACR1 */ #define RG_USB20_INTR_CAL (0x1f<<19) /* 23:19 */ #define RG_USB20_OTG_VBUSTH (0x7<<16) /* 18:16 */ #define RG_USB20_VRT_VREF_SEL (0x7<<12) /* 14:12 */ #define RG_USB20_TERM_VREF_SEL (0x7<<8) /* 10:8 */ #define RG_USB20_MPX_SEL (0xff<<0) /* 7:0 */ /* U3D_USBPHYACR2 */ #define RG_SIFSLV_MAC_BANDGAP_EN (0x1<<17) /* 17:17 */ #define RG_SIFSLV_MAC_CHOPPER_EN (0x1<<16) /* 16:16 */ #define RG_USB20_CLKREF_REV (0xffff<<0) /* 15:0 */ /* U3D_USBPHYACR2_0 */ #define RG_SIFSLV_USB20_PLL_FORCE_MODE (0x1<<18) /* 18:18 */ /* U3D_USBPHYACR4 */ #define RG_USB20_DP_ABIST_SOURCE_EN (0x1<<31) /* 31:31 */ #define RG_USB20_DP_ABIST_SELE (0xf<<24) /* 27:24 */ #define RG_USB20_ICUSB_EN (0x1<<16) /* 16:16 */ #define RG_USB20_LS_CR (0x7<<12) /* 14:12 */ #define RG_USB20_FS_CR (0x7<<8) /* 10:8 */ #define RG_USB20_LS_SR (0x7<<4) /* 6:4 */ #define RG_USB20_FS_SR (0x7<<0) /* 2:0 */ /* U3D_USBPHYACR5 */ #define RG_USB20_DISC_FIT_EN (0x1<<28) /* 28:28 */ #define RG_USB20_INIT_SQ_EN_DG (0x3<<26) /* 27:26 */ #define RG_USB20_HSTX_TMODE_SEL (0x3<<24) /* 25:24 */ #define RG_USB20_SQD (0x3<<22) /* 23:22 */ #define RG_USB20_DISCD (0x3<<20) /* 21:20 */ #define RG_USB20_HSTX_TMODE_EN (0x1<<19) /* 19:19 */ #define RG_USB20_PHYD_MONEN (0x1<<18) /* 18:18 */ #define RG_USB20_INLPBK_EN (0x1<<17) /* 17:17 */ #define RG_USB20_CHIRP_EN (0x1<<16) /* 16:16 */ #define RG_USB20_HSTX_SRCAL_EN (0x1<<15) /* 15:15 */ #define RG_USB20_HSTX_SRCTRL (0x7<<12) /* 14:12 */ #define RG_USB20_HS_100U_U3_EN (0x1<<11) /* 11:11 */ #define RG_USB20_GBIAS_ENB (0x1<<10) /* 10:10 */ #define RG_USB20_DM_ABIST_SOURCE_EN (0x1<<7) /* 7:7 */ #define RG_USB20_DM_ABIST_SELE (0xf<<0) /* 3:0 */ /* U3D_USBPHYACR6 */ #define RG_USB20_PHY_REV_6 (0x3<<30) /* 31:31 */ #define RG_USB20_PHY_REV (0xef<<24) /* 31:24 */ #define RG_USB20_BC11_SW_EN (0x1<<23) /* 23:23 */ #define RG_USB20_SR_CLK_SEL (0x1<<22) /* 22:22 */ #define RG_USB20_OTG_VBUSCMP_EN (0x1<<20) /* 20:20 */ #define RG_USB20_OTG_ABIST_EN (0x1<<19) /* 19:19 */ #define RG_USB20_OTG_ABIST_SELE (0x7<<16) /* 18:16 */ #define RG_USB20_HSRX_MMODE_SELE (0x3<<12) /* 13:12 */ #define RG_USB20_HSRX_BIAS_EN_SEL (0x3<<9) /* 10:9 */ #define RG_USB20_HSRX_TMODE_EN (0x1<<8) /* 8:8 */ #define RG_USB20_DISCTH (0xf<<4) /* 7:4 */ #define RG_USB20_SQTH (0xf<<0) /* 3:0 */ /* U3D_U2PHYACR3 */ #define RG_USB20_HSTX_DBIST (0xf<<28) /* 31:28 */ #define RG_USB20_HSTX_BIST_EN (0x1<<26) /* 26:26 */ #define RG_USB20_HSTX_I_EN_MODE (0x3<<24) /* 25:24 */ #define RG_USB20_USB11_TMODE_EN (0x1<<19) /* 19:19 */ #define RG_USB20_TMODE_FS_LS_TX_EN (0x1<<18) /* 18:18 */ #define RG_USB20_TMODE_FS_LS_RCV_EN (0x1<<17) /* 17:17 */ #define RG_USB20_TMODE_FS_LS_MODE (0x1<<16) /* 16:16 */ #define RG_USB20_HS_TERM_EN_MODE (0x3<<13) /* 14:13 */ #define RG_USB20_PUPD_BIST_EN (0x1<<12) /* 12:12 */ #define RG_USB20_EN_PU_DM (0x1<<11) /* 11:11 */ #define RG_USB20_EN_PD_DM (0x1<<10) /* 10:10 */ #define RG_USB20_EN_PU_DP (0x1<<9) /* 9:9 */ #define RG_USB20_EN_PD_DP (0x1<<8) /* 8:8 */ /* U3D_U2PHYACR4 */ #define RG_USB20_DP_100K_MODE (0x1<<18) /* 18:18 */ #define RG_USB20_DM_100K_EN (0x1<<17) /* 17:17 */ #define USB20_DP_100K_EN (0x1<<16) /* 16:16 */ #define USB20_GPIO_DM_I (0x1<<15) /* 15:15 */ #define USB20_GPIO_DP_I (0x1<<14) /* 14:14 */ #define USB20_GPIO_DM_OE (0x1<<13) /* 13:13 */ #define USB20_GPIO_DP_OE (0x1<<12) /* 12:12 */ #define RG_USB20_GPIO_CTL (0x1<<9) /* 9:9 */ #define USB20_GPIO_MODE (0x1<<8) /* 8:8 */ #define RG_USB20_TX_BIAS_EN (0x1<<5) /* 5:5 */ #define RG_USB20_TX_VCMPDN_EN (0x1<<4) /* 4:4 */ #define RG_USB20_HS_SQ_EN_MODE (0x3<<2) /* 3:2 */ #define RG_USB20_HS_RCV_EN_MODE (0x3<<0) /* 1:0 */ /* U3D_U2PHYAMON0 */ #define RGO_USB20_GPIO_DM_O (0x1<<1) /* 1:1 */ #define RGO_USB20_GPIO_DP_O (0x1<<0) /* 0:0 */ /* U3D_U2PHYDCR0 */ #define RG_USB20_CDR_TST (0x3<<30) /* 31:30 */ #define RG_USB20_GATED_ENB (0x1<<29) /* 29:29 */ #define RG_USB20_TESTMODE (0x3<<26) /* 27:26 */ #define RG_SIFSLV_USB20_PLL_STABLE (0x1<<25) /* 25:25 */ #define RG_SIFSLV_USB20_PLL_FORCE_ON (0x1<<24) /* 24:24 */ #define RG_USB20_PHYD_RESERVE (0xffff<<8) /* 23:8 */ #define RG_USB20_EBTHRLD (0x1<<7) /* 7:7 */ #define RG_USB20_EARLY_HSTX_I (0x1<<6) /* 6:6 */ #define RG_USB20_TX_TST (0x1<<5) /* 5:5 */ #define RG_USB20_NEGEDGE_ENB (0x1<<4) /* 4:4 */ #define RG_USB20_CDR_FILT (0xf<<0) /* 3:0 */ /* U3D_U2PHYDCR1 */ #define RG_USB20_PROBE_SEL (0xff<<24) /* 31:24 */ #define RG_USB20_DRVVBUS (0x1<<23) /* 23:23 */ #define RG_DEBUG_EN (0x1<<22) /* 22:22 */ #define RG_USB20_OTG_PROBE (0x3<<20) /* 21:20 */ #define RG_USB20_SW_PLLMODE (0x3<<18) /* 19:18 */ #define E60802_RG_USB20_SW_PLLMODE (0x3<<18) /* 19:18 */ #define RG_USB20_BERTH (0x3<<16) /* 17:16 */ #define RG_USB20_LBMODE (0x3<<13) /* 14:13 */ #define RG_USB20_FORCE_TAP (0x1<<12) /* 12:12 */ #define RG_USB20_TAPSEL (0xfff<<0) /* 11:0 */ /* U3D_U2PHYDTM0 */ #define RG_UART_MODE (0x3<<30) /* 31:30 */ #define FORCE_UART_I (0x1<<29) /* 29:29 */ #define FORCE_UART_BIAS_EN (0x1<<28) /* 28:28 */ #define FORCE_UART_TX_OE (0x1<<27) /* 27:27 */ #define FORCE_UART_EN (0x1<<26) /* 26:26 */ #define FORCE_USB_CLKEN (0x1<<25) /* 25:25 */ #define FORCE_DRVVBUS (0x1<<24) /* 24:24 */ #define FORCE_DATAIN (0x1<<23) /* 23:23 */ #define FORCE_TXVALID (0x1<<22) /* 22:22 */ #define FORCE_DM_PULLDOWN (0x1<<21) /* 21:21 */ #define FORCE_DP_PULLDOWN (0x1<<20) /* 20:20 */ #define FORCE_XCVRSEL (0x1<<19) /* 19:19 */ #define FORCE_SUSPENDM (0x1<<18) /* 18:18 */ #define FORCE_TERMSEL (0x1<<17) /* 17:17 */ #define FORCE_OPMODE (0x1<<16) /* 16:16 */ #define UTMI_MUXSEL (0x1<<15) /* 15:15 */ #define RG_RESET (0x1<<14) /* 14:14 */ #define RG_DATAIN (0xf<<10) /* 13:10 */ #define RG_TXVALIDH (0x1<<9) /* 9:9 */ #define RG_TXVALID (0x1<<8) /* 8:8 */ #define RG_DMPULLDOWN (0x1<<7) /* 7:7 */ #define RG_DPPULLDOWN (0x1<<6) /* 6:6 */ #define RG_XCVRSEL (0x3<<4) /* 5:4 */ #define RG_SUSPENDM (0x1<<3) /* 3:3 */ #define RG_TERMSEL (0x1<<2) /* 2:2 */ #define RG_OPMODE (0x3<<0) /* 1:0 */ /* U3D_U2PHYDTM1 */ #define RG_USB20_PRBS7_EN (0x1<<31) /* 31:31 */ #define RG_USB20_PRBS7_BITCNT (0x3f<<24) /* 29:24 */ #define RG_USB20_CLK48M_EN (0x1<<23) /* 23:23 */ #define RG_USB20_CLK60M_EN (0x1<<22) /* 22:22 */ #define RG_UART_I (0x1<<19) /* 19:19 */ #define RG_UART_BIAS_EN (0x1<<18) /* 18:18 */ #define RG_UART_TX_OE (0x1<<17) /* 17:17 */ #define RG_UART_EN (0x1<<16) /* 16:16 */ #define FORCE_LINESTATE (0x1<<14) /* 14:14 */ #define FORCE_VBUSVALID (0x1<<13) /* 13:13 */ #define FORCE_SESSEND (0x1<<12) /* 12:12 */ #define FORCE_BVALID (0x1<<11) /* 11:11 */ #define FORCE_AVALID (0x1<<10) /* 10:10 */ #define FORCE_IDDIG (0x1<<9) /* 9:9 */ #define FORCE_IDPULLUP (0x1<<8) /* 8:8 */ #define RG_LINESTATE (0x3<<6) /* 7:6 */ #define RG_VBUSVALID (0x1<<5) /* 5:5 */ #define RG_SESSEND (0x1<<4) /* 4:4 */ #define RG_BVALID (0x1<<3) /* 3:3 */ #define RG_AVALID (0x1<<2) /* 2:2 */ #define RG_IDDIG (0x1<<1) /* 1:1 */ #define RG_IDPULLUP (0x1<<0) /* 0:0 */ /* U3D_U2PHYDMON0 */ #define RG_USB20_PRBS7_BERTH (0xff<<0) /* 7:0 */ /* U3D_U2PHYDMON1 */ #define USB20_UART_O (0x1<<31) /* 31:31 */ #define RGO_USB20_LB_PASS (0x1<<30) /* 30:30 */ #define RGO_USB20_LB_DONE (0x1<<29) /* 29:29 */ #define AD_USB20_BVALID (0x1<<28) /* 28:28 */ #define USB20_IDDIG (0x1<<27) /* 27:27 */ #define AD_USB20_VBUSVALID (0x1<<26) /* 26:26 */ #define AD_USB20_SESSEND (0x1<<25) /* 25:25 */ #define AD_USB20_AVALID (0x1<<24) /* 24:24 */ #define USB20_LINE_STATE (0x3<<22) /* 23:22 */ #define USB20_HST_DISCON (0x1<<21) /* 21:21 */ #define USB20_TX_READY (0x1<<20) /* 20:20 */ #define USB20_RX_ERROR (0x1<<19) /* 19:19 */ #define USB20_RX_ACTIVE (0x1<<18) /* 18:18 */ #define USB20_RX_VALIDH (0x1<<17) /* 17:17 */ #define USB20_RX_VALID (0x1<<16) /* 16:16 */ #define USB20_DATA_OUT (0xffff<<0) /* 15:0 */ /* U3D_U2PHYDMON2 */ #define RGO_TXVALID_CNT (0xff<<24) /* 31:24 */ #define RGO_RXACTIVE_CNT (0xff<<16) /* 23:16 */ #define RGO_USB20_LB_BERCNT (0xff<<8) /* 15:8 */ #define USB20_PROBE_OUT (0xff<<0) /* 7:0 */ /* U3D_U2PHYDMON3 */ #define RGO_USB20_PRBS7_ERRCNT (0xffff<<16) /* 31:16 */ #define RGO_USB20_PRBS7_DONE (0x1<<3) /* 3:3 */ #define RGO_USB20_PRBS7_LOCK (0x1<<2) /* 2:2 */ #define RGO_USB20_PRBS7_PASS (0x1<<1) /* 1:1 */ #define RGO_USB20_PRBS7_PASSTH (0x1<<0) /* 0:0 */ /* U3D_U2PHYBC12C */ #define RG_SIFSLV_CHGDT_DEGLCH_CNT (0xf<<28) /* 31:28 */ #define RG_SIFSLV_CHGDT_CTRL_CNT (0xf<<24) /* 27:24 */ #define RG_SIFSLV_CHGDT_FORCE_MODE (0x1<<16) /* 16:16 */ #define RG_CHGDT_ISRC_LEV (0x3<<14) /* 15:14 */ #define RG_CHGDT_VDATSRC (0x1<<13) /* 13:13 */ #define RG_CHGDT_BGVREF_SEL (0x7<<10) /* 12:10 */ #define RG_CHGDT_RDVREF_SEL (0x3<<8) /* 9:8 */ #define RG_CHGDT_ISRC_DP (0x1<<7) /* 7:7 */ #define RG_SIFSLV_CHGDT_OPOUT_DM (0x1<<6) /* 6:6 */ #define RG_CHGDT_VDAT_DM (0x1<<5) /* 5:5 */ #define RG_CHGDT_OPOUT_DP (0x1<<4) /* 4:4 */ #define RG_SIFSLV_CHGDT_VDAT_DP (0x1<<3) /* 3:3 */ #define RG_SIFSLV_CHGDT_COMP_EN (0x1<<2) /* 2:2 */ #define RG_SIFSLV_CHGDT_OPDRV_EN (0x1<<1) /* 1:1 */ #define RG_CHGDT_EN (0x1<<0) /* 0:0 */ /* U3D_U2PHYBC12C1 */ #define RG_CHGDT_REV (0xff<<0) /* 7:0 */ /* U3D_REGFPPC */ #define USB11_OTG_REG (0x1<<4) /* 4:4 */ #define USB20_OTG_REG (0x1<<3) /* 3:3 */ #define CHGDT_REG (0x1<<2) /* 2:2 */ #define USB11_REG (0x1<<1) /* 1:1 */ #define USB20_REG (0x1<<0) /* 0:0 */ /* U3D_VERSIONC */ #define VERSION_CODE_REGFILE (0xff<<24) /* 31:24 */ #define USB11_VERSION_CODE (0xff<<16) /* 23:16 */ #define VERSION_CODE_ANA (0xff<<8) /* 15:8 */ #define VERSION_CODE_DIG (0xff<<0) /* 7:0 */ /* U3D_REGFCOM */ #define RG_PAGE (0xff<<24) /* 31:24 */ #define I2C_MODE (0x1<<16) /* 16:16 */ /* U3 PLL BAND*/ #define RG_SSUSB_DA_SSUSB_PLL_BAND (0x3F<<11) /* 17:11 */ /* OFFSET */ /* U3D_USBPHYACR0 */ #define RG_USB20_MPX_OUT_SEL_OFST (28) #define RG_USB20_TX_PH_ROT_SEL_OFST (24) #define RG_USB20_PLL_DIVEN_OFST (20) #define RG_USB20_PLL_BR_OFST (18) #define RG_USB20_PLL_BP_OFST (17) #define RG_USB20_PLL_BLP_OFST (16) #define RG_USB20_USBPLL_FORCE_ON_OFST (15) #define RG_USB20_PLL_FBDIV_OFST (8) #define RG_USB20_PLL_PREDIV_OFST (6) #define RG_USB20_INTR_EN_OFST (5) #define RG_USB20_REF_EN_OFST (4) #define RG_USB20_BGR_DIV_OFST (2) #define RG_SIFSLV_CHP_EN_OFST (1) #define RG_SIFSLV_BGR_EN_OFST (0) /* U3D_USBPHYACR1 */ #define RG_USB20_INTR_CAL_OFST (19) #define RG_USB20_OTG_VBUSTH_OFST (16) #define RG_USB20_VRT_VREF_SEL_OFST (12) #define RG_USB20_TERM_VREF_SEL_OFST (8) #define RG_USB20_MPX_SEL_OFST (0) /* U3D_USBPHYACR2 */ #define RG_SIFSLV_MAC_BANDGAP_EN_OFST (17) #define RG_SIFSLV_MAC_CHOPPER_EN_OFST (16) #define RG_USB20_CLKREF_REV_OFST (0) /* U3D_USBPHYACR2_0 */ #define RG_SIFSLV_USB20_PLL_FORCE_MODE_OFST (18) /* U3D_USBPHYACR4 */ #define RG_USB20_DP_ABIST_SOURCE_EN_OFST (31) #define RG_USB20_DP_ABIST_SELE_OFST (24) #define RG_USB20_ICUSB_EN_OFST (16) #define RG_USB20_LS_CR_OFST (12) #define RG_USB20_FS_CR_OFST (8) #define RG_USB20_LS_SR_OFST (4) #define RG_USB20_FS_SR_OFST (0) /* U3D_USBPHYACR5 */ #define RG_USB20_DISC_FIT_EN_OFST (28) #define RG_USB20_INIT_SQ_EN_DG_OFST (26) #define RG_USB20_HSTX_TMODE_SEL_OFST (24) #define RG_USB20_SQD_OFST (22) #define RG_USB20_DISCD_OFST (20) #define RG_USB20_HSTX_TMODE_EN_OFST (19) #define RG_USB20_PHYD_MONEN_OFST (18) #define RG_USB20_INLPBK_EN_OFST (17) #define RG_USB20_CHIRP_EN_OFST (16) #define RG_USB20_HSTX_SRCAL_EN_OFST (15) #define RG_USB20_HSTX_SRCTRL_OFST (12) #define RG_USB20_HS_100U_U3_EN_OFST (11) #define RG_USB20_GBIAS_ENB_OFST (10) #define RG_USB20_DM_ABIST_SOURCE_EN_OFST (7) #define RG_USB20_DM_ABIST_SELE_OFST (0) /* U3D_USBPHYACR6 */ #define RG_USB20_PHY_REV_6_OFST (30) #define RG_USB20_PHY_REV_OFST (24) #define RG_USB20_BC11_SW_EN_OFST (23) #define RG_USB20_SR_CLK_SEL_OFST (22) #define RG_USB20_OTG_VBUSCMP_EN_OFST (20) #define RG_USB20_OTG_ABIST_EN_OFST (19) #define RG_USB20_OTG_ABIST_SELE_OFST (16) #define RG_USB20_HSRX_MMODE_SELE_OFST (12) #define RG_USB20_HSRX_BIAS_EN_SEL_OFST (9) #define RG_USB20_HSRX_TMODE_EN_OFST (8) #define RG_USB20_DISCTH_OFST (4) #define RG_USB20_SQTH_OFST (0) /* U3D_U2PHYACR3 */ #define RG_USB20_HSTX_DBIST_OFST (28) #define RG_USB20_HSTX_BIST_EN_OFST (26) #define RG_USB20_HSTX_I_EN_MODE_OFST (24) #define RG_USB20_USB11_TMODE_EN_OFST (19) #define RG_USB20_TMODE_FS_LS_TX_EN_OFST (18) #define RG_USB20_TMODE_FS_LS_RCV_EN_OFST (17) #define RG_USB20_TMODE_FS_LS_MODE_OFST (16) #define RG_USB20_HS_TERM_EN_MODE_OFST (13) #define RG_USB20_PUPD_BIST_EN_OFST (12) #define RG_USB20_EN_PU_DM_OFST (11) #define RG_USB20_EN_PD_DM_OFST (10) #define RG_USB20_EN_PU_DP_OFST (9) #define RG_USB20_EN_PD_DP_OFST (8) /* U3D_U2PHYACR4 */ #define RG_USB20_DP_100K_MODE_OFST (18) #define RG_USB20_DM_100K_EN_OFST (17) #define USB20_DP_100K_EN_OFST (16) #define USB20_GPIO_DM_I_OFST (15) #define USB20_GPIO_DP_I_OFST (14) #define USB20_GPIO_DM_OE_OFST (13) #define USB20_GPIO_DP_OE_OFST (12) #define RG_USB20_GPIO_CTL_OFST (9) #define USB20_GPIO_MODE_OFST (8) #define RG_USB20_TX_BIAS_EN_OFST (5) #define RG_USB20_TX_VCMPDN_EN_OFST (4) #define RG_USB20_HS_SQ_EN_MODE_OFST (2) #define RG_USB20_HS_RCV_EN_MODE_OFST (0) /* U3D_U2PHYAMON0 */ #define RGO_USB20_GPIO_DM_O_OFST (1) #define RGO_USB20_GPIO_DP_O_OFST (0) /* U3D_U2PHYDCR0 */ #define RG_USB20_CDR_TST_OFST (30) #define RG_USB20_GATED_ENB_OFST (29) #define RG_USB20_TESTMODE_OFST (26) #define RG_SIFSLV_USB20_PLL_STABLE_OFST (25) #define RG_SIFSLV_USB20_PLL_FORCE_ON_OFST (24) #define RG_USB20_PHYD_RESERVE_OFST (8) #define RG_USB20_EBTHRLD_OFST (7) #define RG_USB20_EARLY_HSTX_I_OFST (6) #define RG_USB20_TX_TST_OFST (5) #define RG_USB20_NEGEDGE_ENB_OFST (4) #define RG_USB20_CDR_FILT_OFST (0) /* U3D_U2PHYDCR1 */ #define RG_USB20_PROBE_SEL_OFST (24) #define RG_USB20_DRVVBUS_OFST (23) #define RG_DEBUG_EN_OFST (22) #define RG_USB20_OTG_PROBE_OFST (20) #define RG_USB20_SW_PLLMODE_OFST (18) #define E60802_RG_USB20_SW_PLLMODE_OFST (18) #define RG_USB20_BERTH_OFST (16) #define RG_USB20_LBMODE_OFST (13) #define RG_USB20_FORCE_TAP_OFST (12) #define RG_USB20_TAPSEL_OFST (0) /* U3D_U2PHYDTM0 */ #define RG_UART_MODE_OFST (30) #define FORCE_UART_I_OFST (29) #define FORCE_UART_BIAS_EN_OFST (28) #define FORCE_UART_TX_OE_OFST (27) #define FORCE_UART_EN_OFST (26) #define FORCE_USB_CLKEN_OFST (25) #define FORCE_DRVVBUS_OFST (24) #define FORCE_DATAIN_OFST (23) #define FORCE_TXVALID_OFST (22) #define FORCE_DM_PULLDOWN_OFST (21) #define FORCE_DP_PULLDOWN_OFST (20) #define FORCE_XCVRSEL_OFST (19) #define FORCE_SUSPENDM_OFST (18) #define FORCE_TERMSEL_OFST (17) #define FORCE_OPMODE_OFST (16) #define UTMI_MUXSEL_OFST (15) #define RG_RESET_OFST (14) #define RG_DATAIN_OFST (10) #define RG_TXVALIDH_OFST (9) #define RG_TXVALID_OFST (8) #define RG_DMPULLDOWN_OFST (7) #define RG_DPPULLDOWN_OFST (6) #define RG_XCVRSEL_OFST (4) #define RG_SUSPENDM_OFST (3) #define RG_TERMSEL_OFST (2) #define RG_OPMODE_OFST (0) /* U3D_U2PHYDTM1 */ #define RG_USB20_PRBS7_EN_OFST (31) #define RG_USB20_PRBS7_BITCNT_OFST (24) #define RG_USB20_CLK48M_EN_OFST (23) #define RG_USB20_CLK60M_EN_OFST (22) #define RG_UART_I_OFST (19) #define RG_UART_BIAS_EN_OFST (18) #define RG_UART_TX_OE_OFST (17) #define RG_UART_EN_OFST (16) #define FORCE_LINESTATE_OFST (14) #define FORCE_VBUSVALID_OFST (13) #define FORCE_SESSEND_OFST (12) #define FORCE_BVALID_OFST (11) #define FORCE_AVALID_OFST (10) #define FORCE_IDDIG_OFST (9) #define FORCE_IDPULLUP_OFST (8) #define RG_LINESTATE_OFST (6) #define RG_VBUSVALID_OFST (5) #define RG_SESSEND_OFST (4) #define RG_BVALID_OFST (3) #define RG_AVALID_OFST (2) #define RG_IDDIG_OFST (1) #define RG_IDPULLUP_OFST (0) /* U3D_U2PHYDMON0 */ #define RG_USB20_PRBS7_BERTH_OFST (0) /* U3D_U2PHYDMON1 */ #define USB20_UART_O_OFST (31) #define RGO_USB20_LB_PASS_OFST (30) #define RGO_USB20_LB_DONE_OFST (29) #define AD_USB20_BVALID_OFST (28) #define USB20_IDDIG_OFST (27) #define AD_USB20_VBUSVALID_OFST (26) #define AD_USB20_SESSEND_OFST (25) #define AD_USB20_AVALID_OFST (24) #define USB20_LINE_STATE_OFST (22) #define USB20_HST_DISCON_OFST (21) #define USB20_TX_READY_OFST (20) #define USB20_RX_ERROR_OFST (19) #define USB20_RX_ACTIVE_OFST (18) #define USB20_RX_VALIDH_OFST (17) #define USB20_RX_VALID_OFST (16) #define USB20_DATA_OUT_OFST (0) /* U3D_U2PHYDMON2 */ #define RGO_TXVALID_CNT_OFST (24) #define RGO_RXACTIVE_CNT_OFST (16) #define RGO_USB20_LB_BERCNT_OFST (8) #define USB20_PROBE_OUT_OFST (0) /* U3D_U2PHYDMON3 */ #define RGO_USB20_PRBS7_ERRCNT_OFST (16) #define RGO_USB20_PRBS7_DONE_OFST (3) #define RGO_USB20_PRBS7_LOCK_OFST (2) #define RGO_USB20_PRBS7_PASS_OFST (1) #define RGO_USB20_PRBS7_PASSTH_OFST (0) /* U3D_U2PHYBC12C */ #define RG_SIFSLV_CHGDT_DEGLCH_CNT_OFST (28) #define RG_SIFSLV_CHGDT_CTRL_CNT_OFST (24) #define RG_SIFSLV_CHGDT_FORCE_MODE_OFST (16) #define RG_CHGDT_ISRC_LEV_OFST (14) #define RG_CHGDT_VDATSRC_OFST (13) #define RG_CHGDT_BGVREF_SEL_OFST (10) #define RG_CHGDT_RDVREF_SEL_OFST (8) #define RG_CHGDT_ISRC_DP_OFST (7) #define RG_SIFSLV_CHGDT_OPOUT_DM_OFST (6) #define RG_CHGDT_VDAT_DM_OFST (5) #define RG_CHGDT_OPOUT_DP_OFST (4) #define RG_SIFSLV_CHGDT_VDAT_DP_OFST (3) #define RG_SIFSLV_CHGDT_COMP_EN_OFST (2) #define RG_SIFSLV_CHGDT_OPDRV_EN_OFST (1) #define RG_CHGDT_EN_OFST (0) /* U3D_U2PHYBC12C1 */ #define RG_CHGDT_REV_OFST (0) /* U3D_REGFPPC */ #define USB11_OTG_REG_OFST (4) #define USB20_OTG_REG_OFST (3) #define CHGDT_REG_OFST (2) #define USB11_REG_OFST (1) #define USB20_REG_OFST (0) /* U3D_VERSIONC */ #define VERSION_CODE_REGFILE_OFST (24) #define USB11_VERSION_CODE_OFST (16) #define VERSION_CODE_ANA_OFST (8) #define VERSION_CODE_DIG_OFST (0) /* U3D_REGFCOM */ #define RG_PAGE_OFST (24) #define I2C_MODE_OFST (16) /* U3 PLL BAND*/ #define RG_SSUSB_DA_SSUSB_PLL_BAND_OFST (11) /* ///////////////////////////////////////////////////////////////////////////// */ struct u3phya_reg_e { /* 0x0 */ PHY_LE32 reg0; PHY_LE32 reg1; PHY_LE32 reg2; PHY_LE32 reg3; /* 0x10 */ PHY_LE32 reg4; PHY_LE32 reg5; PHY_LE32 reg6; PHY_LE32 reg7; /* 0x20 */ PHY_LE32 reg8; PHY_LE32 reg9; PHY_LE32 rega; PHY_LE32 regb; /* 0x30 */ PHY_LE32 regc; }; /* U3D_reg0 */ #define RG_SSUSB_BGR_EN (0x1<<31) /* 31:31 */ #define RG_SSUSB_CHPEN (0x1<<30) /* 30:30 */ #define RG_SSUSB_BG_DIV (0x3<<28) /* 29:28 */ #define RG_SSUSB_INTR_EN (0x1<<26) /* 26:26 */ #define RG_SSUSB_MPX_EN (0x1<<24) /* 24:24 */ #define RG_SSUSB_MPX_SEL (0xff<<16) /* 23:16 */ #define RG_SSUSB_IEXT_INTR_CTRL (0x3f<<10) /* 15:10 */ #define RG_SSUSB_VRT_VREF_SEL (0xf<<6) /* 9:6 */ #define RG_SSUSB_REF_EN (0x1<<5) /* 5:5 */ #define RG_SSUSB_BG_MONEN (0x1<<4) /* 4:4 */ #define RG_SSUSB_INT_BIAS_SEL (0x1<<3) /* 3:3 */ #define RG_SSUSB_EXT_BIAS_SEL (0x1<<2) /* 2:2 */ /* U3D_reg1 */ #define RG_PCIE_CLKDRV_AMP (0x7<<29) /* 31:29 */ #define RG_SSUSB_XTAL_TST_A2DCK_EN (0x1<<28) /* 28:28 */ #define RG_SSUSB_XTAL_MON_EN (0x1<<27) /* 27:27 */ #define RG_SSUSB_XTAL_HYS (0x1<<26) /* 26:26 */ #define RG_SSUSB_XTAL_TOP_RESERVE (0xffff<<10) /* 25:10 */ #define RG_SSUSB_SYSPLL_PREDIV (0x3<<8) /* 9:8 */ #define RG_SSUSB_SYSPLL_POSDIV (0x3<<6) /* 7:6 */ #define RG_SSUSB_SYSPLL_VCO_DIV_SEL (0x1<<5) /* 5:5 */ #define RG_SSUSB_SYSPLL_VOD_EN (0x1<<4) /* 4:4 */ #define RG_SSUSB_SYSPLL_RST_DLY (0x3<<2) /* 3:2 */ #define RG_SSUSB_SYSPLL_BLP (0x1<<1) /* 1:1 */ #define RG_SSUSB_SYSPLL_BP (0x1<<0) /* 0:0 */ /* U3D_reg2 */ #define RG_SSUSB_SYSPLL_BR (0x1<<31) /* 31:31 */ #define RG_SSUSB_SYSPLL_BC (0x1<<30) /* 30:30 */ #define RG_SSUSB_SYSPLL_MONCK_EN (0x1<<29) /* 29:29 */ #define RG_SSUSB_SYSPLL_MONVC_EN (0x1<<28) /* 28:28 */ #define RG_SSUSB_SYSPLL_MONREF_EN (0x1<<27) /* 27:27 */ #define RG_SSUSB_SYSPLL_SDM_IFM (0x1<<26) /* 26:26 */ #define RG_SSUSB_SYSPLL_SDM_OUT (0x1<<25) /* 25:25 */ #define RG_SSUSB_SYSPLL_BACK_EN (0x1<<24) /* 24:24 */ /* U3D_reg3 */ #define RG_SSUSB_SYSPLL_FBDIV (0x7fffffff<<1) /* 31:1 */ #define RG_SSUSB_SYSPLL_HR_EN (0x1<<0) /* 0:0 */ /* U3D_reg4 */ #define RG_SSUSB_SYSPLL_SDM_DI_EN (0x1<<31) /* 31:31 */ #define RG_SSUSB_SYSPLL_SDM_DI_LS (0x3<<29) /* 30:29 */ #define RG_SSUSB_SYSPLL_SDM_ORD (0x3<<27) /* 28:27 */ #define RG_SSUSB_SYSPLL_SDM_MODE (0x3<<25) /* 26:25 */ #define RG_SSUSB_SYSPLL_RESERVE (0xff<<17) /* 24:17 */ #define RG_SSUSB_SYSPLL_TOP_RESERVE (0xffff<<1) /* 16:1 */ /* U3D_reg5 */ #define RG_SSUSB_TX250MCK_INVB (0x1<<31) /* 31:31 */ #define RG_SSUSB_IDRV_ITAILOP_EN (0x1<<30) /* 30:30 */ #define RG_SSUSB_IDRV_CALIB (0x3f<<24) /* 29:24 */ #define RG_SSUSB_IDEM_BIAS (0xf<<20) /* 23:20 */ #define RG_SSUSB_TX_R50_FON (0x1<<19) /* 19:19 */ #define RG_SSUSB_TX_SR (0x7<<16) /* 18:16 */ #define RG_SSUSB_RXDET_RSEL (0x3<<14) /* 15:14 */ #define RG_SSUSB_RXDET_UPDN_FORCE (0x1<<13) /* 13:13 */ #define RG_SSUSB_RXDET_UPDN_SEL (0x1<<12) /* 12:12 */ #define RG_SSUSB_RXDET_VTHSEL_L (0x3<<10) /* 11:10 */ #define RG_SSUSB_RXDET_VTHSEL_H (0x3<<8) /* 9:8 */ #define RG_SSUSB_CKMON_EN (0x1<<7) /* 7:7 */ #define RG_SSUSB_TX_VLMON_EN (0x1<<6) /* 6:6 */ #define RG_SSUSB_TX_VLMON_SEL (0x3<<4) /* 5:4 */ #define RG_SSUSB_CKMON_SEL (0xf<<0) /* 3:0 */ /* U3D_reg6 */ #define RG_SSUSB_TX_EIDLE_CM (0xf<<28) /* 31:28 */ #define RG_SSUSB_RXLBTX_EN (0x1<<27) /* 27:27 */ #define RG_SSUSB_TXLBRX_EN (0x1<<26) /* 26:26 */ #define RG_SSUSB_RESERVE6 (0x1<<22) /* 22:22 */ #define RG_SSUSB_RESERVE (0x3ff<<16) /* 25:16 */ #define RG_SSUSB_PLL_POSDIV (0x3<<14) /* 15:14 */ #define RG_SSUSB_PLL_AUTOK_LOAD (0x1<<13) /* 13:13 */ #define RG_SSUSB_PLL_VOD_EN (0x1<<12) /* 12:12 */ #define RG_SSUSB_PLL_MONREF_EN (0x1<<11) /* 11:11 */ #define RG_SSUSB_PLL_MONCK_EN (0x1<<10) /* 10:10 */ #define RG_SSUSB_PLL_MONVC_EN (0x1<<9) /* 9:9 */ #define RG_SSUSB_PLL_RLH_EN (0x1<<8) /* 8:8 */ #define RG_SSUSB_PLL_AUTOK_KS (0x3<<6) /* 7:6 */ #define RG_SSUSB_PLL_AUTOK_KF (0x3<<4) /* 5:4 */ #define RG_SSUSB_PLL_RST_DLY (0x3<<2) /* 3:2 */ /* U3D_reg7 */ #define RG_SSUSB_PLL_RESERVE (0xffff<<16) /* 31:16 */ #define RG_SSUSB_PLL_SSC_PRD (0xffff<<0) /* 15:0 */ /* U3D_reg8 */ #define RG_SSUSB_PLL_SSC_PHASE_INI (0x1<<31) /* 31:31 */ #define RG_SSUSB_PLL_SSC_TRI_EN (0x1<<30) /* 30:30 */ #define RG_SSUSB_PLL_CLK_PH_INV (0x1<<29) /* 29:29 */ #define RG_SSUSB_PLL_DDS_LPF_EN (0x1<<28) /* 28:28 */ #define RG_SSUSB_PLL_DDS_RST_SEL (0x1<<27) /* 27:27 */ #define RG_SSUSB_PLL_DDS_VADJ (0x1<<26) /* 26:26 */ #define RG_SSUSB_PLL_DDS_MONEN (0x1<<25) /* 25:25 */ #define RG_SSUSB_PLL_DDS_SEL_EXT (0x1<<24) /* 24:24 */ #define RG_SSUSB_PLL_DDS_PI_PL_EN (0x1<<23) /* 23:23 */ #define RG_SSUSB_PLL_DDS_FRAC_MUTE (0x7<<20) /* 22:20 */ #define RG_SSUSB_PLL_DDS_HF_EN (0x1<<19) /* 19:19 */ #define RG_SSUSB_PLL_DDS_C (0x7<<16) /* 18:16 */ #define RG_SSUSB_PLL_DDS_PREDIV2 (0x1<<15) /* 15:15 */ #define RG_SSUSB_LFPS_LPF (0x3<<13) /* 14:13 */ /* U3D_reg9 */ #define RG_SSUSB_CDR_PD_DIV_BYPASS (0x1<<31) /* 31:31 */ #define RG_SSUSB_CDR_PD_DIV_SEL (0x1<<30) /* 30:30 */ #define RG_SSUSB_CDR_CPBIAS_SEL (0x1<<29) /* 29:29 */ #define RG_SSUSB_CDR_OSCDET_EN (0x1<<28) /* 28:28 */ #define RG_SSUSB_CDR_MONMUX (0x1<<27) /* 27:27 */ #define RG_SSUSB_CDR_RST_DLY (0x3<<25) /* 26:25 */ #define RG_SSUSB_CDR_RSTB_MANUAL (0x1<<24) /* 24:24 */ #define RG_SSUSB_CDR_BYPASS (0x3<<22) /* 23:22 */ #define RG_SSUSB_CDR_PI_SLEW (0x3<<20) /* 21:20 */ #define RG_SSUSB_CDR_EPEN (0x1<<19) /* 19:19 */ #define RG_SSUSB_CDR_AUTOK_LOAD (0x1<<18) /* 18:18 */ #define RG_SSUSB_CDR_MONEN (0x1<<16) /* 16:16 */ #define RG_SSUSB_CDR_MONEN_DIG (0x1<<15) /* 15:15 */ #define RG_SSUSB_CDR_REGOD (0x3<<13) /* 14:13 */ #define RG_SSUSB_CDR_AUTOK_KS (0x3<<11) /* 12:11 */ #define RG_SSUSB_CDR_AUTOK_KF (0x3<<9) /* 10:9 */ #define RG_SSUSB_RX_DAC_EN (0x1<<8) /* 8:8 */ #define RG_SSUSB_RX_DAC_PWD (0x1<<7) /* 7:7 */ #define RG_SSUSB_EQ_CURSEL (0x1<<6) /* 6:6 */ #define RG_SSUSB_RX_DAC_MUX (0x1f<<1) /* 5:1 */ #define RG_SSUSB_RX_R2T_EN (0x1<<0) /* 0:0 */ /* U3D_regA */ #define RG_SSUSB_RX_T2R_EN (0x1<<31) /* 31:31 */ #define RG_SSUSB_RX_50_LOWER (0x7<<28) /* 30:28 */ #define RG_SSUSB_RX_50_TAR (0x3<<26) /* 27:26 */ #define RG_SSUSB_RX_SW_CTRL (0xf<<21) /* 24:21 */ #define RG_PCIE_SIGDET_VTH (0x3<<19) /* 20:19 */ #define RG_PCIE_SIGDET_LPF (0x3<<17) /* 18:17 */ #define RG_SSUSB_LFPS_MON_EN (0x1<<16) /* 16:16 */ #define RG_SSUSB_RXAFE_DCMON_SEL (0xf<<12) /* 15:12 */ #define RG_SSUSB_RX_P1_ENTRY_PASS (0x1<<11) /* 11:11 */ #define RG_SSUSB_RX_PD_RST (0x1<<10) /* 10:10 */ #define RG_SSUSB_RX_PD_RST_PASS (0x1<<9) /* 9:9 */ /* U3D_regB */ #define RG_SSUSB_CDR_RESERVE (0xff<<24) /* 31:24 */ #define RG_SSUSB_RXAFE_RESERVE (0xff<<16) /* 23:16 */ #define RG_PCIE_RX_RESERVE (0xff<<8) /* 15:8 */ #define RG_SSUSB_VRT_25M_EN (0x1<<7) /* 7:7 */ #define RG_SSUSB_RX_PD_PICAL_SWAP (0x1<<6) /* 6:6 */ #define RG_SSUSB_RX_DAC_MEAS_EN (0x1<<5) /* 5:5 */ #define RG_SSUSB_MPX_SEL_L0 (0x1<<4) /* 4:4 */ #define RG_SSUSB_LFPS_SLCOUT_SEL (0x1<<3) /* 3:3 */ #define RG_SSUSB_LFPS_CMPOUT_SEL (0x1<<2) /* 2:2 */ #define RG_PCIE_SIGDET_HF (0x3<<0) /* 1:0 */ /* U3D_regC */ #define RGS_SSUSB_RX_DEBUG_RESERVE (0xff<<0) /* 7:0 */ /* OFFSET */ /* U3D_reg0 */ #define RG_SSUSB_BGR_EN_OFST (31) #define RG_SSUSB_CHPEN_OFST (30) #define RG_SSUSB_BG_DIV_OFST (28) #define RG_SSUSB_INTR_EN_OFST (26) #define RG_SSUSB_MPX_EN_OFST (24) #define RG_SSUSB_MPX_SEL_OFST (16) #define RG_SSUSB_IEXT_INTR_CTRL_OFST (10) #define RG_SSUSB_RG_SSUSB_VRT_VREF_SEL (6) #define RG_SSUSB_REF_EN_OFST (5) #define RG_SSUSB_BG_MONEN_OFST (4) #define RG_SSUSB_INT_BIAS_SEL_OFST (3) #define RG_SSUSB_EXT_BIAS_SEL_OFST (2) /* U3D_reg1 */ #define RG_PCIE_CLKDRV_AMP_OFST (29) #define RG_SSUSB_XTAL_TST_A2DCK_EN_OFST (28) #define RG_SSUSB_XTAL_MON_EN_OFST (27) #define RG_SSUSB_XTAL_HYS_OFST (26) #define RG_SSUSB_XTAL_TOP_RESERVE_OFST (10) #define RG_SSUSB_SYSPLL_PREDIV_OFST (8) #define RG_SSUSB_SYSPLL_POSDIV_OFST (6) #define RG_SSUSB_SYSPLL_VCO_DIV_SEL_OFST (5) #define RG_SSUSB_SYSPLL_VOD_EN_OFST (4) #define RG_SSUSB_SYSPLL_RST_DLY_OFST (2) #define RG_SSUSB_SYSPLL_BLP_OFST (1) #define RG_SSUSB_SYSPLL_BP_OFST (0) /* U3D_reg2 */ #define RG_SSUSB_SYSPLL_BR_OFST (31) #define RG_SSUSB_SYSPLL_BC_OFST (30) #define RG_SSUSB_SYSPLL_MONCK_EN_OFST (29) #define RG_SSUSB_SYSPLL_MONVC_EN_OFST (28) #define RG_SSUSB_SYSPLL_MONREF_EN_OFST (27) #define RG_SSUSB_SYSPLL_SDM_IFM_OFST (26) #define RG_SSUSB_SYSPLL_SDM_OUT_OFST (25) #define RG_SSUSB_SYSPLL_BACK_EN_OFST (24) /* U3D_reg3 */ #define RG_SSUSB_SYSPLL_FBDIV_OFST (1) #define RG_SSUSB_SYSPLL_HR_EN_OFST (0) /* U3D_reg4 */ #define RG_SSUSB_SYSPLL_SDM_DI_EN_OFST (31) #define RG_SSUSB_SYSPLL_SDM_DI_LS_OFST (29) #define RG_SSUSB_SYSPLL_SDM_ORD_OFST (27) #define RG_SSUSB_SYSPLL_SDM_MODE_OFST (25) #define RG_SSUSB_SYSPLL_RESERVE_OFST (17) #define RG_SSUSB_SYSPLL_TOP_RESERVE_OFST (1) /* U3D_reg5 */ #define RG_SSUSB_TX250MCK_INVB_OFST (31) #define RG_SSUSB_IDRV_ITAILOP_EN_OFST (30) #define RG_SSUSB_IDRV_CALIB_OFST (24) #define RG_SSUSB_IDEM_BIAS_OFST (20) #define RG_SSUSB_TX_R50_FON_OFST (19) #define RG_SSUSB_TX_SR_OFST (16) #define RG_SSUSB_RXDET_RSEL_OFST (14) #define RG_SSUSB_RXDET_UPDN_FORCE_OFST (13) #define RG_SSUSB_RXDET_UPDN_SEL_OFST (12) #define RG_SSUSB_RXDET_VTHSEL_L_OFST (10) #define RG_SSUSB_RXDET_VTHSEL_H_OFST (8) #define RG_SSUSB_CKMON_EN_OFST (7) #define RG_SSUSB_TX_VLMON_EN_OFST (6) #define RG_SSUSB_TX_VLMON_SEL_OFST (4) #define RG_SSUSB_CKMON_SEL_OFST (0) /* U3D_reg6 */ #define RG_SSUSB_TX_EIDLE_CM_OFST (28) #define RG_SSUSB_RXLBTX_EN_OFST (27) #define RG_SSUSB_TXLBRX_EN_OFST (26) #define RG_SSUSB_RESERVE6_OFST (22) #define RG_SSUSB_RESERVE_OFST (16) #define RG_SSUSB_PLL_POSDIV_OFST (14) #define RG_SSUSB_PLL_AUTOK_LOAD_OFST (13) #define RG_SSUSB_PLL_VOD_EN_OFST (12) #define RG_SSUSB_PLL_MONREF_EN_OFST (11) #define RG_SSUSB_PLL_MONCK_EN_OFST (10) #define RG_SSUSB_PLL_MONVC_EN_OFST (9) #define RG_SSUSB_PLL_RLH_EN_OFST (8) #define RG_SSUSB_PLL_AUTOK_KS_OFST (6) #define RG_SSUSB_PLL_AUTOK_KF_OFST (4) #define RG_SSUSB_PLL_RST_DLY_OFST (2) /* U3D_reg7 */ #define RG_SSUSB_PLL_RESERVE_OFST (16) #define RG_SSUSB_PLL_SSC_PRD_OFST (0) /* U3D_reg8 */ #define RG_SSUSB_PLL_SSC_PHASE_INI_OFST (31) #define RG_SSUSB_PLL_SSC_TRI_EN_OFST (30) #define RG_SSUSB_PLL_CLK_PH_INV_OFST (29) #define RG_SSUSB_PLL_DDS_LPF_EN_OFST (28) #define RG_SSUSB_PLL_DDS_RST_SEL_OFST (27) #define RG_SSUSB_PLL_DDS_VADJ_OFST (26) #define RG_SSUSB_PLL_DDS_MONEN_OFST (25) #define RG_SSUSB_PLL_DDS_SEL_EXT_OFST (24) #define RG_SSUSB_PLL_DDS_PI_PL_EN_OFST (23) #define RG_SSUSB_PLL_DDS_FRAC_MUTE_OFST (20) #define RG_SSUSB_PLL_DDS_HF_EN_OFST (19) #define RG_SSUSB_PLL_DDS_C_OFST (16) #define RG_SSUSB_PLL_DDS_PREDIV2_OFST (15) #define RG_SSUSB_LFPS_LPF_OFST (13) /* U3D_reg9 */ #define RG_SSUSB_CDR_PD_DIV_BYPASS_OFST (31) #define RG_SSUSB_CDR_PD_DIV_SEL_OFST (30) #define RG_SSUSB_CDR_CPBIAS_SEL_OFST (29) #define RG_SSUSB_CDR_OSCDET_EN_OFST (28) #define RG_SSUSB_CDR_MONMUX_OFST (27) #define RG_SSUSB_CDR_RST_DLY_OFST (25) #define RG_SSUSB_CDR_RSTB_MANUAL_OFST (24) #define RG_SSUSB_CDR_BYPASS_OFST (22) #define RG_SSUSB_CDR_PI_SLEW_OFST (20) #define RG_SSUSB_CDR_EPEN_OFST (19) #define RG_SSUSB_CDR_AUTOK_LOAD_OFST (18) #define RG_SSUSB_CDR_MONEN_OFST (16) #define RG_SSUSB_CDR_MONEN_DIG_OFST (15) #define RG_SSUSB_CDR_REGOD_OFST (13) #define RG_SSUSB_CDR_AUTOK_KS_OFST (11) #define RG_SSUSB_CDR_AUTOK_KF_OFST (9) #define RG_SSUSB_RX_DAC_EN_OFST (8) #define RG_SSUSB_RX_DAC_PWD_OFST (7) #define RG_SSUSB_EQ_CURSEL_OFST (6) #define RG_SSUSB_RX_DAC_MUX_OFST (1) #define RG_SSUSB_RX_R2T_EN_OFST (0) /* U3D_regA */ #define RG_SSUSB_RX_T2R_EN_OFST (31) #define RG_SSUSB_RX_50_LOWER_OFST (28) #define RG_SSUSB_RX_50_TAR_OFST (26) #define RG_SSUSB_RX_SW_CTRL_OFST (21) #define RG_PCIE_SIGDET_VTH_OFST (19) #define RG_PCIE_SIGDET_LPF_OFST (17) #define RG_SSUSB_LFPS_MON_EN_OFST (16) #define RG_SSUSB_RXAFE_DCMON_SEL_OFST (12) #define RG_SSUSB_RX_P1_ENTRY_PASS_OFST (11) #define RG_SSUSB_RX_PD_RST_OFST (10) #define RG_SSUSB_RX_PD_RST_PASS_OFST (9) /* U3D_regB */ #define RG_SSUSB_CDR_RESERVE_OFST (24) #define RG_SSUSB_RXAFE_RESERVE_OFST (16) #define RG_PCIE_RX_RESERVE_OFST (8) #define RG_SSUSB_VRT_25M_EN_OFST (7) #define RG_SSUSB_RX_PD_PICAL_SWAP_OFST (6) #define RG_SSUSB_RX_DAC_MEAS_EN_OFST (5) #define RG_SSUSB_MPX_SEL_L0_OFST (4) #define RG_SSUSB_LFPS_SLCOUT_SEL_OFST (3) #define RG_SSUSB_LFPS_CMPOUT_SEL_OFST (2) #define RG_PCIE_SIGDET_HF_OFST (0) /* U3D_regC */ #define RGS_SSUSB_RX_DEBUG_RESERVE_OFST (0) /* ///////////////////////////////////////////////////////////////////////////// */ struct u3phya_da_reg_e { /* 0x0 */ PHY_LE32 reg0; PHY_LE32 reg1; PHY_LE32 reg4; PHY_LE32 reg5; /* 0x10 */ PHY_LE32 reg6; PHY_LE32 reg7; PHY_LE32 reg8; PHY_LE32 reg9; /* 0x20 */ PHY_LE32 reg10; PHY_LE32 reg12; PHY_LE32 reg13; PHY_LE32 reg14; /* 0x30 */ PHY_LE32 reg15; PHY_LE32 reg16; PHY_LE32 reg19; PHY_LE32 reg20; /* 0x40 */ PHY_LE32 reg21; PHY_LE32 reg23; PHY_LE32 reg25; PHY_LE32 reg26; /* 0x50 */ PHY_LE32 reg28; PHY_LE32 reg29; PHY_LE32 reg30; PHY_LE32 reg31; /* 0x60 */ PHY_LE32 reg32; PHY_LE32 reg33; }; /* U3D_reg0 */ #define RG_PCIE_SPEED_PE2D (0x1<<24) /* 24:24 */ #define RG_PCIE_SPEED_PE2H (0x1<<23) /* 23:23 */ #define RG_PCIE_SPEED_PE1D (0x1<<22) /* 22:22 */ #define RG_PCIE_SPEED_PE1H (0x1<<21) /* 21:21 */ #define RG_PCIE_SPEED_U3 (0x1<<20) /* 20:20 */ #define RG_SSUSB_XTAL_EXT_EN_PE2D (0x3<<18) /* 19:18 */ #define RG_SSUSB_XTAL_EXT_EN_PE2H (0x3<<16) /* 17:16 */ #define RG_SSUSB_XTAL_EXT_EN_PE1D (0x3<<14) /* 15:14 */ #define RG_SSUSB_XTAL_EXT_EN_PE1H (0x3<<12) /* 13:12 */ #define RG_SSUSB_XTAL_EXT_EN_U3 (0x3<<10) /* 11:10 */ #define RG_SSUSB_CDR_REFCK_SEL_PE2D (0x3<<8) /* 9:8 */ #define RG_SSUSB_CDR_REFCK_SEL_PE2H (0x3<<6) /* 7:6 */ #define RG_SSUSB_CDR_REFCK_SEL_PE1D (0x3<<4) /* 5:4 */ #define RG_SSUSB_CDR_REFCK_SEL_PE1H (0x3<<2) /* 3:2 */ #define RG_SSUSB_CDR_REFCK_SEL_U3 (0x3<<0) /* 1:0 */ /* U3D_reg1 */ #define RG_USB20_REFCK_SEL_PE2D (0x1<<30) /* 30:30 */ #define RG_USB20_REFCK_SEL_PE2H (0x1<<29) /* 29:29 */ #define RG_USB20_REFCK_SEL_PE1D (0x1<<28) /* 28:28 */ #define RG_USB20_REFCK_SEL_PE1H (0x1<<27) /* 27:27 */ #define RG_USB20_REFCK_SEL_U3 (0x1<<26) /* 26:26 */ #define RG_PCIE_REFCK_DIV4_PE2D (0x1<<25) /* 25:25 */ #define RG_PCIE_REFCK_DIV4_PE2H (0x1<<24) /* 24:24 */ #define RG_PCIE_REFCK_DIV4_PE1D (0x1<<18) /* 18:18 */ #define RG_PCIE_REFCK_DIV4_PE1H (0x1<<17) /* 17:17 */ #define RG_PCIE_REFCK_DIV4_U3 (0x1<<16) /* 16:16 */ #define RG_PCIE_MODE_PE2D (0x1<<8) /* 8:8 */ #define RG_PCIE_MODE_PE2H (0x1<<3) /* 3:3 */ #define RG_PCIE_MODE_PE1D (0x1<<2) /* 2:2 */ #define RG_PCIE_MODE_PE1H (0x1<<1) /* 1:1 */ #define RG_PCIE_MODE_U3 (0x1<<0) /* 0:0 */ /* U3D_reg4 */ #define RG_SSUSB_PLL_DIVEN_PE2D (0x7<<22) /* 24:22 */ #define RG_SSUSB_PLL_DIVEN_PE2H (0x7<<19) /* 21:19 */ #define RG_SSUSB_PLL_DIVEN_PE1D (0x7<<16) /* 18:16 */ #define RG_SSUSB_PLL_DIVEN_PE1H (0x7<<13) /* 15:13 */ #define RG_SSUSB_PLL_DIVEN_U3 (0x7<<10) /* 12:10 */ #define RG_SSUSB_PLL_BC_PE2D (0x3<<8) /* 9:8 */ #define RG_SSUSB_PLL_BC_PE2H (0x3<<6) /* 7:6 */ #define RG_SSUSB_PLL_BC_PE1D (0x3<<4) /* 5:4 */ #define RG_SSUSB_PLL_BC_PE1H (0x3<<2) /* 3:2 */ #define RG_SSUSB_PLL_BC_U3 (0x3<<0) /* 1:0 */ /* U3D_reg5 */ #define RG_SSUSB_PLL_BR_PE2D (0x3<<30) /* 31:30 */ #define RG_SSUSB_PLL_BR_PE2H (0x3<<28) /* 29:28 */ #define RG_SSUSB_PLL_BR_PE1D (0x3<<26) /* 27:26 */ #define RG_SSUSB_PLL_BR_PE1H (0x3<<24) /* 25:24 */ #define RG_SSUSB_PLL_BR_U3 (0x3<<22) /* 23:22 */ #define RG_SSUSB_PLL_IC_PE2D (0xf<<16) /* 19:16 */ #define RG_SSUSB_PLL_IC_PE2H (0xf<<12) /* 15:12 */ #define RG_SSUSB_PLL_IC_PE1D (0xf<<8) /* 11:8 */ #define RG_SSUSB_PLL_IC_PE1H (0xf<<4) /* 7:4 */ #define RG_SSUSB_PLL_IC_U3 (0xf<<0) /* 3:0 */ /* U3D_reg6 */ #define RG_SSUSB_PLL_IR_PE2D (0xf<<24) /* 27:24 */ #define RG_SSUSB_PLL_IR_PE2H (0xf<<16) /* 19:16 */ #define RG_SSUSB_PLL_IR_PE1D (0xf<<8) /* 11:8 */ #define RG_SSUSB_PLL_IR_PE1H (0xf<<4) /* 7:4 */ #define RG_SSUSB_PLL_IR_U3 (0xf<<0) /* 3:0 */ /* U3D_reg7 */ #define RG_SSUSB_PLL_BP_PE2D (0xf<<24) /* 27:24 */ #define RG_SSUSB_PLL_BP_PE2H (0xf<<16) /* 19:16 */ #define RG_SSUSB_PLL_BP_PE1D (0xf<<8) /* 11:8 */ #define RG_SSUSB_PLL_BP_PE1H (0xf<<4) /* 7:4 */ #define RG_SSUSB_PLL_BP_U3 (0xf<<0) /* 3:0 */ /* U3D_reg8 */ #define RG_SSUSB_PLL_FBKSEL_PE2D (0x3<<24) /* 25:24 */ #define RG_SSUSB_PLL_FBKSEL_PE2H (0x3<<16) /* 17:16 */ #define RG_SSUSB_PLL_FBKSEL_PE1D (0x3<<8) /* 9:8 */ #define RG_SSUSB_PLL_FBKSEL_PE1H (0x3<<2) /* 3:2 */ #define RG_SSUSB_PLL_FBKSEL_U3 (0x3<<0) /* 1:0 */ /* U3D_reg9 */ #define RG_SSUSB_PLL_FBKDIV_PE2H (0x7f<<24) /* 30:24 */ #define RG_SSUSB_PLL_FBKDIV_PE1D (0x7f<<16) /* 22:16 */ #define RG_SSUSB_PLL_FBKDIV_PE1H (0x7f<<8) /* 14:8 */ #define RG_SSUSB_PLL_FBKDIV_U3 (0x7f<<0) /* 6:0 */ /* U3D_reg10 */ #define RG_SSUSB_PLL_PREDIV_PE2D (0x3<<26) /* 27:26 */ #define RG_SSUSB_PLL_PREDIV_PE2H (0x3<<24) /* 25:24 */ #define RG_SSUSB_PLL_PREDIV_PE1D (0x3<<18) /* 19:18 */ #define RG_SSUSB_PLL_PREDIV_PE1H (0x3<<16) /* 17:16 */ #define RG_SSUSB_PLL_PREDIV_U3 (0x3<<8) /* 9:8 */ #define RG_SSUSB_PLL_FBKDIV_PE2D (0x7f<<0) /* 6:0 */ /* U3D_reg12 */ #define RG_SSUSB_PLL_PCW_NCPO_U3 (0x7fffffff<<0) /* 30:0 */ /* U3D_reg13 */ #define RG_SSUSB_PLL_PCW_NCPO_PE1H (0x7fffffff<<0) /* 30:0 */ /* U3D_reg14 */ #define RG_SSUSB_PLL_PCW_NCPO_PE1D (0x7fffffff<<0) /* 30:0 */ /* U3D_reg15 */ #define RG_SSUSB_PLL_PCW_NCPO_PE2H (0x7fffffff<<0) /* 30:0 */ /* U3D_reg16 */ #define RG_SSUSB_PLL_PCW_NCPO_PE2D (0x7fffffff<<0) /* 30:0 */ /* U3D_reg19 */ #define RG_SSUSB_PLL_SSC_DELTA1_PE1H (0xffff<<16) /* 31:16 */ #define RG_SSUSB_PLL_SSC_DELTA1_U3 (0xffff<<0) /* 15:0 */ /* U3D_reg20 */ #define RG_SSUSB_PLL_SSC_DELTA1_PE2H (0xffff<<16) /* 31:16 */ #define RG_SSUSB_PLL_SSC_DELTA1_PE1D (0xffff<<0) /* 15:0 */ /* U3D_reg21 */ #define RG_SSUSB_PLL_SSC_DELTA_U3 (0xffffU<<16) /* 31:16 */ #define RG_SSUSB_PLL_SSC_DELTA1_PE2D (0xffff<<0) /* 15:0 */ /* U3D_reg23 */ #define RG_SSUSB_PLL_SSC_DELTA_PE1D (0xffff<<16) /* 31:16 */ #define RG_SSUSB_PLL_SSC_DELTA_PE1H (0xffff<<0) /* 15:0 */ /* U3D_reg25 */ #define RG_SSUSB_PLL_SSC_DELTA_PE2D (0xffff<<16) /* 31:16 */ #define RG_SSUSB_PLL_SSC_DELTA_PE2H (0xffff<<0) /* 15:0 */ /* U3D_reg26 */ #define RG_SSUSB_PLL_REFCKDIV_PE2D (0x1<<25) /* 25:25 */ #define RG_SSUSB_PLL_REFCKDIV_PE2H (0x1<<24) /* 24:24 */ #define RG_SSUSB_PLL_REFCKDIV_PE1D (0x1<<16) /* 16:16 */ #define RG_SSUSB_PLL_REFCKDIV_PE1H (0x1<<8) /* 8:8 */ #define RG_SSUSB_PLL_REFCKDIV_U3 (0x1<<0) /* 0:0 */ /* U3D_reg28 */ #define RG_SSUSB_CDR_BPA_PE2D (0x3<<24) /* 25:24 */ #define RG_SSUSB_CDR_BPA_PE2H (0x3<<16) /* 17:16 */ #define RG_SSUSB_CDR_BPA_PE1D (0x3<<10) /* 11:10 */ #define RG_SSUSB_CDR_BPA_PE1H (0x3<<8) /* 9:8 */ #define RG_SSUSB_CDR_BPA_U3 (0x3<<0) /* 1:0 */ /* U3D_reg29 */ #define RG_SSUSB_CDR_BPB_PE2D (0x7<<24) /* 26:24 */ #define RG_SSUSB_CDR_BPB_PE2H (0x7<<16) /* 18:16 */ #define RG_SSUSB_CDR_BPB_PE1D (0x7<<6) /* 8:6 */ #define RG_SSUSB_CDR_BPB_PE1H (0x7<<3) /* 5:3 */ #define RG_SSUSB_CDR_BPB_U3 (0x7<<0) /* 2:0 */ /* U3D_reg30 */ #define RG_SSUSB_CDR_BR_PE2D (0x7<<24) /* 26:24 */ #define RG_SSUSB_CDR_BR_PE2H (0x7<<16) /* 18:16 */ #define RG_SSUSB_CDR_BR_PE1D (0x7<<6) /* 8:6 */ #define RG_SSUSB_CDR_BR_PE1H (0x7<<3) /* 5:3 */ #define RG_SSUSB_CDR_BR_U3 (0x7<<0) /* 2:0 */ /* U3D_reg31 */ #define RG_SSUSB_CDR_FBDIV_PE2H (0x7f<<24) /* 30:24 */ #define RG_SSUSB_CDR_FBDIV_PE1D (0x7f<<16) /* 22:16 */ #define RG_SSUSB_CDR_FBDIV_PE1H (0x7f<<8) /* 14:8 */ #define RG_SSUSB_CDR_FBDIV_U3 (0x7f<<0) /* 6:0 */ /* U3D_reg32 */ #define RG_SSUSB_EQ_RSTEP1_PE2D (0x3<<30) /* 31:30 */ #define RG_SSUSB_EQ_RSTEP1_PE2H (0x3<<28) /* 29:28 */ #define RG_SSUSB_EQ_RSTEP1_PE1D (0x3<<26) /* 27:26 */ #define RG_SSUSB_EQ_RSTEP1_PE1H (0x3<<24) /* 25:24 */ #define RG_SSUSB_EQ_RSTEP1_U3 (0x3<<22) /* 23:22 */ #define RG_SSUSB_LFPS_DEGLITCH_PE2D (0x3<<20) /* 21:20 */ #define RG_SSUSB_LFPS_DEGLITCH_PE2H (0x3<<18) /* 19:18 */ #define RG_SSUSB_LFPS_DEGLITCH_PE1D (0x3<<16) /* 17:16 */ #define RG_SSUSB_LFPS_DEGLITCH_PE1H (0x3<<14) /* 15:14 */ #define RG_SSUSB_LFPS_DEGLITCH_U3 (0x3<<12) /* 13:12 */ #define RG_SSUSB_CDR_KVSEL_PE2D (0x1<<11) /* 11:11 */ #define RG_SSUSB_CDR_KVSEL_PE2H (0x1<<10) /* 10:10 */ #define RG_SSUSB_CDR_KVSEL_PE1D (0x1<<9) /* 9:9 */ #define RG_SSUSB_CDR_KVSEL_PE1H (0x1<<8) /* 8:8 */ #define RG_SSUSB_CDR_KVSEL_U3 (0x1<<7) /* 7:7 */ #define RG_SSUSB_CDR_FBDIV_PE2D (0x7f<<0) /* 6:0 */ /* U3D_reg33 */ #define RG_SSUSB_RX_CMPWD_PE2D (0x1<<26) /* 26:26 */ #define RG_SSUSB_RX_CMPWD_PE2H (0x1<<25) /* 25:25 */ #define RG_SSUSB_RX_CMPWD_PE1D (0x1<<24) /* 24:24 */ #define RG_SSUSB_RX_CMPWD_PE1H (0x1<<23) /* 23:23 */ #define RG_SSUSB_RX_CMPWD_U3 (0x1<<16) /* 16:16 */ #define RG_SSUSB_EQ_RSTEP2_PE2D (0x3<<8) /* 9:8 */ #define RG_SSUSB_EQ_RSTEP2_PE2H (0x3<<6) /* 7:6 */ #define RG_SSUSB_EQ_RSTEP2_PE1D (0x3<<4) /* 5:4 */ #define RG_SSUSB_EQ_RSTEP2_PE1H (0x3<<2) /* 3:2 */ #define RG_SSUSB_EQ_RSTEP2_U3 (0x3<<0) /* 1:0 */ /* OFFSET DEFINITION */ /* U3D_reg0 */ #define RG_PCIE_SPEED_PE2D_OFST (24) #define RG_PCIE_SPEED_PE2H_OFST (23) #define RG_PCIE_SPEED_PE1D_OFST (22) #define RG_PCIE_SPEED_PE1H_OFST (21) #define RG_PCIE_SPEED_U3_OFST (20) #define RG_SSUSB_XTAL_EXT_EN_PE2D_OFST (18) #define RG_SSUSB_XTAL_EXT_EN_PE2H_OFST (16) #define RG_SSUSB_XTAL_EXT_EN_PE1D_OFST (14) #define RG_SSUSB_XTAL_EXT_EN_PE1H_OFST (12) #define RG_SSUSB_XTAL_EXT_EN_U3_OFST (10) #define RG_SSUSB_CDR_REFCK_SEL_PE2D_OFST (8) #define RG_SSUSB_CDR_REFCK_SEL_PE2H_OFST (6) #define RG_SSUSB_CDR_REFCK_SEL_PE1D_OFST (4) #define RG_SSUSB_CDR_REFCK_SEL_PE1H_OFST (2) #define RG_SSUSB_CDR_REFCK_SEL_U3_OFST (0) /* U3D_reg1 */ #define RG_USB20_REFCK_SEL_PE2D_OFST (30) #define RG_USB20_REFCK_SEL_PE2H_OFST (29) #define RG_USB20_REFCK_SEL_PE1D_OFST (28) #define RG_USB20_REFCK_SEL_PE1H_OFST (27) #define RG_USB20_REFCK_SEL_U3_OFST (26) #define RG_PCIE_REFCK_DIV4_PE2D_OFST (25) #define RG_PCIE_REFCK_DIV4_PE2H_OFST (24) #define RG_PCIE_REFCK_DIV4_PE1D_OFST (18) #define RG_PCIE_REFCK_DIV4_PE1H_OFST (17) #define RG_PCIE_REFCK_DIV4_U3_OFST (16) #define RG_PCIE_MODE_PE2D_OFST (8) #define RG_PCIE_MODE_PE2H_OFST (3) #define RG_PCIE_MODE_PE1D_OFST (2) #define RG_PCIE_MODE_PE1H_OFST (1) #define RG_PCIE_MODE_U3_OFST (0) /* U3D_reg4 */ #define RG_SSUSB_PLL_DIVEN_PE2D_OFST (22) #define RG_SSUSB_PLL_DIVEN_PE2H_OFST (19) #define RG_SSUSB_PLL_DIVEN_PE1D_OFST (16) #define RG_SSUSB_PLL_DIVEN_PE1H_OFST (13) #define RG_SSUSB_PLL_DIVEN_U3_OFST (10) #define RG_SSUSB_PLL_BC_PE2D_OFST (8) #define RG_SSUSB_PLL_BC_PE2H_OFST (6) #define RG_SSUSB_PLL_BC_PE1D_OFST (4) #define RG_SSUSB_PLL_BC_PE1H_OFST (2) #define RG_SSUSB_PLL_BC_U3_OFST (0) /* U3D_reg5 */ #define RG_SSUSB_PLL_BR_PE2D_OFST (30) #define RG_SSUSB_PLL_BR_PE2H_OFST (28) #define RG_SSUSB_PLL_BR_PE1D_OFST (26) #define RG_SSUSB_PLL_BR_PE1H_OFST (24) #define RG_SSUSB_PLL_BR_U3_OFST (22) #define RG_SSUSB_PLL_IC_PE2D_OFST (16) #define RG_SSUSB_PLL_IC_PE2H_OFST (12) #define RG_SSUSB_PLL_IC_PE1D_OFST (8) #define RG_SSUSB_PLL_IC_PE1H_OFST (4) #define RG_SSUSB_PLL_IC_U3_OFST (0) /* U3D_reg6 */ #define RG_SSUSB_PLL_IR_PE2D_OFST (24) #define RG_SSUSB_PLL_IR_PE2H_OFST (16) #define RG_SSUSB_PLL_IR_PE1D_OFST (8) #define RG_SSUSB_PLL_IR_PE1H_OFST (4) #define RG_SSUSB_PLL_IR_U3_OFST (0) /* U3D_reg7 */ #define RG_SSUSB_PLL_BP_PE2D_OFST (24) #define RG_SSUSB_PLL_BP_PE2H_OFST (16) #define RG_SSUSB_PLL_BP_PE1D_OFST (8) #define RG_SSUSB_PLL_BP_PE1H_OFST (4) #define RG_SSUSB_PLL_BP_U3_OFST (0) /* U3D_reg8 */ #define RG_SSUSB_PLL_FBKSEL_PE2D_OFST (24) #define RG_SSUSB_PLL_FBKSEL_PE2H_OFST (16) #define RG_SSUSB_PLL_FBKSEL_PE1D_OFST (8) #define RG_SSUSB_PLL_FBKSEL_PE1H_OFST (2) #define RG_SSUSB_PLL_FBKSEL_U3_OFST (0) /* U3D_reg9 */ #define RG_SSUSB_PLL_FBKDIV_PE2H_OFST (24) #define RG_SSUSB_PLL_FBKDIV_PE1D_OFST (16) #define RG_SSUSB_PLL_FBKDIV_PE1H_OFST (8) #define RG_SSUSB_PLL_FBKDIV_U3_OFST (0) /* U3D_reg10 */ #define RG_SSUSB_PLL_PREDIV_PE2D_OFST (26) #define RG_SSUSB_PLL_PREDIV_PE2H_OFST (24) #define RG_SSUSB_PLL_PREDIV_PE1D_OFST (18) #define RG_SSUSB_PLL_PREDIV_PE1H_OFST (16) #define RG_SSUSB_PLL_PREDIV_U3_OFST (8) #define RG_SSUSB_PLL_FBKDIV_PE2D_OFST (0) /* U3D_reg12 */ #define RG_SSUSB_PLL_PCW_NCPO_U3_OFST (0) /* U3D_reg13 */ #define RG_SSUSB_PLL_PCW_NCPO_PE1H_OFST (0) /* U3D_reg14 */ #define RG_SSUSB_PLL_PCW_NCPO_PE1D_OFST (0) /* U3D_reg15 */ #define RG_SSUSB_PLL_PCW_NCPO_PE2H_OFST (0) /* U3D_reg16 */ #define RG_SSUSB_PLL_PCW_NCPO_PE2D_OFST (0) /* U3D_reg19 */ #define RG_SSUSB_PLL_SSC_DELTA1_PE1H_OFST (16) #define RG_SSUSB_PLL_SSC_DELTA1_U3_OFST (0) /* U3D_reg20 */ #define RG_SSUSB_PLL_SSC_DELTA1_PE2H_OFST (16) #define RG_SSUSB_PLL_SSC_DELTA1_PE1D_OFST (0) /* U3D_reg21 */ #define RG_SSUSB_PLL_SSC_DELTA_U3_OFST (16) #define RG_SSUSB_PLL_SSC_DELTA1_PE2D_OFST (0) /* U3D_reg23 */ #define RG_SSUSB_PLL_SSC_DELTA_PE1D_OFST (16) #define RG_SSUSB_PLL_SSC_DELTA_PE1H_OFST (0) /* U3D_reg25 */ #define RG_SSUSB_PLL_SSC_DELTA_PE2D_OFST (16) #define RG_SSUSB_PLL_SSC_DELTA_PE2H_OFST (0) /* U3D_reg26 */ #define RG_SSUSB_PLL_REFCKDIV_PE2D_OFST (25) #define RG_SSUSB_PLL_REFCKDIV_PE2H_OFST (24) #define RG_SSUSB_PLL_REFCKDIV_PE1D_OFST (16) #define RG_SSUSB_PLL_REFCKDIV_PE1H_OFST (8) #define RG_SSUSB_PLL_REFCKDIV_U3_OFST (0) /* U3D_reg28 */ #define RG_SSUSB_CDR_BPA_PE2D_OFST (24) #define RG_SSUSB_CDR_BPA_PE2H_OFST (16) #define RG_SSUSB_CDR_BPA_PE1D_OFST (10) #define RG_SSUSB_CDR_BPA_PE1H_OFST (8) #define RG_SSUSB_CDR_BPA_U3_OFST (0) /* U3D_reg29 */ #define RG_SSUSB_CDR_BPB_PE2D_OFST (24) #define RG_SSUSB_CDR_BPB_PE2H_OFST (16) #define RG_SSUSB_CDR_BPB_PE1D_OFST (6) #define RG_SSUSB_CDR_BPB_PE1H_OFST (3) #define RG_SSUSB_CDR_BPB_U3_OFST (0) /* U3D_reg30 */ #define RG_SSUSB_CDR_BR_PE2D_OFST (24) #define RG_SSUSB_CDR_BR_PE2H_OFST (16) #define RG_SSUSB_CDR_BR_PE1D_OFST (6) #define RG_SSUSB_CDR_BR_PE1H_OFST (3) #define RG_SSUSB_CDR_BR_U3_OFST (0) /* U3D_reg31 */ #define RG_SSUSB_CDR_FBDIV_PE2H_OFST (24) #define RG_SSUSB_CDR_FBDIV_PE1D_OFST (16) #define RG_SSUSB_CDR_FBDIV_PE1H_OFST (8) #define RG_SSUSB_CDR_FBDIV_U3_OFST (0) /* U3D_reg32 */ #define RG_SSUSB_EQ_RSTEP1_PE2D_OFST (30) #define RG_SSUSB_EQ_RSTEP1_PE2H_OFST (28) #define RG_SSUSB_EQ_RSTEP1_PE1D_OFST (26) #define RG_SSUSB_EQ_RSTEP1_PE1H_OFST (24) #define RG_SSUSB_EQ_RSTEP1_U3_OFST (22) #define RG_SSUSB_LFPS_DEGLITCH_PE2D_OFST (20) #define RG_SSUSB_LFPS_DEGLITCH_PE2H_OFST (18) #define RG_SSUSB_LFPS_DEGLITCH_PE1D_OFST (16) #define RG_SSUSB_LFPS_DEGLITCH_PE1H_OFST (14) #define RG_SSUSB_LFPS_DEGLITCH_U3_OFST (12) #define RG_SSUSB_CDR_KVSEL_PE2D_OFST (11) #define RG_SSUSB_CDR_KVSEL_PE2H_OFST (10) #define RG_SSUSB_CDR_KVSEL_PE1D_OFST (9) #define RG_SSUSB_CDR_KVSEL_PE1H_OFST (8) #define RG_SSUSB_CDR_KVSEL_U3_OFST (7) #define RG_SSUSB_CDR_FBDIV_PE2D_OFST (0) /* U3D_reg33 */ #define RG_SSUSB_RX_CMPWD_PE2D_OFST (26) #define RG_SSUSB_RX_CMPWD_PE2H_OFST (25) #define RG_SSUSB_RX_CMPWD_PE1D_OFST (24) #define RG_SSUSB_RX_CMPWD_PE1H_OFST (23) #define RG_SSUSB_RX_CMPWD_U3_OFST (16) #define RG_SSUSB_EQ_RSTEP2_PE2D_OFST (8) #define RG_SSUSB_EQ_RSTEP2_PE2H_OFST (6) #define RG_SSUSB_EQ_RSTEP2_PE1D_OFST (4) #define RG_SSUSB_EQ_RSTEP2_PE1H_OFST (2) #define RG_SSUSB_EQ_RSTEP2_U3_OFST (0) /* ///////////////////////////////////////////////////////////////////////////// */ struct u3phyd_reg_e { /* 0x0 */ PHY_LE32 phyd_mix0; PHY_LE32 phyd_mix1; PHY_LE32 phyd_lfps0; PHY_LE32 phyd_lfps1; /* 0x10 */ PHY_LE32 phyd_impcal0; PHY_LE32 phyd_impcal1; PHY_LE32 phyd_txpll0; PHY_LE32 phyd_txpll1; /* 0x20 */ PHY_LE32 phyd_txpll2; PHY_LE32 phyd_fl0; PHY_LE32 phyd_mix2; PHY_LE32 phyd_rx0; /* 0x30 */ PHY_LE32 phyd_t2rlb; PHY_LE32 phyd_cppat; PHY_LE32 phyd_mix3; PHY_LE32 phyd_ebufctl; /* 0x40 */ PHY_LE32 phyd_pipe0; PHY_LE32 phyd_pipe1; PHY_LE32 phyd_mix4; PHY_LE32 phyd_ckgen0; /* 0x50 */ PHY_LE32 phyd_mix5; PHY_LE32 phyd_reserved; PHY_LE32 phyd_cdr0; PHY_LE32 phyd_cdr1; /* 0x60 */ PHY_LE32 phyd_pll_0; PHY_LE32 phyd_pll_1; PHY_LE32 phyd_bcn_det_1; PHY_LE32 phyd_bcn_det_2; /* 0x70 */ PHY_LE32 eq0; PHY_LE32 eq1; PHY_LE32 eq2; PHY_LE32 eq3; /* 0x80 */ PHY_LE32 eq_eye0; PHY_LE32 eq_eye1; PHY_LE32 eq_eye2; PHY_LE32 eq_dfe0; /* 0x90 */ PHY_LE32 eq_dfe1; PHY_LE32 eq_dfe2; PHY_LE32 eq_dfe3; PHY_LE32 reserve0; /* 0xa0 */ PHY_LE32 phyd_mon0; PHY_LE32 phyd_mon1; PHY_LE32 phyd_mon2; PHY_LE32 phyd_mon3; /* 0xb0 */ PHY_LE32 phyd_mon4; PHY_LE32 phyd_mon5; PHY_LE32 phyd_mon6; PHY_LE32 phyd_mon7; /* 0xc0 */ PHY_LE32 phya_rx_mon0; PHY_LE32 phya_rx_mon1; PHY_LE32 phya_rx_mon2; PHY_LE32 phya_rx_mon3; /* 0xd0 */ PHY_LE32 phya_rx_mon4; PHY_LE32 phya_rx_mon5; PHY_LE32 phyd_cppat2; PHY_LE32 eq_eye3; /* 0xe0 */ PHY_LE32 kband_out; PHY_LE32 kband_out1; }; /* U3D_PHYD_MIX0 */ #define RG_SSUSB_P_P3_TX_NG (0x1<<31) /* 31:31 */ #define RG_SSUSB_TSEQ_EN (0x1<<30) /* 30:30 */ #define RG_SSUSB_TSEQ_POLEN (0x1<<29) /* 29:29 */ #define RG_SSUSB_TSEQ_POL (0x1<<28) /* 28:28 */ #define RG_SSUSB_P_P3_PCLK_NG (0x1<<27) /* 27:27 */ #define RG_SSUSB_TSEQ_TH (0x7<<24) /* 26:24 */ #define RG_SSUSB_PRBS_BERTH (0xff<<16) /* 23:16 */ #define RG_SSUSB_DISABLE_PHY_U2_ON (0x1<<15) /* 15:15 */ #define RG_SSUSB_DISABLE_PHY_U2_OFF (0x1<<14) /* 14:14 */ #define RG_SSUSB_PRBS_EN (0x1<<13) /* 13:13 */ #define RG_SSUSB_BPSLOCK (0x1<<12) /* 12:12 */ #define RG_SSUSB_RTCOMCNT (0xf<<8) /* 11:8 */ #define RG_SSUSB_COMCNT (0xf<<4) /* 7:4 */ #define RG_SSUSB_PRBSEL_CALIB (0xf<<0) /* 3:0 */ /* U3D_PHYD_MIX1 */ #define RG_SSUSB_SLEEP_EN (0x1<<31) /* 31:31 */ #define RG_SSUSB_PRBSEL_PCS (0x7<<28) /* 30:28 */ #define RG_SSUSB_TXLFPS_PRD (0xf<<24) /* 27:24 */ #define RG_SSUSB_P_RX_P0S_CK (0x1<<23) /* 23:23 */ #define RG_SSUSB_P_TX_P0S_CK (0x1<<22) /* 22:22 */ #define RG_SSUSB_PDNCTL (0x3f<<16) /* 21:16 */ #define RG_SSUSB_TX_DRV_EN (0x1<<15) /* 15:15 */ #define RG_SSUSB_TX_DRV_SEL (0x1<<14) /* 14:14 */ #define RG_SSUSB_TX_DRV_DLY (0x3f<<8) /* 13:8 */ #define RG_SSUSB_BERT_EN (0x1<<7) /* 7:7 */ #define RG_SSUSB_SCP_TH (0x7<<4) /* 6:4 */ #define RG_SSUSB_SCP_EN (0x1<<3) /* 3:3 */ #define RG_SSUSB_RXANSIDEC_TEST (0x7<<0) /* 2:0 */ /* U3D_PHYD_LFPS0 */ #define RG_SSUSB_LFPS_PWD (0x1<<30) /* 30:30 */ #define RG_SSUSB_FORCE_LFPS_PWD (0x1<<29) /* 29:29 */ #define RG_SSUSB_RXLFPS_OVF (0x1f<<24) /* 28:24 */ #define RG_SSUSB_P3_ENTRY_SEL (0x1<<23) /* 23:23 */ #define RG_SSUSB_P3_ENTRY (0x1<<22) /* 22:22 */ #define RG_SSUSB_RXLFPS_CDRSEL (0x3<<20) /* 21:20 */ #define RG_SSUSB_RXLFPS_CDRTH (0xf<<16) /* 19:16 */ #define RG_SSUSB_LOCK5G_BLOCK (0x1<<15) /* 15:15 */ #define RG_SSUSB_TFIFO_EXT_D_SEL (0x1<<14) /* 14:14 */ #define RG_SSUSB_TFIFO_NO_EXTEND (0x1<<13) /* 13:13 */ #define RG_SSUSB_RXLFPS_LOB (0x1f<<8) /* 12:8 */ #define RG_SSUSB_TXLFPS_EN (0x1<<7) /* 7:7 */ #define RG_SSUSB_TXLFPS_SEL (0x1<<6) /* 6:6 */ #define RG_SSUSB_RXLFPS_CDRLOCK (0x1<<5) /* 5:5 */ #define RG_SSUSB_RXLFPS_UPB (0x1f<<0) /* 4:0 */ /* U3D_PHYD_LFPS1 */ #define RG_SSUSB_RX_IMP_BIAS (0xf<<28) /* 31:28 */ #define RG_SSUSB_TX_IMP_BIAS (0xf<<24) /* 27:24 */ #define RG_SSUSB_FWAKE_TH (0x3f<<16) /* 21:16 */ #define RG_SSUSB_P1_ENTRY_SEL (0x1<<14) /* 14:14 */ #define RG_SSUSB_P1_ENTRY (0x1<<13) /* 13:13 */ #define RG_SSUSB_RXLFPS_UDF (0x1f<<8) /* 12:8 */ #define RG_SSUSB_RXLFPS_P0IDLETH (0xff<<0) /* 7:0 */ /* U3D_PHYD_IMPCAL0 */ #define RG_SSUSB_FORCE_TX_IMPSEL (0x1<<31) /* 31:31 */ #define RG_SSUSB_TX_IMPCAL_EN (0x1<<30) /* 30:30 */ #define RG_SSUSB_FORCE_TX_IMPCAL_EN (0x1<<29) /* 29:29 */ #define RG_SSUSB_TX_IMPSEL (0x1f<<24) /* 28:24 */ #define RG_SSUSB_TX_IMPCAL_CALCYC (0x3f<<16) /* 21:16 */ #define RG_SSUSB_TX_IMPCAL_STBCYC (0x1f<<10) /* 14:10 */ #define RG_SSUSB_TX_IMPCAL_CYCCNT (0x3ff<<0) /* 9:0 */ /* U3D_PHYD_IMPCAL1 */ #define RG_SSUSB_FORCE_RX_IMPSEL (0x1<<31) /* 31:31 */ #define RG_SSUSB_RX_IMPCAL_EN (0x1<<30) /* 30:30 */ #define RG_SSUSB_FORCE_RX_IMPCAL_EN (0x1<<29) /* 29:29 */ #define RG_SSUSB_RX_IMPSEL (0x1f<<24) /* 28:24 */ #define RG_SSUSB_RX_IMPCAL_CALCYC (0x3f<<16) /* 21:16 */ #define RG_SSUSB_RX_IMPCAL_STBCYC (0x1f<<10) /* 14:10 */ #define RG_SSUSB_RX_IMPCAL_CYCCNT (0x3ff<<0) /* 9:0 */ /* U3D_PHYD_TXPLL0 */ #define RG_SSUSB_TXPLL_DDSEN_CYC (0x1f<<27) /* 31:27 */ #define RG_SSUSB_TXPLL_ON (0x1<<26) /* 26:26 */ #define RG_SSUSB_FORCE_TXPLLON (0x1<<25) /* 25:25 */ #define RG_SSUSB_TXPLL_STBCYC (0x1ff<<16) /* 24:16 */ #define RG_SSUSB_TXPLL_NCPOCHG_CYC (0xf<<12) /* 15:12 */ #define RG_SSUSB_TXPLL_NCPOEN_CYC (0x3<<10) /* 11:10 */ #define RG_SSUSB_TXPLL_DDSRSTB_CYC (0x7<<0) /* 2:0 */ /* U3D_PHYD_TXPLL1 */ #define RG_SSUSB_PLL_NCPO_EN (0x1<<31) /* 31:31 */ #define RG_SSUSB_PLL_FIFO_START_MAN (0x1<<30) /* 30:30 */ #define RG_SSUSB_PLL_NCPO_CHG (0x1<<28) /* 28:28 */ #define RG_SSUSB_PLL_DDS_RSTB (0x1<<27) /* 27:27 */ #define RG_SSUSB_PLL_DDS_PWDB (0x1<<26) /* 26:26 */ #define RG_SSUSB_PLL_DDSEN (0x1<<25) /* 25:25 */ #define RG_SSUSB_PLL_AUTOK_VCO (0x1<<24) /* 24:24 */ #define RG_SSUSB_PLL_PWD (0x1<<23) /* 23:23 */ #define RG_SSUSB_RX_AFE_PWD (0x1<<22) /* 22:22 */ #define RG_SSUSB_PLL_TCADJ (0x3f<<16) /* 21:16 */ #define RG_SSUSB_FORCE_CDR_TCADJ (0x1<<15) /* 15:15 */ #define RG_SSUSB_FORCE_CDR_AUTOK_VCO (0x1<<14) /* 14:14 */ #define RG_SSUSB_FORCE_CDR_PWD (0x1<<13) /* 13:13 */ #define RG_SSUSB_FORCE_PLL_NCPO_EN (0x1<<12) /* 12:12 */ #define RG_SSUSB_FORCE_PLL_FIFO_START_MAN (0x1<<11) /* 11:11 */ #define RG_SSUSB_FORCE_PLL_NCPO_CHG (0x1<<9) /* 9:9 */ #define RG_SSUSB_FORCE_PLL_DDS_RSTB (0x1<<8) /* 8:8 */ #define RG_SSUSB_FORCE_PLL_DDS_PWDB (0x1<<7) /* 7:7 */ #define RG_SSUSB_FORCE_PLL_DDSEN (0x1<<6) /* 6:6 */ #define RG_SSUSB_FORCE_PLL_TCADJ (0x1<<5) /* 5:5 */ #define RG_SSUSB_FORCE_PLL_AUTOK_VCO (0x1<<4) /* 4:4 */ #define RG_SSUSB_FORCE_PLL_PWD (0x1<<3) /* 3:3 */ #define RG_SSUSB_FLT_1_DISPERR_B (0x1<<2) /* 2:2 */ /* U3D_PHYD_TXPLL2 */ #define RG_SSUSB_TX_LFPS_EN (0x1<<31) /* 31:31 */ #define RG_SSUSB_FORCE_TX_LFPS_EN (0x1<<30) /* 30:30 */ #define RG_SSUSB_TX_LFPS (0x1<<29) /* 29:29 */ #define RG_SSUSB_FORCE_TX_LFPS (0x1<<28) /* 28:28 */ #define RG_SSUSB_RXPLL_STB (0x1<<27) /* 27:27 */ #define RG_SSUSB_TXPLL_STB (0x1<<26) /* 26:26 */ #define RG_SSUSB_FORCE_RXPLL_STB (0x1<<25) /* 25:25 */ #define RG_SSUSB_FORCE_TXPLL_STB (0x1<<24) /* 24:24 */ #define RG_SSUSB_RXPLL_REFCKSEL (0x1<<16) /* 16:16 */ #define RG_SSUSB_RXPLL_STBMODE (0x1<<11) /* 11:11 */ #define RG_SSUSB_RXPLL_ON (0x1<<10) /* 10:10 */ #define RG_SSUSB_FORCE_RXPLLON (0x1<<9) /* 9:9 */ #define RG_SSUSB_FORCE_RX_AFE_PWD (0x1<<8) /* 8:8 */ #define RG_SSUSB_CDR_AUTOK_VCO (0x1<<7) /* 7:7 */ #define RG_SSUSB_CDR_PWD (0x1<<6) /* 6:6 */ #define RG_SSUSB_CDR_TCADJ (0x3f<<0) /* 5:0 */ /* U3D_PHYD_FL0 */ #define RG_SSUSB_RX_FL_TARGET (0xffff<<16) /* 31:16 */ #define RG_SSUSB_RX_FL_CYCLECNT (0xffff<<0) /* 15:0 */ /* U3D_PHYD_MIX2 */ #define RG_SSUSB_RX_EQ_RST (0x1<<31) /* 31:31 */ #define RG_SSUSB_RX_EQ_RST_SEL (0x1<<30) /* 30:30 */ #define RG_SSUSB_RXVAL_RST (0x1<<29) /* 29:29 */ #define RG_SSUSB_RXVAL_CNT (0x1f<<24) /* 28:24 */ #define RG_SSUSB_CDROS_EN (0x1<<18) /* 18:18 */ #define RG_SSUSB_CDR_LCKOP (0x3<<16) /* 17:16 */ #define RG_SSUSB_RX_FL_LOCKTH (0xf<<8) /* 11:8 */ #define RG_SSUSB_RX_FL_OFFSET (0xff<<0) /* 7:0 */ /* U3D_PHYD_RX0 */ #define RG_SSUSB_T2RLB_BERTH (0xff<<24) /* 31:24 */ #define RG_SSUSB_T2RLB_PAT (0xff<<16) /* 23:16 */ #define RG_SSUSB_T2RLB_EN (0x1<<15) /* 15:15 */ #define RG_SSUSB_T2RLB_BPSCRAMB (0x1<<14) /* 14:14 */ #define RG_SSUSB_T2RLB_SERIAL (0x1<<13) /* 13:13 */ #define RG_SSUSB_T2RLB_MODE (0x3<<11) /* 12:11 */ #define RG_SSUSB_RX_SAOSC_EN (0x1<<10) /* 10:10 */ #define RG_SSUSB_RX_SAOSC_EN_SEL (0x1<<9) /* 9:9 */ #define RG_SSUSB_RX_DFE_OPTION (0x1<<8) /* 8:8 */ #define RG_SSUSB_RX_DFE_EN (0x1<<7) /* 7:7 */ #define RG_SSUSB_RX_DFE_EN_SEL (0x1<<6) /* 6:6 */ #define RG_SSUSB_RX_EQ_EN (0x1<<5) /* 5:5 */ #define RG_SSUSB_RX_EQ_EN_SEL (0x1<<4) /* 4:4 */ #define RG_SSUSB_RX_SAOSC_RST (0x1<<3) /* 3:3 */ #define RG_SSUSB_RX_SAOSC_RST_SEL (0x1<<2) /* 2:2 */ #define RG_SSUSB_RX_DFE_RST (0x1<<1) /* 1:1 */ #define RG_SSUSB_RX_DFE_RST_SEL (0x1<<0) /* 0:0 */ /* U3D_PHYD_T2RLB */ #define RG_SSUSB_EQTRAIN_CH_MODE (0x1<<28) /* 28:28 */ #define RG_SSUSB_PRB_OUT_CPPAT (0x1<<27) /* 27:27 */ #define RG_SSUSB_BPANSIENC (0x1<<26) /* 26:26 */ #define RG_SSUSB_VALID_EN (0x1<<25) /* 25:25 */ #define RG_SSUSB_EBUF_SRST (0x1<<24) /* 24:24 */ #define RG_SSUSB_K_EMP (0xf<<20) /* 23:20 */ #define RG_SSUSB_K_FUL (0xf<<16) /* 19:16 */ #define RG_SSUSB_T2RLB_BDATRST (0xf<<12) /* 15:12 */ #define RG_SSUSB_P_T2RLB_SKP_EN (0x1<<10) /* 10:10 */ #define RG_SSUSB_T2RLB_PATMODE (0x3<<8) /* 9:8 */ #define RG_SSUSB_T2RLB_TSEQCNT (0xff<<0) /* 7:0 */ /* U3D_PHYD_CPPAT */ #define RG_SSUSB_CPPAT_PROGRAM_EN (0x1<<24) /* 24:24 */ #define RG_SSUSB_CPPAT_TOZ (0x3<<21) /* 22:21 */ #define RG_SSUSB_CPPAT_PRBS_EN (0x1<<20) /* 20:20 */ #define RG_SSUSB_CPPAT_OUT_TMP2 (0xf<<16) /* 19:16 */ #define RG_SSUSB_CPPAT_OUT_TMP1 (0xff<<8) /* 15:8 */ #define RG_SSUSB_CPPAT_OUT_TMP0 (0xff<<0) /* 7:0 */ /* U3D_PHYD_MIX3 */ #define RG_SSUSB_CDR_TCADJ_MINUS (0x1<<31) /* 31:31 */ #define RG_SSUSB_P_CDROS_EN (0x1<<30) /* 30:30 */ #define RG_SSUSB_P_P2_TX_DRV_DIS (0x1<<28) /* 28:28 */ #define RG_SSUSB_CDR_TCADJ_OFFSET (0x7<<24) /* 26:24 */ #define RG_SSUSB_PLL_TCADJ_MINUS (0x1<<23) /* 23:23 */ #define RG_SSUSB_FORCE_PLL_BIAS_LPF_EN (0x1<<20) /* 20:20 */ #define RG_SSUSB_PLL_BIAS_LPF_EN (0x1<<19) /* 19:19 */ #define RG_SSUSB_PLL_TCADJ_OFFSET (0x7<<16) /* 18:16 */ #define RG_SSUSB_FORCE_PLL_SSCEN (0x1<<15) /* 15:15 */ #define RG_SSUSB_PLL_SSCEN (0x1<<14) /* 14:14 */ #define RG_SSUSB_FORCE_CDR_PI_PWD (0x1<<13) /* 13:13 */ #define RG_SSUSB_CDR_PI_PWD (0x1<<12) /* 12:12 */ #define RG_SSUSB_CDR_PI_MODE (0x1<<11) /* 11:11 */ #define RG_SSUSB_TXPLL_SSCEN_CYC (0x3ff<<0) /* 9:0 */ /* U3D_PHYD_EBUFCTL */ #define RG_SSUSB_EBUFCTL (0xffffffff<<0) /* 31:0 */ /* U3D_PHYD_PIPE0 */ #define RG_SSUSB_RXTERMINATION (0x1<<30) /* 30:30 */ #define RG_SSUSB_RXEQTRAINING (0x1<<29) /* 29:29 */ #define RG_SSUSB_RXPOLARITY (0x1<<28) /* 28:28 */ #define RG_SSUSB_TXDEEMPH (0x3<<26) /* 27:26 */ #define RG_SSUSB_POWERDOWN (0x3<<24) /* 25:24 */ #define RG_SSUSB_TXONESZEROS (0x1<<23) /* 23:23 */ #define RG_SSUSB_TXELECIDLE (0x1<<22) /* 22:22 */ #define RG_SSUSB_TXDETECTRX (0x1<<21) /* 21:21 */ #define RG_SSUSB_PIPE_SEL (0x1<<20) /* 20:20 */ #define RG_SSUSB_TXDATAK (0xf<<16) /* 19:16 */ #define RG_SSUSB_CDR_STABLE_SEL (0x1<<15) /* 15:15 */ #define RG_SSUSB_CDR_STABLE (0x1<<14) /* 14:14 */ #define RG_SSUSB_CDR_RSTB_SEL (0x1<<13) /* 13:13 */ #define RG_SSUSB_CDR_RSTB (0x1<<12) /* 12:12 */ #define RG_SSUSB_FRC_PIPE_POWERDOWN (0x1<<11) /* 11:11 */ #define RG_SSUSB_P_TXBCN_DIS (0x1<<6) /* 6:6 */ #define RG_SSUSB_P_ERROR_SEL (0x3<<4) /* 5:4 */ #define RG_SSUSB_TXMARGIN (0x7<<1) /* 3:1 */ #define RG_SSUSB_TXCOMPLIANCE (0x1<<0) /* 0:0 */ /* U3D_PHYD_PIPE1 */ #define RG_SSUSB_TXDATA (0xffffffff<<0) /* 31:0 */ /* U3D_PHYD_MIX4 */ #define RG_SSUSB_CDROS_CNT (0x3f<<24) /* 29:24 */ #define RG_SSUSB_T2RLB_BER_EN (0x1<<16) /* 16:16 */ #define RG_SSUSB_T2RLB_BER_RATE (0xffff<<0) /* 15:0 */ /* U3D_PHYD_CKGEN0 */ #define RG_SSUSB_RFIFO_IMPLAT (0x1<<27) /* 27:27 */ #define RG_SSUSB_TFIFO_PSEL (0x7<<24) /* 26:24 */ #define RG_SSUSB_CKGEN_PSEL (0x3<<8) /* 9:8 */ #define RG_SSUSB_RXCK_INV (0x1<<0) /* 0:0 */ /* U3D_PHYD_MIX5 */ #define RG_SSUSB_PRB_SEL (0xffff<<16) /* 31:16 */ #define RG_SSUSB_RXPLL_STBCYC (0x7ff<<0) /* 10:0 */ /* U3D_PHYD_RESERVED */ #define RG_SSUSB_PHYD_RESERVE (0xffffffff<<0) /* 31:0 */ /* U3D_PHYD_CDR0 */ #define RG_SSUSB_CDR_BIC_LTR (0xf<<28) /* 31:28 */ #define RG_SSUSB_CDR_BIC_LTD0 (0xf<<24) /* 27:24 */ #define RG_SSUSB_CDR_BC_LTD1 (0x1f<<16) /* 20:16 */ #define RG_SSUSB_CDR_BC_LTR (0x1f<<8) /* 12:8 */ #define RG_SSUSB_CDR_BC_LTD0 (0x1f<<0) /* 4:0 */ /* U3D_PHYD_CDR1 */ #define RG_SSUSB_CDR_BIR_LTD1 (0x1f<<24) /* 28:24 */ #define RG_SSUSB_CDR_BIR_LTR (0x1f<<16) /* 20:16 */ #define RG_SSUSB_CDR_BIR_LTD0 (0x1f<<8) /* 12:8 */ #define RG_SSUSB_CDR_BW_SEL (0x3<<6) /* 7:6 */ #define RG_SSUSB_CDR_BIC_LTD1 (0xf<<0) /* 3:0 */ /* U3D_PHYD_PLL_0 */ #define RG_SSUSB_FORCE_CDR_BAND_5G (0x1<<28) /* 28:28 */ #define RG_SSUSB_FORCE_CDR_BAND_2P5G (0x1<<27) /* 27:27 */ #define RG_SSUSB_FORCE_PLL_BAND_5G (0x1<<26) /* 26:26 */ #define RG_SSUSB_FORCE_PLL_BAND_2P5G (0x1<<25) /* 25:25 */ #define RG_SSUSB_P_EQ_T_SEL (0x3ff<<15) /* 24:15 */ #define RG_SSUSB_PLL_ISO_EN_CYC (0x3ff<<5) /* 14:5 */ #define RG_SSUSB_PLLBAND_RECAL (0x1<<4) /* 4:4 */ #define RG_SSUSB_PLL_DDS_ISO_EN (0x1<<3) /* 3:3 */ #define RG_SSUSB_FORCE_PLL_DDS_ISO_EN (0x1<<2) /* 2:2 */ #define RG_SSUSB_PLL_DDS_PWR_ON (0x1<<1) /* 1:1 */ #define RG_SSUSB_FORCE_PLL_DDS_PWR_ON (0x1<<0) /* 0:0 */ /* U3D_PHYD_PLL_1 */ #define RG_SSUSB_CDR_BAND_5G (0xff<<24) /* 31:24 */ #define RG_SSUSB_CDR_BAND_2P5G (0xff<<16) /* 23:16 */ #define RG_SSUSB_PLL_BAND_5G (0xff<<8) /* 15:8 */ #define RG_SSUSB_PLL_BAND_2P5G (0xff<<0) /* 7:0 */ /* U3D_PHYD_BCN_DET_1 */ #define RG_SSUSB_P_BCN_OBS_PRD (0xffff<<16) /* 31:16 */ #define RG_SSUSB_U_BCN_OBS_PRD (0xffff<<0) /* 15:0 */ /* U3D_PHYD_BCN_DET_2 */ #define RG_SSUSB_P_BCN_OBS_SEL (0xfff<<16) /* 27:16 */ #define RG_SSUSB_BCN_DET_DIS (0x1<<12) /* 12:12 */ #define RG_SSUSB_U_BCN_OBS_SEL (0xfff<<0) /* 11:0 */ /* U3D_EQ0 */ #define RG_SSUSB_EQ_DLHL_LFI (0x7f<<24) /* 30:24 */ #define RG_SSUSB_EQ_DHHL_LFI (0x7f<<16) /* 22:16 */ #define RG_SSUSB_EQ_DD0HOS_LFI (0x7f<<8) /* 14:8 */ #define RG_SSUSB_EQ_DD0LOS_LFI (0x7f<<0) /* 6:0 */ /* U3D_EQ1 */ #define RG_SSUSB_EQ_DD1HOS_LFI (0x7f<<24) /* 30:24 */ #define RG_SSUSB_EQ_DD1LOS_LFI (0x7f<<16) /* 22:16 */ #define RG_SSUSB_EQ_DE0OS_LFI (0x7f<<8) /* 14:8 */ #define RG_SSUSB_EQ_DE1OS_LFI (0x7f<<0) /* 6:0 */ /* U3D_EQ2 */ #define RG_SSUSB_EQ_DLHLOS_LFI (0x7f<<24) /* 30:24 */ #define RG_SSUSB_EQ_DHHLOS_LFI (0x7f<<16) /* 22:16 */ #define RG_SSUSB_EQ_STOPTIME (0x1<<14) /* 14:14 */ #define RG_SSUSB_EQ_DHHL_LF_SEL (0x7<<11) /* 13:11 */ #define RG_SSUSB_EQ_DSAOS_LF_SEL (0x7<<8) /* 10:8 */ #define RG_SSUSB_EQ_STARTTIME (0x3<<6) /* 7:6 */ #define RG_SSUSB_EQ_DLEQ_LF_SEL (0x7<<3) /* 5:3 */ #define RG_SSUSB_EQ_DLHL_LF_SEL (0x7<<0) /* 2:0 */ /* U3D_EQ3 */ #define RG_SSUSB_EQ_DLEQ_LFI_GEN2 (0xf<<28) /* 31:28 */ #define RG_SSUSB_EQ_DLEQ_LFI_GEN1 (0xf<<24) /* 27:24 */ #define RG_SSUSB_EQ_DEYE0OS_LFI (0x7f<<16) /* 22:16 */ #define RG_SSUSB_EQ_DEYE1OS_LFI (0x7f<<8) /* 14:8 */ #define RG_SSUSB_EQ_TRI_DET_EN (0x1<<7) /* 7:7 */ #define RG_SSUSB_EQ_TRI_DET_TH (0x7f<<0) /* 6:0 */ /* U3D_EQ_EYE0 */ #define RG_SSUSB_EQ_EYE_XOFFSET (0x7f<<25) /* 31:25 */ #define RG_SSUSB_EQ_EYE_MON_EN (0x1<<24) /* 24:24 */ #define RG_SSUSB_EQ_EYE0_Y (0x7f<<16) /* 22:16 */ #define RG_SSUSB_EQ_EYE1_Y (0x7f<<8) /* 14:8 */ #define RG_SSUSB_EQ_PILPO_ROUT (0x1<<7) /* 7:7 */ #define RG_SSUSB_EQ_PI_KPGAIN (0x7<<4) /* 6:4 */ #define RG_SSUSB_EQ_EYE_CNT_EN (0x1<<3) /* 3:3 */ /* U3D_EQ_EYE1 */ #define RG_SSUSB_EQ_SIGDET (0x7f<<24) /* 30:24 */ #define RG_SSUSB_EQ_EYE_MASK (0x3ff<<7) /* 16:7 */ /* U3D_EQ_EYE2 */ #define RG_SSUSB_EQ_RX500M_CK_SEL (0x1<<31) /* 31:31 */ #define RG_SSUSB_EQ_SD_CNT1 (0x3f<<24) /* 29:24 */ #define RG_SSUSB_EQ_ISIFLAG_SEL (0x3<<22) /* 23:22 */ #define RG_SSUSB_EQ_SD_CNT0 (0x3f<<16) /* 21:16 */ /* U3D_EQ_DFE0 */ #define RG_SSUSB_EQ_LEQMAX (0xf<<28) /* 31:28 */ #define RG_SSUSB_EQ_DFEX_EN (0x1<<27) /* 27:27 */ #define RG_SSUSB_EQ_DFEX_LF_SEL (0x7<<24) /* 26:24 */ #define RG_SSUSB_EQ_CHK_EYE_H (0x1<<23) /* 23:23 */ #define RG_SSUSB_EQ_PIEYE_INI (0x7f<<16) /* 22:16 */ #define RG_SSUSB_EQ_PI90_INI (0x7f<<8) /* 14:8 */ #define RG_SSUSB_EQ_PI0_INI (0x7f<<0) /* 6:0 */ /* U3D_EQ_DFE1 */ #define RG_SSUSB_EQ_REV (0xffff<<16) /* 31:16 */ #define RG_SSUSB_EQ_DFEYEN_DUR (0x7<<12) /* 14:12 */ #define RG_SSUSB_EQ_DFEXEN_DUR (0x7<<8) /* 10:8 */ #define RG_SSUSB_EQ_DFEX_RST (0x1<<7) /* 7:7 */ #define RG_SSUSB_EQ_GATED_RXD_B (0x1<<6) /* 6:6 */ #define RG_SSUSB_EQ_PI90CK_SEL (0x3<<4) /* 5:4 */ #define RG_SSUSB_EQ_DFEX_DIS (0x1<<2) /* 2:2 */ #define RG_SSUSB_EQ_DFEYEN_STOP_DIS (0x1<<1) /* 1:1 */ #define RG_SSUSB_EQ_DFEXEN_SEL (0x1<<0) /* 0:0 */ /* U3D_EQ_DFE2 */ #define RG_SSUSB_EQ_MON_SEL (0x1f<<24) /* 28:24 */ #define RG_SSUSB_EQ_LEQOSC_DLYCNT (0x7<<16) /* 18:16 */ #define RG_SSUSB_EQ_DLEQOS_LFI (0x1f<<8) /* 12:8 */ #define RG_SSUSB_EQ_DFE_TOG (0x1<<2) /* 2:2 */ #define RG_SSUSB_EQ_LEQ_STOP_TO (0x3<<0) /* 1:0 */ /* U3D_EQ_DFE3 */ #define RG_SSUSB_EQ_RESERVED (0xffffffff<<0) /* 31:0 */ /* U3D_PHYD_MON0 */ #define RGS_SSUSB_BERT_BERC (0xffff<<16) /* 31:16 */ #define RGS_SSUSB_LFPS (0xf<<12) /* 15:12 */ #define RGS_SSUSB_TRAINDEC (0x7<<8) /* 10:8 */ #define RGS_SSUSB_SCP_PAT (0xff<<0) /* 7:0 */ /* U3D_PHYD_MON1 */ #define RGS_SSUSB_RX_FL_OUT (0xffff<<0) /* 15:0 */ /* U3D_PHYD_MON2 */ #define RGS_SSUSB_T2RLB_ERRCNT (0xffff<<16) /* 31:16 */ #define RGS_SSUSB_RETRACK (0xf<<12) /* 15:12 */ #define RGS_SSUSB_RXPLL_LOCK (0x1<<10) /* 10:10 */ #define RGS_SSUSB_CDR_VCOCAL_CPLT_D (0x1<<9) /* 9:9 */ #define RGS_SSUSB_PLL_VCOCAL_CPLT_D (0x1<<8) /* 8:8 */ #define RGS_SSUSB_PDNCTL (0xff<<0) /* 7:0 */ /* U3D_PHYD_MON3 */ #define RGS_SSUSB_TSEQ_ERRCNT (0xffff<<16) /* 31:16 */ #define RGS_SSUSB_PRBS_ERRCNT (0xffff<<0) /* 15:0 */ /* U3D_PHYD_MON4 */ #define RGS_SSUSB_RX_LSLOCK_CNT (0xf<<24) /* 27:24 */ #define RGS_SSUSB_SCP_DETCNT (0xff<<16) /* 23:16 */ #define RGS_SSUSB_TSEQ_DETCNT (0xffff<<0) /* 15:0 */ /* U3D_PHYD_MON5 */ #define RGS_SSUSB_EBUFMSG (0xffff<<16) /* 31:16 */ #define RGS_SSUSB_BERT_LOCK (0x1<<15) /* 15:15 */ #define RGS_SSUSB_SCP_DET (0x1<<14) /* 14:14 */ #define RGS_SSUSB_TSEQ_DET (0x1<<13) /* 13:13 */ #define RGS_SSUSB_EBUF_UDF (0x1<<12) /* 12:12 */ #define RGS_SSUSB_EBUF_OVF (0x1<<11) /* 11:11 */ #define RGS_SSUSB_PRBS_PASSTH (0x1<<10) /* 10:10 */ #define RGS_SSUSB_PRBS_PASS (0x1<<9) /* 9:9 */ #define RGS_SSUSB_PRBS_LOCK (0x1<<8) /* 8:8 */ #define RGS_SSUSB_T2RLB_ERR (0x1<<6) /* 6:6 */ #define RGS_SSUSB_T2RLB_PASSTH (0x1<<5) /* 5:5 */ #define RGS_SSUSB_T2RLB_PASS (0x1<<4) /* 4:4 */ #define RGS_SSUSB_T2RLB_LOCK (0x1<<3) /* 3:3 */ #define RGS_SSUSB_RX_IMPCAL_DONE (0x1<<2) /* 2:2 */ #define RGS_SSUSB_TX_IMPCAL_DONE (0x1<<1) /* 1:1 */ #define RGS_SSUSB_RXDETECTED (0x1<<0) /* 0:0 */ /* U3D_PHYD_MON6 */ #define RGS_SSUSB_SIGCAL_DONE (0x1<<30) /* 30:30 */ #define RGS_SSUSB_SIGCAL_CAL_OUT (0x1<<29) /* 29:29 */ #define RGS_SSUSB_SIGCAL_OFFSET (0x1f<<24) /* 28:24 */ #define RGS_SSUSB_RX_IMP_SEL (0x1f<<16) /* 20:16 */ #define RGS_SSUSB_TX_IMP_SEL (0x1f<<8) /* 12:8 */ #define RGS_SSUSB_TFIFO_MSG (0xf<<4) /* 7:4 */ #define RGS_SSUSB_RFIFO_MSG (0xf<<0) /* 3:0 */ /* U3D_PHYD_MON7 */ #define RGS_SSUSB_FT_OUT (0xff<<8) /* 15:8 */ #define RGS_SSUSB_PRB_OUT (0xff<<0) /* 7:0 */ /* U3D_PHYA_RX_MON0 */ #define RGS_SSUSB_EQ_DCLEQ (0xf<<24) /* 27:24 */ #define RGS_SSUSB_EQ_DCD0H (0x7f<<16) /* 22:16 */ #define RGS_SSUSB_EQ_DCD0L (0x7f<<8) /* 14:8 */ #define RGS_SSUSB_EQ_DCD1H (0x7f<<0) /* 6:0 */ /* U3D_PHYA_RX_MON1 */ #define RGS_SSUSB_EQ_DCD1L (0x7f<<24) /* 30:24 */ #define RGS_SSUSB_EQ_DCE0 (0x7f<<16) /* 22:16 */ #define RGS_SSUSB_EQ_DCE1 (0x7f<<8) /* 14:8 */ #define RGS_SSUSB_EQ_DCHHL (0x7f<<0) /* 6:0 */ /* U3D_PHYA_RX_MON2 */ #define RGS_SSUSB_EQ_LEQ_STOP (0x1<<31) /* 31:31 */ #define RGS_SSUSB_EQ_DCLHL (0x7f<<24) /* 30:24 */ #define RGS_SSUSB_EQ_STATUS (0xff<<16) /* 23:16 */ #define RGS_SSUSB_EQ_DCEYE0 (0x7f<<8) /* 14:8 */ #define RGS_SSUSB_EQ_DCEYE1 (0x7f<<0) /* 6:0 */ /* U3D_PHYA_RX_MON3 */ #define RGS_SSUSB_EQ_EYE_MONITOR_ERRCNT_0 (0xfffff<<0) /* 19:0 */ /* U3D_PHYA_RX_MON4 */ #define RGS_SSUSB_EQ_EYE_MONITOR_ERRCNT_1 (0xfffff<<0) /* 19:0 */ /* U3D_PHYA_RX_MON5 */ #define RGS_SSUSB_EQ_DCLEQOS (0x1f<<8) /* 12:8 */ #define RGS_SSUSB_EQ_EYE_CNT_RDY (0x1<<7) /* 7:7 */ #define RGS_SSUSB_EQ_PILPO (0x7f<<0) /* 6:0 */ /* U3D_PHYD_CPPAT2 */ #define RG_SSUSB_CPPAT_OUT_H_TMP2 (0xf<<16) /* 19:16 */ #define RG_SSUSB_CPPAT_OUT_H_TMP1 (0xff<<8) /* 15:8 */ #define RG_SSUSB_CPPAT_OUT_H_TMP0 (0xff<<0) /* 7:0 */ /* U3D_EQ_EYE3 */ #define RG_SSUSB_EQ_LEQ_SHIFT (0x7<<24) /* 26:24 */ #define RG_SSUSB_EQ_EYE_CNT (0xfffff<<0) /* 19:0 */ /* U3D_KBAND_OUT */ #define RGS_SSUSB_CDR_BAND_5G (0xff<<24) /* 31:24 */ #define RGS_SSUSB_CDR_BAND_2P5G (0xff<<16) /* 23:16 */ #define RGS_SSUSB_PLL_BAND_5G (0xff<<8) /* 15:8 */ #define RGS_SSUSB_PLL_BAND_2P5G (0xff<<0) /* 7:0 */ /* U3D_KBAND_OUT1 */ #define RGS_SSUSB_CDR_VCOCAL_FAIL (0x1<<24) /* 24:24 */ #define RGS_SSUSB_CDR_VCOCAL_STATE (0xff<<16) /* 23:16 */ #define RGS_SSUSB_PLL_VCOCAL_FAIL (0x1<<8) /* 8:8 */ #define RGS_SSUSB_PLL_VCOCAL_STATE (0xff<<0) /* 7:0 */ /* OFFSET */ /* U3D_PHYD_MIX0 */ #define RG_SSUSB_P_P3_TX_NG_OFST (31) #define RG_SSUSB_TSEQ_EN_OFST (30) #define RG_SSUSB_TSEQ_POLEN_OFST (29) #define RG_SSUSB_TSEQ_POL_OFST (28) #define RG_SSUSB_P_P3_PCLK_NG_OFST (27) #define RG_SSUSB_TSEQ_TH_OFST (24) #define RG_SSUSB_PRBS_BERTH_OFST (16) #define RG_SSUSB_DISABLE_PHY_U2_ON_OFST (15) #define RG_SSUSB_DISABLE_PHY_U2_OFF_OFST (14) #define RG_SSUSB_PRBS_EN_OFST (13) #define RG_SSUSB_BPSLOCK_OFST (12) #define RG_SSUSB_RTCOMCNT_OFST (8) #define RG_SSUSB_COMCNT_OFST (4) #define RG_SSUSB_PRBSEL_CALIB_OFST (0) /* U3D_PHYD_MIX1 */ #define RG_SSUSB_SLEEP_EN_OFST (31) #define RG_SSUSB_PRBSEL_PCS_OFST (28) #define RG_SSUSB_TXLFPS_PRD_OFST (24) #define RG_SSUSB_P_RX_P0S_CK_OFST (23) #define RG_SSUSB_P_TX_P0S_CK_OFST (22) #define RG_SSUSB_PDNCTL_OFST (16) #define RG_SSUSB_TX_DRV_EN_OFST (15) #define RG_SSUSB_TX_DRV_SEL_OFST (14) #define RG_SSUSB_TX_DRV_DLY_OFST (8) #define RG_SSUSB_BERT_EN_OFST (7) #define RG_SSUSB_SCP_TH_OFST (4) #define RG_SSUSB_SCP_EN_OFST (3) #define RG_SSUSB_RXANSIDEC_TEST_OFST (0) /* U3D_PHYD_LFPS0 */ #define RG_SSUSB_LFPS_PWD_OFST (30) #define RG_SSUSB_FORCE_LFPS_PWD_OFST (29) #define RG_SSUSB_RXLFPS_OVF_OFST (24) #define RG_SSUSB_P3_ENTRY_SEL_OFST (23) #define RG_SSUSB_P3_ENTRY_OFST (22) #define RG_SSUSB_RXLFPS_CDRSEL_OFST (20) #define RG_SSUSB_RXLFPS_CDRTH_OFST (16) #define RG_SSUSB_LOCK5G_BLOCK_OFST (15) #define RG_SSUSB_TFIFO_EXT_D_SEL_OFST (14) #define RG_SSUSB_TFIFO_NO_EXTEND_OFST (13) #define RG_SSUSB_RXLFPS_LOB_OFST (8) #define RG_SSUSB_TXLFPS_EN_OFST (7) #define RG_SSUSB_TXLFPS_SEL_OFST (6) #define RG_SSUSB_RXLFPS_CDRLOCK_OFST (5) #define RG_SSUSB_RXLFPS_UPB_OFST (0) /* U3D_PHYD_LFPS1 */ #define RG_SSUSB_RX_IMP_BIAS_OFST (28) #define RG_SSUSB_TX_IMP_BIAS_OFST (24) #define RG_SSUSB_FWAKE_TH_OFST (16) #define RG_SSUSB_P1_ENTRY_SEL_OFST (14) #define RG_SSUSB_P1_ENTRY_OFST (13) #define RG_SSUSB_RXLFPS_UDF_OFST (8) #define RG_SSUSB_RXLFPS_P0IDLETH_OFST (0) /* U3D_PHYD_IMPCAL0 */ #define RG_SSUSB_FORCE_TX_IMPSEL_OFST (31) #define RG_SSUSB_TX_IMPCAL_EN_OFST (30) #define RG_SSUSB_FORCE_TX_IMPCAL_EN_OFST (29) #define RG_SSUSB_TX_IMPSEL_OFST (24) #define RG_SSUSB_TX_IMPCAL_CALCYC_OFST (16) #define RG_SSUSB_TX_IMPCAL_STBCYC_OFST (10) #define RG_SSUSB_TX_IMPCAL_CYCCNT_OFST (0) /* U3D_PHYD_IMPCAL1 */ #define RG_SSUSB_FORCE_RX_IMPSEL_OFST (31) #define RG_SSUSB_RX_IMPCAL_EN_OFST (30) #define RG_SSUSB_FORCE_RX_IMPCAL_EN_OFST (29) #define RG_SSUSB_RX_IMPSEL_OFST (24) #define RG_SSUSB_RX_IMPCAL_CALCYC_OFST (16) #define RG_SSUSB_RX_IMPCAL_STBCYC_OFST (10) #define RG_SSUSB_RX_IMPCAL_CYCCNT_OFST (0) /* U3D_PHYD_TXPLL0 */ #define RG_SSUSB_TXPLL_DDSEN_CYC_OFST (27) #define RG_SSUSB_TXPLL_ON_OFST (26) #define RG_SSUSB_FORCE_TXPLLON_OFST (25) #define RG_SSUSB_TXPLL_STBCYC_OFST (16) #define RG_SSUSB_TXPLL_NCPOCHG_CYC_OFST (12) #define RG_SSUSB_TXPLL_NCPOEN_CYC_OFST (10) #define RG_SSUSB_TXPLL_DDSRSTB_CYC_OFST (0) /* U3D_PHYD_TXPLL1 */ #define RG_SSUSB_PLL_NCPO_EN_OFST (31) #define RG_SSUSB_PLL_FIFO_START_MAN_OFST (30) #define RG_SSUSB_PLL_NCPO_CHG_OFST (28) #define RG_SSUSB_PLL_DDS_RSTB_OFST (27) #define RG_SSUSB_PLL_DDS_PWDB_OFST (26) #define RG_SSUSB_PLL_DDSEN_OFST (25) #define RG_SSUSB_PLL_AUTOK_VCO_OFST (24) #define RG_SSUSB_PLL_PWD_OFST (23) #define RG_SSUSB_RX_AFE_PWD_OFST (22) #define RG_SSUSB_PLL_TCADJ_OFST (16) #define RG_SSUSB_FORCE_CDR_TCADJ_OFST (15) #define RG_SSUSB_FORCE_CDR_AUTOK_VCO_OFST (14) #define RG_SSUSB_FORCE_CDR_PWD_OFST (13) #define RG_SSUSB_FORCE_PLL_NCPO_EN_OFST (12) #define RG_SSUSB_FORCE_PLL_FIFO_START_MAN_OFST (11) #define RG_SSUSB_FORCE_PLL_NCPO_CHG_OFST (9) #define RG_SSUSB_FORCE_PLL_DDS_RSTB_OFST (8) #define RG_SSUSB_FORCE_PLL_DDS_PWDB_OFST (7) #define RG_SSUSB_FORCE_PLL_DDSEN_OFST (6) #define RG_SSUSB_FORCE_PLL_TCADJ_OFST (5) #define RG_SSUSB_FORCE_PLL_AUTOK_VCO_OFST (4) #define RG_SSUSB_FORCE_PLL_PWD_OFST (3) #define RG_SSUSB_FLT_1_DISPERR_B_OFST (2) /* U3D_PHYD_TXPLL2 */ #define RG_SSUSB_TX_LFPS_EN_OFST (31) #define RG_SSUSB_FORCE_TX_LFPS_EN_OFST (30) #define RG_SSUSB_TX_LFPS_OFST (29) #define RG_SSUSB_FORCE_TX_LFPS_OFST (28) #define RG_SSUSB_RXPLL_STB_OFST (27) #define RG_SSUSB_TXPLL_STB_OFST (26) #define RG_SSUSB_FORCE_RXPLL_STB_OFST (25) #define RG_SSUSB_FORCE_TXPLL_STB_OFST (24) #define RG_SSUSB_RXPLL_REFCKSEL_OFST (16) #define RG_SSUSB_RXPLL_STBMODE_OFST (11) #define RG_SSUSB_RXPLL_ON_OFST (10) #define RG_SSUSB_FORCE_RXPLLON_OFST (9) #define RG_SSUSB_FORCE_RX_AFE_PWD_OFST (8) #define RG_SSUSB_CDR_AUTOK_VCO_OFST (7) #define RG_SSUSB_CDR_PWD_OFST (6) #define RG_SSUSB_CDR_TCADJ_OFST (0) /* U3D_PHYD_FL0 */ #define RG_SSUSB_RX_FL_TARGET_OFST (16) #define RG_SSUSB_RX_FL_CYCLECNT_OFST (0) /* U3D_PHYD_MIX2 */ #define RG_SSUSB_RX_EQ_RST_OFST (31) #define RG_SSUSB_RX_EQ_RST_SEL_OFST (30) #define RG_SSUSB_RXVAL_RST_OFST (29) #define RG_SSUSB_RXVAL_CNT_OFST (24) #define RG_SSUSB_CDROS_EN_OFST (18) #define RG_SSUSB_CDR_LCKOP_OFST (16) #define RG_SSUSB_RX_FL_LOCKTH_OFST (8) #define RG_SSUSB_RX_FL_OFFSET_OFST (0) /* U3D_PHYD_RX0 */ #define RG_SSUSB_T2RLB_BERTH_OFST (24) #define RG_SSUSB_T2RLB_PAT_OFST (16) #define RG_SSUSB_T2RLB_EN_OFST (15) #define RG_SSUSB_T2RLB_BPSCRAMB_OFST (14) #define RG_SSUSB_T2RLB_SERIAL_OFST (13) #define RG_SSUSB_T2RLB_MODE_OFST (11) #define RG_SSUSB_RX_SAOSC_EN_OFST (10) #define RG_SSUSB_RX_SAOSC_EN_SEL_OFST (9) #define RG_SSUSB_RX_DFE_OPTION_OFST (8) #define RG_SSUSB_RX_DFE_EN_OFST (7) #define RG_SSUSB_RX_DFE_EN_SEL_OFST (6) #define RG_SSUSB_RX_EQ_EN_OFST (5) #define RG_SSUSB_RX_EQ_EN_SEL_OFST (4) #define RG_SSUSB_RX_SAOSC_RST_OFST (3) #define RG_SSUSB_RX_SAOSC_RST_SEL_OFST (2) #define RG_SSUSB_RX_DFE_RST_OFST (1) #define RG_SSUSB_RX_DFE_RST_SEL_OFST (0) /* U3D_PHYD_T2RLB */ #define RG_SSUSB_EQTRAIN_CH_MODE_OFST (28) #define RG_SSUSB_PRB_OUT_CPPAT_OFST (27) #define RG_SSUSB_BPANSIENC_OFST (26) #define RG_SSUSB_VALID_EN_OFST (25) #define RG_SSUSB_EBUF_SRST_OFST (24) #define RG_SSUSB_K_EMP_OFST (20) #define RG_SSUSB_K_FUL_OFST (16) #define RG_SSUSB_T2RLB_BDATRST_OFST (12) #define RG_SSUSB_P_T2RLB_SKP_EN_OFST (10) #define RG_SSUSB_T2RLB_PATMODE_OFST (8) #define RG_SSUSB_T2RLB_TSEQCNT_OFST (0) /* U3D_PHYD_CPPAT */ #define RG_SSUSB_CPPAT_PROGRAM_EN_OFST (24) #define RG_SSUSB_CPPAT_TOZ_OFST (21) #define RG_SSUSB_CPPAT_PRBS_EN_OFST (20) #define RG_SSUSB_CPPAT_OUT_TMP2_OFST (16) #define RG_SSUSB_CPPAT_OUT_TMP1_OFST (8) #define RG_SSUSB_CPPAT_OUT_TMP0_OFST (0) /* U3D_PHYD_MIX3 */ #define RG_SSUSB_CDR_TCADJ_MINUS_OFST (31) #define RG_SSUSB_P_CDROS_EN_OFST (30) #define RG_SSUSB_P_P2_TX_DRV_DIS_OFST (28) #define RG_SSUSB_CDR_TCADJ_OFFSET_OFST (24) #define RG_SSUSB_PLL_TCADJ_MINUS_OFST (23) #define RG_SSUSB_FORCE_PLL_BIAS_LPF_EN_OFST (20) #define RG_SSUSB_PLL_BIAS_LPF_EN_OFST (19) #define RG_SSUSB_PLL_TCADJ_OFFSET_OFST (16) #define RG_SSUSB_FORCE_PLL_SSCEN_OFST (15) #define RG_SSUSB_PLL_SSCEN_OFST (14) #define RG_SSUSB_FORCE_CDR_PI_PWD_OFST (13) #define RG_SSUSB_CDR_PI_PWD_OFST (12) #define RG_SSUSB_CDR_PI_MODE_OFST (11) #define RG_SSUSB_TXPLL_SSCEN_CYC_OFST (0) /* U3D_PHYD_EBUFCTL */ #define RG_SSUSB_EBUFCTL_OFST (0) /* U3D_PHYD_PIPE0 */ #define RG_SSUSB_RXTERMINATION_OFST (30) #define RG_SSUSB_RXEQTRAINING_OFST (29) #define RG_SSUSB_RXPOLARITY_OFST (28) #define RG_SSUSB_TXDEEMPH_OFST (26) #define RG_SSUSB_POWERDOWN_OFST (24) #define RG_SSUSB_TXONESZEROS_OFST (23) #define RG_SSUSB_TXELECIDLE_OFST (22) #define RG_SSUSB_TXDETECTRX_OFST (21) #define RG_SSUSB_PIPE_SEL_OFST (20) #define RG_SSUSB_TXDATAK_OFST (16) #define RG_SSUSB_CDR_STABLE_SEL_OFST (15) #define RG_SSUSB_CDR_STABLE_OFST (14) #define RG_SSUSB_CDR_RSTB_SEL_OFST (13) #define RG_SSUSB_CDR_RSTB_OFST (12) #define RG_SSUSB_FRC_PIPE_POWERDOWN_OFST (11) #define RG_SSUSB_P_TXBCN_DIS_OFST (6) #define RG_SSUSB_P_ERROR_SEL_OFST (4) #define RG_SSUSB_TXMARGIN_OFST (1) #define RG_SSUSB_TXCOMPLIANCE_OFST (0) /* U3D_PHYD_PIPE1 */ #define RG_SSUSB_TXDATA_OFST (0) /* U3D_PHYD_MIX4 */ #define RG_SSUSB_CDROS_CNT_OFST (24) #define RG_SSUSB_T2RLB_BER_EN_OFST (16) #define RG_SSUSB_T2RLB_BER_RATE_OFST (0) /* U3D_PHYD_CKGEN0 */ #define RG_SSUSB_RFIFO_IMPLAT_OFST (27) #define RG_SSUSB_TFIFO_PSEL_OFST (24) #define RG_SSUSB_CKGEN_PSEL_OFST (8) #define RG_SSUSB_RXCK_INV_OFST (0) /* U3D_PHYD_MIX5 */ #define RG_SSUSB_PRB_SEL_OFST (16) #define RG_SSUSB_RXPLL_STBCYC_OFST (0) /* U3D_PHYD_RESERVED */ #define RG_SSUSB_PHYD_RESERVE_OFST (0) /* U3D_PHYD_CDR0 */ #define RG_SSUSB_CDR_BIC_LTR_OFST (28) #define RG_SSUSB_CDR_BIC_LTD0_OFST (24) #define RG_SSUSB_CDR_BC_LTD1_OFST (16) #define RG_SSUSB_CDR_BC_LTR_OFST (8) #define RG_SSUSB_CDR_BC_LTD0_OFST (0) /* U3D_PHYD_CDR1 */ #define RG_SSUSB_CDR_BIR_LTD1_OFST (24) #define RG_SSUSB_CDR_BIR_LTR_OFST (16) #define RG_SSUSB_CDR_BIR_LTD0_OFST (8) #define RG_SSUSB_CDR_BW_SEL_OFST (6) #define RG_SSUSB_CDR_BIC_LTD1_OFST (0) /* U3D_PHYD_PLL_0 */ #define RG_SSUSB_FORCE_CDR_BAND_5G_OFST (28) #define RG_SSUSB_FORCE_CDR_BAND_2P5G_OFST (27) #define RG_SSUSB_FORCE_PLL_BAND_5G_OFST (26) #define RG_SSUSB_FORCE_PLL_BAND_2P5G_OFST (25) #define RG_SSUSB_P_EQ_T_SEL_OFST (15) #define RG_SSUSB_PLL_ISO_EN_CYC_OFST (5) #define RG_SSUSB_PLLBAND_RECAL_OFST (4) #define RG_SSUSB_PLL_DDS_ISO_EN_OFST (3) #define RG_SSUSB_FORCE_PLL_DDS_ISO_EN_OFST (2) #define RG_SSUSB_PLL_DDS_PWR_ON_OFST (1) #define RG_SSUSB_FORCE_PLL_DDS_PWR_ON_OFST (0) /* U3D_PHYD_PLL_1 */ #define RG_SSUSB_CDR_BAND_5G_OFST (24) #define RG_SSUSB_CDR_BAND_2P5G_OFST (16) #define RG_SSUSB_PLL_BAND_5G_OFST (8) #define RG_SSUSB_PLL_BAND_2P5G_OFST (0) /* U3D_PHYD_BCN_DET_1 */ #define RG_SSUSB_P_BCN_OBS_PRD_OFST (16) #define RG_SSUSB_U_BCN_OBS_PRD_OFST (0) /* U3D_PHYD_BCN_DET_2 */ #define RG_SSUSB_P_BCN_OBS_SEL_OFST (16) #define RG_SSUSB_BCN_DET_DIS_OFST (12) #define RG_SSUSB_U_BCN_OBS_SEL_OFST (0) /* U3D_EQ0 */ #define RG_SSUSB_EQ_DLHL_LFI_OFST (24) #define RG_SSUSB_EQ_DHHL_LFI_OFST (16) #define RG_SSUSB_EQ_DD0HOS_LFI_OFST (8) #define RG_SSUSB_EQ_DD0LOS_LFI_OFST (0) /* U3D_EQ1 */ #define RG_SSUSB_EQ_DD1HOS_LFI_OFST (24) #define RG_SSUSB_EQ_DD1LOS_LFI_OFST (16) #define RG_SSUSB_EQ_DE0OS_LFI_OFST (8) #define RG_SSUSB_EQ_DE1OS_LFI_OFST (0) /* U3D_EQ2 */ #define RG_SSUSB_EQ_DLHLOS_LFI_OFST (24) #define RG_SSUSB_EQ_DHHLOS_LFI_OFST (16) #define RG_SSUSB_EQ_STOPTIME_OFST (14) #define RG_SSUSB_EQ_DHHL_LF_SEL_OFST (11) #define RG_SSUSB_EQ_DSAOS_LF_SEL_OFST (8) #define RG_SSUSB_EQ_STARTTIME_OFST (6) #define RG_SSUSB_EQ_DLEQ_LF_SEL_OFST (3) #define RG_SSUSB_EQ_DLHL_LF_SEL_OFST (0) /* U3D_EQ3 */ #define RG_SSUSB_EQ_DLEQ_LFI_GEN2_OFST (28) #define RG_SSUSB_EQ_DLEQ_LFI_GEN1_OFST (24) #define RG_SSUSB_EQ_DEYE0OS_LFI_OFST (16) #define RG_SSUSB_EQ_DEYE1OS_LFI_OFST (8) #define RG_SSUSB_EQ_TRI_DET_EN_OFST (7) #define RG_SSUSB_EQ_TRI_DET_TH_OFST (0) /* U3D_EQ_EYE0 */ #define RG_SSUSB_EQ_EYE_XOFFSET_OFST (25) #define RG_SSUSB_EQ_EYE_MON_EN_OFST (24) #define RG_SSUSB_EQ_EYE0_Y_OFST (16) #define RG_SSUSB_EQ_EYE1_Y_OFST (8) #define RG_SSUSB_EQ_PILPO_ROUT_OFST (7) #define RG_SSUSB_EQ_PI_KPGAIN_OFST (4) #define RG_SSUSB_EQ_EYE_CNT_EN_OFST (3) /* U3D_EQ_EYE1 */ #define RG_SSUSB_EQ_SIGDET_OFST (24) #define RG_SSUSB_EQ_EYE_MASK_OFST (7) /* U3D_EQ_EYE2 */ #define RG_SSUSB_EQ_RX500M_CK_SEL_OFST (31) #define RG_SSUSB_EQ_SD_CNT1_OFST (24) #define RG_SSUSB_EQ_ISIFLAG_SEL_OFST (22) #define RG_SSUSB_EQ_SD_CNT0_OFST (16) /* U3D_EQ_DFE0 */ #define RG_SSUSB_EQ_LEQMAX_OFST (28) #define RG_SSUSB_EQ_DFEX_EN_OFST (27) #define RG_SSUSB_EQ_DFEX_LF_SEL_OFST (24) #define RG_SSUSB_EQ_CHK_EYE_H_OFST (23) #define RG_SSUSB_EQ_PIEYE_INI_OFST (16) #define RG_SSUSB_EQ_PI90_INI_OFST (8) #define RG_SSUSB_EQ_PI0_INI_OFST (0) /* U3D_EQ_DFE1 */ #define RG_SSUSB_EQ_REV_OFST (16) #define RG_SSUSB_EQ_DFEYEN_DUR_OFST (12) #define RG_SSUSB_EQ_DFEXEN_DUR_OFST (8) #define RG_SSUSB_EQ_DFEX_RST_OFST (7) #define RG_SSUSB_EQ_GATED_RXD_B_OFST (6) #define RG_SSUSB_EQ_PI90CK_SEL_OFST (4) #define RG_SSUSB_EQ_DFEX_DIS_OFST (2) #define RG_SSUSB_EQ_DFEYEN_STOP_DIS_OFST (1) #define RG_SSUSB_EQ_DFEXEN_SEL_OFST (0) /* U3D_EQ_DFE2 */ #define RG_SSUSB_EQ_MON_SEL_OFST (24) #define RG_SSUSB_EQ_LEQOSC_DLYCNT_OFST (16) #define RG_SSUSB_EQ_DLEQOS_LFI_OFST (8) #define RG_SSUSB_EQ_DFE_TOG_OFST (2) #define RG_SSUSB_EQ_LEQ_STOP_TO_OFST (0) /* U3D_EQ_DFE3 */ #define RG_SSUSB_EQ_RESERVED_OFST (0) /* U3D_PHYD_MON0 */ #define RGS_SSUSB_BERT_BERC_OFST (16) #define RGS_SSUSB_LFPS_OFST (12) #define RGS_SSUSB_TRAINDEC_OFST (8) #define RGS_SSUSB_SCP_PAT_OFST (0) /* U3D_PHYD_MON1 */ #define RGS_SSUSB_RX_FL_OUT_OFST (0) /* U3D_PHYD_MON2 */ #define RGS_SSUSB_T2RLB_ERRCNT_OFST (16) #define RGS_SSUSB_RETRACK_OFST (12) #define RGS_SSUSB_RXPLL_LOCK_OFST (10) #define RGS_SSUSB_CDR_VCOCAL_CPLT_D_OFST (9) #define RGS_SSUSB_PLL_VCOCAL_CPLT_D_OFST (8) #define RGS_SSUSB_PDNCTL_OFST (0) /* U3D_PHYD_MON3 */ #define RGS_SSUSB_TSEQ_ERRCNT_OFST (16) #define RGS_SSUSB_PRBS_ERRCNT_OFST (0) /* U3D_PHYD_MON4 */ #define RGS_SSUSB_RX_LSLOCK_CNT_OFST (24) #define RGS_SSUSB_SCP_DETCNT_OFST (16) #define RGS_SSUSB_TSEQ_DETCNT_OFST (0) /* U3D_PHYD_MON5 */ #define RGS_SSUSB_EBUFMSG_OFST (16) #define RGS_SSUSB_BERT_LOCK_OFST (15) #define RGS_SSUSB_SCP_DET_OFST (14) #define RGS_SSUSB_TSEQ_DET_OFST (13) #define RGS_SSUSB_EBUF_UDF_OFST (12) #define RGS_SSUSB_EBUF_OVF_OFST (11) #define RGS_SSUSB_PRBS_PASSTH_OFST (10) #define RGS_SSUSB_PRBS_PASS_OFST (9) #define RGS_SSUSB_PRBS_LOCK_OFST (8) #define RGS_SSUSB_T2RLB_ERR_OFST (6) #define RGS_SSUSB_T2RLB_PASSTH_OFST (5) #define RGS_SSUSB_T2RLB_PASS_OFST (4) #define RGS_SSUSB_T2RLB_LOCK_OFST (3) #define RGS_SSUSB_RX_IMPCAL_DONE_OFST (2) #define RGS_SSUSB_TX_IMPCAL_DONE_OFST (1) #define RGS_SSUSB_RXDETECTED_OFST (0) /* U3D_PHYD_MON6 */ #define RGS_SSUSB_SIGCAL_DONE_OFST (30) #define RGS_SSUSB_SIGCAL_CAL_OUT_OFST (29) #define RGS_SSUSB_SIGCAL_OFFSET_OFST (24) #define RGS_SSUSB_RX_IMP_SEL_OFST (16) #define RGS_SSUSB_TX_IMP_SEL_OFST (8) #define RGS_SSUSB_TFIFO_MSG_OFST (4) #define RGS_SSUSB_RFIFO_MSG_OFST (0) /* U3D_PHYD_MON7 */ #define RGS_SSUSB_FT_OUT_OFST (8) #define RGS_SSUSB_PRB_OUT_OFST (0) /* U3D_PHYA_RX_MON0 */ #define RGS_SSUSB_EQ_DCLEQ_OFST (24) #define RGS_SSUSB_EQ_DCD0H_OFST (16) #define RGS_SSUSB_EQ_DCD0L_OFST (8) #define RGS_SSUSB_EQ_DCD1H_OFST (0) /* U3D_PHYA_RX_MON1 */ #define RGS_SSUSB_EQ_DCD1L_OFST (24) #define RGS_SSUSB_EQ_DCE0_OFST (16) #define RGS_SSUSB_EQ_DCE1_OFST (8) #define RGS_SSUSB_EQ_DCHHL_OFST (0) /* U3D_PHYA_RX_MON2 */ #define RGS_SSUSB_EQ_LEQ_STOP_OFST (31) #define RGS_SSUSB_EQ_DCLHL_OFST (24) #define RGS_SSUSB_EQ_STATUS_OFST (16) #define RGS_SSUSB_EQ_DCEYE0_OFST (8) #define RGS_SSUSB_EQ_DCEYE1_OFST (0) /* U3D_PHYA_RX_MON3 */ #define RGS_SSUSB_EQ_EYE_MONITOR_ERRCNT_0_OFST (0) /* U3D_PHYA_RX_MON4 */ #define RGS_SSUSB_EQ_EYE_MONITOR_ERRCNT_1_OFST (0) /* U3D_PHYA_RX_MON5 */ #define RGS_SSUSB_EQ_DCLEQOS_OFST (8) #define RGS_SSUSB_EQ_EYE_CNT_RDY_OFST (7) #define RGS_SSUSB_EQ_PILPO_OFST (0) /* U3D_PHYD_CPPAT2 */ #define RG_SSUSB_CPPAT_OUT_H_TMP2_OFST (16) #define RG_SSUSB_CPPAT_OUT_H_TMP1_OFST (8) #define RG_SSUSB_CPPAT_OUT_H_TMP0_OFST (0) /* U3D_EQ_EYE3 */ #define RG_SSUSB_EQ_LEQ_SHIFT_OFST (24) #define RG_SSUSB_EQ_EYE_CNT_OFST (0) /* U3D_KBAND_OUT */ #define RGS_SSUSB_CDR_BAND_5G_OFST (24) #define RGS_SSUSB_CDR_BAND_2P5G_OFST (16) #define RGS_SSUSB_PLL_BAND_5G_OFST (8) #define RGS_SSUSB_PLL_BAND_2P5G_OFST (0) /* U3D_KBAND_OUT1 */ #define RGS_SSUSB_CDR_VCOCAL_FAIL_OFST (24) #define RGS_SSUSB_CDR_VCOCAL_STATE_OFST (16) #define RGS_SSUSB_PLL_VCOCAL_FAIL_OFST (8) #define RGS_SSUSB_PLL_VCOCAL_STATE_OFST (0) /* ///////////////////////////////////////////////////////////////////////////// */ struct u3phyd_bank2_reg_e { /* 0x0 */ PHY_LE32 b2_phyd_top1; PHY_LE32 b2_phyd_top2; PHY_LE32 b2_phyd_top3; PHY_LE32 b2_phyd_top4; /* 0x10 */ PHY_LE32 b2_phyd_top5; PHY_LE32 b2_phyd_top6; PHY_LE32 b2_phyd_top7; PHY_LE32 b2_phyd_p_sigdet1; /* 0x20 */ PHY_LE32 b2_phyd_p_sigdet2; PHY_LE32 b2_phyd_p_sigdet_cal1; PHY_LE32 b2_phyd_rxdet1; PHY_LE32 b2_phyd_rxdet2; /* 0x30 */ PHY_LE32 b2_phyd_misc0; PHY_LE32 b2_phyd_misc2; PHY_LE32 b2_phyd_misc3; PHY_LE32 b2_phyd_l1ss; /* 0x40 */ PHY_LE32 b2_rosc_0; PHY_LE32 b2_rosc_1; PHY_LE32 b2_rosc_2; PHY_LE32 b2_rosc_3; /* 0x50 */ PHY_LE32 b2_rosc_4; PHY_LE32 b2_rosc_5; PHY_LE32 b2_rosc_6; PHY_LE32 b2_rosc_7; /* 0x60 */ PHY_LE32 b2_rosc_8; PHY_LE32 b2_rosc_9; PHY_LE32 b2_rosc_a; PHY_LE32 reserve1; /* 0x70~0xd0 */ PHY_LE32 reserve2[28]; /* 0xe0 */ PHY_LE32 phyd_version; PHY_LE32 phyd_model; }; /* U3D_B2_PHYD_TOP1 */ #define RG_SSUSB_PCIE2_K_EMP (0xf<<28) /* 31:28 */ #define RG_SSUSB_PCIE2_K_FUL (0xf<<24) /* 27:24 */ #define RG_SSUSB_TX_EIDLE_LP_EN (0x1<<17) /* 17:17 */ #define RG_SSUSB_FORCE_TX_EIDLE_LP_EN (0x1<<16) /* 16:16 */ #define RG_SSUSB_SIGDET_EN (0x1<<15) /* 15:15 */ #define RG_SSUSB_FORCE_SIGDET_EN (0x1<<14) /* 14:14 */ #define RG_SSUSB_CLKRX_EN (0x1<<13) /* 13:13 */ #define RG_SSUSB_FORCE_CLKRX_EN (0x1<<12) /* 12:12 */ #define RG_SSUSB_CLKTX_EN (0x1<<11) /* 11:11 */ #define RG_SSUSB_FORCE_CLKTX_EN (0x1<<10) /* 10:10 */ #define RG_SSUSB_CLK_REQ_N_I (0x1<<9) /* 9:9 */ #define RG_SSUSB_FORCE_CLK_REQ_N_I (0x1<<8) /* 8:8 */ #define RG_SSUSB_RATE (0x1<<6) /* 6:6 */ #define RG_SSUSB_FORCE_RATE (0x1<<5) /* 5:5 */ #define RG_SSUSB_PCIE_MODE_SEL (0x1<<4) /* 4:4 */ #define RG_SSUSB_FORCE_PCIE_MODE_SEL (0x1<<3) /* 3:3 */ #define RG_SSUSB_PHY_MODE (0x3<<1) /* 2:1 */ #define RG_SSUSB_FORCE_PHY_MODE (0x1<<0) /* 0:0 */ /* U3D_B2_PHYD_TOP2 */ #define RG_SSUSB_FORCE_IDRV_6DB (0x1<<30) /* 30:30 */ #define RG_SSUSB_IDRV_6DB (0x3f<<24) /* 29:24 */ #define RG_SSUSB_FORCE_IDEM_3P5DB (0x1<<22) /* 22:22 */ #define RG_SSUSB_IDEM_3P5DB (0x3f<<16) /* 21:16 */ #define RG_SSUSB_FORCE_IDRV_3P5DB (0x1<<14) /* 14:14 */ #define RG_SSUSB_IDRV_3P5DB (0x3f<<8) /* 13:8 */ #define RG_SSUSB_FORCE_IDRV_0DB (0x1<<6) /* 6:6 */ #define RG_SSUSB_IDRV_0DB (0x3f<<0) /* 5:0 */ /* U3D_B2_PHYD_TOP3 */ #define RG_SSUSB_TX_BIASI (0x7<<25) /* 27:25 */ #define RG_SSUSB_FORCE_TX_BIASI_EN (0x1<<24) /* 24:24 */ #define RG_SSUSB_TX_BIASI_EN (0x1<<16) /* 16:16 */ #define RG_SSUSB_FORCE_TX_BIASI (0x1<<13) /* 13:13 */ #define RG_SSUSB_FORCE_IDEM_6DB (0x1<<8) /* 8:8 */ #define RG_SSUSB_IDEM_6DB (0x3f<<0) /* 5:0 */ /* U3D_B2_PHYD_TOP4 */ #define RG_SSUSB_G1_CDR_BIC_LTR (0xf<<28) /* 31:28 */ #define RG_SSUSB_G1_CDR_BIC_LTD0 (0xf<<24) /* 27:24 */ #define RG_SSUSB_G1_CDR_BC_LTD1 (0x1f<<16) /* 20:16 */ #define RG_SSUSB_G1_L1SS_CDR_BW_SEL (0x3<<13) /* 14:13 */ #define RG_SSUSB_G1_CDR_BC_LTR (0x1f<<8) /* 12:8 */ #define RG_SSUSB_G1_CDR_BW_SEL (0x3<<5) /* 6:5 */ #define RG_SSUSB_G1_CDR_BC_LTD0 (0x1f<<0) /* 4:0 */ /* U3D_B2_PHYD_TOP5 */ #define RG_SSUSB_G1_CDR_BIR_LTD1 (0x1f<<24) /* 28:24 */ #define RG_SSUSB_G1_CDR_BIR_LTR (0x1f<<16) /* 20:16 */ #define RG_SSUSB_G1_CDR_BIR_LTD0 (0x1f<<8) /* 12:8 */ #define RG_SSUSB_G1_CDR_BIC_LTD1 (0xf<<0) /* 3:0 */ /* U3D_B2_PHYD_TOP6 */ #define RG_SSUSB_G2_CDR_BIC_LTR (0xf<<28) /* 31:28 */ #define RG_SSUSB_G2_CDR_BIC_LTD0 (0xf<<24) /* 27:24 */ #define RG_SSUSB_G2_CDR_BC_LTD1 (0x1f<<16) /* 20:16 */ #define RG_SSUSB_G2_L1SS_CDR_BW_SEL (0x3<<13) /* 14:13 */ #define RG_SSUSB_G2_CDR_BC_LTR (0x1f<<8) /* 12:8 */ #define RG_SSUSB_G2_CDR_BW_SEL (0x3<<5) /* 6:5 */ #define RG_SSUSB_G2_CDR_BC_LTD0 (0x1f<<0) /* 4:0 */ /* U3D_B2_PHYD_TOP7 */ #define RG_SSUSB_G2_CDR_BIR_LTD1 (0x1f<<24) /* 28:24 */ #define RG_SSUSB_G2_CDR_BIR_LTR (0x1f<<16) /* 20:16 */ #define RG_SSUSB_G2_CDR_BIR_LTD0 (0x1f<<8) /* 12:8 */ #define RG_SSUSB_G2_CDR_BIC_LTD1 (0xf<<0) /* 3:0 */ /* U3D_B2_PHYD_P_SIGDET1 */ #define RG_SSUSB_P_SIGDET_FLT_DIS (0x1<<31) /* 31:31 */ #define RG_SSUSB_P_SIGDET_FLT_G2_DEAST_SEL (0x7f<<24) /* 30:24 */ #define RG_SSUSB_P_SIGDET_FLT_G1_DEAST_SEL (0x7f<<16) /* 22:16 */ #define RG_SSUSB_P_SIGDET_FLT_P2_AST_SEL (0x7f<<8) /* 14:8 */ #define RG_SSUSB_P_SIGDET_FLT_PX_AST_SEL (0x7f<<0) /* 6:0 */ /* U3D_B2_PHYD_P_SIGDET2 */ #define RG_SSUSB_P_SIGDET_RX_VAL_S (0x1<<29) /* 29:29 */ #define RG_SSUSB_P_SIGDET_L0S_DEAS_SEL (0x1<<28) /* 28:28 */ #define RG_SSUSB_P_SIGDET_L0_EXIT_S (0x1<<27) /* 27:27 */ #define RG_SSUSB_P_SIGDET_L0S_EXIT_T_S (0x3<<25) /* 26:25 */ #define RG_SSUSB_P_SIGDET_L0S_EXIT_S (0x1<<24) /* 24:24 */ #define RG_SSUSB_P_SIGDET_L0S_ENTRY_S (0x1<<16) /* 16:16 */ #define RG_SSUSB_P_SIGDET_PRB_SEL (0x1<<10) /* 10:10 */ #define RG_SSUSB_P_SIGDET_BK_SIG_T (0x3<<8) /* 9:8 */ #define RG_SSUSB_P_SIGDET_P2_RXLFPS (0x1<<6) /* 6:6 */ #define RG_SSUSB_P_SIGDET_NON_BK_AD (0x1<<5) /* 5:5 */ #define RG_SSUSB_P_SIGDET_BK_B_RXEQ (0x1<<4) /* 4:4 */ #define RG_SSUSB_P_SIGDET_G2_KO_SEL (0x3<<2) /* 3:2 */ #define RG_SSUSB_P_SIGDET_G1_KO_SEL (0x3<<0) /* 1:0 */ /* U3D_B2_PHYD_P_SIGDET_CAL1 */ #define RG_SSUSB_G2_2EIOS_DET_EN (0x1<<29) /* 29:29 */ #define RG_SSUSB_P_SIGDET_CAL_OFFSET (0x1f<<24) /* 28:24 */ #define RG_SSUSB_P_FORCE_SIGDET_CAL_OFFSET (0x1<<16) /* 16:16 */ #define RG_SSUSB_P_SIGDET_CAL_EN (0x1<<8) /* 8:8 */ #define RG_SSUSB_P_FORCE_SIGDET_CAL_EN (0x1<<3) /* 3:3 */ #define RG_SSUSB_P_SIGDET_FLT_EN (0x1<<2) /* 2:2 */ #define RG_SSUSB_P_SIGDET_SAMPLE_PRD (0x1<<1) /* 1:1 */ #define RG_SSUSB_P_SIGDET_REK (0x1<<0) /* 0:0 */ /* U3D_B2_PHYD_RXDET1 */ #define RG_SSUSB_RXDET_PRB_SEL (0x1<<31) /* 31:31 */ #define RG_SSUSB_FORCE_CMDET (0x1<<30) /* 30:30 */ #define RG_SSUSB_RXDET_EN (0x1<<29) /* 29:29 */ #define RG_SSUSB_FORCE_RXDET_EN (0x1<<28) /* 28:28 */ #define RG_SSUSB_RXDET_K_TWICE (0x1<<27) /* 27:27 */ #define RG_SSUSB_RXDET_STB3_SET (0x1ff<<18) /* 26:18 */ #define RG_SSUSB_RXDET_STB2_SET (0x1ff<<9) /* 17:9 */ #define RG_SSUSB_RXDET_STB1_SET (0x1ff<<0) /* 8:0 */ /* U3D_B2_PHYD_RXDET2 */ #define RG_SSUSB_PHYD_TRAINDEC_FORCE_CGEN (0x1<<31) /* 31:31 */ #define RG_SSUSB_PHYD_BERTLB_FORCE_CGEN (0x1<<30) /* 30:30 */ #define RG_SSUSB_PHYD_T2RLB_FORCE_CGEN (0x1<<29) /* 29:29 */ #define RG_SSUSB_LCK2REF_EXT_EN (0x1<<28) /* 28:28 */ #define RG_SSUSB_G2_LCK2REF_EXT_SEL (0xf<<24) /* 27:24 */ #define RG_SSUSB_LCK2REF_EXT_SEL (0xf<<20) /* 23:20 */ #define RG_SSUSB_PDN_T_SEL (0x3<<18) /* 19:18 */ #define RG_SSUSB_RXDET_STB3_SET_P3 (0x1ff<<9) /* 17:9 */ #define RG_SSUSB_RXDET_STB2_SET_P3 (0x1ff<<0) /* 8:0 */ /* U3D_B2_PHYD_MISC0 */ #define RG_SSUSB_TX_EIDLE_LP_P0DLYCYC (0x3f<<26) /* 31:26 */ #define RG_SSUSB_TX_SER_EN (0x1<<25) /* 25:25 */ #define RG_SSUSB_FORCE_TX_SER_EN (0x1<<24) /* 24:24 */ #define RG_SSUSB_TXPLL_REFCKSEL (0x1<<23) /* 23:23 */ #define RG_SSUSB_FORCE_PLL_DDS_HF_EN (0x1<<22) /* 22:22 */ #define RG_SSUSB_PLL_DDS_HF_EN_MAN (0x1<<21) /* 21:21 */ #define RG_SSUSB_RXLFPS_ENTXDRV (0x1<<20) /* 20:20 */ #define RG_SSUSB_RX_FL_UNLOCKTH (0xf<<16) /* 19:16 */ #define RG_SSUSB_LFPS_PSEL (0x1<<15) /* 15:15 */ #define RG_SSUSB_RX_SIGDET_EN (0x1<<14) /* 14:14 */ #define RG_SSUSB_RX_SIGDET_EN_SEL (0x1<<13) /* 13:13 */ #define RG_SSUSB_RX_PI_CAL_EN (0x1<<12) /* 12:12 */ #define RG_SSUSB_RX_PI_CAL_EN_SEL (0x1<<11) /* 11:11 */ #define RG_SSUSB_P3_CLS_CK_SEL (0x1<<10) /* 10:10 */ #define RG_SSUSB_T2RLB_PSEL (0x3<<8) /* 9:8 */ #define RG_SSUSB_PPCTL_PSEL (0x7<<5) /* 7:5 */ #define RG_SSUSB_PHYD_TX_DATA_INV (0x1<<4) /* 4:4 */ #define RG_SSUSB_BERTLB_PSEL (0x3<<2) /* 3:2 */ #define RG_SSUSB_RETRACK_DIS (0x1<<1) /* 1:1 */ #define RG_SSUSB_PPERRCNT_CLR (0x1<<0) /* 0:0 */ /* U3D_B2_PHYD_MISC2 */ #define RG_SSUSB_FRC_PLL_DDS_PREDIV2 (0x1<<31) /* 31:31 */ #define RG_SSUSB_FRC_PLL_DDS_IADJ (0xf<<27) /* 30:27 */ #define RG_SSUSB_P_SIGDET_125FILTER (0x1<<26) /* 26:26 */ #define RG_SSUSB_P_SIGDET_RST_FILTER (0x1<<25) /* 25:25 */ #define RG_SSUSB_P_SIGDET_EID_USE_RAW (0x1<<24) /* 24:24 */ #define RG_SSUSB_P_SIGDET_LTD_USE_RAW (0x1<<23) /* 23:23 */ #define RG_SSUSB_EIDLE_BF_RXDET (0x1<<22) /* 22:22 */ #define RG_SSUSB_EIDLE_LP_STBCYC (0x1ff<<13) /* 21:13 */ #define RG_SSUSB_TX_EIDLE_LP_POSTDLY (0x3f<<7) /* 12:7 */ #define RG_SSUSB_TX_EIDLE_LP_PREDLY (0x3f<<1) /* 6:1 */ #define RG_SSUSB_TX_EIDLE_LP_EN_ADV (0x1<<0) /* 0:0 */ /* U3D_B2_PHYD_MISC3 */ #define RGS_SSUSB_DDS_CALIB_C_STATE (0x7<<16) /* 18:16 */ #define RGS_SSUSB_PPERRCNT (0xffff<<0) /* 15:0 */ /* U3D_B2_PHYD_L1SS */ #define RG_SSUSB_L1SS_REV1 (0xff<<24) /* 31:24 */ #define RG_SSUSB_L1SS_REV0 (0xff<<16) /* 23:16 */ #define RG_SSUSB_P_LTD1_SLOCK_DIS (0x1<<11) /* 11:11 */ #define RG_SSUSB_PLL_CNT_CLEAN_DIS (0x1<<10) /* 10:10 */ #define RG_SSUSB_P_PLL_REK_SEL (0x1<<9) /* 9:9 */ #define RG_SSUSB_TXDRV_MASKDLY (0x1<<8) /* 8:8 */ #define RG_SSUSB_RXSTS_VAL (0x1<<7) /* 7:7 */ #define RG_PCIE_PHY_CLKREQ_N_EN (0x1<<6) /* 6:6 */ #define RG_PCIE_FORCE_PHY_CLKREQ_N_EN (0x1<<5) /* 5:5 */ #define RG_PCIE_PHY_CLKREQ_N_OUT (0x1<<4) /* 4:4 */ #define RG_PCIE_FORCE_PHY_CLKREQ_N_OUT (0x1<<3) /* 3:3 */ #define RG_SSUSB_RXPLL_STB_PX0 (0x1<<2) /* 2:2 */ #define RG_PCIE_L1SS_EN (0x1<<1) /* 1:1 */ #define RG_PCIE_FORCE_L1SS_EN (0x1<<0) /* 0:0 */ /* U3D_B2_ROSC_0 */ #define RG_SSUSB_RING_OSC_CNTEND (0x1ff<<23) /* 31:23 */ #define RG_SSUSB_XTAL_OSC_CNTEND (0x7f<<16) /* 22:16 */ #define RG_SSUSB_RING_OSC_EN (0x1<<3) /* 3:3 */ #define RG_SSUSB_RING_OSC_FORCE_EN (0x1<<2) /* 2:2 */ #define RG_SSUSB_FRC_RING_BYPASS_DET (0x1<<1) /* 1:1 */ #define RG_SSUSB_RING_BYPASS_DET (0x1<<0) /* 0:0 */ /* U3D_B2_ROSC_1 */ #define RG_SSUSB_RING_OSC_FRC_P3 (0x1<<20) /* 20:20 */ #define RG_SSUSB_RING_OSC_P3 (0x1<<19) /* 19:19 */ #define RG_SSUSB_RING_OSC_FRC_RECAL (0x3<<17) /* 18:17 */ #define RG_SSUSB_RING_OSC_RECAL (0x1<<16) /* 16:16 */ #define RG_SSUSB_RING_OSC_SEL (0xff<<8) /* 15:8 */ #define RG_SSUSB_RING_OSC_FRC_SEL (0x1<<0) /* 0:0 */ /* U3D_B2_ROSC_2 */ #define RG_SSUSB_RING_DET_STRCYC2 (0xffff<<16) /* 31:16 */ #define RG_SSUSB_RING_DET_STRCYC1 (0xffff<<0) /* 15:0 */ /* U3D_B2_ROSC_3 */ #define RG_SSUSB_RING_DET_DETWIN1 (0xffff<<16) /* 31:16 */ #define RG_SSUSB_RING_DET_STRCYC3 (0xffff<<0) /* 15:0 */ /* U3D_B2_ROSC_4 */ #define RG_SSUSB_RING_DET_DETWIN3 (0xffff<<16) /* 31:16 */ #define RG_SSUSB_RING_DET_DETWIN2 (0xffff<<0) /* 15:0 */ /* U3D_B2_ROSC_5 */ #define RG_SSUSB_RING_DET_LBOND1 (0xffff<<16) /* 31:16 */ #define RG_SSUSB_RING_DET_UBOND1 (0xffff<<0) /* 15:0 */ /* U3D_B2_ROSC_6 */ #define RG_SSUSB_RING_DET_LBOND2 (0xffff<<16) /* 31:16 */ #define RG_SSUSB_RING_DET_UBOND2 (0xffff<<0) /* 15:0 */ /* U3D_B2_ROSC_7 */ #define RG_SSUSB_RING_DET_LBOND3 (0xffff<<16) /* 31:16 */ #define RG_SSUSB_RING_DET_UBOND3 (0xffff<<0) /* 15:0 */ /* U3D_B2_ROSC_8 */ #define RG_SSUSB_RING_RESERVE (0xffff<<16) /* 31:16 */ #define RG_SSUSB_ROSC_PROB_SEL (0xf<<2) /* 5:2 */ #define RG_SSUSB_RING_FREQMETER_EN (0x1<<1) /* 1:1 */ #define RG_SSUSB_RING_DET_BPS_UBOND (0x1<<0) /* 0:0 */ /* U3D_B2_ROSC_9 */ #define RGS_FM_RING_CNT (0xffff<<16) /* 31:16 */ #define RGS_SSUSB_RING_OSC_STATE (0x3<<10) /* 11:10 */ #define RGS_SSUSB_RING_OSC_STABLE (0x1<<9) /* 9:9 */ #define RGS_SSUSB_RING_OSC_CAL_FAIL (0x1<<8) /* 8:8 */ #define RGS_SSUSB_RING_OSC_CAL (0xff<<0) /* 7:0 */ /* U3D_B2_ROSC_A */ #define RGS_SSUSB_ROSC_PROB_OUT (0xff<<0) /* 7:0 */ /* U3D_PHYD_VERSION */ #define RGS_SSUSB_PHYD_VERSION (0xffffffff<<0) /* 31:0 */ /* U3D_PHYD_MODEL */ #define RGS_SSUSB_PHYD_MODEL (0xffffffff<<0) /* 31:0 */ /* OFFSET */ /* U3D_B2_PHYD_TOP1 */ #define RG_SSUSB_PCIE2_K_EMP_OFST (28) #define RG_SSUSB_PCIE2_K_FUL_OFST (24) #define RG_SSUSB_TX_EIDLE_LP_EN_OFST (17) #define RG_SSUSB_FORCE_TX_EIDLE_LP_EN_OFST (16) #define RG_SSUSB_SIGDET_EN_OFST (15) #define RG_SSUSB_FORCE_SIGDET_EN_OFST (14) #define RG_SSUSB_CLKRX_EN_OFST (13) #define RG_SSUSB_FORCE_CLKRX_EN_OFST (12) #define RG_SSUSB_CLKTX_EN_OFST (11) #define RG_SSUSB_FORCE_CLKTX_EN_OFST (10) #define RG_SSUSB_CLK_REQ_N_I_OFST (9) #define RG_SSUSB_FORCE_CLK_REQ_N_I_OFST (8) #define RG_SSUSB_RATE_OFST (6) #define RG_SSUSB_FORCE_RATE_OFST (5) #define RG_SSUSB_PCIE_MODE_SEL_OFST (4) #define RG_SSUSB_FORCE_PCIE_MODE_SEL_OFST (3) #define RG_SSUSB_PHY_MODE_OFST (1) #define RG_SSUSB_FORCE_PHY_MODE_OFST (0) /* U3D_B2_PHYD_TOP2 */ #define RG_SSUSB_FORCE_IDRV_6DB_OFST (30) #define RG_SSUSB_IDRV_6DB_OFST (24) #define RG_SSUSB_FORCE_IDEM_3P5DB_OFST (22) #define RG_SSUSB_IDEM_3P5DB_OFST (16) #define RG_SSUSB_FORCE_IDRV_3P5DB_OFST (14) #define RG_SSUSB_IDRV_3P5DB_OFST (8) #define RG_SSUSB_FORCE_IDRV_0DB_OFST (6) #define RG_SSUSB_IDRV_0DB_OFST (0) /* U3D_B2_PHYD_TOP3 */ #define RG_SSUSB_TX_BIASI_OFST (25) #define RG_SSUSB_FORCE_TX_BIASI_EN_OFST (24) #define RG_SSUSB_TX_BIASI_EN_OFST (16) #define RG_SSUSB_FORCE_TX_BIASI_OFST (13) #define RG_SSUSB_FORCE_IDEM_6DB_OFST (8) #define RG_SSUSB_IDEM_6DB_OFST (0) /* U3D_B2_PHYD_TOP4 */ #define RG_SSUSB_G1_CDR_BIC_LTR_OFST (28) #define RG_SSUSB_G1_CDR_BIC_LTD0_OFST (24) #define RG_SSUSB_G1_CDR_BC_LTD1_OFST (16) #define RG_SSUSB_G1_L1SS_CDR_BW_SEL_OFST (13) #define RG_SSUSB_G1_CDR_BC_LTR_OFST (8) #define RG_SSUSB_G1_CDR_BW_SEL_OFST (5) #define RG_SSUSB_G1_CDR_BC_LTD0_OFST (0) /* U3D_B2_PHYD_TOP5 */ #define RG_SSUSB_G1_CDR_BIR_LTD1_OFST (24) #define RG_SSUSB_G1_CDR_BIR_LTR_OFST (16) #define RG_SSUSB_G1_CDR_BIR_LTD0_OFST (8) #define RG_SSUSB_G1_CDR_BIC_LTD1_OFST (0) /* U3D_B2_PHYD_TOP6 */ #define RG_SSUSB_G2_CDR_BIC_LTR_OFST (28) #define RG_SSUSB_G2_CDR_BIC_LTD0_OFST (24) #define RG_SSUSB_G2_CDR_BC_LTD1_OFST (16) #define RG_SSUSB_G2_L1SS_CDR_BW_SEL_OFST (13) #define RG_SSUSB_G2_CDR_BC_LTR_OFST (8) #define RG_SSUSB_G2_CDR_BW_SEL_OFST (5) #define RG_SSUSB_G2_CDR_BC_LTD0_OFST (0) /* U3D_B2_PHYD_TOP7 */ #define RG_SSUSB_G2_CDR_BIR_LTD1_OFST (24) #define RG_SSUSB_G2_CDR_BIR_LTR_OFST (16) #define RG_SSUSB_G2_CDR_BIR_LTD0_OFST (8) #define RG_SSUSB_G2_CDR_BIC_LTD1_OFST (0) /* U3D_B2_PHYD_P_SIGDET1 */ #define RG_SSUSB_P_SIGDET_FLT_DIS_OFST (31) #define RG_SSUSB_P_SIGDET_FLT_G2_DEAST_SEL_OFST (24) #define RG_SSUSB_P_SIGDET_FLT_G1_DEAST_SEL_OFST (16) #define RG_SSUSB_P_SIGDET_FLT_P2_AST_SEL_OFST (8) #define RG_SSUSB_P_SIGDET_FLT_PX_AST_SEL_OFST (0) /* U3D_B2_PHYD_P_SIGDET2 */ #define RG_SSUSB_P_SIGDET_RX_VAL_S_OFST (29) #define RG_SSUSB_P_SIGDET_L0S_DEAS_SEL_OFST (28) #define RG_SSUSB_P_SIGDET_L0_EXIT_S_OFST (27) #define RG_SSUSB_P_SIGDET_L0S_EXIT_T_S_OFST (25) #define RG_SSUSB_P_SIGDET_L0S_EXIT_S_OFST (24) #define RG_SSUSB_P_SIGDET_L0S_ENTRY_S_OFST (16) #define RG_SSUSB_P_SIGDET_PRB_SEL_OFST (10) #define RG_SSUSB_P_SIGDET_BK_SIG_T_OFST (8) #define RG_SSUSB_P_SIGDET_P2_RXLFPS_OFST (6) #define RG_SSUSB_P_SIGDET_NON_BK_AD_OFST (5) #define RG_SSUSB_P_SIGDET_BK_B_RXEQ_OFST (4) #define RG_SSUSB_P_SIGDET_G2_KO_SEL_OFST (2) #define RG_SSUSB_P_SIGDET_G1_KO_SEL_OFST (0) /* U3D_B2_PHYD_P_SIGDET_CAL1 */ #define RG_SSUSB_G2_2EIOS_DET_EN_OFST (29) #define RG_SSUSB_P_SIGDET_CAL_OFFSET_OFST (24) #define RG_SSUSB_P_FORCE_SIGDET_CAL_OFFSET_OFST (16) #define RG_SSUSB_P_SIGDET_CAL_EN_OFST (8) #define RG_SSUSB_P_FORCE_SIGDET_CAL_EN_OFST (3) #define RG_SSUSB_P_SIGDET_FLT_EN_OFST (2) #define RG_SSUSB_P_SIGDET_SAMPLE_PRD_OFST (1) #define RG_SSUSB_P_SIGDET_REK_OFST (0) /* U3D_B2_PHYD_RXDET1 */ #define RG_SSUSB_RXDET_PRB_SEL_OFST (31) #define RG_SSUSB_FORCE_CMDET_OFST (30) #define RG_SSUSB_RXDET_EN_OFST (29) #define RG_SSUSB_FORCE_RXDET_EN_OFST (28) #define RG_SSUSB_RXDET_K_TWICE_OFST (27) #define RG_SSUSB_RXDET_STB3_SET_OFST (18) #define RG_SSUSB_RXDET_STB2_SET_OFST (9) #define RG_SSUSB_RXDET_STB1_SET_OFST (0) /* U3D_B2_PHYD_RXDET2 */ #define RG_SSUSB_PHYD_TRAINDEC_FORCE_CGEN_OFST (31) #define RG_SSUSB_PHYD_BERTLB_FORCE_CGEN_OFST (30) #define RG_SSUSB_PHYD_T2RLB_FORCE_CGEN_OFST (29) #define RG_SSUSB_LCK2REF_EXT_EN_OFST (28) #define RG_SSUSB_G2_LCK2REF_EXT_SEL_OFST (24) #define RG_SSUSB_LCK2REF_EXT_SEL_OFST (20) #define RG_SSUSB_PDN_T_SEL_OFST (18) #define RG_SSUSB_RXDET_STB3_SET_P3_OFST (9) #define RG_SSUSB_RXDET_STB2_SET_P3_OFST (0) /* U3D_B2_PHYD_MISC0 */ #define RG_SSUSB_TX_EIDLE_LP_P0DLYCYC_OFST (26) #define RG_SSUSB_TX_SER_EN_OFST (25) #define RG_SSUSB_FORCE_TX_SER_EN_OFST (24) #define RG_SSUSB_TXPLL_REFCKSEL_OFST (23) #define RG_SSUSB_FORCE_PLL_DDS_HF_EN_OFST (22) #define RG_SSUSB_PLL_DDS_HF_EN_MAN_OFST (21) #define RG_SSUSB_RXLFPS_ENTXDRV_OFST (20) #define RG_SSUSB_RX_FL_UNLOCKTH_OFST (16) #define RG_SSUSB_LFPS_PSEL_OFST (15) #define RG_SSUSB_RX_SIGDET_EN_OFST (14) #define RG_SSUSB_RX_SIGDET_EN_SEL_OFST (13) #define RG_SSUSB_RX_PI_CAL_EN_OFST (12) #define RG_SSUSB_RX_PI_CAL_EN_SEL_OFST (11) #define RG_SSUSB_P3_CLS_CK_SEL_OFST (10) #define RG_SSUSB_T2RLB_PSEL_OFST (8) #define RG_SSUSB_PPCTL_PSEL_OFST (5) #define RG_SSUSB_PHYD_TX_DATA_INV_OFST (4) #define RG_SSUSB_BERTLB_PSEL_OFST (2) #define RG_SSUSB_RETRACK_DIS_OFST (1) #define RG_SSUSB_PPERRCNT_CLR_OFST (0) /* U3D_B2_PHYD_MISC2 */ #define RG_SSUSB_FRC_PLL_DDS_PREDIV2_OFST (31) #define RG_SSUSB_FRC_PLL_DDS_IADJ_OFST (27) #define RG_SSUSB_P_SIGDET_125FILTER_OFST (26) #define RG_SSUSB_P_SIGDET_RST_FILTER_OFST (25) #define RG_SSUSB_P_SIGDET_EID_USE_RAW_OFST (24) #define RG_SSUSB_P_SIGDET_LTD_USE_RAW_OFST (23) #define RG_SSUSB_EIDLE_BF_RXDET_OFST (22) #define RG_SSUSB_EIDLE_LP_STBCYC_OFST (13) #define RG_SSUSB_TX_EIDLE_LP_POSTDLY_OFST (7) #define RG_SSUSB_TX_EIDLE_LP_PREDLY_OFST (1) #define RG_SSUSB_TX_EIDLE_LP_EN_ADV_OFST (0) /* U3D_B2_PHYD_MISC3 */ #define RGS_SSUSB_DDS_CALIB_C_STATE_OFST (16) #define RGS_SSUSB_PPERRCNT_OFST (0) /* U3D_B2_PHYD_L1SS */ #define RG_SSUSB_L1SS_REV1_OFST (24) #define RG_SSUSB_L1SS_REV0_OFST (16) #define RG_SSUSB_P_LTD1_SLOCK_DIS_OFST (11) #define RG_SSUSB_PLL_CNT_CLEAN_DIS_OFST (10) #define RG_SSUSB_P_PLL_REK_SEL_OFST (9) #define RG_SSUSB_TXDRV_MASKDLY_OFST (8) #define RG_SSUSB_RXSTS_VAL_OFST (7) #define RG_PCIE_PHY_CLKREQ_N_EN_OFST (6) #define RG_PCIE_FORCE_PHY_CLKREQ_N_EN_OFST (5) #define RG_PCIE_PHY_CLKREQ_N_OUT_OFST (4) #define RG_PCIE_FORCE_PHY_CLKREQ_N_OUT_OFST (3) #define RG_SSUSB_RXPLL_STB_PX0_OFST (2) #define RG_PCIE_L1SS_EN_OFST (1) #define RG_PCIE_FORCE_L1SS_EN_OFST (0) /* U3D_B2_ROSC_0 */ #define RG_SSUSB_RING_OSC_CNTEND_OFST (23) #define RG_SSUSB_XTAL_OSC_CNTEND_OFST (16) #define RG_SSUSB_RING_OSC_EN_OFST (3) #define RG_SSUSB_RING_OSC_FORCE_EN_OFST (2) #define RG_SSUSB_FRC_RING_BYPASS_DET_OFST (1) #define RG_SSUSB_RING_BYPASS_DET_OFST (0) /* U3D_B2_ROSC_1 */ #define RG_SSUSB_RING_OSC_FRC_P3_OFST (20) #define RG_SSUSB_RING_OSC_P3_OFST (19) #define RG_SSUSB_RING_OSC_FRC_RECAL_OFST (17) #define RG_SSUSB_RING_OSC_RECAL_OFST (16) #define RG_SSUSB_RING_OSC_SEL_OFST (8) #define RG_SSUSB_RING_OSC_FRC_SEL_OFST (0) /* U3D_B2_ROSC_2 */ #define RG_SSUSB_RING_DET_STRCYC2_OFST (16) #define RG_SSUSB_RING_DET_STRCYC1_OFST (0) /* U3D_B2_ROSC_3 */ #define RG_SSUSB_RING_DET_DETWIN1_OFST (16) #define RG_SSUSB_RING_DET_STRCYC3_OFST (0) /* U3D_B2_ROSC_4 */ #define RG_SSUSB_RING_DET_DETWIN3_OFST (16) #define RG_SSUSB_RING_DET_DETWIN2_OFST (0) /* U3D_B2_ROSC_5 */ #define RG_SSUSB_RING_DET_LBOND1_OFST (16) #define RG_SSUSB_RING_DET_UBOND1_OFST (0) /* U3D_B2_ROSC_6 */ #define RG_SSUSB_RING_DET_LBOND2_OFST (16) #define RG_SSUSB_RING_DET_UBOND2_OFST (0) /* U3D_B2_ROSC_7 */ #define RG_SSUSB_RING_DET_LBOND3_OFST (16) #define RG_SSUSB_RING_DET_UBOND3_OFST (0) /* U3D_B2_ROSC_8 */ #define RG_SSUSB_RING_RESERVE_OFST (16) #define RG_SSUSB_ROSC_PROB_SEL_OFST (2) #define RG_SSUSB_RING_FREQMETER_EN_OFST (1) #define RG_SSUSB_RING_DET_BPS_UBOND_OFST (0) /* U3D_B2_ROSC_9 */ #define RGS_FM_RING_CNT_OFST (16) #define RGS_SSUSB_RING_OSC_STATE_OFST (10) #define RGS_SSUSB_RING_OSC_STABLE_OFST (9) #define RGS_SSUSB_RING_OSC_CAL_FAIL_OFST (8) #define RGS_SSUSB_RING_OSC_CAL_OFST (0) /* U3D_B2_ROSC_A */ #define RGS_SSUSB_ROSC_PROB_OUT_OFST (0) /* U3D_PHYD_VERSION */ #define RGS_SSUSB_PHYD_VERSION_OFST (0) /* U3D_PHYD_MODEL */ #define RGS_SSUSB_PHYD_MODEL_OFST (0) /* ///////////////////////////////////////////////////////////////////////////// */ struct sifslv_chip_reg_e { /* 0x0 */ PHY_LE32 gpio_ctla; PHY_LE32 gpio_ctlb; PHY_LE32 gpio_ctlc; }; /* ///////////////////////////////////////////////////////////////////////////// */ struct sifslv_fm_feg_e { /* 0x0 */ PHY_LE32 fmcr0; PHY_LE32 fmcr1; PHY_LE32 fmcr2; PHY_LE32 fmmonr0; /* 0X10 */ PHY_LE32 fmmonr1; }; /* U3D_FMCR0 */ #define RG_LOCKTH (0xf<<28) /* 31:28 */ #define RG_MONCLK_SEL (0x3<<26) /* 27:26 */ #define RG_FM_MODE (0x1<<25) /* 25:25 */ #define RG_FREQDET_EN (0x1<<24) /* 24:24 */ #define RG_CYCLECNT (0xffffff<<0) /* 23:0 */ /* U3D_FMCR1 */ #define RG_TARGET (0xffffffff<<0) /* 31:0 */ /* U3D_FMCR2 */ #define RG_OFFSET (0xffffffff<<0) /* 31:0 */ /* U3D_FMMONR0 */ #define USB_FM_OUT (0xffffffff<<0) /* 31:0 */ /* U3D_FMMONR1 */ #define RG_MONCLK_SEL_2 (0x1<<9) /* 9:9 */ #define RG_FRCK_EN (0x1<<8) /* 8:8 */ #define USBPLL_LOCK (0x1<<1) /* 1:1 */ #define USB_FM_VLD (0x1<<0) /* 0:0 */ /* OFFSET */ /* U3D_FMCR0 */ #define RG_LOCKTH_OFST (28) #define RG_MONCLK_SEL_OFST (26) #define RG_FM_MODE_OFST (25) #define RG_FREQDET_EN_OFST (24) #define RG_CYCLECNT_OFST (0) /* U3D_FMCR1 */ #define RG_TARGET_OFST (0) /* U3D_FMCR2 */ #define RG_OFFSET_OFST (0) /* U3D_FMMONR0 */ #define USB_FM_OUT_OFST (0) /* U3D_FMMONR1 */ #define RG_MONCLK_SEL_2_OFST (9) #define RG_FRCK_EN_OFST (8) #define USBPLL_LOCK_OFST (1) #define USB_FM_VLD_OFST (0) /* ///////////////////////////////////////////////////////////////////////////// */ struct spllc_reg_e { /* 0x0 */ PHY_LE32 u3d_syspll_0; PHY_LE32 u3d_syspll_1; PHY_LE32 u3d_syspll_2; PHY_LE32 u3d_syspll_sdm; /* 0x10 */ PHY_LE32 u3d_xtalctl_1; PHY_LE32 u3d_xtalctl_2; PHY_LE32 u3d_xtalctl3; }; /* U3D_SYSPLL_0 */ #define RG_SSUSB_SPLL_DDSEN_CYC (0x1f<<27) /* 31:27 */ #define RG_SSUSB_SPLL_NCPOEN_CYC (0x3<<25) /* 26:25 */ #define RG_SSUSB_SPLL_STBCYC (0x1ff<<16) /* 24:16 */ #define RG_SSUSB_SPLL_NCPOCHG_CYC (0xf<<12) /* 15:12 */ #define RG_SSUSB_SYSPLL_ON (0x1<<11) /* 11:11 */ #define RG_SSUSB_FORCE_SYSPLLON (0x1<<10) /* 10:10 */ #define RG_SSUSB_SPLL_DDSRSTB_CYC (0x7<<0) /* 2:0 */ /* U3D_SYSPLL_1 */ #define RG_SSUSB_PLL_BIAS_CYC (0xff<<24) /* 31:24 */ #define RG_SSUSB_SYSPLL_STB (0x1<<23) /* 23:23 */ #define RG_SSUSB_FORCE_SYSPLL_STB (0x1<<22) /* 22:22 */ #define RG_SSUSB_SPLL_DDS_ISO_EN (0x1<<21) /* 21:21 */ #define RG_SSUSB_FORCE_SPLL_DDS_ISO_EN (0x1<<20) /* 20:20 */ #define RG_SSUSB_SPLL_DDS_PWR_ON (0x1<<19) /* 19:19 */ #define RG_SSUSB_FORCE_SPLL_DDS_PWR_ON (0x1<<18) /* 18:18 */ #define RG_SSUSB_PLL_BIAS_PWD (0x1<<17) /* 17:17 */ #define RG_SSUSB_FORCE_PLL_BIAS_PWD (0x1<<16) /* 16:16 */ #define RG_SSUSB_FORCE_SPLL_NCPO_EN (0x1<<15) /* 15:15 */ #define RG_SSUSB_FORCE_SPLL_FIFO_START_MAN (0x1<<14) /* 14:14 */ #define RG_SSUSB_FORCE_SPLL_NCPO_CHG (0x1<<12) /* 12:12 */ #define RG_SSUSB_FORCE_SPLL_DDS_RSTB (0x1<<11) /* 11:11 */ #define RG_SSUSB_FORCE_SPLL_DDS_PWDB (0x1<<10) /* 10:10 */ #define RG_SSUSB_FORCE_SPLL_DDSEN (0x1<<9) /* 9:9 */ #define RG_SSUSB_FORCE_SPLL_PWD (0x1<<8) /* 8:8 */ #define RG_SSUSB_SPLL_NCPO_EN (0x1<<7) /* 7:7 */ #define RG_SSUSB_SPLL_FIFO_START_MAN (0x1<<6) /* 6:6 */ #define RG_SSUSB_SPLL_NCPO_CHG (0x1<<4) /* 4:4 */ #define RG_SSUSB_SPLL_DDS_RSTB (0x1<<3) /* 3:3 */ #define RG_SSUSB_SPLL_DDS_PWDB (0x1<<2) /* 2:2 */ #define RG_SSUSB_SPLL_DDSEN (0x1<<1) /* 1:1 */ #define RG_SSUSB_SPLL_PWD (0x1<<0) /* 0:0 */ /* U3D_SYSPLL_2 */ #define RG_SSUSB_SPLL_P_ON_SEL (0x1<<11) /* 11:11 */ #define RG_SSUSB_SPLL_FBDIV_CHG (0x1<<10) /* 10:10 */ #define RG_SSUSB_SPLL_DDS_ISOEN_CYC (0x3ff<<0) /* 9:0 */ /* U3D_SYSPLL_SDM */ #define RG_SSUSB_SPLL_SDM_ISO_EN_CYC (0x3ff<<14) /* 23:14 */ #define RG_SSUSB_SPLL_FORCE_SDM_ISO_EN (0x1<<13) /* 13:13 */ #define RG_SSUSB_SPLL_SDM_ISO_EN (0x1<<12) /* 12:12 */ #define RG_SSUSB_SPLL_SDM_PWR_ON_CYC (0x3ff<<2) /* 11:2 */ #define RG_SSUSB_SPLL_FORCE_SDM_PWR_ON (0x1<<1) /* 1:1 */ #define RG_SSUSB_SPLL_SDM_PWR_ON (0x1<<0) /* 0:0 */ /* U3D_XTALCTL_1 */ #define RG_SSUSB_BIAS_STBCYC (0x3fff<<17) /* 30:17 */ #define RG_SSUSB_XTAL_CLK_REQ_N (0x1<<16) /* 16:16 */ #define RG_SSUSB_XTAL_FORCE_CLK_REQ_N (0x1<<15) /* 15:15 */ #define RG_SSUSB_XTAL_STBCYC (0x7fff<<0) /* 14:0 */ /* U3D_XTALCTL_2 */ #define RG_SSUSB_INT_XTAL_SEL (0x1<<29) /* 29:29 */ #define RG_SSUSB_BG_LPF_DLY (0x3<<27) /* 28:27 */ #define RG_SSUSB_BG_LPF_EN (0x1<<26) /* 26:26 */ #define RG_SSUSB_FORCE_BG_LPF_EN (0x1<<25) /* 25:25 */ #define RG_SSUSB_P3_BIAS_PWD (0x1<<24) /* 24:24 */ #define RG_SSUSB_PCIE_CLKDET_HIT (0x1<<20) /* 20:20 */ #define RG_SSUSB_PCIE_CLKDET_EN (0x1<<19) /* 19:19 */ #define RG_SSUSB_FRC_PCIE_CLKDET_EN (0x1<<18) /* 18:18 */ #define RG_SSUSB_USB20_BIAS_EN (0x1<<17) /* 17:17 */ #define RG_SSUSB_USB20_SLEEP (0x1<<16) /* 16:16 */ #define RG_SSUSB_OSC_ONLY (0x1<<9) /* 9:9 */ #define RG_SSUSB_OSC_EN (0x1<<8) /* 8:8 */ #define RG_SSUSB_XTALBIAS_STB (0x1<<5) /* 5:5 */ #define RG_SSUSB_FORCE_XTALBIAS_STB (0x1<<4) /* 4:4 */ #define RG_SSUSB_BIAS_PWD (0x1<<3) /* 3:3 */ #define RG_SSUSB_XTAL_PWD (0x1<<2) /* 2:2 */ #define RG_SSUSB_FORCE_BIAS_PWD (0x1<<1) /* 1:1 */ #define RG_SSUSB_FORCE_XTAL_PWD (0x1<<0) /* 0:0 */ /* U3D_XTALCTL3 */ #define RG_SSUSB_XTALCTL_REV (0xf<<12) /* 15:12 */ #define RG_SSUSB_BIASIMR_EN (0x1<<11) /* 11:11 */ #define RG_SSUSB_FORCE_BIASIMR_EN (0x1<<10) /* 10:10 */ #define RG_SSUSB_XTAL_RX_PWD (0x1<<9) /* 9:9 */ #define RG_SSUSB_FRC_XTAL_RX_PWD (0x1<<8) /* 8:8 */ #define RG_SSUSB_CKBG_PROB_SEL (0x3<<6) /* 7:6 */ #define RG_SSUSB_XTAL_PROB_SEL (0x3<<4) /* 5:4 */ #define RG_SSUSB_XTAL_VREGBIAS_LPF_ENB (0x1<<3) /* 3:3 */ #define RG_SSUSB_XTAL_FRC_VREGBIAS_LPF_ENB (0x1<<2) /* 2:2 */ #define RG_SSUSB_XTAL_VREGBIAS_PWD (0x1<<1) /* 1:1 */ #define RG_SSUSB_XTAL_FRC_VREGBIAS_PWD (0x1<<0) /* 0:0 */ /* SSUSB_SIFSLV_SPLLC FIELD OFFSET DEFINITION */ /* U3D_SYSPLL_0 */ #define RG_SSUSB_SPLL_DDSEN_CYC_OFST (27) #define RG_SSUSB_SPLL_NCPOEN_CYC_OFST (25) #define RG_SSUSB_SPLL_STBCYC_OFST (16) #define RG_SSUSB_SPLL_NCPOCHG_CYC_OFST (12) #define RG_SSUSB_SYSPLL_ON_OFST (11) #define RG_SSUSB_FORCE_SYSPLLON_OFST (10) #define RG_SSUSB_SPLL_DDSRSTB_CYC_OFST (0) /* U3D_SYSPLL_1 */ #define RG_SSUSB_PLL_BIAS_CYC_OFST (24) #define RG_SSUSB_SYSPLL_STB_OFST (23) #define RG_SSUSB_FORCE_SYSPLL_STB_OFST (22) #define RG_SSUSB_SPLL_DDS_ISO_EN_OFST (21) #define RG_SSUSB_FORCE_SPLL_DDS_ISO_EN_OFST (20) #define RG_SSUSB_SPLL_DDS_PWR_ON_OFST (19) #define RG_SSUSB_FORCE_SPLL_DDS_PWR_ON_OFST (18) #define RG_SSUSB_PLL_BIAS_PWD_OFST (17) #define RG_SSUSB_FORCE_PLL_BIAS_PWD_OFST (16) #define RG_SSUSB_FORCE_SPLL_NCPO_EN_OFST (15) #define RG_SSUSB_FORCE_SPLL_FIFO_START_MAN_OFST (14) #define RG_SSUSB_FORCE_SPLL_NCPO_CHG_OFST (12) #define RG_SSUSB_FORCE_SPLL_DDS_RSTB_OFST (11) #define RG_SSUSB_FORCE_SPLL_DDS_PWDB_OFST (10) #define RG_SSUSB_FORCE_SPLL_DDSEN_OFST (9) #define RG_SSUSB_FORCE_SPLL_PWD_OFST (8) #define RG_SSUSB_SPLL_NCPO_EN_OFST (7) #define RG_SSUSB_SPLL_FIFO_START_MAN_OFST (6) #define RG_SSUSB_SPLL_NCPO_CHG_OFST (4) #define RG_SSUSB_SPLL_DDS_RSTB_OFST (3) #define RG_SSUSB_SPLL_DDS_PWDB_OFST (2) #define RG_SSUSB_SPLL_DDSEN_OFST (1) #define RG_SSUSB_SPLL_PWD_OFST (0) /* U3D_SYSPLL_2 */ #define RG_SSUSB_SPLL_P_ON_SEL_OFST (11) #define RG_SSUSB_SPLL_FBDIV_CHG_OFST (10) #define RG_SSUSB_SPLL_DDS_ISOEN_CYC_OFST (0) /* U3D_SYSPLL_SDM */ #define RG_SSUSB_SPLL_SDM_ISO_EN_CYC_OFST (14) #define RG_SSUSB_SPLL_FORCE_SDM_ISO_EN_OFST (13) #define RG_SSUSB_SPLL_SDM_ISO_EN_OFST (12) #define RG_SSUSB_SPLL_SDM_PWR_ON_CYC_OFST (2) #define RG_SSUSB_SPLL_FORCE_SDM_PWR_ON_OFST (1) #define RG_SSUSB_SPLL_SDM_PWR_ON_OFST (0) /* U3D_XTALCTL_1 */ #define RG_SSUSB_BIAS_STBCYC_OFST (17) #define RG_SSUSB_XTAL_CLK_REQ_N_OFST (16) #define RG_SSUSB_XTAL_FORCE_CLK_REQ_N_OFST (15) #define RG_SSUSB_XTAL_STBCYC_OFST (0) /* U3D_XTALCTL_2 */ #define RG_SSUSB_INT_XTAL_SEL_OFST (29) #define RG_SSUSB_BG_LPF_DLY_OFST (27) #define RG_SSUSB_BG_LPF_EN_OFST (26) #define RG_SSUSB_FORCE_BG_LPF_EN_OFST (25) #define RG_SSUSB_P3_BIAS_PWD_OFST (24) #define RG_SSUSB_PCIE_CLKDET_HIT_OFST (20) #define RG_SSUSB_PCIE_CLKDET_EN_OFST (19) #define RG_SSUSB_FRC_PCIE_CLKDET_EN_OFST (18) #define RG_SSUSB_USB20_BIAS_EN_OFST (17) #define RG_SSUSB_USB20_SLEEP_OFST (16) #define RG_SSUSB_OSC_ONLY_OFST (9) #define RG_SSUSB_OSC_EN_OFST (8) #define RG_SSUSB_XTALBIAS_STB_OFST (5) #define RG_SSUSB_FORCE_XTALBIAS_STB_OFST (4) #define RG_SSUSB_BIAS_PWD_OFST (3) #define RG_SSUSB_XTAL_PWD_OFST (2) #define RG_SSUSB_FORCE_BIAS_PWD_OFST (1) #define RG_SSUSB_FORCE_XTAL_PWD_OFST (0) /* U3D_XTALCTL3 */ #define RG_SSUSB_XTALCTL_REV_OFST (12) #define RG_SSUSB_BIASIMR_EN_OFST (11) #define RG_SSUSB_FORCE_BIASIMR_EN_OFST (10) #define RG_SSUSB_XTAL_RX_PWD_OFST (9) #define RG_SSUSB_FRC_XTAL_RX_PWD_OFST (8) #define RG_SSUSB_CKBG_PROB_SEL_OFST (6) #define RG_SSUSB_XTAL_PROB_SEL_OFST (4) #define RG_SSUSB_XTAL_VREGBIAS_LPF_ENB_OFST (3) #define RG_SSUSB_XTAL_FRC_VREGBIAS_LPF_ENB_OFST (2) #define RG_SSUSB_XTAL_VREGBIAS_PWD_OFST (1) #define RG_SSUSB_XTAL_FRC_VREGBIAS_PWD_OFST (0) /* ///////////////////////////////////////////////////////////////////////////// */ PHY_INT32 phy_init_soc(struct u3phy_info *info); PHY_INT32 u2_slew_rate_calibration(struct u3phy_info *info); void usb_phy_savecurrent(unsigned int clk_on); void usb_phy_recover(unsigned int clk_on); void usb_fake_powerdown(unsigned int clk_on); void usb20_pll_settings(bool host, bool forceOn); extern u32 get_devinfo_with_index(u32 index); void usb20_rev6_setting(int value, bool is_update); #ifdef VCORE_OPS_DEV void vcore_op(int on); #endif #ifdef CONFIG_MTK_SIB_USB_SWITCH extern void usb_phy_sib_enable_switch(bool enable); extern bool usb_phy_sib_enable_switch_status(void); #endif /*CONFIG_MTK_SIB_USB_SWITCH*/ #ifdef CONFIG_MTK_UART_USB_SWITCH enum PORT_MODE { PORT_MODE_USB = 0, PORT_MODE_UART, PORT_MODE_MAX }; extern bool in_uart_mode; extern void uart_usb_switch_dump_register(void); extern bool usb_phy_check_in_uart_mode(void); extern void usb_phy_switch_to_usb(void); extern void usb_phy_switch_to_uart(void); extern void __iomem *ap_uart0_base; #endif extern void mtk_usb_phy_tuning(void); #endif #endif