phy: qcom-qmp-combo: Add sc8280xp USB/DP combo phys

The SC8280P has two copies of an USB/DP compbo PHY, add support for this
to the Qualcomm QMP PHY driver.

Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Link: https://lore.kernel.org/r/20220810042303.3583194-5-bjorn.andersson@linaro.org
Signed-off-by: Vinod Koul <vkoul@kernel.org>
This commit is contained in:
Bjorn Andersson 2022-08-09 21:23:03 -07:00 committed by Vinod Koul
parent c0c7769cda
commit a2e927b0e5
4 changed files with 674 additions and 4 deletions

View File

@ -606,6 +606,160 @@ static const struct qmp_phy_init_tbl qmp_v4_dp_tx_tbl[] = {
QMP_PHY_INIT_CFG(QSERDES_V4_TX_TX_EMP_POST1_LVL, 0x20),
};
static const struct qmp_phy_init_tbl qmp_v5_dp_serdes_tbl[] = {
QMP_PHY_INIT_CFG(QSERDES_V4_COM_SVS_MODE_CLK_SEL, 0x05),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_SYSCLK_EN_SEL, 0x3b),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_SYS_CLK_CTRL, 0x02),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_CLK_ENABLE1, 0x0c),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_SYSCLK_BUF_ENABLE, 0x06),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_CLK_SELECT, 0x30),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_IVCO, 0x0f),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_CCTRL_MODE0, 0x36),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_CCTRL_MODE1, 0x36),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_RCTRL_MODE0, 0x16),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_RCTRL_MODE1, 0x16),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_CP_CTRL_MODE0, 0x06),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_CP_CTRL_MODE1, 0x06),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_CMN_CONFIG, 0x02),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_INTEGLOOP_GAIN0_MODE0, 0x3f),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_INTEGLOOP_GAIN1_MODE0, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE_MAP, 0x02),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START1_MODE0, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_BG_TIMER, 0x0a),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_CORECLK_DIV_MODE0, 0x0a),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE_CTRL, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIAS_EN_CLKBUFLR_EN, 0x17),
QMP_PHY_INIT_CFG(QSERDES_V4_COM_CORE_CLK_EN, 0x1f),
};
static const struct qmp_phy_init_tbl qmp_v5_5nm_dp_tx_tbl[] = {
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_LANE_MODE_3, 0x51),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_TRANSCEIVER_BIAS_EN, 0x1a),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_VMODE_CTRL1, 0x40),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_PRE_STALL_LDO_BOOST_EN, 0x0),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_INTERFACE_SELECT, 0xff),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_CLKBUF_ENABLE, 0x0f),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_RESET_TSYNC_EN, 0x03),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_TRAN_DRVR_EMP_EN, 0xf),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_PARRATE_REC_DETECT_IDLE_EN, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_RES_CODE_LANE_OFFSET_TX, 0x11),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_RES_CODE_LANE_OFFSET_RX, 0x11),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_TX_BAND, 0x01),
};
static const struct qmp_phy_init_tbl sc8280xp_usb43dp_serdes_tbl[] = {
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_EN_CENTER, 0x01),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_PER1, 0x31),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_PER2, 0x01),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_STEP_SIZE1_MODE0, 0xfd),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_STEP_SIZE2_MODE0, 0x0d),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_STEP_SIZE1_MODE1, 0xfd),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_STEP_SIZE2_MODE1, 0x0d),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SYSCLK_BUF_ENABLE, 0x0a),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_CP_CTRL_MODE0, 0x02),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_CP_CTRL_MODE1, 0x02),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_RCTRL_MODE0, 0x16),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_RCTRL_MODE1, 0x16),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_CCTRL_MODE0, 0x36),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_CCTRL_MODE1, 0x36),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SYSCLK_EN_SEL, 0x1a),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP_EN, 0x04),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP1_MODE0, 0x14),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP2_MODE0, 0x34),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP1_MODE1, 0x34),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP2_MODE1, 0x82),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DEC_START_MODE0, 0x04),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DEC_START_MSB_MODE0, 0x01),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DEC_START_MODE1, 0x04),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DEC_START_MSB_MODE1, 0x01),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START1_MODE0, 0x55),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START2_MODE0, 0xd5),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START3_MODE0, 0x05),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START1_MODE1, 0x55),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START2_MODE1, 0xd5),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START3_MODE1, 0x05),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE_MAP, 0x02),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE1_MODE0, 0xd4),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE2_MODE0, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE1_MODE1, 0xd4),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE2_MODE1, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_HSCLK_SEL, 0x13),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_HSCLK_HS_SWITCH_SEL, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_CORECLK_DIV_MODE0, 0x0a),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_CORECLK_DIV_MODE1, 0x04),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_CORE_CLK_EN, 0x60),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_CMN_CONFIG, 0x76),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_IVCO, 0xff),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_INTEGLOOP_GAIN0_MODE0, 0x20),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_INTEGLOOP_GAIN0_MODE1, 0x20),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE_INITVAL2, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE_MAXVAL2, 0x01),
QMP_PHY_INIT_CFG(QSERDES_V5_COM_SVS_MODE_CLK_SEL, 0x0a),
};
static const struct qmp_phy_init_tbl sc8280xp_usb43dp_tx_tbl[] = {
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_LANE_MODE_1, 0x05),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_LANE_MODE_2, 0xc2),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_LANE_MODE_3, 0x10),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_RES_CODE_LANE_OFFSET_TX, 0x1f),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_TX_RES_CODE_LANE_OFFSET_RX, 0x0a),
};
static const struct qmp_phy_init_tbl sc8280xp_usb43dp_rx_tbl[] = {
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_SIGDET_CNTRL, 0x04),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_SIGDET_ENABLES, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B0, 0xd2),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B1, 0xd2),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B2, 0xdb),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B3, 0x21),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B4, 0x3f),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B5, 0x80),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B6, 0x45),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B7, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE2_B0, 0x6b),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE2_B1, 0x63),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE2_B2, 0xb6),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE2_B3, 0x23),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE2_B4, 0x35),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE2_B5, 0x30),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE2_B6, 0x8e),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_MODE_RATE2_B7, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_IVCM_CAL_CODE_OVERRIDE, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_IVCM_CAL_CTRL2, 0x80),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_SUMMER_CAL_SPD_MODE, 0x1b),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_UCDR_PI_CONTROLS, 0x15),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_UCDR_SB2_GAIN2_RATE2, 0x0a),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_RX_IVCM_POSTCAL_OFFSET, 0x7c),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_VGA_CAL_CNTRL1, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_VGA_CAL_MAN_VAL, 0x0d),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_DFE_DAC_ENABLE1, 0x00),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_DFE_3, 0x45),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_GM_CAL, 0x09),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_UCDR_FO_GAIN_RATE2, 0x09),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_UCDR_SO_GAIN_RATE2, 0x05),
QMP_PHY_INIT_CFG(QSERDES_V5_5NM_RX_Q_PI_INTRINSIC_BIAS_RATE32, 0x3f),
};
static const struct qmp_phy_init_tbl sc8280xp_usb43dp_pcs_tbl[] = {
QMP_PHY_INIT_CFG(QPHY_V5_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_LOCK_DETECT_CONFIG1, 0xd0),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_LOCK_DETECT_CONFIG2, 0x07),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_LOCK_DETECT_CONFIG3, 0x20),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_LOCK_DETECT_CONFIG6, 0x13),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_REFGEN_REQ_CONFIG1, 0x21),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_RX_SIGDET_LVL, 0xaa),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_RX_CONFIG, 0x0a),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_ALIGN_DETECT_CONFIG1, 0x88),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_ALIGN_DETECT_CONFIG2, 0x13),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_PCS_TX_RX_CONFIG, 0x0c),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_EQ_CONFIG1, 0x4b),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_EQ_CONFIG5, 0x10),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_LFPS_DET_HIGH_COUNT_VAL, 0xf8),
QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_RXEQTRAINING_DFE_TIME_S2, 0x07),
};
/* list of regulators */
struct qmp_regulator_data {
@ -646,6 +800,34 @@ static const u8 qmp_dp_v3_voltage_swing_hbr_rbr[4][4] = {
{ 0x1f, 0xff, 0xff, 0xff }
};
static const u8 qmp_dp_v5_pre_emphasis_hbr3_hbr2[4][4] = {
{ 0x20, 0x2c, 0x35, 0x3b },
{ 0x22, 0x2e, 0x36, 0xff },
{ 0x22, 0x31, 0xff, 0xff },
{ 0x24, 0xff, 0xff, 0xff }
};
static const u8 qmp_dp_v5_voltage_swing_hbr3_hbr2[4][4] = {
{ 0x22, 0x32, 0x36, 0x3a },
{ 0x29, 0x39, 0x3f, 0xff },
{ 0x30, 0x3f, 0xff, 0xff },
{ 0x3f, 0xff, 0xff, 0xff }
};
static const u8 qmp_dp_v5_pre_emphasis_hbr_rbr[4][4] = {
{ 0x20, 0x2d, 0x34, 0x3a },
{ 0x20, 0x2e, 0x35, 0xff },
{ 0x20, 0x2e, 0xff, 0xff },
{ 0x24, 0xff, 0xff, 0xff }
};
static const u8 qmp_dp_v5_voltage_swing_hbr_rbr[4][4] = {
{ 0x28, 0x2f, 0x36, 0x3f },
{ 0x31, 0x3e, 0x3f, 0xff },
{ 0x36, 0x3f, 0xff, 0xff },
{ 0x3f, 0xff, 0xff, 0xff }
};
struct qmp_phy;
/* struct qmp_phy_cfg - per-PHY initialization config */
@ -818,6 +1000,8 @@ static void qcom_qmp_v4_phy_configure_dp_tx(struct qmp_phy *qphy);
static int qcom_qmp_v4_phy_configure_dp_phy(struct qmp_phy *qphy);
static int qcom_qmp_v4_dp_phy_calibrate(struct qmp_phy *qphy);
static int qcom_qmp_v5_phy_configure_dp_phy(struct qmp_phy *qphy);
static inline void qphy_setbits(void __iomem *base, u32 offset, u32 val)
{
u32 reg;
@ -1060,6 +1244,83 @@ static const struct qmp_phy_combo_cfg sc8180x_usb3dpphy_cfg = {
.dp_cfg = &sc8180x_dpphy_cfg,
};
static const struct qmp_phy_cfg sc8280xp_usb43dp_usb_cfg = {
.type = PHY_TYPE_USB3,
.nlanes = 1,
.serdes_tbl = sc8280xp_usb43dp_serdes_tbl,
.serdes_tbl_num = ARRAY_SIZE(sc8280xp_usb43dp_serdes_tbl),
.tx_tbl = sc8280xp_usb43dp_tx_tbl,
.tx_tbl_num = ARRAY_SIZE(sc8280xp_usb43dp_tx_tbl),
.rx_tbl = sc8280xp_usb43dp_rx_tbl,
.rx_tbl_num = ARRAY_SIZE(sc8280xp_usb43dp_rx_tbl),
.pcs_tbl = sc8280xp_usb43dp_pcs_tbl,
.pcs_tbl_num = ARRAY_SIZE(sc8280xp_usb43dp_pcs_tbl),
.clk_list = qmp_v4_phy_clk_l,
.num_clks = ARRAY_SIZE(qmp_v4_phy_clk_l),
.reset_list = msm8996_usb3phy_reset_l,
.num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
.vreg_list = qmp_phy_vreg_l,
.num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
.regs = qmp_v4_usb3phy_regs_layout,
.start_ctrl = SERDES_START | PCS_START,
.pwrdn_ctrl = SW_PWRDN,
.phy_status = PHYSTATUS,
.has_pwrdn_delay = true,
.pwrdn_delay_min = POWER_DOWN_DELAY_US_MIN,
.pwrdn_delay_max = POWER_DOWN_DELAY_US_MAX,
.has_phy_dp_com_ctrl = true,
.is_dual_lane_phy = true,
};
static const struct qmp_phy_cfg sc8280xp_usb43dp_dp_cfg = {
.type = PHY_TYPE_DP,
.nlanes = 1,
.serdes_tbl = qmp_v5_dp_serdes_tbl,
.serdes_tbl_num = ARRAY_SIZE(qmp_v5_dp_serdes_tbl),
.tx_tbl = qmp_v5_5nm_dp_tx_tbl,
.tx_tbl_num = ARRAY_SIZE(qmp_v5_5nm_dp_tx_tbl),
.serdes_tbl_rbr = qmp_v4_dp_serdes_tbl_rbr,
.serdes_tbl_rbr_num = ARRAY_SIZE(qmp_v4_dp_serdes_tbl_rbr),
.serdes_tbl_hbr = qmp_v4_dp_serdes_tbl_hbr,
.serdes_tbl_hbr_num = ARRAY_SIZE(qmp_v4_dp_serdes_tbl_hbr),
.serdes_tbl_hbr2 = qmp_v4_dp_serdes_tbl_hbr2,
.serdes_tbl_hbr2_num = ARRAY_SIZE(qmp_v4_dp_serdes_tbl_hbr2),
.serdes_tbl_hbr3 = qmp_v4_dp_serdes_tbl_hbr3,
.serdes_tbl_hbr3_num = ARRAY_SIZE(qmp_v4_dp_serdes_tbl_hbr3),
.swing_hbr_rbr = &qmp_dp_v5_voltage_swing_hbr_rbr,
.pre_emphasis_hbr_rbr = &qmp_dp_v5_pre_emphasis_hbr_rbr,
.swing_hbr3_hbr2 = &qmp_dp_v5_voltage_swing_hbr3_hbr2,
.pre_emphasis_hbr3_hbr2 = &qmp_dp_v5_pre_emphasis_hbr3_hbr2,
.clk_list = qmp_v4_phy_clk_l,
.num_clks = ARRAY_SIZE(qmp_v4_phy_clk_l),
.reset_list = msm8996_usb3phy_reset_l,
.num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
.vreg_list = qmp_phy_vreg_l,
.num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
.regs = qmp_v4_usb3phy_regs_layout,
.has_phy_dp_com_ctrl = true,
.is_dual_lane_phy = true,
.dp_aux_init = qcom_qmp_v4_phy_dp_aux_init,
.configure_dp_tx = qcom_qmp_v4_phy_configure_dp_tx,
.configure_dp_phy = qcom_qmp_v5_phy_configure_dp_phy,
.calibrate_dp_phy = qcom_qmp_v4_dp_phy_calibrate,
};
static const struct qmp_phy_combo_cfg sc8280xp_usb43dpphy_combo_cfg = {
.usb_cfg = &sc8280xp_usb43dp_usb_cfg,
.dp_cfg = &sc8280xp_usb43dp_dp_cfg,
};
static const struct qmp_phy_cfg sm8250_usb3phy_cfg = {
.type = PHY_TYPE_USB3,
.nlanes = 1,
@ -1479,18 +1740,16 @@ static void qcom_qmp_v4_phy_configure_dp_tx(struct qmp_phy *qphy)
QSERDES_V4_TX_TX_EMP_POST1_LVL);
}
static int qcom_qmp_v4_phy_configure_dp_phy(struct qmp_phy *qphy)
static int qcom_qmp_v45_phy_configure_dp_phy(struct qmp_phy *qphy)
{
const struct qmp_phy_dp_clks *dp_clks = qphy->dp_clks;
const struct phy_configure_opts_dp *dp_opts = &qphy->dp_opts;
u32 phy_vco_div, status;
unsigned long pixel_freq;
u32 bias0_en, drvr0_en, bias1_en, drvr1_en;
bool reverse;
writel(0x0f, qphy->pcs + QSERDES_V4_DP_PHY_CFG_1);
reverse = qcom_qmp_phy_combo_configure_dp_mode(qphy);
qcom_qmp_phy_combo_configure_dp_mode(qphy);
writel(0x13, qphy->pcs + QSERDES_DP_PHY_AUX_CFG1);
writel(0xa4, qphy->pcs + QSERDES_DP_PHY_AUX_CFG2);
@ -1568,6 +1827,21 @@ static int qcom_qmp_v4_phy_configure_dp_phy(struct qmp_phy *qphy)
10000))
return -ETIMEDOUT;
return 0;
}
static int qcom_qmp_v4_phy_configure_dp_phy(struct qmp_phy *qphy)
{
const struct phy_configure_opts_dp *dp_opts = &qphy->dp_opts;
u32 bias0_en, drvr0_en, bias1_en, drvr1_en;
bool reverse = false;
u32 status;
int ret;
ret = qcom_qmp_v45_phy_configure_dp_phy(qphy);
if (ret < 0)
return ret;
/*
* At least for 7nm DP PHY this has to be done after enabling link
* clock.
@ -1618,6 +1892,63 @@ static int qcom_qmp_v4_phy_configure_dp_phy(struct qmp_phy *qphy)
return 0;
}
static int qcom_qmp_v5_phy_configure_dp_phy(struct qmp_phy *qphy)
{
const struct phy_configure_opts_dp *dp_opts = &qphy->dp_opts;
u32 bias0_en, drvr0_en, bias1_en, drvr1_en;
bool reverse = false;
u32 status;
int ret;
ret = qcom_qmp_v45_phy_configure_dp_phy(qphy);
if (ret < 0)
return ret;
if (dp_opts->lanes == 1) {
bias0_en = reverse ? 0x3e : 0x1a;
drvr0_en = reverse ? 0x13 : 0x10;
bias1_en = reverse ? 0x15 : 0x3e;
drvr1_en = reverse ? 0x10 : 0x13;
} else if (dp_opts->lanes == 2) {
bias0_en = reverse ? 0x3f : 0x15;
drvr0_en = 0x10;
bias1_en = reverse ? 0x15 : 0x3f;
drvr1_en = 0x10;
} else {
bias0_en = 0x3f;
bias1_en = 0x3f;
drvr0_en = 0x10;
drvr1_en = 0x10;
}
writel(drvr0_en, qphy->tx + QSERDES_V5_5NM_TX_HIGHZ_DRVR_EN);
writel(bias0_en, qphy->tx + QSERDES_V5_5NM_TX_TRANSCEIVER_BIAS_EN);
writel(drvr1_en, qphy->tx2 + QSERDES_V5_5NM_TX_HIGHZ_DRVR_EN);
writel(bias1_en, qphy->tx2 + QSERDES_V5_5NM_TX_TRANSCEIVER_BIAS_EN);
writel(0x18, qphy->pcs + QSERDES_DP_PHY_CFG);
udelay(2000);
writel(0x19, qphy->pcs + QSERDES_DP_PHY_CFG);
if (readl_poll_timeout(qphy->pcs + QSERDES_V4_DP_PHY_STATUS,
status,
((status & BIT(1)) > 0),
500,
10000))
return -ETIMEDOUT;
writel(0x0a, qphy->tx + QSERDES_V5_5NM_TX_TX_POL_INV);
writel(0x0a, qphy->tx2 + QSERDES_V5_5NM_TX_TX_POL_INV);
writel(0x27, qphy->tx + QSERDES_V5_5NM_TX_TX_DRV_LVL);
writel(0x27, qphy->tx2 + QSERDES_V5_5NM_TX_TX_DRV_LVL);
writel(0x20, qphy->tx + QSERDES_V5_5NM_TX_TX_EMP_POST1_LVL);
writel(0x20, qphy->tx2 + QSERDES_V5_5NM_TX_TX_EMP_POST1_LVL);
return 0;
}
/*
* We need to calibrate the aux setting here as many times
* as the caller tries
@ -2512,6 +2843,10 @@ static const struct of_device_id qcom_qmp_combo_phy_of_match_table[] = {
.compatible = "qcom,sc8180x-qmp-usb3-dp-phy",
.data = &sc8180x_usb3dpphy_cfg,
},
{
.compatible = "qcom,sc8280xp-qmp-usb43dp-phy",
.data = &sc8280xp_usb43dpphy_combo_cfg,
},
{ }
};
MODULE_DEVICE_TABLE(of, qcom_qmp_combo_phy_of_match_table);

View File

@ -18,6 +18,7 @@
#define QPHY_V5_PCS_RCVR_DTCT_DLY_P1U2_H 0x194
#define QPHY_V5_PCS_RATE_SLEW_CNTRL1 0x198
#define QPHY_V5_PCS_CDR_RESET_TIME 0x1b0
#define QPHY_V5_PCS_RX_CONFIG 0x1b0
#define QPHY_V5_PCS_ALIGN_DETECT_CONFIG1 0x1c0
#define QPHY_V5_PCS_ALIGN_DETECT_CONFIG2 0x1c4
#define QPHY_V5_PCS_PCS_TX_RX_CONFIG 0x1d0

View File

@ -0,0 +1,333 @@
/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2021, The Linux Foundation. All rights reserved.
*/
#ifndef QCOM_PHY_QMP_QSERDES_TXRX_V5_5NM_H_
#define QCOM_PHY_QMP_QSERDES_TXRX_V5_5NM_H_
/* Only for QMP V5 5NM PHY - TX registers */
#define QSERDES_V5_5NM_TX_RES_CODE_LANE_OFFSET_TX 0x30
#define QSERDES_V5_5NM_TX_RES_CODE_LANE_OFFSET_RX 0x34
#define QSERDES_V5_5NM_TX_LANE_MODE_1 0x78
#define QSERDES_V5_5NM_TX_LANE_MODE_2 0x7c
#define QSERDES_V5_5NM_TX_LANE_MODE_3 0x80
#define QSERDES_V5_5NM_TX_BIST_MODE_LANENO 0x00
#define QSERDES_V5_5NM_TX_BIST_INVERT 0x04
#define QSERDES_V5_5NM_TX_CLKBUF_ENABLE 0x08
#define QSERDES_V5_5NM_TX_TX_EMP_POST1_LVL 0x0c
#define QSERDES_V5_5NM_TX_TX_IDLE_LVL_LARGE_AMP 0x10
#define QSERDES_V5_5NM_TX_TX_DRV_LVL 0x14
#define QSERDES_V5_5NM_TX_TX_DRV_LVL_OFFSET 0x18
#define QSERDES_V5_5NM_TX_RESET_TSYNC_EN 0x1c
#define QSERDES_V5_5NM_TX_PRE_STALL_LDO_BOOST_EN 0x20
#define QSERDES_V5_5NM_TX_LPB_EN 0x24
#define QSERDES_V5_5NM_TX_RES_CODE_LANE_TX 0x28
#define QSERDES_V5_5NM_TX_RES_CODE_LANE_RX 0x2c
#define QSERDES_V5_5NM_TX_RES_CODE_LANE_OFFSET_TX 0x30
#define QSERDES_V5_5NM_TX_RES_CODE_LANE_OFFSET_RX 0x34
#define QSERDES_V5_5NM_TX_PERL_LENGTH1 0x38
#define QSERDES_V5_5NM_TX_PERL_LENGTH2 0x3c
#define QSERDES_V5_5NM_TX_SERDES_BYP_EN_OUT 0x40
#define QSERDES_V5_5NM_TX_DEBUG_BUS_SEL 0x44
#define QSERDES_V5_5NM_TX_TRANSCEIVER_BIAS_EN 0x48
#define QSERDES_V5_5NM_TX_HIGHZ_DRVR_EN 0x4c
#define QSERDES_V5_5NM_TX_TX_POL_INV 0x50
#define QSERDES_V5_5NM_TX_PARRATE_REC_DETECT_IDLE_EN 0x54
#define QSERDES_V5_5NM_TX_BIST_PATTERN1 0x58
#define QSERDES_V5_5NM_TX_BIST_PATTERN2 0x5c
#define QSERDES_V5_5NM_TX_BIST_PATTERN3 0x60
#define QSERDES_V5_5NM_TX_BIST_PATTERN4 0x64
#define QSERDES_V5_5NM_TX_BIST_PATTERN5 0x68
#define QSERDES_V5_5NM_TX_BIST_PATTERN6 0x6c
#define QSERDES_V5_5NM_TX_BIST_PATTERN7 0x70
#define QSERDES_V5_5NM_TX_BIST_PATTERN8 0x74
#define QSERDES_V5_5NM_TX_LANE_MODE_1 0x78
#define QSERDES_V5_5NM_TX_LANE_MODE_2 0x7c
#define QSERDES_V5_5NM_TX_LANE_MODE_3 0x80
#define QSERDES_V5_5NM_TX_ATB_SEL1 0x84
#define QSERDES_V5_5NM_TX_ATB_SEL2 0x88
#define QSERDES_V5_5NM_TX_RCV_DETECT_LVL 0x8c
#define QSERDES_V5_5NM_TX_RCV_DETECT_LVL_2 0x90
#define QSERDES_V5_5NM_TX_PRBS_SEED1 0x94
#define QSERDES_V5_5NM_TX_PRBS_SEED2 0x98
#define QSERDES_V5_5NM_TX_PRBS_SEED3 0x9c
#define QSERDES_V5_5NM_TX_PRBS_SEED4 0xa0
#define QSERDES_V5_5NM_TX_RESET_GEN 0xa4
#define QSERDES_V5_5NM_TX_RESET_GEN_MUXES 0xa8
#define QSERDES_V5_5NM_TX_TRAN_DRVR_EMP_EN 0xac
#define QSERDES_V5_5NM_TX_VMODE_CTRL1 0xb0
#define QSERDES_V5_5NM_TX_ALOG_OBSV_BUS_CTRL_1 0xb4
#define QSERDES_V5_5NM_TX_BIST_STATUS 0xb8
#define QSERDES_V5_5NM_TX_BIST_ERROR_COUNT1 0xbc
#define QSERDES_V5_5NM_TX_BIST_ERROR_COUNT2 0xc0
#define QSERDES_V5_5NM_TX_ALOG_OBSV_BUS_STATUS_1 0xc4
#define QSERDES_V5_5NM_TX_LANE_DIG_CONFIG 0xc8
#define QSERDES_V5_5NM_TX_PI_QEC_CTRL 0xcc
#define QSERDES_V5_5NM_TX_PRE_EMPH 0xd0
#define QSERDES_V5_5NM_TX_SW_RESET 0xd4
#define QSERDES_V5_5NM_TX_TX_BAND 0xd8
#define QSERDES_V5_5NM_TX_SLEW_CNTL0 0xdc
#define QSERDES_V5_5NM_TX_SLEW_CNTL1 0xe0
#define QSERDES_V5_5NM_TX_INTERFACE_SELECT 0xe4
#define QSERDES_V5_5NM_TX_DIG_BKUP_CTRL 0xe8
#define QSERDES_V5_5NM_TX_DEBUG_BUS0 0xec
#define QSERDES_V5_5NM_TX_DEBUG_BUS1 0xf0
#define QSERDES_V5_5NM_TX_DEBUG_BUS2 0xf4
#define QSERDES_V5_5NM_TX_DEBUG_BUS3 0xf8
#define QSERDES_V5_5NM_TX_TX_BKUP_RO_BUS 0xfc
/* Only for QMP V5 5NM PHY - RX registers */
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_FO_GAIN_RATE0 0x000
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_FO_GAIN_RATE1 0x004
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_FO_GAIN_RATE2 0x008
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_FO_GAIN_RATE3 0x00c
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_SO_GAIN_RATE0 0x010
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_SO_GAIN_RATE1 0x014
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_SO_GAIN_RATE2 0x018
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_SO_GAIN_RATE3 0x01c
#define QSERDES_V5_5NM_RX_UCDR_SO_SATURATION 0x020
#define QSERDES_V5_5NM_RX_UCDR_FO_TO_SO_DELAY 0x024
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_COUNT_LOW_RATE0 0x028
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_COUNT_HIGH_RATE0 0x02c
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_COUNT_LOW_RATE1 0x030
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_COUNT_HIGH_RATE1 0x034
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_COUNT_LOW_RATE2 0x038
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_COUNT_HIGH_RATE2 0x03c
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_COUNT_LOW_RATE3 0x040
#define QSERDES_V5_5NM_RX_UCDR_FASTLOCK_COUNT_HIGH_RATE3 0x044
#define QSERDES_V5_5NM_RX_UCDR_PI_CTRL1 0x048
#define QSERDES_V5_5NM_RX_UCDR_PI_CTRL2 0x04c
#define QSERDES_V5_5NM_RX_UCDR_SB2_THRESH1_RATE0 0x050
#define QSERDES_V5_5NM_RX_UCDR_SB2_THRESH1_RATE1 0x054
#define QSERDES_V5_5NM_RX_UCDR_SB2_THRESH1_RATE2 0x058
#define QSERDES_V5_5NM_RX_UCDR_SB2_THRESH1_RATE3 0x05c
#define QSERDES_V5_5NM_RX_UCDR_SB2_THRESH2_RATE0 0x060
#define QSERDES_V5_5NM_RX_UCDR_SB2_THRESH2_RATE1 0x064
#define QSERDES_V5_5NM_RX_UCDR_SB2_THRESH2_RATE2 0x068
#define QSERDES_V5_5NM_RX_UCDR_SB2_THRESH2_RATE3 0x06c
#define QSERDES_V5_5NM_RX_UCDR_SB2_GAIN1_RATE0 0x070
#define QSERDES_V5_5NM_RX_UCDR_SB2_GAIN1_RATE1 0x074
#define QSERDES_V5_5NM_RX_UCDR_SB2_GAIN1_RATE2 0x078
#define QSERDES_V5_5NM_RX_UCDR_SB2_GAIN1_RATE3 0x07c
#define QSERDES_V5_5NM_RX_UCDR_SB2_GAIN2_RATE0 0x080
#define QSERDES_V5_5NM_RX_UCDR_SB2_GAIN2_RATE1 0x084
#define QSERDES_V5_5NM_RX_UCDR_SB2_GAIN2_RATE2 0x088
#define QSERDES_V5_5NM_RX_UCDR_SB2_GAIN2_RATE3 0x08c
#define QSERDES_V5_5NM_RX_RXCLK_DIV2_CTRL 0x090
#define QSERDES_V5_5NM_RX_RX_BAND 0x094
#define QSERDES_V5_5NM_RX_RX_TERM_BW 0x098
#define QSERDES_V5_5NM_RX_UCDR_FO_GAIN_RATE0 0x09c
#define QSERDES_V5_5NM_RX_UCDR_FO_GAIN_RATE1 0x0a0
#define QSERDES_V5_5NM_RX_UCDR_FO_GAIN_RATE2 0x0a4
#define QSERDES_V5_5NM_RX_UCDR_FO_GAIN_RATE3 0x0a8
#define QSERDES_V5_5NM_RX_UCDR_SO_GAIN_RATE0 0x0ac
#define QSERDES_V5_5NM_RX_UCDR_SO_GAIN_RATE1 0x0b0
#define QSERDES_V5_5NM_RX_UCDR_SO_GAIN_RATE2 0x0b4
#define QSERDES_V5_5NM_RX_UCDR_SO_GAIN_RATE3 0x0b8
#define QSERDES_V5_5NM_RX_UCDR_PI_CONTROLS 0x0bc
#define QSERDES_V5_5NM_RX_UCDR_PD_DATA_FILTER_ENABLES 0x0c0
#define QSERDES_V5_5NM_RX_UCDR_SO_ACC_DEFAULT_VAL_RATE0 0x0c4
#define QSERDES_V5_5NM_RX_UCDR_SO_ACC_DEFAULT_VAL_RATE1 0x0c8
#define QSERDES_V5_5NM_RX_UCDR_SO_ACC_DEFAULT_VAL_RATE2 0x0cc
#define QSERDES_V5_5NM_RX_UCDR_SO_ACC_DEFAULT_VAL_RATE3 0x0d0
#define QSERDES_V5_5NM_RX_AUX_CONTROL 0x0d4
#define QSERDES_V5_5NM_RX_AUXDATA_TB 0x0d8
#define QSERDES_V5_5NM_RX_RCLK_AUXDATA_SEL 0x0dc
#define QSERDES_V5_5NM_RX_EOM_CTRL 0x0e0
#define QSERDES_V5_5NM_RX_AC_JTAG_ENABLE 0x0e4
#define QSERDES_V5_5NM_RX_AC_JTAG_INITP 0x0e8
#define QSERDES_V5_5NM_RX_AC_JTAG_INITN 0x0ec
#define QSERDES_V5_5NM_RX_AC_JTAG_LVL 0x0f0
#define QSERDES_V5_5NM_RX_AC_JTAG_MODE 0x0f4
#define QSERDES_V5_5NM_RX_AC_JTAG_RESET 0x0f8
#define QSERDES_V5_5NM_RX_RX_RCVR_IQ_EN 0x0fc
#define QSERDES_V5_5NM_RX_RX_Q_EN_RATES 0x100
#define QSERDES_V5_5NM_RX_RX_IDAC_I0_DC_OFFSETS 0x104
#define QSERDES_V5_5NM_RX_RX_IDAC_I0BAR_DC_OFFSETS 0x108
#define QSERDES_V5_5NM_RX_RX_IDAC_I1_DC_OFFSETS 0x10c
#define QSERDES_V5_5NM_RX_RX_IDAC_I1BAR_DC_OFFSETS 0x110
#define QSERDES_V5_5NM_RX_RX_IDAC_Q_DC_OFFSETS 0x114
#define QSERDES_V5_5NM_RX_RX_IDAC_QBAR_DC_OFFSETS 0x118
#define QSERDES_V5_5NM_RX_RX_IDAC_A_DC_OFFSETS 0x11c
#define QSERDES_V5_5NM_RX_RX_IDAC_ABAR_DC_OFFSETS 0x120
#define QSERDES_V5_5NM_RX_RX_IDAC_EN 0x124
#define QSERDES_V5_5NM_RX_RX_IDAC_ENABLES 0x128
#define QSERDES_V5_5NM_RX_RX_IDAC_SIGN 0x12c
#define QSERDES_V5_5NM_RX_RX_IVCM_CAL_CODE_OVERRIDE 0x130
#define QSERDES_V5_5NM_RX_RX_IVCM_CAL_CTRL1 0x134
#define QSERDES_V5_5NM_RX_RX_IVCM_CAL_CTRL2 0x138
#define QSERDES_V5_5NM_RX_RX_IVCM_POSTCAL_OFFSET 0x13c
#define QSERDES_V5_5NM_RX_RX_SUMMER_CAL_SPD_MODE 0x140
#define QSERDES_V5_5NM_RX_RX_HIGHZ_PARRATE 0x144
#define QSERDES_V5_5NM_RX_RX_TERM_AC_BYPASS_DC_COUPLE_OFFSET 0x148
#define QSERDES_V5_5NM_RX_DFE_1 0x14c
#define QSERDES_V5_5NM_RX_DFE_2 0x150
#define QSERDES_V5_5NM_RX_DFE_3 0x154
#define QSERDES_V5_5NM_RX_DFE_4 0x158
#define QSERDES_V5_5NM_RX_DFE_TAP3_CTRL 0x15c
#define QSERDES_V5_5NM_RX_DFE_TAP3_MANVAL_KTAP 0x160
#define QSERDES_V5_5NM_RX_DFE_TAP4_CTRL 0x164
#define QSERDES_V5_5NM_RX_DFE_TAP4_MANVAL_KTAP 0x168
#define QSERDES_V5_5NM_RX_DFE_TAP5_CTRL 0x16c
#define QSERDES_V5_5NM_RX_DFE_TAP5_MANVAL_KTAP 0x170
#define QSERDES_V5_5NM_RX_TX_ADPT_CTRL 0x174
#define QSERDES_V5_5NM_RX_DFE_DAC_ENABLE1 0x178
#define QSERDES_V5_5NM_RX_DFE_DAC_ENABLE2 0x17c
#define QSERDES_V5_5NM_RX_TX_ADAPT_PRE_THRESH1 0x180
#define QSERDES_V5_5NM_RX_TX_ADAPT_PRE_THRESH2 0x184
#define QSERDES_V5_5NM_RX_TX_ADAPT_POST_THRESH1 0x188
#define QSERDES_V5_5NM_RX_TX_ADAPT_POST_THRESH2 0x18c
#define QSERDES_V5_5NM_RX_TX_ADAPT_MAIN_THRESH1 0x190
#define QSERDES_V5_5NM_RX_TX_ADAPT_MAIN_THRESH2 0x194
#define QSERDES_V5_5NM_RX_VGA_CAL_CNTRL1 0x198
#define QSERDES_V5_5NM_RX_VGA_CAL_CNTRL2 0x19c
#define QSERDES_V5_5NM_RX_VGA_CAL_MAN_VAL 0x1a0
#define QSERDES_V5_5NM_RX_VTHRESH_CAL_CNTRL1 0x1a4
#define QSERDES_V5_5NM_RX_VTHRESH_CAL_CNTRL2 0x1a8
#define QSERDES_V5_5NM_RX_VTHRESH_CAL_MAN_VAL_RATE0 0x1ac
#define QSERDES_V5_5NM_RX_VTHRESH_CAL_MAN_VAL_RATE1 0x1b0
#define QSERDES_V5_5NM_RX_VTHRESH_CAL_MAN_VAL_RATE2 0x1b4
#define QSERDES_V5_5NM_RX_VTHRESH_CAL_MAN_VAL_RATE3 0x1b8
#define QSERDES_V5_5NM_RX_GM_CAL 0x1bc
#define QSERDES_V5_5NM_RX_RX_VGA_GAIN2_BLK1 0x1c0
#define QSERDES_V5_5NM_RX_RX_VGA_GAIN2_BLK2 0x1c4
#define QSERDES_V5_5NM_RX_RX_EQU_ADAPTOR_CNTRL2 0x1c8
#define QSERDES_V5_5NM_RX_RX_EQU_ADAPTOR_CNTRL3 0x1cc
#define QSERDES_V5_5NM_RX_RX_EQU_ADAPTOR_CNTRL4 0x1d0
#define QSERDES_V5_5NM_RX_RX_IDAC_TSETTLE_LOW 0x1d4
#define QSERDES_V5_5NM_RX_RX_EQ_OFFSET_LSB 0x1d8
#define QSERDES_V5_5NM_RX_RX_EQ_OFFSET_MSB 0x1dc
#define QSERDES_V5_5NM_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1 0x1e0
#define QSERDES_V5_5NM_RX_RX_OFFSET_ADAPTOR_CNTRL2 0x1e4
#define QSERDES_V5_5NM_RX_SIGDET_ENABLES 0x1e8
#define QSERDES_V5_5NM_RX_SIGDET_CNTRL 0x1ec
#define QSERDES_V5_5NM_RX_SIGDET_LVL 0x1f0
#define QSERDES_V5_5NM_RX_SIGDET_DEGLITCH_CNTRL 0x1f4
#define QSERDES_V5_5NM_RX_CDR_FREEZE_UP_DN 0x1f8
#define QSERDES_V5_5NM_RX_CDR_RESET_OVERRIDE 0x1fc
#define QSERDES_V5_5NM_RX_RX_INTERFACE_MODE 0x200
#define QSERDES_V5_5NM_RX_JITTER_GEN_MODE 0x204
#define QSERDES_V5_5NM_RX_SJ_AMP1 0x208
#define QSERDES_V5_5NM_RX_SJ_AMP2 0x20c
#define QSERDES_V5_5NM_RX_SJ_PER1 0x210
#define QSERDES_V5_5NM_RX_SJ_PER2 0x214
#define QSERDES_V5_5NM_RX_PPM_OFFSET1 0x218
#define QSERDES_V5_5NM_RX_PPM_OFFSET2 0x21c
#define QSERDES_V5_5NM_RX_SIGN_PPM_PERIOD1 0x220
#define QSERDES_V5_5NM_RX_SIGN_PPM_PERIOD2 0x224
#define QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B0 0x228
#define QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B1 0x22c
#define QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B2 0x230
#define QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B3 0x234
#define QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B4 0x238
#define QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B5 0x23c
#define QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B6 0x240
#define QSERDES_V5_5NM_RX_RX_MODE_RATE_0_1_B7 0x244
#define QSERDES_V5_5NM_RX_RX_MODE_RATE2_B0 0x248
#define QSERDES_V5_5NM_RX_RX_MODE_RATE2_B1 0x24c
#define QSERDES_V5_5NM_RX_RX_MODE_RATE2_B2 0x250
#define QSERDES_V5_5NM_RX_RX_MODE_RATE2_B3 0x254
#define QSERDES_V5_5NM_RX_RX_MODE_RATE2_B4 0x258
#define QSERDES_V5_5NM_RX_RX_MODE_RATE2_B5 0x25c
#define QSERDES_V5_5NM_RX_RX_MODE_RATE2_B6 0x260
#define QSERDES_V5_5NM_RX_RX_MODE_RATE2_B7 0x264
#define QSERDES_V5_5NM_RX_RX_MODE_RATE3_B0 0x268
#define QSERDES_V5_5NM_RX_RX_MODE_RATE3_B1 0x26c
#define QSERDES_V5_5NM_RX_RX_MODE_RATE3_B2 0x270
#define QSERDES_V5_5NM_RX_RX_MODE_RATE3_B3 0x274
#define QSERDES_V5_5NM_RX_RX_MODE_RATE3_B4 0x278
#define QSERDES_V5_5NM_RX_RX_MODE_RATE3_B5 0x27c
#define QSERDES_V5_5NM_RX_RX_MODE_RATE3_B6 0x280
#define QSERDES_V5_5NM_RX_RX_MODE_RATE3_B7 0x284
#define QSERDES_V5_5NM_RX_PHPRE_CTRL 0x288
#define QSERDES_V5_5NM_RX_PHPRE_INITVAL 0x28c
#define QSERDES_V5_5NM_RX_DFE_EN_TIMER 0x290
#define QSERDES_V5_5NM_RX_DFE_CTLE_POST_CAL_OFFSET 0x294
#define QSERDES_V5_5NM_RX_DCC_CTRL1 0x298
#define QSERDES_V5_5NM_RX_DCC_CTRL2 0x29c
#define QSERDES_V5_5NM_RX_DCC_OFFSET 0x2a0
#define QSERDES_V5_5NM_RX_DCC_CMUX_POSTCAL_OFFSET 0x2a4
#define QSERDES_V5_5NM_RX_DCC_CMUX_CAL_CTRL1 0x2a8
#define QSERDES_V5_5NM_RX_DCC_CMUX_CAL_CTRL2 0x2ac
#define QSERDES_V5_5NM_RX_ALOG_OBSV_BUS_CTRL_1 0x2b0
#define QSERDES_V5_5NM_RX_RX_MARG_CTRL1 0x2b4
#define QSERDES_V5_5NM_RX_RX_MARG_CTRL2 0x2b8
#define QSERDES_V5_5NM_RX_RX_MARG_CTRL3 0x2bc
#define QSERDES_V5_5NM_RX_RX_MARG_CTRL_4 0x2c0
#define QSERDES_V5_5NM_RX_RX_MARG_CFG_RATE_0_1 0x2c4
#define QSERDES_V5_5NM_RX_RX_MARG_CFG_RATE_2_3 0x2c8
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_CTRL1 0x2cc
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_CTRL2 0x2d0
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH1_RATE210 0x2d4
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH1_RATE3 0x2d8
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH2_RATE210 0x2dc
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH2_RATE3 0x2e0
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH3_RATE210 0x2e4
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH3_RATE3 0x2e8
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH4_RATE210 0x2ec
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH4_RATE3 0x2f0
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH5_RATE210 0x2f4
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH5_RATE3 0x2f8
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH6_RATE210 0x2fc
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH6_RATE3 0x300
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH7_RATE210 0x304
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_THRESH7_RATE3 0x308
#define QSERDES_V5_5NM_RX_Q_PI_INTRINSIC_BIAS_RATE10 0x30c
#define QSERDES_V5_5NM_RX_Q_PI_INTRINSIC_BIAS_RATE32 0x310
#define QSERDES_V5_5NM_RX_RX_MARG_VERTICAL_CTRL 0x314
#define QSERDES_V5_5NM_RX_RX_MARG_VERTICAL_CODE 0x318
#define QSERDES_V5_5NM_RX_RES_CODE_THRESH_HIGH_AND_BYP 0x31c
#define QSERDES_V5_5NM_RX_RES_CODE_THRESH_LOW 0x320
#define QSERDES_V5_5NM_RX_RX_BKUP_CTRL1 0x324
#define QSERDES_V5_5NM_RX_RX_BKUP_CTRL2 0x328
#define QSERDES_V5_5NM_RX_RX_BKUP_CTRL3 0x32c
#define QSERDES_V5_5NM_RX_PI_CTRL1 0x330
#define QSERDES_V5_5NM_RX_PI_CTRL2 0x334
#define QSERDES_V5_5NM_RX_PI_QUAD 0x338
#define QSERDES_V5_5NM_RX_QPI_CTRL1 0x33c
#define QSERDES_V5_5NM_RX_QPI_CTRL2 0x340
#define QSERDES_V5_5NM_RX_QPI_QUAD 0x344
#define QSERDES_V5_5NM_RX_IDATA1 0x348
#define QSERDES_V5_5NM_RX_IDATA2 0x34c
#define QSERDES_V5_5NM_RX_IDATA3 0x350
#define QSERDES_V5_5NM_RX_AC_JTAG_OUTP 0x354
#define QSERDES_V5_5NM_RX_AC_JTAG_OUTN 0x358
#define QSERDES_V5_5NM_RX_RX_SIGDET 0x35c
#define QSERDES_V5_5NM_RX_ALOG_OBSV_BUS_STATUS_1 0x360
#define QSERDES_V5_5NM_RX_READ_EQCODE 0x364
#define QSERDES_V5_5NM_RX_READ_OFFSETCODE 0x368
#define QSERDES_V5_5NM_RX_IA_ERROR_COUNTER_LOW 0x36c
#define QSERDES_V5_5NM_RX_IA_ERROR_COUNTER_HIGH 0x370
#define QSERDES_V5_5NM_RX_VGA_READ_CODE 0x374
#define QSERDES_V5_5NM_RX_VTHRESH_READ_CODE 0x378
#define QSERDES_V5_5NM_RX_DFE_TAP1_READ_CODE 0x37c
#define QSERDES_V5_5NM_RX_DFE_TAP2_READ_CODE 0x380
#define QSERDES_V5_5NM_RX_DFE_TAP3_READ_CODE 0x384
#define QSERDES_V5_5NM_RX_DFE_TAP4_READ_CODE 0x388
#define QSERDES_V5_5NM_RX_DFE_TAP5_READ_CODE 0x38c
#define QSERDES_V5_5NM_RX_IDAC_STATUS_I0 0x390
#define QSERDES_V5_5NM_RX_IDAC_STATUS_I0BAR 0x394
#define QSERDES_V5_5NM_RX_IDAC_STATUS_I1 0x398
#define QSERDES_V5_5NM_RX_IDAC_STATUS_I1BAR 0x39c
#define QSERDES_V5_5NM_RX_IDAC_STATUS_Q 0x3a0
#define QSERDES_V5_5NM_RX_IDAC_STATUS_QBAR 0x3a4
#define QSERDES_V5_5NM_RX_IDAC_STATUS_A 0x3a8
#define QSERDES_V5_5NM_RX_IDAC_STATUS_ABAR 0x3ac
#define QSERDES_V5_5NM_RX_IDAC_STATUS_SM_ON 0x3b0
#define QSERDES_V5_5NM_RX_IDAC_STATUS_SIGNERROR 0x3b4
#define QSERDES_V5_5NM_RX_IVCM_CAL_STATUS 0x3b8
#define QSERDES_V5_5NM_RX_IVCM_CAL_DEBUG_STATUS 0x3bc
#define QSERDES_V5_5NM_RX_DCC_CAL_STATUS 0x3c0
#define QSERDES_V5_5NM_RX_DCC_READ_CODE_STATUS 0x3c4
#define QSERDES_V5_5NM_RX_RX_MARG_DEBUG1_STATUS 0x3c8
#define QSERDES_V5_5NM_RX_RX_MARG_DEBUG2_STATUS 0x3cc
#define QSERDES_V5_5NM_RX_RX_MARG_READ_CODE_STATUS 0x3d0
#define QSERDES_V5_5NM_RX_EOM_ERR_CNT_LSB_STATUS 0x3d4
#define QSERDES_V5_5NM_RX_EOM_ERR_CNT_MSB_STATUS 0x3d8
#define QSERDES_V5_5NM_RX_RX_MARG_COARSE_TUNE_STATUS 0x3dc
#define QSERDES_V5_5NM_RX_RX_BKUP_READ_BUS1_STATUS 0x3e0
#define QSERDES_V5_5NM_RX_RX_BKUP_READ_BUS2_STATUS 0x3e4
#define QSERDES_V5_5NM_RX_RX_BKUP_READ_BUS3_STATUS 0x3e8
#endif

View File

@ -19,6 +19,7 @@
#include "phy-qcom-qmp-qserdes-com-v5.h"
#include "phy-qcom-qmp-qserdes-txrx-v5.h"
#include "phy-qcom-qmp-qserdes-txrx-v5_20.h"
#include "phy-qcom-qmp-qserdes-txrx-v5_5nm.h"
#include "phy-qcom-qmp-qserdes-pll.h"