1 // SPDX-License-Identifier: GPL-2.0-only
3 * Cadence Torrent SD0801 PHY driver.
5 * Copyright 2018 Cadence Design Systems, Inc.
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>
16 #include <linux/iopoll.h>
17 #include <linux/kernel.h>
18 #include <linux/module.h>
20 #include <linux/phy/phy.h>
21 #include <linux/platform_device.h>
22 #include <linux/reset.h>
23 #include <linux/regmap.h>
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
30 #define MAX_NUM_LANES 4
31 #define DEFAULT_MAX_BIT_RATE 8100 /* in Mbps */
33 #define POLL_TIMEOUT_US 5000
34 #define PLL_LOCK_TIMEOUT 100000
36 #define DP_PLL0 BIT(0)
37 #define DP_PLL1 BIT(1)
39 #define TORRENT_COMMON_CDB_OFFSET 0x0
41 #define TORRENT_TX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \
42 ((0x4000 << (block_offset)) + \
43 (((ln) << 9) << (reg_offset)))
45 #define TORRENT_RX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \
46 ((0x8000 << (block_offset)) + \
47 (((ln) << 9) << (reg_offset)))
49 #define TORRENT_PHY_PCS_COMMON_OFFSET(block_offset) \
50 (0xC000 << (block_offset))
52 #define TORRENT_PHY_PCS_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \
53 ((0xD000 << (block_offset)) + \
54 (((ln) << 8) << (reg_offset)))
56 #define TORRENT_PHY_PMA_COMMON_OFFSET(block_offset) \
57 (0xE000 << (block_offset))
59 #define TORRENT_DPTX_PHY_OFFSET 0x0
62 * register offsets from DPTX PHY register block base (i.e MHDP
63 * register base + 0x30a00)
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
77 * register offsets from SD0801 PHY register block base (i.e MHDP
78 * register base + 0x500000)
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
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
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
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
228 /* PHY PCS lane registers */
229 #define PHY_PCS_ISO_LINK_CTRL 0x000BU
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
236 #define CDNS_TORRENT_OUTPUT_CLOCKS 3
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",
244 static const struct reg_field phy_pll_cfg =
245 REG_FIELD(PHY_PLL_CFG, 0, 1);
247 static const struct reg_field phy_pma_cmn_ctrl_1 =
248 REG_FIELD(PHY_PMA_CMN_CTRL1, 0, 0);
250 static const struct reg_field phy_pma_cmn_ctrl_2 =
251 REG_FIELD(PHY_PMA_CMN_CTRL2, 0, 7);
253 static const struct reg_field phy_pma_pll_raw_ctrl =
254 REG_FIELD(PHY_PMA_PLL_RAW_CTRL, 0, 1);
256 static const struct reg_field phy_reset_ctrl =
257 REG_FIELD(PHY_RESET, 8, 8);
259 static const struct reg_field phy_pcs_iso_link_ctrl_1 =
260 REG_FIELD(PHY_PCS_ISO_LINK_CTRL, 1, 1);
262 static const struct reg_field phy_pipe_cmn_ctrl1_0 = REG_FIELD(PHY_PIPE_CMN_CTRL1, 0, 0);
264 static const struct reg_field cmn_cdiag_refclk_ovrd_4 =
265 REG_FIELD(CMN_CDIAG_REFCLK_OVRD, 4, 4);
267 #define REFCLK_OUT_NUM_CMN_CONFIG 4
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,
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),
283 static const int refclk_driver_parent_index[] = {
284 CDNS_TORRENT_DERIVED_REFCLK,
285 CDNS_TORRENT_RECEIVED_REFCLK
288 static u32 cdns_torrent_refclk_driver_mux_table[] = { 1, 0 };
290 enum cdns_torrent_phy_type {
300 enum cdns_torrent_ref_clk {
308 enum cdns_torrent_ssc_mode {
315 /* Unique key id for vals table entry
316 * REFCLK0_RATE | REFCLK1_RATE | LINK0_TYPE | LINK1_TYPE | SSC_TYPE
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)
327 #define SSC_MASK GENMASK(2, 0)
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))
336 #define CDNS_TORRENT_KEY_ANYCLK(link0, link1) \
337 CDNS_TORRENT_KEY(CLK_ANY, CLK_ANY, \
338 (link0), (link1), ANY_SSC)
340 struct cdns_torrent_inst {
343 enum cdns_torrent_phy_type phy_type;
345 struct reset_control *lnk_rst;
346 enum cdns_torrent_ssc_mode ssc_mode;
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) */
354 struct reset_control *phy_rst;
355 struct reset_control *apb_rst;
359 enum cdns_torrent_ref_clk ref_clk_rate;
360 enum cdns_torrent_ref_clk ref_clk1_rate;
361 struct cdns_torrent_inst phys[MAX_NUM_LANES];
363 int already_configured;
364 const struct cdns_torrent_data *init_data;
365 struct regmap *regmap_common_cdb;
366 struct regmap *regmap_phy_pcs_common_cdb;
367 struct regmap *regmap_phy_pma_common_cdb;
368 struct regmap *regmap_tx_lane_cdb[MAX_NUM_LANES];
369 struct regmap *regmap_rx_lane_cdb[MAX_NUM_LANES];
370 struct regmap *regmap_phy_pcs_lane_cdb[MAX_NUM_LANES];
371 struct regmap *regmap_dptx_phy_reg;
372 struct regmap_field *phy_pll_cfg;
373 struct regmap_field *phy_pipe_cmn_ctrl1_0;
374 struct regmap_field *cmn_cdiag_refclk_ovrd_4;
375 struct regmap_field *phy_pma_cmn_ctrl_1;
376 struct regmap_field *phy_pma_cmn_ctrl_2;
377 struct regmap_field *phy_pma_pll_raw_ctrl;
378 struct regmap_field *phy_reset_ctrl;
379 struct regmap_field *phy_pcs_iso_link_ctrl_1[MAX_NUM_LANES];
380 struct clk_hw_onecell_data *clk_hw_data;
383 enum phy_powerstate {
385 /* Powerstate A1 is unused */
390 struct cdns_torrent_refclk_driver {
392 struct regmap_field *cmn_fields[REFCLK_OUT_NUM_CMN_CONFIG];
393 struct clk_init_data clk_data;
396 #define to_cdns_torrent_refclk_driver(_hw) \
397 container_of(_hw, struct cdns_torrent_refclk_driver, hw)
399 struct cdns_torrent_derived_refclk {
401 struct regmap_field *phy_pipe_cmn_ctrl1_0;
402 struct regmap_field *cmn_cdiag_refclk_ovrd_4;
403 struct clk_init_data clk_data;
406 #define to_cdns_torrent_derived_refclk(_hw) \
407 container_of(_hw, struct cdns_torrent_derived_refclk, hw)
409 struct cdns_torrent_received_refclk {
411 struct regmap_field *phy_pipe_cmn_ctrl1_0;
412 struct regmap_field *cmn_cdiag_refclk_ovrd_4;
413 struct clk_init_data clk_data;
416 #define to_cdns_torrent_received_refclk(_hw) \
417 container_of(_hw, struct cdns_torrent_received_refclk, hw)
419 struct cdns_reg_pairs {
424 struct cdns_torrent_vals {
425 struct cdns_reg_pairs *reg_pairs;
429 struct cdns_torrent_vals_entry {
431 struct cdns_torrent_vals *vals;
434 struct cdns_torrent_vals_table {
435 struct cdns_torrent_vals_entry *entries;
439 struct cdns_torrent_data {
440 u8 block_offset_shift;
442 struct cdns_torrent_vals_table link_cmn_vals_tbl;
443 struct cdns_torrent_vals_table xcvr_diag_vals_tbl;
444 struct cdns_torrent_vals_table pcs_cmn_vals_tbl;
445 struct cdns_torrent_vals_table phy_pma_cmn_vals_tbl;
446 struct cdns_torrent_vals_table cmn_vals_tbl;
447 struct cdns_torrent_vals_table tx_ln_vals_tbl;
448 struct cdns_torrent_vals_table rx_ln_vals_tbl;
451 struct cdns_regmap_cdb_context {
457 static struct cdns_torrent_vals *cdns_torrent_get_tbl_vals(const struct cdns_torrent_vals_table *tbl,
458 enum cdns_torrent_ref_clk refclk0,
459 enum cdns_torrent_ref_clk refclk1,
460 enum cdns_torrent_phy_type link0,
461 enum cdns_torrent_phy_type link1,
462 enum cdns_torrent_ssc_mode ssc)
465 u32 key = CDNS_TORRENT_KEY(refclk0, refclk1, link0, link1, ssc);
467 for (i = 0; i < tbl->num_entries; i++) {
468 if (tbl->entries[i].key == key)
469 return tbl->entries[i].vals;
475 static int cdns_regmap_write(void *context, unsigned int reg, unsigned int val)
477 struct cdns_regmap_cdb_context *ctx = context;
478 u32 offset = reg << ctx->reg_offset_shift;
480 writew(val, ctx->base + offset);
485 static int cdns_regmap_read(void *context, unsigned int reg, unsigned int *val)
487 struct cdns_regmap_cdb_context *ctx = context;
488 u32 offset = reg << ctx->reg_offset_shift;
490 *val = readw(ctx->base + offset);
494 static int cdns_regmap_dptx_write(void *context, unsigned int reg,
497 struct cdns_regmap_cdb_context *ctx = context;
500 writel(val, ctx->base + offset);
505 static int cdns_regmap_dptx_read(void *context, unsigned int reg,
508 struct cdns_regmap_cdb_context *ctx = context;
511 *val = readl(ctx->base + offset);
515 #define TORRENT_TX_LANE_CDB_REGMAP_CONF(n) \
517 .name = "torrent_tx_lane" n "_cdb", \
520 .reg_write = cdns_regmap_write, \
521 .reg_read = cdns_regmap_read, \
524 #define TORRENT_RX_LANE_CDB_REGMAP_CONF(n) \
526 .name = "torrent_rx_lane" n "_cdb", \
529 .reg_write = cdns_regmap_write, \
530 .reg_read = cdns_regmap_read, \
533 static const struct regmap_config cdns_torrent_tx_lane_cdb_config[] = {
534 TORRENT_TX_LANE_CDB_REGMAP_CONF("0"),
535 TORRENT_TX_LANE_CDB_REGMAP_CONF("1"),
536 TORRENT_TX_LANE_CDB_REGMAP_CONF("2"),
537 TORRENT_TX_LANE_CDB_REGMAP_CONF("3"),
540 static const struct regmap_config cdns_torrent_rx_lane_cdb_config[] = {
541 TORRENT_RX_LANE_CDB_REGMAP_CONF("0"),
542 TORRENT_RX_LANE_CDB_REGMAP_CONF("1"),
543 TORRENT_RX_LANE_CDB_REGMAP_CONF("2"),
544 TORRENT_RX_LANE_CDB_REGMAP_CONF("3"),
547 static const struct regmap_config cdns_torrent_common_cdb_config = {
548 .name = "torrent_common_cdb",
551 .reg_write = cdns_regmap_write,
552 .reg_read = cdns_regmap_read,
555 #define TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF(n) \
557 .name = "torrent_phy_pcs_lane" n "_cdb", \
560 .reg_write = cdns_regmap_write, \
561 .reg_read = cdns_regmap_read, \
564 static const struct regmap_config cdns_torrent_phy_pcs_lane_cdb_config[] = {
565 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("0"),
566 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("1"),
567 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("2"),
568 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("3"),
571 static const struct regmap_config cdns_torrent_phy_pcs_cmn_cdb_config = {
572 .name = "torrent_phy_pcs_cmn_cdb",
575 .reg_write = cdns_regmap_write,
576 .reg_read = cdns_regmap_read,
579 static const struct regmap_config cdns_torrent_phy_pma_cmn_cdb_config = {
580 .name = "torrent_phy_pma_cmn_cdb",
583 .reg_write = cdns_regmap_write,
584 .reg_read = cdns_regmap_read,
587 static const struct regmap_config cdns_torrent_dptx_phy_config = {
588 .name = "torrent_dptx_phy",
591 .reg_write = cdns_regmap_dptx_write,
592 .reg_read = cdns_regmap_dptx_read,
595 /* PHY mmr access functions */
597 static void cdns_torrent_phy_write(struct regmap *regmap, u32 offset, u32 val)
599 regmap_write(regmap, offset, val);
602 static u32 cdns_torrent_phy_read(struct regmap *regmap, u32 offset)
606 regmap_read(regmap, offset, &val);
610 /* DPTX mmr access functions */
612 static void cdns_torrent_dp_write(struct regmap *regmap, u32 offset, u32 val)
614 regmap_write(regmap, offset, val);
617 static u32 cdns_torrent_dp_read(struct regmap *regmap, u32 offset)
621 regmap_read(regmap, offset, &val);
626 * Structure used to store values of PHY registers for voltage-related
627 * coefficients, for particular voltage swing and pre-emphasis level. Values
628 * are shared across all physical lanes.
630 struct coefficients {
631 /* Value of DRV_DIAG_TX_DRV register to use */
633 /* Value of TX_TXCC_MGNFS_MULT_000 register to use */
635 /* Value of TX_TXCC_CPOST_MULT_00 register to use */
640 * Array consists of values of voltage-related registers for sd0801 PHY. A value
641 * of 0xFFFF is a placeholder for invalid combination, and will never be used.
643 static const struct coefficients vltg_coeff[4][4] = {
644 /* voltage swing 0, pre-emphasis 0->3 */
645 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x002A,
646 .cpost_mult = 0x0000},
647 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x001F,
648 .cpost_mult = 0x0014},
649 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0012,
650 .cpost_mult = 0x0020},
651 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000,
652 .cpost_mult = 0x002A}
655 /* voltage swing 1, pre-emphasis 0->3 */
656 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x001F,
657 .cpost_mult = 0x0000},
658 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0013,
659 .cpost_mult = 0x0012},
660 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000,
661 .cpost_mult = 0x001F},
662 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
663 .cpost_mult = 0xFFFF}
666 /* voltage swing 2, pre-emphasis 0->3 */
667 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0013,
668 .cpost_mult = 0x0000},
669 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000,
670 .cpost_mult = 0x0013},
671 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
672 .cpost_mult = 0xFFFF},
673 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
674 .cpost_mult = 0xFFFF}
677 /* voltage swing 3, pre-emphasis 0->3 */
678 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000,
679 .cpost_mult = 0x0000},
680 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
681 .cpost_mult = 0xFFFF},
682 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
683 .cpost_mult = 0xFFFF},
684 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
685 .cpost_mult = 0xFFFF}
689 static const char *cdns_torrent_get_phy_type(enum cdns_torrent_phy_type phy_type)
693 return "DisplayPort";
710 * Set registers responsible for enabling and configuring SSC, with second and
711 * third register values provided by parameters.
714 void cdns_torrent_dp_enable_ssc_19_2mhz(struct cdns_torrent_phy *cdns_phy,
715 u32 ctrl2_val, u32 ctrl3_val)
717 struct regmap *regmap = cdns_phy->regmap_common_cdb;
719 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0001);
720 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl2_val);
721 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl3_val);
722 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0003);
723 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0001);
724 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl2_val);
725 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl3_val);
726 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0003);
730 void cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(struct cdns_torrent_phy *cdns_phy,
733 struct regmap *regmap = cdns_phy->regmap_common_cdb;
735 /* Assumes 19.2 MHz refclock */
737 /* Setting VCO for 10.8GHz */
740 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0119);
741 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x4000);
742 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
743 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x00BC);
744 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0012);
745 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0119);
746 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x4000);
747 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
748 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x00BC);
749 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0012);
751 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x033A, 0x006A);
753 /* Setting VCO for 9.72GHz */
757 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01FA);
758 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x4000);
759 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
760 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0152);
761 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
762 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01FA);
763 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x4000);
764 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
765 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0152);
766 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
768 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x05DD, 0x0069);
770 /* Setting VCO for 8.64GHz */
773 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01C2);
774 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x0000);
775 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
776 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x012C);
777 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
778 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01C2);
779 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x0000);
780 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
781 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x012C);
782 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
784 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x0536, 0x0069);
786 /* Setting VCO for 8.1GHz */
788 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01A5);
789 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0xE000);
790 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
791 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x011A);
792 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
793 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01A5);
794 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0xE000);
795 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
796 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x011A);
797 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
799 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x04D7, 0x006A);
804 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_PLLCNT_START, 0x025E);
805 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_THR, 0x0005);
806 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_PLLCNT_START, 0x025E);
807 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_THR, 0x0005);
809 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_PLLCNT_START, 0x0260);
810 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_PLLCNT_START, 0x0260);
811 /* Set reset register values to disable SSC */
812 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0002);
813 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL2_M0, 0x0000);
814 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL3_M0, 0x0000);
815 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0000);
816 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_THR, 0x0003);
817 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0002);
818 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL2_M0, 0x0000);
819 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL3_M0, 0x0000);
820 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0000);
821 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_THR, 0x0003);
824 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_REFCNT_START, 0x0099);
825 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_START, 0x0099);
826 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_REFCNT_START, 0x0099);
827 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_START, 0x0099);
831 * Set registers responsible for enabling and configuring SSC, with second
832 * register value provided by a parameter.
834 static void cdns_torrent_dp_enable_ssc_25mhz(struct cdns_torrent_phy *cdns_phy,
837 struct regmap *regmap = cdns_phy->regmap_common_cdb;
839 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0001);
840 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl2_val);
841 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x007F);
842 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0003);
843 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0001);
844 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl2_val);
845 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x007F);
846 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0003);
850 void cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(struct cdns_torrent_phy *cdns_phy,
853 struct regmap *regmap = cdns_phy->regmap_common_cdb;
855 /* Assumes 25 MHz refclock */
857 /* Setting VCO for 10.8GHz */
860 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01B0);
861 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x0000);
862 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
863 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0120);
864 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01B0);
865 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x0000);
866 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
867 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0120);
869 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x0423);
871 /* Setting VCO for 9.72GHz */
875 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0184);
876 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0xCCCD);
877 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
878 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0104);
879 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0184);
880 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0xCCCD);
881 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
882 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0104);
884 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x03B9);
886 /* Setting VCO for 8.64GHz */
889 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0159);
890 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x999A);
891 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
892 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x00E7);
893 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0159);
894 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x999A);
895 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
896 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x00E7);
898 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x034F);
900 /* Setting VCO for 8.1GHz */
902 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0144);
903 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x0000);
904 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
905 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x00D8);
906 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0144);
907 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x0000);
908 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
909 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x00D8);
911 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x031A);
915 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
916 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
919 cdns_torrent_phy_write(regmap,
920 CMN_PLL0_VCOCAL_PLLCNT_START, 0x0315);
921 cdns_torrent_phy_write(regmap,
922 CMN_PLL0_LOCK_PLLCNT_THR, 0x0005);
923 cdns_torrent_phy_write(regmap,
924 CMN_PLL1_VCOCAL_PLLCNT_START, 0x0315);
925 cdns_torrent_phy_write(regmap,
926 CMN_PLL1_LOCK_PLLCNT_THR, 0x0005);
928 cdns_torrent_phy_write(regmap,
929 CMN_PLL0_VCOCAL_PLLCNT_START, 0x0317);
930 cdns_torrent_phy_write(regmap,
931 CMN_PLL1_VCOCAL_PLLCNT_START, 0x0317);
932 /* Set reset register values to disable SSC */
933 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0002);
934 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL2_M0, 0x0000);
935 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL3_M0, 0x0000);
936 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0000);
937 cdns_torrent_phy_write(regmap,
938 CMN_PLL0_LOCK_PLLCNT_THR, 0x0003);
939 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0002);
940 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL2_M0, 0x0000);
941 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL3_M0, 0x0000);
942 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0000);
943 cdns_torrent_phy_write(regmap,
944 CMN_PLL1_LOCK_PLLCNT_THR, 0x0003);
947 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_REFCNT_START, 0x00C7);
948 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_START, 0x00C7);
949 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_REFCNT_START, 0x00C7);
950 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_START, 0x00C7);
954 void cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(struct cdns_torrent_phy *cdns_phy,
957 struct regmap *regmap = cdns_phy->regmap_common_cdb;
959 /* Assumes 100 MHz refclock */
961 /* Setting VCO for 10.8GHz */
964 if (cdns_phy->dp_pll & DP_PLL0)
965 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_FBH_OVRD_M0, 0x0022);
967 if (cdns_phy->dp_pll & DP_PLL1) {
968 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0028);
969 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_FBH_OVRD_M0, 0x0022);
970 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_FBL_OVRD_M0, 0x000C);
973 /* Setting VCO for 9.72GHz */
977 if (cdns_phy->dp_pll & DP_PLL0) {
978 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_DIAG_M0, 0x0004);
979 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_PADJ_M0, 0x0509);
980 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_IADJ_M0, 0x0F00);
981 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_FILT_PADJ_M0, 0x0F08);
982 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0061);
983 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x3333);
984 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
985 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0042);
986 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
988 if (cdns_phy->dp_pll & DP_PLL1) {
989 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_DIAG_M0, 0x0004);
990 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0509);
991 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_IADJ_M0, 0x0F00);
992 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_FILT_PADJ_M0, 0x0F08);
993 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0061);
994 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x3333);
995 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
996 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0042);
997 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
1000 /* Setting VCO for 8.64GHz */
1003 if (cdns_phy->dp_pll & DP_PLL0) {
1004 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_DIAG_M0, 0x0004);
1005 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_PADJ_M0, 0x0509);
1006 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_IADJ_M0, 0x0F00);
1007 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_FILT_PADJ_M0, 0x0F08);
1008 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0056);
1009 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x6666);
1010 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
1011 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x003A);
1012 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
1014 if (cdns_phy->dp_pll & DP_PLL1) {
1015 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_DIAG_M0, 0x0004);
1016 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0509);
1017 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_IADJ_M0, 0x0F00);
1018 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_FILT_PADJ_M0, 0x0F08);
1019 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0056);
1020 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x6666);
1021 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
1022 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x003A);
1023 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
1026 /* Setting VCO for 8.1GHz */
1028 if (cdns_phy->dp_pll & DP_PLL0) {
1029 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_DIAG_M0, 0x0004);
1030 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_PADJ_M0, 0x0509);
1031 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_IADJ_M0, 0x0F00);
1032 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_FILT_PADJ_M0, 0x0F08);
1033 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0051);
1034 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
1035 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0036);
1036 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
1038 if (cdns_phy->dp_pll & DP_PLL1) {
1039 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_DIAG_M0, 0x0004);
1040 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0509);
1041 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_IADJ_M0, 0x0F00);
1042 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_FILT_PADJ_M0, 0x0F08);
1043 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0051);
1044 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
1045 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0036);
1046 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
1052 /* Set PLL used for DP configuration */
1053 static int cdns_torrent_dp_get_pll(struct cdns_torrent_phy *cdns_phy,
1054 enum cdns_torrent_phy_type phy_t2)
1059 cdns_phy->dp_pll = DP_PLL1;
1063 cdns_phy->dp_pll = DP_PLL0;
1066 cdns_phy->dp_pll = DP_PLL0 | DP_PLL1;
1069 dev_err(cdns_phy->dev, "Unsupported PHY configuration\n");
1077 * Enable or disable PLL for selected lanes.
1079 static int cdns_torrent_dp_set_pll_en(struct cdns_torrent_phy *cdns_phy,
1080 struct cdns_torrent_inst *inst,
1081 struct phy_configure_opts_dp *dp,
1084 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1085 u32 rd_val, pll_ack_val;
1089 * Used to determine, which bits to check for or enable in
1090 * PHY_PMA_XCVR_PLLCLK_EN register.
1093 /* Used to enable or disable lanes. */
1096 /* Select values of registers and mask, depending on enabled lane count. */
1097 pll_val = cdns_torrent_dp_read(regmap, PHY_PMA_XCVR_PLLCLK_EN);
1100 pll_bits = ((1 << dp->lanes) - 1);
1101 pll_val |= pll_bits;
1102 pll_ack_val = pll_bits;
1104 pll_bits = ((1 << inst->num_lanes) - 1);
1105 pll_val &= (~pll_bits);
1109 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, pll_val);
1111 /* Wait for acknowledgment from PHY. */
1112 ret = regmap_read_poll_timeout(regmap,
1113 PHY_PMA_XCVR_PLLCLK_EN_ACK,
1115 (rd_val & pll_bits) == pll_ack_val,
1116 0, POLL_TIMEOUT_US);
1121 static int cdns_torrent_dp_set_power_state(struct cdns_torrent_phy *cdns_phy,
1122 struct cdns_torrent_inst *inst,
1124 enum phy_powerstate powerstate)
1126 /* Register value for power state for a single byte. */
1132 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1134 switch (powerstate) {
1135 case (POWERSTATE_A0):
1138 case (POWERSTATE_A2):
1147 /* Select values of registers and mask, depending on enabled lane count. */
1149 for (i = 0; i < num_lanes; i++) {
1150 value |= (value_part << PHY_POWER_STATE_LN(i));
1151 mask |= (PMA_XCVR_POWER_STATE_REQ_LN_MASK << PHY_POWER_STATE_LN(i));
1154 /* Set power state A<n>. */
1155 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, value);
1156 /* Wait, until PHY acknowledges power state completion. */
1157 ret = regmap_read_poll_timeout(regmap, PHY_PMA_XCVR_POWER_STATE_ACK,
1158 read_val, (read_val & mask) == value, 0,
1163 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, 0x00000000);
1169 static int cdns_torrent_dp_run(struct cdns_torrent_phy *cdns_phy,
1170 struct cdns_torrent_inst *inst, u32 num_lanes)
1172 unsigned int read_val;
1174 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1177 * waiting for ACK of pma_xcvr_pllclk_en_ln_*, only for the
1180 ret = regmap_read_poll_timeout(regmap, PHY_PMA_XCVR_PLLCLK_EN_ACK,
1181 read_val, read_val & 1,
1182 0, POLL_TIMEOUT_US);
1183 if (ret == -ETIMEDOUT) {
1184 dev_err(cdns_phy->dev,
1185 "timeout waiting for link PLL clock enable ack\n");
1191 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, num_lanes,
1196 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, num_lanes,
1202 static int cdns_torrent_dp_wait_pma_cmn_ready(struct cdns_torrent_phy *cdns_phy)
1206 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1208 ret = regmap_read_poll_timeout(regmap, PHY_PMA_CMN_READY, reg,
1209 reg & 1, 0, POLL_TIMEOUT_US);
1210 if (ret == -ETIMEDOUT) {
1211 dev_err(cdns_phy->dev,
1212 "timeout waiting for PMA common ready\n");
1219 static void cdns_torrent_dp_pma_cmn_rate(struct cdns_torrent_phy *cdns_phy,
1220 struct cdns_torrent_inst *inst,
1221 u32 rate, u32 num_lanes)
1223 unsigned int clk_sel_val = 0;
1224 unsigned int hsclk_div_val = 0;
1229 clk_sel_val = 0x0f01;
1235 clk_sel_val = 0x0701;
1239 clk_sel_val = 0x0b00;
1244 clk_sel_val = 0x0301;
1248 clk_sel_val = 0x0200;
1253 if (cdns_phy->dp_pll & DP_PLL0)
1254 cdns_torrent_phy_write(cdns_phy->regmap_common_cdb,
1255 CMN_PDIAG_PLL0_CLK_SEL_M0, clk_sel_val);
1257 if (cdns_phy->dp_pll & DP_PLL1)
1258 cdns_torrent_phy_write(cdns_phy->regmap_common_cdb,
1259 CMN_PDIAG_PLL1_CLK_SEL_M0, clk_sel_val);
1261 /* PMA lane configuration to deal with multi-link operation */
1262 for (i = 0; i < num_lanes; i++)
1263 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + i],
1264 XCVR_DIAG_HSCLK_DIV, hsclk_div_val);
1268 * Perform register operations related to setting link rate, once powerstate is
1269 * set and PLL disable request was processed.
1271 static int cdns_torrent_dp_configure_rate(struct cdns_torrent_phy *cdns_phy,
1272 struct cdns_torrent_inst *inst,
1273 struct phy_configure_opts_dp *dp)
1275 u32 read_val, field_val;
1279 * Disable the associated PLL (cmn_pll0_en or cmn_pll1_en) before
1280 * re-programming the new data rate.
1282 ret = regmap_field_read(cdns_phy->phy_pma_pll_raw_ctrl, &field_val);
1285 field_val &= ~(cdns_phy->dp_pll);
1286 regmap_field_write(cdns_phy->phy_pma_pll_raw_ctrl, field_val);
1289 * Wait for PLL ready de-assertion.
1290 * For PLL0 - PHY_PMA_CMN_CTRL2[2] == 1
1291 * For PLL1 - PHY_PMA_CMN_CTRL2[3] == 1
1293 if (cdns_phy->dp_pll & DP_PLL0) {
1294 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2,
1296 ((read_val >> 2) & 0x01) != 0,
1297 0, POLL_TIMEOUT_US);
1302 if ((cdns_phy->dp_pll & DP_PLL1) && cdns_phy->nsubnodes != 1) {
1303 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2,
1305 ((read_val >> 3) & 0x01) != 0,
1306 0, POLL_TIMEOUT_US);
1312 /* DP Rate Change - VCO Output settings. */
1313 if (cdns_phy->ref_clk_rate == CLK_19_2_MHZ)
1314 /* PMA common configuration 19.2MHz */
1315 cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(cdns_phy, dp->link_rate, dp->ssc);
1316 else if (cdns_phy->ref_clk_rate == CLK_25_MHZ)
1317 /* PMA common configuration 25MHz */
1318 cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(cdns_phy, dp->link_rate, dp->ssc);
1319 else if (cdns_phy->ref_clk_rate == CLK_100_MHZ)
1320 /* PMA common configuration 100MHz */
1321 cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(cdns_phy, dp->link_rate, dp->ssc);
1323 cdns_torrent_dp_pma_cmn_rate(cdns_phy, inst, dp->link_rate, dp->lanes);
1325 /* Enable the associated PLL (cmn_pll0_en or cmn_pll1_en) */
1326 ret = regmap_field_read(cdns_phy->phy_pma_pll_raw_ctrl, &field_val);
1329 field_val |= cdns_phy->dp_pll;
1330 regmap_field_write(cdns_phy->phy_pma_pll_raw_ctrl, field_val);
1333 * Wait for PLL ready assertion.
1334 * For PLL0 - PHY_PMA_CMN_CTRL2[0] == 1
1335 * For PLL1 - PHY_PMA_CMN_CTRL2[1] == 1
1337 if (cdns_phy->dp_pll & DP_PLL0) {
1338 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2,
1340 (read_val & 0x01) != 0,
1341 0, POLL_TIMEOUT_US);
1346 if ((cdns_phy->dp_pll & DP_PLL1) && cdns_phy->nsubnodes != 1)
1347 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2,
1349 ((read_val >> 1) & 0x01) != 0,
1350 0, POLL_TIMEOUT_US);
1356 * Verify, that parameters to configure PHY with are correct.
1358 static int cdns_torrent_dp_verify_config(struct cdns_torrent_inst *inst,
1359 struct phy_configure_opts_dp *dp)
1363 /* If changing link rate was required, verify it's supported. */
1365 switch (dp->link_rate) {
1374 /* valid bit rate */
1381 /* Verify lane count. */
1382 switch (dp->lanes) {
1386 /* valid lane count. */
1392 /* Check against actual number of PHY's lanes. */
1393 if (dp->lanes > inst->num_lanes)
1397 * If changing voltages is required, check swing and pre-emphasis
1400 if (dp->set_voltages) {
1401 /* Lane count verified previously. */
1402 for (i = 0; i < dp->lanes; i++) {
1403 if (dp->voltage[i] > 3 || dp->pre[i] > 3)
1406 /* Sum of voltage swing and pre-emphasis levels cannot
1409 if (dp->voltage[i] + dp->pre[i] > 3)
1417 /* Set power state A0 and PLL clock enable to 0 on enabled lanes. */
1418 static void cdns_torrent_dp_set_a0_pll(struct cdns_torrent_phy *cdns_phy,
1419 struct cdns_torrent_inst *inst,
1422 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1423 u32 pwr_state = cdns_torrent_dp_read(regmap,
1424 PHY_PMA_XCVR_POWER_STATE_REQ);
1425 u32 pll_clk_en = cdns_torrent_dp_read(regmap,
1426 PHY_PMA_XCVR_PLLCLK_EN);
1429 for (i = 0; i < num_lanes; i++) {
1430 pwr_state &= ~(PMA_XCVR_POWER_STATE_REQ_LN_MASK
1431 << PHY_POWER_STATE_LN(inst->mlane + i));
1433 pll_clk_en &= ~(0x01U << (inst->mlane + i));
1436 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, pwr_state);
1437 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, pll_clk_en);
1440 /* Configure lane count as required. */
1441 static int cdns_torrent_dp_set_lanes(struct cdns_torrent_phy *cdns_phy,
1442 struct cdns_torrent_inst *inst,
1443 struct phy_configure_opts_dp *dp)
1447 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1448 u8 lane_mask = (1 << dp->lanes) - 1;
1449 u8 pma_tx_elec_idle_mask = 0;
1450 u32 clane = inst->mlane;
1452 lane_mask <<= clane;
1454 value = cdns_torrent_dp_read(regmap, PHY_RESET);
1455 /* clear pma_tx_elec_idle_ln_* bits. */
1456 pma_tx_elec_idle_mask = ((1 << inst->num_lanes) - 1) << clane;
1458 pma_tx_elec_idle_mask <<= PMA_TX_ELEC_IDLE_SHIFT;
1460 value &= ~pma_tx_elec_idle_mask;
1462 /* Assert pma_tx_elec_idle_ln_* for disabled lanes. */
1463 value |= ((~lane_mask) << PMA_TX_ELEC_IDLE_SHIFT) &
1464 pma_tx_elec_idle_mask;
1466 cdns_torrent_dp_write(regmap, PHY_RESET, value);
1468 /* reset the link by asserting master lane phy_l0*_reset_n low */
1469 cdns_torrent_dp_write(regmap, PHY_RESET,
1470 value & (~(1 << clane)));
1473 * Assert lane reset on unused lanes and master lane so they remain in reset
1474 * and powered down when re-enabling the link
1476 for (i = 0; i < inst->num_lanes; i++)
1477 value &= (~(1 << (clane + i)));
1479 for (i = 1; i < inst->num_lanes; i++)
1480 value |= ((1 << (clane + i)) & lane_mask);
1482 cdns_torrent_dp_write(regmap, PHY_RESET, value);
1484 cdns_torrent_dp_set_a0_pll(cdns_phy, inst, dp->lanes);
1486 /* release phy_l0*_reset_n based on used laneCount */
1487 for (i = 0; i < inst->num_lanes; i++)
1488 value &= (~(1 << (clane + i)));
1490 for (i = 0; i < inst->num_lanes; i++)
1491 value |= ((1 << (clane + i)) & lane_mask);
1493 cdns_torrent_dp_write(regmap, PHY_RESET, value);
1495 /* Wait, until PHY gets ready after releasing PHY reset signal. */
1496 ret = cdns_torrent_dp_wait_pma_cmn_ready(cdns_phy);
1502 /* release pma_xcvr_pllclk_en_ln_*, only for the master lane */
1503 value = cdns_torrent_dp_read(regmap, PHY_PMA_XCVR_PLLCLK_EN);
1504 value |= (1 << clane);
1505 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, value);
1507 ret = cdns_torrent_dp_run(cdns_phy, inst, dp->lanes);
1512 /* Configure link rate as required. */
1513 static int cdns_torrent_dp_set_rate(struct cdns_torrent_phy *cdns_phy,
1514 struct cdns_torrent_inst *inst,
1515 struct phy_configure_opts_dp *dp)
1519 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, dp->lanes,
1523 ret = cdns_torrent_dp_set_pll_en(cdns_phy, inst, dp, false);
1528 ret = cdns_torrent_dp_configure_rate(cdns_phy, inst, dp);
1533 ret = cdns_torrent_dp_set_pll_en(cdns_phy, inst, dp, true);
1536 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, dp->lanes,
1540 ret = cdns_torrent_dp_set_power_state(cdns_phy, inst, dp->lanes,
1549 /* Configure voltage swing and pre-emphasis for all enabled lanes. */
1550 static void cdns_torrent_dp_set_voltages(struct cdns_torrent_phy *cdns_phy,
1551 struct cdns_torrent_inst *inst,
1552 struct phy_configure_opts_dp *dp)
1557 for (lane = 0; lane < dp->lanes; lane++) {
1558 val = cdns_torrent_phy_read(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
1561 * Write 1 to register bit TX_DIAG_ACYA[0] to freeze the
1562 * current state of the analog TX driver.
1564 val |= TX_DIAG_ACYA_HBDC_MASK;
1565 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
1568 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
1569 TX_TXCC_CTRL, 0x08A4);
1570 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].diag_tx_drv;
1571 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
1572 DRV_DIAG_TX_DRV, val);
1573 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].mgnfs_mult;
1574 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
1575 TX_TXCC_MGNFS_MULT_000,
1577 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].cpost_mult;
1578 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
1579 TX_TXCC_CPOST_MULT_00,
1582 val = cdns_torrent_phy_read(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
1585 * Write 0 to register bit TX_DIAG_ACYA[0] to allow the state of
1586 * analog TX driver to reflect the new programmed one.
1588 val &= ~TX_DIAG_ACYA_HBDC_MASK;
1589 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
1594 static int cdns_torrent_dp_configure(struct phy *phy,
1595 union phy_configure_opts *opts)
1597 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
1598 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
1601 if (cdns_phy->already_configured)
1604 ret = cdns_torrent_dp_verify_config(inst, &opts->dp);
1606 dev_err(&phy->dev, "invalid params for phy configure\n");
1610 if (opts->dp.set_lanes) {
1611 ret = cdns_torrent_dp_set_lanes(cdns_phy, inst, &opts->dp);
1613 dev_err(&phy->dev, "cdns_torrent_dp_set_lanes failed\n");
1618 if (opts->dp.set_rate) {
1619 ret = cdns_torrent_dp_set_rate(cdns_phy, inst, &opts->dp);
1621 dev_err(&phy->dev, "cdns_torrent_dp_set_rate failed\n");
1626 if (opts->dp.set_voltages)
1627 cdns_torrent_dp_set_voltages(cdns_phy, inst, &opts->dp);
1632 static int cdns_torrent_phy_on(struct phy *phy)
1634 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
1635 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
1639 if (cdns_phy->already_configured) {
1640 /* Give 5ms to 10ms delay for the PIPE clock to be stable */
1641 usleep_range(5000, 10000);
1645 if (cdns_phy->nsubnodes == 1) {
1646 /* Take the PHY lane group out of reset */
1647 reset_control_deassert(inst->lnk_rst);
1649 /* Take the PHY out of reset */
1650 ret = reset_control_deassert(cdns_phy->phy_rst);
1656 * Wait for cmn_ready assertion
1657 * PHY_PMA_CMN_CTRL1[0] == 1
1659 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_1,
1660 read_val, read_val, 1000,
1663 dev_err(cdns_phy->dev, "Timeout waiting for CMN ready\n");
1667 if (inst->phy_type == TYPE_PCIE || inst->phy_type == TYPE_USB) {
1668 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pcs_iso_link_ctrl_1[inst->mlane],
1669 read_val, !read_val, 1000,
1671 if (ret == -ETIMEDOUT) {
1672 dev_err(cdns_phy->dev, "Timeout waiting for PHY status ready\n");
1680 static int cdns_torrent_phy_off(struct phy *phy)
1682 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
1683 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
1686 if (cdns_phy->nsubnodes != 1)
1689 ret = reset_control_assert(cdns_phy->phy_rst);
1693 return reset_control_assert(inst->lnk_rst);
1696 static void cdns_torrent_dp_common_init(struct cdns_torrent_phy *cdns_phy,
1697 struct cdns_torrent_inst *inst)
1699 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1700 unsigned char lane_bits;
1703 cdns_torrent_dp_write(regmap, PHY_AUX_CTRL, 0x0003); /* enable AUX */
1706 * Set lines power state to A0
1707 * Set lines pll clk enable to 0
1709 cdns_torrent_dp_set_a0_pll(cdns_phy, inst, inst->num_lanes);
1712 * release phy_l0*_reset_n and pma_tx_elec_idle_ln_* based on
1715 lane_bits = (1 << inst->num_lanes) - 1;
1717 val = cdns_torrent_dp_read(regmap, PHY_RESET);
1718 val |= (0xF & lane_bits);
1719 val &= ~(lane_bits << 4);
1720 cdns_torrent_dp_write(regmap, PHY_RESET, val);
1722 /* release pma_xcvr_pllclk_en_ln_*, only for the master lane */
1723 val = cdns_torrent_dp_read(regmap, PHY_PMA_XCVR_PLLCLK_EN);
1725 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, val);
1728 * PHY PMA registers configuration functions
1729 * Initialize PHY with max supported link rate, without SSC.
1731 if (cdns_phy->ref_clk_rate == CLK_19_2_MHZ)
1732 cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(cdns_phy,
1733 cdns_phy->max_bit_rate,
1735 else if (cdns_phy->ref_clk_rate == CLK_25_MHZ)
1736 cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(cdns_phy,
1737 cdns_phy->max_bit_rate,
1739 else if (cdns_phy->ref_clk_rate == CLK_100_MHZ)
1740 cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(cdns_phy,
1741 cdns_phy->max_bit_rate,
1744 cdns_torrent_dp_pma_cmn_rate(cdns_phy, inst, cdns_phy->max_bit_rate,
1747 /* take out of reset */
1748 regmap_field_write(cdns_phy->phy_reset_ctrl, 0x1);
1751 static int cdns_torrent_dp_start(struct cdns_torrent_phy *cdns_phy,
1752 struct cdns_torrent_inst *inst,
1757 ret = cdns_torrent_phy_on(phy);
1761 ret = cdns_torrent_dp_wait_pma_cmn_ready(cdns_phy);
1765 ret = cdns_torrent_dp_run(cdns_phy, inst, inst->num_lanes);
1770 static int cdns_torrent_dp_init(struct phy *phy)
1772 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
1773 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
1776 switch (cdns_phy->ref_clk_rate) {
1780 /* Valid Ref Clock Rate */
1783 dev_err(cdns_phy->dev, "Unsupported Ref Clock Rate\n");
1787 ret = cdns_torrent_dp_get_pll(cdns_phy, TYPE_NONE);
1791 cdns_torrent_dp_common_init(cdns_phy, inst);
1793 return cdns_torrent_dp_start(cdns_phy, inst, phy);
1796 static int cdns_torrent_dp_multilink_init(struct cdns_torrent_phy *cdns_phy,
1797 struct cdns_torrent_inst *inst,
1800 if (cdns_phy->ref_clk_rate != CLK_100_MHZ) {
1801 dev_err(cdns_phy->dev, "Unsupported Ref Clock Rate\n");
1805 cdns_torrent_dp_common_init(cdns_phy, inst);
1807 return cdns_torrent_dp_start(cdns_phy, inst, phy);
1810 static int cdns_torrent_derived_refclk_enable(struct clk_hw *hw)
1812 struct cdns_torrent_derived_refclk *derived_refclk = to_cdns_torrent_derived_refclk(hw);
1814 regmap_field_write(derived_refclk->cmn_cdiag_refclk_ovrd_4, 1);
1815 regmap_field_write(derived_refclk->phy_pipe_cmn_ctrl1_0, 1);
1820 static void cdns_torrent_derived_refclk_disable(struct clk_hw *hw)
1822 struct cdns_torrent_derived_refclk *derived_refclk = to_cdns_torrent_derived_refclk(hw);
1824 regmap_field_write(derived_refclk->phy_pipe_cmn_ctrl1_0, 0);
1825 regmap_field_write(derived_refclk->cmn_cdiag_refclk_ovrd_4, 0);
1828 static int cdns_torrent_derived_refclk_is_enabled(struct clk_hw *hw)
1830 struct cdns_torrent_derived_refclk *derived_refclk = to_cdns_torrent_derived_refclk(hw);
1833 regmap_field_read(derived_refclk->cmn_cdiag_refclk_ovrd_4, &val);
1838 static const struct clk_ops cdns_torrent_derived_refclk_ops = {
1839 .enable = cdns_torrent_derived_refclk_enable,
1840 .disable = cdns_torrent_derived_refclk_disable,
1841 .is_enabled = cdns_torrent_derived_refclk_is_enabled,
1844 static int cdns_torrent_derived_refclk_register(struct cdns_torrent_phy *cdns_phy)
1846 struct cdns_torrent_derived_refclk *derived_refclk;
1847 struct device *dev = cdns_phy->dev;
1848 struct clk_init_data *init;
1849 const char *parent_name;
1855 derived_refclk = devm_kzalloc(dev, sizeof(*derived_refclk), GFP_KERNEL);
1856 if (!derived_refclk)
1859 snprintf(clk_name, sizeof(clk_name), "%s_%s", dev_name(dev),
1860 clk_names[CDNS_TORRENT_DERIVED_REFCLK]);
1862 clk = devm_clk_get_optional(dev, "phy_en_refclk");
1864 dev_err(dev, "No parent clock for derived_refclk\n");
1865 return PTR_ERR(clk);
1868 init = &derived_refclk->clk_data;
1871 parent_name = __clk_get_name(clk);
1872 init->parent_names = &parent_name;
1873 init->num_parents = 1;
1875 init->ops = &cdns_torrent_derived_refclk_ops;
1877 init->name = clk_name;
1879 derived_refclk->phy_pipe_cmn_ctrl1_0 = cdns_phy->phy_pipe_cmn_ctrl1_0;
1880 derived_refclk->cmn_cdiag_refclk_ovrd_4 = cdns_phy->cmn_cdiag_refclk_ovrd_4;
1882 derived_refclk->hw.init = init;
1884 hw = &derived_refclk->hw;
1885 ret = devm_clk_hw_register(dev, hw);
1889 cdns_phy->clk_hw_data->hws[CDNS_TORRENT_DERIVED_REFCLK] = hw;
1894 static int cdns_torrent_received_refclk_enable(struct clk_hw *hw)
1896 struct cdns_torrent_received_refclk *received_refclk = to_cdns_torrent_received_refclk(hw);
1898 regmap_field_write(received_refclk->phy_pipe_cmn_ctrl1_0, 1);
1903 static void cdns_torrent_received_refclk_disable(struct clk_hw *hw)
1905 struct cdns_torrent_received_refclk *received_refclk = to_cdns_torrent_received_refclk(hw);
1907 regmap_field_write(received_refclk->phy_pipe_cmn_ctrl1_0, 0);
1910 static int cdns_torrent_received_refclk_is_enabled(struct clk_hw *hw)
1912 struct cdns_torrent_received_refclk *received_refclk = to_cdns_torrent_received_refclk(hw);
1915 regmap_field_read(received_refclk->phy_pipe_cmn_ctrl1_0, &val);
1916 regmap_field_read(received_refclk->cmn_cdiag_refclk_ovrd_4, &cmn_val);
1918 return val && !cmn_val;
1921 static const struct clk_ops cdns_torrent_received_refclk_ops = {
1922 .enable = cdns_torrent_received_refclk_enable,
1923 .disable = cdns_torrent_received_refclk_disable,
1924 .is_enabled = cdns_torrent_received_refclk_is_enabled,
1927 static int cdns_torrent_received_refclk_register(struct cdns_torrent_phy *cdns_phy)
1929 struct cdns_torrent_received_refclk *received_refclk;
1930 struct device *dev = cdns_phy->dev;
1931 struct clk_init_data *init;
1932 const char *parent_name;
1938 received_refclk = devm_kzalloc(dev, sizeof(*received_refclk), GFP_KERNEL);
1939 if (!received_refclk)
1942 snprintf(clk_name, sizeof(clk_name), "%s_%s", dev_name(dev),
1943 clk_names[CDNS_TORRENT_RECEIVED_REFCLK]);
1945 clk = devm_clk_get_optional(dev, "phy_en_refclk");
1947 dev_err(dev, "No parent clock for received_refclk\n");
1948 return PTR_ERR(clk);
1951 init = &received_refclk->clk_data;
1954 parent_name = __clk_get_name(clk);
1955 init->parent_names = &parent_name;
1956 init->num_parents = 1;
1958 init->ops = &cdns_torrent_received_refclk_ops;
1960 init->name = clk_name;
1962 received_refclk->phy_pipe_cmn_ctrl1_0 = cdns_phy->phy_pipe_cmn_ctrl1_0;
1963 received_refclk->cmn_cdiag_refclk_ovrd_4 = cdns_phy->cmn_cdiag_refclk_ovrd_4;
1965 received_refclk->hw.init = init;
1967 hw = &received_refclk->hw;
1968 ret = devm_clk_hw_register(dev, hw);
1972 cdns_phy->clk_hw_data->hws[CDNS_TORRENT_RECEIVED_REFCLK] = hw;
1977 static int cdns_torrent_refclk_driver_enable(struct clk_hw *hw)
1979 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw);
1981 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_6], 0);
1982 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_5], 1);
1983 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_1], 0);
1988 static void cdns_torrent_refclk_driver_disable(struct clk_hw *hw)
1990 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw);
1992 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_1], 1);
1995 static int cdns_torrent_refclk_driver_is_enabled(struct clk_hw *hw)
1997 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw);
2000 regmap_field_read(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_1], &val);
2005 static u8 cdns_torrent_refclk_driver_get_parent(struct clk_hw *hw)
2007 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw);
2010 regmap_field_read(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_4], &val);
2011 return clk_mux_val_to_index(hw, cdns_torrent_refclk_driver_mux_table, 0, val);
2014 static int cdns_torrent_refclk_driver_set_parent(struct clk_hw *hw, u8 index)
2016 struct cdns_torrent_refclk_driver *refclk_driver = to_cdns_torrent_refclk_driver(hw);
2019 val = cdns_torrent_refclk_driver_mux_table[index];
2020 return regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_4], val);
2023 static const struct clk_ops cdns_torrent_refclk_driver_ops = {
2024 .enable = cdns_torrent_refclk_driver_enable,
2025 .disable = cdns_torrent_refclk_driver_disable,
2026 .is_enabled = cdns_torrent_refclk_driver_is_enabled,
2027 .determine_rate = __clk_mux_determine_rate,
2028 .set_parent = cdns_torrent_refclk_driver_set_parent,
2029 .get_parent = cdns_torrent_refclk_driver_get_parent,
2032 static int cdns_torrent_refclk_driver_register(struct cdns_torrent_phy *cdns_phy)
2034 struct cdns_torrent_refclk_driver *refclk_driver;
2035 struct device *dev = cdns_phy->dev;
2036 struct regmap_field *field;
2037 struct clk_init_data *init;
2038 const char **parent_names;
2039 unsigned int num_parents;
2040 struct regmap *regmap;
2045 refclk_driver = devm_kzalloc(dev, sizeof(*refclk_driver), GFP_KERNEL);
2049 num_parents = ARRAY_SIZE(refclk_driver_parent_index);
2050 parent_names = devm_kzalloc(dev, (sizeof(char *) * num_parents), GFP_KERNEL);
2054 for (i = 0; i < num_parents; i++) {
2055 hw = cdns_phy->clk_hw_data->hws[refclk_driver_parent_index[i]];
2056 if (IS_ERR_OR_NULL(hw)) {
2057 dev_err(dev, "No parent clock for refclk driver clock\n");
2058 return IS_ERR(hw) ? PTR_ERR(hw) : -ENOENT;
2060 parent_names[i] = clk_hw_get_name(hw);
2063 snprintf(clk_name, sizeof(clk_name), "%s_%s", dev_name(dev),
2064 clk_names[CDNS_TORRENT_REFCLK_DRIVER]);
2066 init = &refclk_driver->clk_data;
2068 init->ops = &cdns_torrent_refclk_driver_ops;
2069 init->flags = CLK_SET_RATE_NO_REPARENT;
2070 init->parent_names = parent_names;
2071 init->num_parents = num_parents;
2072 init->name = clk_name;
2074 regmap = cdns_phy->regmap_common_cdb;
2076 for (i = 0; i < REFCLK_OUT_NUM_CMN_CONFIG; i++) {
2077 field = devm_regmap_field_alloc(dev, regmap, refclk_out_cmn_cfg[i]);
2078 if (IS_ERR(field)) {
2079 dev_err(dev, "Refclk driver CMN reg field init failed\n");
2080 return PTR_ERR(field);
2082 refclk_driver->cmn_fields[i] = field;
2085 /* Enable Derived reference clock as default */
2086 regmap_field_write(refclk_driver->cmn_fields[CMN_CDIAG_REFCLK_DRV0_CTRL_4], 1);
2088 refclk_driver->hw.init = init;
2090 hw = &refclk_driver->hw;
2091 ret = devm_clk_hw_register(dev, hw);
2095 cdns_phy->clk_hw_data->hws[CDNS_TORRENT_REFCLK_DRIVER] = hw;
2100 static struct regmap *cdns_regmap_init(struct device *dev, void __iomem *base,
2102 u8 reg_offset_shift,
2103 const struct regmap_config *config)
2105 struct cdns_regmap_cdb_context *ctx;
2107 ctx = devm_kzalloc(dev, sizeof(*ctx), GFP_KERNEL);
2109 return ERR_PTR(-ENOMEM);
2112 ctx->base = base + block_offset;
2113 ctx->reg_offset_shift = reg_offset_shift;
2115 return devm_regmap_init(dev, NULL, ctx, config);
2118 static int cdns_torrent_dp_regfield_init(struct cdns_torrent_phy *cdns_phy)
2120 struct device *dev = cdns_phy->dev;
2121 struct regmap_field *field;
2122 struct regmap *regmap;
2124 regmap = cdns_phy->regmap_dptx_phy_reg;
2125 field = devm_regmap_field_alloc(dev, regmap, phy_reset_ctrl);
2126 if (IS_ERR(field)) {
2127 dev_err(dev, "PHY_RESET reg field init failed\n");
2128 return PTR_ERR(field);
2130 cdns_phy->phy_reset_ctrl = field;
2135 static int cdns_torrent_regfield_init(struct cdns_torrent_phy *cdns_phy)
2137 struct device *dev = cdns_phy->dev;
2138 struct regmap_field *field;
2139 struct regmap *regmap;
2142 regmap = cdns_phy->regmap_phy_pcs_common_cdb;
2143 field = devm_regmap_field_alloc(dev, regmap, phy_pll_cfg);
2144 if (IS_ERR(field)) {
2145 dev_err(dev, "PHY_PLL_CFG reg field init failed\n");
2146 return PTR_ERR(field);
2148 cdns_phy->phy_pll_cfg = field;
2150 regmap = cdns_phy->regmap_phy_pcs_common_cdb;
2151 field = devm_regmap_field_alloc(dev, regmap, phy_pipe_cmn_ctrl1_0);
2152 if (IS_ERR(field)) {
2153 dev_err(dev, "phy_pipe_cmn_ctrl1_0 reg field init failed\n");
2154 return PTR_ERR(field);
2156 cdns_phy->phy_pipe_cmn_ctrl1_0 = field;
2158 regmap = cdns_phy->regmap_common_cdb;
2159 field = devm_regmap_field_alloc(dev, regmap, cmn_cdiag_refclk_ovrd_4);
2160 if (IS_ERR(field)) {
2161 dev_err(dev, "cmn_cdiag_refclk_ovrd_4 reg field init failed\n");
2162 return PTR_ERR(field);
2164 cdns_phy->cmn_cdiag_refclk_ovrd_4 = field;
2166 regmap = cdns_phy->regmap_phy_pma_common_cdb;
2167 field = devm_regmap_field_alloc(dev, regmap, phy_pma_cmn_ctrl_1);
2168 if (IS_ERR(field)) {
2169 dev_err(dev, "PHY_PMA_CMN_CTRL1 reg field init failed\n");
2170 return PTR_ERR(field);
2172 cdns_phy->phy_pma_cmn_ctrl_1 = field;
2174 regmap = cdns_phy->regmap_phy_pma_common_cdb;
2175 field = devm_regmap_field_alloc(dev, regmap, phy_pma_cmn_ctrl_2);
2176 if (IS_ERR(field)) {
2177 dev_err(dev, "PHY_PMA_CMN_CTRL2 reg field init failed\n");
2178 return PTR_ERR(field);
2180 cdns_phy->phy_pma_cmn_ctrl_2 = field;
2182 regmap = cdns_phy->regmap_phy_pma_common_cdb;
2183 field = devm_regmap_field_alloc(dev, regmap, phy_pma_pll_raw_ctrl);
2184 if (IS_ERR(field)) {
2185 dev_err(dev, "PHY_PMA_PLL_RAW_CTRL reg field init failed\n");
2186 return PTR_ERR(field);
2188 cdns_phy->phy_pma_pll_raw_ctrl = field;
2190 for (i = 0; i < MAX_NUM_LANES; i++) {
2191 regmap = cdns_phy->regmap_phy_pcs_lane_cdb[i];
2192 field = devm_regmap_field_alloc(dev, regmap, phy_pcs_iso_link_ctrl_1);
2193 if (IS_ERR(field)) {
2194 dev_err(dev, "PHY_PCS_ISO_LINK_CTRL reg field init for ln %d failed\n", i);
2195 return PTR_ERR(field);
2197 cdns_phy->phy_pcs_iso_link_ctrl_1[i] = field;
2203 static int cdns_torrent_dp_regmap_init(struct cdns_torrent_phy *cdns_phy)
2205 void __iomem *base = cdns_phy->base;
2206 struct device *dev = cdns_phy->dev;
2207 struct regmap *regmap;
2208 u8 reg_offset_shift;
2211 reg_offset_shift = cdns_phy->init_data->reg_offset_shift;
2213 block_offset = TORRENT_DPTX_PHY_OFFSET;
2214 regmap = cdns_regmap_init(dev, base, block_offset,
2216 &cdns_torrent_dptx_phy_config);
2217 if (IS_ERR(regmap)) {
2218 dev_err(dev, "Failed to init DPTX PHY regmap\n");
2219 return PTR_ERR(regmap);
2221 cdns_phy->regmap_dptx_phy_reg = regmap;
2226 static int cdns_torrent_regmap_init(struct cdns_torrent_phy *cdns_phy)
2228 void __iomem *sd_base = cdns_phy->sd_base;
2229 u8 block_offset_shift, reg_offset_shift;
2230 struct device *dev = cdns_phy->dev;
2231 struct regmap *regmap;
2235 block_offset_shift = cdns_phy->init_data->block_offset_shift;
2236 reg_offset_shift = cdns_phy->init_data->reg_offset_shift;
2238 for (i = 0; i < MAX_NUM_LANES; i++) {
2239 block_offset = TORRENT_TX_LANE_CDB_OFFSET(i, block_offset_shift,
2241 regmap = cdns_regmap_init(dev, sd_base, block_offset,
2243 &cdns_torrent_tx_lane_cdb_config[i]);
2244 if (IS_ERR(regmap)) {
2245 dev_err(dev, "Failed to init tx lane CDB regmap\n");
2246 return PTR_ERR(regmap);
2248 cdns_phy->regmap_tx_lane_cdb[i] = regmap;
2250 block_offset = TORRENT_RX_LANE_CDB_OFFSET(i, block_offset_shift,
2252 regmap = cdns_regmap_init(dev, sd_base, block_offset,
2254 &cdns_torrent_rx_lane_cdb_config[i]);
2255 if (IS_ERR(regmap)) {
2256 dev_err(dev, "Failed to init rx lane CDB regmap\n");
2257 return PTR_ERR(regmap);
2259 cdns_phy->regmap_rx_lane_cdb[i] = regmap;
2261 block_offset = TORRENT_PHY_PCS_LANE_CDB_OFFSET(i, block_offset_shift,
2263 regmap = cdns_regmap_init(dev, sd_base, block_offset,
2265 &cdns_torrent_phy_pcs_lane_cdb_config[i]);
2266 if (IS_ERR(regmap)) {
2267 dev_err(dev, "Failed to init PHY PCS lane CDB regmap\n");
2268 return PTR_ERR(regmap);
2270 cdns_phy->regmap_phy_pcs_lane_cdb[i] = regmap;
2273 block_offset = TORRENT_COMMON_CDB_OFFSET;
2274 regmap = cdns_regmap_init(dev, sd_base, block_offset,
2276 &cdns_torrent_common_cdb_config);
2277 if (IS_ERR(regmap)) {
2278 dev_err(dev, "Failed to init common CDB regmap\n");
2279 return PTR_ERR(regmap);
2281 cdns_phy->regmap_common_cdb = regmap;
2283 block_offset = TORRENT_PHY_PCS_COMMON_OFFSET(block_offset_shift);
2284 regmap = cdns_regmap_init(dev, sd_base, block_offset,
2286 &cdns_torrent_phy_pcs_cmn_cdb_config);
2287 if (IS_ERR(regmap)) {
2288 dev_err(dev, "Failed to init PHY PCS common CDB regmap\n");
2289 return PTR_ERR(regmap);
2291 cdns_phy->regmap_phy_pcs_common_cdb = regmap;
2293 block_offset = TORRENT_PHY_PMA_COMMON_OFFSET(block_offset_shift);
2294 regmap = cdns_regmap_init(dev, sd_base, block_offset,
2296 &cdns_torrent_phy_pma_cmn_cdb_config);
2297 if (IS_ERR(regmap)) {
2298 dev_err(dev, "Failed to init PHY PMA common CDB regmap\n");
2299 return PTR_ERR(regmap);
2301 cdns_phy->regmap_phy_pma_common_cdb = regmap;
2306 static int cdns_torrent_phy_init(struct phy *phy)
2308 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
2309 const struct cdns_torrent_data *init_data = cdns_phy->init_data;
2310 struct cdns_torrent_vals *cmn_vals, *tx_ln_vals, *rx_ln_vals;
2311 enum cdns_torrent_ref_clk ref_clk = cdns_phy->ref_clk_rate;
2312 struct cdns_torrent_vals *link_cmn_vals, *xcvr_diag_vals;
2313 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
2314 enum cdns_torrent_phy_type phy_type = inst->phy_type;
2315 enum cdns_torrent_ssc_mode ssc = inst->ssc_mode;
2316 struct cdns_torrent_vals *phy_pma_cmn_vals;
2317 struct cdns_torrent_vals *pcs_cmn_vals;
2318 struct cdns_reg_pairs *reg_pairs;
2319 struct regmap *regmap;
2323 if (cdns_phy->already_configured)
2326 if (cdns_phy->nsubnodes > 1) {
2327 if (phy_type == TYPE_DP)
2328 return cdns_torrent_dp_multilink_init(cdns_phy, inst, phy);
2333 * Spread spectrum generation is not required or supported
2334 * for SGMII/QSGMII/USXGMII
2336 if (phy_type == TYPE_SGMII || phy_type == TYPE_QSGMII || phy_type == TYPE_USXGMII)
2339 /* PHY configuration specific registers for single link */
2340 link_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->link_cmn_vals_tbl,
2342 phy_type, TYPE_NONE,
2344 if (link_cmn_vals) {
2345 reg_pairs = link_cmn_vals->reg_pairs;
2346 num_regs = link_cmn_vals->num_regs;
2347 regmap = cdns_phy->regmap_common_cdb;
2350 * First array value in link_cmn_vals must be of
2351 * PHY_PLL_CFG register
2353 regmap_field_write(cdns_phy->phy_pll_cfg, reg_pairs[0].val);
2355 for (i = 1; i < num_regs; i++)
2356 regmap_write(regmap, reg_pairs[i].off,
2360 xcvr_diag_vals = cdns_torrent_get_tbl_vals(&init_data->xcvr_diag_vals_tbl,
2362 phy_type, TYPE_NONE,
2364 if (xcvr_diag_vals) {
2365 reg_pairs = xcvr_diag_vals->reg_pairs;
2366 num_regs = xcvr_diag_vals->num_regs;
2367 for (i = 0; i < inst->num_lanes; i++) {
2368 regmap = cdns_phy->regmap_tx_lane_cdb[i + inst->mlane];
2369 for (j = 0; j < num_regs; j++)
2370 regmap_write(regmap, reg_pairs[j].off,
2375 /* PHY PCS common registers configurations */
2376 pcs_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->pcs_cmn_vals_tbl,
2378 phy_type, TYPE_NONE,
2381 reg_pairs = pcs_cmn_vals->reg_pairs;
2382 num_regs = pcs_cmn_vals->num_regs;
2383 regmap = cdns_phy->regmap_phy_pcs_common_cdb;
2384 for (i = 0; i < num_regs; i++)
2385 regmap_write(regmap, reg_pairs[i].off,
2389 /* PHY PMA common registers configurations */
2390 phy_pma_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->phy_pma_cmn_vals_tbl,
2392 phy_type, TYPE_NONE,
2394 if (phy_pma_cmn_vals) {
2395 reg_pairs = phy_pma_cmn_vals->reg_pairs;
2396 num_regs = phy_pma_cmn_vals->num_regs;
2397 regmap = cdns_phy->regmap_phy_pma_common_cdb;
2398 for (i = 0; i < num_regs; i++)
2399 regmap_write(regmap, reg_pairs[i].off,
2403 /* PMA common registers configurations */
2404 cmn_vals = cdns_torrent_get_tbl_vals(&init_data->cmn_vals_tbl,
2406 phy_type, TYPE_NONE,
2409 reg_pairs = cmn_vals->reg_pairs;
2410 num_regs = cmn_vals->num_regs;
2411 regmap = cdns_phy->regmap_common_cdb;
2412 for (i = 0; i < num_regs; i++)
2413 regmap_write(regmap, reg_pairs[i].off,
2417 /* PMA TX lane registers configurations */
2418 tx_ln_vals = cdns_torrent_get_tbl_vals(&init_data->tx_ln_vals_tbl,
2420 phy_type, TYPE_NONE,
2423 reg_pairs = tx_ln_vals->reg_pairs;
2424 num_regs = tx_ln_vals->num_regs;
2425 for (i = 0; i < inst->num_lanes; i++) {
2426 regmap = cdns_phy->regmap_tx_lane_cdb[i + inst->mlane];
2427 for (j = 0; j < num_regs; j++)
2428 regmap_write(regmap, reg_pairs[j].off,
2433 /* PMA RX lane registers configurations */
2434 rx_ln_vals = cdns_torrent_get_tbl_vals(&init_data->rx_ln_vals_tbl,
2436 phy_type, TYPE_NONE,
2439 reg_pairs = rx_ln_vals->reg_pairs;
2440 num_regs = rx_ln_vals->num_regs;
2441 for (i = 0; i < inst->num_lanes; i++) {
2442 regmap = cdns_phy->regmap_rx_lane_cdb[i + inst->mlane];
2443 for (j = 0; j < num_regs; j++)
2444 regmap_write(regmap, reg_pairs[j].off,
2449 if (phy_type == TYPE_DP)
2450 return cdns_torrent_dp_init(phy);
2455 static const struct phy_ops cdns_torrent_phy_ops = {
2456 .init = cdns_torrent_phy_init,
2457 .configure = cdns_torrent_dp_configure,
2458 .power_on = cdns_torrent_phy_on,
2459 .power_off = cdns_torrent_phy_off,
2460 .owner = THIS_MODULE,
2464 int cdns_torrent_phy_configure_multilink(struct cdns_torrent_phy *cdns_phy)
2466 const struct cdns_torrent_data *init_data = cdns_phy->init_data;
2467 struct cdns_torrent_vals *cmn_vals, *tx_ln_vals, *rx_ln_vals;
2468 enum cdns_torrent_ref_clk ref_clk1 = cdns_phy->ref_clk1_rate;
2469 enum cdns_torrent_ref_clk ref_clk = cdns_phy->ref_clk_rate;
2470 struct cdns_torrent_vals *link_cmn_vals, *xcvr_diag_vals;
2471 enum cdns_torrent_phy_type phy_t1, phy_t2;
2472 struct cdns_torrent_vals *phy_pma_cmn_vals;
2473 struct cdns_torrent_vals *pcs_cmn_vals;
2474 int i, j, node, mlane, num_lanes, ret;
2475 struct cdns_reg_pairs *reg_pairs;
2476 enum cdns_torrent_ssc_mode ssc;
2477 struct regmap *regmap;
2480 /* Maximum 2 links (subnodes) are supported */
2481 if (cdns_phy->nsubnodes != 2)
2484 phy_t1 = cdns_phy->phys[0].phy_type;
2485 phy_t2 = cdns_phy->phys[1].phy_type;
2488 * First configure the PHY for first link with phy_t1. Get the array
2489 * values as [phy_t1][phy_t2][ssc].
2491 for (node = 0; node < cdns_phy->nsubnodes; node++) {
2494 * If first link with phy_t1 is configured, then
2495 * configure the PHY for second link with phy_t2.
2496 * Get the array values as [phy_t2][phy_t1][ssc].
2498 swap(phy_t1, phy_t2);
2499 swap(ref_clk, ref_clk1);
2502 mlane = cdns_phy->phys[node].mlane;
2503 ssc = cdns_phy->phys[node].ssc_mode;
2504 num_lanes = cdns_phy->phys[node].num_lanes;
2507 * PHY configuration specific registers:
2508 * link_cmn_vals depend on combination of PHY types being
2509 * configured and are common for both PHY types, so array
2510 * values should be same for [phy_t1][phy_t2][ssc] and
2511 * [phy_t2][phy_t1][ssc].
2512 * xcvr_diag_vals also depend on combination of PHY types
2513 * being configured, but these can be different for particular
2514 * PHY type and are per lane.
2516 link_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->link_cmn_vals_tbl,
2518 phy_t1, phy_t2, ANY_SSC);
2519 if (link_cmn_vals) {
2520 reg_pairs = link_cmn_vals->reg_pairs;
2521 num_regs = link_cmn_vals->num_regs;
2522 regmap = cdns_phy->regmap_common_cdb;
2525 * First array value in link_cmn_vals must be of
2526 * PHY_PLL_CFG register
2528 regmap_field_write(cdns_phy->phy_pll_cfg,
2531 for (i = 1; i < num_regs; i++)
2532 regmap_write(regmap, reg_pairs[i].off,
2536 xcvr_diag_vals = cdns_torrent_get_tbl_vals(&init_data->xcvr_diag_vals_tbl,
2538 phy_t1, phy_t2, ANY_SSC);
2539 if (xcvr_diag_vals) {
2540 reg_pairs = xcvr_diag_vals->reg_pairs;
2541 num_regs = xcvr_diag_vals->num_regs;
2542 for (i = 0; i < num_lanes; i++) {
2543 regmap = cdns_phy->regmap_tx_lane_cdb[i + mlane];
2544 for (j = 0; j < num_regs; j++)
2545 regmap_write(regmap, reg_pairs[j].off,
2550 /* PHY PCS common registers configurations */
2551 pcs_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->pcs_cmn_vals_tbl,
2553 phy_t1, phy_t2, ANY_SSC);
2555 reg_pairs = pcs_cmn_vals->reg_pairs;
2556 num_regs = pcs_cmn_vals->num_regs;
2557 regmap = cdns_phy->regmap_phy_pcs_common_cdb;
2558 for (i = 0; i < num_regs; i++)
2559 regmap_write(regmap, reg_pairs[i].off,
2563 /* PHY PMA common registers configurations */
2564 phy_pma_cmn_vals = cdns_torrent_get_tbl_vals(&init_data->phy_pma_cmn_vals_tbl,
2566 phy_t1, phy_t2, ANY_SSC);
2567 if (phy_pma_cmn_vals) {
2568 reg_pairs = phy_pma_cmn_vals->reg_pairs;
2569 num_regs = phy_pma_cmn_vals->num_regs;
2570 regmap = cdns_phy->regmap_phy_pma_common_cdb;
2571 for (i = 0; i < num_regs; i++)
2572 regmap_write(regmap, reg_pairs[i].off,
2576 /* PMA common registers configurations */
2577 cmn_vals = cdns_torrent_get_tbl_vals(&init_data->cmn_vals_tbl,
2579 phy_t1, phy_t2, ssc);
2581 reg_pairs = cmn_vals->reg_pairs;
2582 num_regs = cmn_vals->num_regs;
2583 regmap = cdns_phy->regmap_common_cdb;
2584 for (i = 0; i < num_regs; i++)
2585 regmap_write(regmap, reg_pairs[i].off,
2589 /* PMA TX lane registers configurations */
2590 tx_ln_vals = cdns_torrent_get_tbl_vals(&init_data->tx_ln_vals_tbl,
2592 phy_t1, phy_t2, ssc);
2594 reg_pairs = tx_ln_vals->reg_pairs;
2595 num_regs = tx_ln_vals->num_regs;
2596 for (i = 0; i < num_lanes; i++) {
2597 regmap = cdns_phy->regmap_tx_lane_cdb[i + mlane];
2598 for (j = 0; j < num_regs; j++)
2599 regmap_write(regmap, reg_pairs[j].off,
2604 /* PMA RX lane registers configurations */
2605 rx_ln_vals = cdns_torrent_get_tbl_vals(&init_data->rx_ln_vals_tbl,
2607 phy_t1, phy_t2, ssc);
2609 reg_pairs = rx_ln_vals->reg_pairs;
2610 num_regs = rx_ln_vals->num_regs;
2611 for (i = 0; i < num_lanes; i++) {
2612 regmap = cdns_phy->regmap_rx_lane_cdb[i + mlane];
2613 for (j = 0; j < num_regs; j++)
2614 regmap_write(regmap, reg_pairs[j].off,
2619 if (phy_t1 == TYPE_DP) {
2620 ret = cdns_torrent_dp_get_pll(cdns_phy, phy_t2);
2625 reset_control_deassert(cdns_phy->phys[node].lnk_rst);
2628 /* Take the PHY out of reset */
2629 ret = reset_control_deassert(cdns_phy->phy_rst);
2636 static void cdns_torrent_clk_cleanup(struct cdns_torrent_phy *cdns_phy)
2638 struct device *dev = cdns_phy->dev;
2640 of_clk_del_provider(dev->of_node);
2643 static int cdns_torrent_clk_register(struct cdns_torrent_phy *cdns_phy)
2645 struct device *dev = cdns_phy->dev;
2646 struct device_node *node = dev->of_node;
2647 struct clk_hw_onecell_data *data;
2650 data = devm_kzalloc(dev, struct_size(data, hws, CDNS_TORRENT_OUTPUT_CLOCKS), GFP_KERNEL);
2654 data->num = CDNS_TORRENT_OUTPUT_CLOCKS;
2655 cdns_phy->clk_hw_data = data;
2657 ret = cdns_torrent_derived_refclk_register(cdns_phy);
2659 dev_err(dev, "failed to register derived refclk\n");
2663 ret = cdns_torrent_received_refclk_register(cdns_phy);
2665 dev_err(dev, "failed to register received refclk\n");
2669 ret = cdns_torrent_refclk_driver_register(cdns_phy);
2671 dev_err(dev, "failed to register refclk driver\n");
2675 ret = of_clk_add_hw_provider(node, of_clk_hw_onecell_get, data);
2677 dev_err(dev, "Failed to add clock provider: %s\n", node->name);
2684 static int cdns_torrent_of_get_reset(struct cdns_torrent_phy *cdns_phy)
2686 struct device *dev = cdns_phy->dev;
2688 cdns_phy->phy_rst = devm_reset_control_get_exclusive_by_index(dev, 0);
2689 if (IS_ERR(cdns_phy->phy_rst)) {
2690 dev_err(dev, "%s: failed to get reset\n",
2691 dev->of_node->full_name);
2692 return PTR_ERR(cdns_phy->phy_rst);
2695 cdns_phy->apb_rst = devm_reset_control_get_optional_exclusive(dev, "torrent_apb");
2696 if (IS_ERR(cdns_phy->apb_rst)) {
2697 dev_err(dev, "%s: failed to get apb reset\n",
2698 dev->of_node->full_name);
2699 return PTR_ERR(cdns_phy->apb_rst);
2705 static int cdns_torrent_of_get_clk(struct cdns_torrent_phy *cdns_phy)
2707 /* refclk: Input reference clock for PLL0 */
2708 cdns_phy->clk = devm_clk_get(cdns_phy->dev, "refclk");
2709 if (IS_ERR(cdns_phy->clk))
2710 return dev_err_probe(cdns_phy->dev, PTR_ERR(cdns_phy->clk),
2711 "phy ref clock not found\n");
2713 /* refclk1: Input reference clock for PLL1 */
2714 cdns_phy->clk1 = devm_clk_get_optional(cdns_phy->dev, "pll1_refclk");
2715 if (IS_ERR(cdns_phy->clk1))
2716 return dev_err_probe(cdns_phy->dev, PTR_ERR(cdns_phy->clk1),
2717 "phy PLL1 ref clock not found\n");
2722 static int cdns_torrent_clk(struct cdns_torrent_phy *cdns_phy)
2724 unsigned long ref_clk1_rate;
2725 unsigned long ref_clk_rate;
2728 ret = clk_prepare_enable(cdns_phy->clk);
2730 dev_err(cdns_phy->dev, "Failed to prepare ref clock: %d\n", ret);
2734 ref_clk_rate = clk_get_rate(cdns_phy->clk);
2735 if (!ref_clk_rate) {
2736 dev_err(cdns_phy->dev, "Failed to get ref clock rate\n");
2741 switch (ref_clk_rate) {
2742 case REF_CLK_19_2MHZ:
2743 cdns_phy->ref_clk_rate = CLK_19_2_MHZ;
2746 cdns_phy->ref_clk_rate = CLK_25_MHZ;
2748 case REF_CLK_100MHZ:
2749 cdns_phy->ref_clk_rate = CLK_100_MHZ;
2751 case REF_CLK_156_25MHZ:
2752 cdns_phy->ref_clk_rate = CLK_156_25_MHZ;
2755 dev_err(cdns_phy->dev, "Invalid ref clock rate\n");
2760 if (cdns_phy->clk1) {
2761 ret = clk_prepare_enable(cdns_phy->clk1);
2763 dev_err(cdns_phy->dev, "Failed to prepare PLL1 ref clock: %d\n", ret);
2767 ref_clk1_rate = clk_get_rate(cdns_phy->clk1);
2768 if (!ref_clk1_rate) {
2769 dev_err(cdns_phy->dev, "Failed to get PLL1 ref clock rate\n");
2774 switch (ref_clk1_rate) {
2775 case REF_CLK_19_2MHZ:
2776 cdns_phy->ref_clk1_rate = CLK_19_2_MHZ;
2779 cdns_phy->ref_clk1_rate = CLK_25_MHZ;
2781 case REF_CLK_100MHZ:
2782 cdns_phy->ref_clk1_rate = CLK_100_MHZ;
2784 case REF_CLK_156_25MHZ:
2785 cdns_phy->ref_clk1_rate = CLK_156_25_MHZ;
2788 dev_err(cdns_phy->dev, "Invalid PLL1 ref clock rate\n");
2793 cdns_phy->ref_clk1_rate = cdns_phy->ref_clk_rate;
2799 clk_disable_unprepare(cdns_phy->clk1);
2801 clk_disable_unprepare(cdns_phy->clk);
2805 static int cdns_torrent_phy_probe(struct platform_device *pdev)
2807 struct cdns_torrent_phy *cdns_phy;
2808 struct device *dev = &pdev->dev;
2809 struct phy_provider *phy_provider;
2810 const struct cdns_torrent_data *data;
2811 struct device_node *child;
2812 int ret, subnodes, node = 0, i;
2813 u32 total_num_lanes = 0;
2814 u8 init_dp_regmap = 0;
2817 /* Get init data for this PHY */
2818 data = of_device_get_match_data(dev);
2822 cdns_phy = devm_kzalloc(dev, sizeof(*cdns_phy), GFP_KERNEL);
2826 dev_set_drvdata(dev, cdns_phy);
2827 cdns_phy->dev = dev;
2828 cdns_phy->init_data = data;
2830 cdns_phy->sd_base = devm_platform_ioremap_resource(pdev, 0);
2831 if (IS_ERR(cdns_phy->sd_base))
2832 return PTR_ERR(cdns_phy->sd_base);
2834 subnodes = of_get_available_child_count(dev->of_node);
2835 if (subnodes == 0) {
2836 dev_err(dev, "No available link subnodes found\n");
2840 ret = cdns_torrent_regmap_init(cdns_phy);
2844 ret = cdns_torrent_regfield_init(cdns_phy);
2848 ret = cdns_torrent_clk_register(cdns_phy);
2852 ret = cdns_torrent_of_get_reset(cdns_phy);
2856 ret = cdns_torrent_of_get_clk(cdns_phy);
2860 regmap_field_read(cdns_phy->phy_pma_cmn_ctrl_1, &cdns_phy->already_configured);
2862 if (!cdns_phy->already_configured) {
2863 ret = cdns_torrent_clk(cdns_phy);
2868 reset_control_deassert(cdns_phy->apb_rst);
2871 for_each_available_child_of_node(dev->of_node, child) {
2874 /* PHY subnode name must be 'phy'. */
2875 if (!(of_node_name_eq(child, "phy")))
2878 cdns_phy->phys[node].lnk_rst =
2879 of_reset_control_array_get_exclusive(child);
2880 if (IS_ERR(cdns_phy->phys[node].lnk_rst)) {
2881 dev_err(dev, "%s: failed to get reset\n",
2883 ret = PTR_ERR(cdns_phy->phys[node].lnk_rst);
2887 if (of_property_read_u32(child, "reg",
2888 &cdns_phy->phys[node].mlane)) {
2889 dev_err(dev, "%s: No \"reg\"-property.\n",
2895 if (of_property_read_u32(child, "cdns,phy-type", &phy_type)) {
2896 dev_err(dev, "%s: No \"cdns,phy-type\"-property.\n",
2904 cdns_phy->phys[node].phy_type = TYPE_PCIE;
2907 cdns_phy->phys[node].phy_type = TYPE_DP;
2909 case PHY_TYPE_SGMII:
2910 cdns_phy->phys[node].phy_type = TYPE_SGMII;
2912 case PHY_TYPE_QSGMII:
2913 cdns_phy->phys[node].phy_type = TYPE_QSGMII;
2916 cdns_phy->phys[node].phy_type = TYPE_USB;
2918 case PHY_TYPE_USXGMII:
2919 cdns_phy->phys[node].phy_type = TYPE_USXGMII;
2922 dev_err(dev, "Unsupported protocol\n");
2927 if (of_property_read_u32(child, "cdns,num-lanes",
2928 &cdns_phy->phys[node].num_lanes)) {
2929 dev_err(dev, "%s: No \"cdns,num-lanes\"-property.\n",
2935 total_num_lanes += cdns_phy->phys[node].num_lanes;
2938 cdns_phy->phys[node].ssc_mode = NO_SSC;
2939 of_property_read_u32(child, "cdns,ssc-mode",
2940 &cdns_phy->phys[node].ssc_mode);
2942 gphy = devm_phy_create(dev, child, &cdns_torrent_phy_ops);
2944 ret = PTR_ERR(gphy);
2948 if (cdns_phy->phys[node].phy_type == TYPE_DP) {
2949 switch (cdns_phy->phys[node].num_lanes) {
2953 /* valid number of lanes */
2956 dev_err(dev, "unsupported number of lanes: %d\n",
2957 cdns_phy->phys[node].num_lanes);
2962 cdns_phy->max_bit_rate = DEFAULT_MAX_BIT_RATE;
2963 of_property_read_u32(child, "cdns,max-bit-rate",
2964 &cdns_phy->max_bit_rate);
2966 switch (cdns_phy->max_bit_rate) {
2975 /* valid bit rate */
2978 dev_err(dev, "unsupported max bit rate: %dMbps\n",
2979 cdns_phy->max_bit_rate);
2984 /* DPTX registers */
2985 cdns_phy->base = devm_platform_ioremap_resource(pdev, 1);
2986 if (IS_ERR(cdns_phy->base)) {
2987 ret = PTR_ERR(cdns_phy->base);
2991 if (!init_dp_regmap) {
2992 ret = cdns_torrent_dp_regmap_init(cdns_phy);
2996 ret = cdns_torrent_dp_regfield_init(cdns_phy);
3003 dev_dbg(dev, "DP max bit rate %d.%03d Gbps\n",
3004 cdns_phy->max_bit_rate / 1000,
3005 cdns_phy->max_bit_rate % 1000);
3007 gphy->attrs.bus_width = cdns_phy->phys[node].num_lanes;
3008 gphy->attrs.max_link_rate = cdns_phy->max_bit_rate;
3009 gphy->attrs.mode = PHY_MODE_DP;
3012 cdns_phy->phys[node].phy = gphy;
3013 phy_set_drvdata(gphy, &cdns_phy->phys[node]);
3017 cdns_phy->nsubnodes = node;
3019 if (total_num_lanes > MAX_NUM_LANES) {
3020 dev_err(dev, "Invalid lane configuration\n");
3025 if (cdns_phy->nsubnodes > 1 && !cdns_phy->already_configured) {
3026 ret = cdns_torrent_phy_configure_multilink(cdns_phy);
3031 phy_provider = devm_of_phy_provider_register(dev, of_phy_simple_xlate);
3032 if (IS_ERR(phy_provider)) {
3033 ret = PTR_ERR(phy_provider);
3037 if (cdns_phy->nsubnodes > 1)
3038 dev_dbg(dev, "Multi-link: %s (%d lanes) & %s (%d lanes)",
3039 cdns_torrent_get_phy_type(cdns_phy->phys[0].phy_type),
3040 cdns_phy->phys[0].num_lanes,
3041 cdns_torrent_get_phy_type(cdns_phy->phys[1].phy_type),
3042 cdns_phy->phys[1].num_lanes);
3044 dev_dbg(dev, "Single link: %s (%d lanes)",
3045 cdns_torrent_get_phy_type(cdns_phy->phys[0].phy_type),
3046 cdns_phy->phys[0].num_lanes);
3053 for (i = 0; i < node; i++)
3054 reset_control_put(cdns_phy->phys[i].lnk_rst);
3056 reset_control_assert(cdns_phy->apb_rst);
3057 clk_disable_unprepare(cdns_phy->clk1);
3058 clk_disable_unprepare(cdns_phy->clk);
3060 cdns_torrent_clk_cleanup(cdns_phy);
3064 static void cdns_torrent_phy_remove(struct platform_device *pdev)
3066 struct cdns_torrent_phy *cdns_phy = platform_get_drvdata(pdev);
3069 reset_control_assert(cdns_phy->phy_rst);
3070 reset_control_assert(cdns_phy->apb_rst);
3071 for (i = 0; i < cdns_phy->nsubnodes; i++) {
3072 reset_control_assert(cdns_phy->phys[i].lnk_rst);
3073 reset_control_put(cdns_phy->phys[i].lnk_rst);
3076 clk_disable_unprepare(cdns_phy->clk1);
3077 clk_disable_unprepare(cdns_phy->clk);
3078 cdns_torrent_clk_cleanup(cdns_phy);
3081 /* SGMII and QSGMII link configuration */
3082 static struct cdns_reg_pairs sgmii_qsgmii_link_cmn_regs[] = {
3083 {0x0002, PHY_PLL_CFG}
3086 static struct cdns_reg_pairs sgmii_qsgmii_xcvr_diag_ln_regs[] = {
3087 {0x0003, XCVR_DIAG_HSCLK_DIV},
3088 {0x0113, XCVR_DIAG_PLLDRC_CTRL}
3091 static struct cdns_torrent_vals sgmii_qsgmii_link_cmn_vals = {
3092 .reg_pairs = sgmii_qsgmii_link_cmn_regs,
3093 .num_regs = ARRAY_SIZE(sgmii_qsgmii_link_cmn_regs),
3096 static struct cdns_torrent_vals sgmii_qsgmii_xcvr_diag_ln_vals = {
3097 .reg_pairs = sgmii_qsgmii_xcvr_diag_ln_regs,
3098 .num_regs = ARRAY_SIZE(sgmii_qsgmii_xcvr_diag_ln_regs),
3101 static int cdns_torrent_phy_suspend_noirq(struct device *dev)
3103 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(dev);
3106 reset_control_assert(cdns_phy->phy_rst);
3107 reset_control_assert(cdns_phy->apb_rst);
3108 for (i = 0; i < cdns_phy->nsubnodes; i++)
3109 reset_control_assert(cdns_phy->phys[i].lnk_rst);
3111 if (cdns_phy->already_configured)
3112 cdns_phy->already_configured = 0;
3114 clk_disable_unprepare(cdns_phy->clk1);
3115 clk_disable_unprepare(cdns_phy->clk);
3121 static int cdns_torrent_phy_resume_noirq(struct device *dev)
3123 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(dev);
3124 int node = cdns_phy->nsubnodes;
3127 ret = cdns_torrent_clk(cdns_phy);
3132 reset_control_deassert(cdns_phy->apb_rst);
3134 if (cdns_phy->nsubnodes > 1) {
3135 ret = cdns_torrent_phy_configure_multilink(cdns_phy);
3143 for (i = 0; i < node; i++)
3144 reset_control_assert(cdns_phy->phys[i].lnk_rst);
3145 reset_control_assert(cdns_phy->apb_rst);
3147 clk_disable_unprepare(cdns_phy->clk1);
3148 clk_disable_unprepare(cdns_phy->clk);
3153 static DEFINE_NOIRQ_DEV_PM_OPS(cdns_torrent_phy_pm_ops,
3154 cdns_torrent_phy_suspend_noirq,
3155 cdns_torrent_phy_resume_noirq);
3157 /* USB and DP link configuration */
3158 static struct cdns_reg_pairs usb_dp_link_cmn_regs[] = {
3159 {0x0002, PHY_PLL_CFG},
3160 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0}
3163 static struct cdns_reg_pairs usb_dp_xcvr_diag_ln_regs[] = {
3164 {0x0000, XCVR_DIAG_HSCLK_SEL},
3165 {0x0001, XCVR_DIAG_HSCLK_DIV},
3166 {0x0041, XCVR_DIAG_PLLDRC_CTRL}
3169 static struct cdns_reg_pairs dp_usb_xcvr_diag_ln_regs[] = {
3170 {0x0001, XCVR_DIAG_HSCLK_SEL},
3171 {0x0009, XCVR_DIAG_PLLDRC_CTRL}
3174 static struct cdns_torrent_vals usb_dp_link_cmn_vals = {
3175 .reg_pairs = usb_dp_link_cmn_regs,
3176 .num_regs = ARRAY_SIZE(usb_dp_link_cmn_regs),
3179 static struct cdns_torrent_vals usb_dp_xcvr_diag_ln_vals = {
3180 .reg_pairs = usb_dp_xcvr_diag_ln_regs,
3181 .num_regs = ARRAY_SIZE(usb_dp_xcvr_diag_ln_regs),
3184 static struct cdns_torrent_vals dp_usb_xcvr_diag_ln_vals = {
3185 .reg_pairs = dp_usb_xcvr_diag_ln_regs,
3186 .num_regs = ARRAY_SIZE(dp_usb_xcvr_diag_ln_regs),
3189 /* USXGMII and SGMII/QSGMII link configuration */
3190 static struct cdns_reg_pairs usxgmii_sgmii_link_cmn_regs[] = {
3191 {0x0002, PHY_PLL_CFG},
3192 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M0},
3193 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0}
3196 static struct cdns_reg_pairs usxgmii_sgmii_xcvr_diag_ln_regs[] = {
3197 {0x0000, XCVR_DIAG_HSCLK_SEL},
3198 {0x0001, XCVR_DIAG_HSCLK_DIV},
3199 {0x0001, XCVR_DIAG_PLLDRC_CTRL}
3202 static struct cdns_reg_pairs sgmii_usxgmii_xcvr_diag_ln_regs[] = {
3203 {0x0111, XCVR_DIAG_HSCLK_SEL},
3204 {0x0103, XCVR_DIAG_HSCLK_DIV},
3205 {0x0A9B, XCVR_DIAG_PLLDRC_CTRL}
3208 static struct cdns_torrent_vals usxgmii_sgmii_link_cmn_vals = {
3209 .reg_pairs = usxgmii_sgmii_link_cmn_regs,
3210 .num_regs = ARRAY_SIZE(usxgmii_sgmii_link_cmn_regs),
3213 static struct cdns_torrent_vals usxgmii_sgmii_xcvr_diag_ln_vals = {
3214 .reg_pairs = usxgmii_sgmii_xcvr_diag_ln_regs,
3215 .num_regs = ARRAY_SIZE(usxgmii_sgmii_xcvr_diag_ln_regs),
3218 static struct cdns_torrent_vals sgmii_usxgmii_xcvr_diag_ln_vals = {
3219 .reg_pairs = sgmii_usxgmii_xcvr_diag_ln_regs,
3220 .num_regs = ARRAY_SIZE(sgmii_usxgmii_xcvr_diag_ln_regs),
3223 /* Multilink USXGMII, using PLL0, 156.25 MHz Ref clk, no SSC */
3224 static struct cdns_reg_pairs ml_usxgmii_pll0_156_25_no_ssc_cmn_regs[] = {
3225 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0},
3226 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0},
3227 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR},
3228 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR},
3229 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START},
3230 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START},
3231 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
3232 {0x0138, CMN_PLL0_LOCK_REFCNT_START},
3233 {0x0138, CMN_PLL0_LOCK_PLLCNT_START}
3236 static struct cdns_torrent_vals ml_usxgmii_pll0_156_25_no_ssc_cmn_vals = {
3237 .reg_pairs = ml_usxgmii_pll0_156_25_no_ssc_cmn_regs,
3238 .num_regs = ARRAY_SIZE(ml_usxgmii_pll0_156_25_no_ssc_cmn_regs),
3241 /* Multilink SGMII/QSGMII, using PLL1, 100 MHz Ref clk, no SSC */
3242 static struct cdns_reg_pairs ml_sgmii_pll1_100_no_ssc_cmn_regs[] = {
3243 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0},
3244 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0},
3245 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0},
3246 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
3247 {0x007F, CMN_TXPUCAL_TUNE},
3248 {0x007F, CMN_TXPDCAL_TUNE}
3251 static struct cdns_torrent_vals ml_sgmii_pll1_100_no_ssc_cmn_vals = {
3252 .reg_pairs = ml_sgmii_pll1_100_no_ssc_cmn_regs,
3253 .num_regs = ARRAY_SIZE(ml_sgmii_pll1_100_no_ssc_cmn_regs),
3256 /* TI J7200, Multilink USXGMII, using PLL0, 156.25 MHz Ref clk, no SSC */
3257 static struct cdns_reg_pairs j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs[] = {
3258 {0x0014, CMN_SSM_BIAS_TMR},
3259 {0x0028, CMN_PLLSM0_PLLPRE_TMR},
3260 {0x00A4, CMN_PLLSM0_PLLLOCK_TMR},
3261 {0x0062, CMN_BGCAL_INIT_TMR},
3262 {0x0062, CMN_BGCAL_ITER_TMR},
3263 {0x0014, CMN_IBCAL_INIT_TMR},
3264 {0x0018, CMN_TXPUCAL_INIT_TMR},
3265 {0x0005, CMN_TXPUCAL_ITER_TMR},
3266 {0x0018, CMN_TXPDCAL_INIT_TMR},
3267 {0x0005, CMN_TXPDCAL_ITER_TMR},
3268 {0x024A, CMN_RXCAL_INIT_TMR},
3269 {0x0005, CMN_RXCAL_ITER_TMR},
3270 {0x000B, CMN_SD_CAL_REFTIM_START},
3271 {0x0132, CMN_SD_CAL_PLLCNT_START},
3272 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0},
3273 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0},
3274 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR},
3275 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR},
3276 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START},
3277 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START},
3278 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
3279 {0x0138, CMN_PLL0_LOCK_REFCNT_START},
3280 {0x0138, CMN_PLL0_LOCK_PLLCNT_START}
3283 static struct cdns_torrent_vals j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_vals = {
3284 .reg_pairs = j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs,
3285 .num_regs = ARRAY_SIZE(j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs),
3288 /* TI J7200, Multilink SGMII/QSGMII, using PLL1, 100 MHz Ref clk, no SSC */
3289 static struct cdns_reg_pairs j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs[] = {
3290 {0x0028, CMN_PLLSM1_PLLPRE_TMR},
3291 {0x00A4, CMN_PLLSM1_PLLLOCK_TMR},
3292 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0},
3293 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0},
3294 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0},
3295 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
3296 {0x007F, CMN_TXPUCAL_TUNE},
3297 {0x007F, CMN_TXPDCAL_TUNE}
3300 static struct cdns_torrent_vals j7200_ml_sgmii_pll1_100_no_ssc_cmn_vals = {
3301 .reg_pairs = j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs,
3302 .num_regs = ARRAY_SIZE(j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs),
3305 /* PCIe and USXGMII link configuration */
3306 static struct cdns_reg_pairs pcie_usxgmii_link_cmn_regs[] = {
3307 {0x0003, PHY_PLL_CFG},
3308 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0},
3309 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1},
3310 {0x0400, CMN_PDIAG_PLL1_CLK_SEL_M0}
3313 static struct cdns_reg_pairs pcie_usxgmii_xcvr_diag_ln_regs[] = {
3314 {0x0000, XCVR_DIAG_HSCLK_SEL},
3315 {0x0001, XCVR_DIAG_HSCLK_DIV},
3316 {0x0012, XCVR_DIAG_PLLDRC_CTRL}
3319 static struct cdns_reg_pairs usxgmii_pcie_xcvr_diag_ln_regs[] = {
3320 {0x0011, XCVR_DIAG_HSCLK_SEL},
3321 {0x0001, XCVR_DIAG_HSCLK_DIV},
3322 {0x0089, XCVR_DIAG_PLLDRC_CTRL}
3325 static struct cdns_torrent_vals pcie_usxgmii_link_cmn_vals = {
3326 .reg_pairs = pcie_usxgmii_link_cmn_regs,
3327 .num_regs = ARRAY_SIZE(pcie_usxgmii_link_cmn_regs),
3330 static struct cdns_torrent_vals pcie_usxgmii_xcvr_diag_ln_vals = {
3331 .reg_pairs = pcie_usxgmii_xcvr_diag_ln_regs,
3332 .num_regs = ARRAY_SIZE(pcie_usxgmii_xcvr_diag_ln_regs),
3335 static struct cdns_torrent_vals usxgmii_pcie_xcvr_diag_ln_vals = {
3336 .reg_pairs = usxgmii_pcie_xcvr_diag_ln_regs,
3337 .num_regs = ARRAY_SIZE(usxgmii_pcie_xcvr_diag_ln_regs),
3341 * Multilink USXGMII, using PLL1, 156.25 MHz Ref clk, no SSC
3343 static struct cdns_reg_pairs ml_usxgmii_pll1_156_25_no_ssc_cmn_regs[] = {
3344 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0},
3345 {0x0014, CMN_PLL1_DSM_FBH_OVRD_M0},
3346 {0x0005, CMN_PLL1_DSM_FBL_OVRD_M0},
3347 {0x061B, CMN_PLL1_VCOCAL_INIT_TMR},
3348 {0x0019, CMN_PLL1_VCOCAL_ITER_TMR},
3349 {0x1354, CMN_PLL1_VCOCAL_REFTIM_START},
3350 {0x1354, CMN_PLL1_VCOCAL_PLLCNT_START},
3351 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
3352 {0x0138, CMN_PLL1_LOCK_REFCNT_START},
3353 {0x0138, CMN_PLL1_LOCK_PLLCNT_START},
3354 {0x007F, CMN_TXPUCAL_TUNE},
3355 {0x007F, CMN_TXPDCAL_TUNE}
3358 static struct cdns_reg_pairs ml_usxgmii_156_25_no_ssc_tx_ln_regs[] = {
3359 {0x00F3, TX_PSC_A0},
3360 {0x04A2, TX_PSC_A2},
3361 {0x04A2, TX_PSC_A3 },
3362 {0x0000, TX_TXCC_CPOST_MULT_00},
3363 {0x0000, XCVR_DIAG_PSC_OVRD}
3366 static struct cdns_reg_pairs ml_usxgmii_156_25_no_ssc_rx_ln_regs[] = {
3367 {0x091D, RX_PSC_A0},
3368 {0x0900, RX_PSC_A2},
3369 {0x0100, RX_PSC_A3},
3370 {0x0030, RX_REE_SMGM_CTRL1},
3371 {0x03C7, RX_REE_GCSM1_EQENM_PH1},
3372 {0x01C7, RX_REE_GCSM1_EQENM_PH2},
3373 {0x0000, RX_DIAG_DFE_CTRL},
3374 {0x0019, RX_REE_TAP1_CLIP},
3375 {0x0019, RX_REE_TAP2TON_CLIP},
3376 {0x00B9, RX_DIAG_NQST_CTRL},
3377 {0x0C21, RX_DIAG_DFE_AMP_TUNE_2},
3378 {0x0002, RX_DIAG_DFE_AMP_TUNE_3},
3379 {0x0033, RX_DIAG_PI_RATE},
3380 {0x0001, RX_DIAG_ACYA},
3381 {0x018C, RX_CDRLF_CNFG}
3384 static struct cdns_torrent_vals ml_usxgmii_pll1_156_25_no_ssc_cmn_vals = {
3385 .reg_pairs = ml_usxgmii_pll1_156_25_no_ssc_cmn_regs,
3386 .num_regs = ARRAY_SIZE(ml_usxgmii_pll1_156_25_no_ssc_cmn_regs),
3389 static struct cdns_torrent_vals ml_usxgmii_156_25_no_ssc_tx_ln_vals = {
3390 .reg_pairs = ml_usxgmii_156_25_no_ssc_tx_ln_regs,
3391 .num_regs = ARRAY_SIZE(ml_usxgmii_156_25_no_ssc_tx_ln_regs),
3394 static struct cdns_torrent_vals ml_usxgmii_156_25_no_ssc_rx_ln_vals = {
3395 .reg_pairs = ml_usxgmii_156_25_no_ssc_rx_ln_regs,
3396 .num_regs = ARRAY_SIZE(ml_usxgmii_156_25_no_ssc_rx_ln_regs),
3399 /* TI USXGMII configuration: Enable cmn_refclk_rcv_out_en */
3400 static struct cdns_reg_pairs ti_usxgmii_phy_pma_cmn_regs[] = {
3401 {0x0040, PHY_PMA_CMN_CTRL1},
3404 static struct cdns_torrent_vals ti_usxgmii_phy_pma_cmn_vals = {
3405 .reg_pairs = ti_usxgmii_phy_pma_cmn_regs,
3406 .num_regs = ARRAY_SIZE(ti_usxgmii_phy_pma_cmn_regs),
3409 /* Single USXGMII link configuration */
3410 static struct cdns_reg_pairs sl_usxgmii_link_cmn_regs[] = {
3411 {0x0000, PHY_PLL_CFG},
3412 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M0}
3415 static struct cdns_reg_pairs sl_usxgmii_xcvr_diag_ln_regs[] = {
3416 {0x0000, XCVR_DIAG_HSCLK_SEL},
3417 {0x0001, XCVR_DIAG_HSCLK_DIV},
3418 {0x0001, XCVR_DIAG_PLLDRC_CTRL}
3421 static struct cdns_torrent_vals sl_usxgmii_link_cmn_vals = {
3422 .reg_pairs = sl_usxgmii_link_cmn_regs,
3423 .num_regs = ARRAY_SIZE(sl_usxgmii_link_cmn_regs),
3426 static struct cdns_torrent_vals sl_usxgmii_xcvr_diag_ln_vals = {
3427 .reg_pairs = sl_usxgmii_xcvr_diag_ln_regs,
3428 .num_regs = ARRAY_SIZE(sl_usxgmii_xcvr_diag_ln_regs),
3431 /* Single link USXGMII, 156.25 MHz Ref clk, no SSC */
3432 static struct cdns_reg_pairs sl_usxgmii_156_25_no_ssc_cmn_regs[] = {
3433 {0x0014, CMN_SSM_BIAS_TMR},
3434 {0x0028, CMN_PLLSM0_PLLPRE_TMR},
3435 {0x00A4, CMN_PLLSM0_PLLLOCK_TMR},
3436 {0x0028, CMN_PLLSM1_PLLPRE_TMR},
3437 {0x00A4, CMN_PLLSM1_PLLLOCK_TMR},
3438 {0x0062, CMN_BGCAL_INIT_TMR},
3439 {0x0062, CMN_BGCAL_ITER_TMR},
3440 {0x0014, CMN_IBCAL_INIT_TMR},
3441 {0x0018, CMN_TXPUCAL_INIT_TMR},
3442 {0x0005, CMN_TXPUCAL_ITER_TMR},
3443 {0x0018, CMN_TXPDCAL_INIT_TMR},
3444 {0x0005, CMN_TXPDCAL_ITER_TMR},
3445 {0x024A, CMN_RXCAL_INIT_TMR},
3446 {0x0005, CMN_RXCAL_ITER_TMR},
3447 {0x000B, CMN_SD_CAL_REFTIM_START},
3448 {0x0132, CMN_SD_CAL_PLLCNT_START},
3449 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0},
3450 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0},
3451 {0x0014, CMN_PLL1_DSM_FBH_OVRD_M0},
3452 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0},
3453 {0x0005, CMN_PLL1_DSM_FBL_OVRD_M0},
3454 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR},
3455 {0x061B, CMN_PLL1_VCOCAL_INIT_TMR},
3456 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR},
3457 {0x0019, CMN_PLL1_VCOCAL_ITER_TMR},
3458 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START},
3459 {0x1354, CMN_PLL1_VCOCAL_REFTIM_START},
3460 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START},
3461 {0x1354, CMN_PLL1_VCOCAL_PLLCNT_START},
3462 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
3463 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
3464 {0x0138, CMN_PLL0_LOCK_REFCNT_START},
3465 {0x0138, CMN_PLL1_LOCK_REFCNT_START},
3466 {0x0138, CMN_PLL0_LOCK_PLLCNT_START},
3467 {0x0138, CMN_PLL1_LOCK_PLLCNT_START}
3470 static struct cdns_reg_pairs usxgmii_156_25_no_ssc_tx_ln_regs[] = {
3471 {0x07A2, TX_RCVDET_ST_TMR},
3472 {0x00F3, TX_PSC_A0},
3473 {0x04A2, TX_PSC_A2},
3474 {0x04A2, TX_PSC_A3},
3475 {0x0000, TX_TXCC_CPOST_MULT_00},
3476 {0x0000, XCVR_DIAG_PSC_OVRD}
3479 static struct cdns_reg_pairs usxgmii_156_25_no_ssc_rx_ln_regs[] = {
3480 {0x0014, RX_SDCAL0_INIT_TMR},
3481 {0x0062, RX_SDCAL0_ITER_TMR},
3482 {0x0014, RX_SDCAL1_INIT_TMR},
3483 {0x0062, RX_SDCAL1_ITER_TMR},
3484 {0x091D, RX_PSC_A0},
3485 {0x0900, RX_PSC_A2},
3486 {0x0100, RX_PSC_A3},
3487 {0x0030, RX_REE_SMGM_CTRL1},
3488 {0x03C7, RX_REE_GCSM1_EQENM_PH1},
3489 {0x01C7, RX_REE_GCSM1_EQENM_PH2},
3490 {0x0000, RX_DIAG_DFE_CTRL},
3491 {0x0019, RX_REE_TAP1_CLIP},
3492 {0x0019, RX_REE_TAP2TON_CLIP},
3493 {0x00B9, RX_DIAG_NQST_CTRL},
3494 {0x0C21, RX_DIAG_DFE_AMP_TUNE_2},
3495 {0x0002, RX_DIAG_DFE_AMP_TUNE_3},
3496 {0x0033, RX_DIAG_PI_RATE},
3497 {0x0001, RX_DIAG_ACYA},
3498 {0x018C, RX_CDRLF_CNFG}
3501 static struct cdns_torrent_vals sl_usxgmii_156_25_no_ssc_cmn_vals = {
3502 .reg_pairs = sl_usxgmii_156_25_no_ssc_cmn_regs,
3503 .num_regs = ARRAY_SIZE(sl_usxgmii_156_25_no_ssc_cmn_regs),
3506 static struct cdns_torrent_vals usxgmii_156_25_no_ssc_tx_ln_vals = {
3507 .reg_pairs = usxgmii_156_25_no_ssc_tx_ln_regs,
3508 .num_regs = ARRAY_SIZE(usxgmii_156_25_no_ssc_tx_ln_regs),
3511 static struct cdns_torrent_vals usxgmii_156_25_no_ssc_rx_ln_vals = {
3512 .reg_pairs = usxgmii_156_25_no_ssc_rx_ln_regs,
3513 .num_regs = ARRAY_SIZE(usxgmii_156_25_no_ssc_rx_ln_regs),
3516 /* PCIe and DP link configuration */
3517 static struct cdns_reg_pairs pcie_dp_link_cmn_regs[] = {
3518 {0x0003, PHY_PLL_CFG},
3519 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0},
3520 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1}
3523 static struct cdns_reg_pairs pcie_dp_xcvr_diag_ln_regs[] = {
3524 {0x0000, XCVR_DIAG_HSCLK_SEL},
3525 {0x0001, XCVR_DIAG_HSCLK_DIV},
3526 {0x0012, XCVR_DIAG_PLLDRC_CTRL}
3529 static struct cdns_reg_pairs dp_pcie_xcvr_diag_ln_regs[] = {
3530 {0x0001, XCVR_DIAG_HSCLK_SEL},
3531 {0x0009, XCVR_DIAG_PLLDRC_CTRL}
3534 static struct cdns_torrent_vals pcie_dp_link_cmn_vals = {
3535 .reg_pairs = pcie_dp_link_cmn_regs,
3536 .num_regs = ARRAY_SIZE(pcie_dp_link_cmn_regs),
3539 static struct cdns_torrent_vals pcie_dp_xcvr_diag_ln_vals = {
3540 .reg_pairs = pcie_dp_xcvr_diag_ln_regs,
3541 .num_regs = ARRAY_SIZE(pcie_dp_xcvr_diag_ln_regs),
3544 static struct cdns_torrent_vals dp_pcie_xcvr_diag_ln_vals = {
3545 .reg_pairs = dp_pcie_xcvr_diag_ln_regs,
3546 .num_regs = ARRAY_SIZE(dp_pcie_xcvr_diag_ln_regs),
3549 /* DP Multilink, 100 MHz Ref clk, no SSC */
3550 static struct cdns_reg_pairs dp_100_no_ssc_cmn_regs[] = {
3551 {0x007F, CMN_TXPUCAL_TUNE},
3552 {0x007F, CMN_TXPDCAL_TUNE}
3555 static struct cdns_reg_pairs dp_100_no_ssc_tx_ln_regs[] = {
3556 {0x00FB, TX_PSC_A0},
3557 {0x04AA, TX_PSC_A2},
3558 {0x04AA, TX_PSC_A3},
3559 {0x000F, XCVR_DIAG_BIDI_CTRL}
3562 static struct cdns_reg_pairs dp_100_no_ssc_rx_ln_regs[] = {
3563 {0x0000, RX_PSC_A0},
3564 {0x0000, RX_PSC_A2},
3565 {0x0000, RX_PSC_A3},
3566 {0x0000, RX_PSC_CAL},
3567 {0x0000, RX_REE_GCSM1_CTRL},
3568 {0x0000, RX_REE_GCSM2_CTRL},
3569 {0x0000, RX_REE_PERGCSM_CTRL}
3572 static struct cdns_torrent_vals dp_100_no_ssc_cmn_vals = {
3573 .reg_pairs = dp_100_no_ssc_cmn_regs,
3574 .num_regs = ARRAY_SIZE(dp_100_no_ssc_cmn_regs),
3577 static struct cdns_torrent_vals dp_100_no_ssc_tx_ln_vals = {
3578 .reg_pairs = dp_100_no_ssc_tx_ln_regs,
3579 .num_regs = ARRAY_SIZE(dp_100_no_ssc_tx_ln_regs),
3582 static struct cdns_torrent_vals dp_100_no_ssc_rx_ln_vals = {
3583 .reg_pairs = dp_100_no_ssc_rx_ln_regs,
3584 .num_regs = ARRAY_SIZE(dp_100_no_ssc_rx_ln_regs),
3587 /* Single DisplayPort(DP) link configuration */
3588 static struct cdns_reg_pairs sl_dp_link_cmn_regs[] = {
3589 {0x0000, PHY_PLL_CFG},
3592 static struct cdns_reg_pairs sl_dp_xcvr_diag_ln_regs[] = {
3593 {0x0000, XCVR_DIAG_HSCLK_SEL},
3594 {0x0001, XCVR_DIAG_PLLDRC_CTRL}
3597 static struct cdns_torrent_vals sl_dp_link_cmn_vals = {
3598 .reg_pairs = sl_dp_link_cmn_regs,
3599 .num_regs = ARRAY_SIZE(sl_dp_link_cmn_regs),
3602 static struct cdns_torrent_vals sl_dp_xcvr_diag_ln_vals = {
3603 .reg_pairs = sl_dp_xcvr_diag_ln_regs,
3604 .num_regs = ARRAY_SIZE(sl_dp_xcvr_diag_ln_regs),
3607 /* Single DP, 19.2 MHz Ref clk, no SSC */
3608 static struct cdns_reg_pairs sl_dp_19_2_no_ssc_cmn_regs[] = {
3609 {0x0014, CMN_SSM_BIAS_TMR},
3610 {0x0027, CMN_PLLSM0_PLLPRE_TMR},
3611 {0x00A1, CMN_PLLSM0_PLLLOCK_TMR},
3612 {0x0027, CMN_PLLSM1_PLLPRE_TMR},
3613 {0x00A1, CMN_PLLSM1_PLLLOCK_TMR},
3614 {0x0060, CMN_BGCAL_INIT_TMR},
3615 {0x0060, CMN_BGCAL_ITER_TMR},
3616 {0x0014, CMN_IBCAL_INIT_TMR},
3617 {0x0018, CMN_TXPUCAL_INIT_TMR},
3618 {0x0005, CMN_TXPUCAL_ITER_TMR},
3619 {0x0018, CMN_TXPDCAL_INIT_TMR},
3620 {0x0005, CMN_TXPDCAL_ITER_TMR},
3621 {0x0240, CMN_RXCAL_INIT_TMR},
3622 {0x0005, CMN_RXCAL_ITER_TMR},
3623 {0x0002, CMN_SD_CAL_INIT_TMR},
3624 {0x0002, CMN_SD_CAL_ITER_TMR},
3625 {0x000B, CMN_SD_CAL_REFTIM_START},
3626 {0x0137, CMN_SD_CAL_PLLCNT_START},
3627 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
3628 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
3629 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
3630 {0x0004, CMN_PLL0_DSM_DIAG_M0},
3631 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
3632 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
3633 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
3634 {0x0004, CMN_PLL1_DSM_DIAG_M0},
3635 {0x00C0, CMN_PLL0_VCOCAL_INIT_TMR},
3636 {0x0004, CMN_PLL0_VCOCAL_ITER_TMR},
3637 {0x00C0, CMN_PLL1_VCOCAL_INIT_TMR},
3638 {0x0004, CMN_PLL1_VCOCAL_ITER_TMR},
3639 {0x0260, CMN_PLL0_VCOCAL_REFTIM_START},
3640 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
3641 {0x0260, CMN_PLL1_VCOCAL_REFTIM_START},
3642 {0x0003, CMN_PLL1_VCOCAL_TCTRL}
3645 static struct cdns_reg_pairs sl_dp_19_2_no_ssc_tx_ln_regs[] = {
3646 {0x0780, TX_RCVDET_ST_TMR},
3647 {0x00FB, TX_PSC_A0},
3648 {0x04AA, TX_PSC_A2},
3649 {0x04AA, TX_PSC_A3},
3650 {0x000F, XCVR_DIAG_BIDI_CTRL}
3653 static struct cdns_reg_pairs sl_dp_19_2_no_ssc_rx_ln_regs[] = {
3654 {0x0000, RX_PSC_A0},
3655 {0x0000, RX_PSC_A2},
3656 {0x0000, RX_PSC_A3},
3657 {0x0000, RX_PSC_CAL},
3658 {0x0000, RX_REE_GCSM1_CTRL},
3659 {0x0000, RX_REE_GCSM2_CTRL},
3660 {0x0000, RX_REE_PERGCSM_CTRL}
3663 static struct cdns_torrent_vals sl_dp_19_2_no_ssc_cmn_vals = {
3664 .reg_pairs = sl_dp_19_2_no_ssc_cmn_regs,
3665 .num_regs = ARRAY_SIZE(sl_dp_19_2_no_ssc_cmn_regs),
3668 static struct cdns_torrent_vals sl_dp_19_2_no_ssc_tx_ln_vals = {
3669 .reg_pairs = sl_dp_19_2_no_ssc_tx_ln_regs,
3670 .num_regs = ARRAY_SIZE(sl_dp_19_2_no_ssc_tx_ln_regs),
3673 static struct cdns_torrent_vals sl_dp_19_2_no_ssc_rx_ln_vals = {
3674 .reg_pairs = sl_dp_19_2_no_ssc_rx_ln_regs,
3675 .num_regs = ARRAY_SIZE(sl_dp_19_2_no_ssc_rx_ln_regs),
3678 /* Single DP, 25 MHz Ref clk, no SSC */
3679 static struct cdns_reg_pairs sl_dp_25_no_ssc_cmn_regs[] = {
3680 {0x0019, CMN_SSM_BIAS_TMR},
3681 {0x0032, CMN_PLLSM0_PLLPRE_TMR},
3682 {0x00D1, CMN_PLLSM0_PLLLOCK_TMR},
3683 {0x0032, CMN_PLLSM1_PLLPRE_TMR},
3684 {0x00D1, CMN_PLLSM1_PLLLOCK_TMR},
3685 {0x007D, CMN_BGCAL_INIT_TMR},
3686 {0x007D, CMN_BGCAL_ITER_TMR},
3687 {0x0019, CMN_IBCAL_INIT_TMR},
3688 {0x001E, CMN_TXPUCAL_INIT_TMR},
3689 {0x0006, CMN_TXPUCAL_ITER_TMR},
3690 {0x001E, CMN_TXPDCAL_INIT_TMR},
3691 {0x0006, CMN_TXPDCAL_ITER_TMR},
3692 {0x02EE, CMN_RXCAL_INIT_TMR},
3693 {0x0006, CMN_RXCAL_ITER_TMR},
3694 {0x0002, CMN_SD_CAL_INIT_TMR},
3695 {0x0002, CMN_SD_CAL_ITER_TMR},
3696 {0x000E, CMN_SD_CAL_REFTIM_START},
3697 {0x012B, CMN_SD_CAL_PLLCNT_START},
3698 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
3699 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
3700 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
3701 {0x0004, CMN_PLL0_DSM_DIAG_M0},
3702 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
3703 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
3704 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
3705 {0x0004, CMN_PLL1_DSM_DIAG_M0},
3706 {0x00FA, CMN_PLL0_VCOCAL_INIT_TMR},
3707 {0x0004, CMN_PLL0_VCOCAL_ITER_TMR},
3708 {0x00FA, CMN_PLL1_VCOCAL_INIT_TMR},
3709 {0x0004, CMN_PLL1_VCOCAL_ITER_TMR},
3710 {0x0317, CMN_PLL0_VCOCAL_REFTIM_START},
3711 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
3712 {0x0317, CMN_PLL1_VCOCAL_REFTIM_START},
3713 {0x0003, CMN_PLL1_VCOCAL_TCTRL}
3716 static struct cdns_reg_pairs sl_dp_25_no_ssc_tx_ln_regs[] = {
3717 {0x09C4, TX_RCVDET_ST_TMR},
3718 {0x00FB, TX_PSC_A0},
3719 {0x04AA, TX_PSC_A2},
3720 {0x04AA, TX_PSC_A3},
3721 {0x000F, XCVR_DIAG_BIDI_CTRL}
3724 static struct cdns_reg_pairs sl_dp_25_no_ssc_rx_ln_regs[] = {
3725 {0x0000, RX_PSC_A0},
3726 {0x0000, RX_PSC_A2},
3727 {0x0000, RX_PSC_A3},
3728 {0x0000, RX_PSC_CAL},
3729 {0x0000, RX_REE_GCSM1_CTRL},
3730 {0x0000, RX_REE_GCSM2_CTRL},
3731 {0x0000, RX_REE_PERGCSM_CTRL}
3734 static struct cdns_torrent_vals sl_dp_25_no_ssc_cmn_vals = {
3735 .reg_pairs = sl_dp_25_no_ssc_cmn_regs,
3736 .num_regs = ARRAY_SIZE(sl_dp_25_no_ssc_cmn_regs),
3739 static struct cdns_torrent_vals sl_dp_25_no_ssc_tx_ln_vals = {
3740 .reg_pairs = sl_dp_25_no_ssc_tx_ln_regs,
3741 .num_regs = ARRAY_SIZE(sl_dp_25_no_ssc_tx_ln_regs),
3744 static struct cdns_torrent_vals sl_dp_25_no_ssc_rx_ln_vals = {
3745 .reg_pairs = sl_dp_25_no_ssc_rx_ln_regs,
3746 .num_regs = ARRAY_SIZE(sl_dp_25_no_ssc_rx_ln_regs),
3749 /* Single DP, 100 MHz Ref clk, no SSC */
3750 static struct cdns_reg_pairs sl_dp_100_no_ssc_cmn_regs[] = {
3751 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
3752 {0x0003, CMN_PLL1_VCOCAL_TCTRL}
3755 static struct cdns_reg_pairs sl_dp_100_no_ssc_tx_ln_regs[] = {
3756 {0x00FB, TX_PSC_A0},
3757 {0x04AA, TX_PSC_A2},
3758 {0x04AA, TX_PSC_A3},
3759 {0x000F, XCVR_DIAG_BIDI_CTRL}
3762 static struct cdns_reg_pairs sl_dp_100_no_ssc_rx_ln_regs[] = {
3763 {0x0000, RX_PSC_A0},
3764 {0x0000, RX_PSC_A2},
3765 {0x0000, RX_PSC_A3},
3766 {0x0000, RX_PSC_CAL},
3767 {0x0000, RX_REE_GCSM1_CTRL},
3768 {0x0000, RX_REE_GCSM2_CTRL},
3769 {0x0000, RX_REE_PERGCSM_CTRL}
3772 static struct cdns_torrent_vals sl_dp_100_no_ssc_cmn_vals = {
3773 .reg_pairs = sl_dp_100_no_ssc_cmn_regs,
3774 .num_regs = ARRAY_SIZE(sl_dp_100_no_ssc_cmn_regs),
3777 static struct cdns_torrent_vals sl_dp_100_no_ssc_tx_ln_vals = {
3778 .reg_pairs = sl_dp_100_no_ssc_tx_ln_regs,
3779 .num_regs = ARRAY_SIZE(sl_dp_100_no_ssc_tx_ln_regs),
3782 static struct cdns_torrent_vals sl_dp_100_no_ssc_rx_ln_vals = {
3783 .reg_pairs = sl_dp_100_no_ssc_rx_ln_regs,
3784 .num_regs = ARRAY_SIZE(sl_dp_100_no_ssc_rx_ln_regs),
3787 /* USB and SGMII/QSGMII link configuration */
3788 static struct cdns_reg_pairs usb_sgmii_link_cmn_regs[] = {
3789 {0x0002, PHY_PLL_CFG},
3790 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0},
3791 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0}
3794 static struct cdns_reg_pairs usb_sgmii_xcvr_diag_ln_regs[] = {
3795 {0x0000, XCVR_DIAG_HSCLK_SEL},
3796 {0x0001, XCVR_DIAG_HSCLK_DIV},
3797 {0x0041, XCVR_DIAG_PLLDRC_CTRL}
3800 static struct cdns_reg_pairs sgmii_usb_xcvr_diag_ln_regs[] = {
3801 {0x0011, XCVR_DIAG_HSCLK_SEL},
3802 {0x0003, XCVR_DIAG_HSCLK_DIV},
3803 {0x009B, XCVR_DIAG_PLLDRC_CTRL}
3806 static struct cdns_torrent_vals usb_sgmii_link_cmn_vals = {
3807 .reg_pairs = usb_sgmii_link_cmn_regs,
3808 .num_regs = ARRAY_SIZE(usb_sgmii_link_cmn_regs),
3811 static struct cdns_torrent_vals usb_sgmii_xcvr_diag_ln_vals = {
3812 .reg_pairs = usb_sgmii_xcvr_diag_ln_regs,
3813 .num_regs = ARRAY_SIZE(usb_sgmii_xcvr_diag_ln_regs),
3816 static struct cdns_torrent_vals sgmii_usb_xcvr_diag_ln_vals = {
3817 .reg_pairs = sgmii_usb_xcvr_diag_ln_regs,
3818 .num_regs = ARRAY_SIZE(sgmii_usb_xcvr_diag_ln_regs),
3821 /* PCIe and USB Unique SSC link configuration */
3822 static struct cdns_reg_pairs pcie_usb_link_cmn_regs[] = {
3823 {0x0003, PHY_PLL_CFG},
3824 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0},
3825 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1},
3826 {0x8600, CMN_PDIAG_PLL1_CLK_SEL_M0}
3829 static struct cdns_reg_pairs pcie_usb_xcvr_diag_ln_regs[] = {
3830 {0x0000, XCVR_DIAG_HSCLK_SEL},
3831 {0x0001, XCVR_DIAG_HSCLK_DIV},
3832 {0x0012, XCVR_DIAG_PLLDRC_CTRL}
3835 static struct cdns_reg_pairs usb_pcie_xcvr_diag_ln_regs[] = {
3836 {0x0011, XCVR_DIAG_HSCLK_SEL},
3837 {0x0001, XCVR_DIAG_HSCLK_DIV},
3838 {0x00C9, XCVR_DIAG_PLLDRC_CTRL}
3841 static struct cdns_torrent_vals pcie_usb_link_cmn_vals = {
3842 .reg_pairs = pcie_usb_link_cmn_regs,
3843 .num_regs = ARRAY_SIZE(pcie_usb_link_cmn_regs),
3846 static struct cdns_torrent_vals pcie_usb_xcvr_diag_ln_vals = {
3847 .reg_pairs = pcie_usb_xcvr_diag_ln_regs,
3848 .num_regs = ARRAY_SIZE(pcie_usb_xcvr_diag_ln_regs),
3851 static struct cdns_torrent_vals usb_pcie_xcvr_diag_ln_vals = {
3852 .reg_pairs = usb_pcie_xcvr_diag_ln_regs,
3853 .num_regs = ARRAY_SIZE(usb_pcie_xcvr_diag_ln_regs),
3856 /* USB 100 MHz Ref clk, internal SSC */
3857 static struct cdns_reg_pairs usb_100_int_ssc_cmn_regs[] = {
3858 {0x0004, CMN_PLL0_DSM_DIAG_M0},
3859 {0x0004, CMN_PLL0_DSM_DIAG_M1},
3860 {0x0004, CMN_PLL1_DSM_DIAG_M0},
3861 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
3862 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
3863 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
3864 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
3865 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
3866 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
3867 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
3868 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
3869 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
3870 {0x0064, CMN_PLL0_INTDIV_M0},
3871 {0x0050, CMN_PLL0_INTDIV_M1},
3872 {0x0064, CMN_PLL1_INTDIV_M0},
3873 {0x0002, CMN_PLL0_FRACDIVH_M0},
3874 {0x0002, CMN_PLL0_FRACDIVH_M1},
3875 {0x0002, CMN_PLL1_FRACDIVH_M0},
3876 {0x0044, CMN_PLL0_HIGH_THR_M0},
3877 {0x0036, CMN_PLL0_HIGH_THR_M1},
3878 {0x0044, CMN_PLL1_HIGH_THR_M0},
3879 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
3880 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
3881 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
3882 {0x0001, CMN_PLL0_SS_CTRL1_M0},
3883 {0x0001, CMN_PLL0_SS_CTRL1_M1},
3884 {0x0001, CMN_PLL1_SS_CTRL1_M0},
3885 {0x011B, CMN_PLL0_SS_CTRL2_M0},
3886 {0x011B, CMN_PLL0_SS_CTRL2_M1},
3887 {0x011B, CMN_PLL1_SS_CTRL2_M0},
3888 {0x006E, CMN_PLL0_SS_CTRL3_M0},
3889 {0x0058, CMN_PLL0_SS_CTRL3_M1},
3890 {0x006E, CMN_PLL1_SS_CTRL3_M0},
3891 {0x000E, CMN_PLL0_SS_CTRL4_M0},
3892 {0x0012, CMN_PLL0_SS_CTRL4_M1},
3893 {0x000E, CMN_PLL1_SS_CTRL4_M0},
3894 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
3895 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
3896 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
3897 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
3898 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
3899 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
3900 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
3901 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
3902 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
3903 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR},
3904 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD},
3905 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD},
3906 {0x007F, CMN_TXPUCAL_TUNE},
3907 {0x007F, CMN_TXPDCAL_TUNE}
3910 static struct cdns_torrent_vals usb_100_int_ssc_cmn_vals = {
3911 .reg_pairs = usb_100_int_ssc_cmn_regs,
3912 .num_regs = ARRAY_SIZE(usb_100_int_ssc_cmn_regs),
3915 /* Single USB link configuration */
3916 static struct cdns_reg_pairs sl_usb_link_cmn_regs[] = {
3917 {0x0000, PHY_PLL_CFG},
3918 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0}
3921 static struct cdns_reg_pairs sl_usb_xcvr_diag_ln_regs[] = {
3922 {0x0000, XCVR_DIAG_HSCLK_SEL},
3923 {0x0001, XCVR_DIAG_HSCLK_DIV},
3924 {0x0041, XCVR_DIAG_PLLDRC_CTRL}
3927 static struct cdns_torrent_vals sl_usb_link_cmn_vals = {
3928 .reg_pairs = sl_usb_link_cmn_regs,
3929 .num_regs = ARRAY_SIZE(sl_usb_link_cmn_regs),
3932 static struct cdns_torrent_vals sl_usb_xcvr_diag_ln_vals = {
3933 .reg_pairs = sl_usb_xcvr_diag_ln_regs,
3934 .num_regs = ARRAY_SIZE(sl_usb_xcvr_diag_ln_regs),
3937 /* USB PHY PCS common configuration */
3938 static struct cdns_reg_pairs usb_phy_pcs_cmn_regs[] = {
3939 {0x0A0A, PHY_PIPE_USB3_GEN2_PRE_CFG0},
3940 {0x1000, PHY_PIPE_USB3_GEN2_POST_CFG0},
3941 {0x0010, PHY_PIPE_USB3_GEN2_POST_CFG1}
3944 static struct cdns_torrent_vals usb_phy_pcs_cmn_vals = {
3945 .reg_pairs = usb_phy_pcs_cmn_regs,
3946 .num_regs = ARRAY_SIZE(usb_phy_pcs_cmn_regs),
3949 /* USB 100 MHz Ref clk, no SSC */
3950 static struct cdns_reg_pairs sl_usb_100_no_ssc_cmn_regs[] = {
3951 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0},
3952 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0},
3953 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0},
3954 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
3955 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
3956 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD},
3957 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD}
3960 static struct cdns_torrent_vals sl_usb_100_no_ssc_cmn_vals = {
3961 .reg_pairs = sl_usb_100_no_ssc_cmn_regs,
3962 .num_regs = ARRAY_SIZE(sl_usb_100_no_ssc_cmn_regs),
3965 static struct cdns_reg_pairs usb_100_no_ssc_cmn_regs[] = {
3966 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD},
3967 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD},
3968 {0x007F, CMN_TXPUCAL_TUNE},
3969 {0x007F, CMN_TXPDCAL_TUNE}
3972 static struct cdns_reg_pairs usb_100_no_ssc_tx_ln_regs[] = {
3973 {0x02FF, TX_PSC_A0},
3974 {0x06AF, TX_PSC_A1},
3975 {0x06AE, TX_PSC_A2},
3976 {0x06AE, TX_PSC_A3},
3977 {0x2A82, TX_TXCC_CTRL},
3978 {0x0014, TX_TXCC_CPOST_MULT_01},
3979 {0x0003, XCVR_DIAG_PSC_OVRD}
3982 static struct cdns_reg_pairs usb_100_no_ssc_rx_ln_regs[] = {
3983 {0x0D1D, RX_PSC_A0},
3984 {0x0D1D, RX_PSC_A1},
3985 {0x0D00, RX_PSC_A2},
3986 {0x0500, RX_PSC_A3},
3987 {0x0013, RX_SIGDET_HL_FILT_TMR},
3988 {0x0000, RX_REE_GCSM1_CTRL},
3989 {0x0C02, RX_REE_ATTEN_THR},
3990 {0x0330, RX_REE_SMGM_CTRL1},
3991 {0x0300, RX_REE_SMGM_CTRL2},
3992 {0x0019, RX_REE_TAP1_CLIP},
3993 {0x0019, RX_REE_TAP2TON_CLIP},
3994 {0x1004, RX_DIAG_SIGDET_TUNE},
3995 {0x00F9, RX_DIAG_NQST_CTRL},
3996 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2},
3997 {0x0002, RX_DIAG_DFE_AMP_TUNE_3},
3998 {0x0000, RX_DIAG_PI_CAP},
3999 {0x0031, RX_DIAG_PI_RATE},
4000 {0x0001, RX_DIAG_ACYA},
4001 {0x018C, RX_CDRLF_CNFG},
4002 {0x0003, RX_CDRLF_CNFG3}
4005 static struct cdns_torrent_vals usb_100_no_ssc_cmn_vals = {
4006 .reg_pairs = usb_100_no_ssc_cmn_regs,
4007 .num_regs = ARRAY_SIZE(usb_100_no_ssc_cmn_regs),
4010 static struct cdns_torrent_vals usb_100_no_ssc_tx_ln_vals = {
4011 .reg_pairs = usb_100_no_ssc_tx_ln_regs,
4012 .num_regs = ARRAY_SIZE(usb_100_no_ssc_tx_ln_regs),
4015 static struct cdns_torrent_vals usb_100_no_ssc_rx_ln_vals = {
4016 .reg_pairs = usb_100_no_ssc_rx_ln_regs,
4017 .num_regs = ARRAY_SIZE(usb_100_no_ssc_rx_ln_regs),
4020 /* Single link USB, 100 MHz Ref clk, internal SSC */
4021 static struct cdns_reg_pairs sl_usb_100_int_ssc_cmn_regs[] = {
4022 {0x0004, CMN_PLL0_DSM_DIAG_M0},
4023 {0x0004, CMN_PLL1_DSM_DIAG_M0},
4024 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
4025 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
4026 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
4027 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
4028 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
4029 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
4030 {0x0064, CMN_PLL0_INTDIV_M0},
4031 {0x0064, CMN_PLL1_INTDIV_M0},
4032 {0x0002, CMN_PLL0_FRACDIVH_M0},
4033 {0x0002, CMN_PLL1_FRACDIVH_M0},
4034 {0x0044, CMN_PLL0_HIGH_THR_M0},
4035 {0x0044, CMN_PLL1_HIGH_THR_M0},
4036 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
4037 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
4038 {0x0001, CMN_PLL0_SS_CTRL1_M0},
4039 {0x0001, CMN_PLL1_SS_CTRL1_M0},
4040 {0x011B, CMN_PLL0_SS_CTRL2_M0},
4041 {0x011B, CMN_PLL1_SS_CTRL2_M0},
4042 {0x006E, CMN_PLL0_SS_CTRL3_M0},
4043 {0x006E, CMN_PLL1_SS_CTRL3_M0},
4044 {0x000E, CMN_PLL0_SS_CTRL4_M0},
4045 {0x000E, CMN_PLL1_SS_CTRL4_M0},
4046 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
4047 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
4048 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
4049 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
4050 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
4051 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
4052 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
4053 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
4054 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
4055 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
4056 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
4057 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR},
4058 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD},
4059 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD}
4062 static struct cdns_torrent_vals sl_usb_100_int_ssc_cmn_vals = {
4063 .reg_pairs = sl_usb_100_int_ssc_cmn_regs,
4064 .num_regs = ARRAY_SIZE(sl_usb_100_int_ssc_cmn_regs),
4067 /* PCIe and SGMII/QSGMII Unique SSC link configuration */
4068 static struct cdns_reg_pairs pcie_sgmii_link_cmn_regs[] = {
4069 {0x0003, PHY_PLL_CFG},
4070 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0},
4071 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1},
4072 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0}
4075 static struct cdns_reg_pairs pcie_sgmii_xcvr_diag_ln_regs[] = {
4076 {0x0000, XCVR_DIAG_HSCLK_SEL},
4077 {0x0001, XCVR_DIAG_HSCLK_DIV},
4078 {0x0012, XCVR_DIAG_PLLDRC_CTRL}
4081 static struct cdns_reg_pairs sgmii_pcie_xcvr_diag_ln_regs[] = {
4082 {0x0011, XCVR_DIAG_HSCLK_SEL},
4083 {0x0003, XCVR_DIAG_HSCLK_DIV},
4084 {0x009B, XCVR_DIAG_PLLDRC_CTRL}
4087 static struct cdns_torrent_vals pcie_sgmii_link_cmn_vals = {
4088 .reg_pairs = pcie_sgmii_link_cmn_regs,
4089 .num_regs = ARRAY_SIZE(pcie_sgmii_link_cmn_regs),
4092 static struct cdns_torrent_vals pcie_sgmii_xcvr_diag_ln_vals = {
4093 .reg_pairs = pcie_sgmii_xcvr_diag_ln_regs,
4094 .num_regs = ARRAY_SIZE(pcie_sgmii_xcvr_diag_ln_regs),
4097 static struct cdns_torrent_vals sgmii_pcie_xcvr_diag_ln_vals = {
4098 .reg_pairs = sgmii_pcie_xcvr_diag_ln_regs,
4099 .num_regs = ARRAY_SIZE(sgmii_pcie_xcvr_diag_ln_regs),
4102 /* SGMII 100 MHz Ref clk, no SSC */
4103 static struct cdns_reg_pairs sl_sgmii_100_no_ssc_cmn_regs[] = {
4104 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0},
4105 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0},
4106 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0},
4107 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
4108 {0x0003, CMN_PLL1_VCOCAL_TCTRL}
4111 static struct cdns_torrent_vals sl_sgmii_100_no_ssc_cmn_vals = {
4112 .reg_pairs = sl_sgmii_100_no_ssc_cmn_regs,
4113 .num_regs = ARRAY_SIZE(sl_sgmii_100_no_ssc_cmn_regs),
4116 static struct cdns_reg_pairs sgmii_100_no_ssc_cmn_regs[] = {
4117 {0x007F, CMN_TXPUCAL_TUNE},
4118 {0x007F, CMN_TXPDCAL_TUNE}
4121 static struct cdns_reg_pairs sgmii_100_no_ssc_tx_ln_regs[] = {
4122 {0x00F3, TX_PSC_A0},
4123 {0x04A2, TX_PSC_A2},
4124 {0x04A2, TX_PSC_A3},
4125 {0x0000, TX_TXCC_CPOST_MULT_00},
4126 {0x00B3, DRV_DIAG_TX_DRV},
4127 {0x0002, XCVR_DIAG_PSC_OVRD}
4130 static struct cdns_reg_pairs ti_sgmii_100_no_ssc_tx_ln_regs[] = {
4131 {0x00F3, TX_PSC_A0},
4132 {0x04A2, TX_PSC_A2},
4133 {0x04A2, TX_PSC_A3},
4134 {0x0000, TX_TXCC_CPOST_MULT_00},
4135 {0x00B3, DRV_DIAG_TX_DRV},
4136 {0x0002, XCVR_DIAG_PSC_OVRD},
4137 {0x4000, XCVR_DIAG_RXCLK_CTRL}
4140 static struct cdns_reg_pairs sgmii_100_no_ssc_rx_ln_regs[] = {
4141 {0x091D, RX_PSC_A0},
4142 {0x0900, RX_PSC_A2},
4143 {0x0100, RX_PSC_A3},
4144 {0x03C7, RX_REE_GCSM1_EQENM_PH1},
4145 {0x01C7, RX_REE_GCSM1_EQENM_PH2},
4146 {0x0000, RX_DIAG_DFE_CTRL},
4147 {0x0019, RX_REE_TAP1_CLIP},
4148 {0x0019, RX_REE_TAP2TON_CLIP},
4149 {0x0098, RX_DIAG_NQST_CTRL},
4150 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2},
4151 {0x0000, RX_DIAG_DFE_AMP_TUNE_3},
4152 {0x0000, RX_DIAG_PI_CAP},
4153 {0x0010, RX_DIAG_PI_RATE},
4154 {0x0001, RX_DIAG_ACYA},
4155 {0x018C, RX_CDRLF_CNFG},
4158 static struct cdns_torrent_vals sgmii_100_no_ssc_cmn_vals = {
4159 .reg_pairs = sgmii_100_no_ssc_cmn_regs,
4160 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_cmn_regs),
4163 static struct cdns_torrent_vals sgmii_100_no_ssc_tx_ln_vals = {
4164 .reg_pairs = sgmii_100_no_ssc_tx_ln_regs,
4165 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_tx_ln_regs),
4168 static struct cdns_torrent_vals ti_sgmii_100_no_ssc_tx_ln_vals = {
4169 .reg_pairs = ti_sgmii_100_no_ssc_tx_ln_regs,
4170 .num_regs = ARRAY_SIZE(ti_sgmii_100_no_ssc_tx_ln_regs),
4173 static struct cdns_torrent_vals sgmii_100_no_ssc_rx_ln_vals = {
4174 .reg_pairs = sgmii_100_no_ssc_rx_ln_regs,
4175 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_rx_ln_regs),
4178 /* TI J7200, multilink SGMII */
4179 static struct cdns_reg_pairs j7200_sgmii_100_no_ssc_tx_ln_regs[] = {
4180 {0x07A2, TX_RCVDET_ST_TMR},
4181 {0x00F3, TX_PSC_A0},
4182 {0x04A2, TX_PSC_A2},
4183 {0x04A2, TX_PSC_A3 },
4184 {0x0000, TX_TXCC_CPOST_MULT_00},
4185 {0x00B3, DRV_DIAG_TX_DRV},
4186 {0x0002, XCVR_DIAG_PSC_OVRD},
4187 {0x4000, XCVR_DIAG_RXCLK_CTRL}
4190 static struct cdns_torrent_vals j7200_sgmii_100_no_ssc_tx_ln_vals = {
4191 .reg_pairs = j7200_sgmii_100_no_ssc_tx_ln_regs,
4192 .num_regs = ARRAY_SIZE(j7200_sgmii_100_no_ssc_tx_ln_regs),
4195 static struct cdns_reg_pairs j7200_sgmii_100_no_ssc_rx_ln_regs[] = {
4196 {0x0014, RX_SDCAL0_INIT_TMR},
4197 {0x0062, RX_SDCAL0_ITER_TMR},
4198 {0x0014, RX_SDCAL1_INIT_TMR},
4199 {0x0062, RX_SDCAL1_ITER_TMR},
4200 {0x091D, RX_PSC_A0},
4201 {0x0900, RX_PSC_A2},
4202 {0x0100, RX_PSC_A3},
4203 {0x03C7, RX_REE_GCSM1_EQENM_PH1},
4204 {0x01C7, RX_REE_GCSM1_EQENM_PH2},
4205 {0x0000, RX_DIAG_DFE_CTRL},
4206 {0x0019, RX_REE_TAP1_CLIP},
4207 {0x0019, RX_REE_TAP2TON_CLIP},
4208 {0x0098, RX_DIAG_NQST_CTRL},
4209 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2},
4210 {0x0000, RX_DIAG_DFE_AMP_TUNE_3},
4211 {0x0000, RX_DIAG_PI_CAP},
4212 {0x0010, RX_DIAG_PI_RATE},
4213 {0x0001, RX_DIAG_ACYA},
4214 {0x018C, RX_CDRLF_CNFG}
4217 static struct cdns_torrent_vals j7200_sgmii_100_no_ssc_rx_ln_vals = {
4218 .reg_pairs = j7200_sgmii_100_no_ssc_rx_ln_regs,
4219 .num_regs = ARRAY_SIZE(j7200_sgmii_100_no_ssc_rx_ln_regs),
4222 /* SGMII 100 MHz Ref clk, internal SSC */
4223 static struct cdns_reg_pairs sgmii_100_int_ssc_cmn_regs[] = {
4224 {0x0004, CMN_PLL0_DSM_DIAG_M0},
4225 {0x0004, CMN_PLL0_DSM_DIAG_M1},
4226 {0x0004, CMN_PLL1_DSM_DIAG_M0},
4227 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
4228 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
4229 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
4230 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
4231 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
4232 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
4233 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
4234 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
4235 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
4236 {0x0064, CMN_PLL0_INTDIV_M0},
4237 {0x0050, CMN_PLL0_INTDIV_M1},
4238 {0x0064, CMN_PLL1_INTDIV_M0},
4239 {0x0002, CMN_PLL0_FRACDIVH_M0},
4240 {0x0002, CMN_PLL0_FRACDIVH_M1},
4241 {0x0002, CMN_PLL1_FRACDIVH_M0},
4242 {0x0044, CMN_PLL0_HIGH_THR_M0},
4243 {0x0036, CMN_PLL0_HIGH_THR_M1},
4244 {0x0044, CMN_PLL1_HIGH_THR_M0},
4245 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
4246 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
4247 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
4248 {0x0001, CMN_PLL0_SS_CTRL1_M0},
4249 {0x0001, CMN_PLL0_SS_CTRL1_M1},
4250 {0x0001, CMN_PLL1_SS_CTRL1_M0},
4251 {0x011B, CMN_PLL0_SS_CTRL2_M0},
4252 {0x011B, CMN_PLL0_SS_CTRL2_M1},
4253 {0x011B, CMN_PLL1_SS_CTRL2_M0},
4254 {0x006E, CMN_PLL0_SS_CTRL3_M0},
4255 {0x0058, CMN_PLL0_SS_CTRL3_M1},
4256 {0x006E, CMN_PLL1_SS_CTRL3_M0},
4257 {0x000E, CMN_PLL0_SS_CTRL4_M0},
4258 {0x0012, CMN_PLL0_SS_CTRL4_M1},
4259 {0x000E, CMN_PLL1_SS_CTRL4_M0},
4260 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
4261 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
4262 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
4263 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
4264 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
4265 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
4266 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
4267 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
4268 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
4269 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR},
4270 {0x007F, CMN_TXPUCAL_TUNE},
4271 {0x007F, CMN_TXPDCAL_TUNE}
4274 static struct cdns_torrent_vals sgmii_100_int_ssc_cmn_vals = {
4275 .reg_pairs = sgmii_100_int_ssc_cmn_regs,
4276 .num_regs = ARRAY_SIZE(sgmii_100_int_ssc_cmn_regs),
4279 /* QSGMII 100 MHz Ref clk, no SSC */
4280 static struct cdns_reg_pairs sl_qsgmii_100_no_ssc_cmn_regs[] = {
4281 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0},
4282 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0},
4283 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0},
4284 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
4285 {0x0003, CMN_PLL1_VCOCAL_TCTRL}
4288 static struct cdns_torrent_vals sl_qsgmii_100_no_ssc_cmn_vals = {
4289 .reg_pairs = sl_qsgmii_100_no_ssc_cmn_regs,
4290 .num_regs = ARRAY_SIZE(sl_qsgmii_100_no_ssc_cmn_regs),
4293 static struct cdns_reg_pairs qsgmii_100_no_ssc_cmn_regs[] = {
4294 {0x007F, CMN_TXPUCAL_TUNE},
4295 {0x007F, CMN_TXPDCAL_TUNE}
4298 static struct cdns_reg_pairs qsgmii_100_no_ssc_tx_ln_regs[] = {
4299 {0x00F3, TX_PSC_A0},
4300 {0x04A2, TX_PSC_A2},
4301 {0x04A2, TX_PSC_A3},
4302 {0x0000, TX_TXCC_CPOST_MULT_00},
4303 {0x0011, TX_TXCC_MGNFS_MULT_100},
4304 {0x0003, DRV_DIAG_TX_DRV},
4305 {0x0002, XCVR_DIAG_PSC_OVRD}
4308 static struct cdns_reg_pairs ti_qsgmii_100_no_ssc_tx_ln_regs[] = {
4309 {0x00F3, TX_PSC_A0},
4310 {0x04A2, TX_PSC_A2},
4311 {0x04A2, TX_PSC_A3},
4312 {0x0000, TX_TXCC_CPOST_MULT_00},
4313 {0x0011, TX_TXCC_MGNFS_MULT_100},
4314 {0x0003, DRV_DIAG_TX_DRV},
4315 {0x0002, XCVR_DIAG_PSC_OVRD},
4316 {0x4000, XCVR_DIAG_RXCLK_CTRL}
4319 static struct cdns_reg_pairs qsgmii_100_no_ssc_rx_ln_regs[] = {
4320 {0x091D, RX_PSC_A0},
4321 {0x0900, RX_PSC_A2},
4322 {0x0100, RX_PSC_A3},
4323 {0x03C7, RX_REE_GCSM1_EQENM_PH1},
4324 {0x01C7, RX_REE_GCSM1_EQENM_PH2},
4325 {0x0000, RX_DIAG_DFE_CTRL},
4326 {0x0019, RX_REE_TAP1_CLIP},
4327 {0x0019, RX_REE_TAP2TON_CLIP},
4328 {0x0098, RX_DIAG_NQST_CTRL},
4329 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2},
4330 {0x0000, RX_DIAG_DFE_AMP_TUNE_3},
4331 {0x0000, RX_DIAG_PI_CAP},
4332 {0x0010, RX_DIAG_PI_RATE},
4333 {0x0001, RX_DIAG_ACYA},
4334 {0x018C, RX_CDRLF_CNFG},
4337 static struct cdns_torrent_vals qsgmii_100_no_ssc_cmn_vals = {
4338 .reg_pairs = qsgmii_100_no_ssc_cmn_regs,
4339 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_cmn_regs),
4342 static struct cdns_torrent_vals qsgmii_100_no_ssc_tx_ln_vals = {
4343 .reg_pairs = qsgmii_100_no_ssc_tx_ln_regs,
4344 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_tx_ln_regs),
4347 static struct cdns_torrent_vals ti_qsgmii_100_no_ssc_tx_ln_vals = {
4348 .reg_pairs = ti_qsgmii_100_no_ssc_tx_ln_regs,
4349 .num_regs = ARRAY_SIZE(ti_qsgmii_100_no_ssc_tx_ln_regs),
4352 static struct cdns_torrent_vals qsgmii_100_no_ssc_rx_ln_vals = {
4353 .reg_pairs = qsgmii_100_no_ssc_rx_ln_regs,
4354 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_rx_ln_regs),
4357 /* TI J7200, multilink QSGMII */
4358 static struct cdns_reg_pairs j7200_qsgmii_100_no_ssc_tx_ln_regs[] = {
4359 {0x07A2, TX_RCVDET_ST_TMR},
4360 {0x00F3, TX_PSC_A0},
4361 {0x04A2, TX_PSC_A2},
4362 {0x04A2, TX_PSC_A3 },
4363 {0x0000, TX_TXCC_CPOST_MULT_00},
4364 {0x0011, TX_TXCC_MGNFS_MULT_100},
4365 {0x0003, DRV_DIAG_TX_DRV},
4366 {0x0002, XCVR_DIAG_PSC_OVRD},
4367 {0x4000, XCVR_DIAG_RXCLK_CTRL}
4370 static struct cdns_torrent_vals j7200_qsgmii_100_no_ssc_tx_ln_vals = {
4371 .reg_pairs = j7200_qsgmii_100_no_ssc_tx_ln_regs,
4372 .num_regs = ARRAY_SIZE(j7200_qsgmii_100_no_ssc_tx_ln_regs),
4375 static struct cdns_reg_pairs j7200_qsgmii_100_no_ssc_rx_ln_regs[] = {
4376 {0x0014, RX_SDCAL0_INIT_TMR},
4377 {0x0062, RX_SDCAL0_ITER_TMR},
4378 {0x0014, RX_SDCAL1_INIT_TMR},
4379 {0x0062, RX_SDCAL1_ITER_TMR},
4380 {0x091D, RX_PSC_A0},
4381 {0x0900, RX_PSC_A2},
4382 {0x0100, RX_PSC_A3},
4383 {0x03C7, RX_REE_GCSM1_EQENM_PH1},
4384 {0x01C7, RX_REE_GCSM1_EQENM_PH2},
4385 {0x0000, RX_DIAG_DFE_CTRL},
4386 {0x0019, RX_REE_TAP1_CLIP},
4387 {0x0019, RX_REE_TAP2TON_CLIP},
4388 {0x0098, RX_DIAG_NQST_CTRL},
4389 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2},
4390 {0x0000, RX_DIAG_DFE_AMP_TUNE_3},
4391 {0x0000, RX_DIAG_PI_CAP},
4392 {0x0010, RX_DIAG_PI_RATE},
4393 {0x0001, RX_DIAG_ACYA},
4394 {0x018C, RX_CDRLF_CNFG}
4397 static struct cdns_torrent_vals j7200_qsgmii_100_no_ssc_rx_ln_vals = {
4398 .reg_pairs = j7200_qsgmii_100_no_ssc_rx_ln_regs,
4399 .num_regs = ARRAY_SIZE(j7200_qsgmii_100_no_ssc_rx_ln_regs),
4402 /* QSGMII 100 MHz Ref clk, internal SSC */
4403 static struct cdns_reg_pairs qsgmii_100_int_ssc_cmn_regs[] = {
4404 {0x0004, CMN_PLL0_DSM_DIAG_M0},
4405 {0x0004, CMN_PLL0_DSM_DIAG_M1},
4406 {0x0004, CMN_PLL1_DSM_DIAG_M0},
4407 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
4408 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
4409 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
4410 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
4411 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
4412 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
4413 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
4414 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
4415 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
4416 {0x0064, CMN_PLL0_INTDIV_M0},
4417 {0x0050, CMN_PLL0_INTDIV_M1},
4418 {0x0064, CMN_PLL1_INTDIV_M0},
4419 {0x0002, CMN_PLL0_FRACDIVH_M0},
4420 {0x0002, CMN_PLL0_FRACDIVH_M1},
4421 {0x0002, CMN_PLL1_FRACDIVH_M0},
4422 {0x0044, CMN_PLL0_HIGH_THR_M0},
4423 {0x0036, CMN_PLL0_HIGH_THR_M1},
4424 {0x0044, CMN_PLL1_HIGH_THR_M0},
4425 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
4426 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
4427 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
4428 {0x0001, CMN_PLL0_SS_CTRL1_M0},
4429 {0x0001, CMN_PLL0_SS_CTRL1_M1},
4430 {0x0001, CMN_PLL1_SS_CTRL1_M0},
4431 {0x011B, CMN_PLL0_SS_CTRL2_M0},
4432 {0x011B, CMN_PLL0_SS_CTRL2_M1},
4433 {0x011B, CMN_PLL1_SS_CTRL2_M0},
4434 {0x006E, CMN_PLL0_SS_CTRL3_M0},
4435 {0x0058, CMN_PLL0_SS_CTRL3_M1},
4436 {0x006E, CMN_PLL1_SS_CTRL3_M0},
4437 {0x000E, CMN_PLL0_SS_CTRL4_M0},
4438 {0x0012, CMN_PLL0_SS_CTRL4_M1},
4439 {0x000E, CMN_PLL1_SS_CTRL4_M0},
4440 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
4441 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
4442 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
4443 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
4444 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
4445 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
4446 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
4447 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
4448 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
4449 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR},
4450 {0x007F, CMN_TXPUCAL_TUNE},
4451 {0x007F, CMN_TXPDCAL_TUNE}
4454 static struct cdns_torrent_vals qsgmii_100_int_ssc_cmn_vals = {
4455 .reg_pairs = qsgmii_100_int_ssc_cmn_regs,
4456 .num_regs = ARRAY_SIZE(qsgmii_100_int_ssc_cmn_regs),
4459 /* Single SGMII/QSGMII link configuration */
4460 static struct cdns_reg_pairs sl_sgmii_link_cmn_regs[] = {
4461 {0x0000, PHY_PLL_CFG},
4462 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0}
4465 static struct cdns_reg_pairs sl_sgmii_xcvr_diag_ln_regs[] = {
4466 {0x0000, XCVR_DIAG_HSCLK_SEL},
4467 {0x0003, XCVR_DIAG_HSCLK_DIV},
4468 {0x0013, XCVR_DIAG_PLLDRC_CTRL}
4471 static struct cdns_torrent_vals sl_sgmii_link_cmn_vals = {
4472 .reg_pairs = sl_sgmii_link_cmn_regs,
4473 .num_regs = ARRAY_SIZE(sl_sgmii_link_cmn_regs),
4476 static struct cdns_torrent_vals sl_sgmii_xcvr_diag_ln_vals = {
4477 .reg_pairs = sl_sgmii_xcvr_diag_ln_regs,
4478 .num_regs = ARRAY_SIZE(sl_sgmii_xcvr_diag_ln_regs),
4481 /* Multi link PCIe, 100 MHz Ref clk, internal SSC */
4482 static struct cdns_reg_pairs pcie_100_int_ssc_cmn_regs[] = {
4483 {0x0004, CMN_PLL0_DSM_DIAG_M0},
4484 {0x0004, CMN_PLL0_DSM_DIAG_M1},
4485 {0x0004, CMN_PLL1_DSM_DIAG_M0},
4486 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
4487 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
4488 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
4489 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
4490 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
4491 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
4492 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
4493 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
4494 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
4495 {0x0064, CMN_PLL0_INTDIV_M0},
4496 {0x0050, CMN_PLL0_INTDIV_M1},
4497 {0x0064, CMN_PLL1_INTDIV_M0},
4498 {0x0002, CMN_PLL0_FRACDIVH_M0},
4499 {0x0002, CMN_PLL0_FRACDIVH_M1},
4500 {0x0002, CMN_PLL1_FRACDIVH_M0},
4501 {0x0044, CMN_PLL0_HIGH_THR_M0},
4502 {0x0036, CMN_PLL0_HIGH_THR_M1},
4503 {0x0044, CMN_PLL1_HIGH_THR_M0},
4504 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
4505 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
4506 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
4507 {0x0001, CMN_PLL0_SS_CTRL1_M0},
4508 {0x0001, CMN_PLL0_SS_CTRL1_M1},
4509 {0x0001, CMN_PLL1_SS_CTRL1_M0},
4510 {0x011B, CMN_PLL0_SS_CTRL2_M0},
4511 {0x011B, CMN_PLL0_SS_CTRL2_M1},
4512 {0x011B, CMN_PLL1_SS_CTRL2_M0},
4513 {0x006E, CMN_PLL0_SS_CTRL3_M0},
4514 {0x0058, CMN_PLL0_SS_CTRL3_M1},
4515 {0x006E, CMN_PLL1_SS_CTRL3_M0},
4516 {0x000E, CMN_PLL0_SS_CTRL4_M0},
4517 {0x0012, CMN_PLL0_SS_CTRL4_M1},
4518 {0x000E, CMN_PLL1_SS_CTRL4_M0},
4519 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
4520 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
4521 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
4522 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
4523 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
4524 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
4525 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
4526 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
4527 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
4528 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}
4531 static struct cdns_torrent_vals pcie_100_int_ssc_cmn_vals = {
4532 .reg_pairs = pcie_100_int_ssc_cmn_regs,
4533 .num_regs = ARRAY_SIZE(pcie_100_int_ssc_cmn_regs),
4536 /* Single link PCIe, 100 MHz Ref clk, internal SSC */
4537 static struct cdns_reg_pairs sl_pcie_100_int_ssc_cmn_regs[] = {
4538 {0x0004, CMN_PLL0_DSM_DIAG_M0},
4539 {0x0004, CMN_PLL0_DSM_DIAG_M1},
4540 {0x0004, CMN_PLL1_DSM_DIAG_M0},
4541 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
4542 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
4543 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
4544 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
4545 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
4546 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
4547 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
4548 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
4549 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
4550 {0x0064, CMN_PLL0_INTDIV_M0},
4551 {0x0050, CMN_PLL0_INTDIV_M1},
4552 {0x0050, CMN_PLL1_INTDIV_M0},
4553 {0x0002, CMN_PLL0_FRACDIVH_M0},
4554 {0x0002, CMN_PLL0_FRACDIVH_M1},
4555 {0x0002, CMN_PLL1_FRACDIVH_M0},
4556 {0x0044, CMN_PLL0_HIGH_THR_M0},
4557 {0x0036, CMN_PLL0_HIGH_THR_M1},
4558 {0x0036, CMN_PLL1_HIGH_THR_M0},
4559 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
4560 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
4561 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
4562 {0x0001, CMN_PLL0_SS_CTRL1_M0},
4563 {0x0001, CMN_PLL0_SS_CTRL1_M1},
4564 {0x0001, CMN_PLL1_SS_CTRL1_M0},
4565 {0x011B, CMN_PLL0_SS_CTRL2_M0},
4566 {0x011B, CMN_PLL0_SS_CTRL2_M1},
4567 {0x011B, CMN_PLL1_SS_CTRL2_M0},
4568 {0x006E, CMN_PLL0_SS_CTRL3_M0},
4569 {0x0058, CMN_PLL0_SS_CTRL3_M1},
4570 {0x0058, CMN_PLL1_SS_CTRL3_M0},
4571 {0x000E, CMN_PLL0_SS_CTRL4_M0},
4572 {0x0012, CMN_PLL0_SS_CTRL4_M1},
4573 {0x0012, CMN_PLL1_SS_CTRL4_M0},
4574 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
4575 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
4576 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
4577 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
4578 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
4579 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
4580 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
4581 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
4582 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
4583 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}
4586 static struct cdns_torrent_vals sl_pcie_100_int_ssc_cmn_vals = {
4587 .reg_pairs = sl_pcie_100_int_ssc_cmn_regs,
4588 .num_regs = ARRAY_SIZE(sl_pcie_100_int_ssc_cmn_regs),
4591 /* PCIe, 100 MHz Ref clk, no SSC & external SSC */
4592 static struct cdns_reg_pairs pcie_100_ext_no_ssc_cmn_regs[] = {
4593 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0},
4594 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0},
4595 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0}
4598 static struct cdns_reg_pairs pcie_100_ext_no_ssc_rx_ln_regs[] = {
4599 {0x0019, RX_REE_TAP1_CLIP},
4600 {0x0019, RX_REE_TAP2TON_CLIP},
4601 {0x0001, RX_DIAG_ACYA}
4604 static struct cdns_torrent_vals pcie_100_no_ssc_cmn_vals = {
4605 .reg_pairs = pcie_100_ext_no_ssc_cmn_regs,
4606 .num_regs = ARRAY_SIZE(pcie_100_ext_no_ssc_cmn_regs),
4609 static struct cdns_torrent_vals pcie_100_no_ssc_rx_ln_vals = {
4610 .reg_pairs = pcie_100_ext_no_ssc_rx_ln_regs,
4611 .num_regs = ARRAY_SIZE(pcie_100_ext_no_ssc_rx_ln_regs),
4614 static struct cdns_torrent_vals_entry link_cmn_vals_entries[] = {
4615 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_NONE), &sl_dp_link_cmn_vals},
4616 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_PCIE), &pcie_dp_link_cmn_vals},
4617 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_USB), &usb_dp_link_cmn_vals},
4619 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_NONE), NULL},
4620 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_SGMII), &pcie_sgmii_link_cmn_vals},
4621 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_QSGMII), &pcie_sgmii_link_cmn_vals},
4622 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_USB), &pcie_usb_link_cmn_vals},
4623 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_DP), &pcie_dp_link_cmn_vals},
4624 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_USXGMII), &pcie_usxgmii_link_cmn_vals},
4626 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_NONE), &sl_sgmii_link_cmn_vals},
4627 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_PCIE), &pcie_sgmii_link_cmn_vals},
4628 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_QSGMII), &sgmii_qsgmii_link_cmn_vals},
4629 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_USB), &usb_sgmii_link_cmn_vals},
4630 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_USXGMII), &usxgmii_sgmii_link_cmn_vals},
4632 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_NONE), &sl_sgmii_link_cmn_vals},
4633 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_PCIE), &pcie_sgmii_link_cmn_vals},
4634 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_SGMII), &sgmii_qsgmii_link_cmn_vals},
4635 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_USB), &usb_sgmii_link_cmn_vals},
4636 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_USXGMII), &usxgmii_sgmii_link_cmn_vals},
4638 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_NONE), &sl_usb_link_cmn_vals},
4639 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_PCIE), &pcie_usb_link_cmn_vals},
4640 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_SGMII), &usb_sgmii_link_cmn_vals},
4641 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_QSGMII), &usb_sgmii_link_cmn_vals},
4642 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_DP), &usb_dp_link_cmn_vals},
4644 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_NONE), &sl_usxgmii_link_cmn_vals},
4645 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_PCIE), &pcie_usxgmii_link_cmn_vals},
4646 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_SGMII), &usxgmii_sgmii_link_cmn_vals},
4647 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_QSGMII), &usxgmii_sgmii_link_cmn_vals},
4650 static struct cdns_torrent_vals_entry xcvr_diag_vals_entries[] = {
4651 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_NONE), &sl_dp_xcvr_diag_ln_vals},
4652 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_PCIE), &dp_pcie_xcvr_diag_ln_vals},
4653 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP, TYPE_USB), &dp_usb_xcvr_diag_ln_vals},
4655 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_NONE), NULL},
4656 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_SGMII), &pcie_sgmii_xcvr_diag_ln_vals},
4657 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_QSGMII), &pcie_sgmii_xcvr_diag_ln_vals},
4658 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_USB), &pcie_usb_xcvr_diag_ln_vals},
4659 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_DP), &pcie_dp_xcvr_diag_ln_vals},
4660 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE, TYPE_USXGMII), &pcie_usxgmii_xcvr_diag_ln_vals},
4662 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_NONE), &sl_sgmii_xcvr_diag_ln_vals},
4663 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_PCIE), &sgmii_pcie_xcvr_diag_ln_vals},
4664 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_QSGMII), &sgmii_qsgmii_xcvr_diag_ln_vals},
4665 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_USB), &sgmii_usb_xcvr_diag_ln_vals},
4666 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII, TYPE_USXGMII), &sgmii_usxgmii_xcvr_diag_ln_vals},
4668 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_NONE), &sl_sgmii_xcvr_diag_ln_vals},
4669 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_PCIE), &sgmii_pcie_xcvr_diag_ln_vals},
4670 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_SGMII), &sgmii_qsgmii_xcvr_diag_ln_vals},
4671 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_USB), &sgmii_usb_xcvr_diag_ln_vals},
4672 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII, TYPE_USXGMII), &sgmii_usxgmii_xcvr_diag_ln_vals},
4674 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_NONE), &sl_usb_xcvr_diag_ln_vals},
4675 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_PCIE), &usb_pcie_xcvr_diag_ln_vals},
4676 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_SGMII), &usb_sgmii_xcvr_diag_ln_vals},
4677 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_QSGMII), &usb_sgmii_xcvr_diag_ln_vals},
4678 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_DP), &usb_dp_xcvr_diag_ln_vals},
4680 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_NONE), &sl_usxgmii_xcvr_diag_ln_vals},
4681 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_PCIE), &usxgmii_pcie_xcvr_diag_ln_vals},
4682 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_SGMII), &usxgmii_sgmii_xcvr_diag_ln_vals},
4683 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_QSGMII), &usxgmii_sgmii_xcvr_diag_ln_vals},
4686 static struct cdns_torrent_vals_entry pcs_cmn_vals_entries[] = {
4687 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_NONE), &usb_phy_pcs_cmn_vals},
4688 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_PCIE), &usb_phy_pcs_cmn_vals},
4689 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_SGMII), &usb_phy_pcs_cmn_vals},
4690 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_QSGMII), &usb_phy_pcs_cmn_vals},
4691 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB, TYPE_DP), &usb_phy_pcs_cmn_vals},
4694 static struct cdns_torrent_vals_entry cmn_vals_entries[] = {
4695 {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},
4696 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_cmn_vals},
4698 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_cmn_vals},
4699 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_cmn_vals},
4700 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &sl_dp_100_no_ssc_cmn_vals},
4702 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL},
4703 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL},
4704 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), &sl_pcie_100_int_ssc_cmn_vals},
4706 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), &pcie_100_no_ssc_cmn_vals},
4707 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals},
4708 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals},
4710 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), &pcie_100_no_ssc_cmn_vals},
4711 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals},
4712 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals},
4714 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), &pcie_100_no_ssc_cmn_vals},
4715 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals},
4716 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals},
4718 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL},
4720 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sl_sgmii_100_no_ssc_cmn_vals},
4722 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_cmn_vals},
4723 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals},
4724 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_int_ssc_cmn_vals},
4726 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sl_sgmii_100_no_ssc_cmn_vals},
4728 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_cmn_vals},
4729 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals},
4730 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals},
4732 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &sl_qsgmii_100_no_ssc_cmn_vals},
4734 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_cmn_vals},
4735 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals},
4736 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_int_ssc_cmn_vals},
4738 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &sl_qsgmii_100_no_ssc_cmn_vals},
4740 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_cmn_vals},
4741 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals},
4742 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals},
4744 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &sl_usb_100_no_ssc_cmn_vals},
4745 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals},
4746 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals},
4748 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_cmn_vals},
4749 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_cmn_vals},
4750 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_int_ssc_cmn_vals},
4752 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &sl_usb_100_no_ssc_cmn_vals},
4753 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals},
4754 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals},
4756 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &sl_usb_100_no_ssc_cmn_vals},
4757 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals},
4758 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals},
4760 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_cmn_vals},
4762 {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},
4765 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL},
4767 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &ml_sgmii_pll1_100_no_ssc_cmn_vals},
4769 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &ml_sgmii_pll1_100_no_ssc_cmn_vals},
4771 {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},
4772 {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},
4773 {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},
4776 static struct cdns_torrent_vals_entry cdns_tx_ln_vals_entries[] = {
4777 {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},
4778 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_tx_ln_vals},
4780 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_tx_ln_vals},
4781 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_tx_ln_vals},
4782 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_tx_ln_vals},
4784 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL},
4785 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL},
4786 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), NULL},
4788 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), NULL},
4789 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), NULL},
4790 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), NULL},
4792 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), NULL},
4793 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), NULL},
4794 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), NULL},
4796 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), NULL},
4797 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), NULL},
4798 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), NULL},
4800 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL},
4802 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4804 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4805 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4806 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4808 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4810 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4811 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4812 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4814 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4816 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4817 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4818 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4820 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4822 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4823 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4824 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4826 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
4827 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
4828 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
4830 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
4831 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
4832 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
4834 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
4835 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
4836 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
4838 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
4839 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
4840 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
4842 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
4844 {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},
4847 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL},
4849 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &sgmii_100_no_ssc_tx_ln_vals},
4851 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &qsgmii_100_no_ssc_tx_ln_vals},
4853 {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},
4854 {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},
4855 {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},
4858 static struct cdns_torrent_vals_entry cdns_rx_ln_vals_entries[] = {
4859 {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},
4860 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_rx_ln_vals},
4862 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_rx_ln_vals},
4863 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_rx_ln_vals},
4864 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_rx_ln_vals},
4866 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
4867 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
4868 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
4870 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
4871 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
4872 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
4874 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
4875 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
4876 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
4878 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
4879 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
4880 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
4882 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
4884 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4886 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4887 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4888 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4890 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4892 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4893 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4894 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4896 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4898 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4899 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4900 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4902 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4904 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4905 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4906 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4908 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
4909 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
4910 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
4912 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
4913 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
4914 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
4916 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
4917 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
4918 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
4920 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
4921 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
4922 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
4924 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
4926 {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},
4929 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
4931 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
4933 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
4935 {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},
4936 {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},
4937 {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},
4940 static const struct cdns_torrent_data cdns_map_torrent = {
4941 .block_offset_shift = 0x2,
4942 .reg_offset_shift = 0x2,
4943 .link_cmn_vals_tbl = {
4944 .entries = link_cmn_vals_entries,
4945 .num_entries = ARRAY_SIZE(link_cmn_vals_entries),
4947 .xcvr_diag_vals_tbl = {
4948 .entries = xcvr_diag_vals_entries,
4949 .num_entries = ARRAY_SIZE(xcvr_diag_vals_entries),
4951 .pcs_cmn_vals_tbl = {
4952 .entries = pcs_cmn_vals_entries,
4953 .num_entries = ARRAY_SIZE(pcs_cmn_vals_entries),
4956 .entries = cmn_vals_entries,
4957 .num_entries = ARRAY_SIZE(cmn_vals_entries),
4960 .entries = cdns_tx_ln_vals_entries,
4961 .num_entries = ARRAY_SIZE(cdns_tx_ln_vals_entries),
4964 .entries = cdns_rx_ln_vals_entries,
4965 .num_entries = ARRAY_SIZE(cdns_rx_ln_vals_entries),
4969 static struct cdns_torrent_vals_entry j721e_phy_pma_cmn_vals_entries[] = {
4970 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_NONE), &ti_usxgmii_phy_pma_cmn_vals},
4971 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_PCIE), &ti_usxgmii_phy_pma_cmn_vals},
4972 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_SGMII), &ti_usxgmii_phy_pma_cmn_vals},
4973 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII, TYPE_QSGMII), &ti_usxgmii_phy_pma_cmn_vals},
4976 static struct cdns_torrent_vals_entry ti_tx_ln_vals_entries[] = {
4977 {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},
4978 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_tx_ln_vals},
4980 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_tx_ln_vals},
4981 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_tx_ln_vals},
4982 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_tx_ln_vals},
4984 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL},
4985 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL},
4986 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), NULL},
4988 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), NULL},
4989 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), NULL},
4990 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), NULL},
4992 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), NULL},
4993 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), NULL},
4994 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), NULL},
4996 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), NULL},
4997 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), NULL},
4998 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), NULL},
5000 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL},
5002 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5004 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5005 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5006 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5008 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5010 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5011 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5012 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5014 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5016 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5017 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5018 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5020 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5022 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5023 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5024 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5026 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5027 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5028 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5030 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5031 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5032 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5034 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5035 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5036 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5038 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5039 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5040 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5042 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5044 {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},
5047 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL},
5049 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5051 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5053 {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},
5054 {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},
5055 {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},
5058 static const struct cdns_torrent_data ti_j721e_map_torrent = {
5059 .block_offset_shift = 0x0,
5060 .reg_offset_shift = 0x1,
5061 .link_cmn_vals_tbl = {
5062 .entries = link_cmn_vals_entries,
5063 .num_entries = ARRAY_SIZE(link_cmn_vals_entries),
5065 .xcvr_diag_vals_tbl = {
5066 .entries = xcvr_diag_vals_entries,
5067 .num_entries = ARRAY_SIZE(xcvr_diag_vals_entries),
5069 .pcs_cmn_vals_tbl = {
5070 .entries = pcs_cmn_vals_entries,
5071 .num_entries = ARRAY_SIZE(pcs_cmn_vals_entries),
5073 .phy_pma_cmn_vals_tbl = {
5074 .entries = j721e_phy_pma_cmn_vals_entries,
5075 .num_entries = ARRAY_SIZE(j721e_phy_pma_cmn_vals_entries),
5078 .entries = cmn_vals_entries,
5079 .num_entries = ARRAY_SIZE(cmn_vals_entries),
5082 .entries = ti_tx_ln_vals_entries,
5083 .num_entries = ARRAY_SIZE(ti_tx_ln_vals_entries),
5086 .entries = cdns_rx_ln_vals_entries,
5087 .num_entries = ARRAY_SIZE(cdns_rx_ln_vals_entries),
5091 /* TI J7200 (Torrent SD0805) */
5092 static struct cdns_torrent_vals_entry ti_j7200_cmn_vals_entries[] = {
5093 {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},
5094 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_cmn_vals},
5096 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_cmn_vals},
5097 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_cmn_vals},
5098 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &sl_dp_100_no_ssc_cmn_vals},
5100 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL},
5101 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL},
5102 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), &sl_pcie_100_int_ssc_cmn_vals},
5104 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), &pcie_100_no_ssc_cmn_vals},
5105 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals},
5106 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals},
5108 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), &pcie_100_no_ssc_cmn_vals},
5109 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals},
5110 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals},
5112 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), &pcie_100_no_ssc_cmn_vals},
5113 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), &pcie_100_no_ssc_cmn_vals},
5114 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), &pcie_100_int_ssc_cmn_vals},
5116 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL},
5118 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sl_sgmii_100_no_ssc_cmn_vals},
5120 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_cmn_vals},
5121 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals},
5122 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_int_ssc_cmn_vals},
5124 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sl_sgmii_100_no_ssc_cmn_vals},
5126 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_cmn_vals},
5127 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals},
5128 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_cmn_vals},
5130 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &sl_qsgmii_100_no_ssc_cmn_vals},
5132 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_cmn_vals},
5133 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals},
5134 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_int_ssc_cmn_vals},
5136 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &sl_qsgmii_100_no_ssc_cmn_vals},
5138 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_cmn_vals},
5139 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals},
5140 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_cmn_vals},
5142 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &sl_usb_100_no_ssc_cmn_vals},
5143 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals},
5144 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals},
5146 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_cmn_vals},
5147 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_cmn_vals},
5148 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_int_ssc_cmn_vals},
5150 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &sl_usb_100_no_ssc_cmn_vals},
5151 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals},
5152 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals},
5154 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &sl_usb_100_no_ssc_cmn_vals},
5155 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &sl_usb_100_no_ssc_cmn_vals},
5156 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &sl_usb_100_int_ssc_cmn_vals},
5158 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_cmn_vals},
5160 {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},
5163 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL},
5165 {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},
5167 {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},
5169 {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},
5170 {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},
5171 {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},
5174 static struct cdns_torrent_vals_entry ti_j7200_tx_ln_vals_entries[] = {
5175 {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},
5176 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_tx_ln_vals},
5178 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_tx_ln_vals},
5179 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_tx_ln_vals},
5180 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_tx_ln_vals},
5182 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), NULL},
5183 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), NULL},
5184 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), NULL},
5186 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), NULL},
5187 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), NULL},
5188 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), NULL},
5190 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), NULL},
5191 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), NULL},
5192 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), NULL},
5194 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), NULL},
5195 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), NULL},
5196 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), NULL},
5198 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), NULL},
5200 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5202 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5203 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5204 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5206 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5208 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5209 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5210 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &ti_sgmii_100_no_ssc_tx_ln_vals},
5212 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5214 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5215 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5216 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5218 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5220 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5221 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5222 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &ti_qsgmii_100_no_ssc_tx_ln_vals},
5224 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5225 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5226 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5228 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5229 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5230 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5232 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5233 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5234 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5236 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5237 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5238 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_tx_ln_vals},
5240 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_tx_ln_vals},
5242 {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},
5245 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), NULL},
5247 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &j7200_sgmii_100_no_ssc_tx_ln_vals},
5249 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &j7200_qsgmii_100_no_ssc_tx_ln_vals},
5251 {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},
5252 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &usxgmii_156_25_no_ssc_tx_ln_vals},
5253 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &usxgmii_156_25_no_ssc_tx_ln_vals},
5256 static struct cdns_torrent_vals_entry ti_j7200_rx_ln_vals_entries[] = {
5257 {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},
5258 {CDNS_TORRENT_KEY(CLK_25_MHZ, CLK_25_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_25_no_ssc_rx_ln_vals},
5260 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_NONE, NO_SSC), &sl_dp_100_no_ssc_rx_ln_vals},
5261 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_PCIE, NO_SSC), &dp_100_no_ssc_rx_ln_vals},
5262 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_DP, TYPE_USB, NO_SSC), &dp_100_no_ssc_rx_ln_vals},
5264 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
5265 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
5266 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_NONE, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
5268 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
5269 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
5270 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_SGMII, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
5272 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
5273 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
5274 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_QSGMII, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
5276 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
5277 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, EXTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
5278 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_USB, INTERNAL_SSC), &pcie_100_no_ssc_rx_ln_vals},
5280 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_PCIE, TYPE_DP, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
5282 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_NONE, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
5284 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
5285 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, EXTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals},
5286 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_PCIE, INTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals},
5288 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_QSGMII, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
5290 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, NO_SSC), &sgmii_100_no_ssc_rx_ln_vals},
5291 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, EXTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals},
5292 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_SGMII, TYPE_USB, INTERNAL_SSC), &sgmii_100_no_ssc_rx_ln_vals},
5294 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_NONE, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
5296 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
5297 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, EXTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
5298 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_PCIE, INTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
5300 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_SGMII, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
5302 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, NO_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
5303 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, EXTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
5304 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_QSGMII, TYPE_USB, INTERNAL_SSC), &qsgmii_100_no_ssc_rx_ln_vals},
5306 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
5307 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
5308 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_NONE, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
5310 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
5311 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
5312 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_PCIE, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
5314 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
5315 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
5316 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_SGMII, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
5318 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
5319 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, EXTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
5320 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_QSGMII, INTERNAL_SSC), &usb_100_no_ssc_rx_ln_vals},
5322 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_100_MHZ, TYPE_USB, TYPE_DP, NO_SSC), &usb_100_no_ssc_rx_ln_vals},
5324 {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},
5327 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_PCIE, TYPE_USXGMII, NO_SSC), &pcie_100_no_ssc_rx_ln_vals},
5329 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_SGMII, TYPE_USXGMII, NO_SSC), &j7200_sgmii_100_no_ssc_rx_ln_vals},
5331 {CDNS_TORRENT_KEY(CLK_100_MHZ, CLK_156_25_MHZ, TYPE_QSGMII, TYPE_USXGMII, NO_SSC), &j7200_qsgmii_100_no_ssc_rx_ln_vals},
5333 {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},
5334 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_SGMII, NO_SSC), &usxgmii_156_25_no_ssc_rx_ln_vals},
5335 {CDNS_TORRENT_KEY(CLK_156_25_MHZ, CLK_100_MHZ, TYPE_USXGMII, TYPE_QSGMII, NO_SSC), &usxgmii_156_25_no_ssc_rx_ln_vals},
5338 static const struct cdns_torrent_data ti_j7200_map_torrent = {
5339 .block_offset_shift = 0x0,
5340 .reg_offset_shift = 0x1,
5341 .link_cmn_vals_tbl = {
5342 .entries = link_cmn_vals_entries,
5343 .num_entries = ARRAY_SIZE(link_cmn_vals_entries),
5345 .xcvr_diag_vals_tbl = {
5346 .entries = xcvr_diag_vals_entries,
5347 .num_entries = ARRAY_SIZE(xcvr_diag_vals_entries),
5349 .pcs_cmn_vals_tbl = {
5350 .entries = pcs_cmn_vals_entries,
5351 .num_entries = ARRAY_SIZE(pcs_cmn_vals_entries),
5353 .phy_pma_cmn_vals_tbl = {
5354 .entries = j721e_phy_pma_cmn_vals_entries,
5355 .num_entries = ARRAY_SIZE(j721e_phy_pma_cmn_vals_entries),
5358 .entries = ti_j7200_cmn_vals_entries,
5359 .num_entries = ARRAY_SIZE(ti_j7200_cmn_vals_entries),
5362 .entries = ti_j7200_tx_ln_vals_entries,
5363 .num_entries = ARRAY_SIZE(ti_j7200_tx_ln_vals_entries),
5366 .entries = ti_j7200_rx_ln_vals_entries,
5367 .num_entries = ARRAY_SIZE(ti_j7200_rx_ln_vals_entries),
5371 static const struct of_device_id cdns_torrent_phy_of_match[] = {
5373 .compatible = "cdns,torrent-phy",
5374 .data = &cdns_map_torrent,
5377 .compatible = "ti,j721e-serdes-10g",
5378 .data = &ti_j721e_map_torrent,
5381 .compatible = "ti,j7200-serdes-10g",
5382 .data = &ti_j7200_map_torrent,
5386 MODULE_DEVICE_TABLE(of, cdns_torrent_phy_of_match);
5388 static struct platform_driver cdns_torrent_phy_driver = {
5389 .probe = cdns_torrent_phy_probe,
5390 .remove_new = cdns_torrent_phy_remove,
5392 .name = "cdns-torrent-phy",
5393 .of_match_table = cdns_torrent_phy_of_match,
5394 .pm = pm_sleep_ptr(&cdns_torrent_phy_pm_ops),
5397 module_platform_driver(cdns_torrent_phy_driver);
5399 MODULE_AUTHOR("Cadence Design Systems, Inc.");
5400 MODULE_DESCRIPTION("Cadence Torrent PHY driver");
5401 MODULE_LICENSE("GPL v2");