1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Cadence Torrent SD0801 PHY driver. 4 * 5 * Copyright 2018 Cadence Design Systems, Inc. 6 * 7 */ 8 9 #include <dt-bindings/phy/phy.h> 10 #include <dt-bindings/phy/phy-cadence.h> 11 #include <linux/clk.h> 12 #include <linux/clk-provider.h> 13 #include <linux/delay.h> 14 #include <linux/err.h> 15 #include <linux/io.h> 16 #include <linux/iopoll.h> 17 #include <linux/kernel.h> 18 #include <linux/module.h> 19 #include <linux/of.h> 20 #include <linux/phy/phy.h> 21 #include <linux/platform_device.h> 22 #include <linux/reset.h> 23 #include <linux/regmap.h> 24 25 #define REF_CLK_19_2MHZ 19200000 26 #define REF_CLK_25MHZ 25000000 27 #define REF_CLK_100MHZ 100000000 28 #define REF_CLK_156_25MHZ 156250000 29 30 #define MAX_NUM_LANES 4 31 #define DEFAULT_MAX_BIT_RATE 8100 /* in Mbps */ 32 33 #define POLL_TIMEOUT_US 5000 34 #define PLL_LOCK_TIMEOUT 100000 35 36 #define DP_PLL0 BIT(0) 37 #define DP_PLL1 BIT(1) 38 39 #define TORRENT_COMMON_CDB_OFFSET 0x0 40 41 #define TORRENT_TX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \ 42 ((0x4000 << (block_offset)) + \ 43 (((ln) << 9) << (reg_offset))) 44 45 #define TORRENT_RX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \ 46 ((0x8000 << (block_offset)) + \ 47 (((ln) << 9) << (reg_offset))) 48 49 #define TORRENT_PHY_PCS_COMMON_OFFSET(block_offset) \ 50 (0xC000 << (block_offset)) 51 52 #define TORRENT_PHY_PCS_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \ 53 ((0xD000 << (block_offset)) + \ 54 (((ln) << 8) << (reg_offset))) 55 56 #define TORRENT_PHY_PMA_COMMON_OFFSET(block_offset) \ 57 (0xE000 << (block_offset)) 58 59 #define TORRENT_DPTX_PHY_OFFSET 0x0 60 61 /* 62 * register offsets from DPTX PHY register block base (i.e MHDP 63 * register base + 0x30a00) 64 */ 65 #define PHY_AUX_CTRL 0x04 66 #define PHY_RESET 0x20 67 #define PMA_TX_ELEC_IDLE_SHIFT 4 68 #define PHY_PMA_XCVR_PLLCLK_EN 0x24 69 #define PHY_PMA_XCVR_PLLCLK_EN_ACK 0x28 70 #define PHY_PMA_XCVR_POWER_STATE_REQ 0x2c 71 #define PHY_POWER_STATE_LN(ln) ((ln) * 8) 72 #define PMA_XCVR_POWER_STATE_REQ_LN_MASK 0x3FU 73 #define PHY_PMA_XCVR_POWER_STATE_ACK 0x30 74 #define PHY_PMA_CMN_READY 0x34 75 76 /* 77 * register offsets from SD0801 PHY register block base (i.e MHDP 78 * register base + 0x500000) 79 */ 80 #define CMN_SSM_BANDGAP_TMR 0x0021U 81 #define CMN_SSM_BIAS_TMR 0x0022U 82 #define CMN_PLLSM0_PLLPRE_TMR 0x002AU 83 #define CMN_PLLSM0_PLLLOCK_TMR 0x002CU 84 #define CMN_PLLSM1_PLLPRE_TMR 0x0032U 85 #define CMN_PLLSM1_PLLLOCK_TMR 0x0034U 86 #define CMN_CDIAG_CDB_PWRI_OVRD 0x0041U 87 #define CMN_CDIAG_XCVRC_PWRI_OVRD 0x0047U 88 #define CMN_CDIAG_REFCLK_OVRD 0x004CU 89 #define CMN_CDIAG_REFCLK_DRV0_CTRL 0x0050U 90 #define CMN_BGCAL_INIT_TMR 0x0064U 91 #define CMN_BGCAL_ITER_TMR 0x0065U 92 #define CMN_IBCAL_INIT_TMR 0x0074U 93 #define CMN_PLL0_VCOCAL_TCTRL 0x0082U 94 #define CMN_PLL0_VCOCAL_INIT_TMR 0x0084U 95 #define CMN_PLL0_VCOCAL_ITER_TMR 0x0085U 96 #define CMN_PLL0_VCOCAL_REFTIM_START 0x0086U 97 #define CMN_PLL0_VCOCAL_PLLCNT_START 0x0088U 98 #define CMN_PLL0_INTDIV_M0 0x0090U 99 #define CMN_PLL0_FRACDIVL_M0 0x0091U 100 #define CMN_PLL0_FRACDIVH_M0 0x0092U 101 #define CMN_PLL0_HIGH_THR_M0 0x0093U 102 #define CMN_PLL0_DSM_DIAG_M0 0x0094U 103 #define CMN_PLL0_DSM_FBH_OVRD_M0 0x0095U 104 #define CMN_PLL0_DSM_FBL_OVRD_M0 0x0096U 105 #define CMN_PLL0_SS_CTRL1_M0 0x0098U 106 #define CMN_PLL0_SS_CTRL2_M0 0x0099U 107 #define CMN_PLL0_SS_CTRL3_M0 0x009AU 108 #define CMN_PLL0_SS_CTRL4_M0 0x009BU 109 #define CMN_PLL0_LOCK_REFCNT_START 0x009CU 110 #define CMN_PLL0_LOCK_PLLCNT_START 0x009EU 111 #define CMN_PLL0_LOCK_PLLCNT_THR 0x009FU 112 #define CMN_PLL0_INTDIV_M1 0x00A0U 113 #define CMN_PLL0_FRACDIVH_M1 0x00A2U 114 #define CMN_PLL0_HIGH_THR_M1 0x00A3U 115 #define CMN_PLL0_DSM_DIAG_M1 0x00A4U 116 #define CMN_PLL0_SS_CTRL1_M1 0x00A8U 117 #define CMN_PLL0_SS_CTRL2_M1 0x00A9U 118 #define CMN_PLL0_SS_CTRL3_M1 0x00AAU 119 #define CMN_PLL0_SS_CTRL4_M1 0x00ABU 120 #define CMN_PLL1_VCOCAL_TCTRL 0x00C2U 121 #define CMN_PLL1_VCOCAL_INIT_TMR 0x00C4U 122 #define CMN_PLL1_VCOCAL_ITER_TMR 0x00C5U 123 #define CMN_PLL1_VCOCAL_REFTIM_START 0x00C6U 124 #define CMN_PLL1_VCOCAL_PLLCNT_START 0x00C8U 125 #define CMN_PLL1_INTDIV_M0 0x00D0U 126 #define CMN_PLL1_FRACDIVL_M0 0x00D1U 127 #define CMN_PLL1_FRACDIVH_M0 0x00D2U 128 #define CMN_PLL1_HIGH_THR_M0 0x00D3U 129 #define CMN_PLL1_DSM_DIAG_M0 0x00D4U 130 #define CMN_PLL1_DSM_FBH_OVRD_M0 0x00D5U 131 #define CMN_PLL1_DSM_FBL_OVRD_M0 0x00D6U 132 #define CMN_PLL1_SS_CTRL1_M0 0x00D8U 133 #define CMN_PLL1_SS_CTRL2_M0 0x00D9U 134 #define CMN_PLL1_SS_CTRL3_M0 0x00DAU 135 #define CMN_PLL1_SS_CTRL4_M0 0x00DBU 136 #define CMN_PLL1_LOCK_REFCNT_START 0x00DCU 137 #define CMN_PLL1_LOCK_PLLCNT_START 0x00DEU 138 #define CMN_PLL1_LOCK_PLLCNT_THR 0x00DFU 139 #define CMN_TXPUCAL_TUNE 0x0103U 140 #define CMN_TXPUCAL_INIT_TMR 0x0104U 141 #define CMN_TXPUCAL_ITER_TMR 0x0105U 142 #define CMN_TXPDCAL_TUNE 0x010BU 143 #define CMN_TXPDCAL_INIT_TMR 0x010CU 144 #define CMN_TXPDCAL_ITER_TMR 0x010DU 145 #define CMN_RXCAL_INIT_TMR 0x0114U 146 #define CMN_RXCAL_ITER_TMR 0x0115U 147 #define CMN_SD_CAL_INIT_TMR 0x0124U 148 #define CMN_SD_CAL_ITER_TMR 0x0125U 149 #define CMN_SD_CAL_REFTIM_START 0x0126U 150 #define CMN_SD_CAL_PLLCNT_START 0x0128U 151 #define CMN_PDIAG_PLL0_CTRL_M0 0x01A0U 152 #define CMN_PDIAG_PLL0_CLK_SEL_M0 0x01A1U 153 #define CMN_PDIAG_PLL0_CP_PADJ_M0 0x01A4U 154 #define CMN_PDIAG_PLL0_CP_IADJ_M0 0x01A5U 155 #define CMN_PDIAG_PLL0_FILT_PADJ_M0 0x01A6U 156 #define CMN_PDIAG_PLL0_CTRL_M1 0x01B0U 157 #define CMN_PDIAG_PLL0_CLK_SEL_M1 0x01B1U 158 #define CMN_PDIAG_PLL0_CP_PADJ_M1 0x01B4U 159 #define CMN_PDIAG_PLL0_CP_IADJ_M1 0x01B5U 160 #define CMN_PDIAG_PLL0_FILT_PADJ_M1 0x01B6U 161 #define CMN_PDIAG_PLL1_CTRL_M0 0x01C0U 162 #define CMN_PDIAG_PLL1_CLK_SEL_M0 0x01C1U 163 #define CMN_PDIAG_PLL1_CP_PADJ_M0 0x01C4U 164 #define CMN_PDIAG_PLL1_CP_IADJ_M0 0x01C5U 165 #define CMN_PDIAG_PLL1_FILT_PADJ_M0 0x01C6U 166 #define CMN_DIAG_BIAS_OVRD1 0x01E1U 167 168 /* PMA TX Lane registers */ 169 #define TX_TXCC_CTRL 0x0040U 170 #define TX_TXCC_CPOST_MULT_00 0x004CU 171 #define TX_TXCC_CPOST_MULT_01 0x004DU 172 #define TX_TXCC_MGNFS_MULT_000 0x0050U 173 #define TX_TXCC_MGNFS_MULT_100 0x0054U 174 #define DRV_DIAG_TX_DRV 0x00C6U 175 #define XCVR_DIAG_PLLDRC_CTRL 0x00E5U 176 #define XCVR_DIAG_HSCLK_SEL 0x00E6U 177 #define XCVR_DIAG_HSCLK_DIV 0x00E7U 178 #define XCVR_DIAG_RXCLK_CTRL 0x00E9U 179 #define XCVR_DIAG_BIDI_CTRL 0x00EAU 180 #define XCVR_DIAG_PSC_OVRD 0x00EBU 181 #define TX_PSC_A0 0x0100U 182 #define TX_PSC_A1 0x0101U 183 #define TX_PSC_A2 0x0102U 184 #define TX_PSC_A3 0x0103U 185 #define TX_RCVDET_ST_TMR 0x0123U 186 #define TX_DIAG_ACYA 0x01E7U 187 #define TX_DIAG_ACYA_HBDC_MASK 0x0001U 188 189 /* PMA RX Lane registers */ 190 #define RX_PSC_A0 0x0000U 191 #define RX_PSC_A1 0x0001U 192 #define RX_PSC_A2 0x0002U 193 #define RX_PSC_A3 0x0003U 194 #define RX_PSC_CAL 0x0006U 195 #define RX_SDCAL0_INIT_TMR 0x0044U 196 #define RX_SDCAL0_ITER_TMR 0x0045U 197 #define RX_SDCAL1_INIT_TMR 0x004CU 198 #define RX_SDCAL1_ITER_TMR 0x004DU 199 #define RX_CDRLF_CNFG 0x0080U 200 #define RX_CDRLF_CNFG3 0x0082U 201 #define RX_SIGDET_HL_FILT_TMR 0x0090U 202 #define RX_REE_GCSM1_CTRL 0x0108U 203 #define RX_REE_GCSM1_EQENM_PH1 0x0109U 204 #define RX_REE_GCSM1_EQENM_PH2 0x010AU 205 #define RX_REE_GCSM2_CTRL 0x0110U 206 #define RX_REE_PERGCSM_CTRL 0x0118U 207 #define RX_REE_ATTEN_THR 0x0149U 208 #define RX_REE_TAP1_CLIP 0x0171U 209 #define RX_REE_TAP2TON_CLIP 0x0172U 210 #define RX_REE_SMGM_CTRL1 0x0177U 211 #define RX_REE_SMGM_CTRL2 0x0178U 212 #define RX_DIAG_DFE_CTRL 0x01E0U 213 #define RX_DIAG_DFE_AMP_TUNE_2 0x01E2U 214 #define RX_DIAG_DFE_AMP_TUNE_3 0x01E3U 215 #define RX_DIAG_NQST_CTRL 0x01E5U 216 #define RX_DIAG_SIGDET_TUNE 0x01E8U 217 #define RX_DIAG_PI_RATE 0x01F4U 218 #define RX_DIAG_PI_CAP 0x01F5U 219 #define RX_DIAG_ACYA 0x01FFU 220 221 /* PHY PCS common registers */ 222 #define PHY_PIPE_CMN_CTRL1 0x0000U 223 #define PHY_PLL_CFG 0x000EU 224 #define PHY_PIPE_USB3_GEN2_PRE_CFG0 0x0020U 225 #define PHY_PIPE_USB3_GEN2_POST_CFG0 0x0022U 226 #define PHY_PIPE_USB3_GEN2_POST_CFG1 0x0023U 227 228 /* PHY PCS lane registers */ 229 #define PHY_PCS_ISO_LINK_CTRL 0x000BU 230 231 /* PHY PMA common registers */ 232 #define PHY_PMA_CMN_CTRL1 0x0000U 233 #define PHY_PMA_CMN_CTRL2 0x0001U 234 #define PHY_PMA_PLL_RAW_CTRL 0x0003U 235 236 #define CDNS_TORRENT_OUTPUT_CLOCKS 3 237 238 static const char * const clk_names[] = { 239 [CDNS_TORRENT_REFCLK_DRIVER] = "refclk-driver", 240 [CDNS_TORRENT_DERIVED_REFCLK] = "refclk-der", 241 [CDNS_TORRENT_RECEIVED_REFCLK] = "refclk-rec", 242 }; 243 244 static const struct reg_field phy_pll_cfg = 245 REG_FIELD(PHY_PLL_CFG, 0, 1); 246 247 static const struct reg_field phy_pma_cmn_ctrl_1 = 248 REG_FIELD(PHY_PMA_CMN_CTRL1, 0, 0); 249 250 static const struct reg_field phy_pma_cmn_ctrl_2 = 251 REG_FIELD(PHY_PMA_CMN_CTRL2, 0, 7); 252 253 static const struct reg_field phy_pma_pll_raw_ctrl = 254 REG_FIELD(PHY_PMA_PLL_RAW_CTRL, 0, 1); 255 256 static const struct reg_field phy_reset_ctrl = 257 REG_FIELD(PHY_RESET, 8, 8); 258 259 static const struct reg_field phy_pcs_iso_link_ctrl_1 = 260 REG_FIELD(PHY_PCS_ISO_LINK_CTRL, 1, 1); 261 262 static const struct reg_field phy_pipe_cmn_ctrl1_0 = REG_FIELD(PHY_PIPE_CMN_CTRL1, 0, 0); 263 264 static const struct reg_field cmn_cdiag_refclk_ovrd_4 = 265 REG_FIELD(CMN_CDIAG_REFCLK_OVRD, 4, 4); 266 267 #define REFCLK_OUT_NUM_CMN_CONFIG 4 268 269 enum cdns_torrent_refclk_out_cmn { 270 CMN_CDIAG_REFCLK_DRV0_CTRL_1, 271 CMN_CDIAG_REFCLK_DRV0_CTRL_4, 272 CMN_CDIAG_REFCLK_DRV0_CTRL_5, 273 CMN_CDIAG_REFCLK_DRV0_CTRL_6, 274 }; 275 276 static const struct reg_field refclk_out_cmn_cfg[] = { 277 [CMN_CDIAG_REFCLK_DRV0_CTRL_1] = REG_FIELD(CMN_CDIAG_REFCLK_DRV0_CTRL, 1, 1), 278 [CMN_CDIAG_REFCLK_DRV0_CTRL_4] = REG_FIELD(CMN_CDIAG_REFCLK_DRV0_CTRL, 4, 4), 279 [CMN_CDIAG_REFCLK_DRV0_CTRL_5] = REG_FIELD(CMN_CDIAG_REFCLK_DRV0_CTRL, 5, 5), 280 [CMN_CDIAG_REFCLK_DRV0_CTRL_6] = REG_FIELD(CMN_CDIAG_REFCLK_DRV0_CTRL, 6, 6), 281 }; 282 283 static const int refclk_driver_parent_index[] = { 284 CDNS_TORRENT_DERIVED_REFCLK, 285 CDNS_TORRENT_RECEIVED_REFCLK 286 }; 287 288 static const u32 cdns_torrent_refclk_driver_mux_table[] = { 1, 0 }; 289 290 enum cdns_torrent_phy_type { 291 TYPE_NONE, 292 TYPE_DP, 293 TYPE_PCIE, 294 TYPE_SGMII, 295 TYPE_QSGMII, 296 TYPE_USB, 297 TYPE_USXGMII, 298 }; 299 300 enum cdns_torrent_ref_clk { 301 CLK_19_2_MHZ, 302 CLK_25_MHZ, 303 CLK_100_MHZ, 304 CLK_156_25_MHZ, 305 CLK_ANY, 306 }; 307 308 enum cdns_torrent_ssc_mode { 309 NO_SSC, 310 EXTERNAL_SSC, 311 INTERNAL_SSC, 312 ANY_SSC, 313 }; 314 315 /* Unique key id for vals table entry 316 * REFCLK0_RATE | REFCLK1_RATE | LINK0_TYPE | LINK1_TYPE | SSC_TYPE 317 */ 318 #define REFCLK0_SHIFT 12 319 #define REFCLK0_MASK GENMASK(14, 12) 320 #define REFCLK1_SHIFT 9 321 #define REFCLK1_MASK GENMASK(11, 9) 322 #define LINK0_SHIFT 6 323 #define LINK0_MASK GENMASK(8, 6) 324 #define LINK1_SHIFT 3 325 #define LINK1_MASK GENMASK(5, 3) 326 #define SSC_SHIFT 0 327 #define SSC_MASK GENMASK(2, 0) 328 329 #define CDNS_TORRENT_KEY(refclk0, refclk1, link0, link1, ssc) \ 330 ((((refclk0) << REFCLK0_SHIFT) & REFCLK0_MASK) | \ 331 (((refclk1) << REFCLK1_SHIFT) & REFCLK1_MASK) | \ 332 (((link0) << LINK0_SHIFT) & LINK0_MASK) | \ 333 (((link1) << LINK1_SHIFT) & LINK1_MASK) | \ 334 (((ssc) << SSC_SHIFT) & SSC_MASK)) 335 336 #define CDNS_TORRENT_KEY_ANYCLK(link0, link1) \ 337 CDNS_TORRENT_KEY(CLK_ANY, CLK_ANY, \ 338 (link0), (link1), ANY_SSC) 339 340 struct cdns_torrent_inst { 341 struct phy *phy; 342 u32 mlane; 343 enum cdns_torrent_phy_type phy_type; 344 u32 num_lanes; 345 struct reset_control *lnk_rst; 346 enum cdns_torrent_ssc_mode ssc_mode; 347 }; 348 349 struct cdns_torrent_phy { 350 void __iomem *base; /* DPTX registers base */ 351 void __iomem *sd_base; /* SD0801 registers base */ 352 u32 max_bit_rate; /* Maximum link bit rate to use (in Mbps) */ 353 u32 dp_pll; 354 u32 protocol_bitmask; 355 struct reset_control *phy_rst; 356 struct reset_control *apb_rst; 357 struct device *dev; 358 struct clk *clk; 359 struct clk *clk1; 360 enum cdns_torrent_ref_clk ref_clk_rate; 361 enum cdns_torrent_ref_clk ref_clk1_rate; 362 struct cdns_torrent_inst phys[MAX_NUM_LANES]; 363 int nsubnodes; 364 int already_configured; 365 const struct cdns_torrent_data *init_data; 366 struct regmap *regmap_common_cdb; 367 struct regmap *regmap_phy_pcs_common_cdb; 368 struct regmap *regmap_phy_pma_common_cdb; 369 struct regmap *regmap_tx_lane_cdb[MAX_NUM_LANES]; 370 struct regmap *regmap_rx_lane_cdb[MAX_NUM_LANES]; 371 struct regmap *regmap_phy_pcs_lane_cdb[MAX_NUM_LANES]; 372 struct regmap *regmap_dptx_phy_reg; 373 struct regmap_field *phy_pll_cfg; 374 struct regmap_field *phy_pipe_cmn_ctrl1_0; 375 struct regmap_field *cmn_cdiag_refclk_ovrd_4; 376 struct regmap_field *phy_pma_cmn_ctrl_1; 377 struct regmap_field *phy_pma_cmn_ctrl_2; 378 struct regmap_field *phy_pma_pll_raw_ctrl; 379 struct regmap_field *phy_reset_ctrl; 380 struct regmap_field *phy_pcs_iso_link_ctrl_1[MAX_NUM_LANES]; 381 struct clk_hw_onecell_data *clk_hw_data; 382 }; 383 384 enum phy_powerstate { 385 POWERSTATE_A0 = 0, 386 /* Powerstate A1 is unused */ 387 POWERSTATE_A2 = 2, 388 POWERSTATE_A3 = 3, 389 }; 390 391 struct cdns_torrent_refclk_driver { 392 struct clk_hw hw; 393 struct regmap_field *cmn_fields[REFCLK_OUT_NUM_CMN_CONFIG]; 394 struct clk_init_data clk_data; 395 }; 396 397 #define to_cdns_torrent_refclk_driver(_hw) \ 398 container_of(_hw, struct cdns_torrent_refclk_driver, hw) 399 400 struct cdns_torrent_derived_refclk { 401 struct clk_hw hw; 402 struct regmap_field *phy_pipe_cmn_ctrl1_0; 403 struct regmap_field *cmn_cdiag_refclk_ovrd_4; 404 struct clk_init_data clk_data; 405 }; 406 407 #define to_cdns_torrent_derived_refclk(_hw) \ 408 container_of(_hw, struct cdns_torrent_derived_refclk, hw) 409 410 struct cdns_torrent_received_refclk { 411 struct clk_hw hw; 412 struct regmap_field *phy_pipe_cmn_ctrl1_0; 413 struct regmap_field *cmn_cdiag_refclk_ovrd_4; 414 struct clk_init_data clk_data; 415 }; 416 417 #define to_cdns_torrent_received_refclk(_hw) \ 418 container_of(_hw, struct cdns_torrent_received_refclk, hw) 419 420 struct cdns_reg_pairs { 421 u32 val; 422 u32 off; 423 }; 424 425 struct cdns_torrent_vals { 426 const struct cdns_reg_pairs *reg_pairs; 427 u32 num_regs; 428 }; 429 430 struct cdns_torrent_vals_entry { 431 u32 key; 432 const struct cdns_torrent_vals *vals; 433 }; 434 435 struct cdns_torrent_vals_table { 436 const struct cdns_torrent_vals_entry *entries; 437 u32 num_entries; 438 }; 439 440 struct cdns_torrent_data { 441 u8 block_offset_shift; 442 u8 reg_offset_shift; 443 struct cdns_torrent_vals_table link_cmn_vals_tbl; 444 struct cdns_torrent_vals_table xcvr_diag_vals_tbl; 445 struct cdns_torrent_vals_table pcs_cmn_vals_tbl; 446 struct cdns_torrent_vals_table phy_pma_cmn_vals_tbl; 447 struct cdns_torrent_vals_table cmn_vals_tbl; 448 struct cdns_torrent_vals_table tx_ln_vals_tbl; 449 struct cdns_torrent_vals_table rx_ln_vals_tbl; 450 }; 451 452 struct cdns_regmap_cdb_context { 453 struct device *dev; 454 void __iomem *base; 455 u8 reg_offset_shift; 456 }; 457 458 static const struct cdns_torrent_vals *cdns_torrent_get_tbl_vals(const struct cdns_torrent_vals_table *tbl, 459 enum cdns_torrent_ref_clk refclk0, 460 enum cdns_torrent_ref_clk refclk1, 461 enum cdns_torrent_phy_type link0, 462 enum cdns_torrent_phy_type link1, 463 enum cdns_torrent_ssc_mode ssc) 464 { 465 int i; 466 u32 key = CDNS_TORRENT_KEY(refclk0, refclk1, link0, link1, ssc); 467 468 for (i = 0; i < tbl->num_entries; i++) { 469 if (tbl->entries[i].key == key) 470 return tbl->entries[i].vals; 471 } 472 473 return NULL; 474 } 475 476 static int cdns_regmap_write(void *context, unsigned int reg, unsigned int val) 477 { 478 struct cdns_regmap_cdb_context *ctx = context; 479 u32 offset = reg << ctx->reg_offset_shift; 480 481 writew(val, ctx->base + offset); 482 483 return 0; 484 } 485 486 static int cdns_regmap_read(void *context, unsigned int reg, unsigned int *val) 487 { 488 struct cdns_regmap_cdb_context *ctx = context; 489 u32 offset = reg << ctx->reg_offset_shift; 490 491 *val = readw(ctx->base + offset); 492 return 0; 493 } 494 495 static int cdns_regmap_dptx_write(void *context, unsigned int reg, 496 unsigned int val) 497 { 498 struct cdns_regmap_cdb_context *ctx = context; 499 u32 offset = reg; 500 501 writel(val, ctx->base + offset); 502 503 return 0; 504 } 505 506 static int cdns_regmap_dptx_read(void *context, unsigned int reg, 507 unsigned int *val) 508 { 509 struct cdns_regmap_cdb_context *ctx = context; 510 u32 offset = reg; 511 512 *val = readl(ctx->base + offset); 513 return 0; 514 } 515 516 #define TORRENT_TX_LANE_CDB_REGMAP_CONF(n) \ 517 { \ 518 .name = "torrent_tx_lane" n "_cdb", \ 519 .reg_stride = 1, \ 520 .fast_io = true, \ 521 .reg_write = cdns_regmap_write, \ 522 .reg_read = cdns_regmap_read, \ 523 } 524 525 #define TORRENT_RX_LANE_CDB_REGMAP_CONF(n) \ 526 { \ 527 .name = "torrent_rx_lane" n "_cdb", \ 528 .reg_stride = 1, \ 529 .fast_io = true, \ 530 .reg_write = cdns_regmap_write, \ 531 .reg_read = cdns_regmap_read, \ 532 } 533 534 static const struct regmap_config cdns_torrent_tx_lane_cdb_config[] = { 535 TORRENT_TX_LANE_CDB_REGMAP_CONF("0"), 536 TORRENT_TX_LANE_CDB_REGMAP_CONF("1"), 537 TORRENT_TX_LANE_CDB_REGMAP_CONF("2"), 538 TORRENT_TX_LANE_CDB_REGMAP_CONF("3"), 539 }; 540 541 static const struct regmap_config cdns_torrent_rx_lane_cdb_config[] = { 542 TORRENT_RX_LANE_CDB_REGMAP_CONF("0"), 543 TORRENT_RX_LANE_CDB_REGMAP_CONF("1"), 544 TORRENT_RX_LANE_CDB_REGMAP_CONF("2"), 545 TORRENT_RX_LANE_CDB_REGMAP_CONF("3"), 546 }; 547 548 static const struct regmap_config cdns_torrent_common_cdb_config = { 549 .name = "torrent_common_cdb", 550 .reg_stride = 1, 551 .fast_io = true, 552 .reg_write = cdns_regmap_write, 553 .reg_read = cdns_regmap_read, 554 }; 555 556 #define TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF(n) \ 557 { \ 558 .name = "torrent_phy_pcs_lane" n "_cdb", \ 559 .reg_stride = 1, \ 560 .fast_io = true, \ 561 .reg_write = cdns_regmap_write, \ 562 .reg_read = cdns_regmap_read, \ 563 } 564 565 static const struct regmap_config cdns_torrent_phy_pcs_lane_cdb_config[] = { 566 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("0"), 567 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("1"), 568 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("2"), 569 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("3"), 570 }; 571 572 static const struct regmap_config cdns_torrent_phy_pcs_cmn_cdb_config = { 573 .name = "torrent_phy_pcs_cmn_cdb", 574 .reg_stride = 1, 575 .fast_io = true, 576 .reg_write = cdns_regmap_write, 577 .reg_read = cdns_regmap_read, 578 }; 579 580 static const struct regmap_config cdns_torrent_phy_pma_cmn_cdb_config = { 581 .name = "torrent_phy_pma_cmn_cdb", 582 .reg_stride = 1, 583 .fast_io = true, 584 .reg_write = cdns_regmap_write, 585 .reg_read = cdns_regmap_read, 586 }; 587 588 static const struct regmap_config cdns_torrent_dptx_phy_config = { 589 .name = "torrent_dptx_phy", 590 .reg_stride = 1, 591 .fast_io = true, 592 .reg_write = cdns_regmap_dptx_write, 593 .reg_read = cdns_regmap_dptx_read, 594 }; 595 596 /* PHY mmr access functions */ 597 598 static void cdns_torrent_phy_write(struct regmap *regmap, u32 offset, u32 val) 599 { 600 regmap_write(regmap, offset, val); 601 } 602 603 static u32 cdns_torrent_phy_read(struct regmap *regmap, u32 offset) 604 { 605 unsigned int val; 606 607 regmap_read(regmap, offset, &val); 608 return val; 609 } 610 611 /* DPTX mmr access functions */ 612 613 static void cdns_torrent_dp_write(struct regmap *regmap, u32 offset, u32 val) 614 { 615 regmap_write(regmap, offset, val); 616 } 617 618 static u32 cdns_torrent_dp_read(struct regmap *regmap, u32 offset) 619 { 620 u32 val; 621 622 regmap_read(regmap, offset, &val); 623 return val; 624 } 625 626 /* 627 * Structure used to store values of PHY registers for voltage-related 628 * coefficients, for particular voltage swing and pre-emphasis level. Values 629 * are shared across all physical lanes. 630 */ 631 struct coefficients { 632 /* Value of DRV_DIAG_TX_DRV register to use */ 633 u16 diag_tx_drv; 634 /* Value of TX_TXCC_MGNFS_MULT_000 register to use */ 635 u16 mgnfs_mult; 636 /* Value of TX_TXCC_CPOST_MULT_00 register to use */ 637 u16 cpost_mult; 638 }; 639 640 /* 641 * Array consists of values of voltage-related registers for sd0801 PHY. A value 642 * of 0xFFFF is a placeholder for invalid combination, and will never be used. 643 */ 644 static const struct coefficients vltg_coeff[4][4] = { 645 /* voltage swing 0, pre-emphasis 0->3 */ 646 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x002A, 647 .cpost_mult = 0x0000}, 648 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x001F, 649 .cpost_mult = 0x0014}, 650 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0012, 651 .cpost_mult = 0x0020}, 652 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000, 653 .cpost_mult = 0x002A} 654 }, 655 656 /* voltage swing 1, pre-emphasis 0->3 */ 657 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x001F, 658 .cpost_mult = 0x0000}, 659 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0013, 660 .cpost_mult = 0x0012}, 661 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000, 662 .cpost_mult = 0x001F}, 663 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF, 664 .cpost_mult = 0xFFFF} 665 }, 666 667 /* voltage swing 2, pre-emphasis 0->3 */ 668 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0013, 669 .cpost_mult = 0x0000}, 670 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000, 671 .cpost_mult = 0x0013}, 672 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF, 673 .cpost_mult = 0xFFFF}, 674 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF, 675 .cpost_mult = 0xFFFF} 676 }, 677 678 /* voltage swing 3, pre-emphasis 0->3 */ 679 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000, 680 .cpost_mult = 0x0000}, 681 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF, 682 .cpost_mult = 0xFFFF}, 683 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF, 684 .cpost_mult = 0xFFFF}, 685 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF, 686 .cpost_mult = 0xFFFF} 687 } 688 }; 689 690 static const char *cdns_torrent_get_phy_type(enum cdns_torrent_phy_type phy_type) 691 { 692 switch (phy_type) { 693 case TYPE_DP: 694 return "DisplayPort"; 695 case TYPE_PCIE: 696 return "PCIe"; 697 case TYPE_SGMII: 698 return "SGMII"; 699 case TYPE_QSGMII: 700 return "QSGMII"; 701 case TYPE_USB: 702 return "USB"; 703 case TYPE_USXGMII: 704 return "USXGMII"; 705 default: 706 return "None"; 707 } 708 } 709 710 /* 711 * Set registers responsible for enabling and configuring SSC, with second and 712 * third register values provided by parameters. 713 */ 714 static 715 void cdns_torrent_dp_enable_ssc_19_2mhz(struct cdns_torrent_phy *cdns_phy, 716 u32 ctrl2_val, u32 ctrl3_val) 717 { 718 struct regmap *regmap = cdns_phy->regmap_common_cdb; 719 720 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0001); 721 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl2_val); 722 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl3_val); 723 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0003); 724 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0001); 725 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl2_val); 726 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl3_val); 727 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0003); 728 } 729 730 static 731 void cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(struct cdns_torrent_phy *cdns_phy, 732 u32 rate, bool ssc) 733 { 734 struct regmap *regmap = cdns_phy->regmap_common_cdb; 735 736 /* Assumes 19.2 MHz refclock */ 737 switch (rate) { 738 /* Setting VCO for 10.8GHz */ 739 case 2700: 740 case 5400: 741 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0119); 742 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x4000); 743 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 744 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x00BC); 745 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0012); 746 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0119); 747 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x4000); 748 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 749 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x00BC); 750 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0012); 751 if (ssc) 752 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x033A, 0x006A); 753 break; 754 /* Setting VCO for 9.72GHz */ 755 case 1620: 756 case 2430: 757 case 3240: 758 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01FA); 759 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x4000); 760 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 761 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0152); 762 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002); 763 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01FA); 764 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x4000); 765 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 766 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0152); 767 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002); 768 if (ssc) 769 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x05DD, 0x0069); 770 break; 771 /* Setting VCO for 8.64GHz */ 772 case 2160: 773 case 4320: 774 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01C2); 775 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x0000); 776 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 777 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x012C); 778 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002); 779 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01C2); 780 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x0000); 781 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 782 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x012C); 783 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002); 784 if (ssc) 785 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x0536, 0x0069); 786 break; 787 /* Setting VCO for 8.1GHz */ 788 case 8100: 789 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01A5); 790 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0xE000); 791 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 792 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x011A); 793 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002); 794 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01A5); 795 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0xE000); 796 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 797 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x011A); 798 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002); 799 if (ssc) 800 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x04D7, 0x006A); 801 break; 802 } 803 804 if (ssc) { 805 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_PLLCNT_START, 0x025E); 806 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_THR, 0x0005); 807 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_PLLCNT_START, 0x025E); 808 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_THR, 0x0005); 809 } else { 810 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_PLLCNT_START, 0x0260); 811 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_PLLCNT_START, 0x0260); 812 /* Set reset register values to disable SSC */ 813 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0002); 814 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL2_M0, 0x0000); 815 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL3_M0, 0x0000); 816 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0000); 817 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_THR, 0x0003); 818 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0002); 819 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL2_M0, 0x0000); 820 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL3_M0, 0x0000); 821 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0000); 822 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_THR, 0x0003); 823 } 824 825 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_REFCNT_START, 0x0099); 826 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_START, 0x0099); 827 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_REFCNT_START, 0x0099); 828 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_START, 0x0099); 829 } 830 831 /* 832 * Set registers responsible for enabling and configuring SSC, with second 833 * register value provided by a parameter. 834 */ 835 static void cdns_torrent_dp_enable_ssc_25mhz(struct cdns_torrent_phy *cdns_phy, 836 u32 ctrl2_val) 837 { 838 struct regmap *regmap = cdns_phy->regmap_common_cdb; 839 840 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0001); 841 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl2_val); 842 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x007F); 843 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0003); 844 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0001); 845 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl2_val); 846 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x007F); 847 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0003); 848 } 849 850 static 851 void cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(struct cdns_torrent_phy *cdns_phy, 852 u32 rate, bool ssc) 853 { 854 struct regmap *regmap = cdns_phy->regmap_common_cdb; 855 856 /* Assumes 25 MHz refclock */ 857 switch (rate) { 858 /* Setting VCO for 10.8GHz */ 859 case 2700: 860 case 5400: 861 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01B0); 862 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x0000); 863 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 864 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0120); 865 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01B0); 866 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x0000); 867 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 868 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0120); 869 if (ssc) 870 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x0423); 871 break; 872 /* Setting VCO for 9.72GHz */ 873 case 1620: 874 case 2430: 875 case 3240: 876 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0184); 877 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0xCCCD); 878 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 879 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0104); 880 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0184); 881 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0xCCCD); 882 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 883 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0104); 884 if (ssc) 885 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x03B9); 886 break; 887 /* Setting VCO for 8.64GHz */ 888 case 2160: 889 case 4320: 890 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0159); 891 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x999A); 892 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 893 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x00E7); 894 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0159); 895 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x999A); 896 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 897 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x00E7); 898 if (ssc) 899 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x034F); 900 break; 901 /* Setting VCO for 8.1GHz */ 902 case 8100: 903 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0144); 904 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x0000); 905 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 906 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x00D8); 907 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0144); 908 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x0000); 909 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 910 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x00D8); 911 if (ssc) 912 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x031A); 913 break; 914 } 915 916 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002); 917 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002); 918 919 if (ssc) { 920 cdns_torrent_phy_write(regmap, 921 CMN_PLL0_VCOCAL_PLLCNT_START, 0x0315); 922 cdns_torrent_phy_write(regmap, 923 CMN_PLL0_LOCK_PLLCNT_THR, 0x0005); 924 cdns_torrent_phy_write(regmap, 925 CMN_PLL1_VCOCAL_PLLCNT_START, 0x0315); 926 cdns_torrent_phy_write(regmap, 927 CMN_PLL1_LOCK_PLLCNT_THR, 0x0005); 928 } else { 929 cdns_torrent_phy_write(regmap, 930 CMN_PLL0_VCOCAL_PLLCNT_START, 0x0317); 931 cdns_torrent_phy_write(regmap, 932 CMN_PLL1_VCOCAL_PLLCNT_START, 0x0317); 933 /* Set reset register values to disable SSC */ 934 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0002); 935 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL2_M0, 0x0000); 936 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL3_M0, 0x0000); 937 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0000); 938 cdns_torrent_phy_write(regmap, 939 CMN_PLL0_LOCK_PLLCNT_THR, 0x0003); 940 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0002); 941 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL2_M0, 0x0000); 942 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL3_M0, 0x0000); 943 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0000); 944 cdns_torrent_phy_write(regmap, 945 CMN_PLL1_LOCK_PLLCNT_THR, 0x0003); 946 } 947 948 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_REFCNT_START, 0x00C7); 949 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_START, 0x00C7); 950 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_REFCNT_START, 0x00C7); 951 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_START, 0x00C7); 952 } 953 954 static 955 void cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(struct cdns_torrent_phy *cdns_phy, 956 u32 rate, bool ssc) 957 { 958 struct regmap *regmap = cdns_phy->regmap_common_cdb; 959 960 /* Assumes 100 MHz refclock */ 961 switch (rate) { 962 /* Setting VCO for 10.8GHz */ 963 case 2700: 964 case 5400: 965 if (cdns_phy->dp_pll & DP_PLL0) 966 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_FBH_OVRD_M0, 0x0022); 967 968 if (cdns_phy->dp_pll & DP_PLL1) { 969 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0028); 970 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_FBH_OVRD_M0, 0x0022); 971 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_FBL_OVRD_M0, 0x000C); 972 } 973 break; 974 /* Setting VCO for 9.72GHz */ 975 case 1620: 976 case 2430: 977 case 3240: 978 if (cdns_phy->dp_pll & DP_PLL0) { 979 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_DIAG_M0, 0x0004); 980 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_PADJ_M0, 0x0509); 981 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_IADJ_M0, 0x0F00); 982 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_FILT_PADJ_M0, 0x0F08); 983 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0061); 984 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x3333); 985 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 986 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0042); 987 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002); 988 } 989 if (cdns_phy->dp_pll & DP_PLL1) { 990 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_DIAG_M0, 0x0004); 991 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0509); 992 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_IADJ_M0, 0x0F00); 993 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_FILT_PADJ_M0, 0x0F08); 994 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0061); 995 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x3333); 996 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 997 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0042); 998 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002); 999 } 1000 break; 1001 /* Setting VCO for 8.64GHz */ 1002 case 2160: 1003 case 4320: 1004 if (cdns_phy->dp_pll & DP_PLL0) { 1005 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_DIAG_M0, 0x0004); 1006 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_PADJ_M0, 0x0509); 1007 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_IADJ_M0, 0x0F00); 1008 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_FILT_PADJ_M0, 0x0F08); 1009 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0056); 1010 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x6666); 1011 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 1012 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x003A); 1013 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002); 1014 } 1015 if (cdns_phy->dp_pll & DP_PLL1) { 1016 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_DIAG_M0, 0x0004); 1017 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0509); 1018 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_IADJ_M0, 0x0F00); 1019 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_FILT_PADJ_M0, 0x0F08); 1020 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0056); 1021 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x6666); 1022 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 1023 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x003A); 1024 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002); 1025 } 1026 break; 1027 /* Setting VCO for 8.1GHz */ 1028 case 8100: 1029 if (cdns_phy->dp_pll & DP_PLL0) { 1030 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_DIAG_M0, 0x0004); 1031 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_PADJ_M0, 0x0509); 1032 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_IADJ_M0, 0x0F00); 1033 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_FILT_PADJ_M0, 0x0F08); 1034 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0051); 1035 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002); 1036 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0036); 1037 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002); 1038 } 1039 if (cdns_phy->dp_pll & DP_PLL1) { 1040 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_DIAG_M0, 0x0004); 1041 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0509); 1042 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_IADJ_M0, 0x0F00); 1043 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_FILT_PADJ_M0, 0x0F08); 1044 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0051); 1045 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002); 1046 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0036); 1047 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002); 1048 } 1049 break; 1050 } 1051 } 1052 1053 /* Set PLL used for DP configuration */ 1054 static int cdns_torrent_dp_get_pll(struct cdns_torrent_phy *cdns_phy, 1055 enum cdns_torrent_phy_type phy_t2) 1056 { 1057 switch (phy_t2) { 1058 case TYPE_PCIE: 1059 case TYPE_USB: 1060 cdns_phy->dp_pll = DP_PLL1; 1061 break; 1062 case TYPE_SGMII: 1063 case TYPE_QSGMII: 1064 cdns_phy->dp_pll = DP_PLL0; 1065 break; 1066 case TYPE_NONE: 1067 cdns_phy->dp_pll = DP_PLL0 | DP_PLL1; 1068 break; 1069 default: 1070 dev_err(cdns_phy->dev, "Unsupported PHY configuration\n"); 1071 return -EINVAL; 1072 } 1073 1074 return 0; 1075 } 1076 1077 /* 1078 * Enable or disable PLL for selected lanes. 1079 */ 1080 static int cdns_torrent_dp_set_pll_en(struct cdns_torrent_phy *cdns_phy, 1081 struct cdns_torrent_inst *inst, 1082 struct phy_configure_opts_dp *dp, 1083 bool enable) 1084 { 1085 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg; 1086 u32 rd_val, pll_ack_val; 1087 int ret; 1088 1089 /* 1090 * Used to determine, which bits to check for or enable in 1091 * PHY_PMA_XCVR_PLLCLK_EN register. 1092 */ 1093 u32 pll_bits; 1094 /* Used to enable or disable lanes. */ 1095 u32 pll_val; 1096 1097 /* Select values of registers and mask, depending on enabled lane count. */ 1098 pll_val = cdns_torrent_dp_read(regmap, PHY_PMA_XCVR_PLLCLK_EN); 1099 1100 if (enable) { 1101 pll_bits = ((1 << dp->lanes) - 1); 1102 pll_val |= pll_bits; 1103 pll_ack_val = pll_bits; 1104 } else { 1105 pll_bits = ((1 << inst->num_lanes) - 1); 1106 pll_val &= (~pll_bits); 1107 pll_ack_val = 0; 1108 } 1109 1110 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, pll_val); 1111 1112 /* Wait for acknowledgment from PHY. */ 1113 ret = regmap_read_poll_timeout(regmap, 1114 PHY_PMA_XCVR_PLLCLK_EN_ACK, 1115 rd_val, 1116 (rd_val & pll_bits) == pll_ack_val, 1117 0, POLL_TIMEOUT_US); 1118 ndelay(100); 1119 return ret; 1120 } 1121 1122 static int cdns_torrent_dp_set_power_state(struct cdns_torrent_phy *cdns_phy, 1123 struct cdns_torrent_inst *inst, 1124 u32 num_lanes, 1125 enum phy_powerstate powerstate) 1126 { 1127 /* Register value for power state for a single byte. */ 1128 u32 value_part, i; 1129 u32 value = 0; 1130 u32 mask = 0; 1131 u32 read_val; 1132 int ret; 1133 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg; 1134 1135 switch (powerstate) { 1136 case (POWERSTATE_A0): 1137 value_part = 0x01U; 1138 break; 1139 case (POWERSTATE_A2): 1140 value_part = 0x04U; 1141 break; 1142 default: 1143 /* Powerstate A3 */ 1144 value_part = 0x08U; 1145 break; 1146 } 1147 1148 /* Select values of registers and mask, depending on enabled lane count. */ 1149 1150 for (i = 0; i < num_lanes; i++) { 1151 value |= (value_part << PHY_POWER_STATE_LN(i)); 1152 mask |= (PMA_XCVR_POWER_STATE_REQ_LN_MASK << PHY_POWER_STATE_LN(i)); 1153 } 1154 1155 /* Set power state A<n>. */ 1156 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, value); 1157 /* Wait, until PHY acknowledges power state completion. */ 1158 ret = regmap_read_poll_timeout(regmap, PHY_PMA_XCVR_POWER_STATE_ACK, 1159 read_val, (read_val & mask) == value, 0, 1160 POLL_TIMEOUT_US); 1161 if (ret) 1162 return ret; 1163 1164 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, 0x00000000); 1165 ndelay(100); 1166 1167 return ret; 1168 } 1169 1170 static int cdns_torrent_dp_run(struct cdns_torrent_phy *cdns_phy, 1171 struct cdns_torrent_inst *inst, u32 num_lanes) 1172 { 1173 unsigned int read_val; 1174 int ret; 1175 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg; 1176 1177 /* 1178 * waiting for ACK of pma_xcvr_pllclk_en_ln_*, only for the 1179 * master lane 1180 */ 1181 ret = regmap_read_poll_timeout(regmap, PHY_PMA_XCVR_PLLCLK_EN_ACK, 1182 read_val, read_val & 1, 1183 0, POLL_TIMEOUT_US); 1184 if (ret == -ETIMEDOUT) { 1185 dev_err(cdns_phy->dev, 1186 "timeout waiting for link PLL clock enable ack\n"); 1187 return ret; 1188 } 1189 1190 ndelay(100); 1191 1192 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, num_lanes, 1193 POWERSTATE_A2); 1194 if (ret) 1195 return ret; 1196 1197 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, num_lanes, 1198 POWERSTATE_A0); 1199 1200 return ret; 1201 } 1202 1203 static int cdns_torrent_dp_wait_pma_cmn_ready(struct cdns_torrent_phy *cdns_phy) 1204 { 1205 unsigned int reg; 1206 int ret; 1207 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg; 1208 1209 ret = regmap_read_poll_timeout(regmap, PHY_PMA_CMN_READY, reg, 1210 reg & 1, 0, POLL_TIMEOUT_US); 1211 if (ret == -ETIMEDOUT) { 1212 dev_err(cdns_phy->dev, 1213 "timeout waiting for PMA common ready\n"); 1214 return -ETIMEDOUT; 1215 } 1216 1217 return 0; 1218 } 1219 1220 static void cdns_torrent_dp_pma_cmn_rate(struct cdns_torrent_phy *cdns_phy, 1221 struct cdns_torrent_inst *inst, 1222 u32 rate, u32 num_lanes) 1223 { 1224 unsigned int clk_sel_val = 0; 1225 unsigned int hsclk_div_val = 0; 1226 unsigned int i; 1227 1228 switch (rate) { 1229 case 1620: 1230 clk_sel_val = 0x0f01; 1231 hsclk_div_val = 2; 1232 break; 1233 case 2160: 1234 case 2430: 1235 case 2700: 1236 clk_sel_val = 0x0701; 1237 hsclk_div_val = 1; 1238 break; 1239 case 3240: 1240 clk_sel_val = 0x0b00; 1241 hsclk_div_val = 2; 1242 break; 1243 case 4320: 1244 case 5400: 1245 clk_sel_val = 0x0301; 1246 hsclk_div_val = 0; 1247 break; 1248 case 8100: 1249 clk_sel_val = 0x0200; 1250 hsclk_div_val = 0; 1251 break; 1252 } 1253 1254 if (cdns_phy->dp_pll & DP_PLL0) 1255 cdns_torrent_phy_write(cdns_phy->regmap_common_cdb, 1256 CMN_PDIAG_PLL0_CLK_SEL_M0, clk_sel_val); 1257 1258 if (cdns_phy->dp_pll & DP_PLL1) 1259 cdns_torrent_phy_write(cdns_phy->regmap_common_cdb, 1260 CMN_PDIAG_PLL1_CLK_SEL_M0, clk_sel_val); 1261 1262 /* PMA lane configuration to deal with multi-link operation */ 1263 for (i = 0; i < num_lanes; i++) 1264 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + i], 1265 XCVR_DIAG_HSCLK_DIV, hsclk_div_val); 1266 } 1267 1268 /* 1269 * Perform register operations related to setting link rate, once powerstate is 1270 * set and PLL disable request was processed. 1271 */ 1272 static int cdns_torrent_dp_configure_rate(struct cdns_torrent_phy *cdns_phy, 1273 struct cdns_torrent_inst *inst, 1274 struct phy_configure_opts_dp *dp) 1275 { 1276 u32 read_val, field_val; 1277 int ret; 1278 1279 /* 1280 * Disable the associated PLL (cmn_pll0_en or cmn_pll1_en) before 1281 * re-programming the new data rate. 1282 */ 1283 ret = regmap_field_read(cdns_phy->phy_pma_pll_raw_ctrl, &field_val); 1284 if (ret) 1285 return ret; 1286 field_val &= ~(cdns_phy->dp_pll); 1287 regmap_field_write(cdns_phy->phy_pma_pll_raw_ctrl, field_val); 1288 1289 /* 1290 * Wait for PLL ready de-assertion. 1291 * For PLL0 - PHY_PMA_CMN_CTRL2[2] == 1 1292 * For PLL1 - PHY_PMA_CMN_CTRL2[3] == 1 1293 */ 1294 if (cdns_phy->dp_pll & DP_PLL0) { 1295 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2, 1296 read_val, 1297 ((read_val >> 2) & 0x01) != 0, 1298 0, POLL_TIMEOUT_US); 1299 if (ret) 1300 return ret; 1301 } 1302 1303 if ((cdns_phy->dp_pll & DP_PLL1) && cdns_phy->nsubnodes != 1) { 1304 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2, 1305 read_val, 1306 ((read_val >> 3) & 0x01) != 0, 1307 0, POLL_TIMEOUT_US); 1308 if (ret) 1309 return ret; 1310 } 1311 ndelay(200); 1312 1313 /* DP Rate Change - VCO Output settings. */ 1314 if (cdns_phy->ref_clk_rate == CLK_19_2_MHZ) 1315 /* PMA common configuration 19.2MHz */ 1316 cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(cdns_phy, dp->link_rate, dp->ssc); 1317 else if (cdns_phy->ref_clk_rate == CLK_25_MHZ) 1318 /* PMA common configuration 25MHz */ 1319 cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(cdns_phy, dp->link_rate, dp->ssc); 1320 else if (cdns_phy->ref_clk_rate == CLK_100_MHZ) 1321 /* PMA common configuration 100MHz */ 1322 cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(cdns_phy, dp->link_rate, dp->ssc); 1323 1324 cdns_torrent_dp_pma_cmn_rate(cdns_phy, inst, dp->link_rate, dp->lanes); 1325 1326 /* Enable the associated PLL (cmn_pll0_en or cmn_pll1_en) */ 1327 ret = regmap_field_read(cdns_phy->phy_pma_pll_raw_ctrl, &field_val); 1328 if (ret) 1329 return ret; 1330 field_val |= cdns_phy->dp_pll; 1331 regmap_field_write(cdns_phy->phy_pma_pll_raw_ctrl, field_val); 1332 1333 /* 1334 * Wait for PLL ready assertion. 1335 * For PLL0 - PHY_PMA_CMN_CTRL2[0] == 1 1336 * For PLL1 - PHY_PMA_CMN_CTRL2[1] == 1 1337 */ 1338 if (cdns_phy->dp_pll & DP_PLL0) { 1339 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2, 1340 read_val, 1341 (read_val & 0x01) != 0, 1342 0, POLL_TIMEOUT_US); 1343 if (ret) 1344 return ret; 1345 } 1346 1347 if ((cdns_phy->dp_pll & DP_PLL1) && cdns_phy->nsubnodes != 1) 1348 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2, 1349 read_val, 1350 ((read_val >> 1) & 0x01) != 0, 1351 0, POLL_TIMEOUT_US); 1352 1353 return ret; 1354 } 1355 1356 /* 1357 * Verify, that parameters to configure PHY with are correct. 1358 */ 1359 static int cdns_torrent_dp_verify_config(struct cdns_torrent_inst *inst, 1360 struct phy_configure_opts_dp *dp) 1361 { 1362 u8 i; 1363 1364 /* If changing link rate was required, verify it's supported. */ 1365 if (dp->set_rate) { 1366 switch (dp->link_rate) { 1367 case 1620: 1368 case 2160: 1369 case 2430: 1370 case 2700: 1371 case 3240: 1372 case 4320: 1373 case 5400: 1374 case 8100: 1375 /* valid bit rate */ 1376 break; 1377 default: 1378 return -EINVAL; 1379 } 1380 } 1381 1382 /* Verify lane count. */ 1383 switch (dp->lanes) { 1384 case 1: 1385 case 2: 1386 case 4: 1387 /* valid lane count. */ 1388 break; 1389 default: 1390 return -EINVAL; 1391 } 1392 1393 /* Check against actual number of PHY's lanes. */ 1394 if (dp->lanes > inst->num_lanes) 1395 return -EINVAL; 1396 1397 /* 1398 * If changing voltages is required, check swing and pre-emphasis 1399 * levels, per-lane. 1400 */ 1401 if (dp->set_voltages) { 1402 /* Lane count verified previously. */ 1403 for (i = 0; i < dp->lanes; i++) { 1404 if (dp->voltage[i] > 3 || dp->pre[i] > 3) 1405 return -EINVAL; 1406 1407 /* Sum of voltage swing and pre-emphasis levels cannot 1408 * exceed 3. 1409 */ 1410 if (dp->voltage[i] + dp->pre[i] > 3) 1411 return -EINVAL; 1412 } 1413 } 1414 1415 return 0; 1416 } 1417 1418 /* Set power state A0 and PLL clock enable to 0 on enabled lanes. */ 1419 static void cdns_torrent_dp_set_a0_pll(struct cdns_torrent_phy *cdns_phy, 1420 struct cdns_torrent_inst *inst, 1421 u32 num_lanes) 1422 { 1423 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg; 1424 u32 pwr_state = cdns_torrent_dp_read(regmap, 1425 PHY_PMA_XCVR_POWER_STATE_REQ); 1426 u32 pll_clk_en = cdns_torrent_dp_read(regmap, 1427 PHY_PMA_XCVR_PLLCLK_EN); 1428 u32 i; 1429 1430 for (i = 0; i < num_lanes; i++) { 1431 pwr_state &= ~(PMA_XCVR_POWER_STATE_REQ_LN_MASK 1432 << PHY_POWER_STATE_LN(inst->mlane + i)); 1433 1434 pll_clk_en &= ~(0x01U << (inst->mlane + i)); 1435 } 1436 1437 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, pwr_state); 1438 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, pll_clk_en); 1439 } 1440 1441 /* Configure lane count as required. */ 1442 static int cdns_torrent_dp_set_lanes(struct cdns_torrent_phy *cdns_phy, 1443 struct cdns_torrent_inst *inst, 1444 struct phy_configure_opts_dp *dp) 1445 { 1446 u32 value, i; 1447 int ret; 1448 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg; 1449 u8 lane_mask = (1 << dp->lanes) - 1; 1450 u8 pma_tx_elec_idle_mask = 0; 1451 u32 clane = inst->mlane; 1452 1453 lane_mask <<= clane; 1454 1455 value = cdns_torrent_dp_read(regmap, PHY_RESET); 1456 /* clear pma_tx_elec_idle_ln_* bits. */ 1457 pma_tx_elec_idle_mask = ((1 << inst->num_lanes) - 1) << clane; 1458 1459 pma_tx_elec_idle_mask <<= PMA_TX_ELEC_IDLE_SHIFT; 1460 1461 value &= ~pma_tx_elec_idle_mask; 1462 1463 /* Assert pma_tx_elec_idle_ln_* for disabled lanes. */ 1464 value |= ((~lane_mask) << PMA_TX_ELEC_IDLE_SHIFT) & 1465 pma_tx_elec_idle_mask; 1466 1467 cdns_torrent_dp_write(regmap, PHY_RESET, value); 1468 1469 /* reset the link by asserting master lane phy_l0*_reset_n low */ 1470 cdns_torrent_dp_write(regmap, PHY_RESET, 1471 value & (~(1 << clane))); 1472 1473 /* 1474 * Assert lane reset on unused lanes and master lane so they remain in reset 1475 * and powered down when re-enabling the link 1476 */ 1477 for (i = 0; i < inst->num_lanes; i++) 1478 value &= (~(1 << (clane + i))); 1479 1480 for (i = 1; i < inst->num_lanes; i++) 1481 value |= ((1 << (clane + i)) & lane_mask); 1482 1483 cdns_torrent_dp_write(regmap, PHY_RESET, value); 1484 1485 cdns_torrent_dp_set_a0_pll(cdns_phy, inst, dp->lanes); 1486 1487 /* release phy_l0*_reset_n based on used laneCount */ 1488 for (i = 0; i < inst->num_lanes; i++) 1489 value &= (~(1 << (clane + i))); 1490 1491 for (i = 0; i < inst->num_lanes; i++) 1492 value |= ((1 << (clane + i)) & lane_mask); 1493 1494 cdns_torrent_dp_write(regmap, PHY_RESET, value); 1495 1496 /* Wait, until PHY gets ready after releasing PHY reset signal. */ 1497 ret = cdns_torrent_dp_wait_pma_cmn_ready(cdns_phy); 1498 if (ret) 1499 return ret; 1500 1501 ndelay(100); 1502 1503 /* release pma_xcvr_pllclk_en_ln_*, only for the master lane */ 1504 value = cdns_torrent_dp_read(regmap, PHY_PMA_XCVR_PLLCLK_EN); 1505 value |= (1 << clane); 1506 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, value); 1507 1508 ret = cdns_torrent_dp_run(cdns_phy, inst, dp->lanes); 1509 1510 return ret; 1511 } 1512 1513 /* Configure link rate as required. */ 1514 static int cdns_torrent_dp_set_rate(struct cdns_torrent_phy *cdns_phy, 1515 struct cdns_torrent_inst *inst, 1516 struct phy_configure_opts_dp *dp) 1517 { 1518 int ret; 1519 1520 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, dp->lanes, 1521 POWERSTATE_A3); 1522 if (ret) 1523 return ret; 1524 ret = cdns_torrent_dp_set_pll_en(cdns_phy, inst, dp, false); 1525 if (ret) 1526 return ret; 1527 ndelay(200); 1528 1529 ret = cdns_torrent_dp_configure_rate(cdns_phy, inst, dp); 1530 if (ret) 1531 return ret; 1532 ndelay(200); 1533 1534 ret = cdns_torrent_dp_set_pll_en(cdns_phy, inst, dp, true); 1535 if (ret) 1536 return ret; 1537 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, dp->lanes, 1538 POWERSTATE_A2); 1539 if (ret) 1540 return ret; 1541 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, dp->lanes, 1542 POWERSTATE_A0); 1543 if (ret) 1544 return ret; 1545 ndelay(900); 1546 1547 return ret; 1548 } 1549 1550 /* Configure voltage swing and pre-emphasis for all enabled lanes. */ 1551 static void cdns_torrent_dp_set_voltages(struct cdns_torrent_phy *cdns_phy, 1552 struct cdns_torrent_inst *inst, 1553 struct phy_configure_opts_dp *dp) 1554 { 1555 u8 lane; 1556 u16 val; 1557 1558 for (lane = 0; lane < dp->lanes; lane++) { 1559 val = cdns_torrent_phy_read(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane], 1560 TX_DIAG_ACYA); 1561 /* 1562 * Write 1 to register bit TX_DIAG_ACYA[0] to freeze the 1563 * current state of the analog TX driver. 1564 */ 1565 val |= TX_DIAG_ACYA_HBDC_MASK; 1566 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane], 1567 TX_DIAG_ACYA, val); 1568 1569 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane], 1570 TX_TXCC_CTRL, 0x08A4); 1571 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].diag_tx_drv; 1572 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane], 1573 DRV_DIAG_TX_DRV, val); 1574 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].mgnfs_mult; 1575 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane], 1576 TX_TXCC_MGNFS_MULT_000, 1577 val); 1578 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].cpost_mult; 1579 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane], 1580 TX_TXCC_CPOST_MULT_00, 1581 val); 1582 1583 val = cdns_torrent_phy_read(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane], 1584 TX_DIAG_ACYA); 1585 /* 1586 * Write 0 to register bit TX_DIAG_ACYA[0] to allow the state of 1587 * analog TX driver to reflect the new programmed one. 1588 */ 1589 val &= ~TX_DIAG_ACYA_HBDC_MASK; 1590 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane], 1591 TX_DIAG_ACYA, val); 1592 } 1593 }; 1594 1595 static int cdns_torrent_dp_configure(struct phy *phy, 1596 union phy_configure_opts *opts) 1597 { 1598 struct cdns_torrent_inst *inst = phy_get_drvdata(phy); 1599 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent); 1600 int ret; 1601 1602 if (cdns_phy->already_configured) 1603 return 0; 1604 1605 ret = cdns_torrent_dp_verify_config(inst, &opts->dp); 1606 if (ret) { 1607 dev_err(&phy->dev, "invalid params for phy configure\n"); 1608 return ret; 1609 } 1610 1611 if (opts->dp.set_lanes) { 1612 ret = cdns_torrent_dp_set_lanes(cdns_phy, inst, &opts->dp); 1613 if (ret) { 1614 dev_err(&phy->dev, "cdns_torrent_dp_set_lanes failed\n"); 1615 return ret; 1616 } 1617 } 1618 1619 if (opts->dp.set_rate) { 1620 ret = cdns_torrent_dp_set_rate(cdns_phy, inst, &opts->dp); 1621 if (ret) { 1622 dev_err(&phy->dev, "cdns_torrent_dp_set_rate failed\n"); 1623 return ret; 1624 } 1625 } 1626 1627 if (opts->dp.set_voltages) 1628 cdns_torrent_dp_set_voltages(cdns_phy, inst, &opts->dp); 1629 1630 return ret; 1631 } 1632 1633 static int cdns_torrent_phy_on(struct phy *phy) 1634 { 1635 struct cdns_torrent_inst *inst = phy_get_drvdata(phy); 1636 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent); 1637 u32 read_val; 1638 int ret; 1639 1640 if (cdns_phy->already_configured) { 1641 /* Give 5ms to 10ms delay for the PIPE clock to be stable */ 1642 usleep_range(5000, 10000); 1643 return 0; 1644 } 1645 1646 if (cdns_phy->nsubnodes == 1) { 1647 /* Take the PHY lane group out of reset */ 1648 reset_control_deassert(inst->lnk_rst); 1649 1650 /* Take the PHY out of reset */ 1651 ret = reset_control_deassert(cdns_phy->phy_rst); 1652 if (ret) 1653 return ret; 1654 } 1655 1656 /* 1657 * Wait for cmn_ready assertion 1658 * PHY_PMA_CMN_CTRL1[0] == 1 1659 */ 1660 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_1, 1661 read_val, read_val, 1000, 1662 PLL_LOCK_TIMEOUT); 1663 if (ret) { 1664 dev_err(cdns_phy->dev, "Timeout waiting for CMN ready\n"); 1665 return ret; 1666 } 1667 1668 if (inst->phy_type == TYPE_PCIE || inst->phy_type == TYPE_USB) { 1669 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pcs_iso_link_ctrl_1[inst->mlane], 1670 read_val, !read_val, 1000, 1671 PLL_LOCK_TIMEOUT); 1672 if (ret == -ETIMEDOUT) { 1673 dev_err(cdns_phy->dev, "Timeout waiting for PHY status ready\n"); 1674 return ret; 1675 } 1676 } 1677 1678 return 0; 1679 } 1680 1681 static int cdns_torrent_phy_off(struct phy *phy) 1682 { 1683 struct cdns_torrent_inst *inst = phy_get_drvdata(phy); 1684 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent); 1685 int ret; 1686 1687 if (cdns_phy->nsubnodes != 1) 1688 return 0; 1689 1690 ret = reset_control_assert(cdns_phy->phy_rst); 1691 if (ret) 1692 return ret; 1693 1694 return reset_control_assert(inst->lnk_rst); 1695 } 1696 1697 static void cdns_torrent_dp_common_init(struct cdns_torrent_phy *cdns_phy, 1698 struct cdns_torrent_inst *inst) 1699 { 1700 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg; 1701 unsigned char lane_bits; 1702 u32 val; 1703 1704 cdns_torrent_dp_write(regmap, PHY_AUX_CTRL, 0x0003); /* enable AUX */ 1705 1706 /* 1707 * Set lines power state to A0 1708 * Set lines pll clk enable to 0 1709 */ 1710 cdns_torrent_dp_set_a0_pll(cdns_phy, inst, inst->num_lanes); 1711 1712 /* 1713 * release phy_l0*_reset_n and pma_tx_elec_idle_ln_* based on 1714 * used lanes 1715 */ 1716 lane_bits = (1 << inst->num_lanes) - 1; 1717 1718 val = cdns_torrent_dp_read(regmap, PHY_RESET); 1719 val |= (0xF & lane_bits); 1720 val &= ~(lane_bits << 4); 1721 cdns_torrent_dp_write(regmap, PHY_RESET, val); 1722 1723 /* release pma_xcvr_pllclk_en_ln_*, only for the master lane */ 1724 val = cdns_torrent_dp_read(regmap, PHY_PMA_XCVR_PLLCLK_EN); 1725 val |= 1; 1726 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, val); 1727 1728 /* 1729 * PHY PMA registers configuration functions 1730 * Initialize PHY with max supported link rate, without SSC. 1731 */ 1732 if (cdns_phy->ref_clk_rate == CLK_19_2_MHZ) 1733 cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(cdns_phy, 1734 cdns_phy->max_bit_rate, 1735 false); 1736 else if (cdns_phy->ref_clk_rate == CLK_25_MHZ) 1737 cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(cdns_phy, 1738 cdns_phy->max_bit_rate, 1739 false); 1740 else if (cdns_phy->ref_clk_rate == CLK_100_MHZ) 1741 cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(cdns_phy, 1742 cdns_phy->max_bit_rate, 1743 false); 1744 1745 cdns_torrent_dp_pma_cmn_rate(cdns_phy, inst, cdns_phy->max_bit_rate, 1746 inst->num_lanes); 1747 1748 /* take out of reset */ 1749 regmap_field_write(cdns_phy->phy_reset_ctrl, 0x1); 1750 } 1751 1752 static int cdns_torrent_dp_start(struct cdns_torrent_phy *cdns_phy, 1753 struct cdns_torrent_inst *inst, 1754 struct phy *phy) 1755 { 1756 int ret; 1757 1758 ret = cdns_torrent_phy_on(phy); 1759 if (ret) 1760 return ret; 1761 1762 ret = cdns_torrent_dp_wait_pma_cmn_ready(cdns_phy); 1763 if (ret) 1764 return ret; 1765 1766 ret = cdns_torrent_dp_run(cdns_phy, inst, inst->num_lanes); 1767 1768 return ret; 1769 } 1770 1771 static int cdns_torrent_dp_init(struct phy *phy) 1772 { 1773 struct cdns_torrent_inst *inst = phy_get_drvdata(phy); 1774 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent); 1775 int ret; 1776 1777 switch (cdns_phy->ref_clk_rate) { 1778 case CLK_19_2_MHZ: 1779 case CLK_25_MHZ: 1780 case CLK_100_MHZ: 1781 /* Valid Ref Clock Rate */ 1782 break; 1783 default: 1784 dev_err(cdns_phy->dev, "Unsupported Ref Clock Rate\n"); 1785 return -EINVAL; 1786 } 1787 1788 ret = cdns_torrent_dp_get_pll(cdns_phy, TYPE_NONE); 1789 if (ret) 1790 return ret; 1791 1792 cdns_torrent_dp_common_init(cdns_phy, inst); 1793 1794 return cdns_torrent_dp_start(cdns_phy, inst, phy); 1795 } 1796 1797 static int cdns_torrent_dp_multilink_init(struct cdns_torrent_phy *cdns_phy, 1798 struct cdns_torrent_inst *inst, 1799 struct phy *phy) 1800 { 1801 if (cdns_phy->ref_clk_rate != CLK_100_MHZ) { 1802 dev_err(cdns_phy->dev, "Unsupported Ref Clock Rate\n"); 1803 return -EINVAL; 1804 } 1805 1806 cdns_torrent_dp_common_init(cdns_phy, inst); 1807 1808 return cdns_torrent_dp_start(cdns_phy, inst, phy); 1809 } 1810 1811 static int cdns_torrent_derived_refclk_enable(struct clk_hw *hw) 1812 { 1813 struct cdns_torrent_derived_refclk *derived_refclk = to_cdns_torrent_derived_refclk(hw); 1814 1815 regmap_field_write(derived_refclk->cmn_cdiag_refclk_ovrd_4, 1); 1816 regmap_field_write(derived_refclk->phy_pipe_cmn_ctrl1_0, 1); 1817 1818 return 0; 1819 } 1820 1821 static void cdns_torrent_derived_refclk_disable(struct clk_hw *hw) 1822 { 1823 struct cdns_torrent_derived_refclk *derived_refclk = to_cdns_torrent_derived_refclk(hw); 1824 1825 regmap_field_write(derived_refclk->phy_pipe_cmn_ctrl1_0, 0); 1826 regmap_field_write(derived_refclk->cmn_cdiag_refclk_ovrd_4, 0); 1827 } 1828 1829 static int cdns_torrent_derived_refclk_is_enabled(struct clk_hw *hw) 1830 { 1831 struct cdns_torrent_derived_refclk *derived_refclk = to_cdns_torrent_derived_refclk(hw); 1832 int val; 1833 1834 regmap_field_read(derived_refclk->cmn_cdiag_refclk_ovrd_4, &val); 1835 1836 return !!val; 1837 } 1838 1839 static const struct clk_ops cdns_torrent_derived_refclk_ops = { 1840 .enable = cdns_torrent_derived_refclk_enable, 1841 .disable = cdns_torrent_derived_refclk_disable, 1842 .is_enabled = cdns_torrent_derived_refclk_is_enabled, 1843 }; 1844 1845 static int cdns_torrent_derived_refclk_register(struct cdns_torrent_phy *cdns_phy) 1846 { 1847 struct cdns_torrent_derived_refclk *derived_refclk; 1848 struct device *dev = cdns_phy->dev; 1849 struct clk_init_data *init; 1850 const char *parent_name; 1851 char clk_name[100]; 1852 struct clk_hw *hw; 1853 struct clk *clk; 1854 int ret; 1855 1856 derived_refclk = devm_kzalloc(dev, sizeof(*derived_refclk), GFP_KERNEL); 1857 if (!derived_refclk) 1858 return -ENOMEM; 1859 1860 snprintf(clk_name, sizeof(clk_name), "%s_%s", dev_name(dev), 1861 clk_names[CDNS_TORRENT_DERIVED_REFCLK]); 1862 1863 clk = devm_clk_get_optional(dev, "phy_en_refclk"); 1864 if (IS_ERR(clk)) { 1865 dev_err(dev, "No parent clock for derived_refclk\n"); 1866 return PTR_ERR(clk); 1867 } 1868 1869 init = &derived_refclk->clk_data; 1870 1871 if (clk) { 1872 parent_name = __clk_get_name(clk); 1873 init->parent_names = &parent_name; 1874 init->num_parents = 1; 1875 } 1876 init->ops = &cdns_torrent_derived_refclk_ops; 1877 init->flags = 0; 1878 init->name = clk_name; 1879 1880 derived_refclk->phy_pipe_cmn_ctrl1_0 = cdns_phy->phy_pipe_cmn_ctrl1_0; 1881 derived_refclk->cmn_cdiag_refclk_ovrd_4 = cdns_phy->cmn_cdiag_refclk_ovrd_4; 1882 1883 derived_refclk->hw.init = init; 1884 1885 hw = &derived_refclk->hw; 1886 ret = devm_clk_hw_register(dev, hw); 1887 if (ret) 1888 return ret; 1889 1890 cdns_phy->clk_hw_data->hws[CDNS_TORRENT_DERIVED_REFCLK] = hw; 1891 1892 return 0; 1893 } 1894 1895 static int cdns_torrent_received_refclk_enable(struct clk_hw *hw) 1896 { 1897 struct cdns_torrent_received_refclk *received_refclk = to_cdns_torrent_received_refclk(hw); 1898 1899 regmap_field_write(received_refclk->phy_pipe_cmn_ctrl1_0, 1); 1900 1901 return 0; 1902 } 1903 1904 static void cdns_torrent_received_refclk_disable(struct clk_hw *hw) 1905 { 1906 struct cdns_torrent_received_refclk *received_refclk = to_cdns_torrent_received_refclk(hw); 1907 1908 regmap_field_write(received_refclk->phy_pipe_cmn_ctrl1_0, 0); 1909 } 1910 1911 static int cdns_torrent_received_refclk_is_enabled(struct clk_hw *hw) 1912 { 1913 struct cdns_torrent_received_refclk *received_refclk = to_cdns_torrent_received_refclk(hw); 1914 int val, cmn_val; 1915 1916 regmap_field_read(received_refclk->phy_pipe_cmn_ctrl1_0, &val); 1917 regmap_field_read(received_refclk->cmn_cdiag_refclk_ovrd_4, &cmn_val); 1918 1919 return val && !cmn_val; 1920 } 1921 1922 static const struct clk_ops cdns_torrent_received_refclk_ops = { 1923 .enable = cdns_torrent_received_refclk_enable, 1924 .disable = cdns_torrent_received_refclk_disable, 1925 .is_enabled = cdns_torrent_received_refclk_is_enabled, 1926 }; 1927 1928 static int cdns_torrent_received_refclk_register(struct cdns_torrent_phy *cdns_phy) 1929 { 1930 struct cdns_torrent_received_refclk *received_refclk; 1931 struct device *dev = cdns_phy->dev; 1932 struct clk_init_data *init; 1933 const char *parent_name; 1934 char clk_name[100]; 1935 struct clk_hw *hw; 1936 struct clk *clk; 1937 int ret; 1938 1939 received_refclk = devm_kzalloc(dev, sizeof(*received_refclk), GFP_KERNEL); 1940 if (!received_refclk) 1941 return -ENOMEM; 1942 1943 snprintf(clk_name, sizeof(clk_name), "%s_%s", dev_name(dev), 1944 clk_names[CDNS_TORRENT_RECEIVED_REFCLK]); 1945 1946 clk = devm_clk_get_optional(dev, "phy_en_refclk"); 1947 if (IS_ERR(clk)) { 1948 dev_err(dev, "No parent clock for received_refclk\n"); 1949 return PTR_ERR(clk); 1950 } 1951 1952 init = &received_refclk->clk_data; 1953 1954 if (clk) { 1955 parent_name = __clk_get_name(clk); 1956 init->parent_names = &parent_name; 1957 init->num_parents = 1; 1958 } 1959 init->ops = &cdns_torrent_received_refclk_ops; 1960 init->flags = 0; 1961 init->name = clk_name; 1962 1963 received_refclk->phy_pipe_cmn_ctrl1_0 = cdns_phy->phy_pipe_cmn_ctrl1_0; 1964 received_refclk->cmn_cdiag_refclk_ovrd_4 = cdns_phy->cmn_cdiag_refclk_ovrd_4; 1965 1966 received_refclk->hw.init = init; 1967 1968 hw = &received_refclk->hw; 1969 ret = devm_clk_hw_register(dev, hw); 1970 if (ret) 1971 return ret; 1972 1973 cdns_phy->clk_hw_data->hws[CDNS_TORRENT_RECEIVED_REFCLK] = hw; 1974 1975 return 0; 1976 } 1977 1978 static int cdns_torrent_refclk_driver_enable(struct clk_hw *hw) 1979 { 1980 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw); 1981 1982 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_6], 0); 1983 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_5], 1); 1984 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_1], 0); 1985 1986 return 0; 1987 } 1988 1989 static void cdns_torrent_refclk_driver_disable(struct clk_hw *hw) 1990 { 1991 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw); 1992 1993 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_1], 1); 1994 } 1995 1996 static int cdns_torrent_refclk_driver_is_enabled(struct clk_hw *hw) 1997 { 1998 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw); 1999 int val; 2000 2001 regmap_field_read(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_1], &val); 2002 2003 return !val; 2004 } 2005 2006 static u8 cdns_torrent_refclk_driver_get_parent(struct clk_hw *hw) 2007 { 2008 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw); 2009 unsigned int val; 2010 2011 regmap_field_read(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_4], &val); 2012 return clk_mux_val_to_index(hw, cdns_torrent_refclk_driver_mux_table, 0, val); 2013 } 2014 2015 static int cdns_torrent_refclk_driver_set_parent(struct clk_hw *hw, u8 index) 2016 { 2017 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw); 2018 unsigned int val; 2019 2020 val = cdns_torrent_refclk_driver_mux_table[index]; 2021 return regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_4], val); 2022 } 2023 2024 static const struct clk_ops cdns_torrent_refclk_driver_ops = { 2025 .enable = cdns_torrent_refclk_driver_enable, 2026 .disable = cdns_torrent_refclk_driver_disable, 2027 .is_enabled = cdns_torrent_refclk_driver_is_enabled, 2028 .determine_rate = __clk_mux_determine_rate, 2029 .set_parent = cdns_torrent_refclk_driver_set_parent, 2030 .get_parent = cdns_torrent_refclk_driver_get_parent, 2031 }; 2032 2033 static int cdns_torrent_refclk_driver_register(struct cdns_torrent_phy *cdns_phy) 2034 { 2035 struct cdns_torrent_refclk_driver *refclk_driver; 2036 struct device *dev = cdns_phy->dev; 2037 struct regmap_field *field; 2038 struct clk_init_data *init; 2039 const char **parent_names; 2040 unsigned int num_parents; 2041 struct regmap *regmap; 2042 char clk_name[100]; 2043 struct clk_hw *hw; 2044 int i, ret; 2045 2046 refclk_driver = devm_kzalloc(dev, sizeof(*refclk_driver), GFP_KERNEL); 2047 if (!refclk_driver) 2048 return -ENOMEM; 2049 2050 num_parents = ARRAY_SIZE(refclk_driver_parent_index); 2051 parent_names = devm_kzalloc(dev, (sizeof(char *) * num_parents), GFP_KERNEL); 2052 if (!parent_names) 2053 return -ENOMEM; 2054 2055 for (i = 0; i < num_parents; i++) { 2056 hw = cdns_phy->clk_hw_data->hws[refclk_driver_parent_index[i]]; 2057 if (IS_ERR_OR_NULL(hw)) { 2058 dev_err(dev, "No parent clock for refclk driver clock\n"); 2059 return IS_ERR(hw) ? PTR_ERR(hw) : -ENOENT; 2060 } 2061 parent_names[i] = clk_hw_get_name(hw); 2062 } 2063 2064 snprintf(clk_name, sizeof(clk_name), "%s_%s", dev_name(dev), 2065 clk_names[CDNS_TORRENT_REFCLK_DRIVER]); 2066 2067 init = &refclk_driver->clk_data; 2068 2069 init->ops = &cdns_torrent_refclk_driver_ops; 2070 init->flags = CLK_SET_RATE_NO_REPARENT; 2071 init->parent_names = parent_names; 2072 init->num_parents = num_parents; 2073 init->name = clk_name; 2074 2075 regmap = cdns_phy->regmap_common_cdb; 2076 2077 for (i = 0; i < REFCLK_OUT_NUM_CMN_CONFIG; i++) { 2078 field = devm_regmap_field_alloc(dev, regmap, refclk_out_cmn_cfg[i]); 2079 if (IS_ERR(field)) { 2080 dev_err(dev, "Refclk driver CMN reg field init failed\n"); 2081 return PTR_ERR(field); 2082 } 2083 refclk_driver->cmn_fields[i] = field; 2084 } 2085 2086 /* Enable Derived reference clock as default */ 2087 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_4], 1); 2088 2089 refclk_driver->hw.init = init; 2090 2091 hw = &refclk_driver->hw; 2092 ret = devm_clk_hw_register(dev, hw); 2093 if (ret) 2094 return ret; 2095 2096 cdns_phy->clk_hw_data->hws[CDNS_TORRENT_REFCLK_DRIVER] = hw; 2097 2098 return 0; 2099 } 2100 2101 static struct regmap *cdns_regmap_init(struct device *dev, void __iomem *base, 2102 u32 block_offset, 2103 u8 reg_offset_shift, 2104 const struct regmap_config *config) 2105 { 2106 struct cdns_regmap_cdb_context *ctx; 2107 2108 ctx = devm_kzalloc(dev, sizeof(*ctx), GFP_KERNEL); 2109 if (!ctx) 2110 return ERR_PTR(-ENOMEM); 2111 2112 ctx->dev = dev; 2113 ctx->base = base + block_offset; 2114 ctx->reg_offset_shift = reg_offset_shift; 2115 2116 return devm_regmap_init(dev, NULL, ctx, config); 2117 } 2118 2119 static int cdns_torrent_dp_regfield_init(struct cdns_torrent_phy *cdns_phy) 2120 { 2121 struct device *dev = cdns_phy->dev; 2122 struct regmap_field *field; 2123 struct regmap *regmap; 2124 2125 regmap = cdns_phy->regmap_dptx_phy_reg; 2126 field = devm_regmap_field_alloc(dev, regmap, phy_reset_ctrl); 2127 if (IS_ERR(field)) { 2128 dev_err(dev, "PHY_RESET reg field init failed\n"); 2129 return PTR_ERR(field); 2130 } 2131 cdns_phy->phy_reset_ctrl = field; 2132 2133 return 0; 2134 } 2135 2136 static int cdns_torrent_regfield_init(struct cdns_torrent_phy *cdns_phy) 2137 { 2138 struct device *dev = cdns_phy->dev; 2139 struct regmap_field *field; 2140 struct regmap *regmap; 2141 int i; 2142 2143 regmap = cdns_phy->regmap_phy_pcs_common_cdb; 2144 field = devm_regmap_field_alloc(dev, regmap, phy_pll_cfg); 2145 if (IS_ERR(field)) { 2146 dev_err(dev, "PHY_PLL_CFG reg field init failed\n"); 2147 return PTR_ERR(field); 2148 } 2149 cdns_phy->phy_pll_cfg = field; 2150 2151 regmap = cdns_phy->regmap_phy_pcs_common_cdb; 2152 field = devm_regmap_field_alloc(dev, regmap, phy_pipe_cmn_ctrl1_0); 2153 if (IS_ERR(field)) { 2154 dev_err(dev, "phy_pipe_cmn_ctrl1_0 reg field init failed\n"); 2155 return PTR_ERR(field); 2156 } 2157 cdns_phy->phy_pipe_cmn_ctrl1_0 = field; 2158 2159 regmap = cdns_phy->regmap_common_cdb; 2160 field = devm_regmap_field_alloc(dev, regmap, cmn_cdiag_refclk_ovrd_4); 2161 if (IS_ERR(field)) { 2162 dev_err(dev, "cmn_cdiag_refclk_ovrd_4 reg field init failed\n"); 2163 return PTR_ERR(field); 2164 } 2165 cdns_phy->cmn_cdiag_refclk_ovrd_4 = field; 2166 2167 regmap = cdns_phy->regmap_phy_pma_common_cdb; 2168 field = devm_regmap_field_alloc(dev, regmap, phy_pma_cmn_ctrl_1); 2169 if (IS_ERR(field)) { 2170 dev_err(dev, "PHY_PMA_CMN_CTRL1 reg field init failed\n"); 2171 return PTR_ERR(field); 2172 } 2173 cdns_phy->phy_pma_cmn_ctrl_1 = field; 2174 2175 regmap = cdns_phy->regmap_phy_pma_common_cdb; 2176 field = devm_regmap_field_alloc(dev, regmap, phy_pma_cmn_ctrl_2); 2177 if (IS_ERR(field)) { 2178 dev_err(dev, "PHY_PMA_CMN_CTRL2 reg field init failed\n"); 2179 return PTR_ERR(field); 2180 } 2181 cdns_phy->phy_pma_cmn_ctrl_2 = field; 2182 2183 regmap = cdns_phy->regmap_phy_pma_common_cdb; 2184 field = devm_regmap_field_alloc(dev, regmap, phy_pma_pll_raw_ctrl); 2185 if (IS_ERR(field)) { 2186 dev_err(dev, "PHY_PMA_PLL_RAW_CTRL reg field init failed\n"); 2187 return PTR_ERR(field); 2188 } 2189 cdns_phy->phy_pma_pll_raw_ctrl = field; 2190 2191 for (i = 0; i < MAX_NUM_LANES; i++) { 2192 regmap = cdns_phy->regmap_phy_pcs_lane_cdb[i]; 2193 field = devm_regmap_field_alloc(dev, regmap, phy_pcs_iso_link_ctrl_1); 2194 if (IS_ERR(field)) { 2195 dev_err(dev, "PHY_PCS_ISO_LINK_CTRL reg field init for ln %d failed\n", i); 2196 return PTR_ERR(field); 2197 } 2198 cdns_phy->phy_pcs_iso_link_ctrl_1[i] = field; 2199 } 2200 2201 return 0; 2202 } 2203 2204 static int cdns_torrent_dp_regmap_init(struct cdns_torrent_phy *cdns_phy) 2205 { 2206 void __iomem *base = cdns_phy->base; 2207 struct device *dev = cdns_phy->dev; 2208 struct regmap *regmap; 2209 u8 reg_offset_shift; 2210 u32 block_offset; 2211 2212 reg_offset_shift = cdns_phy->init_data->reg_offset_shift; 2213 2214 block_offset = TORRENT_DPTX_PHY_OFFSET; 2215 regmap = cdns_regmap_init(dev, base, block_offset, 2216 reg_offset_shift, 2217 &cdns_torrent_dptx_phy_config); 2218 if (IS_ERR(regmap)) { 2219 dev_err(dev, "Failed to init DPTX PHY regmap\n"); 2220 return PTR_ERR(regmap); 2221 } 2222 cdns_phy->regmap_dptx_phy_reg = regmap; 2223 2224 return 0; 2225 } 2226 2227 static int cdns_torrent_regmap_init(struct cdns_torrent_phy *cdns_phy) 2228 { 2229 void __iomem *sd_base = cdns_phy->sd_base; 2230 u8 block_offset_shift, reg_offset_shift; 2231 struct device *dev = cdns_phy->dev; 2232 struct regmap *regmap; 2233 u32 block_offset; 2234 int i; 2235 2236 block_offset_shift = cdns_phy->init_data->block_offset_shift; 2237 reg_offset_shift = cdns_phy->init_data->reg_offset_shift; 2238 2239 for (i = 0; i < MAX_NUM_LANES; i++) { 2240 block_offset = TORRENT_TX_LANE_CDB_OFFSET(i, block_offset_shift, 2241 reg_offset_shift); 2242 regmap = cdns_regmap_init(dev, sd_base, block_offset, 2243 reg_offset_shift, 2244 &cdns_torrent_tx_lane_cdb_config[i]); 2245 if (IS_ERR(regmap)) { 2246 dev_err(dev, "Failed to init tx lane CDB regmap\n"); 2247 return PTR_ERR(regmap); 2248 } 2249 cdns_phy->regmap_tx_lane_cdb[i] = regmap; 2250 2251 block_offset = TORRENT_RX_LANE_CDB_OFFSET(i, block_offset_shift, 2252 reg_offset_shift); 2253 regmap = cdns_regmap_init(dev, sd_base, block_offset, 2254 reg_offset_shift, 2255 &cdns_torrent_rx_lane_cdb_config[i]); 2256 if (IS_ERR(regmap)) { 2257 dev_err(dev, "Failed to init rx lane CDB regmap\n"); 2258 return PTR_ERR(regmap); 2259 } 2260 cdns_phy->regmap_rx_lane_cdb[i] = regmap; 2261 2262 block_offset = TORRENT_PHY_PCS_LANE_CDB_OFFSET(i, block_offset_shift, 2263 reg_offset_shift); 2264 regmap = cdns_regmap_init(dev, sd_base, block_offset, 2265 reg_offset_shift, 2266 &cdns_torrent_phy_pcs_lane_cdb_config[i]); 2267 if (IS_ERR(regmap)) { 2268 dev_err(dev, "Failed to init PHY PCS lane CDB regmap\n"); 2269 return PTR_ERR(regmap); 2270 } 2271 cdns_phy->regmap_phy_pcs_lane_cdb[i] = regmap; 2272 } 2273 2274 block_offset = TORRENT_COMMON_CDB_OFFSET; 2275 regmap = cdns_regmap_init(dev, sd_base, block_offset, 2276 reg_offset_shift, 2277 &cdns_torrent_common_cdb_config); 2278 if (IS_ERR(regmap)) { 2279 dev_err(dev, "Failed to init common CDB regmap\n"); 2280 return PTR_ERR(regmap); 2281 } 2282 cdns_phy->regmap_common_cdb = regmap; 2283 2284 block_offset = TORRENT_PHY_PCS_COMMON_OFFSET(block_offset_shift); 2285 regmap = cdns_regmap_init(dev, sd_base, block_offset, 2286 reg_offset_shift, 2287 &cdns_torrent_phy_pcs_cmn_cdb_config); 2288 if (IS_ERR(regmap)) { 2289 dev_err(dev, "Failed to init PHY PCS common CDB regmap\n"); 2290 return PTR_ERR(regmap); 2291 } 2292 cdns_phy->regmap_phy_pcs_common_cdb = regmap; 2293 2294 block_offset = TORRENT_PHY_PMA_COMMON_OFFSET(block_offset_shift); 2295 regmap = cdns_regmap_init(dev, sd_base, block_offset, 2296 reg_offset_shift, 2297 &cdns_torrent_phy_pma_cmn_cdb_config); 2298 if (IS_ERR(regmap)) { 2299 dev_err(dev, "Failed to init PHY PMA common CDB regmap\n"); 2300 return PTR_ERR(regmap); 2301 } 2302 cdns_phy->regmap_phy_pma_common_cdb = regmap; 2303 2304 return 0; 2305 } 2306 2307 static int cdns_torrent_phy_init(struct phy *phy) 2308 { 2309 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent); 2310 const struct cdns_torrent_vals *cmn_vals, *tx_ln_vals, *rx_ln_vals; 2311 const struct cdns_torrent_data *init_data = cdns_phy->init_data; 2312 const struct cdns_torrent_vals *link_cmn_vals, *xcvr_diag_vals; 2313 enum cdns_torrent_ref_clk ref_clk = cdns_phy->ref_clk_rate; 2314 struct cdns_torrent_inst *inst = phy_get_drvdata(phy); 2315 enum cdns_torrent_phy_type phy_type = inst->phy_type; 2316 const struct cdns_torrent_vals *phy_pma_cmn_vals; 2317 enum cdns_torrent_ssc_mode ssc = inst->ssc_mode; 2318 const struct cdns_torrent_vals *pcs_cmn_vals; 2319 const struct cdns_reg_pairs *reg_pairs; 2320 struct regmap *regmap; 2321 u32 num_regs; 2322 int i, j; 2323 2324 if (cdns_phy->already_configured) 2325 return 0; 2326 2327 if (cdns_phy->nsubnodes > 1) { 2328 if (phy_type == TYPE_DP) 2329 return cdns_torrent_dp_multilink_init(cdns_phy, inst, phy); 2330 return 0; 2331 } 2332 2333 /** 2334 * Spread spectrum generation is not required or supported 2335 * for SGMII/QSGMII/USXGMII 2336 */ 2337 if (phy_type == TYPE_SGMII || phy_type == TYPE_QSGMII || phy_type == TYPE_USXGMII) 2338 ssc = NO_SSC; 2339 2340 /* PHY configuration specific registers for single link */ 2341 link_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->link_cmn_vals_tbl, 2342 CLK_ANY, CLK_ANY, 2343 phy_type, TYPE_NONE, 2344 ANY_SSC); 2345 if (link_cmn_vals) { 2346 reg_pairs = link_cmn_vals->reg_pairs; 2347 num_regs = link_cmn_vals->num_regs; 2348 regmap = cdns_phy->regmap_common_cdb; 2349 2350 /** 2351 * First array value in link_cmn_vals must be of 2352 * PHY_PLL_CFG register 2353 */ 2354 regmap_field_write(cdns_phy->phy_pll_cfg, reg_pairs[0].val); 2355 2356 for (i = 1; i < num_regs; i++) 2357 regmap_write(regmap, reg_pairs[i].off, 2358 reg_pairs[i].val); 2359 } 2360 2361 xcvr_diag_vals = cdns_torrent_get_tbl_vals(&init_data->xcvr_diag_vals_tbl, 2362 CLK_ANY, CLK_ANY, 2363 phy_type, TYPE_NONE, 2364 ANY_SSC); 2365 if (xcvr_diag_vals) { 2366 reg_pairs = xcvr_diag_vals->reg_pairs; 2367 num_regs = xcvr_diag_vals->num_regs; 2368 for (i = 0; i < inst->num_lanes; i++) { 2369 regmap = cdns_phy->regmap_tx_lane_cdb[i + inst->mlane]; 2370 for (j = 0; j < num_regs; j++) 2371 regmap_write(regmap, reg_pairs[j].off, 2372 reg_pairs[j].val); 2373 } 2374 } 2375 2376 /* PHY PCS common registers configurations */ 2377 pcs_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->pcs_cmn_vals_tbl, 2378 CLK_ANY, CLK_ANY, 2379 phy_type, TYPE_NONE, 2380 ANY_SSC); 2381 if (pcs_cmn_vals) { 2382 reg_pairs = pcs_cmn_vals->reg_pairs; 2383 num_regs = pcs_cmn_vals->num_regs; 2384 regmap = cdns_phy->regmap_phy_pcs_common_cdb; 2385 for (i = 0; i < num_regs; i++) 2386 regmap_write(regmap, reg_pairs[i].off, 2387 reg_pairs[i].val); 2388 } 2389 2390 /* PHY PMA common registers configurations */ 2391 phy_pma_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->phy_pma_cmn_vals_tbl, 2392 CLK_ANY, CLK_ANY, 2393 phy_type, TYPE_NONE, 2394 ANY_SSC); 2395 if (phy_pma_cmn_vals) { 2396 reg_pairs = phy_pma_cmn_vals->reg_pairs; 2397 num_regs = phy_pma_cmn_vals->num_regs; 2398 regmap = cdns_phy->regmap_phy_pma_common_cdb; 2399 for (i = 0; i < num_regs; i++) 2400 regmap_write(regmap, reg_pairs[i].off, 2401 reg_pairs[i].val); 2402 } 2403 2404 /* PMA common registers configurations */ 2405 cmn_vals = cdns_torrent_get_tbl_vals(&init_data->cmn_vals_tbl, 2406 ref_clk, ref_clk, 2407 phy_type, TYPE_NONE, 2408 ssc); 2409 if (cmn_vals) { 2410 reg_pairs = cmn_vals->reg_pairs; 2411 num_regs = cmn_vals->num_regs; 2412 regmap = cdns_phy->regmap_common_cdb; 2413 for (i = 0; i < num_regs; i++) 2414 regmap_write(regmap, reg_pairs[i].off, 2415 reg_pairs[i].val); 2416 } 2417 2418 /* PMA TX lane registers configurations */ 2419 tx_ln_vals = cdns_torrent_get_tbl_vals(&init_data->tx_ln_vals_tbl, 2420 ref_clk, ref_clk, 2421 phy_type, TYPE_NONE, 2422 ssc); 2423 if (tx_ln_vals) { 2424 reg_pairs = tx_ln_vals->reg_pairs; 2425 num_regs = tx_ln_vals->num_regs; 2426 for (i = 0; i < inst->num_lanes; i++) { 2427 regmap = cdns_phy->regmap_tx_lane_cdb[i + inst->mlane]; 2428 for (j = 0; j < num_regs; j++) 2429 regmap_write(regmap, reg_pairs[j].off, 2430 reg_pairs[j].val); 2431 } 2432 } 2433 2434 /* PMA RX lane registers configurations */ 2435 rx_ln_vals = cdns_torrent_get_tbl_vals(&init_data->rx_ln_vals_tbl, 2436 ref_clk, ref_clk, 2437 phy_type, TYPE_NONE, 2438 ssc); 2439 if (rx_ln_vals) { 2440 reg_pairs = rx_ln_vals->reg_pairs; 2441 num_regs = rx_ln_vals->num_regs; 2442 for (i = 0; i < inst->num_lanes; i++) { 2443 regmap = cdns_phy->regmap_rx_lane_cdb[i + inst->mlane]; 2444 for (j = 0; j < num_regs; j++) 2445 regmap_write(regmap, reg_pairs[j].off, 2446 reg_pairs[j].val); 2447 } 2448 } 2449 2450 if (phy_type == TYPE_DP) 2451 return cdns_torrent_dp_init(phy); 2452 2453 return 0; 2454 } 2455 2456 static const struct phy_ops cdns_torrent_phy_ops = { 2457 .init = cdns_torrent_phy_init, 2458 .configure = cdns_torrent_dp_configure, 2459 .power_on = cdns_torrent_phy_on, 2460 .power_off = cdns_torrent_phy_off, 2461 .owner = THIS_MODULE, 2462 }; 2463 2464 static 2465 int cdns_torrent_phy_configure_multilink(struct cdns_torrent_phy *cdns_phy) 2466 { 2467 const struct cdns_torrent_vals *cmn_vals, *tx_ln_vals, *rx_ln_vals; 2468 const struct cdns_torrent_data *init_data = cdns_phy->init_data; 2469 const struct cdns_torrent_vals *link_cmn_vals, *xcvr_diag_vals; 2470 enum cdns_torrent_ref_clk ref_clk1 = cdns_phy->ref_clk1_rate; 2471 enum cdns_torrent_ref_clk ref_clk = cdns_phy->ref_clk_rate; 2472 const struct cdns_torrent_vals *phy_pma_cmn_vals; 2473 const struct cdns_torrent_vals *pcs_cmn_vals; 2474 enum cdns_torrent_phy_type phy_t1, phy_t2; 2475 const struct cdns_reg_pairs *reg_pairs; 2476 int i, j, node, mlane, num_lanes, ret; 2477 struct device *dev = cdns_phy->dev; 2478 enum cdns_torrent_ssc_mode ssc; 2479 struct regmap *regmap; 2480 u32 num_regs, num_protocols, protocol; 2481 2482 num_protocols = hweight32(cdns_phy->protocol_bitmask); 2483 /* Maximum 2 protocols are supported */ 2484 if (num_protocols > 2) { 2485 dev_err(dev, "at most 2 protocols are supported\n"); 2486 return -EINVAL; 2487 } 2488 2489 2490 /** 2491 * Get PHY types directly from subnodes if only 2 subnodes exist. 2492 * It is possible for phy_t1 to be the same as phy_t2 for special 2493 * configurations such as PCIe Multilink. 2494 */ 2495 if (cdns_phy->nsubnodes == 2) { 2496 phy_t1 = cdns_phy->phys[0].phy_type; 2497 phy_t2 = cdns_phy->phys[1].phy_type; 2498 } else { 2499 /** 2500 * Both PHY types / protocols should be unique. 2501 * If they are the same, it should be expressed with either 2502 * a) Single-Link (1 Sub-node) - handled via PHY APIs 2503 * OR 2504 * b) Double-Link (2 Sub-nodes) - handled above 2505 */ 2506 if (num_protocols != 2) { 2507 dev_err(dev, "incorrect representation of link\n"); 2508 return -EINVAL; 2509 } 2510 2511 phy_t1 = fns(cdns_phy->protocol_bitmask, 0); 2512 phy_t2 = fns(cdns_phy->protocol_bitmask, 1); 2513 } 2514 2515 /** 2516 * Configure all links with the protocol phy_t1 first followed by 2517 * configuring all links with the protocol phy_t2. 2518 * 2519 * When phy_t1 = phy_t2, it is a single protocol and configuration 2520 * is performed with a single iteration of the protocol and multiple 2521 * iterations over the sub-nodes (links). 2522 * 2523 * When phy_t1 != phy_t2, there are two protocols and configuration 2524 * is performed by iterating over all sub-nodes matching the first 2525 * protocol and configuring them first, followed by iterating over 2526 * all sub-nodes matching the second protocol and configuring them 2527 * next. 2528 */ 2529 for (protocol = 0; protocol < num_protocols; protocol++) { 2530 /** 2531 * For the case where num_protocols is 1, 2532 * phy_t1 = phy_t2 and the swap is unnecessary. 2533 * 2534 * Swapping phy_t1 and phy_t2 is only required when the 2535 * number of protocols is 2 and there are 2 or more links. 2536 */ 2537 if (protocol == 1) { 2538 /** 2539 * If first protocol with phy_t1 is configured, then 2540 * configure the PHY for second protocol with phy_t2. 2541 * Get the array values as [phy_t2][phy_t1][ssc]. 2542 */ 2543 swap(phy_t1, phy_t2); 2544 swap(ref_clk, ref_clk1); 2545 } 2546 2547 for (node = 0; node < cdns_phy->nsubnodes; node++) { 2548 if (cdns_phy->phys[node].phy_type != phy_t1) 2549 continue; 2550 2551 mlane = cdns_phy->phys[node].mlane; 2552 ssc = cdns_phy->phys[node].ssc_mode; 2553 num_lanes = cdns_phy->phys[node].num_lanes; 2554 2555 /** 2556 * PHY configuration specific registers: 2557 * link_cmn_vals depend on combination of PHY types being 2558 * configured and are common for both PHY types, so array 2559 * values should be same for [phy_t1][phy_t2][ssc] and 2560 * [phy_t2][phy_t1][ssc]. 2561 * xcvr_diag_vals also depend on combination of PHY types 2562 * being configured, but these can be different for particular 2563 * PHY type and are per lane. 2564 */ 2565 link_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->link_cmn_vals_tbl, 2566 CLK_ANY, CLK_ANY, 2567 phy_t1, phy_t2, ANY_SSC); 2568 if (link_cmn_vals) { 2569 reg_pairs = link_cmn_vals->reg_pairs; 2570 num_regs = link_cmn_vals->num_regs; 2571 regmap = cdns_phy->regmap_common_cdb; 2572 2573 /** 2574 * First array value in link_cmn_vals must be of 2575 * PHY_PLL_CFG register 2576 */ 2577 regmap_field_write(cdns_phy->phy_pll_cfg, 2578 reg_pairs[0].val); 2579 2580 for (i = 1; i < num_regs; i++) 2581 regmap_write(regmap, reg_pairs[i].off, 2582 reg_pairs[i].val); 2583 } 2584 2585 xcvr_diag_vals = cdns_torrent_get_tbl_vals(&init_data->xcvr_diag_vals_tbl, 2586 CLK_ANY, CLK_ANY, 2587 phy_t1, phy_t2, ANY_SSC); 2588 if (xcvr_diag_vals) { 2589 reg_pairs = xcvr_diag_vals->reg_pairs; 2590 num_regs = xcvr_diag_vals->num_regs; 2591 for (i = 0; i < num_lanes; i++) { 2592 regmap = cdns_phy->regmap_tx_lane_cdb[i + mlane]; 2593 for (j = 0; j < num_regs; j++) 2594 regmap_write(regmap, reg_pairs[j].off, 2595 reg_pairs[j].val); 2596 } 2597 } 2598 2599 /* PHY PCS common registers configurations */ 2600 pcs_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->pcs_cmn_vals_tbl, 2601 CLK_ANY, CLK_ANY, 2602 phy_t1, phy_t2, ANY_SSC); 2603 if (pcs_cmn_vals) { 2604 reg_pairs = pcs_cmn_vals->reg_pairs; 2605 num_regs = pcs_cmn_vals->num_regs; 2606 regmap = cdns_phy->regmap_phy_pcs_common_cdb; 2607 for (i = 0; i < num_regs; i++) 2608 regmap_write(regmap, reg_pairs[i].off, 2609 reg_pairs[i].val); 2610 } 2611 2612 /* PHY PMA common registers configurations */ 2613 phy_pma_cmn_vals = 2614 cdns_torrent_get_tbl_vals(&init_data->phy_pma_cmn_vals_tbl, 2615 CLK_ANY, CLK_ANY, phy_t1, phy_t2, 2616 ANY_SSC); 2617 if (phy_pma_cmn_vals) { 2618 reg_pairs = phy_pma_cmn_vals->reg_pairs; 2619 num_regs = phy_pma_cmn_vals->num_regs; 2620 regmap = cdns_phy->regmap_phy_pma_common_cdb; 2621 for (i = 0; i < num_regs; i++) 2622 regmap_write(regmap, reg_pairs[i].off, 2623 reg_pairs[i].val); 2624 } 2625 2626 /* PMA common registers configurations */ 2627 cmn_vals = cdns_torrent_get_tbl_vals(&init_data->cmn_vals_tbl, 2628 ref_clk, ref_clk1, 2629 phy_t1, phy_t2, ssc); 2630 if (cmn_vals) { 2631 reg_pairs = cmn_vals->reg_pairs; 2632 num_regs = cmn_vals->num_regs; 2633 regmap = cdns_phy->regmap_common_cdb; 2634 for (i = 0; i < num_regs; i++) 2635 regmap_write(regmap, reg_pairs[i].off, 2636 reg_pairs[i].val); 2637 } 2638 2639 /* PMA TX lane registers configurations */ 2640 tx_ln_vals = cdns_torrent_get_tbl_vals(&init_data->tx_ln_vals_tbl, 2641 ref_clk, ref_clk1, 2642 phy_t1, phy_t2, ssc); 2643 if (tx_ln_vals) { 2644 reg_pairs = tx_ln_vals->reg_pairs; 2645 num_regs = tx_ln_vals->num_regs; 2646 for (i = 0; i < num_lanes; i++) { 2647 regmap = cdns_phy->regmap_tx_lane_cdb[i + mlane]; 2648 for (j = 0; j < num_regs; j++) 2649 regmap_write(regmap, reg_pairs[j].off, 2650 reg_pairs[j].val); 2651 } 2652 } 2653 2654 /* PMA RX lane registers configurations */ 2655 rx_ln_vals = cdns_torrent_get_tbl_vals(&init_data->rx_ln_vals_tbl, 2656 ref_clk, ref_clk1, 2657 phy_t1, phy_t2, ssc); 2658 if (rx_ln_vals) { 2659 reg_pairs = rx_ln_vals->reg_pairs; 2660 num_regs = rx_ln_vals->num_regs; 2661 for (i = 0; i < num_lanes; i++) { 2662 regmap = cdns_phy->regmap_rx_lane_cdb[i + mlane]; 2663 for (j = 0; j < num_regs; j++) 2664 regmap_write(regmap, reg_pairs[j].off, 2665 reg_pairs[j].val); 2666 } 2667 } 2668 2669 if (phy_t1 == TYPE_DP) { 2670 ret = cdns_torrent_dp_get_pll(cdns_phy, phy_t2); 2671 if (ret) 2672 return ret; 2673 } 2674 2675 reset_control_deassert(cdns_phy->phys[node].lnk_rst); 2676 } 2677 } 2678 2679 /* Take the PHY out of reset */ 2680 ret = reset_control_deassert(cdns_phy->phy_rst); 2681 if (ret) 2682 return ret; 2683 2684 return 0; 2685 } 2686 2687 static void cdns_torrent_clk_cleanup(struct cdns_torrent_phy *cdns_phy) 2688 { 2689 struct device *dev = cdns_phy->dev; 2690 2691 of_clk_del_provider(dev->of_node); 2692 } 2693 2694 static int cdns_torrent_clk_register(struct cdns_torrent_phy *cdns_phy) 2695 { 2696 struct device *dev = cdns_phy->dev; 2697 struct device_node *node = dev->of_node; 2698 struct clk_hw_onecell_data *data; 2699 int ret; 2700 2701 data = devm_kzalloc(dev, struct_size(data, hws, CDNS_TORRENT_OUTPUT_CLOCKS), GFP_KERNEL); 2702 if (!data) 2703 return -ENOMEM; 2704 2705 data->num = CDNS_TORRENT_OUTPUT_CLOCKS; 2706 cdns_phy->clk_hw_data = data; 2707 2708 ret = cdns_torrent_derived_refclk_register(cdns_phy); 2709 if (ret) { 2710 dev_err(dev, "failed to register derived refclk\n"); 2711 return ret; 2712 } 2713 2714 ret = cdns_torrent_received_refclk_register(cdns_phy); 2715 if (ret) { 2716 dev_err(dev, "failed to register received refclk\n"); 2717 return ret; 2718 } 2719 2720 ret = cdns_torrent_refclk_driver_register(cdns_phy); 2721 if (ret) { 2722 dev_err(dev, "failed to register refclk driver\n"); 2723 return ret; 2724 } 2725 2726 ret = of_clk_add_hw_provider(node, of_clk_hw_onecell_get, data); 2727 if (ret) { 2728 dev_err(dev, "Failed to add clock provider: %s\n", node->name); 2729 return ret; 2730 } 2731 2732 return 0; 2733 } 2734 2735 static int cdns_torrent_of_get_reset(struct cdns_torrent_phy *cdns_phy) 2736 { 2737 struct device *dev = cdns_phy->dev; 2738 2739 cdns_phy->phy_rst = devm_reset_control_get_exclusive_by_index(dev, 0); 2740 if (IS_ERR(cdns_phy->phy_rst)) { 2741 dev_err(dev, "%s: failed to get reset\n", 2742 dev->of_node->full_name); 2743 return PTR_ERR(cdns_phy->phy_rst); 2744 } 2745 2746 cdns_phy->apb_rst = devm_reset_control_get_optional_exclusive(dev, "torrent_apb"); 2747 if (IS_ERR(cdns_phy->apb_rst)) { 2748 dev_err(dev, "%s: failed to get apb reset\n", 2749 dev->of_node->full_name); 2750 return PTR_ERR(cdns_phy->apb_rst); 2751 } 2752 2753 return 0; 2754 } 2755 2756 static int cdns_torrent_of_get_clk(struct cdns_torrent_phy *cdns_phy) 2757 { 2758 /* refclk: Input reference clock for PLL0 */ 2759 cdns_phy->clk = devm_clk_get(cdns_phy->dev, "refclk"); 2760 if (IS_ERR(cdns_phy->clk)) 2761 return dev_err_probe(cdns_phy->dev, PTR_ERR(cdns_phy->clk), 2762 "phy ref clock not found\n"); 2763 2764 /* refclk1: Input reference clock for PLL1 */ 2765 cdns_phy->clk1 = devm_clk_get_optional(cdns_phy->dev, "pll1_refclk"); 2766 if (IS_ERR(cdns_phy->clk1)) 2767 return dev_err_probe(cdns_phy->dev, PTR_ERR(cdns_phy->clk1), 2768 "phy PLL1 ref clock not found\n"); 2769 2770 return 0; 2771 } 2772 2773 static int cdns_torrent_clk(struct cdns_torrent_phy *cdns_phy) 2774 { 2775 unsigned long ref_clk1_rate; 2776 unsigned long ref_clk_rate; 2777 int ret; 2778 2779 ret = clk_prepare_enable(cdns_phy->clk); 2780 if (ret) { 2781 dev_err(cdns_phy->dev, "Failed to prepare ref clock: %d\n", ret); 2782 return ret; 2783 } 2784 2785 ref_clk_rate = clk_get_rate(cdns_phy->clk); 2786 if (!ref_clk_rate) { 2787 dev_err(cdns_phy->dev, "Failed to get ref clock rate\n"); 2788 ret = -EINVAL; 2789 goto disable_clk; 2790 } 2791 2792 switch (ref_clk_rate) { 2793 case REF_CLK_19_2MHZ: 2794 cdns_phy->ref_clk_rate = CLK_19_2_MHZ; 2795 break; 2796 case REF_CLK_25MHZ: 2797 cdns_phy->ref_clk_rate = CLK_25_MHZ; 2798 break; 2799 case REF_CLK_100MHZ: 2800 cdns_phy->ref_clk_rate = CLK_100_MHZ; 2801 break; 2802 case REF_CLK_156_25MHZ: 2803 cdns_phy->ref_clk_rate = CLK_156_25_MHZ; 2804 break; 2805 default: 2806 dev_err(cdns_phy->dev, "Invalid ref clock rate\n"); 2807 ret = -EINVAL; 2808 goto disable_clk; 2809 } 2810 2811 if (cdns_phy->clk1) { 2812 ret = clk_prepare_enable(cdns_phy->clk1); 2813 if (ret) { 2814 dev_err(cdns_phy->dev, "Failed to prepare PLL1 ref clock: %d\n", ret); 2815 goto disable_clk; 2816 } 2817 2818 ref_clk1_rate = clk_get_rate(cdns_phy->clk1); 2819 if (!ref_clk1_rate) { 2820 dev_err(cdns_phy->dev, "Failed to get PLL1 ref clock rate\n"); 2821 ret = -EINVAL; 2822 goto disable_clk1; 2823 } 2824 2825 switch (ref_clk1_rate) { 2826 case REF_CLK_19_2MHZ: 2827 cdns_phy->ref_clk1_rate = CLK_19_2_MHZ; 2828 break; 2829 case REF_CLK_25MHZ: 2830 cdns_phy->ref_clk1_rate = CLK_25_MHZ; 2831 break; 2832 case REF_CLK_100MHZ: 2833 cdns_phy->ref_clk1_rate = CLK_100_MHZ; 2834 break; 2835 case REF_CLK_156_25MHZ: 2836 cdns_phy->ref_clk1_rate = CLK_156_25_MHZ; 2837 break; 2838 default: 2839 dev_err(cdns_phy->dev, "Invalid PLL1 ref clock rate\n"); 2840 ret = -EINVAL; 2841 goto disable_clk1; 2842 } 2843 } else { 2844 cdns_phy->ref_clk1_rate = cdns_phy->ref_clk_rate; 2845 } 2846 2847 return 0; 2848 2849 disable_clk1: 2850 clk_disable_unprepare(cdns_phy->clk1); 2851 disable_clk: 2852 clk_disable_unprepare(cdns_phy->clk); 2853 return ret; 2854 } 2855 2856 static int cdns_torrent_phy_probe(struct platform_device *pdev) 2857 { 2858 struct cdns_torrent_phy *cdns_phy; 2859 struct device *dev = &pdev->dev; 2860 struct phy_provider *phy_provider; 2861 const struct cdns_torrent_data *data; 2862 struct device_node *child; 2863 int ret, subnodes, node = 0, i; 2864 u32 total_num_lanes = 0; 2865 u8 init_dp_regmap = 0; 2866 u32 phy_type; 2867 2868 /* Get init data for this PHY */ 2869 data = of_device_get_match_data(dev); 2870 if (!data) 2871 return -EINVAL; 2872 2873 cdns_phy = devm_kzalloc(dev, sizeof(*cdns_phy), GFP_KERNEL); 2874 if (!cdns_phy) 2875 return -ENOMEM; 2876 2877 dev_set_drvdata(dev, cdns_phy); 2878 cdns_phy->dev = dev; 2879 cdns_phy->init_data = data; 2880 cdns_phy->protocol_bitmask = 0; 2881 2882 cdns_phy->sd_base = devm_platform_ioremap_resource(pdev, 0); 2883 if (IS_ERR(cdns_phy->sd_base)) 2884 return PTR_ERR(cdns_phy->sd_base); 2885 2886 subnodes = of_get_available_child_count(dev->of_node); 2887 if (subnodes == 0) { 2888 dev_err(dev, "No available link subnodes found\n"); 2889 return -EINVAL; 2890 } 2891 2892 ret = cdns_torrent_regmap_init(cdns_phy); 2893 if (ret) 2894 return ret; 2895 2896 ret = cdns_torrent_regfield_init(cdns_phy); 2897 if (ret) 2898 return ret; 2899 2900 ret = cdns_torrent_clk_register(cdns_phy); 2901 if (ret) 2902 return ret; 2903 2904 ret = cdns_torrent_of_get_reset(cdns_phy); 2905 if (ret) 2906 goto clk_cleanup; 2907 2908 ret = cdns_torrent_of_get_clk(cdns_phy); 2909 if (ret) 2910 goto clk_cleanup; 2911 2912 regmap_field_read(cdns_phy->phy_pma_cmn_ctrl_1, &cdns_phy->already_configured); 2913 2914 if (!cdns_phy->already_configured) { 2915 ret = cdns_torrent_clk(cdns_phy); 2916 if (ret) 2917 goto clk_cleanup; 2918 2919 /* Enable APB */ 2920 reset_control_deassert(cdns_phy->apb_rst); 2921 } 2922 2923 for_each_available_child_of_node(dev->of_node, child) { 2924 struct phy *gphy; 2925 2926 /* PHY subnode name must be 'phy'. */ 2927 if (!(of_node_name_eq(child, "phy"))) 2928 continue; 2929 2930 cdns_phy->phys[node].lnk_rst = 2931 of_reset_control_array_get_exclusive(child); 2932 if (IS_ERR(cdns_phy->phys[node].lnk_rst)) { 2933 dev_err(dev, "%s: failed to get reset\n", 2934 child->full_name); 2935 ret = PTR_ERR(cdns_phy->phys[node].lnk_rst); 2936 goto put_lnk_rst; 2937 } 2938 2939 if (of_property_read_u32(child, "reg", 2940 &cdns_phy->phys[node].mlane)) { 2941 dev_err(dev, "%s: No \"reg\"-property.\n", 2942 child->full_name); 2943 ret = -EINVAL; 2944 goto put_child; 2945 } 2946 2947 if (of_property_read_u32(child, "cdns,phy-type", &phy_type)) { 2948 dev_err(dev, "%s: No \"cdns,phy-type\"-property.\n", 2949 child->full_name); 2950 ret = -EINVAL; 2951 goto put_child; 2952 } 2953 2954 switch (phy_type) { 2955 case PHY_TYPE_PCIE: 2956 cdns_phy->phys[node].phy_type = TYPE_PCIE; 2957 break; 2958 case PHY_TYPE_DP: 2959 cdns_phy->phys[node].phy_type = TYPE_DP; 2960 break; 2961 case PHY_TYPE_SGMII: 2962 cdns_phy->phys[node].phy_type = TYPE_SGMII; 2963 break; 2964 case PHY_TYPE_QSGMII: 2965 cdns_phy->phys[node].phy_type = TYPE_QSGMII; 2966 break; 2967 case PHY_TYPE_USB3: 2968 cdns_phy->phys[node].phy_type = TYPE_USB; 2969 break; 2970 case PHY_TYPE_USXGMII: 2971 cdns_phy->phys[node].phy_type = TYPE_USXGMII; 2972 break; 2973 default: 2974 dev_err(dev, "Unsupported protocol\n"); 2975 ret = -EINVAL; 2976 goto put_child; 2977 } 2978 2979 if (of_property_read_u32(child, "cdns,num-lanes", 2980 &cdns_phy->phys[node].num_lanes)) { 2981 dev_err(dev, "%s: No \"cdns,num-lanes\"-property.\n", 2982 child->full_name); 2983 ret = -EINVAL; 2984 goto put_child; 2985 } 2986 2987 total_num_lanes += cdns_phy->phys[node].num_lanes; 2988 2989 /* Get SSC mode */ 2990 cdns_phy->phys[node].ssc_mode = NO_SSC; 2991 of_property_read_u32(child, "cdns,ssc-mode", 2992 &cdns_phy->phys[node].ssc_mode); 2993 2994 gphy = devm_phy_create(dev, child, &cdns_torrent_phy_ops); 2995 if (IS_ERR(gphy)) { 2996 ret = PTR_ERR(gphy); 2997 goto put_child; 2998 } 2999 3000 if (cdns_phy->phys[node].phy_type == TYPE_DP) { 3001 switch (cdns_phy->phys[node].num_lanes) { 3002 case 1: 3003 case 2: 3004 case 4: 3005 /* valid number of lanes */ 3006 break; 3007 default: 3008 dev_err(dev, "unsupported number of lanes: %d\n", 3009 cdns_phy->phys[node].num_lanes); 3010 ret = -EINVAL; 3011 goto put_child; 3012 } 3013 3014 cdns_phy->max_bit_rate = DEFAULT_MAX_BIT_RATE; 3015 of_property_read_u32(child, "cdns,max-bit-rate", 3016 &cdns_phy->max_bit_rate); 3017 3018 switch (cdns_phy->max_bit_rate) { 3019 case 1620: 3020 case 2160: 3021 case 2430: 3022 case 2700: 3023 case 3240: 3024 case 4320: 3025 case 5400: 3026 case 8100: 3027 /* valid bit rate */ 3028 break; 3029 default: 3030 dev_err(dev, "unsupported max bit rate: %dMbps\n", 3031 cdns_phy->max_bit_rate); 3032 ret = -EINVAL; 3033 goto put_child; 3034 } 3035 3036 /* DPTX registers */ 3037 cdns_phy->base = devm_platform_ioremap_resource(pdev, 1); 3038 if (IS_ERR(cdns_phy->base)) { 3039 ret = PTR_ERR(cdns_phy->base); 3040 goto put_child; 3041 } 3042 3043 if (!init_dp_regmap) { 3044 ret = cdns_torrent_dp_regmap_init(cdns_phy); 3045 if (ret) 3046 goto put_child; 3047 3048 ret = cdns_torrent_dp_regfield_init(cdns_phy); 3049 if (ret) 3050 goto put_child; 3051 3052 init_dp_regmap++; 3053 } 3054 3055 dev_dbg(dev, "DP max bit rate %d.%03d Gbps\n", 3056 cdns_phy->max_bit_rate / 1000, 3057 cdns_phy->max_bit_rate % 1000); 3058 3059 gphy->attrs.bus_width = cdns_phy->phys[node].num_lanes; 3060 gphy->attrs.max_link_rate = cdns_phy->max_bit_rate; 3061 gphy->attrs.mode = PHY_MODE_DP; 3062 } 3063 3064 cdns_phy->phys[node].phy = gphy; 3065 cdns_phy->protocol_bitmask |= BIT(cdns_phy->phys[node].phy_type); 3066 phy_set_drvdata(gphy, &cdns_phy->phys[node]); 3067 3068 node++; 3069 } 3070 cdns_phy->nsubnodes = node; 3071 3072 if (total_num_lanes > MAX_NUM_LANES) { 3073 dev_err(dev, "Invalid lane configuration\n"); 3074 ret = -EINVAL; 3075 goto put_lnk_rst; 3076 } 3077 3078 if (cdns_phy->nsubnodes > 1 && !cdns_phy->already_configured) { 3079 ret = cdns_torrent_phy_configure_multilink(cdns_phy); 3080 if (ret) 3081 goto put_lnk_rst; 3082 } 3083 3084 phy_provider = devm_of_phy_provider_register(dev, of_phy_simple_xlate); 3085 if (IS_ERR(phy_provider)) { 3086 ret = PTR_ERR(phy_provider); 3087 goto put_lnk_rst; 3088 } 3089 3090 if (cdns_phy->nsubnodes > 1) 3091 dev_dbg(dev, "Multi-link: %s (%d lanes) & %s (%d lanes)", 3092 cdns_torrent_get_phy_type(cdns_phy->phys[0].phy_type), 3093 cdns_phy->phys[0].num_lanes, 3094 cdns_torrent_get_phy_type(cdns_phy->phys[1].phy_type), 3095 cdns_phy->phys[1].num_lanes); 3096 else 3097 dev_dbg(dev, "Single link: %s (%d lanes)", 3098 cdns_torrent_get_phy_type(cdns_phy->phys[0].phy_type), 3099 cdns_phy->phys[0].num_lanes); 3100 3101 return 0; 3102 3103 put_child: 3104 node++; 3105 put_lnk_rst: 3106 for (i = 0; i < node; i++) 3107 reset_control_put(cdns_phy->phys[i].lnk_rst); 3108 of_node_put(child); 3109 reset_control_assert(cdns_phy->apb_rst); 3110 clk_disable_unprepare(cdns_phy->clk1); 3111 clk_disable_unprepare(cdns_phy->clk); 3112 clk_cleanup: 3113 cdns_torrent_clk_cleanup(cdns_phy); 3114 return ret; 3115 } 3116 3117 static void cdns_torrent_phy_remove(struct platform_device *pdev) 3118 { 3119 struct cdns_torrent_phy *cdns_phy = platform_get_drvdata(pdev); 3120 int i; 3121 3122 reset_control_assert(cdns_phy->phy_rst); 3123 reset_control_assert(cdns_phy->apb_rst); 3124 for (i = 0; i < cdns_phy->nsubnodes; i++) { 3125 reset_control_assert(cdns_phy->phys[i].lnk_rst); 3126 reset_control_put(cdns_phy->phys[i].lnk_rst); 3127 } 3128 3129 clk_disable_unprepare(cdns_phy->clk1); 3130 clk_disable_unprepare(cdns_phy->clk); 3131 cdns_torrent_clk_cleanup(cdns_phy); 3132 } 3133 3134 /* SGMII and QSGMII link configuration */ 3135 static const struct cdns_reg_pairs sgmii_qsgmii_link_cmn_regs[] = { 3136 {0x0002, PHY_PLL_CFG} 3137 }; 3138 3139 static const struct cdns_reg_pairs sgmii_qsgmii_xcvr_diag_ln_regs[] = { 3140 {0x0003, XCVR_DIAG_HSCLK_DIV}, 3141 {0x0113, XCVR_DIAG_PLLDRC_CTRL} 3142 }; 3143 3144 static const struct cdns_torrent_vals sgmii_qsgmii_link_cmn_vals = { 3145 .reg_pairs = sgmii_qsgmii_link_cmn_regs, 3146 .num_regs = ARRAY_SIZE(sgmii_qsgmii_link_cmn_regs), 3147 }; 3148 3149 static const struct cdns_torrent_vals sgmii_qsgmii_xcvr_diag_ln_vals = { 3150 .reg_pairs = sgmii_qsgmii_xcvr_diag_ln_regs, 3151 .num_regs = ARRAY_SIZE(sgmii_qsgmii_xcvr_diag_ln_regs), 3152 }; 3153 3154 static int cdns_torrent_phy_suspend_noirq(struct device *dev) 3155 { 3156 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(dev); 3157 int i; 3158 3159 reset_control_assert(cdns_phy->phy_rst); 3160 reset_control_assert(cdns_phy->apb_rst); 3161 for (i = 0; i < cdns_phy->nsubnodes; i++) 3162 reset_control_assert(cdns_phy->phys[i].lnk_rst); 3163 3164 if (cdns_phy->already_configured) 3165 cdns_phy->already_configured = 0; 3166 else { 3167 clk_disable_unprepare(cdns_phy->clk1); 3168 clk_disable_unprepare(cdns_phy->clk); 3169 } 3170 3171 return 0; 3172 } 3173 3174 static int cdns_torrent_phy_resume_noirq(struct device *dev) 3175 { 3176 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(dev); 3177 int node = cdns_phy->nsubnodes; 3178 int ret, i; 3179 3180 ret = cdns_torrent_clk(cdns_phy); 3181 if (ret) 3182 return ret; 3183 3184 /* Enable APB */ 3185 reset_control_deassert(cdns_phy->apb_rst); 3186 3187 if (cdns_phy->nsubnodes > 1) { 3188 ret = cdns_torrent_phy_configure_multilink(cdns_phy); 3189 if (ret) 3190 goto put_lnk_rst; 3191 } 3192 3193 return 0; 3194 3195 put_lnk_rst: 3196 for (i = 0; i < node; i++) 3197 reset_control_assert(cdns_phy->phys[i].lnk_rst); 3198 reset_control_assert(cdns_phy->apb_rst); 3199 3200 clk_disable_unprepare(cdns_phy->clk1); 3201 clk_disable_unprepare(cdns_phy->clk); 3202 3203 return ret; 3204 } 3205 3206 static DEFINE_NOIRQ_DEV_PM_OPS(cdns_torrent_phy_pm_ops, 3207 cdns_torrent_phy_suspend_noirq, 3208 cdns_torrent_phy_resume_noirq); 3209 3210 /* USB and DP link configuration */ 3211 static const struct cdns_reg_pairs usb_dp_link_cmn_regs[] = { 3212 {0x0002, PHY_PLL_CFG}, 3213 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0} 3214 }; 3215 3216 static const struct cdns_reg_pairs usb_dp_xcvr_diag_ln_regs[] = { 3217 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3218 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3219 {0x0041, XCVR_DIAG_PLLDRC_CTRL} 3220 }; 3221 3222 static const struct cdns_reg_pairs dp_usb_xcvr_diag_ln_regs[] = { 3223 {0x0001, XCVR_DIAG_HSCLK_SEL}, 3224 {0x0009, XCVR_DIAG_PLLDRC_CTRL} 3225 }; 3226 3227 static const struct cdns_torrent_vals usb_dp_link_cmn_vals = { 3228 .reg_pairs = usb_dp_link_cmn_regs, 3229 .num_regs = ARRAY_SIZE(usb_dp_link_cmn_regs), 3230 }; 3231 3232 static const struct cdns_torrent_vals usb_dp_xcvr_diag_ln_vals = { 3233 .reg_pairs = usb_dp_xcvr_diag_ln_regs, 3234 .num_regs = ARRAY_SIZE(usb_dp_xcvr_diag_ln_regs), 3235 }; 3236 3237 static const struct cdns_torrent_vals dp_usb_xcvr_diag_ln_vals = { 3238 .reg_pairs = dp_usb_xcvr_diag_ln_regs, 3239 .num_regs = ARRAY_SIZE(dp_usb_xcvr_diag_ln_regs), 3240 }; 3241 3242 /* USXGMII and SGMII/QSGMII link configuration */ 3243 static const struct cdns_reg_pairs usxgmii_sgmii_link_cmn_regs[] = { 3244 {0x0002, PHY_PLL_CFG}, 3245 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M0}, 3246 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0} 3247 }; 3248 3249 static const struct cdns_reg_pairs usxgmii_sgmii_xcvr_diag_ln_regs[] = { 3250 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3251 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3252 {0x0001, XCVR_DIAG_PLLDRC_CTRL} 3253 }; 3254 3255 static const struct cdns_reg_pairs sgmii_usxgmii_xcvr_diag_ln_regs[] = { 3256 {0x0111, XCVR_DIAG_HSCLK_SEL}, 3257 {0x0103, XCVR_DIAG_HSCLK_DIV}, 3258 {0x0A9B, XCVR_DIAG_PLLDRC_CTRL} 3259 }; 3260 3261 static const struct cdns_torrent_vals usxgmii_sgmii_link_cmn_vals = { 3262 .reg_pairs = usxgmii_sgmii_link_cmn_regs, 3263 .num_regs = ARRAY_SIZE(usxgmii_sgmii_link_cmn_regs), 3264 }; 3265 3266 static const struct cdns_torrent_vals usxgmii_sgmii_xcvr_diag_ln_vals = { 3267 .reg_pairs = usxgmii_sgmii_xcvr_diag_ln_regs, 3268 .num_regs = ARRAY_SIZE(usxgmii_sgmii_xcvr_diag_ln_regs), 3269 }; 3270 3271 static const struct cdns_torrent_vals sgmii_usxgmii_xcvr_diag_ln_vals = { 3272 .reg_pairs = sgmii_usxgmii_xcvr_diag_ln_regs, 3273 .num_regs = ARRAY_SIZE(sgmii_usxgmii_xcvr_diag_ln_regs), 3274 }; 3275 3276 /* Multilink USXGMII, using PLL0, 156.25 MHz Ref clk, no SSC */ 3277 static const struct cdns_reg_pairs ml_usxgmii_pll0_156_25_no_ssc_cmn_regs[] = { 3278 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0}, 3279 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0}, 3280 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR}, 3281 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR}, 3282 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START}, 3283 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START}, 3284 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 3285 {0x0138, CMN_PLL0_LOCK_REFCNT_START}, 3286 {0x0138, CMN_PLL0_LOCK_PLLCNT_START} 3287 }; 3288 3289 static const struct cdns_torrent_vals ml_usxgmii_pll0_156_25_no_ssc_cmn_vals = { 3290 .reg_pairs = ml_usxgmii_pll0_156_25_no_ssc_cmn_regs, 3291 .num_regs = ARRAY_SIZE(ml_usxgmii_pll0_156_25_no_ssc_cmn_regs), 3292 }; 3293 3294 /* Multilink SGMII/QSGMII, using PLL1, 100 MHz Ref clk, no SSC */ 3295 static const struct cdns_reg_pairs ml_sgmii_pll1_100_no_ssc_cmn_regs[] = { 3296 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0}, 3297 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0}, 3298 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0}, 3299 {0x0003, CMN_PLL1_VCOCAL_TCTRL}, 3300 {0x007F, CMN_TXPUCAL_TUNE}, 3301 {0x007F, CMN_TXPDCAL_TUNE} 3302 }; 3303 3304 static const struct cdns_torrent_vals ml_sgmii_pll1_100_no_ssc_cmn_vals = { 3305 .reg_pairs = ml_sgmii_pll1_100_no_ssc_cmn_regs, 3306 .num_regs = ARRAY_SIZE(ml_sgmii_pll1_100_no_ssc_cmn_regs), 3307 }; 3308 3309 /* TI J7200, Multilink USXGMII, using PLL0, 156.25 MHz Ref clk, no SSC */ 3310 static const struct cdns_reg_pairs j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs[] = { 3311 {0x0014, CMN_SSM_BIAS_TMR}, 3312 {0x0028, CMN_PLLSM0_PLLPRE_TMR}, 3313 {0x00A4, CMN_PLLSM0_PLLLOCK_TMR}, 3314 {0x0062, CMN_BGCAL_INIT_TMR}, 3315 {0x0062, CMN_BGCAL_ITER_TMR}, 3316 {0x0014, CMN_IBCAL_INIT_TMR}, 3317 {0x0018, CMN_TXPUCAL_INIT_TMR}, 3318 {0x0005, CMN_TXPUCAL_ITER_TMR}, 3319 {0x0018, CMN_TXPDCAL_INIT_TMR}, 3320 {0x0005, CMN_TXPDCAL_ITER_TMR}, 3321 {0x024A, CMN_RXCAL_INIT_TMR}, 3322 {0x0005, CMN_RXCAL_ITER_TMR}, 3323 {0x000B, CMN_SD_CAL_REFTIM_START}, 3324 {0x0132, CMN_SD_CAL_PLLCNT_START}, 3325 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0}, 3326 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0}, 3327 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR}, 3328 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR}, 3329 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START}, 3330 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START}, 3331 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 3332 {0x0138, CMN_PLL0_LOCK_REFCNT_START}, 3333 {0x0138, CMN_PLL0_LOCK_PLLCNT_START} 3334 }; 3335 3336 static const struct cdns_torrent_vals j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_vals = { 3337 .reg_pairs = j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs, 3338 .num_regs = ARRAY_SIZE(j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs), 3339 }; 3340 3341 /* TI J7200, Multilink SGMII/QSGMII, using PLL1, 100 MHz Ref clk, no SSC */ 3342 static const struct cdns_reg_pairs j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs[] = { 3343 {0x0028, CMN_PLLSM1_PLLPRE_TMR}, 3344 {0x00A4, CMN_PLLSM1_PLLLOCK_TMR}, 3345 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0}, 3346 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0}, 3347 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0}, 3348 {0x0003, CMN_PLL1_VCOCAL_TCTRL}, 3349 {0x007F, CMN_TXPUCAL_TUNE}, 3350 {0x007F, CMN_TXPDCAL_TUNE} 3351 }; 3352 3353 static const struct cdns_torrent_vals j7200_ml_sgmii_pll1_100_no_ssc_cmn_vals = { 3354 .reg_pairs = j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs, 3355 .num_regs = ARRAY_SIZE(j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs), 3356 }; 3357 3358 /* PCIe and USXGMII link configuration */ 3359 static const struct cdns_reg_pairs pcie_usxgmii_link_cmn_regs[] = { 3360 {0x0003, PHY_PLL_CFG}, 3361 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0}, 3362 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1}, 3363 {0x0400, CMN_PDIAG_PLL1_CLK_SEL_M0} 3364 }; 3365 3366 static const struct cdns_reg_pairs pcie_usxgmii_xcvr_diag_ln_regs[] = { 3367 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3368 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3369 {0x0012, XCVR_DIAG_PLLDRC_CTRL} 3370 }; 3371 3372 static const struct cdns_reg_pairs usxgmii_pcie_xcvr_diag_ln_regs[] = { 3373 {0x0011, XCVR_DIAG_HSCLK_SEL}, 3374 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3375 {0x0089, XCVR_DIAG_PLLDRC_CTRL} 3376 }; 3377 3378 static const struct cdns_torrent_vals pcie_usxgmii_link_cmn_vals = { 3379 .reg_pairs = pcie_usxgmii_link_cmn_regs, 3380 .num_regs = ARRAY_SIZE(pcie_usxgmii_link_cmn_regs), 3381 }; 3382 3383 static const struct cdns_torrent_vals pcie_usxgmii_xcvr_diag_ln_vals = { 3384 .reg_pairs = pcie_usxgmii_xcvr_diag_ln_regs, 3385 .num_regs = ARRAY_SIZE(pcie_usxgmii_xcvr_diag_ln_regs), 3386 }; 3387 3388 static const struct cdns_torrent_vals usxgmii_pcie_xcvr_diag_ln_vals = { 3389 .reg_pairs = usxgmii_pcie_xcvr_diag_ln_regs, 3390 .num_regs = ARRAY_SIZE(usxgmii_pcie_xcvr_diag_ln_regs), 3391 }; 3392 3393 /* 3394 * Multilink USXGMII, using PLL1, 156.25 MHz Ref clk, no SSC 3395 */ 3396 static const struct cdns_reg_pairs ml_usxgmii_pll1_156_25_no_ssc_cmn_regs[] = { 3397 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0}, 3398 {0x0014, CMN_PLL1_DSM_FBH_OVRD_M0}, 3399 {0x0005, CMN_PLL1_DSM_FBL_OVRD_M0}, 3400 {0x061B, CMN_PLL1_VCOCAL_INIT_TMR}, 3401 {0x0019, CMN_PLL1_VCOCAL_ITER_TMR}, 3402 {0x1354, CMN_PLL1_VCOCAL_REFTIM_START}, 3403 {0x1354, CMN_PLL1_VCOCAL_PLLCNT_START}, 3404 {0x0003, CMN_PLL1_VCOCAL_TCTRL}, 3405 {0x0138, CMN_PLL1_LOCK_REFCNT_START}, 3406 {0x0138, CMN_PLL1_LOCK_PLLCNT_START}, 3407 {0x007F, CMN_TXPUCAL_TUNE}, 3408 {0x007F, CMN_TXPDCAL_TUNE} 3409 }; 3410 3411 static const struct cdns_reg_pairs ml_usxgmii_156_25_no_ssc_tx_ln_regs[] = { 3412 {0x00F3, TX_PSC_A0}, 3413 {0x04A2, TX_PSC_A2}, 3414 {0x04A2, TX_PSC_A3 }, 3415 {0x0000, TX_TXCC_CPOST_MULT_00}, 3416 {0x0000, XCVR_DIAG_PSC_OVRD} 3417 }; 3418 3419 static const struct cdns_reg_pairs ml_usxgmii_156_25_no_ssc_rx_ln_regs[] = { 3420 {0x091D, RX_PSC_A0}, 3421 {0x0900, RX_PSC_A2}, 3422 {0x0100, RX_PSC_A3}, 3423 {0x0030, RX_REE_SMGM_CTRL1}, 3424 {0x03C7, RX_REE_GCSM1_EQENM_PH1}, 3425 {0x01C7, RX_REE_GCSM1_EQENM_PH2}, 3426 {0x0000, RX_DIAG_DFE_CTRL}, 3427 {0x0019, RX_REE_TAP1_CLIP}, 3428 {0x0019, RX_REE_TAP2TON_CLIP}, 3429 {0x00B9, RX_DIAG_NQST_CTRL}, 3430 {0x0C21, RX_DIAG_DFE_AMP_TUNE_2}, 3431 {0x0002, RX_DIAG_DFE_AMP_TUNE_3}, 3432 {0x0033, RX_DIAG_PI_RATE}, 3433 {0x0001, RX_DIAG_ACYA}, 3434 {0x018C, RX_CDRLF_CNFG} 3435 }; 3436 3437 static const struct cdns_torrent_vals ml_usxgmii_pll1_156_25_no_ssc_cmn_vals = { 3438 .reg_pairs = ml_usxgmii_pll1_156_25_no_ssc_cmn_regs, 3439 .num_regs = ARRAY_SIZE(ml_usxgmii_pll1_156_25_no_ssc_cmn_regs), 3440 }; 3441 3442 static const struct cdns_torrent_vals ml_usxgmii_156_25_no_ssc_tx_ln_vals = { 3443 .reg_pairs = ml_usxgmii_156_25_no_ssc_tx_ln_regs, 3444 .num_regs = ARRAY_SIZE(ml_usxgmii_156_25_no_ssc_tx_ln_regs), 3445 }; 3446 3447 static const struct cdns_torrent_vals ml_usxgmii_156_25_no_ssc_rx_ln_vals = { 3448 .reg_pairs = ml_usxgmii_156_25_no_ssc_rx_ln_regs, 3449 .num_regs = ARRAY_SIZE(ml_usxgmii_156_25_no_ssc_rx_ln_regs), 3450 }; 3451 3452 /* TI USXGMII configuration: Enable cmn_refclk_rcv_out_en */ 3453 static const struct cdns_reg_pairs ti_usxgmii_phy_pma_cmn_regs[] = { 3454 {0x0040, PHY_PMA_CMN_CTRL1}, 3455 }; 3456 3457 static const struct cdns_torrent_vals ti_usxgmii_phy_pma_cmn_vals = { 3458 .reg_pairs = ti_usxgmii_phy_pma_cmn_regs, 3459 .num_regs = ARRAY_SIZE(ti_usxgmii_phy_pma_cmn_regs), 3460 }; 3461 3462 /* Single USXGMII link configuration */ 3463 static const struct cdns_reg_pairs sl_usxgmii_link_cmn_regs[] = { 3464 {0x0000, PHY_PLL_CFG}, 3465 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M0} 3466 }; 3467 3468 static const struct cdns_reg_pairs sl_usxgmii_xcvr_diag_ln_regs[] = { 3469 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3470 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3471 {0x0001, XCVR_DIAG_PLLDRC_CTRL} 3472 }; 3473 3474 static const struct cdns_torrent_vals sl_usxgmii_link_cmn_vals = { 3475 .reg_pairs = sl_usxgmii_link_cmn_regs, 3476 .num_regs = ARRAY_SIZE(sl_usxgmii_link_cmn_regs), 3477 }; 3478 3479 static const struct cdns_torrent_vals sl_usxgmii_xcvr_diag_ln_vals = { 3480 .reg_pairs = sl_usxgmii_xcvr_diag_ln_regs, 3481 .num_regs = ARRAY_SIZE(sl_usxgmii_xcvr_diag_ln_regs), 3482 }; 3483 3484 /* Single link USXGMII, 156.25 MHz Ref clk, no SSC */ 3485 static const struct cdns_reg_pairs sl_usxgmii_156_25_no_ssc_cmn_regs[] = { 3486 {0x0014, CMN_SSM_BIAS_TMR}, 3487 {0x0028, CMN_PLLSM0_PLLPRE_TMR}, 3488 {0x00A4, CMN_PLLSM0_PLLLOCK_TMR}, 3489 {0x0028, CMN_PLLSM1_PLLPRE_TMR}, 3490 {0x00A4, CMN_PLLSM1_PLLLOCK_TMR}, 3491 {0x0062, CMN_BGCAL_INIT_TMR}, 3492 {0x0062, CMN_BGCAL_ITER_TMR}, 3493 {0x0014, CMN_IBCAL_INIT_TMR}, 3494 {0x0018, CMN_TXPUCAL_INIT_TMR}, 3495 {0x0005, CMN_TXPUCAL_ITER_TMR}, 3496 {0x0018, CMN_TXPDCAL_INIT_TMR}, 3497 {0x0005, CMN_TXPDCAL_ITER_TMR}, 3498 {0x024A, CMN_RXCAL_INIT_TMR}, 3499 {0x0005, CMN_RXCAL_ITER_TMR}, 3500 {0x000B, CMN_SD_CAL_REFTIM_START}, 3501 {0x0132, CMN_SD_CAL_PLLCNT_START}, 3502 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0}, 3503 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0}, 3504 {0x0014, CMN_PLL1_DSM_FBH_OVRD_M0}, 3505 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0}, 3506 {0x0005, CMN_PLL1_DSM_FBL_OVRD_M0}, 3507 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR}, 3508 {0x061B, CMN_PLL1_VCOCAL_INIT_TMR}, 3509 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR}, 3510 {0x0019, CMN_PLL1_VCOCAL_ITER_TMR}, 3511 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START}, 3512 {0x1354, CMN_PLL1_VCOCAL_REFTIM_START}, 3513 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START}, 3514 {0x1354, CMN_PLL1_VCOCAL_PLLCNT_START}, 3515 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 3516 {0x0003, CMN_PLL1_VCOCAL_TCTRL}, 3517 {0x0138, CMN_PLL0_LOCK_REFCNT_START}, 3518 {0x0138, CMN_PLL1_LOCK_REFCNT_START}, 3519 {0x0138, CMN_PLL0_LOCK_PLLCNT_START}, 3520 {0x0138, CMN_PLL1_LOCK_PLLCNT_START} 3521 }; 3522 3523 static const struct cdns_reg_pairs usxgmii_156_25_no_ssc_tx_ln_regs[] = { 3524 {0x07A2, TX_RCVDET_ST_TMR}, 3525 {0x00F3, TX_PSC_A0}, 3526 {0x04A2, TX_PSC_A2}, 3527 {0x04A2, TX_PSC_A3}, 3528 {0x0000, TX_TXCC_CPOST_MULT_00}, 3529 {0x0000, XCVR_DIAG_PSC_OVRD} 3530 }; 3531 3532 static const struct cdns_reg_pairs usxgmii_156_25_no_ssc_rx_ln_regs[] = { 3533 {0x0014, RX_SDCAL0_INIT_TMR}, 3534 {0x0062, RX_SDCAL0_ITER_TMR}, 3535 {0x0014, RX_SDCAL1_INIT_TMR}, 3536 {0x0062, RX_SDCAL1_ITER_TMR}, 3537 {0x091D, RX_PSC_A0}, 3538 {0x0900, RX_PSC_A2}, 3539 {0x0100, RX_PSC_A3}, 3540 {0x0030, RX_REE_SMGM_CTRL1}, 3541 {0x03C7, RX_REE_GCSM1_EQENM_PH1}, 3542 {0x01C7, RX_REE_GCSM1_EQENM_PH2}, 3543 {0x0000, RX_DIAG_DFE_CTRL}, 3544 {0x0019, RX_REE_TAP1_CLIP}, 3545 {0x0019, RX_REE_TAP2TON_CLIP}, 3546 {0x00B9, RX_DIAG_NQST_CTRL}, 3547 {0x0C21, RX_DIAG_DFE_AMP_TUNE_2}, 3548 {0x0002, RX_DIAG_DFE_AMP_TUNE_3}, 3549 {0x0033, RX_DIAG_PI_RATE}, 3550 {0x0001, RX_DIAG_ACYA}, 3551 {0x018C, RX_CDRLF_CNFG} 3552 }; 3553 3554 static const struct cdns_torrent_vals sl_usxgmii_156_25_no_ssc_cmn_vals = { 3555 .reg_pairs = sl_usxgmii_156_25_no_ssc_cmn_regs, 3556 .num_regs = ARRAY_SIZE(sl_usxgmii_156_25_no_ssc_cmn_regs), 3557 }; 3558 3559 static const struct cdns_torrent_vals usxgmii_156_25_no_ssc_tx_ln_vals = { 3560 .reg_pairs = usxgmii_156_25_no_ssc_tx_ln_regs, 3561 .num_regs = ARRAY_SIZE(usxgmii_156_25_no_ssc_tx_ln_regs), 3562 }; 3563 3564 static const struct cdns_torrent_vals usxgmii_156_25_no_ssc_rx_ln_vals = { 3565 .reg_pairs = usxgmii_156_25_no_ssc_rx_ln_regs, 3566 .num_regs = ARRAY_SIZE(usxgmii_156_25_no_ssc_rx_ln_regs), 3567 }; 3568 3569 /* PCIe and DP link configuration */ 3570 static const struct cdns_reg_pairs pcie_dp_link_cmn_regs[] = { 3571 {0x0003, PHY_PLL_CFG}, 3572 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0}, 3573 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1} 3574 }; 3575 3576 static const struct cdns_reg_pairs pcie_dp_xcvr_diag_ln_regs[] = { 3577 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3578 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3579 {0x0012, XCVR_DIAG_PLLDRC_CTRL} 3580 }; 3581 3582 static const struct cdns_reg_pairs dp_pcie_xcvr_diag_ln_regs[] = { 3583 {0x0001, XCVR_DIAG_HSCLK_SEL}, 3584 {0x0009, XCVR_DIAG_PLLDRC_CTRL} 3585 }; 3586 3587 static const struct cdns_torrent_vals pcie_dp_link_cmn_vals = { 3588 .reg_pairs = pcie_dp_link_cmn_regs, 3589 .num_regs = ARRAY_SIZE(pcie_dp_link_cmn_regs), 3590 }; 3591 3592 static const struct cdns_torrent_vals pcie_dp_xcvr_diag_ln_vals = { 3593 .reg_pairs = pcie_dp_xcvr_diag_ln_regs, 3594 .num_regs = ARRAY_SIZE(pcie_dp_xcvr_diag_ln_regs), 3595 }; 3596 3597 static const struct cdns_torrent_vals dp_pcie_xcvr_diag_ln_vals = { 3598 .reg_pairs = dp_pcie_xcvr_diag_ln_regs, 3599 .num_regs = ARRAY_SIZE(dp_pcie_xcvr_diag_ln_regs), 3600 }; 3601 3602 /* DP Multilink, 100 MHz Ref clk, no SSC */ 3603 static const struct cdns_reg_pairs dp_100_no_ssc_cmn_regs[] = { 3604 {0x007F, CMN_TXPUCAL_TUNE}, 3605 {0x007F, CMN_TXPDCAL_TUNE} 3606 }; 3607 3608 static const struct cdns_reg_pairs dp_100_no_ssc_tx_ln_regs[] = { 3609 {0x00FB, TX_PSC_A0}, 3610 {0x04AA, TX_PSC_A2}, 3611 {0x04AA, TX_PSC_A3}, 3612 {0x000F, XCVR_DIAG_BIDI_CTRL} 3613 }; 3614 3615 static const struct cdns_reg_pairs dp_100_no_ssc_rx_ln_regs[] = { 3616 {0x0000, RX_PSC_A0}, 3617 {0x0000, RX_PSC_A2}, 3618 {0x0000, RX_PSC_A3}, 3619 {0x0000, RX_PSC_CAL}, 3620 {0x0000, RX_REE_GCSM1_CTRL}, 3621 {0x0000, RX_REE_GCSM2_CTRL}, 3622 {0x0000, RX_REE_PERGCSM_CTRL} 3623 }; 3624 3625 static const struct cdns_torrent_vals dp_100_no_ssc_cmn_vals = { 3626 .reg_pairs = dp_100_no_ssc_cmn_regs, 3627 .num_regs = ARRAY_SIZE(dp_100_no_ssc_cmn_regs), 3628 }; 3629 3630 static const struct cdns_torrent_vals dp_100_no_ssc_tx_ln_vals = { 3631 .reg_pairs = dp_100_no_ssc_tx_ln_regs, 3632 .num_regs = ARRAY_SIZE(dp_100_no_ssc_tx_ln_regs), 3633 }; 3634 3635 static const struct cdns_torrent_vals dp_100_no_ssc_rx_ln_vals = { 3636 .reg_pairs = dp_100_no_ssc_rx_ln_regs, 3637 .num_regs = ARRAY_SIZE(dp_100_no_ssc_rx_ln_regs), 3638 }; 3639 3640 /* Single DisplayPort(DP) link configuration */ 3641 static const struct cdns_reg_pairs sl_dp_link_cmn_regs[] = { 3642 {0x0000, PHY_PLL_CFG}, 3643 }; 3644 3645 static const struct cdns_reg_pairs sl_dp_xcvr_diag_ln_regs[] = { 3646 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3647 {0x0001, XCVR_DIAG_PLLDRC_CTRL} 3648 }; 3649 3650 static const struct cdns_torrent_vals sl_dp_link_cmn_vals = { 3651 .reg_pairs = sl_dp_link_cmn_regs, 3652 .num_regs = ARRAY_SIZE(sl_dp_link_cmn_regs), 3653 }; 3654 3655 static const struct cdns_torrent_vals sl_dp_xcvr_diag_ln_vals = { 3656 .reg_pairs = sl_dp_xcvr_diag_ln_regs, 3657 .num_regs = ARRAY_SIZE(sl_dp_xcvr_diag_ln_regs), 3658 }; 3659 3660 /* Single DP, 19.2 MHz Ref clk, no SSC */ 3661 static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_cmn_regs[] = { 3662 {0x0014, CMN_SSM_BIAS_TMR}, 3663 {0x0027, CMN_PLLSM0_PLLPRE_TMR}, 3664 {0x00A1, CMN_PLLSM0_PLLLOCK_TMR}, 3665 {0x0027, CMN_PLLSM1_PLLPRE_TMR}, 3666 {0x00A1, CMN_PLLSM1_PLLLOCK_TMR}, 3667 {0x0060, CMN_BGCAL_INIT_TMR}, 3668 {0x0060, CMN_BGCAL_ITER_TMR}, 3669 {0x0014, CMN_IBCAL_INIT_TMR}, 3670 {0x0018, CMN_TXPUCAL_INIT_TMR}, 3671 {0x0005, CMN_TXPUCAL_ITER_TMR}, 3672 {0x0018, CMN_TXPDCAL_INIT_TMR}, 3673 {0x0005, CMN_TXPDCAL_ITER_TMR}, 3674 {0x0240, CMN_RXCAL_INIT_TMR}, 3675 {0x0005, CMN_RXCAL_ITER_TMR}, 3676 {0x0002, CMN_SD_CAL_INIT_TMR}, 3677 {0x0002, CMN_SD_CAL_ITER_TMR}, 3678 {0x000B, CMN_SD_CAL_REFTIM_START}, 3679 {0x0137, CMN_SD_CAL_PLLCNT_START}, 3680 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0}, 3681 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0}, 3682 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0}, 3683 {0x0004, CMN_PLL0_DSM_DIAG_M0}, 3684 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0}, 3685 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0}, 3686 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0}, 3687 {0x0004, CMN_PLL1_DSM_DIAG_M0}, 3688 {0x00C0, CMN_PLL0_VCOCAL_INIT_TMR}, 3689 {0x0004, CMN_PLL0_VCOCAL_ITER_TMR}, 3690 {0x00C0, CMN_PLL1_VCOCAL_INIT_TMR}, 3691 {0x0004, CMN_PLL1_VCOCAL_ITER_TMR}, 3692 {0x0260, CMN_PLL0_VCOCAL_REFTIM_START}, 3693 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 3694 {0x0260, CMN_PLL1_VCOCAL_REFTIM_START}, 3695 {0x0003, CMN_PLL1_VCOCAL_TCTRL} 3696 }; 3697 3698 static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_tx_ln_regs[] = { 3699 {0x0780, TX_RCVDET_ST_TMR}, 3700 {0x00FB, TX_PSC_A0}, 3701 {0x04AA, TX_PSC_A2}, 3702 {0x04AA, TX_PSC_A3}, 3703 {0x000F, XCVR_DIAG_BIDI_CTRL} 3704 }; 3705 3706 static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_rx_ln_regs[] = { 3707 {0x0000, RX_PSC_A0}, 3708 {0x0000, RX_PSC_A2}, 3709 {0x0000, RX_PSC_A3}, 3710 {0x0000, RX_PSC_CAL}, 3711 {0x0000, RX_REE_GCSM1_CTRL}, 3712 {0x0000, RX_REE_GCSM2_CTRL}, 3713 {0x0000, RX_REE_PERGCSM_CTRL} 3714 }; 3715 3716 static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_cmn_vals = { 3717 .reg_pairs = sl_dp_19_2_no_ssc_cmn_regs, 3718 .num_regs = ARRAY_SIZE(sl_dp_19_2_no_ssc_cmn_regs), 3719 }; 3720 3721 static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_tx_ln_vals = { 3722 .reg_pairs = sl_dp_19_2_no_ssc_tx_ln_regs, 3723 .num_regs = ARRAY_SIZE(sl_dp_19_2_no_ssc_tx_ln_regs), 3724 }; 3725 3726 static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_rx_ln_vals = { 3727 .reg_pairs = sl_dp_19_2_no_ssc_rx_ln_regs, 3728 .num_regs = ARRAY_SIZE(sl_dp_19_2_no_ssc_rx_ln_regs), 3729 }; 3730 3731 /* Single DP, 25 MHz Ref clk, no SSC */ 3732 static const struct cdns_reg_pairs sl_dp_25_no_ssc_cmn_regs[] = { 3733 {0x0019, CMN_SSM_BIAS_TMR}, 3734 {0x0032, CMN_PLLSM0_PLLPRE_TMR}, 3735 {0x00D1, CMN_PLLSM0_PLLLOCK_TMR}, 3736 {0x0032, CMN_PLLSM1_PLLPRE_TMR}, 3737 {0x00D1, CMN_PLLSM1_PLLLOCK_TMR}, 3738 {0x007D, CMN_BGCAL_INIT_TMR}, 3739 {0x007D, CMN_BGCAL_ITER_TMR}, 3740 {0x0019, CMN_IBCAL_INIT_TMR}, 3741 {0x001E, CMN_TXPUCAL_INIT_TMR}, 3742 {0x0006, CMN_TXPUCAL_ITER_TMR}, 3743 {0x001E, CMN_TXPDCAL_INIT_TMR}, 3744 {0x0006, CMN_TXPDCAL_ITER_TMR}, 3745 {0x02EE, CMN_RXCAL_INIT_TMR}, 3746 {0x0006, CMN_RXCAL_ITER_TMR}, 3747 {0x0002, CMN_SD_CAL_INIT_TMR}, 3748 {0x0002, CMN_SD_CAL_ITER_TMR}, 3749 {0x000E, CMN_SD_CAL_REFTIM_START}, 3750 {0x012B, CMN_SD_CAL_PLLCNT_START}, 3751 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0}, 3752 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0}, 3753 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0}, 3754 {0x0004, CMN_PLL0_DSM_DIAG_M0}, 3755 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0}, 3756 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0}, 3757 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0}, 3758 {0x0004, CMN_PLL1_DSM_DIAG_M0}, 3759 {0x00FA, CMN_PLL0_VCOCAL_INIT_TMR}, 3760 {0x0004, CMN_PLL0_VCOCAL_ITER_TMR}, 3761 {0x00FA, CMN_PLL1_VCOCAL_INIT_TMR}, 3762 {0x0004, CMN_PLL1_VCOCAL_ITER_TMR}, 3763 {0x0317, CMN_PLL0_VCOCAL_REFTIM_START}, 3764 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 3765 {0x0317, CMN_PLL1_VCOCAL_REFTIM_START}, 3766 {0x0003, CMN_PLL1_VCOCAL_TCTRL} 3767 }; 3768 3769 static const struct cdns_reg_pairs sl_dp_25_no_ssc_tx_ln_regs[] = { 3770 {0x09C4, TX_RCVDET_ST_TMR}, 3771 {0x00FB, TX_PSC_A0}, 3772 {0x04AA, TX_PSC_A2}, 3773 {0x04AA, TX_PSC_A3}, 3774 {0x000F, XCVR_DIAG_BIDI_CTRL} 3775 }; 3776 3777 static const struct cdns_reg_pairs sl_dp_25_no_ssc_rx_ln_regs[] = { 3778 {0x0000, RX_PSC_A0}, 3779 {0x0000, RX_PSC_A2}, 3780 {0x0000, RX_PSC_A3}, 3781 {0x0000, RX_PSC_CAL}, 3782 {0x0000, RX_REE_GCSM1_CTRL}, 3783 {0x0000, RX_REE_GCSM2_CTRL}, 3784 {0x0000, RX_REE_PERGCSM_CTRL} 3785 }; 3786 3787 static const struct cdns_torrent_vals sl_dp_25_no_ssc_cmn_vals = { 3788 .reg_pairs = sl_dp_25_no_ssc_cmn_regs, 3789 .num_regs = ARRAY_SIZE(sl_dp_25_no_ssc_cmn_regs), 3790 }; 3791 3792 static const struct cdns_torrent_vals sl_dp_25_no_ssc_tx_ln_vals = { 3793 .reg_pairs = sl_dp_25_no_ssc_tx_ln_regs, 3794 .num_regs = ARRAY_SIZE(sl_dp_25_no_ssc_tx_ln_regs), 3795 }; 3796 3797 static const struct cdns_torrent_vals sl_dp_25_no_ssc_rx_ln_vals = { 3798 .reg_pairs = sl_dp_25_no_ssc_rx_ln_regs, 3799 .num_regs = ARRAY_SIZE(sl_dp_25_no_ssc_rx_ln_regs), 3800 }; 3801 3802 /* Single DP, 100 MHz Ref clk, no SSC */ 3803 static const struct cdns_reg_pairs sl_dp_100_no_ssc_cmn_regs[] = { 3804 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 3805 {0x0003, CMN_PLL1_VCOCAL_TCTRL} 3806 }; 3807 3808 static const struct cdns_reg_pairs sl_dp_100_no_ssc_tx_ln_regs[] = { 3809 {0x00FB, TX_PSC_A0}, 3810 {0x04AA, TX_PSC_A2}, 3811 {0x04AA, TX_PSC_A3}, 3812 {0x000F, XCVR_DIAG_BIDI_CTRL} 3813 }; 3814 3815 static const struct cdns_reg_pairs sl_dp_100_no_ssc_rx_ln_regs[] = { 3816 {0x0000, RX_PSC_A0}, 3817 {0x0000, RX_PSC_A2}, 3818 {0x0000, RX_PSC_A3}, 3819 {0x0000, RX_PSC_CAL}, 3820 {0x0000, RX_REE_GCSM1_CTRL}, 3821 {0x0000, RX_REE_GCSM2_CTRL}, 3822 {0x0000, RX_REE_PERGCSM_CTRL} 3823 }; 3824 3825 static const struct cdns_torrent_vals sl_dp_100_no_ssc_cmn_vals = { 3826 .reg_pairs = sl_dp_100_no_ssc_cmn_regs, 3827 .num_regs = ARRAY_SIZE(sl_dp_100_no_ssc_cmn_regs), 3828 }; 3829 3830 static const struct cdns_torrent_vals sl_dp_100_no_ssc_tx_ln_vals = { 3831 .reg_pairs = sl_dp_100_no_ssc_tx_ln_regs, 3832 .num_regs = ARRAY_SIZE(sl_dp_100_no_ssc_tx_ln_regs), 3833 }; 3834 3835 static const struct cdns_torrent_vals sl_dp_100_no_ssc_rx_ln_vals = { 3836 .reg_pairs = sl_dp_100_no_ssc_rx_ln_regs, 3837 .num_regs = ARRAY_SIZE(sl_dp_100_no_ssc_rx_ln_regs), 3838 }; 3839 3840 /* USB and SGMII/QSGMII link configuration */ 3841 static const struct cdns_reg_pairs usb_sgmii_link_cmn_regs[] = { 3842 {0x0002, PHY_PLL_CFG}, 3843 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0}, 3844 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0} 3845 }; 3846 3847 static const struct cdns_reg_pairs usb_sgmii_xcvr_diag_ln_regs[] = { 3848 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3849 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3850 {0x0041, XCVR_DIAG_PLLDRC_CTRL} 3851 }; 3852 3853 static const struct cdns_reg_pairs sgmii_usb_xcvr_diag_ln_regs[] = { 3854 {0x0011, XCVR_DIAG_HSCLK_SEL}, 3855 {0x0003, XCVR_DIAG_HSCLK_DIV}, 3856 {0x009B, XCVR_DIAG_PLLDRC_CTRL} 3857 }; 3858 3859 static const struct cdns_torrent_vals usb_sgmii_link_cmn_vals = { 3860 .reg_pairs = usb_sgmii_link_cmn_regs, 3861 .num_regs = ARRAY_SIZE(usb_sgmii_link_cmn_regs), 3862 }; 3863 3864 static const struct cdns_torrent_vals usb_sgmii_xcvr_diag_ln_vals = { 3865 .reg_pairs = usb_sgmii_xcvr_diag_ln_regs, 3866 .num_regs = ARRAY_SIZE(usb_sgmii_xcvr_diag_ln_regs), 3867 }; 3868 3869 static const struct cdns_torrent_vals sgmii_usb_xcvr_diag_ln_vals = { 3870 .reg_pairs = sgmii_usb_xcvr_diag_ln_regs, 3871 .num_regs = ARRAY_SIZE(sgmii_usb_xcvr_diag_ln_regs), 3872 }; 3873 3874 /* PCIe and USB Unique SSC link configuration */ 3875 static const struct cdns_reg_pairs pcie_usb_link_cmn_regs[] = { 3876 {0x0003, PHY_PLL_CFG}, 3877 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0}, 3878 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1}, 3879 {0x8600, CMN_PDIAG_PLL1_CLK_SEL_M0} 3880 }; 3881 3882 static const struct cdns_reg_pairs pcie_usb_xcvr_diag_ln_regs[] = { 3883 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3884 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3885 {0x0012, XCVR_DIAG_PLLDRC_CTRL} 3886 }; 3887 3888 static const struct cdns_reg_pairs usb_pcie_xcvr_diag_ln_regs[] = { 3889 {0x0011, XCVR_DIAG_HSCLK_SEL}, 3890 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3891 {0x00C9, XCVR_DIAG_PLLDRC_CTRL} 3892 }; 3893 3894 static const struct cdns_torrent_vals pcie_usb_link_cmn_vals = { 3895 .reg_pairs = pcie_usb_link_cmn_regs, 3896 .num_regs = ARRAY_SIZE(pcie_usb_link_cmn_regs), 3897 }; 3898 3899 static const struct cdns_torrent_vals pcie_usb_xcvr_diag_ln_vals = { 3900 .reg_pairs = pcie_usb_xcvr_diag_ln_regs, 3901 .num_regs = ARRAY_SIZE(pcie_usb_xcvr_diag_ln_regs), 3902 }; 3903 3904 static const struct cdns_torrent_vals usb_pcie_xcvr_diag_ln_vals = { 3905 .reg_pairs = usb_pcie_xcvr_diag_ln_regs, 3906 .num_regs = ARRAY_SIZE(usb_pcie_xcvr_diag_ln_regs), 3907 }; 3908 3909 /* USB 100 MHz Ref clk, internal SSC */ 3910 static const struct cdns_reg_pairs usb_100_int_ssc_cmn_regs[] = { 3911 {0x0004, CMN_PLL0_DSM_DIAG_M0}, 3912 {0x0004, CMN_PLL0_DSM_DIAG_M1}, 3913 {0x0004, CMN_PLL1_DSM_DIAG_M0}, 3914 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0}, 3915 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1}, 3916 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0}, 3917 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0}, 3918 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1}, 3919 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0}, 3920 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0}, 3921 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1}, 3922 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0}, 3923 {0x0064, CMN_PLL0_INTDIV_M0}, 3924 {0x0050, CMN_PLL0_INTDIV_M1}, 3925 {0x0064, CMN_PLL1_INTDIV_M0}, 3926 {0x0002, CMN_PLL0_FRACDIVH_M0}, 3927 {0x0002, CMN_PLL0_FRACDIVH_M1}, 3928 {0x0002, CMN_PLL1_FRACDIVH_M0}, 3929 {0x0044, CMN_PLL0_HIGH_THR_M0}, 3930 {0x0036, CMN_PLL0_HIGH_THR_M1}, 3931 {0x0044, CMN_PLL1_HIGH_THR_M0}, 3932 {0x0002, CMN_PDIAG_PLL0_CTRL_M0}, 3933 {0x0002, CMN_PDIAG_PLL0_CTRL_M1}, 3934 {0x0002, CMN_PDIAG_PLL1_CTRL_M0}, 3935 {0x0001, CMN_PLL0_SS_CTRL1_M0}, 3936 {0x0001, CMN_PLL0_SS_CTRL1_M1}, 3937 {0x0001, CMN_PLL1_SS_CTRL1_M0}, 3938 {0x011B, CMN_PLL0_SS_CTRL2_M0}, 3939 {0x011B, CMN_PLL0_SS_CTRL2_M1}, 3940 {0x011B, CMN_PLL1_SS_CTRL2_M0}, 3941 {0x006E, CMN_PLL0_SS_CTRL3_M0}, 3942 {0x0058, CMN_PLL0_SS_CTRL3_M1}, 3943 {0x006E, CMN_PLL1_SS_CTRL3_M0}, 3944 {0x000E, CMN_PLL0_SS_CTRL4_M0}, 3945 {0x0012, CMN_PLL0_SS_CTRL4_M1}, 3946 {0x000E, CMN_PLL1_SS_CTRL4_M0}, 3947 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START}, 3948 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START}, 3949 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START}, 3950 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START}, 3951 {0x00C7, CMN_PLL0_LOCK_REFCNT_START}, 3952 {0x00C7, CMN_PLL1_LOCK_REFCNT_START}, 3953 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START}, 3954 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START}, 3955 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR}, 3956 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}, 3957 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD}, 3958 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD}, 3959 {0x007F, CMN_TXPUCAL_TUNE}, 3960 {0x007F, CMN_TXPDCAL_TUNE} 3961 }; 3962 3963 static const struct cdns_torrent_vals usb_100_int_ssc_cmn_vals = { 3964 .reg_pairs = usb_100_int_ssc_cmn_regs, 3965 .num_regs = ARRAY_SIZE(usb_100_int_ssc_cmn_regs), 3966 }; 3967 3968 /* Single USB link configuration */ 3969 static const struct cdns_reg_pairs sl_usb_link_cmn_regs[] = { 3970 {0x0000, PHY_PLL_CFG}, 3971 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0} 3972 }; 3973 3974 static const struct cdns_reg_pairs sl_usb_xcvr_diag_ln_regs[] = { 3975 {0x0000, XCVR_DIAG_HSCLK_SEL}, 3976 {0x0001, XCVR_DIAG_HSCLK_DIV}, 3977 {0x0041, XCVR_DIAG_PLLDRC_CTRL} 3978 }; 3979 3980 static const struct cdns_torrent_vals sl_usb_link_cmn_vals = { 3981 .reg_pairs = sl_usb_link_cmn_regs, 3982 .num_regs = ARRAY_SIZE(sl_usb_link_cmn_regs), 3983 }; 3984 3985 static const struct cdns_torrent_vals sl_usb_xcvr_diag_ln_vals = { 3986 .reg_pairs = sl_usb_xcvr_diag_ln_regs, 3987 .num_regs = ARRAY_SIZE(sl_usb_xcvr_diag_ln_regs), 3988 }; 3989 3990 /* USB PHY PCS common configuration */ 3991 static const struct cdns_reg_pairs usb_phy_pcs_cmn_regs[] = { 3992 {0x0A0A, PHY_PIPE_USB3_GEN2_PRE_CFG0}, 3993 {0x1000, PHY_PIPE_USB3_GEN2_POST_CFG0}, 3994 {0x0010, PHY_PIPE_USB3_GEN2_POST_CFG1} 3995 }; 3996 3997 static const struct cdns_torrent_vals usb_phy_pcs_cmn_vals = { 3998 .reg_pairs = usb_phy_pcs_cmn_regs, 3999 .num_regs = ARRAY_SIZE(usb_phy_pcs_cmn_regs), 4000 }; 4001 4002 /* USB 100 MHz Ref clk, no SSC */ 4003 static const struct cdns_reg_pairs sl_usb_100_no_ssc_cmn_regs[] = { 4004 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4005 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0}, 4006 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0}, 4007 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 4008 {0x0003, CMN_PLL1_VCOCAL_TCTRL}, 4009 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD}, 4010 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD} 4011 }; 4012 4013 static const struct cdns_torrent_vals sl_usb_100_no_ssc_cmn_vals = { 4014 .reg_pairs = sl_usb_100_no_ssc_cmn_regs, 4015 .num_regs = ARRAY_SIZE(sl_usb_100_no_ssc_cmn_regs), 4016 }; 4017 4018 static const struct cdns_reg_pairs usb_100_no_ssc_cmn_regs[] = { 4019 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD}, 4020 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD}, 4021 {0x007F, CMN_TXPUCAL_TUNE}, 4022 {0x007F, CMN_TXPDCAL_TUNE} 4023 }; 4024 4025 static const struct cdns_reg_pairs usb_100_no_ssc_tx_ln_regs[] = { 4026 {0x02FF, TX_PSC_A0}, 4027 {0x06AF, TX_PSC_A1}, 4028 {0x06AE, TX_PSC_A2}, 4029 {0x06AE, TX_PSC_A3}, 4030 {0x2A82, TX_TXCC_CTRL}, 4031 {0x0014, TX_TXCC_CPOST_MULT_01}, 4032 {0x0003, XCVR_DIAG_PSC_OVRD} 4033 }; 4034 4035 static const struct cdns_reg_pairs usb_100_no_ssc_rx_ln_regs[] = { 4036 {0x0D1D, RX_PSC_A0}, 4037 {0x0D1D, RX_PSC_A1}, 4038 {0x0D00, RX_PSC_A2}, 4039 {0x0500, RX_PSC_A3}, 4040 {0x0013, RX_SIGDET_HL_FILT_TMR}, 4041 {0x0000, RX_REE_GCSM1_CTRL}, 4042 {0x0C02, RX_REE_ATTEN_THR}, 4043 {0x0330, RX_REE_SMGM_CTRL1}, 4044 {0x0300, RX_REE_SMGM_CTRL2}, 4045 {0x0019, RX_REE_TAP1_CLIP}, 4046 {0x0019, RX_REE_TAP2TON_CLIP}, 4047 {0x1004, RX_DIAG_SIGDET_TUNE}, 4048 {0x00F9, RX_DIAG_NQST_CTRL}, 4049 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2}, 4050 {0x0002, RX_DIAG_DFE_AMP_TUNE_3}, 4051 {0x0000, RX_DIAG_PI_CAP}, 4052 {0x0031, RX_DIAG_PI_RATE}, 4053 {0x0001, RX_DIAG_ACYA}, 4054 {0x018C, RX_CDRLF_CNFG}, 4055 {0x0003, RX_CDRLF_CNFG3} 4056 }; 4057 4058 static const struct cdns_torrent_vals usb_100_no_ssc_cmn_vals = { 4059 .reg_pairs = usb_100_no_ssc_cmn_regs, 4060 .num_regs = ARRAY_SIZE(usb_100_no_ssc_cmn_regs), 4061 }; 4062 4063 static const struct cdns_torrent_vals usb_100_no_ssc_tx_ln_vals = { 4064 .reg_pairs = usb_100_no_ssc_tx_ln_regs, 4065 .num_regs = ARRAY_SIZE(usb_100_no_ssc_tx_ln_regs), 4066 }; 4067 4068 static const struct cdns_torrent_vals usb_100_no_ssc_rx_ln_vals = { 4069 .reg_pairs = usb_100_no_ssc_rx_ln_regs, 4070 .num_regs = ARRAY_SIZE(usb_100_no_ssc_rx_ln_regs), 4071 }; 4072 4073 /* Single link USB, 100 MHz Ref clk, internal SSC */ 4074 static const struct cdns_reg_pairs sl_usb_100_int_ssc_cmn_regs[] = { 4075 {0x0004, CMN_PLL0_DSM_DIAG_M0}, 4076 {0x0004, CMN_PLL1_DSM_DIAG_M0}, 4077 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0}, 4078 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4079 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0}, 4080 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0}, 4081 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0}, 4082 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0}, 4083 {0x0064, CMN_PLL0_INTDIV_M0}, 4084 {0x0064, CMN_PLL1_INTDIV_M0}, 4085 {0x0002, CMN_PLL0_FRACDIVH_M0}, 4086 {0x0002, CMN_PLL1_FRACDIVH_M0}, 4087 {0x0044, CMN_PLL0_HIGH_THR_M0}, 4088 {0x0044, CMN_PLL1_HIGH_THR_M0}, 4089 {0x0002, CMN_PDIAG_PLL0_CTRL_M0}, 4090 {0x0002, CMN_PDIAG_PLL1_CTRL_M0}, 4091 {0x0001, CMN_PLL0_SS_CTRL1_M0}, 4092 {0x0001, CMN_PLL1_SS_CTRL1_M0}, 4093 {0x011B, CMN_PLL0_SS_CTRL2_M0}, 4094 {0x011B, CMN_PLL1_SS_CTRL2_M0}, 4095 {0x006E, CMN_PLL0_SS_CTRL3_M0}, 4096 {0x006E, CMN_PLL1_SS_CTRL3_M0}, 4097 {0x000E, CMN_PLL0_SS_CTRL4_M0}, 4098 {0x000E, CMN_PLL1_SS_CTRL4_M0}, 4099 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START}, 4100 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START}, 4101 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START}, 4102 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START}, 4103 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 4104 {0x0003, CMN_PLL1_VCOCAL_TCTRL}, 4105 {0x00C7, CMN_PLL0_LOCK_REFCNT_START}, 4106 {0x00C7, CMN_PLL1_LOCK_REFCNT_START}, 4107 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START}, 4108 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START}, 4109 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR}, 4110 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}, 4111 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD}, 4112 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD} 4113 }; 4114 4115 static const struct cdns_torrent_vals sl_usb_100_int_ssc_cmn_vals = { 4116 .reg_pairs = sl_usb_100_int_ssc_cmn_regs, 4117 .num_regs = ARRAY_SIZE(sl_usb_100_int_ssc_cmn_regs), 4118 }; 4119 4120 /* PCIe and SGMII/QSGMII Unique SSC link configuration */ 4121 static const struct cdns_reg_pairs pcie_sgmii_link_cmn_regs[] = { 4122 {0x0003, PHY_PLL_CFG}, 4123 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0}, 4124 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1}, 4125 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0} 4126 }; 4127 4128 static const struct cdns_reg_pairs pcie_sgmii_xcvr_diag_ln_regs[] = { 4129 {0x0000, XCVR_DIAG_HSCLK_SEL}, 4130 {0x0001, XCVR_DIAG_HSCLK_DIV}, 4131 {0x0012, XCVR_DIAG_PLLDRC_CTRL} 4132 }; 4133 4134 static const struct cdns_reg_pairs sgmii_pcie_xcvr_diag_ln_regs[] = { 4135 {0x0011, XCVR_DIAG_HSCLK_SEL}, 4136 {0x0003, XCVR_DIAG_HSCLK_DIV}, 4137 {0x009B, XCVR_DIAG_PLLDRC_CTRL} 4138 }; 4139 4140 static const struct cdns_torrent_vals pcie_sgmii_link_cmn_vals = { 4141 .reg_pairs = pcie_sgmii_link_cmn_regs, 4142 .num_regs = ARRAY_SIZE(pcie_sgmii_link_cmn_regs), 4143 }; 4144 4145 static const struct cdns_torrent_vals pcie_sgmii_xcvr_diag_ln_vals = { 4146 .reg_pairs = pcie_sgmii_xcvr_diag_ln_regs, 4147 .num_regs = ARRAY_SIZE(pcie_sgmii_xcvr_diag_ln_regs), 4148 }; 4149 4150 static const struct cdns_torrent_vals sgmii_pcie_xcvr_diag_ln_vals = { 4151 .reg_pairs = sgmii_pcie_xcvr_diag_ln_regs, 4152 .num_regs = ARRAY_SIZE(sgmii_pcie_xcvr_diag_ln_regs), 4153 }; 4154 4155 /* SGMII 100 MHz Ref clk, no SSC */ 4156 static const struct cdns_reg_pairs sl_sgmii_100_no_ssc_cmn_regs[] = { 4157 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4158 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0}, 4159 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0}, 4160 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 4161 {0x0003, CMN_PLL1_VCOCAL_TCTRL} 4162 }; 4163 4164 static const struct cdns_torrent_vals sl_sgmii_100_no_ssc_cmn_vals = { 4165 .reg_pairs = sl_sgmii_100_no_ssc_cmn_regs, 4166 .num_regs = ARRAY_SIZE(sl_sgmii_100_no_ssc_cmn_regs), 4167 }; 4168 4169 static const struct cdns_reg_pairs sgmii_100_no_ssc_cmn_regs[] = { 4170 {0x007F, CMN_TXPUCAL_TUNE}, 4171 {0x007F, CMN_TXPDCAL_TUNE} 4172 }; 4173 4174 static const struct cdns_reg_pairs sgmii_100_no_ssc_tx_ln_regs[] = { 4175 {0x00F3, TX_PSC_A0}, 4176 {0x04A2, TX_PSC_A2}, 4177 {0x04A2, TX_PSC_A3}, 4178 {0x0000, TX_TXCC_CPOST_MULT_00}, 4179 {0x00B3, DRV_DIAG_TX_DRV}, 4180 {0x0002, XCVR_DIAG_PSC_OVRD} 4181 }; 4182 4183 static const struct cdns_reg_pairs ti_sgmii_100_no_ssc_tx_ln_regs[] = { 4184 {0x00F3, TX_PSC_A0}, 4185 {0x04A2, TX_PSC_A2}, 4186 {0x04A2, TX_PSC_A3}, 4187 {0x0000, TX_TXCC_CPOST_MULT_00}, 4188 {0x00B3, DRV_DIAG_TX_DRV}, 4189 {0x0002, XCVR_DIAG_PSC_OVRD}, 4190 {0x4000, XCVR_DIAG_RXCLK_CTRL} 4191 }; 4192 4193 static const struct cdns_reg_pairs sgmii_100_no_ssc_rx_ln_regs[] = { 4194 {0x091D, RX_PSC_A0}, 4195 {0x0900, RX_PSC_A2}, 4196 {0x0100, RX_PSC_A3}, 4197 {0x03C7, RX_REE_GCSM1_EQENM_PH1}, 4198 {0x01C7, RX_REE_GCSM1_EQENM_PH2}, 4199 {0x0000, RX_DIAG_DFE_CTRL}, 4200 {0x0019, RX_REE_TAP1_CLIP}, 4201 {0x0019, RX_REE_TAP2TON_CLIP}, 4202 {0x0098, RX_DIAG_NQST_CTRL}, 4203 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2}, 4204 {0x0000, RX_DIAG_DFE_AMP_TUNE_3}, 4205 {0x0000, RX_DIAG_PI_CAP}, 4206 {0x0010, RX_DIAG_PI_RATE}, 4207 {0x0001, RX_DIAG_ACYA}, 4208 {0x018C, RX_CDRLF_CNFG}, 4209 }; 4210 4211 static const struct cdns_torrent_vals sgmii_100_no_ssc_cmn_vals = { 4212 .reg_pairs = sgmii_100_no_ssc_cmn_regs, 4213 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_cmn_regs), 4214 }; 4215 4216 static const struct cdns_torrent_vals sgmii_100_no_ssc_tx_ln_vals = { 4217 .reg_pairs = sgmii_100_no_ssc_tx_ln_regs, 4218 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_tx_ln_regs), 4219 }; 4220 4221 static const struct cdns_torrent_vals ti_sgmii_100_no_ssc_tx_ln_vals = { 4222 .reg_pairs = ti_sgmii_100_no_ssc_tx_ln_regs, 4223 .num_regs = ARRAY_SIZE(ti_sgmii_100_no_ssc_tx_ln_regs), 4224 }; 4225 4226 static const struct cdns_torrent_vals sgmii_100_no_ssc_rx_ln_vals = { 4227 .reg_pairs = sgmii_100_no_ssc_rx_ln_regs, 4228 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_rx_ln_regs), 4229 }; 4230 4231 /* TI J7200, multilink SGMII */ 4232 static const struct cdns_reg_pairs j7200_sgmii_100_no_ssc_tx_ln_regs[] = { 4233 {0x07A2, TX_RCVDET_ST_TMR}, 4234 {0x00F3, TX_PSC_A0}, 4235 {0x04A2, TX_PSC_A2}, 4236 {0x04A2, TX_PSC_A3 }, 4237 {0x0000, TX_TXCC_CPOST_MULT_00}, 4238 {0x00B3, DRV_DIAG_TX_DRV}, 4239 {0x0002, XCVR_DIAG_PSC_OVRD}, 4240 {0x4000, XCVR_DIAG_RXCLK_CTRL} 4241 }; 4242 4243 static const struct cdns_torrent_vals j7200_sgmii_100_no_ssc_tx_ln_vals = { 4244 .reg_pairs = j7200_sgmii_100_no_ssc_tx_ln_regs, 4245 .num_regs = ARRAY_SIZE(j7200_sgmii_100_no_ssc_tx_ln_regs), 4246 }; 4247 4248 static const struct cdns_reg_pairs j7200_sgmii_100_no_ssc_rx_ln_regs[] = { 4249 {0x0014, RX_SDCAL0_INIT_TMR}, 4250 {0x0062, RX_SDCAL0_ITER_TMR}, 4251 {0x0014, RX_SDCAL1_INIT_TMR}, 4252 {0x0062, RX_SDCAL1_ITER_TMR}, 4253 {0x091D, RX_PSC_A0}, 4254 {0x0900, RX_PSC_A2}, 4255 {0x0100, RX_PSC_A3}, 4256 {0x03C7, RX_REE_GCSM1_EQENM_PH1}, 4257 {0x01C7, RX_REE_GCSM1_EQENM_PH2}, 4258 {0x0000, RX_DIAG_DFE_CTRL}, 4259 {0x0019, RX_REE_TAP1_CLIP}, 4260 {0x0019, RX_REE_TAP2TON_CLIP}, 4261 {0x0098, RX_DIAG_NQST_CTRL}, 4262 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2}, 4263 {0x0000, RX_DIAG_DFE_AMP_TUNE_3}, 4264 {0x0000, RX_DIAG_PI_CAP}, 4265 {0x0010, RX_DIAG_PI_RATE}, 4266 {0x0001, RX_DIAG_ACYA}, 4267 {0x018C, RX_CDRLF_CNFG} 4268 }; 4269 4270 static const struct cdns_torrent_vals j7200_sgmii_100_no_ssc_rx_ln_vals = { 4271 .reg_pairs = j7200_sgmii_100_no_ssc_rx_ln_regs, 4272 .num_regs = ARRAY_SIZE(j7200_sgmii_100_no_ssc_rx_ln_regs), 4273 }; 4274 4275 /* SGMII 100 MHz Ref clk, internal SSC */ 4276 static const struct cdns_reg_pairs sgmii_100_int_ssc_cmn_regs[] = { 4277 {0x0004, CMN_PLL0_DSM_DIAG_M0}, 4278 {0x0004, CMN_PLL0_DSM_DIAG_M1}, 4279 {0x0004, CMN_PLL1_DSM_DIAG_M0}, 4280 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0}, 4281 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1}, 4282 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4283 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0}, 4284 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1}, 4285 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0}, 4286 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0}, 4287 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1}, 4288 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0}, 4289 {0x0064, CMN_PLL0_INTDIV_M0}, 4290 {0x0050, CMN_PLL0_INTDIV_M1}, 4291 {0x0064, CMN_PLL1_INTDIV_M0}, 4292 {0x0002, CMN_PLL0_FRACDIVH_M0}, 4293 {0x0002, CMN_PLL0_FRACDIVH_M1}, 4294 {0x0002, CMN_PLL1_FRACDIVH_M0}, 4295 {0x0044, CMN_PLL0_HIGH_THR_M0}, 4296 {0x0036, CMN_PLL0_HIGH_THR_M1}, 4297 {0x0044, CMN_PLL1_HIGH_THR_M0}, 4298 {0x0002, CMN_PDIAG_PLL0_CTRL_M0}, 4299 {0x0002, CMN_PDIAG_PLL0_CTRL_M1}, 4300 {0x0002, CMN_PDIAG_PLL1_CTRL_M0}, 4301 {0x0001, CMN_PLL0_SS_CTRL1_M0}, 4302 {0x0001, CMN_PLL0_SS_CTRL1_M1}, 4303 {0x0001, CMN_PLL1_SS_CTRL1_M0}, 4304 {0x011B, CMN_PLL0_SS_CTRL2_M0}, 4305 {0x011B, CMN_PLL0_SS_CTRL2_M1}, 4306 {0x011B, CMN_PLL1_SS_CTRL2_M0}, 4307 {0x006E, CMN_PLL0_SS_CTRL3_M0}, 4308 {0x0058, CMN_PLL0_SS_CTRL3_M1}, 4309 {0x006E, CMN_PLL1_SS_CTRL3_M0}, 4310 {0x000E, CMN_PLL0_SS_CTRL4_M0}, 4311 {0x0012, CMN_PLL0_SS_CTRL4_M1}, 4312 {0x000E, CMN_PLL1_SS_CTRL4_M0}, 4313 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START}, 4314 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START}, 4315 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START}, 4316 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START}, 4317 {0x00C7, CMN_PLL0_LOCK_REFCNT_START}, 4318 {0x00C7, CMN_PLL1_LOCK_REFCNT_START}, 4319 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START}, 4320 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START}, 4321 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR}, 4322 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}, 4323 {0x007F, CMN_TXPUCAL_TUNE}, 4324 {0x007F, CMN_TXPDCAL_TUNE} 4325 }; 4326 4327 static const struct cdns_torrent_vals sgmii_100_int_ssc_cmn_vals = { 4328 .reg_pairs = sgmii_100_int_ssc_cmn_regs, 4329 .num_regs = ARRAY_SIZE(sgmii_100_int_ssc_cmn_regs), 4330 }; 4331 4332 /* QSGMII 100 MHz Ref clk, no SSC */ 4333 static const struct cdns_reg_pairs sl_qsgmii_100_no_ssc_cmn_regs[] = { 4334 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4335 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0}, 4336 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0}, 4337 {0x0003, CMN_PLL0_VCOCAL_TCTRL}, 4338 {0x0003, CMN_PLL1_VCOCAL_TCTRL} 4339 }; 4340 4341 static const struct cdns_torrent_vals sl_qsgmii_100_no_ssc_cmn_vals = { 4342 .reg_pairs = sl_qsgmii_100_no_ssc_cmn_regs, 4343 .num_regs = ARRAY_SIZE(sl_qsgmii_100_no_ssc_cmn_regs), 4344 }; 4345 4346 static const struct cdns_reg_pairs qsgmii_100_no_ssc_cmn_regs[] = { 4347 {0x007F, CMN_TXPUCAL_TUNE}, 4348 {0x007F, CMN_TXPDCAL_TUNE} 4349 }; 4350 4351 static const struct cdns_reg_pairs qsgmii_100_no_ssc_tx_ln_regs[] = { 4352 {0x00F3, TX_PSC_A0}, 4353 {0x04A2, TX_PSC_A2}, 4354 {0x04A2, TX_PSC_A3}, 4355 {0x0000, TX_TXCC_CPOST_MULT_00}, 4356 {0x0011, TX_TXCC_MGNFS_MULT_100}, 4357 {0x0003, DRV_DIAG_TX_DRV}, 4358 {0x0002, XCVR_DIAG_PSC_OVRD} 4359 }; 4360 4361 static const struct cdns_reg_pairs ti_qsgmii_100_no_ssc_tx_ln_regs[] = { 4362 {0x00F3, TX_PSC_A0}, 4363 {0x04A2, TX_PSC_A2}, 4364 {0x04A2, TX_PSC_A3}, 4365 {0x0000, TX_TXCC_CPOST_MULT_00}, 4366 {0x0011, TX_TXCC_MGNFS_MULT_100}, 4367 {0x0003, DRV_DIAG_TX_DRV}, 4368 {0x0002, XCVR_DIAG_PSC_OVRD}, 4369 {0x4000, XCVR_DIAG_RXCLK_CTRL} 4370 }; 4371 4372 static const struct cdns_reg_pairs qsgmii_100_no_ssc_rx_ln_regs[] = { 4373 {0x091D, RX_PSC_A0}, 4374 {0x0900, RX_PSC_A2}, 4375 {0x0100, RX_PSC_A3}, 4376 {0x03C7, RX_REE_GCSM1_EQENM_PH1}, 4377 {0x01C7, RX_REE_GCSM1_EQENM_PH2}, 4378 {0x0000, RX_DIAG_DFE_CTRL}, 4379 {0x0019, RX_REE_TAP1_CLIP}, 4380 {0x0019, RX_REE_TAP2TON_CLIP}, 4381 {0x0098, RX_DIAG_NQST_CTRL}, 4382 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2}, 4383 {0x0000, RX_DIAG_DFE_AMP_TUNE_3}, 4384 {0x0000, RX_DIAG_PI_CAP}, 4385 {0x0010, RX_DIAG_PI_RATE}, 4386 {0x0001, RX_DIAG_ACYA}, 4387 {0x018C, RX_CDRLF_CNFG}, 4388 }; 4389 4390 static const struct cdns_torrent_vals qsgmii_100_no_ssc_cmn_vals = { 4391 .reg_pairs = qsgmii_100_no_ssc_cmn_regs, 4392 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_cmn_regs), 4393 }; 4394 4395 static const struct cdns_torrent_vals qsgmii_100_no_ssc_tx_ln_vals = { 4396 .reg_pairs = qsgmii_100_no_ssc_tx_ln_regs, 4397 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_tx_ln_regs), 4398 }; 4399 4400 static const struct cdns_torrent_vals ti_qsgmii_100_no_ssc_tx_ln_vals = { 4401 .reg_pairs = ti_qsgmii_100_no_ssc_tx_ln_regs, 4402 .num_regs = ARRAY_SIZE(ti_qsgmii_100_no_ssc_tx_ln_regs), 4403 }; 4404 4405 static const struct cdns_torrent_vals qsgmii_100_no_ssc_rx_ln_vals = { 4406 .reg_pairs = qsgmii_100_no_ssc_rx_ln_regs, 4407 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_rx_ln_regs), 4408 }; 4409 4410 /* TI J7200, multilink QSGMII */ 4411 static const struct cdns_reg_pairs j7200_qsgmii_100_no_ssc_tx_ln_regs[] = { 4412 {0x07A2, TX_RCVDET_ST_TMR}, 4413 {0x00F3, TX_PSC_A0}, 4414 {0x04A2, TX_PSC_A2}, 4415 {0x04A2, TX_PSC_A3 }, 4416 {0x0000, TX_TXCC_CPOST_MULT_00}, 4417 {0x0011, TX_TXCC_MGNFS_MULT_100}, 4418 {0x0003, DRV_DIAG_TX_DRV}, 4419 {0x0002, XCVR_DIAG_PSC_OVRD}, 4420 {0x4000, XCVR_DIAG_RXCLK_CTRL} 4421 }; 4422 4423 static const struct cdns_torrent_vals j7200_qsgmii_100_no_ssc_tx_ln_vals = { 4424 .reg_pairs = j7200_qsgmii_100_no_ssc_tx_ln_regs, 4425 .num_regs = ARRAY_SIZE(j7200_qsgmii_100_no_ssc_tx_ln_regs), 4426 }; 4427 4428 static const struct cdns_reg_pairs j7200_qsgmii_100_no_ssc_rx_ln_regs[] = { 4429 {0x0014, RX_SDCAL0_INIT_TMR}, 4430 {0x0062, RX_SDCAL0_ITER_TMR}, 4431 {0x0014, RX_SDCAL1_INIT_TMR}, 4432 {0x0062, RX_SDCAL1_ITER_TMR}, 4433 {0x091D, RX_PSC_A0}, 4434 {0x0900, RX_PSC_A2}, 4435 {0x0100, RX_PSC_A3}, 4436 {0x03C7, RX_REE_GCSM1_EQENM_PH1}, 4437 {0x01C7, RX_REE_GCSM1_EQENM_PH2}, 4438 {0x0000, RX_DIAG_DFE_CTRL}, 4439 {0x0019, RX_REE_TAP1_CLIP}, 4440 {0x0019, RX_REE_TAP2TON_CLIP}, 4441 {0x0098, RX_DIAG_NQST_CTRL}, 4442 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2}, 4443 {0x0000, RX_DIAG_DFE_AMP_TUNE_3}, 4444 {0x0000, RX_DIAG_PI_CAP}, 4445 {0x0010, RX_DIAG_PI_RATE}, 4446 {0x0001, RX_DIAG_ACYA}, 4447 {0x018C, RX_CDRLF_CNFG} 4448 }; 4449 4450 static const struct cdns_torrent_vals j7200_qsgmii_100_no_ssc_rx_ln_vals = { 4451 .reg_pairs = j7200_qsgmii_100_no_ssc_rx_ln_regs, 4452 .num_regs = ARRAY_SIZE(j7200_qsgmii_100_no_ssc_rx_ln_regs), 4453 }; 4454 4455 /* QSGMII 100 MHz Ref clk, internal SSC */ 4456 static const struct cdns_reg_pairs qsgmii_100_int_ssc_cmn_regs[] = { 4457 {0x0004, CMN_PLL0_DSM_DIAG_M0}, 4458 {0x0004, CMN_PLL0_DSM_DIAG_M1}, 4459 {0x0004, CMN_PLL1_DSM_DIAG_M0}, 4460 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0}, 4461 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1}, 4462 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4463 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0}, 4464 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1}, 4465 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0}, 4466 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0}, 4467 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1}, 4468 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0}, 4469 {0x0064, CMN_PLL0_INTDIV_M0}, 4470 {0x0050, CMN_PLL0_INTDIV_M1}, 4471 {0x0064, CMN_PLL1_INTDIV_M0}, 4472 {0x0002, CMN_PLL0_FRACDIVH_M0}, 4473 {0x0002, CMN_PLL0_FRACDIVH_M1}, 4474 {0x0002, CMN_PLL1_FRACDIVH_M0}, 4475 {0x0044, CMN_PLL0_HIGH_THR_M0}, 4476 {0x0036, CMN_PLL0_HIGH_THR_M1}, 4477 {0x0044, CMN_PLL1_HIGH_THR_M0}, 4478 {0x0002, CMN_PDIAG_PLL0_CTRL_M0}, 4479 {0x0002, CMN_PDIAG_PLL0_CTRL_M1}, 4480 {0x0002, CMN_PDIAG_PLL1_CTRL_M0}, 4481 {0x0001, CMN_PLL0_SS_CTRL1_M0}, 4482 {0x0001, CMN_PLL0_SS_CTRL1_M1}, 4483 {0x0001, CMN_PLL1_SS_CTRL1_M0}, 4484 {0x011B, CMN_PLL0_SS_CTRL2_M0}, 4485 {0x011B, CMN_PLL0_SS_CTRL2_M1}, 4486 {0x011B, CMN_PLL1_SS_CTRL2_M0}, 4487 {0x006E, CMN_PLL0_SS_CTRL3_M0}, 4488 {0x0058, CMN_PLL0_SS_CTRL3_M1}, 4489 {0x006E, CMN_PLL1_SS_CTRL3_M0}, 4490 {0x000E, CMN_PLL0_SS_CTRL4_M0}, 4491 {0x0012, CMN_PLL0_SS_CTRL4_M1}, 4492 {0x000E, CMN_PLL1_SS_CTRL4_M0}, 4493 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START}, 4494 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START}, 4495 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START}, 4496 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START}, 4497 {0x00C7, CMN_PLL0_LOCK_REFCNT_START}, 4498 {0x00C7, CMN_PLL1_LOCK_REFCNT_START}, 4499 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START}, 4500 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START}, 4501 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR}, 4502 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}, 4503 {0x007F, CMN_TXPUCAL_TUNE}, 4504 {0x007F, CMN_TXPDCAL_TUNE} 4505 }; 4506 4507 static const struct cdns_torrent_vals qsgmii_100_int_ssc_cmn_vals = { 4508 .reg_pairs = qsgmii_100_int_ssc_cmn_regs, 4509 .num_regs = ARRAY_SIZE(qsgmii_100_int_ssc_cmn_regs), 4510 }; 4511 4512 /* Single SGMII/QSGMII link configuration */ 4513 static const struct cdns_reg_pairs sl_sgmii_link_cmn_regs[] = { 4514 {0x0000, PHY_PLL_CFG}, 4515 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0} 4516 }; 4517 4518 static const struct cdns_reg_pairs sl_sgmii_xcvr_diag_ln_regs[] = { 4519 {0x0000, XCVR_DIAG_HSCLK_SEL}, 4520 {0x0003, XCVR_DIAG_HSCLK_DIV}, 4521 {0x0013, XCVR_DIAG_PLLDRC_CTRL} 4522 }; 4523 4524 static const struct cdns_torrent_vals sl_sgmii_link_cmn_vals = { 4525 .reg_pairs = sl_sgmii_link_cmn_regs, 4526 .num_regs = ARRAY_SIZE(sl_sgmii_link_cmn_regs), 4527 }; 4528 4529 static const struct cdns_torrent_vals sl_sgmii_xcvr_diag_ln_vals = { 4530 .reg_pairs = sl_sgmii_xcvr_diag_ln_regs, 4531 .num_regs = ARRAY_SIZE(sl_sgmii_xcvr_diag_ln_regs), 4532 }; 4533 4534 /* Multi link PCIe, 100 MHz Ref clk, internal SSC */ 4535 static const struct cdns_reg_pairs pcie_100_int_ssc_cmn_regs[] = { 4536 {0x0004, CMN_PLL0_DSM_DIAG_M0}, 4537 {0x0004, CMN_PLL0_DSM_DIAG_M1}, 4538 {0x0004, CMN_PLL1_DSM_DIAG_M0}, 4539 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0}, 4540 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1}, 4541 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4542 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0}, 4543 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1}, 4544 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0}, 4545 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0}, 4546 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1}, 4547 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0}, 4548 {0x0064, CMN_PLL0_INTDIV_M0}, 4549 {0x0050, CMN_PLL0_INTDIV_M1}, 4550 {0x0064, CMN_PLL1_INTDIV_M0}, 4551 {0x0002, CMN_PLL0_FRACDIVH_M0}, 4552 {0x0002, CMN_PLL0_FRACDIVH_M1}, 4553 {0x0002, CMN_PLL1_FRACDIVH_M0}, 4554 {0x0044, CMN_PLL0_HIGH_THR_M0}, 4555 {0x0036, CMN_PLL0_HIGH_THR_M1}, 4556 {0x0044, CMN_PLL1_HIGH_THR_M0}, 4557 {0x0002, CMN_PDIAG_PLL0_CTRL_M0}, 4558 {0x0002, CMN_PDIAG_PLL0_CTRL_M1}, 4559 {0x0002, CMN_PDIAG_PLL1_CTRL_M0}, 4560 {0x0001, CMN_PLL0_SS_CTRL1_M0}, 4561 {0x0001, CMN_PLL0_SS_CTRL1_M1}, 4562 {0x0001, CMN_PLL1_SS_CTRL1_M0}, 4563 {0x011B, CMN_PLL0_SS_CTRL2_M0}, 4564 {0x011B, CMN_PLL0_SS_CTRL2_M1}, 4565 {0x011B, CMN_PLL1_SS_CTRL2_M0}, 4566 {0x006E, CMN_PLL0_SS_CTRL3_M0}, 4567 {0x0058, CMN_PLL0_SS_CTRL3_M1}, 4568 {0x006E, CMN_PLL1_SS_CTRL3_M0}, 4569 {0x000E, CMN_PLL0_SS_CTRL4_M0}, 4570 {0x0012, CMN_PLL0_SS_CTRL4_M1}, 4571 {0x000E, CMN_PLL1_SS_CTRL4_M0}, 4572 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START}, 4573 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START}, 4574 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START}, 4575 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START}, 4576 {0x00C7, CMN_PLL0_LOCK_REFCNT_START}, 4577 {0x00C7, CMN_PLL1_LOCK_REFCNT_START}, 4578 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START}, 4579 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START}, 4580 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR}, 4581 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR} 4582 }; 4583 4584 static const struct cdns_torrent_vals pcie_100_int_ssc_cmn_vals = { 4585 .reg_pairs = pcie_100_int_ssc_cmn_regs, 4586 .num_regs = ARRAY_SIZE(pcie_100_int_ssc_cmn_regs), 4587 }; 4588 4589 /* Single link PCIe, 100 MHz Ref clk, internal SSC */ 4590 static const struct cdns_reg_pairs sl_pcie_100_int_ssc_cmn_regs[] = { 4591 {0x0004, CMN_PLL0_DSM_DIAG_M0}, 4592 {0x0004, CMN_PLL0_DSM_DIAG_M1}, 4593 {0x0004, CMN_PLL1_DSM_DIAG_M0}, 4594 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0}, 4595 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1}, 4596 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4597 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0}, 4598 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1}, 4599 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0}, 4600 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0}, 4601 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1}, 4602 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0}, 4603 {0x0064, CMN_PLL0_INTDIV_M0}, 4604 {0x0050, CMN_PLL0_INTDIV_M1}, 4605 {0x0050, CMN_PLL1_INTDIV_M0}, 4606 {0x0002, CMN_PLL0_FRACDIVH_M0}, 4607 {0x0002, CMN_PLL0_FRACDIVH_M1}, 4608 {0x0002, CMN_PLL1_FRACDIVH_M0}, 4609 {0x0044, CMN_PLL0_HIGH_THR_M0}, 4610 {0x0036, CMN_PLL0_HIGH_THR_M1}, 4611 {0x0036, CMN_PLL1_HIGH_THR_M0}, 4612 {0x0002, CMN_PDIAG_PLL0_CTRL_M0}, 4613 {0x0002, CMN_PDIAG_PLL0_CTRL_M1}, 4614 {0x0002, CMN_PDIAG_PLL1_CTRL_M0}, 4615 {0x0001, CMN_PLL0_SS_CTRL1_M0}, 4616 {0x0001, CMN_PLL0_SS_CTRL1_M1}, 4617 {0x0001, CMN_PLL1_SS_CTRL1_M0}, 4618 {0x011B, CMN_PLL0_SS_CTRL2_M0}, 4619 {0x011B, CMN_PLL0_SS_CTRL2_M1}, 4620 {0x011B, CMN_PLL1_SS_CTRL2_M0}, 4621 {0x006E, CMN_PLL0_SS_CTRL3_M0}, 4622 {0x0058, CMN_PLL0_SS_CTRL3_M1}, 4623 {0x0058, CMN_PLL1_SS_CTRL3_M0}, 4624 {0x000E, CMN_PLL0_SS_CTRL4_M0}, 4625 {0x0012, CMN_PLL0_SS_CTRL4_M1}, 4626 {0x0012, CMN_PLL1_SS_CTRL4_M0}, 4627 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START}, 4628 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START}, 4629 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START}, 4630 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START}, 4631 {0x00C7, CMN_PLL0_LOCK_REFCNT_START}, 4632 {0x00C7, CMN_PLL1_LOCK_REFCNT_START}, 4633 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START}, 4634 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START}, 4635 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR}, 4636 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR} 4637 }; 4638 4639 static const struct cdns_torrent_vals sl_pcie_100_int_ssc_cmn_vals = { 4640 .reg_pairs = sl_pcie_100_int_ssc_cmn_regs, 4641 .num_regs = ARRAY_SIZE(sl_pcie_100_int_ssc_cmn_regs), 4642 }; 4643 4644 /* PCIe, 100 MHz Ref clk, no SSC & external SSC */ 4645 static const struct cdns_reg_pairs pcie_100_ext_no_ssc_cmn_regs[] = { 4646 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0}, 4647 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0}, 4648 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0} 4649 }; 4650 4651 static const struct cdns_reg_pairs pcie_100_ext_no_ssc_rx_ln_regs[] = { 4652 {0x0019, RX_REE_TAP1_CLIP}, 4653 {0x0019, RX_REE_TAP2TON_CLIP}, 4654 {0x0001, RX_DIAG_ACYA} 4655 }; 4656 4657 static const struct cdns_torrent_vals pcie_100_no_ssc_cmn_vals = { 4658 .reg_pairs = pcie_100_ext_no_ssc_cmn_regs, 4659 .num_regs = ARRAY_SIZE(pcie_100_ext_no_ssc_cmn_regs), 4660 }; 4661 4662 static const struct cdns_torrent_vals pcie_100_no_ssc_rx_ln_vals = { 4663 .reg_pairs = pcie_100_ext_no_ssc_rx_ln_regs, 4664 .num_regs = ARRAY_SIZE(pcie_100_ext_no_ssc_rx_ln_regs), 4665 }; 4666 4667 static const struct cdns_torrent_vals_entry link_cmn_vals_entries[] = { 4668 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_NONE), &sl_dp_link_cmn_vals}, 4669 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_PCIE), &pcie_dp_link_cmn_vals}, 4670 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_USB), &usb_dp_link_cmn_vals}, 4671 4672 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_NONE), NULL}, 4673 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_SGMII), &pcie_sgmii_link_cmn_vals}, 4674 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_QSGMII), &pcie_sgmii_link_cmn_vals}, 4675 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_USB), &pcie_usb_link_cmn_vals}, 4676 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_DP), &pcie_dp_link_cmn_vals}, 4677 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_USXGMII), &pcie_usxgmii_link_cmn_vals}, 4678 4679 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_NONE), &sl_sgmii_link_cmn_vals}, 4680 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_PCIE), &pcie_sgmii_link_cmn_vals}, 4681 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_QSGMII), &sgmii_qsgmii_link_cmn_vals}, 4682 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_USB), &usb_sgmii_link_cmn_vals}, 4683 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_USXGMII), &usxgmii_sgmii_link_cmn_vals}, 4684 4685 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_NONE), &sl_sgmii_link_cmn_vals}, 4686 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_PCIE), &pcie_sgmii_link_cmn_vals}, 4687 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_SGMII), &sgmii_qsgmii_link_cmn_vals}, 4688 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_USB), &usb_sgmii_link_cmn_vals}, 4689 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_USXGMII), &usxgmii_sgmii_link_cmn_vals}, 4690 4691 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_NONE), &sl_usb_link_cmn_vals}, 4692 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_PCIE), &pcie_usb_link_cmn_vals}, 4693 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_SGMII), &usb_sgmii_link_cmn_vals}, 4694 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_QSGMII), &usb_sgmii_link_cmn_vals}, 4695 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_DP), &usb_dp_link_cmn_vals}, 4696 4697 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_NONE), &sl_usxgmii_link_cmn_vals}, 4698 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_PCIE), &pcie_usxgmii_link_cmn_vals}, 4699 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_SGMII), &usxgmii_sgmii_link_cmn_vals}, 4700 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_QSGMII), &usxgmii_sgmii_link_cmn_vals}, 4701 }; 4702 4703 static const struct cdns_torrent_vals_entry xcvr_diag_vals_entries[] = { 4704 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_NONE), &sl_dp_xcvr_diag_ln_vals}, 4705 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_PCIE), &dp_pcie_xcvr_diag_ln_vals}, 4706 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_USB), &dp_usb_xcvr_diag_ln_vals}, 4707 4708 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_NONE), NULL}, 4709 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_SGMII), &pcie_sgmii_xcvr_diag_ln_vals}, 4710 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_QSGMII), &pcie_sgmii_xcvr_diag_ln_vals}, 4711 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_USB), &pcie_usb_xcvr_diag_ln_vals}, 4712 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_DP), &pcie_dp_xcvr_diag_ln_vals}, 4713 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_USXGMII), &pcie_usxgmii_xcvr_diag_ln_vals}, 4714 4715 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_NONE), &sl_sgmii_xcvr_diag_ln_vals}, 4716 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_PCIE), &sgmii_pcie_xcvr_diag_ln_vals}, 4717 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_QSGMII), &sgmii_qsgmii_xcvr_diag_ln_vals}, 4718 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_USB), &sgmii_usb_xcvr_diag_ln_vals}, 4719 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_USXGMII), &sgmii_usxgmii_xcvr_diag_ln_vals}, 4720 4721 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_NONE), &sl_sgmii_xcvr_diag_ln_vals}, 4722 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_PCIE), &sgmii_pcie_xcvr_diag_ln_vals}, 4723 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_SGMII), &sgmii_qsgmii_xcvr_diag_ln_vals}, 4724 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_USB), &sgmii_usb_xcvr_diag_ln_vals}, 4725 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_USXGMII), &sgmii_usxgmii_xcvr_diag_ln_vals}, 4726 4727 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_NONE), &sl_usb_xcvr_diag_ln_vals}, 4728 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_PCIE), &usb_pcie_xcvr_diag_ln_vals}, 4729 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_SGMII), &usb_sgmii_xcvr_diag_ln_vals}, 4730 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_QSGMII), &usb_sgmii_xcvr_diag_ln_vals}, 4731 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_DP), &usb_dp_xcvr_diag_ln_vals}, 4732 4733 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_NONE), &sl_usxgmii_xcvr_diag_ln_vals}, 4734 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_PCIE), &usxgmii_pcie_xcvr_diag_ln_vals}, 4735 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_SGMII), &usxgmii_sgmii_xcvr_diag_ln_vals}, 4736 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_QSGMII), &usxgmii_sgmii_xcvr_diag_ln_vals}, 4737 }; 4738 4739 static const struct cdns_torrent_vals_entry pcs_cmn_vals_entries[] = { 4740 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_NONE), &usb_phy_pcs_cmn_vals}, 4741 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_PCIE), &usb_phy_pcs_cmn_vals}, 4742 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_SGMII), &usb_phy_pcs_cmn_vals}, 4743 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_QSGMII), &usb_phy_pcs_cmn_vals}, 4744 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_DP), &usb_phy_pcs_cmn_vals}, 4745 }; 4746 4747 static const struct cdns_torrent_vals_entry cmn_vals_entries[] = { 4748 {CDNS_TORRENT_KEY(CLK_19_2_MHZ, CLK_19_2_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_19_2_no_ssc_cmn_vals}, 4749 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_cmn_vals}, 4750 4751 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_cmn_vals}, 4752 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_cmn_vals}, 4753 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &sl_dp_100_no_ssc_cmn_vals}, 4754 4755 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL}, 4756 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL}, 4757 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), &sl_pcie_100_int_ssc_cmn_vals}, 4758 4759 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), &pcie_100_no_ssc_cmn_vals}, 4760 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals}, 4761 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals}, 4762 4763 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), &pcie_100_no_ssc_cmn_vals}, 4764 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals}, 4765 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals}, 4766 4767 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), &pcie_100_no_ssc_cmn_vals}, 4768 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals}, 4769 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals}, 4770 4771 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL}, 4772 4773 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sl_sgmii_100_no_ssc_cmn_vals}, 4774 4775 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_cmn_vals}, 4776 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals}, 4777 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_int_ssc_cmn_vals}, 4778 4779 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sl_sgmii_100_no_ssc_cmn_vals}, 4780 4781 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_cmn_vals}, 4782 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals}, 4783 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals}, 4784 4785 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &sl_qsgmii_100_no_ssc_cmn_vals}, 4786 4787 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_cmn_vals}, 4788 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals}, 4789 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_int_ssc_cmn_vals}, 4790 4791 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &sl_qsgmii_100_no_ssc_cmn_vals}, 4792 4793 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_cmn_vals}, 4794 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals}, 4795 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals}, 4796 4797 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &sl_usb_100_no_ssc_cmn_vals}, 4798 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals}, 4799 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals}, 4800 4801 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_cmn_vals}, 4802 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_cmn_vals}, 4803 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_int_ssc_cmn_vals}, 4804 4805 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &sl_usb_100_no_ssc_cmn_vals}, 4806 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals}, 4807 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals}, 4808 4809 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &sl_usb_100_no_ssc_cmn_vals}, 4810 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals}, 4811 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals}, 4812 4813 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_cmn_vals}, 4814 4815 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_156_25_MHZ, TYPE_USXGMII, TYPE_NONE, NO_SSC), &sl_usxgmii_156_25_no_ssc_cmn_vals}, 4816 4817 /* Dual refclk */ 4818 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL}, 4819 4820 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &ml_sgmii_pll1_100_no_ssc_cmn_vals}, 4821 4822 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &ml_sgmii_pll1_100_no_ssc_cmn_vals}, 4823 4824 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_PCIE, NO_SSC), &ml_usxgmii_pll1_156_25_no_ssc_cmn_vals}, 4825 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &ml_usxgmii_pll0_156_25_no_ssc_cmn_vals}, 4826 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &ml_usxgmii_pll0_156_25_no_ssc_cmn_vals}, 4827 }; 4828 4829 static const struct cdns_torrent_vals_entry cdns_tx_ln_vals_entries[] = { 4830 {CDNS_TORRENT_KEY(CLK_19_2_MHZ, CLK_19_2_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_19_2_no_ssc_tx_ln_vals}, 4831 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_tx_ln_vals}, 4832 4833 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_tx_ln_vals}, 4834 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_tx_ln_vals}, 4835 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_tx_ln_vals}, 4836 4837 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL}, 4838 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL}, 4839 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), NULL}, 4840 4841 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), NULL}, 4842 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), NULL}, 4843 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), NULL}, 4844 4845 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), NULL}, 4846 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), NULL}, 4847 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), NULL}, 4848 4849 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), NULL}, 4850 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), NULL}, 4851 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), NULL}, 4852 4853 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL}, 4854 4855 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4856 4857 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4858 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4859 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4860 4861 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4862 4863 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4864 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4865 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4866 4867 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4868 4869 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4870 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4871 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4872 4873 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4874 4875 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4876 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4877 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4878 4879 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 4880 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 4881 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 4882 4883 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 4884 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 4885 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 4886 4887 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 4888 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 4889 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 4890 4891 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 4892 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 4893 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 4894 4895 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 4896 4897 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_156_25_MHZ, TYPE_USXGMII, TYPE_NONE, NO_SSC), &usxgmii_156_25_no_ssc_tx_ln_vals}, 4898 4899 /* Dual refclk */ 4900 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL}, 4901 4902 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals}, 4903 4904 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals}, 4905 4906 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_PCIE, NO_SSC), &ml_usxgmii_156_25_no_ssc_tx_ln_vals}, 4907 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &ml_usxgmii_156_25_no_ssc_tx_ln_vals}, 4908 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &ml_usxgmii_156_25_no_ssc_tx_ln_vals}, 4909 }; 4910 4911 static const struct cdns_torrent_vals_entry cdns_rx_ln_vals_entries[] = { 4912 {CDNS_TORRENT_KEY(CLK_19_2_MHZ, CLK_19_2_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_19_2_no_ssc_rx_ln_vals}, 4913 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_rx_ln_vals}, 4914 4915 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_rx_ln_vals}, 4916 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_rx_ln_vals}, 4917 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_rx_ln_vals}, 4918 4919 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4920 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4921 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4922 4923 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4924 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4925 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4926 4927 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4928 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4929 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4930 4931 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4932 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4933 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4934 4935 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4936 4937 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4938 4939 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4940 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4941 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4942 4943 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4944 4945 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4946 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4947 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4948 4949 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4950 4951 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4952 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4953 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4954 4955 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4956 4957 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4958 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4959 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4960 4961 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 4962 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 4963 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 4964 4965 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 4966 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 4967 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 4968 4969 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 4970 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 4971 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 4972 4973 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 4974 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 4975 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 4976 4977 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 4978 4979 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_156_25_MHZ, TYPE_USXGMII, TYPE_NONE, NO_SSC), &usxgmii_156_25_no_ssc_rx_ln_vals}, 4980 4981 /* Dual refclk */ 4982 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 4983 4984 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 4985 4986 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 4987 4988 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_PCIE, NO_SSC), &ml_usxgmii_156_25_no_ssc_rx_ln_vals}, 4989 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &ml_usxgmii_156_25_no_ssc_rx_ln_vals}, 4990 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &ml_usxgmii_156_25_no_ssc_rx_ln_vals}, 4991 }; 4992 4993 static const struct cdns_torrent_data cdns_map_torrent = { 4994 .block_offset_shift = 0x2, 4995 .reg_offset_shift = 0x2, 4996 .link_cmn_vals_tbl = { 4997 .entries = link_cmn_vals_entries, 4998 .num_entries = ARRAY_SIZE(link_cmn_vals_entries), 4999 }, 5000 .xcvr_diag_vals_tbl = { 5001 .entries = xcvr_diag_vals_entries, 5002 .num_entries = ARRAY_SIZE(xcvr_diag_vals_entries), 5003 }, 5004 .pcs_cmn_vals_tbl = { 5005 .entries = pcs_cmn_vals_entries, 5006 .num_entries = ARRAY_SIZE(pcs_cmn_vals_entries), 5007 }, 5008 .cmn_vals_tbl = { 5009 .entries = cmn_vals_entries, 5010 .num_entries = ARRAY_SIZE(cmn_vals_entries), 5011 }, 5012 .tx_ln_vals_tbl = { 5013 .entries = cdns_tx_ln_vals_entries, 5014 .num_entries = ARRAY_SIZE(cdns_tx_ln_vals_entries), 5015 }, 5016 .rx_ln_vals_tbl = { 5017 .entries = cdns_rx_ln_vals_entries, 5018 .num_entries = ARRAY_SIZE(cdns_rx_ln_vals_entries), 5019 }, 5020 }; 5021 5022 static const struct cdns_torrent_vals_entry j721e_phy_pma_cmn_vals_entries[] = { 5023 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_NONE), &ti_usxgmii_phy_pma_cmn_vals}, 5024 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_PCIE), &ti_usxgmii_phy_pma_cmn_vals}, 5025 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_SGMII), &ti_usxgmii_phy_pma_cmn_vals}, 5026 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_QSGMII), &ti_usxgmii_phy_pma_cmn_vals}, 5027 }; 5028 5029 static const struct cdns_torrent_vals_entry ti_tx_ln_vals_entries[] = { 5030 {CDNS_TORRENT_KEY(CLK_19_2_MHZ, CLK_19_2_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_19_2_no_ssc_tx_ln_vals}, 5031 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_tx_ln_vals}, 5032 5033 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_tx_ln_vals}, 5034 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_tx_ln_vals}, 5035 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_tx_ln_vals}, 5036 5037 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL}, 5038 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL}, 5039 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), NULL}, 5040 5041 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), NULL}, 5042 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), NULL}, 5043 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), NULL}, 5044 5045 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), NULL}, 5046 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), NULL}, 5047 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), NULL}, 5048 5049 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), NULL}, 5050 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), NULL}, 5051 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), NULL}, 5052 5053 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL}, 5054 5055 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5056 5057 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5058 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5059 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5060 5061 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5062 5063 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5064 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5065 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5066 5067 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5068 5069 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5070 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5071 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5072 5073 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5074 5075 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5076 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5077 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5078 5079 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5080 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5081 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5082 5083 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5084 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5085 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5086 5087 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5088 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5089 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5090 5091 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5092 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5093 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5094 5095 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5096 5097 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_156_25_MHZ, TYPE_USXGMII, TYPE_NONE, NO_SSC), &usxgmii_156_25_no_ssc_tx_ln_vals}, 5098 5099 /* Dual refclk */ 5100 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL}, 5101 5102 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5103 5104 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5105 5106 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_PCIE, NO_SSC), &ml_usxgmii_156_25_no_ssc_tx_ln_vals}, 5107 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &ml_usxgmii_156_25_no_ssc_tx_ln_vals}, 5108 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &ml_usxgmii_156_25_no_ssc_tx_ln_vals}, 5109 }; 5110 5111 static const struct cdns_torrent_data ti_j721e_map_torrent = { 5112 .block_offset_shift = 0x0, 5113 .reg_offset_shift = 0x1, 5114 .link_cmn_vals_tbl = { 5115 .entries = link_cmn_vals_entries, 5116 .num_entries = ARRAY_SIZE(link_cmn_vals_entries), 5117 }, 5118 .xcvr_diag_vals_tbl = { 5119 .entries = xcvr_diag_vals_entries, 5120 .num_entries = ARRAY_SIZE(xcvr_diag_vals_entries), 5121 }, 5122 .pcs_cmn_vals_tbl = { 5123 .entries = pcs_cmn_vals_entries, 5124 .num_entries = ARRAY_SIZE(pcs_cmn_vals_entries), 5125 }, 5126 .phy_pma_cmn_vals_tbl = { 5127 .entries = j721e_phy_pma_cmn_vals_entries, 5128 .num_entries = ARRAY_SIZE(j721e_phy_pma_cmn_vals_entries), 5129 }, 5130 .cmn_vals_tbl = { 5131 .entries = cmn_vals_entries, 5132 .num_entries = ARRAY_SIZE(cmn_vals_entries), 5133 }, 5134 .tx_ln_vals_tbl = { 5135 .entries = ti_tx_ln_vals_entries, 5136 .num_entries = ARRAY_SIZE(ti_tx_ln_vals_entries), 5137 }, 5138 .rx_ln_vals_tbl = { 5139 .entries = cdns_rx_ln_vals_entries, 5140 .num_entries = ARRAY_SIZE(cdns_rx_ln_vals_entries), 5141 }, 5142 }; 5143 5144 /* TI J7200 (Torrent SD0805) */ 5145 static const struct cdns_torrent_vals_entry ti_j7200_cmn_vals_entries[] = { 5146 {CDNS_TORRENT_KEY(CLK_19_2_MHZ, CLK_19_2_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_19_2_no_ssc_cmn_vals}, 5147 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_cmn_vals}, 5148 5149 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_cmn_vals}, 5150 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_cmn_vals}, 5151 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &sl_dp_100_no_ssc_cmn_vals}, 5152 5153 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL}, 5154 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL}, 5155 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), &sl_pcie_100_int_ssc_cmn_vals}, 5156 5157 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), &pcie_100_no_ssc_cmn_vals}, 5158 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals}, 5159 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals}, 5160 5161 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), &pcie_100_no_ssc_cmn_vals}, 5162 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals}, 5163 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals}, 5164 5165 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), &pcie_100_no_ssc_cmn_vals}, 5166 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals}, 5167 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals}, 5168 5169 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL}, 5170 5171 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sl_sgmii_100_no_ssc_cmn_vals}, 5172 5173 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_cmn_vals}, 5174 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals}, 5175 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_int_ssc_cmn_vals}, 5176 5177 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sl_sgmii_100_no_ssc_cmn_vals}, 5178 5179 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_cmn_vals}, 5180 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals}, 5181 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals}, 5182 5183 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &sl_qsgmii_100_no_ssc_cmn_vals}, 5184 5185 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_cmn_vals}, 5186 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals}, 5187 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_int_ssc_cmn_vals}, 5188 5189 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &sl_qsgmii_100_no_ssc_cmn_vals}, 5190 5191 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_cmn_vals}, 5192 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals}, 5193 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals}, 5194 5195 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &sl_usb_100_no_ssc_cmn_vals}, 5196 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals}, 5197 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals}, 5198 5199 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_cmn_vals}, 5200 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_cmn_vals}, 5201 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_int_ssc_cmn_vals}, 5202 5203 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &sl_usb_100_no_ssc_cmn_vals}, 5204 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals}, 5205 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals}, 5206 5207 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &sl_usb_100_no_ssc_cmn_vals}, 5208 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals}, 5209 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals}, 5210 5211 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_cmn_vals}, 5212 5213 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_156_25_MHZ, TYPE_USXGMII, TYPE_NONE, NO_SSC), &sl_usxgmii_156_25_no_ssc_cmn_vals}, 5214 5215 /* Dual refclk */ 5216 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL}, 5217 5218 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &j7200_ml_sgmii_pll1_100_no_ssc_cmn_vals}, 5219 5220 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &j7200_ml_sgmii_pll1_100_no_ssc_cmn_vals}, 5221 5222 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_PCIE, NO_SSC), &ml_usxgmii_pll1_156_25_no_ssc_cmn_vals}, 5223 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_vals}, 5224 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_vals}, 5225 }; 5226 5227 static const struct cdns_torrent_vals_entry ti_j7200_tx_ln_vals_entries[] = { 5228 {CDNS_TORRENT_KEY(CLK_19_2_MHZ, CLK_19_2_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_19_2_no_ssc_tx_ln_vals}, 5229 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_tx_ln_vals}, 5230 5231 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_tx_ln_vals}, 5232 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_tx_ln_vals}, 5233 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_tx_ln_vals}, 5234 5235 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL}, 5236 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL}, 5237 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), NULL}, 5238 5239 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), NULL}, 5240 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), NULL}, 5241 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), NULL}, 5242 5243 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), NULL}, 5244 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), NULL}, 5245 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), NULL}, 5246 5247 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), NULL}, 5248 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), NULL}, 5249 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), NULL}, 5250 5251 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL}, 5252 5253 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5254 5255 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5256 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5257 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5258 5259 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5260 5261 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5262 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5263 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals}, 5264 5265 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5266 5267 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5268 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5269 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5270 5271 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5272 5273 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5274 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5275 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals}, 5276 5277 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5278 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5279 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5280 5281 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5282 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5283 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5284 5285 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5286 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5287 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5288 5289 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5290 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5291 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals}, 5292 5293 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_tx_ln_vals}, 5294 5295 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_156_25_MHZ, TYPE_USXGMII, TYPE_NONE, NO_SSC), &usxgmii_156_25_no_ssc_tx_ln_vals}, 5296 5297 /* Dual refclk */ 5298 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL}, 5299 5300 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &j7200_sgmii_100_no_ssc_tx_ln_vals}, 5301 5302 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &j7200_qsgmii_100_no_ssc_tx_ln_vals}, 5303 5304 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_PCIE, NO_SSC), &ml_usxgmii_156_25_no_ssc_tx_ln_vals}, 5305 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &usxgmii_156_25_no_ssc_tx_ln_vals}, 5306 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &usxgmii_156_25_no_ssc_tx_ln_vals}, 5307 }; 5308 5309 static const struct cdns_torrent_vals_entry ti_j7200_rx_ln_vals_entries[] = { 5310 {CDNS_TORRENT_KEY(CLK_19_2_MHZ, CLK_19_2_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_19_2_no_ssc_rx_ln_vals}, 5311 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_rx_ln_vals}, 5312 5313 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_rx_ln_vals}, 5314 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_rx_ln_vals}, 5315 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_rx_ln_vals}, 5316 5317 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5318 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5319 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5320 5321 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5322 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5323 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5324 5325 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5326 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5327 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5328 5329 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5330 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5331 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5332 5333 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5334 5335 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 5336 5337 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 5338 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 5339 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 5340 5341 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 5342 5343 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 5344 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 5345 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals}, 5346 5347 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 5348 5349 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 5350 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 5351 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 5352 5353 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 5354 5355 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 5356 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 5357 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals}, 5358 5359 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 5360 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 5361 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 5362 5363 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 5364 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 5365 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 5366 5367 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 5368 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 5369 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 5370 5371 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 5372 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 5373 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals}, 5374 5375 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_rx_ln_vals}, 5376 5377 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_156_25_MHZ, TYPE_USXGMII, TYPE_NONE, NO_SSC), &usxgmii_156_25_no_ssc_rx_ln_vals}, 5378 5379 /* Dual refclk */ 5380 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals}, 5381 5382 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &j7200_sgmii_100_no_ssc_rx_ln_vals}, 5383 5384 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &j7200_qsgmii_100_no_ssc_rx_ln_vals}, 5385 5386 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_PCIE, NO_SSC), &ml_usxgmii_156_25_no_ssc_rx_ln_vals}, 5387 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &usxgmii_156_25_no_ssc_rx_ln_vals}, 5388 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &usxgmii_156_25_no_ssc_rx_ln_vals}, 5389 }; 5390 5391 static const struct cdns_torrent_data ti_j7200_map_torrent = { 5392 .block_offset_shift = 0x0, 5393 .reg_offset_shift = 0x1, 5394 .link_cmn_vals_tbl = { 5395 .entries = link_cmn_vals_entries, 5396 .num_entries = ARRAY_SIZE(link_cmn_vals_entries), 5397 }, 5398 .xcvr_diag_vals_tbl = { 5399 .entries = xcvr_diag_vals_entries, 5400 .num_entries = ARRAY_SIZE(xcvr_diag_vals_entries), 5401 }, 5402 .pcs_cmn_vals_tbl = { 5403 .entries = pcs_cmn_vals_entries, 5404 .num_entries = ARRAY_SIZE(pcs_cmn_vals_entries), 5405 }, 5406 .phy_pma_cmn_vals_tbl = { 5407 .entries = j721e_phy_pma_cmn_vals_entries, 5408 .num_entries = ARRAY_SIZE(j721e_phy_pma_cmn_vals_entries), 5409 }, 5410 .cmn_vals_tbl = { 5411 .entries = ti_j7200_cmn_vals_entries, 5412 .num_entries = ARRAY_SIZE(ti_j7200_cmn_vals_entries), 5413 }, 5414 .tx_ln_vals_tbl = { 5415 .entries = ti_j7200_tx_ln_vals_entries, 5416 .num_entries = ARRAY_SIZE(ti_j7200_tx_ln_vals_entries), 5417 }, 5418 .rx_ln_vals_tbl = { 5419 .entries = ti_j7200_rx_ln_vals_entries, 5420 .num_entries = ARRAY_SIZE(ti_j7200_rx_ln_vals_entries), 5421 }, 5422 }; 5423 5424 static const struct of_device_id cdns_torrent_phy_of_match[] = { 5425 { 5426 .compatible = "cdns,torrent-phy", 5427 .data = &cdns_map_torrent, 5428 }, 5429 { 5430 .compatible = "ti,j721e-serdes-10g", 5431 .data = &ti_j721e_map_torrent, 5432 }, 5433 { 5434 .compatible = "ti,j7200-serdes-10g", 5435 .data = &ti_j7200_map_torrent, 5436 }, 5437 {} 5438 }; 5439 MODULE_DEVICE_TABLE(of, cdns_torrent_phy_of_match); 5440 5441 static struct platform_driver cdns_torrent_phy_driver = { 5442 .probe = cdns_torrent_phy_probe, 5443 .remove = cdns_torrent_phy_remove, 5444 .driver = { 5445 .name = "cdns-torrent-phy", 5446 .of_match_table = cdns_torrent_phy_of_match, 5447 .pm = pm_sleep_ptr(&cdns_torrent_phy_pm_ops), 5448 } 5449 }; 5450 module_platform_driver(cdns_torrent_phy_driver); 5451 5452 MODULE_AUTHOR("Cadence Design Systems, Inc."); 5453 MODULE_DESCRIPTION("Cadence Torrent PHY driver"); 5454 MODULE_LICENSE("GPL v2"); 5455