1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3 * Cadence Torrent SD0801 PHY driver.
4 *
5 * Copyright 2018 Cadence Design Systems, Inc.
6 *
7 */
8
9 #include <dt-bindings/phy/phy.h>
10 #include <linux/clk.h>
11 #include <linux/delay.h>
12 #include <linux/err.h>
13 #include <linux/io.h>
14 #include <linux/iopoll.h>
15 #include <linux/kernel.h>
16 #include <linux/module.h>
17 #include <linux/of.h>
18 #include <linux/of_address.h>
19 #include <linux/of_device.h>
20 #include <linux/phy/phy.h>
21 #include <linux/platform_device.h>
22 #include <linux/reset.h>
23 #include <linux/regmap.h>
24
25 #define REF_CLK_19_2MHz 19200000
26 #define REF_CLK_25MHz 25000000
27
28 #define MAX_NUM_LANES 4
29 #define DEFAULT_MAX_BIT_RATE 8100 /* in Mbps */
30
31 #define NUM_SSC_MODE 3
32 #define NUM_PHY_TYPE 6
33
34 #define POLL_TIMEOUT_US 5000
35 #define PLL_LOCK_TIMEOUT 100000
36
37 #define TORRENT_COMMON_CDB_OFFSET 0x0
38
39 #define TORRENT_TX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \
40 ((0x4000 << (block_offset)) + \
41 (((ln) << 9) << (reg_offset)))
42
43 #define TORRENT_RX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \
44 ((0x8000 << (block_offset)) + \
45 (((ln) << 9) << (reg_offset)))
46
47 #define TORRENT_PHY_PCS_COMMON_OFFSET(block_offset) \
48 (0xC000 << (block_offset))
49
50 #define TORRENT_PHY_PMA_COMMON_OFFSET(block_offset) \
51 (0xE000 << (block_offset))
52
53 #define TORRENT_DPTX_PHY_OFFSET 0x0
54
55 /*
56 * register offsets from DPTX PHY register block base (i.e MHDP
57 * register base + 0x30a00)
58 */
59 #define PHY_AUX_CTRL 0x04
60 #define PHY_RESET 0x20
61 #define PMA_TX_ELEC_IDLE_MASK 0xF0U
62 #define PMA_TX_ELEC_IDLE_SHIFT 4
63 #define PHY_L00_RESET_N_MASK 0x01U
64 #define PHY_PMA_XCVR_PLLCLK_EN 0x24
65 #define PHY_PMA_XCVR_PLLCLK_EN_ACK 0x28
66 #define PHY_PMA_XCVR_POWER_STATE_REQ 0x2c
67 #define PHY_POWER_STATE_LN_0 0x0000
68 #define PHY_POWER_STATE_LN_1 0x0008
69 #define PHY_POWER_STATE_LN_2 0x0010
70 #define PHY_POWER_STATE_LN_3 0x0018
71 #define PMA_XCVR_POWER_STATE_REQ_LN_MASK 0x3FU
72 #define PHY_PMA_XCVR_POWER_STATE_ACK 0x30
73 #define PHY_PMA_CMN_READY 0x34
74
75 /*
76 * register offsets from SD0801 PHY register block base (i.e MHDP
77 * register base + 0x500000)
78 */
79 #define CMN_SSM_BANDGAP_TMR 0x0021U
80 #define CMN_SSM_BIAS_TMR 0x0022U
81 #define CMN_PLLSM0_PLLPRE_TMR 0x002AU
82 #define CMN_PLLSM0_PLLLOCK_TMR 0x002CU
83 #define CMN_PLLSM1_PLLPRE_TMR 0x0032U
84 #define CMN_PLLSM1_PLLLOCK_TMR 0x0034U
85 #define CMN_CDIAG_CDB_PWRI_OVRD 0x0041U
86 #define CMN_CDIAG_XCVRC_PWRI_OVRD 0x0047U
87 #define CMN_BGCAL_INIT_TMR 0x0064U
88 #define CMN_BGCAL_ITER_TMR 0x0065U
89 #define CMN_IBCAL_INIT_TMR 0x0074U
90 #define CMN_PLL0_VCOCAL_TCTRL 0x0082U
91 #define CMN_PLL0_VCOCAL_INIT_TMR 0x0084U
92 #define CMN_PLL0_VCOCAL_ITER_TMR 0x0085U
93 #define CMN_PLL0_VCOCAL_REFTIM_START 0x0086U
94 #define CMN_PLL0_VCOCAL_PLLCNT_START 0x0088U
95 #define CMN_PLL0_INTDIV_M0 0x0090U
96 #define CMN_PLL0_FRACDIVL_M0 0x0091U
97 #define CMN_PLL0_FRACDIVH_M0 0x0092U
98 #define CMN_PLL0_HIGH_THR_M0 0x0093U
99 #define CMN_PLL0_DSM_DIAG_M0 0x0094U
100 #define CMN_PLL0_SS_CTRL1_M0 0x0098U
101 #define CMN_PLL0_SS_CTRL2_M0 0x0099U
102 #define CMN_PLL0_SS_CTRL3_M0 0x009AU
103 #define CMN_PLL0_SS_CTRL4_M0 0x009BU
104 #define CMN_PLL0_LOCK_REFCNT_START 0x009CU
105 #define CMN_PLL0_LOCK_PLLCNT_START 0x009EU
106 #define CMN_PLL0_LOCK_PLLCNT_THR 0x009FU
107 #define CMN_PLL0_INTDIV_M1 0x00A0U
108 #define CMN_PLL0_FRACDIVH_M1 0x00A2U
109 #define CMN_PLL0_HIGH_THR_M1 0x00A3U
110 #define CMN_PLL0_DSM_DIAG_M1 0x00A4U
111 #define CMN_PLL0_SS_CTRL1_M1 0x00A8U
112 #define CMN_PLL0_SS_CTRL2_M1 0x00A9U
113 #define CMN_PLL0_SS_CTRL3_M1 0x00AAU
114 #define CMN_PLL0_SS_CTRL4_M1 0x00ABU
115 #define CMN_PLL1_VCOCAL_TCTRL 0x00C2U
116 #define CMN_PLL1_VCOCAL_INIT_TMR 0x00C4U
117 #define CMN_PLL1_VCOCAL_ITER_TMR 0x00C5U
118 #define CMN_PLL1_VCOCAL_REFTIM_START 0x00C6U
119 #define CMN_PLL1_VCOCAL_PLLCNT_START 0x00C8U
120 #define CMN_PLL1_INTDIV_M0 0x00D0U
121 #define CMN_PLL1_FRACDIVL_M0 0x00D1U
122 #define CMN_PLL1_FRACDIVH_M0 0x00D2U
123 #define CMN_PLL1_HIGH_THR_M0 0x00D3U
124 #define CMN_PLL1_DSM_DIAG_M0 0x00D4U
125 #define CMN_PLL1_SS_CTRL1_M0 0x00D8U
126 #define CMN_PLL1_SS_CTRL2_M0 0x00D9U
127 #define CMN_PLL1_SS_CTRL3_M0 0x00DAU
128 #define CMN_PLL1_SS_CTRL4_M0 0x00DBU
129 #define CMN_PLL1_LOCK_REFCNT_START 0x00DCU
130 #define CMN_PLL1_LOCK_PLLCNT_START 0x00DEU
131 #define CMN_PLL1_LOCK_PLLCNT_THR 0x00DFU
132 #define CMN_TXPUCAL_TUNE 0x0103U
133 #define CMN_TXPUCAL_INIT_TMR 0x0104U
134 #define CMN_TXPUCAL_ITER_TMR 0x0105U
135 #define CMN_TXPDCAL_TUNE 0x010BU
136 #define CMN_TXPDCAL_INIT_TMR 0x010CU
137 #define CMN_TXPDCAL_ITER_TMR 0x010DU
138 #define CMN_RXCAL_INIT_TMR 0x0114U
139 #define CMN_RXCAL_ITER_TMR 0x0115U
140 #define CMN_SD_CAL_INIT_TMR 0x0124U
141 #define CMN_SD_CAL_ITER_TMR 0x0125U
142 #define CMN_SD_CAL_REFTIM_START 0x0126U
143 #define CMN_SD_CAL_PLLCNT_START 0x0128U
144 #define CMN_PDIAG_PLL0_CTRL_M0 0x01A0U
145 #define CMN_PDIAG_PLL0_CLK_SEL_M0 0x01A1U
146 #define CMN_PDIAG_PLL0_CP_PADJ_M0 0x01A4U
147 #define CMN_PDIAG_PLL0_CP_IADJ_M0 0x01A5U
148 #define CMN_PDIAG_PLL0_FILT_PADJ_M0 0x01A6U
149 #define CMN_PDIAG_PLL0_CTRL_M1 0x01B0U
150 #define CMN_PDIAG_PLL0_CLK_SEL_M1 0x01B1U
151 #define CMN_PDIAG_PLL0_CP_PADJ_M1 0x01B4U
152 #define CMN_PDIAG_PLL0_CP_IADJ_M1 0x01B5U
153 #define CMN_PDIAG_PLL0_FILT_PADJ_M1 0x01B6U
154 #define CMN_PDIAG_PLL1_CTRL_M0 0x01C0U
155 #define CMN_PDIAG_PLL1_CLK_SEL_M0 0x01C1U
156 #define CMN_PDIAG_PLL1_CP_PADJ_M0 0x01C4U
157 #define CMN_PDIAG_PLL1_CP_IADJ_M0 0x01C5U
158 #define CMN_PDIAG_PLL1_FILT_PADJ_M0 0x01C6U
159 #define CMN_DIAG_BIAS_OVRD1 0x01E1U
160
161 /* PMA TX Lane registers */
162 #define TX_TXCC_CTRL 0x0040U
163 #define TX_TXCC_CPOST_MULT_00 0x004CU
164 #define TX_TXCC_CPOST_MULT_01 0x004DU
165 #define TX_TXCC_MGNFS_MULT_000 0x0050U
166 #define DRV_DIAG_TX_DRV 0x00C6U
167 #define XCVR_DIAG_PLLDRC_CTRL 0x00E5U
168 #define XCVR_DIAG_HSCLK_SEL 0x00E6U
169 #define XCVR_DIAG_HSCLK_DIV 0x00E7U
170 #define XCVR_DIAG_BIDI_CTRL 0x00EAU
171 #define XCVR_DIAG_PSC_OVRD 0x00EBU
172 #define TX_PSC_A0 0x0100U
173 #define TX_PSC_A1 0x0101U
174 #define TX_PSC_A2 0x0102U
175 #define TX_PSC_A3 0x0103U
176 #define TX_RCVDET_ST_TMR 0x0123U
177 #define TX_DIAG_ACYA 0x01E7U
178 #define TX_DIAG_ACYA_HBDC_MASK 0x0001U
179
180 /* PMA RX Lane registers */
181 #define RX_PSC_A0 0x0000U
182 #define RX_PSC_A1 0x0001U
183 #define RX_PSC_A2 0x0002U
184 #define RX_PSC_A3 0x0003U
185 #define RX_PSC_CAL 0x0006U
186 #define RX_CDRLF_CNFG 0x0080U
187 #define RX_CDRLF_CNFG3 0x0082U
188 #define RX_SIGDET_HL_FILT_TMR 0x0090U
189 #define RX_REE_GCSM1_CTRL 0x0108U
190 #define RX_REE_GCSM1_EQENM_PH1 0x0109U
191 #define RX_REE_GCSM1_EQENM_PH2 0x010AU
192 #define RX_REE_GCSM2_CTRL 0x0110U
193 #define RX_REE_PERGCSM_CTRL 0x0118U
194 #define RX_REE_ATTEN_THR 0x0149U
195 #define RX_REE_TAP1_CLIP 0x0171U
196 #define RX_REE_TAP2TON_CLIP 0x0172U
197 #define RX_REE_SMGM_CTRL1 0x0177U
198 #define RX_REE_SMGM_CTRL2 0x0178U
199 #define RX_DIAG_DFE_CTRL 0x01E0U
200 #define RX_DIAG_DFE_AMP_TUNE_2 0x01E2U
201 #define RX_DIAG_DFE_AMP_TUNE_3 0x01E3U
202 #define RX_DIAG_NQST_CTRL 0x01E5U
203 #define RX_DIAG_SIGDET_TUNE 0x01E8U
204 #define RX_DIAG_PI_RATE 0x01F4U
205 #define RX_DIAG_PI_CAP 0x01F5U
206 #define RX_DIAG_ACYA 0x01FFU
207
208 /* PHY PCS common registers */
209 #define PHY_PLL_CFG 0x000EU
210 #define PHY_PIPE_USB3_GEN2_PRE_CFG0 0x0020U
211 #define PHY_PIPE_USB3_GEN2_POST_CFG0 0x0022U
212 #define PHY_PIPE_USB3_GEN2_POST_CFG1 0x0023U
213
214 /* PHY PMA common registers */
215 #define PHY_PMA_CMN_CTRL1 0x0000U
216 #define PHY_PMA_CMN_CTRL2 0x0001U
217 #define PHY_PMA_PLL_RAW_CTRL 0x0003U
218
219 static const struct reg_field phy_pll_cfg =
220 REG_FIELD(PHY_PLL_CFG, 0, 1);
221
222 static const struct reg_field phy_pma_cmn_ctrl_1 =
223 REG_FIELD(PHY_PMA_CMN_CTRL1, 0, 0);
224
225 static const struct reg_field phy_pma_cmn_ctrl_2 =
226 REG_FIELD(PHY_PMA_CMN_CTRL2, 0, 7);
227
228 static const struct reg_field phy_pma_pll_raw_ctrl =
229 REG_FIELD(PHY_PMA_PLL_RAW_CTRL, 0, 1);
230
231 static const struct reg_field phy_reset_ctrl =
232 REG_FIELD(PHY_RESET, 8, 8);
233
234 enum cdns_torrent_phy_type {
235 TYPE_NONE,
236 TYPE_DP,
237 TYPE_PCIE,
238 TYPE_SGMII,
239 TYPE_QSGMII,
240 TYPE_USB,
241 };
242
243 enum cdns_torrent_ssc_mode {
244 NO_SSC,
245 EXTERNAL_SSC,
246 INTERNAL_SSC
247 };
248
249 struct cdns_torrent_inst {
250 struct phy *phy;
251 u32 mlane;
252 enum cdns_torrent_phy_type phy_type;
253 u32 num_lanes;
254 struct reset_control *lnk_rst;
255 enum cdns_torrent_ssc_mode ssc_mode;
256 };
257
258 struct cdns_torrent_phy {
259 void __iomem *base; /* DPTX registers base */
260 void __iomem *sd_base; /* SD0801 registers base */
261 u32 max_bit_rate; /* Maximum link bit rate to use (in Mbps) */
262 struct reset_control *phy_rst;
263 struct reset_control *apb_rst;
264 struct device *dev;
265 struct clk *clk;
266 unsigned long ref_clk_rate;
267 struct cdns_torrent_inst phys[MAX_NUM_LANES];
268 int nsubnodes;
269 const struct cdns_torrent_data *init_data;
270 struct regmap *regmap;
271 struct regmap *regmap_common_cdb;
272 struct regmap *regmap_phy_pcs_common_cdb;
273 struct regmap *regmap_phy_pma_common_cdb;
274 struct regmap *regmap_tx_lane_cdb[MAX_NUM_LANES];
275 struct regmap *regmap_rx_lane_cdb[MAX_NUM_LANES];
276 struct regmap *regmap_dptx_phy_reg;
277 struct regmap_field *phy_pll_cfg;
278 struct regmap_field *phy_pma_cmn_ctrl_1;
279 struct regmap_field *phy_pma_cmn_ctrl_2;
280 struct regmap_field *phy_pma_pll_raw_ctrl;
281 struct regmap_field *phy_reset_ctrl;
282 };
283
284 enum phy_powerstate {
285 POWERSTATE_A0 = 0,
286 /* Powerstate A1 is unused */
287 POWERSTATE_A2 = 2,
288 POWERSTATE_A3 = 3,
289 };
290
291 static int cdns_torrent_phy_init(struct phy *phy);
292 static int cdns_torrent_dp_init(struct phy *phy);
293 static int cdns_torrent_dp_run(struct cdns_torrent_phy *cdns_phy,
294 u32 num_lanes);
295 static
296 int cdns_torrent_dp_wait_pma_cmn_ready(struct cdns_torrent_phy *cdns_phy);
297 static void cdns_torrent_dp_pma_cfg(struct cdns_torrent_phy *cdns_phy,
298 struct cdns_torrent_inst *inst);
299 static
300 void cdns_torrent_dp_pma_cmn_cfg_19_2mhz(struct cdns_torrent_phy *cdns_phy);
301 static
302 void cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(struct cdns_torrent_phy *cdns_phy,
303 u32 rate, bool ssc);
304 static
305 void cdns_torrent_dp_pma_cmn_cfg_25mhz(struct cdns_torrent_phy *cdns_phy);
306 static
307 void cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(struct cdns_torrent_phy *cdns_phy,
308 u32 rate, bool ssc);
309 static void cdns_torrent_dp_pma_lane_cfg(struct cdns_torrent_phy *cdns_phy,
310 unsigned int lane);
311 static void cdns_torrent_dp_pma_cmn_rate(struct cdns_torrent_phy *cdns_phy,
312 u32 rate, u32 num_lanes);
313 static int cdns_torrent_dp_configure(struct phy *phy,
314 union phy_configure_opts *opts);
315 static int cdns_torrent_dp_set_power_state(struct cdns_torrent_phy *cdns_phy,
316 u32 num_lanes,
317 enum phy_powerstate powerstate);
318 static int cdns_torrent_phy_on(struct phy *phy);
319 static int cdns_torrent_phy_off(struct phy *phy);
320
321 static const struct phy_ops cdns_torrent_phy_ops = {
322 .init = cdns_torrent_phy_init,
323 .configure = cdns_torrent_dp_configure,
324 .power_on = cdns_torrent_phy_on,
325 .power_off = cdns_torrent_phy_off,
326 .owner = THIS_MODULE,
327 };
328
329 struct cdns_reg_pairs {
330 u32 val;
331 u32 off;
332 };
333
334 struct cdns_torrent_vals {
335 struct cdns_reg_pairs *reg_pairs;
336 u32 num_regs;
337 };
338
339 struct cdns_torrent_data {
340 u8 block_offset_shift;
341 u8 reg_offset_shift;
342 struct cdns_torrent_vals *link_cmn_vals[NUM_PHY_TYPE][NUM_PHY_TYPE]
343 [NUM_SSC_MODE];
344 struct cdns_torrent_vals *xcvr_diag_vals[NUM_PHY_TYPE][NUM_PHY_TYPE]
345 [NUM_SSC_MODE];
346 struct cdns_torrent_vals *pcs_cmn_vals[NUM_PHY_TYPE][NUM_PHY_TYPE]
347 [NUM_SSC_MODE];
348 struct cdns_torrent_vals *cmn_vals[NUM_PHY_TYPE][NUM_PHY_TYPE]
349 [NUM_SSC_MODE];
350 struct cdns_torrent_vals *tx_ln_vals[NUM_PHY_TYPE][NUM_PHY_TYPE]
351 [NUM_SSC_MODE];
352 struct cdns_torrent_vals *rx_ln_vals[NUM_PHY_TYPE][NUM_PHY_TYPE]
353 [NUM_SSC_MODE];
354 };
355
356 struct cdns_regmap_cdb_context {
357 struct device *dev;
358 void __iomem *base;
359 u8 reg_offset_shift;
360 };
361
cdns_regmap_write(void * context,unsigned int reg,unsigned int val)362 static int cdns_regmap_write(void *context, unsigned int reg, unsigned int val)
363 {
364 struct cdns_regmap_cdb_context *ctx = context;
365 u32 offset = reg << ctx->reg_offset_shift;
366
367 writew(val, ctx->base + offset);
368
369 return 0;
370 }
371
cdns_regmap_read(void * context,unsigned int reg,unsigned int * val)372 static int cdns_regmap_read(void *context, unsigned int reg, unsigned int *val)
373 {
374 struct cdns_regmap_cdb_context *ctx = context;
375 u32 offset = reg << ctx->reg_offset_shift;
376
377 *val = readw(ctx->base + offset);
378 return 0;
379 }
380
cdns_regmap_dptx_write(void * context,unsigned int reg,unsigned int val)381 static int cdns_regmap_dptx_write(void *context, unsigned int reg,
382 unsigned int val)
383 {
384 struct cdns_regmap_cdb_context *ctx = context;
385 u32 offset = reg;
386
387 writel(val, ctx->base + offset);
388
389 return 0;
390 }
391
cdns_regmap_dptx_read(void * context,unsigned int reg,unsigned int * val)392 static int cdns_regmap_dptx_read(void *context, unsigned int reg,
393 unsigned int *val)
394 {
395 struct cdns_regmap_cdb_context *ctx = context;
396 u32 offset = reg;
397
398 *val = readl(ctx->base + offset);
399 return 0;
400 }
401
402 #define TORRENT_TX_LANE_CDB_REGMAP_CONF(n) \
403 { \
404 .name = "torrent_tx_lane" n "_cdb", \
405 .reg_stride = 1, \
406 .fast_io = true, \
407 .reg_write = cdns_regmap_write, \
408 .reg_read = cdns_regmap_read, \
409 }
410
411 #define TORRENT_RX_LANE_CDB_REGMAP_CONF(n) \
412 { \
413 .name = "torrent_rx_lane" n "_cdb", \
414 .reg_stride = 1, \
415 .fast_io = true, \
416 .reg_write = cdns_regmap_write, \
417 .reg_read = cdns_regmap_read, \
418 }
419
420 static const struct regmap_config cdns_torrent_tx_lane_cdb_config[] = {
421 TORRENT_TX_LANE_CDB_REGMAP_CONF("0"),
422 TORRENT_TX_LANE_CDB_REGMAP_CONF("1"),
423 TORRENT_TX_LANE_CDB_REGMAP_CONF("2"),
424 TORRENT_TX_LANE_CDB_REGMAP_CONF("3"),
425 };
426
427 static const struct regmap_config cdns_torrent_rx_lane_cdb_config[] = {
428 TORRENT_RX_LANE_CDB_REGMAP_CONF("0"),
429 TORRENT_RX_LANE_CDB_REGMAP_CONF("1"),
430 TORRENT_RX_LANE_CDB_REGMAP_CONF("2"),
431 TORRENT_RX_LANE_CDB_REGMAP_CONF("3"),
432 };
433
434 static const struct regmap_config cdns_torrent_common_cdb_config = {
435 .name = "torrent_common_cdb",
436 .reg_stride = 1,
437 .fast_io = true,
438 .reg_write = cdns_regmap_write,
439 .reg_read = cdns_regmap_read,
440 };
441
442 static const struct regmap_config cdns_torrent_phy_pcs_cmn_cdb_config = {
443 .name = "torrent_phy_pcs_cmn_cdb",
444 .reg_stride = 1,
445 .fast_io = true,
446 .reg_write = cdns_regmap_write,
447 .reg_read = cdns_regmap_read,
448 };
449
450 static const struct regmap_config cdns_torrent_phy_pma_cmn_cdb_config = {
451 .name = "torrent_phy_pma_cmn_cdb",
452 .reg_stride = 1,
453 .fast_io = true,
454 .reg_write = cdns_regmap_write,
455 .reg_read = cdns_regmap_read,
456 };
457
458 static const struct regmap_config cdns_torrent_dptx_phy_config = {
459 .name = "torrent_dptx_phy",
460 .reg_stride = 1,
461 .fast_io = true,
462 .reg_write = cdns_regmap_dptx_write,
463 .reg_read = cdns_regmap_dptx_read,
464 };
465
466 /* PHY mmr access functions */
467
cdns_torrent_phy_write(struct regmap * regmap,u32 offset,u32 val)468 static void cdns_torrent_phy_write(struct regmap *regmap, u32 offset, u32 val)
469 {
470 regmap_write(regmap, offset, val);
471 }
472
cdns_torrent_phy_read(struct regmap * regmap,u32 offset)473 static u32 cdns_torrent_phy_read(struct regmap *regmap, u32 offset)
474 {
475 unsigned int val;
476
477 regmap_read(regmap, offset, &val);
478 return val;
479 }
480
481 /* DPTX mmr access functions */
482
cdns_torrent_dp_write(struct regmap * regmap,u32 offset,u32 val)483 static void cdns_torrent_dp_write(struct regmap *regmap, u32 offset, u32 val)
484 {
485 regmap_write(regmap, offset, val);
486 }
487
cdns_torrent_dp_read(struct regmap * regmap,u32 offset)488 static u32 cdns_torrent_dp_read(struct regmap *regmap, u32 offset)
489 {
490 u32 val;
491
492 regmap_read(regmap, offset, &val);
493 return val;
494 }
495
496 /*
497 * Structure used to store values of PHY registers for voltage-related
498 * coefficients, for particular voltage swing and pre-emphasis level. Values
499 * are shared across all physical lanes.
500 */
501 struct coefficients {
502 /* Value of DRV_DIAG_TX_DRV register to use */
503 u16 diag_tx_drv;
504 /* Value of TX_TXCC_MGNFS_MULT_000 register to use */
505 u16 mgnfs_mult;
506 /* Value of TX_TXCC_CPOST_MULT_00 register to use */
507 u16 cpost_mult;
508 };
509
510 /*
511 * Array consists of values of voltage-related registers for sd0801 PHY. A value
512 * of 0xFFFF is a placeholder for invalid combination, and will never be used.
513 */
514 static const struct coefficients vltg_coeff[4][4] = {
515 /* voltage swing 0, pre-emphasis 0->3 */
516 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x002A,
517 .cpost_mult = 0x0000},
518 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x001F,
519 .cpost_mult = 0x0014},
520 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0012,
521 .cpost_mult = 0x0020},
522 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000,
523 .cpost_mult = 0x002A}
524 },
525
526 /* voltage swing 1, pre-emphasis 0->3 */
527 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x001F,
528 .cpost_mult = 0x0000},
529 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0013,
530 .cpost_mult = 0x0012},
531 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000,
532 .cpost_mult = 0x001F},
533 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
534 .cpost_mult = 0xFFFF}
535 },
536
537 /* voltage swing 2, pre-emphasis 0->3 */
538 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0013,
539 .cpost_mult = 0x0000},
540 {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000,
541 .cpost_mult = 0x0013},
542 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
543 .cpost_mult = 0xFFFF},
544 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
545 .cpost_mult = 0xFFFF}
546 },
547
548 /* voltage swing 3, pre-emphasis 0->3 */
549 { {.diag_tx_drv = 0x0003, .mgnfs_mult = 0x0000,
550 .cpost_mult = 0x0000},
551 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
552 .cpost_mult = 0xFFFF},
553 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
554 .cpost_mult = 0xFFFF},
555 {.diag_tx_drv = 0xFFFF, .mgnfs_mult = 0xFFFF,
556 .cpost_mult = 0xFFFF}
557 }
558 };
559
560 /*
561 * Enable or disable PLL for selected lanes.
562 */
cdns_torrent_dp_set_pll_en(struct cdns_torrent_phy * cdns_phy,struct phy_configure_opts_dp * dp,bool enable)563 static int cdns_torrent_dp_set_pll_en(struct cdns_torrent_phy *cdns_phy,
564 struct phy_configure_opts_dp *dp,
565 bool enable)
566 {
567 u32 rd_val;
568 u32 ret;
569 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
570
571 /*
572 * Used to determine, which bits to check for or enable in
573 * PHY_PMA_XCVR_PLLCLK_EN register.
574 */
575 u32 pll_bits;
576 /* Used to enable or disable lanes. */
577 u32 pll_val;
578
579 /* Select values of registers and mask, depending on enabled lane
580 * count.
581 */
582 switch (dp->lanes) {
583 /* lane 0 */
584 case (1):
585 pll_bits = 0x00000001;
586 break;
587 /* lanes 0-1 */
588 case (2):
589 pll_bits = 0x00000003;
590 break;
591 /* lanes 0-3, all */
592 default:
593 pll_bits = 0x0000000F;
594 break;
595 }
596
597 if (enable)
598 pll_val = pll_bits;
599 else
600 pll_val = 0x00000000;
601
602 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, pll_val);
603
604 /* Wait for acknowledgment from PHY. */
605 ret = regmap_read_poll_timeout(regmap,
606 PHY_PMA_XCVR_PLLCLK_EN_ACK,
607 rd_val,
608 (rd_val & pll_bits) == pll_val,
609 0, POLL_TIMEOUT_US);
610 ndelay(100);
611 return ret;
612 }
613
614 /*
615 * Perform register operations related to setting link rate, once powerstate is
616 * set and PLL disable request was processed.
617 */
cdns_torrent_dp_configure_rate(struct cdns_torrent_phy * cdns_phy,struct phy_configure_opts_dp * dp)618 static int cdns_torrent_dp_configure_rate(struct cdns_torrent_phy *cdns_phy,
619 struct phy_configure_opts_dp *dp)
620 {
621 u32 ret;
622 u32 read_val;
623
624 /* Disable the cmn_pll0_en before re-programming the new data rate. */
625 regmap_field_write(cdns_phy->phy_pma_pll_raw_ctrl, 0x0);
626
627 /*
628 * Wait for PLL ready de-assertion.
629 * For PLL0 - PHY_PMA_CMN_CTRL2[2] == 1
630 */
631 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2,
632 read_val,
633 ((read_val >> 2) & 0x01) != 0,
634 0, POLL_TIMEOUT_US);
635 if (ret)
636 return ret;
637 ndelay(200);
638
639 /* DP Rate Change - VCO Output settings. */
640 if (cdns_phy->ref_clk_rate == REF_CLK_19_2MHz) {
641 /* PMA common configuration 19.2MHz */
642 cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(cdns_phy, dp->link_rate,
643 dp->ssc);
644 cdns_torrent_dp_pma_cmn_cfg_19_2mhz(cdns_phy);
645 } else if (cdns_phy->ref_clk_rate == REF_CLK_25MHz) {
646 /* PMA common configuration 25MHz */
647 cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(cdns_phy, dp->link_rate,
648 dp->ssc);
649 cdns_torrent_dp_pma_cmn_cfg_25mhz(cdns_phy);
650 }
651 cdns_torrent_dp_pma_cmn_rate(cdns_phy, dp->link_rate, dp->lanes);
652
653 /* Enable the cmn_pll0_en. */
654 regmap_field_write(cdns_phy->phy_pma_pll_raw_ctrl, 0x3);
655
656 /*
657 * Wait for PLL ready assertion.
658 * For PLL0 - PHY_PMA_CMN_CTRL2[0] == 1
659 */
660 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_2,
661 read_val,
662 (read_val & 0x01) != 0,
663 0, POLL_TIMEOUT_US);
664 return ret;
665 }
666
667 /*
668 * Verify, that parameters to configure PHY with are correct.
669 */
cdns_torrent_dp_verify_config(struct cdns_torrent_inst * inst,struct phy_configure_opts_dp * dp)670 static int cdns_torrent_dp_verify_config(struct cdns_torrent_inst *inst,
671 struct phy_configure_opts_dp *dp)
672 {
673 u8 i;
674
675 /* If changing link rate was required, verify it's supported. */
676 if (dp->set_rate) {
677 switch (dp->link_rate) {
678 case 1620:
679 case 2160:
680 case 2430:
681 case 2700:
682 case 3240:
683 case 4320:
684 case 5400:
685 case 8100:
686 /* valid bit rate */
687 break;
688 default:
689 return -EINVAL;
690 }
691 }
692
693 /* Verify lane count. */
694 switch (dp->lanes) {
695 case 1:
696 case 2:
697 case 4:
698 /* valid lane count. */
699 break;
700 default:
701 return -EINVAL;
702 }
703
704 /* Check against actual number of PHY's lanes. */
705 if (dp->lanes > inst->num_lanes)
706 return -EINVAL;
707
708 /*
709 * If changing voltages is required, check swing and pre-emphasis
710 * levels, per-lane.
711 */
712 if (dp->set_voltages) {
713 /* Lane count verified previously. */
714 for (i = 0; i < dp->lanes; i++) {
715 if (dp->voltage[i] > 3 || dp->pre[i] > 3)
716 return -EINVAL;
717
718 /* Sum of voltage swing and pre-emphasis levels cannot
719 * exceed 3.
720 */
721 if (dp->voltage[i] + dp->pre[i] > 3)
722 return -EINVAL;
723 }
724 }
725
726 return 0;
727 }
728
729 /* Set power state A0 and PLL clock enable to 0 on enabled lanes. */
cdns_torrent_dp_set_a0_pll(struct cdns_torrent_phy * cdns_phy,u32 num_lanes)730 static void cdns_torrent_dp_set_a0_pll(struct cdns_torrent_phy *cdns_phy,
731 u32 num_lanes)
732 {
733 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
734 u32 pwr_state = cdns_torrent_dp_read(regmap,
735 PHY_PMA_XCVR_POWER_STATE_REQ);
736 u32 pll_clk_en = cdns_torrent_dp_read(regmap,
737 PHY_PMA_XCVR_PLLCLK_EN);
738
739 /* Lane 0 is always enabled. */
740 pwr_state &= ~(PMA_XCVR_POWER_STATE_REQ_LN_MASK <<
741 PHY_POWER_STATE_LN_0);
742 pll_clk_en &= ~0x01U;
743
744 if (num_lanes > 1) {
745 /* lane 1 */
746 pwr_state &= ~(PMA_XCVR_POWER_STATE_REQ_LN_MASK <<
747 PHY_POWER_STATE_LN_1);
748 pll_clk_en &= ~(0x01U << 1);
749 }
750
751 if (num_lanes > 2) {
752 /* lanes 2 and 3 */
753 pwr_state &= ~(PMA_XCVR_POWER_STATE_REQ_LN_MASK <<
754 PHY_POWER_STATE_LN_2);
755 pwr_state &= ~(PMA_XCVR_POWER_STATE_REQ_LN_MASK <<
756 PHY_POWER_STATE_LN_3);
757 pll_clk_en &= ~(0x01U << 2);
758 pll_clk_en &= ~(0x01U << 3);
759 }
760
761 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, pwr_state);
762 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, pll_clk_en);
763 }
764
765 /* Configure lane count as required. */
cdns_torrent_dp_set_lanes(struct cdns_torrent_phy * cdns_phy,struct phy_configure_opts_dp * dp)766 static int cdns_torrent_dp_set_lanes(struct cdns_torrent_phy *cdns_phy,
767 struct phy_configure_opts_dp *dp)
768 {
769 u32 value;
770 u32 ret;
771 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
772 u8 lane_mask = (1 << dp->lanes) - 1;
773
774 value = cdns_torrent_dp_read(regmap, PHY_RESET);
775 /* clear pma_tx_elec_idle_ln_* bits. */
776 value &= ~PMA_TX_ELEC_IDLE_MASK;
777 /* Assert pma_tx_elec_idle_ln_* for disabled lanes. */
778 value |= ((~lane_mask) << PMA_TX_ELEC_IDLE_SHIFT) &
779 PMA_TX_ELEC_IDLE_MASK;
780 cdns_torrent_dp_write(regmap, PHY_RESET, value);
781
782 /* reset the link by asserting phy_l00_reset_n low */
783 cdns_torrent_dp_write(regmap, PHY_RESET,
784 value & (~PHY_L00_RESET_N_MASK));
785
786 /*
787 * Assert lane reset on unused lanes and lane 0 so they remain in reset
788 * and powered down when re-enabling the link
789 */
790 value = (value & 0x0000FFF0) | (0x0000000E & lane_mask);
791 cdns_torrent_dp_write(regmap, PHY_RESET, value);
792
793 cdns_torrent_dp_set_a0_pll(cdns_phy, dp->lanes);
794
795 /* release phy_l0*_reset_n based on used laneCount */
796 value = (value & 0x0000FFF0) | (0x0000000F & lane_mask);
797 cdns_torrent_dp_write(regmap, PHY_RESET, value);
798
799 /* Wait, until PHY gets ready after releasing PHY reset signal. */
800 ret = cdns_torrent_dp_wait_pma_cmn_ready(cdns_phy);
801 if (ret)
802 return ret;
803
804 ndelay(100);
805
806 /* release pma_xcvr_pllclk_en_ln_*, only for the master lane */
807 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, 0x0001);
808
809 ret = cdns_torrent_dp_run(cdns_phy, dp->lanes);
810
811 return ret;
812 }
813
814 /* Configure link rate as required. */
cdns_torrent_dp_set_rate(struct cdns_torrent_phy * cdns_phy,struct phy_configure_opts_dp * dp)815 static int cdns_torrent_dp_set_rate(struct cdns_torrent_phy *cdns_phy,
816 struct phy_configure_opts_dp *dp)
817 {
818 u32 ret;
819
820 ret = cdns_torrent_dp_set_power_state(cdns_phy, dp->lanes,
821 POWERSTATE_A3);
822 if (ret)
823 return ret;
824 ret = cdns_torrent_dp_set_pll_en(cdns_phy, dp, false);
825 if (ret)
826 return ret;
827 ndelay(200);
828
829 ret = cdns_torrent_dp_configure_rate(cdns_phy, dp);
830 if (ret)
831 return ret;
832 ndelay(200);
833
834 ret = cdns_torrent_dp_set_pll_en(cdns_phy, dp, true);
835 if (ret)
836 return ret;
837 ret = cdns_torrent_dp_set_power_state(cdns_phy, dp->lanes,
838 POWERSTATE_A2);
839 if (ret)
840 return ret;
841 ret = cdns_torrent_dp_set_power_state(cdns_phy, dp->lanes,
842 POWERSTATE_A0);
843 if (ret)
844 return ret;
845 ndelay(900);
846
847 return ret;
848 }
849
850 /* Configure voltage swing and pre-emphasis for all enabled lanes. */
cdns_torrent_dp_set_voltages(struct cdns_torrent_phy * cdns_phy,struct phy_configure_opts_dp * dp)851 static void cdns_torrent_dp_set_voltages(struct cdns_torrent_phy *cdns_phy,
852 struct phy_configure_opts_dp *dp)
853 {
854 u8 lane;
855 u16 val;
856
857 for (lane = 0; lane < dp->lanes; lane++) {
858 val = cdns_torrent_phy_read(cdns_phy->regmap_tx_lane_cdb[lane],
859 TX_DIAG_ACYA);
860 /*
861 * Write 1 to register bit TX_DIAG_ACYA[0] to freeze the
862 * current state of the analog TX driver.
863 */
864 val |= TX_DIAG_ACYA_HBDC_MASK;
865 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
866 TX_DIAG_ACYA, val);
867
868 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
869 TX_TXCC_CTRL, 0x08A4);
870 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].diag_tx_drv;
871 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
872 DRV_DIAG_TX_DRV, val);
873 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].mgnfs_mult;
874 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
875 TX_TXCC_MGNFS_MULT_000,
876 val);
877 val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].cpost_mult;
878 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
879 TX_TXCC_CPOST_MULT_00,
880 val);
881
882 val = cdns_torrent_phy_read(cdns_phy->regmap_tx_lane_cdb[lane],
883 TX_DIAG_ACYA);
884 /*
885 * Write 0 to register bit TX_DIAG_ACYA[0] to allow the state of
886 * analog TX driver to reflect the new programmed one.
887 */
888 val &= ~TX_DIAG_ACYA_HBDC_MASK;
889 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
890 TX_DIAG_ACYA, val);
891 }
892 };
893
cdns_torrent_dp_configure(struct phy * phy,union phy_configure_opts * opts)894 static int cdns_torrent_dp_configure(struct phy *phy,
895 union phy_configure_opts *opts)
896 {
897 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
898 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
899 int ret;
900
901 ret = cdns_torrent_dp_verify_config(inst, &opts->dp);
902 if (ret) {
903 dev_err(&phy->dev, "invalid params for phy configure\n");
904 return ret;
905 }
906
907 if (opts->dp.set_lanes) {
908 ret = cdns_torrent_dp_set_lanes(cdns_phy, &opts->dp);
909 if (ret) {
910 dev_err(&phy->dev, "cdns_torrent_dp_set_lanes failed\n");
911 return ret;
912 }
913 }
914
915 if (opts->dp.set_rate) {
916 ret = cdns_torrent_dp_set_rate(cdns_phy, &opts->dp);
917 if (ret) {
918 dev_err(&phy->dev, "cdns_torrent_dp_set_rate failed\n");
919 return ret;
920 }
921 }
922
923 if (opts->dp.set_voltages)
924 cdns_torrent_dp_set_voltages(cdns_phy, &opts->dp);
925
926 return ret;
927 }
928
cdns_torrent_dp_init(struct phy * phy)929 static int cdns_torrent_dp_init(struct phy *phy)
930 {
931 unsigned char lane_bits;
932 int ret;
933 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
934 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
935 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
936
937 switch (cdns_phy->ref_clk_rate) {
938 case REF_CLK_19_2MHz:
939 case REF_CLK_25MHz:
940 /* Valid Ref Clock Rate */
941 break;
942 default:
943 dev_err(cdns_phy->dev, "Unsupported Ref Clock Rate\n");
944 return -EINVAL;
945 }
946
947 cdns_torrent_dp_write(regmap, PHY_AUX_CTRL, 0x0003); /* enable AUX */
948
949 /* PHY PMA registers configuration function */
950 cdns_torrent_dp_pma_cfg(cdns_phy, inst);
951
952 /*
953 * Set lines power state to A0
954 * Set lines pll clk enable to 0
955 */
956 cdns_torrent_dp_set_a0_pll(cdns_phy, inst->num_lanes);
957
958 /*
959 * release phy_l0*_reset_n and pma_tx_elec_idle_ln_* based on
960 * used lanes
961 */
962 lane_bits = (1 << inst->num_lanes) - 1;
963 cdns_torrent_dp_write(regmap, PHY_RESET,
964 ((0xF & ~lane_bits) << 4) | (0xF & lane_bits));
965
966 /* release pma_xcvr_pllclk_en_ln_*, only for the master lane */
967 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_PLLCLK_EN, 0x0001);
968
969 /* PHY PMA registers configuration functions */
970 /* Initialize PHY with max supported link rate, without SSC. */
971 if (cdns_phy->ref_clk_rate == REF_CLK_19_2MHz)
972 cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(cdns_phy,
973 cdns_phy->max_bit_rate,
974 false);
975 else if (cdns_phy->ref_clk_rate == REF_CLK_25MHz)
976 cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(cdns_phy,
977 cdns_phy->max_bit_rate,
978 false);
979 cdns_torrent_dp_pma_cmn_rate(cdns_phy, cdns_phy->max_bit_rate,
980 inst->num_lanes);
981
982 /* take out of reset */
983 regmap_field_write(cdns_phy->phy_reset_ctrl, 0x1);
984
985 cdns_torrent_phy_on(phy);
986
987 ret = cdns_torrent_dp_wait_pma_cmn_ready(cdns_phy);
988 if (ret)
989 return ret;
990
991 ret = cdns_torrent_dp_run(cdns_phy, inst->num_lanes);
992
993 return ret;
994 }
995
996 static
cdns_torrent_dp_wait_pma_cmn_ready(struct cdns_torrent_phy * cdns_phy)997 int cdns_torrent_dp_wait_pma_cmn_ready(struct cdns_torrent_phy *cdns_phy)
998 {
999 unsigned int reg;
1000 int ret;
1001 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1002
1003 ret = regmap_read_poll_timeout(regmap, PHY_PMA_CMN_READY, reg,
1004 reg & 1, 0, POLL_TIMEOUT_US);
1005 if (ret == -ETIMEDOUT) {
1006 dev_err(cdns_phy->dev,
1007 "timeout waiting for PMA common ready\n");
1008 return -ETIMEDOUT;
1009 }
1010
1011 return 0;
1012 }
1013
cdns_torrent_dp_pma_cfg(struct cdns_torrent_phy * cdns_phy,struct cdns_torrent_inst * inst)1014 static void cdns_torrent_dp_pma_cfg(struct cdns_torrent_phy *cdns_phy,
1015 struct cdns_torrent_inst *inst)
1016 {
1017 unsigned int i;
1018
1019 if (cdns_phy->ref_clk_rate == REF_CLK_19_2MHz)
1020 /* PMA common configuration 19.2MHz */
1021 cdns_torrent_dp_pma_cmn_cfg_19_2mhz(cdns_phy);
1022 else if (cdns_phy->ref_clk_rate == REF_CLK_25MHz)
1023 /* PMA common configuration 25MHz */
1024 cdns_torrent_dp_pma_cmn_cfg_25mhz(cdns_phy);
1025
1026 /* PMA lane configuration to deal with multi-link operation */
1027 for (i = 0; i < inst->num_lanes; i++)
1028 cdns_torrent_dp_pma_lane_cfg(cdns_phy, i);
1029 }
1030
1031 static
cdns_torrent_dp_pma_cmn_cfg_19_2mhz(struct cdns_torrent_phy * cdns_phy)1032 void cdns_torrent_dp_pma_cmn_cfg_19_2mhz(struct cdns_torrent_phy *cdns_phy)
1033 {
1034 struct regmap *regmap = cdns_phy->regmap_common_cdb;
1035
1036 /* refclock registers - assumes 19.2 MHz refclock */
1037 cdns_torrent_phy_write(regmap, CMN_SSM_BIAS_TMR, 0x0014);
1038 cdns_torrent_phy_write(regmap, CMN_PLLSM0_PLLPRE_TMR, 0x0027);
1039 cdns_torrent_phy_write(regmap, CMN_PLLSM0_PLLLOCK_TMR, 0x00A1);
1040 cdns_torrent_phy_write(regmap, CMN_PLLSM1_PLLPRE_TMR, 0x0027);
1041 cdns_torrent_phy_write(regmap, CMN_PLLSM1_PLLLOCK_TMR, 0x00A1);
1042 cdns_torrent_phy_write(regmap, CMN_BGCAL_INIT_TMR, 0x0060);
1043 cdns_torrent_phy_write(regmap, CMN_BGCAL_ITER_TMR, 0x0060);
1044 cdns_torrent_phy_write(regmap, CMN_IBCAL_INIT_TMR, 0x0014);
1045 cdns_torrent_phy_write(regmap, CMN_TXPUCAL_INIT_TMR, 0x0018);
1046 cdns_torrent_phy_write(regmap, CMN_TXPUCAL_ITER_TMR, 0x0005);
1047 cdns_torrent_phy_write(regmap, CMN_TXPDCAL_INIT_TMR, 0x0018);
1048 cdns_torrent_phy_write(regmap, CMN_TXPDCAL_ITER_TMR, 0x0005);
1049 cdns_torrent_phy_write(regmap, CMN_RXCAL_INIT_TMR, 0x0240);
1050 cdns_torrent_phy_write(regmap, CMN_RXCAL_ITER_TMR, 0x0005);
1051 cdns_torrent_phy_write(regmap, CMN_SD_CAL_INIT_TMR, 0x0002);
1052 cdns_torrent_phy_write(regmap, CMN_SD_CAL_ITER_TMR, 0x0002);
1053 cdns_torrent_phy_write(regmap, CMN_SD_CAL_REFTIM_START, 0x000B);
1054 cdns_torrent_phy_write(regmap, CMN_SD_CAL_PLLCNT_START, 0x0137);
1055
1056 /* PLL registers */
1057 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_PADJ_M0, 0x0509);
1058 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_IADJ_M0, 0x0F00);
1059 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_FILT_PADJ_M0, 0x0F08);
1060 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_DIAG_M0, 0x0004);
1061 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0509);
1062 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_IADJ_M0, 0x0F00);
1063 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_FILT_PADJ_M0, 0x0F08);
1064 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_DIAG_M0, 0x0004);
1065 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_INIT_TMR, 0x00C0);
1066 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_ITER_TMR, 0x0004);
1067 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_INIT_TMR, 0x00C0);
1068 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_ITER_TMR, 0x0004);
1069 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_REFTIM_START, 0x0260);
1070 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_TCTRL, 0x0003);
1071 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_REFTIM_START, 0x0260);
1072 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_TCTRL, 0x0003);
1073 }
1074
1075 /*
1076 * Set registers responsible for enabling and configuring SSC, with second and
1077 * third register values provided by parameters.
1078 */
1079 static
cdns_torrent_dp_enable_ssc_19_2mhz(struct cdns_torrent_phy * cdns_phy,u32 ctrl2_val,u32 ctrl3_val)1080 void cdns_torrent_dp_enable_ssc_19_2mhz(struct cdns_torrent_phy *cdns_phy,
1081 u32 ctrl2_val, u32 ctrl3_val)
1082 {
1083 struct regmap *regmap = cdns_phy->regmap_common_cdb;
1084
1085 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0001);
1086 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl2_val);
1087 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl3_val);
1088 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0003);
1089 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0001);
1090 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl2_val);
1091 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl3_val);
1092 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0003);
1093 }
1094
1095 static
cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(struct cdns_torrent_phy * cdns_phy,u32 rate,bool ssc)1096 void cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(struct cdns_torrent_phy *cdns_phy,
1097 u32 rate, bool ssc)
1098 {
1099 struct regmap *regmap = cdns_phy->regmap_common_cdb;
1100
1101 /* Assumes 19.2 MHz refclock */
1102 switch (rate) {
1103 /* Setting VCO for 10.8GHz */
1104 case 2700:
1105 case 5400:
1106 cdns_torrent_phy_write(regmap,
1107 CMN_PLL0_INTDIV_M0, 0x0119);
1108 cdns_torrent_phy_write(regmap,
1109 CMN_PLL0_FRACDIVL_M0, 0x4000);
1110 cdns_torrent_phy_write(regmap,
1111 CMN_PLL0_FRACDIVH_M0, 0x0002);
1112 cdns_torrent_phy_write(regmap,
1113 CMN_PLL0_HIGH_THR_M0, 0x00BC);
1114 cdns_torrent_phy_write(regmap,
1115 CMN_PDIAG_PLL0_CTRL_M0, 0x0012);
1116 cdns_torrent_phy_write(regmap,
1117 CMN_PLL1_INTDIV_M0, 0x0119);
1118 cdns_torrent_phy_write(regmap,
1119 CMN_PLL1_FRACDIVL_M0, 0x4000);
1120 cdns_torrent_phy_write(regmap,
1121 CMN_PLL1_FRACDIVH_M0, 0x0002);
1122 cdns_torrent_phy_write(regmap,
1123 CMN_PLL1_HIGH_THR_M0, 0x00BC);
1124 cdns_torrent_phy_write(regmap,
1125 CMN_PDIAG_PLL1_CTRL_M0, 0x0012);
1126 if (ssc)
1127 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x033A,
1128 0x006A);
1129 break;
1130 /* Setting VCO for 9.72GHz */
1131 case 1620:
1132 case 2430:
1133 case 3240:
1134 cdns_torrent_phy_write(regmap,
1135 CMN_PLL0_INTDIV_M0, 0x01FA);
1136 cdns_torrent_phy_write(regmap,
1137 CMN_PLL0_FRACDIVL_M0, 0x4000);
1138 cdns_torrent_phy_write(regmap,
1139 CMN_PLL0_FRACDIVH_M0, 0x0002);
1140 cdns_torrent_phy_write(regmap,
1141 CMN_PLL0_HIGH_THR_M0, 0x0152);
1142 cdns_torrent_phy_write(regmap,
1143 CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
1144 cdns_torrent_phy_write(regmap,
1145 CMN_PLL1_INTDIV_M0, 0x01FA);
1146 cdns_torrent_phy_write(regmap,
1147 CMN_PLL1_FRACDIVL_M0, 0x4000);
1148 cdns_torrent_phy_write(regmap,
1149 CMN_PLL1_FRACDIVH_M0, 0x0002);
1150 cdns_torrent_phy_write(regmap,
1151 CMN_PLL1_HIGH_THR_M0, 0x0152);
1152 cdns_torrent_phy_write(regmap,
1153 CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
1154 if (ssc)
1155 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x05DD,
1156 0x0069);
1157 break;
1158 /* Setting VCO for 8.64GHz */
1159 case 2160:
1160 case 4320:
1161 cdns_torrent_phy_write(regmap,
1162 CMN_PLL0_INTDIV_M0, 0x01C2);
1163 cdns_torrent_phy_write(regmap,
1164 CMN_PLL0_FRACDIVL_M0, 0x0000);
1165 cdns_torrent_phy_write(regmap,
1166 CMN_PLL0_FRACDIVH_M0, 0x0002);
1167 cdns_torrent_phy_write(regmap,
1168 CMN_PLL0_HIGH_THR_M0, 0x012C);
1169 cdns_torrent_phy_write(regmap,
1170 CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
1171 cdns_torrent_phy_write(regmap,
1172 CMN_PLL1_INTDIV_M0, 0x01C2);
1173 cdns_torrent_phy_write(regmap,
1174 CMN_PLL1_FRACDIVL_M0, 0x0000);
1175 cdns_torrent_phy_write(regmap,
1176 CMN_PLL1_FRACDIVH_M0, 0x0002);
1177 cdns_torrent_phy_write(regmap,
1178 CMN_PLL1_HIGH_THR_M0, 0x012C);
1179 cdns_torrent_phy_write(regmap,
1180 CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
1181 if (ssc)
1182 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x0536,
1183 0x0069);
1184 break;
1185 /* Setting VCO for 8.1GHz */
1186 case 8100:
1187 cdns_torrent_phy_write(regmap,
1188 CMN_PLL0_INTDIV_M0, 0x01A5);
1189 cdns_torrent_phy_write(regmap,
1190 CMN_PLL0_FRACDIVL_M0, 0xE000);
1191 cdns_torrent_phy_write(regmap,
1192 CMN_PLL0_FRACDIVH_M0, 0x0002);
1193 cdns_torrent_phy_write(regmap,
1194 CMN_PLL0_HIGH_THR_M0, 0x011A);
1195 cdns_torrent_phy_write(regmap,
1196 CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
1197 cdns_torrent_phy_write(regmap,
1198 CMN_PLL1_INTDIV_M0, 0x01A5);
1199 cdns_torrent_phy_write(regmap,
1200 CMN_PLL1_FRACDIVL_M0, 0xE000);
1201 cdns_torrent_phy_write(regmap,
1202 CMN_PLL1_FRACDIVH_M0, 0x0002);
1203 cdns_torrent_phy_write(regmap,
1204 CMN_PLL1_HIGH_THR_M0, 0x011A);
1205 cdns_torrent_phy_write(regmap,
1206 CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
1207 if (ssc)
1208 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy, 0x04D7,
1209 0x006A);
1210 break;
1211 }
1212
1213 if (ssc) {
1214 cdns_torrent_phy_write(regmap,
1215 CMN_PLL0_VCOCAL_PLLCNT_START, 0x025E);
1216 cdns_torrent_phy_write(regmap,
1217 CMN_PLL0_LOCK_PLLCNT_THR, 0x0005);
1218 cdns_torrent_phy_write(regmap,
1219 CMN_PLL1_VCOCAL_PLLCNT_START, 0x025E);
1220 cdns_torrent_phy_write(regmap,
1221 CMN_PLL1_LOCK_PLLCNT_THR, 0x0005);
1222 } else {
1223 cdns_torrent_phy_write(regmap,
1224 CMN_PLL0_VCOCAL_PLLCNT_START, 0x0260);
1225 cdns_torrent_phy_write(regmap,
1226 CMN_PLL1_VCOCAL_PLLCNT_START, 0x0260);
1227 /* Set reset register values to disable SSC */
1228 cdns_torrent_phy_write(regmap,
1229 CMN_PLL0_SS_CTRL1_M0, 0x0002);
1230 cdns_torrent_phy_write(regmap,
1231 CMN_PLL0_SS_CTRL2_M0, 0x0000);
1232 cdns_torrent_phy_write(regmap,
1233 CMN_PLL0_SS_CTRL3_M0, 0x0000);
1234 cdns_torrent_phy_write(regmap,
1235 CMN_PLL0_SS_CTRL4_M0, 0x0000);
1236 cdns_torrent_phy_write(regmap,
1237 CMN_PLL0_LOCK_PLLCNT_THR, 0x0003);
1238 cdns_torrent_phy_write(regmap,
1239 CMN_PLL1_SS_CTRL1_M0, 0x0002);
1240 cdns_torrent_phy_write(regmap,
1241 CMN_PLL1_SS_CTRL2_M0, 0x0000);
1242 cdns_torrent_phy_write(regmap,
1243 CMN_PLL1_SS_CTRL3_M0, 0x0000);
1244 cdns_torrent_phy_write(regmap,
1245 CMN_PLL1_SS_CTRL4_M0, 0x0000);
1246 cdns_torrent_phy_write(regmap,
1247 CMN_PLL1_LOCK_PLLCNT_THR, 0x0003);
1248 }
1249
1250 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_REFCNT_START, 0x0099);
1251 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_START, 0x0099);
1252 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_REFCNT_START, 0x0099);
1253 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_START, 0x0099);
1254 }
1255
1256 static
cdns_torrent_dp_pma_cmn_cfg_25mhz(struct cdns_torrent_phy * cdns_phy)1257 void cdns_torrent_dp_pma_cmn_cfg_25mhz(struct cdns_torrent_phy *cdns_phy)
1258 {
1259 struct regmap *regmap = cdns_phy->regmap_common_cdb;
1260
1261 /* refclock registers - assumes 25 MHz refclock */
1262 cdns_torrent_phy_write(regmap, CMN_SSM_BIAS_TMR, 0x0019);
1263 cdns_torrent_phy_write(regmap, CMN_PLLSM0_PLLPRE_TMR, 0x0032);
1264 cdns_torrent_phy_write(regmap, CMN_PLLSM0_PLLLOCK_TMR, 0x00D1);
1265 cdns_torrent_phy_write(regmap, CMN_PLLSM1_PLLPRE_TMR, 0x0032);
1266 cdns_torrent_phy_write(regmap, CMN_PLLSM1_PLLLOCK_TMR, 0x00D1);
1267 cdns_torrent_phy_write(regmap, CMN_BGCAL_INIT_TMR, 0x007D);
1268 cdns_torrent_phy_write(regmap, CMN_BGCAL_ITER_TMR, 0x007D);
1269 cdns_torrent_phy_write(regmap, CMN_IBCAL_INIT_TMR, 0x0019);
1270 cdns_torrent_phy_write(regmap, CMN_TXPUCAL_INIT_TMR, 0x001E);
1271 cdns_torrent_phy_write(regmap, CMN_TXPUCAL_ITER_TMR, 0x0006);
1272 cdns_torrent_phy_write(regmap, CMN_TXPDCAL_INIT_TMR, 0x001E);
1273 cdns_torrent_phy_write(regmap, CMN_TXPDCAL_ITER_TMR, 0x0006);
1274 cdns_torrent_phy_write(regmap, CMN_RXCAL_INIT_TMR, 0x02EE);
1275 cdns_torrent_phy_write(regmap, CMN_RXCAL_ITER_TMR, 0x0006);
1276 cdns_torrent_phy_write(regmap, CMN_SD_CAL_INIT_TMR, 0x0002);
1277 cdns_torrent_phy_write(regmap, CMN_SD_CAL_ITER_TMR, 0x0002);
1278 cdns_torrent_phy_write(regmap, CMN_SD_CAL_REFTIM_START, 0x000E);
1279 cdns_torrent_phy_write(regmap, CMN_SD_CAL_PLLCNT_START, 0x012B);
1280
1281 /* PLL registers */
1282 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_PADJ_M0, 0x0509);
1283 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CP_IADJ_M0, 0x0F00);
1284 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_FILT_PADJ_M0, 0x0F08);
1285 cdns_torrent_phy_write(regmap, CMN_PLL0_DSM_DIAG_M0, 0x0004);
1286 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_PADJ_M0, 0x0509);
1287 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CP_IADJ_M0, 0x0F00);
1288 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_FILT_PADJ_M0, 0x0F08);
1289 cdns_torrent_phy_write(regmap, CMN_PLL1_DSM_DIAG_M0, 0x0004);
1290 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_INIT_TMR, 0x00FA);
1291 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_ITER_TMR, 0x0004);
1292 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_INIT_TMR, 0x00FA);
1293 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_ITER_TMR, 0x0004);
1294 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_REFTIM_START, 0x0317);
1295 cdns_torrent_phy_write(regmap, CMN_PLL0_VCOCAL_TCTRL, 0x0003);
1296 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_REFTIM_START, 0x0317);
1297 cdns_torrent_phy_write(regmap, CMN_PLL1_VCOCAL_TCTRL, 0x0003);
1298 }
1299
1300 /*
1301 * Set registers responsible for enabling and configuring SSC, with second
1302 * register value provided by a parameter.
1303 */
cdns_torrent_dp_enable_ssc_25mhz(struct cdns_torrent_phy * cdns_phy,u32 ctrl2_val)1304 static void cdns_torrent_dp_enable_ssc_25mhz(struct cdns_torrent_phy *cdns_phy,
1305 u32 ctrl2_val)
1306 {
1307 struct regmap *regmap = cdns_phy->regmap_common_cdb;
1308
1309 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0001);
1310 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, ctrl2_val);
1311 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x007F);
1312 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0003);
1313 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0001);
1314 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, ctrl2_val);
1315 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x007F);
1316 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0003);
1317 }
1318
1319 static
cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(struct cdns_torrent_phy * cdns_phy,u32 rate,bool ssc)1320 void cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(struct cdns_torrent_phy *cdns_phy,
1321 u32 rate, bool ssc)
1322 {
1323 struct regmap *regmap = cdns_phy->regmap_common_cdb;
1324
1325 /* Assumes 25 MHz refclock */
1326 switch (rate) {
1327 /* Setting VCO for 10.8GHz */
1328 case 2700:
1329 case 5400:
1330 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x01B0);
1331 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x0000);
1332 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
1333 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0120);
1334 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x01B0);
1335 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x0000);
1336 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
1337 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0120);
1338 if (ssc)
1339 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x0423);
1340 break;
1341 /* Setting VCO for 9.72GHz */
1342 case 1620:
1343 case 2430:
1344 case 3240:
1345 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0184);
1346 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0xCCCD);
1347 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
1348 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x0104);
1349 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0184);
1350 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0xCCCD);
1351 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
1352 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x0104);
1353 if (ssc)
1354 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x03B9);
1355 break;
1356 /* Setting VCO for 8.64GHz */
1357 case 2160:
1358 case 4320:
1359 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0159);
1360 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x999A);
1361 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
1362 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x00E7);
1363 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0159);
1364 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x999A);
1365 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
1366 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x00E7);
1367 if (ssc)
1368 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x034F);
1369 break;
1370 /* Setting VCO for 8.1GHz */
1371 case 8100:
1372 cdns_torrent_phy_write(regmap, CMN_PLL0_INTDIV_M0, 0x0144);
1373 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVL_M0, 0x0000);
1374 cdns_torrent_phy_write(regmap, CMN_PLL0_FRACDIVH_M0, 0x0002);
1375 cdns_torrent_phy_write(regmap, CMN_PLL0_HIGH_THR_M0, 0x00D8);
1376 cdns_torrent_phy_write(regmap, CMN_PLL1_INTDIV_M0, 0x0144);
1377 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVL_M0, 0x0000);
1378 cdns_torrent_phy_write(regmap, CMN_PLL1_FRACDIVH_M0, 0x0002);
1379 cdns_torrent_phy_write(regmap, CMN_PLL1_HIGH_THR_M0, 0x00D8);
1380 if (ssc)
1381 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy, 0x031A);
1382 break;
1383 }
1384
1385 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL0_CTRL_M0, 0x0002);
1386 cdns_torrent_phy_write(regmap, CMN_PDIAG_PLL1_CTRL_M0, 0x0002);
1387
1388 if (ssc) {
1389 cdns_torrent_phy_write(regmap,
1390 CMN_PLL0_VCOCAL_PLLCNT_START, 0x0315);
1391 cdns_torrent_phy_write(regmap,
1392 CMN_PLL0_LOCK_PLLCNT_THR, 0x0005);
1393 cdns_torrent_phy_write(regmap,
1394 CMN_PLL1_VCOCAL_PLLCNT_START, 0x0315);
1395 cdns_torrent_phy_write(regmap,
1396 CMN_PLL1_LOCK_PLLCNT_THR, 0x0005);
1397 } else {
1398 cdns_torrent_phy_write(regmap,
1399 CMN_PLL0_VCOCAL_PLLCNT_START, 0x0317);
1400 cdns_torrent_phy_write(regmap,
1401 CMN_PLL1_VCOCAL_PLLCNT_START, 0x0317);
1402 /* Set reset register values to disable SSC */
1403 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL1_M0, 0x0002);
1404 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL2_M0, 0x0000);
1405 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL3_M0, 0x0000);
1406 cdns_torrent_phy_write(regmap, CMN_PLL0_SS_CTRL4_M0, 0x0000);
1407 cdns_torrent_phy_write(regmap,
1408 CMN_PLL0_LOCK_PLLCNT_THR, 0x0003);
1409 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL1_M0, 0x0002);
1410 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL2_M0, 0x0000);
1411 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL3_M0, 0x0000);
1412 cdns_torrent_phy_write(regmap, CMN_PLL1_SS_CTRL4_M0, 0x0000);
1413 cdns_torrent_phy_write(regmap,
1414 CMN_PLL1_LOCK_PLLCNT_THR, 0x0003);
1415 }
1416
1417 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_REFCNT_START, 0x00C7);
1418 cdns_torrent_phy_write(regmap, CMN_PLL0_LOCK_PLLCNT_START, 0x00C7);
1419 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_REFCNT_START, 0x00C7);
1420 cdns_torrent_phy_write(regmap, CMN_PLL1_LOCK_PLLCNT_START, 0x00C7);
1421 }
1422
cdns_torrent_dp_pma_cmn_rate(struct cdns_torrent_phy * cdns_phy,u32 rate,u32 num_lanes)1423 static void cdns_torrent_dp_pma_cmn_rate(struct cdns_torrent_phy *cdns_phy,
1424 u32 rate, u32 num_lanes)
1425 {
1426 unsigned int clk_sel_val = 0;
1427 unsigned int hsclk_div_val = 0;
1428 unsigned int i;
1429
1430 /* 16'h0000 for single DP link configuration */
1431 regmap_field_write(cdns_phy->phy_pll_cfg, 0x0);
1432
1433 switch (rate) {
1434 case 1620:
1435 clk_sel_val = 0x0f01;
1436 hsclk_div_val = 2;
1437 break;
1438 case 2160:
1439 case 2430:
1440 case 2700:
1441 clk_sel_val = 0x0701;
1442 hsclk_div_val = 1;
1443 break;
1444 case 3240:
1445 clk_sel_val = 0x0b00;
1446 hsclk_div_val = 2;
1447 break;
1448 case 4320:
1449 case 5400:
1450 clk_sel_val = 0x0301;
1451 hsclk_div_val = 0;
1452 break;
1453 case 8100:
1454 clk_sel_val = 0x0200;
1455 hsclk_div_val = 0;
1456 break;
1457 }
1458
1459 cdns_torrent_phy_write(cdns_phy->regmap_common_cdb,
1460 CMN_PDIAG_PLL0_CLK_SEL_M0, clk_sel_val);
1461 cdns_torrent_phy_write(cdns_phy->regmap_common_cdb,
1462 CMN_PDIAG_PLL1_CLK_SEL_M0, clk_sel_val);
1463
1464 /* PMA lane configuration to deal with multi-link operation */
1465 for (i = 0; i < num_lanes; i++)
1466 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[i],
1467 XCVR_DIAG_HSCLK_DIV, hsclk_div_val);
1468 }
1469
cdns_torrent_dp_pma_lane_cfg(struct cdns_torrent_phy * cdns_phy,unsigned int lane)1470 static void cdns_torrent_dp_pma_lane_cfg(struct cdns_torrent_phy *cdns_phy,
1471 unsigned int lane)
1472 {
1473 /* Per lane, refclock-dependent receiver detection setting */
1474 if (cdns_phy->ref_clk_rate == REF_CLK_19_2MHz)
1475 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
1476 TX_RCVDET_ST_TMR, 0x0780);
1477 else if (cdns_phy->ref_clk_rate == REF_CLK_25MHz)
1478 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
1479 TX_RCVDET_ST_TMR, 0x09C4);
1480
1481 /* Writing Tx/Rx Power State Controllers registers */
1482 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
1483 TX_PSC_A0, 0x00FB);
1484 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
1485 TX_PSC_A2, 0x04AA);
1486 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
1487 TX_PSC_A3, 0x04AA);
1488 cdns_torrent_phy_write(cdns_phy->regmap_rx_lane_cdb[lane],
1489 RX_PSC_A0, 0x0000);
1490 cdns_torrent_phy_write(cdns_phy->regmap_rx_lane_cdb[lane],
1491 RX_PSC_A2, 0x0000);
1492 cdns_torrent_phy_write(cdns_phy->regmap_rx_lane_cdb[lane],
1493 RX_PSC_A3, 0x0000);
1494
1495 cdns_torrent_phy_write(cdns_phy->regmap_rx_lane_cdb[lane],
1496 RX_PSC_CAL, 0x0000);
1497
1498 cdns_torrent_phy_write(cdns_phy->regmap_rx_lane_cdb[lane],
1499 RX_REE_GCSM1_CTRL, 0x0000);
1500 cdns_torrent_phy_write(cdns_phy->regmap_rx_lane_cdb[lane],
1501 RX_REE_GCSM2_CTRL, 0x0000);
1502 cdns_torrent_phy_write(cdns_phy->regmap_rx_lane_cdb[lane],
1503 RX_REE_PERGCSM_CTRL, 0x0000);
1504
1505 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
1506 XCVR_DIAG_BIDI_CTRL, 0x000F);
1507 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
1508 XCVR_DIAG_PLLDRC_CTRL, 0x0001);
1509 cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[lane],
1510 XCVR_DIAG_HSCLK_SEL, 0x0000);
1511 }
1512
cdns_torrent_dp_set_power_state(struct cdns_torrent_phy * cdns_phy,u32 num_lanes,enum phy_powerstate powerstate)1513 static int cdns_torrent_dp_set_power_state(struct cdns_torrent_phy *cdns_phy,
1514 u32 num_lanes,
1515 enum phy_powerstate powerstate)
1516 {
1517 /* Register value for power state for a single byte. */
1518 u32 value_part;
1519 u32 value;
1520 u32 mask;
1521 u32 read_val;
1522 u32 ret;
1523 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1524
1525 switch (powerstate) {
1526 case (POWERSTATE_A0):
1527 value_part = 0x01U;
1528 break;
1529 case (POWERSTATE_A2):
1530 value_part = 0x04U;
1531 break;
1532 default:
1533 /* Powerstate A3 */
1534 value_part = 0x08U;
1535 break;
1536 }
1537
1538 /* Select values of registers and mask, depending on enabled
1539 * lane count.
1540 */
1541 switch (num_lanes) {
1542 /* lane 0 */
1543 case (1):
1544 value = value_part;
1545 mask = 0x0000003FU;
1546 break;
1547 /* lanes 0-1 */
1548 case (2):
1549 value = (value_part
1550 | (value_part << 8));
1551 mask = 0x00003F3FU;
1552 break;
1553 /* lanes 0-3, all */
1554 default:
1555 value = (value_part
1556 | (value_part << 8)
1557 | (value_part << 16)
1558 | (value_part << 24));
1559 mask = 0x3F3F3F3FU;
1560 break;
1561 }
1562
1563 /* Set power state A<n>. */
1564 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, value);
1565 /* Wait, until PHY acknowledges power state completion. */
1566 ret = regmap_read_poll_timeout(regmap, PHY_PMA_XCVR_POWER_STATE_ACK,
1567 read_val, (read_val & mask) == value, 0,
1568 POLL_TIMEOUT_US);
1569 cdns_torrent_dp_write(regmap, PHY_PMA_XCVR_POWER_STATE_REQ, 0x00000000);
1570 ndelay(100);
1571
1572 return ret;
1573 }
1574
cdns_torrent_dp_run(struct cdns_torrent_phy * cdns_phy,u32 num_lanes)1575 static int cdns_torrent_dp_run(struct cdns_torrent_phy *cdns_phy, u32 num_lanes)
1576 {
1577 unsigned int read_val;
1578 int ret;
1579 struct regmap *regmap = cdns_phy->regmap_dptx_phy_reg;
1580
1581 /*
1582 * waiting for ACK of pma_xcvr_pllclk_en_ln_*, only for the
1583 * master lane
1584 */
1585 ret = regmap_read_poll_timeout(regmap, PHY_PMA_XCVR_PLLCLK_EN_ACK,
1586 read_val, read_val & 1,
1587 0, POLL_TIMEOUT_US);
1588 if (ret == -ETIMEDOUT) {
1589 dev_err(cdns_phy->dev,
1590 "timeout waiting for link PLL clock enable ack\n");
1591 return ret;
1592 }
1593
1594 ndelay(100);
1595
1596 ret = cdns_torrent_dp_set_power_state(cdns_phy, num_lanes,
1597 POWERSTATE_A2);
1598 if (ret)
1599 return ret;
1600
1601 ret = cdns_torrent_dp_set_power_state(cdns_phy, num_lanes,
1602 POWERSTATE_A0);
1603
1604 return ret;
1605 }
1606
cdns_torrent_phy_on(struct phy * phy)1607 static int cdns_torrent_phy_on(struct phy *phy)
1608 {
1609 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
1610 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
1611 u32 read_val;
1612 int ret;
1613
1614 if (cdns_phy->nsubnodes == 1) {
1615 /* Take the PHY lane group out of reset */
1616 reset_control_deassert(inst->lnk_rst);
1617
1618 /* Take the PHY out of reset */
1619 ret = reset_control_deassert(cdns_phy->phy_rst);
1620 if (ret)
1621 return ret;
1622 }
1623
1624 /*
1625 * Wait for cmn_ready assertion
1626 * PHY_PMA_CMN_CTRL1[0] == 1
1627 */
1628 ret = regmap_field_read_poll_timeout(cdns_phy->phy_pma_cmn_ctrl_1,
1629 read_val, read_val, 1000,
1630 PLL_LOCK_TIMEOUT);
1631 if (ret) {
1632 dev_err(cdns_phy->dev, "Timeout waiting for CMN ready\n");
1633 return ret;
1634 }
1635
1636 mdelay(10);
1637
1638 return 0;
1639 }
1640
cdns_torrent_phy_off(struct phy * phy)1641 static int cdns_torrent_phy_off(struct phy *phy)
1642 {
1643 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
1644 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
1645 int ret;
1646
1647 if (cdns_phy->nsubnodes != 1)
1648 return 0;
1649
1650 ret = reset_control_assert(cdns_phy->phy_rst);
1651 if (ret)
1652 return ret;
1653
1654 return reset_control_assert(inst->lnk_rst);
1655 }
1656
cdns_regmap_init(struct device * dev,void __iomem * base,u32 block_offset,u8 reg_offset_shift,const struct regmap_config * config)1657 static struct regmap *cdns_regmap_init(struct device *dev, void __iomem *base,
1658 u32 block_offset,
1659 u8 reg_offset_shift,
1660 const struct regmap_config *config)
1661 {
1662 struct cdns_regmap_cdb_context *ctx;
1663
1664 ctx = devm_kzalloc(dev, sizeof(*ctx), GFP_KERNEL);
1665 if (!ctx)
1666 return ERR_PTR(-ENOMEM);
1667
1668 ctx->dev = dev;
1669 ctx->base = base + block_offset;
1670 ctx->reg_offset_shift = reg_offset_shift;
1671
1672 return devm_regmap_init(dev, NULL, ctx, config);
1673 }
1674
cdns_torrent_dp_regfield_init(struct cdns_torrent_phy * cdns_phy)1675 static int cdns_torrent_dp_regfield_init(struct cdns_torrent_phy *cdns_phy)
1676 {
1677 struct device *dev = cdns_phy->dev;
1678 struct regmap_field *field;
1679 struct regmap *regmap;
1680
1681 regmap = cdns_phy->regmap_dptx_phy_reg;
1682 field = devm_regmap_field_alloc(dev, regmap, phy_reset_ctrl);
1683 if (IS_ERR(field)) {
1684 dev_err(dev, "PHY_RESET reg field init failed\n");
1685 return PTR_ERR(field);
1686 }
1687 cdns_phy->phy_reset_ctrl = field;
1688
1689 return 0;
1690 }
1691
cdns_torrent_regfield_init(struct cdns_torrent_phy * cdns_phy)1692 static int cdns_torrent_regfield_init(struct cdns_torrent_phy *cdns_phy)
1693 {
1694 struct device *dev = cdns_phy->dev;
1695 struct regmap_field *field;
1696 struct regmap *regmap;
1697
1698 regmap = cdns_phy->regmap_phy_pcs_common_cdb;
1699 field = devm_regmap_field_alloc(dev, regmap, phy_pll_cfg);
1700 if (IS_ERR(field)) {
1701 dev_err(dev, "PHY_PLL_CFG reg field init failed\n");
1702 return PTR_ERR(field);
1703 }
1704 cdns_phy->phy_pll_cfg = field;
1705
1706 regmap = cdns_phy->regmap_phy_pma_common_cdb;
1707 field = devm_regmap_field_alloc(dev, regmap, phy_pma_cmn_ctrl_1);
1708 if (IS_ERR(field)) {
1709 dev_err(dev, "PHY_PMA_CMN_CTRL1 reg field init failed\n");
1710 return PTR_ERR(field);
1711 }
1712 cdns_phy->phy_pma_cmn_ctrl_1 = field;
1713
1714 regmap = cdns_phy->regmap_phy_pma_common_cdb;
1715 field = devm_regmap_field_alloc(dev, regmap, phy_pma_cmn_ctrl_2);
1716 if (IS_ERR(field)) {
1717 dev_err(dev, "PHY_PMA_CMN_CTRL2 reg field init failed\n");
1718 return PTR_ERR(field);
1719 }
1720 cdns_phy->phy_pma_cmn_ctrl_2 = field;
1721
1722 regmap = cdns_phy->regmap_phy_pma_common_cdb;
1723 field = devm_regmap_field_alloc(dev, regmap, phy_pma_pll_raw_ctrl);
1724 if (IS_ERR(field)) {
1725 dev_err(dev, "PHY_PMA_PLL_RAW_CTRL reg field init failed\n");
1726 return PTR_ERR(field);
1727 }
1728 cdns_phy->phy_pma_pll_raw_ctrl = field;
1729
1730 return 0;
1731 }
1732
cdns_torrent_dp_regmap_init(struct cdns_torrent_phy * cdns_phy)1733 static int cdns_torrent_dp_regmap_init(struct cdns_torrent_phy *cdns_phy)
1734 {
1735 void __iomem *base = cdns_phy->base;
1736 struct device *dev = cdns_phy->dev;
1737 struct regmap *regmap;
1738 u8 reg_offset_shift;
1739 u32 block_offset;
1740
1741 reg_offset_shift = cdns_phy->init_data->reg_offset_shift;
1742
1743 block_offset = TORRENT_DPTX_PHY_OFFSET;
1744 regmap = cdns_regmap_init(dev, base, block_offset,
1745 reg_offset_shift,
1746 &cdns_torrent_dptx_phy_config);
1747 if (IS_ERR(regmap)) {
1748 dev_err(dev, "Failed to init DPTX PHY regmap\n");
1749 return PTR_ERR(regmap);
1750 }
1751 cdns_phy->regmap_dptx_phy_reg = regmap;
1752
1753 return 0;
1754 }
1755
cdns_torrent_regmap_init(struct cdns_torrent_phy * cdns_phy)1756 static int cdns_torrent_regmap_init(struct cdns_torrent_phy *cdns_phy)
1757 {
1758 void __iomem *sd_base = cdns_phy->sd_base;
1759 u8 block_offset_shift, reg_offset_shift;
1760 struct device *dev = cdns_phy->dev;
1761 struct regmap *regmap;
1762 u32 block_offset;
1763 int i;
1764
1765 block_offset_shift = cdns_phy->init_data->block_offset_shift;
1766 reg_offset_shift = cdns_phy->init_data->reg_offset_shift;
1767
1768 for (i = 0; i < MAX_NUM_LANES; i++) {
1769 block_offset = TORRENT_TX_LANE_CDB_OFFSET(i, block_offset_shift,
1770 reg_offset_shift);
1771 regmap = cdns_regmap_init(dev, sd_base, block_offset,
1772 reg_offset_shift,
1773 &cdns_torrent_tx_lane_cdb_config[i]);
1774 if (IS_ERR(regmap)) {
1775 dev_err(dev, "Failed to init tx lane CDB regmap\n");
1776 return PTR_ERR(regmap);
1777 }
1778 cdns_phy->regmap_tx_lane_cdb[i] = regmap;
1779
1780 block_offset = TORRENT_RX_LANE_CDB_OFFSET(i, block_offset_shift,
1781 reg_offset_shift);
1782 regmap = cdns_regmap_init(dev, sd_base, block_offset,
1783 reg_offset_shift,
1784 &cdns_torrent_rx_lane_cdb_config[i]);
1785 if (IS_ERR(regmap)) {
1786 dev_err(dev, "Failed to init rx lane CDB regmap\n");
1787 return PTR_ERR(regmap);
1788 }
1789 cdns_phy->regmap_rx_lane_cdb[i] = regmap;
1790 }
1791
1792 block_offset = TORRENT_COMMON_CDB_OFFSET;
1793 regmap = cdns_regmap_init(dev, sd_base, block_offset,
1794 reg_offset_shift,
1795 &cdns_torrent_common_cdb_config);
1796 if (IS_ERR(regmap)) {
1797 dev_err(dev, "Failed to init common CDB regmap\n");
1798 return PTR_ERR(regmap);
1799 }
1800 cdns_phy->regmap_common_cdb = regmap;
1801
1802 block_offset = TORRENT_PHY_PCS_COMMON_OFFSET(block_offset_shift);
1803 regmap = cdns_regmap_init(dev, sd_base, block_offset,
1804 reg_offset_shift,
1805 &cdns_torrent_phy_pcs_cmn_cdb_config);
1806 if (IS_ERR(regmap)) {
1807 dev_err(dev, "Failed to init PHY PCS common CDB regmap\n");
1808 return PTR_ERR(regmap);
1809 }
1810 cdns_phy->regmap_phy_pcs_common_cdb = regmap;
1811
1812 block_offset = TORRENT_PHY_PMA_COMMON_OFFSET(block_offset_shift);
1813 regmap = cdns_regmap_init(dev, sd_base, block_offset,
1814 reg_offset_shift,
1815 &cdns_torrent_phy_pma_cmn_cdb_config);
1816 if (IS_ERR(regmap)) {
1817 dev_err(dev, "Failed to init PHY PMA common CDB regmap\n");
1818 return PTR_ERR(regmap);
1819 }
1820 cdns_phy->regmap_phy_pma_common_cdb = regmap;
1821
1822 return 0;
1823 }
1824
cdns_torrent_phy_init(struct phy * phy)1825 static int cdns_torrent_phy_init(struct phy *phy)
1826 {
1827 struct cdns_torrent_phy *cdns_phy = dev_get_drvdata(phy->dev.parent);
1828 const struct cdns_torrent_data *init_data = cdns_phy->init_data;
1829 struct cdns_torrent_vals *cmn_vals, *tx_ln_vals, *rx_ln_vals;
1830 struct cdns_torrent_vals *link_cmn_vals, *xcvr_diag_vals;
1831 struct cdns_torrent_inst *inst = phy_get_drvdata(phy);
1832 enum cdns_torrent_phy_type phy_type = inst->phy_type;
1833 enum cdns_torrent_ssc_mode ssc = inst->ssc_mode;
1834 struct cdns_torrent_vals *pcs_cmn_vals;
1835 struct cdns_reg_pairs *reg_pairs;
1836 struct regmap *regmap;
1837 u32 num_regs;
1838 int i, j;
1839
1840 if (cdns_phy->nsubnodes > 1)
1841 return 0;
1842
1843 if (phy_type == TYPE_DP)
1844 return cdns_torrent_dp_init(phy);
1845
1846 /**
1847 * Spread spectrum generation is not required or supported
1848 * for SGMII/QSGMII
1849 */
1850 if (phy_type == TYPE_SGMII || phy_type == TYPE_QSGMII)
1851 ssc = NO_SSC;
1852
1853 /* PHY configuration specific registers for single link */
1854 link_cmn_vals = init_data->link_cmn_vals[phy_type][TYPE_NONE][ssc];
1855 if (link_cmn_vals) {
1856 reg_pairs = link_cmn_vals->reg_pairs;
1857 num_regs = link_cmn_vals->num_regs;
1858 regmap = cdns_phy->regmap_common_cdb;
1859
1860 /**
1861 * First array value in link_cmn_vals must be of
1862 * PHY_PLL_CFG register
1863 */
1864 regmap_field_write(cdns_phy->phy_pll_cfg, reg_pairs[0].val);
1865
1866 for (i = 1; i < num_regs; i++)
1867 regmap_write(regmap, reg_pairs[i].off,
1868 reg_pairs[i].val);
1869 }
1870
1871 xcvr_diag_vals = init_data->xcvr_diag_vals[phy_type][TYPE_NONE][ssc];
1872 if (xcvr_diag_vals) {
1873 reg_pairs = xcvr_diag_vals->reg_pairs;
1874 num_regs = xcvr_diag_vals->num_regs;
1875 for (i = 0; i < inst->num_lanes; i++) {
1876 regmap = cdns_phy->regmap_tx_lane_cdb[i + inst->mlane];
1877 for (j = 0; j < num_regs; j++)
1878 regmap_write(regmap, reg_pairs[j].off,
1879 reg_pairs[j].val);
1880 }
1881 }
1882
1883 /* PHY PCS common registers configurations */
1884 pcs_cmn_vals = init_data->pcs_cmn_vals[phy_type][TYPE_NONE][ssc];
1885 if (pcs_cmn_vals) {
1886 reg_pairs = pcs_cmn_vals->reg_pairs;
1887 num_regs = pcs_cmn_vals->num_regs;
1888 regmap = cdns_phy->regmap_phy_pcs_common_cdb;
1889 for (i = 0; i < num_regs; i++)
1890 regmap_write(regmap, reg_pairs[i].off,
1891 reg_pairs[i].val);
1892 }
1893
1894 /* PMA common registers configurations */
1895 cmn_vals = init_data->cmn_vals[phy_type][TYPE_NONE][ssc];
1896 if (cmn_vals) {
1897 reg_pairs = cmn_vals->reg_pairs;
1898 num_regs = cmn_vals->num_regs;
1899 regmap = cdns_phy->regmap_common_cdb;
1900 for (i = 0; i < num_regs; i++)
1901 regmap_write(regmap, reg_pairs[i].off,
1902 reg_pairs[i].val);
1903 }
1904
1905 /* PMA TX lane registers configurations */
1906 tx_ln_vals = init_data->tx_ln_vals[phy_type][TYPE_NONE][ssc];
1907 if (tx_ln_vals) {
1908 reg_pairs = tx_ln_vals->reg_pairs;
1909 num_regs = tx_ln_vals->num_regs;
1910 for (i = 0; i < inst->num_lanes; i++) {
1911 regmap = cdns_phy->regmap_tx_lane_cdb[i + inst->mlane];
1912 for (j = 0; j < num_regs; j++)
1913 regmap_write(regmap, reg_pairs[j].off,
1914 reg_pairs[j].val);
1915 }
1916 }
1917
1918 /* PMA RX lane registers configurations */
1919 rx_ln_vals = init_data->rx_ln_vals[phy_type][TYPE_NONE][ssc];
1920 if (rx_ln_vals) {
1921 reg_pairs = rx_ln_vals->reg_pairs;
1922 num_regs = rx_ln_vals->num_regs;
1923 for (i = 0; i < inst->num_lanes; i++) {
1924 regmap = cdns_phy->regmap_rx_lane_cdb[i + inst->mlane];
1925 for (j = 0; j < num_regs; j++)
1926 regmap_write(regmap, reg_pairs[j].off,
1927 reg_pairs[j].val);
1928 }
1929 }
1930
1931 return 0;
1932 }
1933
1934 static
cdns_torrent_phy_configure_multilink(struct cdns_torrent_phy * cdns_phy)1935 int cdns_torrent_phy_configure_multilink(struct cdns_torrent_phy *cdns_phy)
1936 {
1937 const struct cdns_torrent_data *init_data = cdns_phy->init_data;
1938 struct cdns_torrent_vals *cmn_vals, *tx_ln_vals, *rx_ln_vals;
1939 struct cdns_torrent_vals *link_cmn_vals, *xcvr_diag_vals;
1940 enum cdns_torrent_phy_type phy_t1, phy_t2, tmp_phy_type;
1941 struct cdns_torrent_vals *pcs_cmn_vals;
1942 int i, j, node, mlane, num_lanes, ret;
1943 struct cdns_reg_pairs *reg_pairs;
1944 enum cdns_torrent_ssc_mode ssc;
1945 struct regmap *regmap;
1946 u32 num_regs;
1947
1948 /* Maximum 2 links (subnodes) are supported */
1949 if (cdns_phy->nsubnodes != 2)
1950 return -EINVAL;
1951
1952 phy_t1 = cdns_phy->phys[0].phy_type;
1953 phy_t2 = cdns_phy->phys[1].phy_type;
1954
1955 /**
1956 * First configure the PHY for first link with phy_t1. Get the array
1957 * values as [phy_t1][phy_t2][ssc].
1958 */
1959 for (node = 0; node < cdns_phy->nsubnodes; node++) {
1960 if (node == 1) {
1961 /**
1962 * If first link with phy_t1 is configured, then
1963 * configure the PHY for second link with phy_t2.
1964 * Get the array values as [phy_t2][phy_t1][ssc].
1965 */
1966 tmp_phy_type = phy_t1;
1967 phy_t1 = phy_t2;
1968 phy_t2 = tmp_phy_type;
1969 }
1970
1971 mlane = cdns_phy->phys[node].mlane;
1972 ssc = cdns_phy->phys[node].ssc_mode;
1973 num_lanes = cdns_phy->phys[node].num_lanes;
1974
1975 /**
1976 * PHY configuration specific registers:
1977 * link_cmn_vals depend on combination of PHY types being
1978 * configured and are common for both PHY types, so array
1979 * values should be same for [phy_t1][phy_t2][ssc] and
1980 * [phy_t2][phy_t1][ssc].
1981 * xcvr_diag_vals also depend on combination of PHY types
1982 * being configured, but these can be different for particular
1983 * PHY type and are per lane.
1984 */
1985 link_cmn_vals = init_data->link_cmn_vals[phy_t1][phy_t2][ssc];
1986 if (link_cmn_vals) {
1987 reg_pairs = link_cmn_vals->reg_pairs;
1988 num_regs = link_cmn_vals->num_regs;
1989 regmap = cdns_phy->regmap_common_cdb;
1990
1991 /**
1992 * First array value in link_cmn_vals must be of
1993 * PHY_PLL_CFG register
1994 */
1995 regmap_field_write(cdns_phy->phy_pll_cfg,
1996 reg_pairs[0].val);
1997
1998 for (i = 1; i < num_regs; i++)
1999 regmap_write(regmap, reg_pairs[i].off,
2000 reg_pairs[i].val);
2001 }
2002
2003 xcvr_diag_vals = init_data->xcvr_diag_vals[phy_t1][phy_t2][ssc];
2004 if (xcvr_diag_vals) {
2005 reg_pairs = xcvr_diag_vals->reg_pairs;
2006 num_regs = xcvr_diag_vals->num_regs;
2007 for (i = 0; i < num_lanes; i++) {
2008 regmap = cdns_phy->regmap_tx_lane_cdb[i + mlane];
2009 for (j = 0; j < num_regs; j++)
2010 regmap_write(regmap, reg_pairs[j].off,
2011 reg_pairs[j].val);
2012 }
2013 }
2014
2015 /* PHY PCS common registers configurations */
2016 pcs_cmn_vals = init_data->pcs_cmn_vals[phy_t1][phy_t2][ssc];
2017 if (pcs_cmn_vals) {
2018 reg_pairs = pcs_cmn_vals->reg_pairs;
2019 num_regs = pcs_cmn_vals->num_regs;
2020 regmap = cdns_phy->regmap_phy_pcs_common_cdb;
2021 for (i = 0; i < num_regs; i++)
2022 regmap_write(regmap, reg_pairs[i].off,
2023 reg_pairs[i].val);
2024 }
2025
2026 /* PMA common registers configurations */
2027 cmn_vals = init_data->cmn_vals[phy_t1][phy_t2][ssc];
2028 if (cmn_vals) {
2029 reg_pairs = cmn_vals->reg_pairs;
2030 num_regs = cmn_vals->num_regs;
2031 regmap = cdns_phy->regmap_common_cdb;
2032 for (i = 0; i < num_regs; i++)
2033 regmap_write(regmap, reg_pairs[i].off,
2034 reg_pairs[i].val);
2035 }
2036
2037 /* PMA TX lane registers configurations */
2038 tx_ln_vals = init_data->tx_ln_vals[phy_t1][phy_t2][ssc];
2039 if (tx_ln_vals) {
2040 reg_pairs = tx_ln_vals->reg_pairs;
2041 num_regs = tx_ln_vals->num_regs;
2042 for (i = 0; i < num_lanes; i++) {
2043 regmap = cdns_phy->regmap_tx_lane_cdb[i + mlane];
2044 for (j = 0; j < num_regs; j++)
2045 regmap_write(regmap, reg_pairs[j].off,
2046 reg_pairs[j].val);
2047 }
2048 }
2049
2050 /* PMA RX lane registers configurations */
2051 rx_ln_vals = init_data->rx_ln_vals[phy_t1][phy_t2][ssc];
2052 if (rx_ln_vals) {
2053 reg_pairs = rx_ln_vals->reg_pairs;
2054 num_regs = rx_ln_vals->num_regs;
2055 for (i = 0; i < num_lanes; i++) {
2056 regmap = cdns_phy->regmap_rx_lane_cdb[i + mlane];
2057 for (j = 0; j < num_regs; j++)
2058 regmap_write(regmap, reg_pairs[j].off,
2059 reg_pairs[j].val);
2060 }
2061 }
2062
2063 reset_control_deassert(cdns_phy->phys[node].lnk_rst);
2064 }
2065
2066 /* Take the PHY out of reset */
2067 ret = reset_control_deassert(cdns_phy->phy_rst);
2068 if (ret)
2069 return ret;
2070
2071 return 0;
2072 }
2073
cdns_torrent_phy_probe(struct platform_device * pdev)2074 static int cdns_torrent_phy_probe(struct platform_device *pdev)
2075 {
2076 struct cdns_torrent_phy *cdns_phy;
2077 struct device *dev = &pdev->dev;
2078 struct phy_provider *phy_provider;
2079 const struct cdns_torrent_data *data;
2080 struct device_node *child;
2081 int ret, subnodes, node = 0, i;
2082 u32 total_num_lanes = 0;
2083 u8 init_dp_regmap = 0;
2084 u32 phy_type;
2085
2086 /* Get init data for this PHY */
2087 data = of_device_get_match_data(dev);
2088 if (!data)
2089 return -EINVAL;
2090
2091 cdns_phy = devm_kzalloc(dev, sizeof(*cdns_phy), GFP_KERNEL);
2092 if (!cdns_phy)
2093 return -ENOMEM;
2094
2095 dev_set_drvdata(dev, cdns_phy);
2096 cdns_phy->dev = dev;
2097 cdns_phy->init_data = data;
2098
2099 cdns_phy->phy_rst = devm_reset_control_get_exclusive_by_index(dev, 0);
2100 if (IS_ERR(cdns_phy->phy_rst)) {
2101 dev_err(dev, "%s: failed to get reset\n",
2102 dev->of_node->full_name);
2103 return PTR_ERR(cdns_phy->phy_rst);
2104 }
2105
2106 cdns_phy->apb_rst = devm_reset_control_get_optional(dev, "torrent_apb");
2107 if (IS_ERR(cdns_phy->apb_rst)) {
2108 dev_err(dev, "%s: failed to get apb reset\n",
2109 dev->of_node->full_name);
2110 return PTR_ERR(cdns_phy->apb_rst);
2111 }
2112
2113 cdns_phy->clk = devm_clk_get(dev, "refclk");
2114 if (IS_ERR(cdns_phy->clk)) {
2115 dev_err(dev, "phy ref clock not found\n");
2116 return PTR_ERR(cdns_phy->clk);
2117 }
2118
2119 cdns_phy->sd_base = devm_platform_ioremap_resource(pdev, 0);
2120 if (IS_ERR(cdns_phy->sd_base))
2121 return PTR_ERR(cdns_phy->sd_base);
2122
2123 subnodes = of_get_available_child_count(dev->of_node);
2124 if (subnodes == 0) {
2125 dev_err(dev, "No available link subnodes found\n");
2126 return -EINVAL;
2127 }
2128
2129 ret = cdns_torrent_regmap_init(cdns_phy);
2130 if (ret)
2131 return ret;
2132
2133 ret = cdns_torrent_regfield_init(cdns_phy);
2134 if (ret)
2135 return ret;
2136
2137 ret = clk_prepare_enable(cdns_phy->clk);
2138 if (ret) {
2139 dev_err(cdns_phy->dev, "Failed to prepare ref clock\n");
2140 return ret;
2141 }
2142
2143 cdns_phy->ref_clk_rate = clk_get_rate(cdns_phy->clk);
2144 if (!(cdns_phy->ref_clk_rate)) {
2145 dev_err(cdns_phy->dev, "Failed to get ref clock rate\n");
2146 clk_disable_unprepare(cdns_phy->clk);
2147 return -EINVAL;
2148 }
2149
2150 /* Enable APB */
2151 reset_control_deassert(cdns_phy->apb_rst);
2152
2153 for_each_available_child_of_node(dev->of_node, child) {
2154 struct phy *gphy;
2155
2156 /* PHY subnode name must be 'phy'. */
2157 if (!(of_node_name_eq(child, "phy")))
2158 continue;
2159
2160 cdns_phy->phys[node].lnk_rst =
2161 of_reset_control_array_get_exclusive(child);
2162 if (IS_ERR(cdns_phy->phys[node].lnk_rst)) {
2163 dev_err(dev, "%s: failed to get reset\n",
2164 child->full_name);
2165 ret = PTR_ERR(cdns_phy->phys[node].lnk_rst);
2166 goto put_lnk_rst;
2167 }
2168
2169 if (of_property_read_u32(child, "reg",
2170 &cdns_phy->phys[node].mlane)) {
2171 dev_err(dev, "%s: No \"reg\"-property.\n",
2172 child->full_name);
2173 ret = -EINVAL;
2174 goto put_child;
2175 }
2176
2177 if (of_property_read_u32(child, "cdns,phy-type", &phy_type)) {
2178 dev_err(dev, "%s: No \"cdns,phy-type\"-property.\n",
2179 child->full_name);
2180 ret = -EINVAL;
2181 goto put_child;
2182 }
2183
2184 switch (phy_type) {
2185 case PHY_TYPE_PCIE:
2186 cdns_phy->phys[node].phy_type = TYPE_PCIE;
2187 break;
2188 case PHY_TYPE_DP:
2189 cdns_phy->phys[node].phy_type = TYPE_DP;
2190 break;
2191 case PHY_TYPE_SGMII:
2192 cdns_phy->phys[node].phy_type = TYPE_SGMII;
2193 break;
2194 case PHY_TYPE_QSGMII:
2195 cdns_phy->phys[node].phy_type = TYPE_QSGMII;
2196 break;
2197 case PHY_TYPE_USB3:
2198 cdns_phy->phys[node].phy_type = TYPE_USB;
2199 break;
2200 default:
2201 dev_err(dev, "Unsupported protocol\n");
2202 ret = -EINVAL;
2203 goto put_child;
2204 }
2205
2206 if (of_property_read_u32(child, "cdns,num-lanes",
2207 &cdns_phy->phys[node].num_lanes)) {
2208 dev_err(dev, "%s: No \"cdns,num-lanes\"-property.\n",
2209 child->full_name);
2210 ret = -EINVAL;
2211 goto put_child;
2212 }
2213
2214 total_num_lanes += cdns_phy->phys[node].num_lanes;
2215
2216 /* Get SSC mode */
2217 cdns_phy->phys[node].ssc_mode = NO_SSC;
2218 of_property_read_u32(child, "cdns,ssc-mode",
2219 &cdns_phy->phys[node].ssc_mode);
2220
2221 gphy = devm_phy_create(dev, child, &cdns_torrent_phy_ops);
2222 if (IS_ERR(gphy)) {
2223 ret = PTR_ERR(gphy);
2224 goto put_child;
2225 }
2226
2227 if (cdns_phy->phys[node].phy_type == TYPE_DP) {
2228 switch (cdns_phy->phys[node].num_lanes) {
2229 case 1:
2230 case 2:
2231 case 4:
2232 /* valid number of lanes */
2233 break;
2234 default:
2235 dev_err(dev, "unsupported number of lanes: %d\n",
2236 cdns_phy->phys[node].num_lanes);
2237 ret = -EINVAL;
2238 goto put_child;
2239 }
2240
2241 cdns_phy->max_bit_rate = DEFAULT_MAX_BIT_RATE;
2242 of_property_read_u32(child, "cdns,max-bit-rate",
2243 &cdns_phy->max_bit_rate);
2244
2245 switch (cdns_phy->max_bit_rate) {
2246 case 1620:
2247 case 2160:
2248 case 2430:
2249 case 2700:
2250 case 3240:
2251 case 4320:
2252 case 5400:
2253 case 8100:
2254 /* valid bit rate */
2255 break;
2256 default:
2257 dev_err(dev, "unsupported max bit rate: %dMbps\n",
2258 cdns_phy->max_bit_rate);
2259 ret = -EINVAL;
2260 goto put_child;
2261 }
2262
2263 /* DPTX registers */
2264 cdns_phy->base = devm_platform_ioremap_resource(pdev, 1);
2265 if (IS_ERR(cdns_phy->base)) {
2266 ret = PTR_ERR(cdns_phy->base);
2267 goto put_child;
2268 }
2269
2270 if (!init_dp_regmap) {
2271 ret = cdns_torrent_dp_regmap_init(cdns_phy);
2272 if (ret)
2273 goto put_child;
2274
2275 ret = cdns_torrent_dp_regfield_init(cdns_phy);
2276 if (ret)
2277 goto put_child;
2278
2279 init_dp_regmap++;
2280 }
2281
2282 dev_info(dev, "%d lanes, max bit rate %d.%03d Gbps\n",
2283 cdns_phy->phys[node].num_lanes,
2284 cdns_phy->max_bit_rate / 1000,
2285 cdns_phy->max_bit_rate % 1000);
2286
2287 gphy->attrs.bus_width = cdns_phy->phys[node].num_lanes;
2288 gphy->attrs.max_link_rate = cdns_phy->max_bit_rate;
2289 gphy->attrs.mode = PHY_MODE_DP;
2290 }
2291
2292 cdns_phy->phys[node].phy = gphy;
2293 phy_set_drvdata(gphy, &cdns_phy->phys[node]);
2294
2295 node++;
2296 }
2297 cdns_phy->nsubnodes = node;
2298
2299 if (total_num_lanes > MAX_NUM_LANES) {
2300 dev_err(dev, "Invalid lane configuration\n");
2301 ret = -EINVAL;
2302 goto put_lnk_rst;
2303 }
2304
2305 if (cdns_phy->nsubnodes > 1) {
2306 ret = cdns_torrent_phy_configure_multilink(cdns_phy);
2307 if (ret)
2308 goto put_lnk_rst;
2309 }
2310
2311 phy_provider = devm_of_phy_provider_register(dev, of_phy_simple_xlate);
2312 if (IS_ERR(phy_provider)) {
2313 ret = PTR_ERR(phy_provider);
2314 goto put_lnk_rst;
2315 }
2316
2317 return 0;
2318
2319 put_child:
2320 node++;
2321 put_lnk_rst:
2322 for (i = 0; i < node; i++)
2323 reset_control_put(cdns_phy->phys[i].lnk_rst);
2324 of_node_put(child);
2325 reset_control_assert(cdns_phy->apb_rst);
2326 clk_disable_unprepare(cdns_phy->clk);
2327 return ret;
2328 }
2329
cdns_torrent_phy_remove(struct platform_device * pdev)2330 static int cdns_torrent_phy_remove(struct platform_device *pdev)
2331 {
2332 struct cdns_torrent_phy *cdns_phy = platform_get_drvdata(pdev);
2333 int i;
2334
2335 reset_control_assert(cdns_phy->phy_rst);
2336 reset_control_assert(cdns_phy->apb_rst);
2337 for (i = 0; i < cdns_phy->nsubnodes; i++) {
2338 reset_control_assert(cdns_phy->phys[i].lnk_rst);
2339 reset_control_put(cdns_phy->phys[i].lnk_rst);
2340 }
2341
2342 clk_disable_unprepare(cdns_phy->clk);
2343
2344 return 0;
2345 }
2346
2347 /* USB and SGMII/QSGMII link configuration */
2348 static struct cdns_reg_pairs usb_sgmii_link_cmn_regs[] = {
2349 {0x0002, PHY_PLL_CFG},
2350 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0},
2351 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0}
2352 };
2353
2354 static struct cdns_reg_pairs usb_sgmii_xcvr_diag_ln_regs[] = {
2355 {0x0000, XCVR_DIAG_HSCLK_SEL},
2356 {0x0001, XCVR_DIAG_HSCLK_DIV},
2357 {0x0041, XCVR_DIAG_PLLDRC_CTRL}
2358 };
2359
2360 static struct cdns_reg_pairs sgmii_usb_xcvr_diag_ln_regs[] = {
2361 {0x0011, XCVR_DIAG_HSCLK_SEL},
2362 {0x0003, XCVR_DIAG_HSCLK_DIV},
2363 {0x009B, XCVR_DIAG_PLLDRC_CTRL}
2364 };
2365
2366 static struct cdns_torrent_vals usb_sgmii_link_cmn_vals = {
2367 .reg_pairs = usb_sgmii_link_cmn_regs,
2368 .num_regs = ARRAY_SIZE(usb_sgmii_link_cmn_regs),
2369 };
2370
2371 static struct cdns_torrent_vals usb_sgmii_xcvr_diag_ln_vals = {
2372 .reg_pairs = usb_sgmii_xcvr_diag_ln_regs,
2373 .num_regs = ARRAY_SIZE(usb_sgmii_xcvr_diag_ln_regs),
2374 };
2375
2376 static struct cdns_torrent_vals sgmii_usb_xcvr_diag_ln_vals = {
2377 .reg_pairs = sgmii_usb_xcvr_diag_ln_regs,
2378 .num_regs = ARRAY_SIZE(sgmii_usb_xcvr_diag_ln_regs),
2379 };
2380
2381 /* PCIe and USB Unique SSC link configuration */
2382 static struct cdns_reg_pairs pcie_usb_link_cmn_regs[] = {
2383 {0x0003, PHY_PLL_CFG},
2384 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0},
2385 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1},
2386 {0x8600, CMN_PDIAG_PLL1_CLK_SEL_M0}
2387 };
2388
2389 static struct cdns_reg_pairs pcie_usb_xcvr_diag_ln_regs[] = {
2390 {0x0000, XCVR_DIAG_HSCLK_SEL},
2391 {0x0001, XCVR_DIAG_HSCLK_DIV},
2392 {0x0012, XCVR_DIAG_PLLDRC_CTRL}
2393 };
2394
2395 static struct cdns_reg_pairs usb_pcie_xcvr_diag_ln_regs[] = {
2396 {0x0011, XCVR_DIAG_HSCLK_SEL},
2397 {0x0001, XCVR_DIAG_HSCLK_DIV},
2398 {0x00C9, XCVR_DIAG_PLLDRC_CTRL}
2399 };
2400
2401 static struct cdns_torrent_vals pcie_usb_link_cmn_vals = {
2402 .reg_pairs = pcie_usb_link_cmn_regs,
2403 .num_regs = ARRAY_SIZE(pcie_usb_link_cmn_regs),
2404 };
2405
2406 static struct cdns_torrent_vals pcie_usb_xcvr_diag_ln_vals = {
2407 .reg_pairs = pcie_usb_xcvr_diag_ln_regs,
2408 .num_regs = ARRAY_SIZE(pcie_usb_xcvr_diag_ln_regs),
2409 };
2410
2411 static struct cdns_torrent_vals usb_pcie_xcvr_diag_ln_vals = {
2412 .reg_pairs = usb_pcie_xcvr_diag_ln_regs,
2413 .num_regs = ARRAY_SIZE(usb_pcie_xcvr_diag_ln_regs),
2414 };
2415
2416 /* USB 100 MHz Ref clk, internal SSC */
2417 static struct cdns_reg_pairs usb_100_int_ssc_cmn_regs[] = {
2418 {0x0004, CMN_PLL0_DSM_DIAG_M0},
2419 {0x0004, CMN_PLL0_DSM_DIAG_M1},
2420 {0x0004, CMN_PLL1_DSM_DIAG_M0},
2421 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
2422 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
2423 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
2424 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
2425 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
2426 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
2427 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
2428 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
2429 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
2430 {0x0064, CMN_PLL0_INTDIV_M0},
2431 {0x0050, CMN_PLL0_INTDIV_M1},
2432 {0x0064, CMN_PLL1_INTDIV_M0},
2433 {0x0002, CMN_PLL0_FRACDIVH_M0},
2434 {0x0002, CMN_PLL0_FRACDIVH_M1},
2435 {0x0002, CMN_PLL1_FRACDIVH_M0},
2436 {0x0044, CMN_PLL0_HIGH_THR_M0},
2437 {0x0036, CMN_PLL0_HIGH_THR_M1},
2438 {0x0044, CMN_PLL1_HIGH_THR_M0},
2439 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
2440 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
2441 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
2442 {0x0001, CMN_PLL0_SS_CTRL1_M0},
2443 {0x0001, CMN_PLL0_SS_CTRL1_M1},
2444 {0x0001, CMN_PLL1_SS_CTRL1_M0},
2445 {0x011B, CMN_PLL0_SS_CTRL2_M0},
2446 {0x011B, CMN_PLL0_SS_CTRL2_M1},
2447 {0x011B, CMN_PLL1_SS_CTRL2_M0},
2448 {0x006E, CMN_PLL0_SS_CTRL3_M0},
2449 {0x0058, CMN_PLL0_SS_CTRL3_M1},
2450 {0x006E, CMN_PLL1_SS_CTRL3_M0},
2451 {0x000E, CMN_PLL0_SS_CTRL4_M0},
2452 {0x0012, CMN_PLL0_SS_CTRL4_M1},
2453 {0x000E, CMN_PLL1_SS_CTRL4_M0},
2454 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
2455 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
2456 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
2457 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
2458 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2459 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
2460 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
2461 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
2462 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
2463 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
2464 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
2465 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR},
2466 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD},
2467 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD}
2468 };
2469
2470 static struct cdns_torrent_vals usb_100_int_ssc_cmn_vals = {
2471 .reg_pairs = usb_100_int_ssc_cmn_regs,
2472 .num_regs = ARRAY_SIZE(usb_100_int_ssc_cmn_regs),
2473 };
2474
2475 /* Single USB link configuration */
2476 static struct cdns_reg_pairs sl_usb_link_cmn_regs[] = {
2477 {0x0000, PHY_PLL_CFG},
2478 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0}
2479 };
2480
2481 static struct cdns_reg_pairs sl_usb_xcvr_diag_ln_regs[] = {
2482 {0x0000, XCVR_DIAG_HSCLK_SEL},
2483 {0x0001, XCVR_DIAG_HSCLK_DIV},
2484 {0x0041, XCVR_DIAG_PLLDRC_CTRL}
2485 };
2486
2487 static struct cdns_torrent_vals sl_usb_link_cmn_vals = {
2488 .reg_pairs = sl_usb_link_cmn_regs,
2489 .num_regs = ARRAY_SIZE(sl_usb_link_cmn_regs),
2490 };
2491
2492 static struct cdns_torrent_vals sl_usb_xcvr_diag_ln_vals = {
2493 .reg_pairs = sl_usb_xcvr_diag_ln_regs,
2494 .num_regs = ARRAY_SIZE(sl_usb_xcvr_diag_ln_regs),
2495 };
2496
2497 /* USB PHY PCS common configuration */
2498 static struct cdns_reg_pairs usb_phy_pcs_cmn_regs[] = {
2499 {0x0A0A, PHY_PIPE_USB3_GEN2_PRE_CFG0},
2500 {0x1000, PHY_PIPE_USB3_GEN2_POST_CFG0},
2501 {0x0010, PHY_PIPE_USB3_GEN2_POST_CFG1}
2502 };
2503
2504 static struct cdns_torrent_vals usb_phy_pcs_cmn_vals = {
2505 .reg_pairs = usb_phy_pcs_cmn_regs,
2506 .num_regs = ARRAY_SIZE(usb_phy_pcs_cmn_regs),
2507 };
2508
2509 /* USB 100 MHz Ref clk, no SSC */
2510 static struct cdns_reg_pairs usb_100_no_ssc_cmn_regs[] = {
2511 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2512 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
2513 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD},
2514 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD}
2515 };
2516
2517 static struct cdns_reg_pairs usb_100_no_ssc_tx_ln_regs[] = {
2518 {0x02FF, TX_PSC_A0},
2519 {0x06AF, TX_PSC_A1},
2520 {0x06AE, TX_PSC_A2},
2521 {0x06AE, TX_PSC_A3},
2522 {0x2A82, TX_TXCC_CTRL},
2523 {0x0014, TX_TXCC_CPOST_MULT_01},
2524 {0x0003, XCVR_DIAG_PSC_OVRD}
2525 };
2526
2527 static struct cdns_reg_pairs usb_100_no_ssc_rx_ln_regs[] = {
2528 {0x0D1D, RX_PSC_A0},
2529 {0x0D1D, RX_PSC_A1},
2530 {0x0D00, RX_PSC_A2},
2531 {0x0500, RX_PSC_A3},
2532 {0x0013, RX_SIGDET_HL_FILT_TMR},
2533 {0x0000, RX_REE_GCSM1_CTRL},
2534 {0x0C02, RX_REE_ATTEN_THR},
2535 {0x0330, RX_REE_SMGM_CTRL1},
2536 {0x0300, RX_REE_SMGM_CTRL2},
2537 {0x0019, RX_REE_TAP1_CLIP},
2538 {0x0019, RX_REE_TAP2TON_CLIP},
2539 {0x1004, RX_DIAG_SIGDET_TUNE},
2540 {0x00F9, RX_DIAG_NQST_CTRL},
2541 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2},
2542 {0x0002, RX_DIAG_DFE_AMP_TUNE_3},
2543 {0x0000, RX_DIAG_PI_CAP},
2544 {0x0031, RX_DIAG_PI_RATE},
2545 {0x0001, RX_DIAG_ACYA},
2546 {0x018C, RX_CDRLF_CNFG},
2547 {0x0003, RX_CDRLF_CNFG3}
2548 };
2549
2550 static struct cdns_torrent_vals usb_100_no_ssc_cmn_vals = {
2551 .reg_pairs = usb_100_no_ssc_cmn_regs,
2552 .num_regs = ARRAY_SIZE(usb_100_no_ssc_cmn_regs),
2553 };
2554
2555 static struct cdns_torrent_vals usb_100_no_ssc_tx_ln_vals = {
2556 .reg_pairs = usb_100_no_ssc_tx_ln_regs,
2557 .num_regs = ARRAY_SIZE(usb_100_no_ssc_tx_ln_regs),
2558 };
2559
2560 static struct cdns_torrent_vals usb_100_no_ssc_rx_ln_vals = {
2561 .reg_pairs = usb_100_no_ssc_rx_ln_regs,
2562 .num_regs = ARRAY_SIZE(usb_100_no_ssc_rx_ln_regs),
2563 };
2564
2565 /* Single link USB, 100 MHz Ref clk, internal SSC */
2566 static struct cdns_reg_pairs sl_usb_100_int_ssc_cmn_regs[] = {
2567 {0x0004, CMN_PLL0_DSM_DIAG_M0},
2568 {0x0004, CMN_PLL1_DSM_DIAG_M0},
2569 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
2570 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
2571 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
2572 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
2573 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
2574 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
2575 {0x0064, CMN_PLL0_INTDIV_M0},
2576 {0x0064, CMN_PLL1_INTDIV_M0},
2577 {0x0002, CMN_PLL0_FRACDIVH_M0},
2578 {0x0002, CMN_PLL1_FRACDIVH_M0},
2579 {0x0044, CMN_PLL0_HIGH_THR_M0},
2580 {0x0044, CMN_PLL1_HIGH_THR_M0},
2581 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
2582 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
2583 {0x0001, CMN_PLL0_SS_CTRL1_M0},
2584 {0x0001, CMN_PLL1_SS_CTRL1_M0},
2585 {0x011B, CMN_PLL0_SS_CTRL2_M0},
2586 {0x011B, CMN_PLL1_SS_CTRL2_M0},
2587 {0x006E, CMN_PLL0_SS_CTRL3_M0},
2588 {0x006E, CMN_PLL1_SS_CTRL3_M0},
2589 {0x000E, CMN_PLL0_SS_CTRL4_M0},
2590 {0x000E, CMN_PLL1_SS_CTRL4_M0},
2591 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
2592 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
2593 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
2594 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
2595 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2596 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
2597 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
2598 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
2599 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
2600 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
2601 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
2602 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR},
2603 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD},
2604 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD}
2605 };
2606
2607 static struct cdns_torrent_vals sl_usb_100_int_ssc_cmn_vals = {
2608 .reg_pairs = sl_usb_100_int_ssc_cmn_regs,
2609 .num_regs = ARRAY_SIZE(sl_usb_100_int_ssc_cmn_regs),
2610 };
2611
2612 /* PCIe and SGMII/QSGMII Unique SSC link configuration */
2613 static struct cdns_reg_pairs pcie_sgmii_link_cmn_regs[] = {
2614 {0x0003, PHY_PLL_CFG},
2615 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0},
2616 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1},
2617 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0}
2618 };
2619
2620 static struct cdns_reg_pairs pcie_sgmii_xcvr_diag_ln_regs[] = {
2621 {0x0000, XCVR_DIAG_HSCLK_SEL},
2622 {0x0001, XCVR_DIAG_HSCLK_DIV},
2623 {0x0012, XCVR_DIAG_PLLDRC_CTRL}
2624 };
2625
2626 static struct cdns_reg_pairs sgmii_pcie_xcvr_diag_ln_regs[] = {
2627 {0x0011, XCVR_DIAG_HSCLK_SEL},
2628 {0x0003, XCVR_DIAG_HSCLK_DIV},
2629 {0x009B, XCVR_DIAG_PLLDRC_CTRL}
2630 };
2631
2632 static struct cdns_torrent_vals pcie_sgmii_link_cmn_vals = {
2633 .reg_pairs = pcie_sgmii_link_cmn_regs,
2634 .num_regs = ARRAY_SIZE(pcie_sgmii_link_cmn_regs),
2635 };
2636
2637 static struct cdns_torrent_vals pcie_sgmii_xcvr_diag_ln_vals = {
2638 .reg_pairs = pcie_sgmii_xcvr_diag_ln_regs,
2639 .num_regs = ARRAY_SIZE(pcie_sgmii_xcvr_diag_ln_regs),
2640 };
2641
2642 static struct cdns_torrent_vals sgmii_pcie_xcvr_diag_ln_vals = {
2643 .reg_pairs = sgmii_pcie_xcvr_diag_ln_regs,
2644 .num_regs = ARRAY_SIZE(sgmii_pcie_xcvr_diag_ln_regs),
2645 };
2646
2647 /* SGMII 100 MHz Ref clk, no SSC */
2648 static struct cdns_reg_pairs sgmii_100_no_ssc_cmn_regs[] = {
2649 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2650 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
2651 {0x3700, CMN_DIAG_BIAS_OVRD1},
2652 {0x0008, CMN_TXPUCAL_TUNE},
2653 {0x0008, CMN_TXPDCAL_TUNE}
2654 };
2655
2656 static struct cdns_reg_pairs sgmii_100_no_ssc_tx_ln_regs[] = {
2657 {0x00F3, TX_PSC_A0},
2658 {0x04A2, TX_PSC_A2},
2659 {0x04A2, TX_PSC_A3},
2660 {0x0000, TX_TXCC_CPOST_MULT_00},
2661 {0x00B3, DRV_DIAG_TX_DRV}
2662 };
2663
2664 static struct cdns_reg_pairs sgmii_100_no_ssc_rx_ln_regs[] = {
2665 {0x091D, RX_PSC_A0},
2666 {0x0900, RX_PSC_A2},
2667 {0x0100, RX_PSC_A3},
2668 {0x03C7, RX_REE_GCSM1_EQENM_PH1},
2669 {0x01C7, RX_REE_GCSM1_EQENM_PH2},
2670 {0x0000, RX_DIAG_DFE_CTRL},
2671 {0x0019, RX_REE_TAP1_CLIP},
2672 {0x0019, RX_REE_TAP2TON_CLIP},
2673 {0x0098, RX_DIAG_NQST_CTRL},
2674 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2},
2675 {0x0000, RX_DIAG_DFE_AMP_TUNE_3},
2676 {0x0000, RX_DIAG_PI_CAP},
2677 {0x0010, RX_DIAG_PI_RATE},
2678 {0x0001, RX_DIAG_ACYA},
2679 {0x018C, RX_CDRLF_CNFG},
2680 };
2681
2682 static struct cdns_torrent_vals sgmii_100_no_ssc_cmn_vals = {
2683 .reg_pairs = sgmii_100_no_ssc_cmn_regs,
2684 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_cmn_regs),
2685 };
2686
2687 static struct cdns_torrent_vals sgmii_100_no_ssc_tx_ln_vals = {
2688 .reg_pairs = sgmii_100_no_ssc_tx_ln_regs,
2689 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_tx_ln_regs),
2690 };
2691
2692 static struct cdns_torrent_vals sgmii_100_no_ssc_rx_ln_vals = {
2693 .reg_pairs = sgmii_100_no_ssc_rx_ln_regs,
2694 .num_regs = ARRAY_SIZE(sgmii_100_no_ssc_rx_ln_regs),
2695 };
2696
2697 /* SGMII 100 MHz Ref clk, internal SSC */
2698 static struct cdns_reg_pairs sgmii_100_int_ssc_cmn_regs[] = {
2699 {0x0004, CMN_PLL0_DSM_DIAG_M0},
2700 {0x0004, CMN_PLL0_DSM_DIAG_M1},
2701 {0x0004, CMN_PLL1_DSM_DIAG_M0},
2702 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
2703 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
2704 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
2705 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
2706 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
2707 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
2708 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
2709 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
2710 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
2711 {0x0064, CMN_PLL0_INTDIV_M0},
2712 {0x0050, CMN_PLL0_INTDIV_M1},
2713 {0x0064, CMN_PLL1_INTDIV_M0},
2714 {0x0002, CMN_PLL0_FRACDIVH_M0},
2715 {0x0002, CMN_PLL0_FRACDIVH_M1},
2716 {0x0002, CMN_PLL1_FRACDIVH_M0},
2717 {0x0044, CMN_PLL0_HIGH_THR_M0},
2718 {0x0036, CMN_PLL0_HIGH_THR_M1},
2719 {0x0044, CMN_PLL1_HIGH_THR_M0},
2720 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
2721 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
2722 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
2723 {0x0001, CMN_PLL0_SS_CTRL1_M0},
2724 {0x0001, CMN_PLL0_SS_CTRL1_M1},
2725 {0x0001, CMN_PLL1_SS_CTRL1_M0},
2726 {0x011B, CMN_PLL0_SS_CTRL2_M0},
2727 {0x011B, CMN_PLL0_SS_CTRL2_M1},
2728 {0x011B, CMN_PLL1_SS_CTRL2_M0},
2729 {0x006E, CMN_PLL0_SS_CTRL3_M0},
2730 {0x0058, CMN_PLL0_SS_CTRL3_M1},
2731 {0x006E, CMN_PLL1_SS_CTRL3_M0},
2732 {0x000E, CMN_PLL0_SS_CTRL4_M0},
2733 {0x0012, CMN_PLL0_SS_CTRL4_M1},
2734 {0x000E, CMN_PLL1_SS_CTRL4_M0},
2735 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
2736 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
2737 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
2738 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
2739 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2740 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
2741 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
2742 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
2743 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
2744 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
2745 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
2746 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR},
2747 {0x3700, CMN_DIAG_BIAS_OVRD1},
2748 {0x0008, CMN_TXPUCAL_TUNE},
2749 {0x0008, CMN_TXPDCAL_TUNE}
2750 };
2751
2752 static struct cdns_torrent_vals sgmii_100_int_ssc_cmn_vals = {
2753 .reg_pairs = sgmii_100_int_ssc_cmn_regs,
2754 .num_regs = ARRAY_SIZE(sgmii_100_int_ssc_cmn_regs),
2755 };
2756
2757 /* QSGMII 100 MHz Ref clk, no SSC */
2758 static struct cdns_reg_pairs qsgmii_100_no_ssc_cmn_regs[] = {
2759 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2760 {0x0003, CMN_PLL1_VCOCAL_TCTRL}
2761 };
2762
2763 static struct cdns_reg_pairs qsgmii_100_no_ssc_tx_ln_regs[] = {
2764 {0x00F3, TX_PSC_A0},
2765 {0x04A2, TX_PSC_A2},
2766 {0x04A2, TX_PSC_A3},
2767 {0x0000, TX_TXCC_CPOST_MULT_00},
2768 {0x0003, DRV_DIAG_TX_DRV}
2769 };
2770
2771 static struct cdns_reg_pairs qsgmii_100_no_ssc_rx_ln_regs[] = {
2772 {0x091D, RX_PSC_A0},
2773 {0x0900, RX_PSC_A2},
2774 {0x0100, RX_PSC_A3},
2775 {0x03C7, RX_REE_GCSM1_EQENM_PH1},
2776 {0x01C7, RX_REE_GCSM1_EQENM_PH2},
2777 {0x0000, RX_DIAG_DFE_CTRL},
2778 {0x0019, RX_REE_TAP1_CLIP},
2779 {0x0019, RX_REE_TAP2TON_CLIP},
2780 {0x0098, RX_DIAG_NQST_CTRL},
2781 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2},
2782 {0x0000, RX_DIAG_DFE_AMP_TUNE_3},
2783 {0x0000, RX_DIAG_PI_CAP},
2784 {0x0010, RX_DIAG_PI_RATE},
2785 {0x0001, RX_DIAG_ACYA},
2786 {0x018C, RX_CDRLF_CNFG},
2787 };
2788
2789 static struct cdns_torrent_vals qsgmii_100_no_ssc_cmn_vals = {
2790 .reg_pairs = qsgmii_100_no_ssc_cmn_regs,
2791 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_cmn_regs),
2792 };
2793
2794 static struct cdns_torrent_vals qsgmii_100_no_ssc_tx_ln_vals = {
2795 .reg_pairs = qsgmii_100_no_ssc_tx_ln_regs,
2796 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_tx_ln_regs),
2797 };
2798
2799 static struct cdns_torrent_vals qsgmii_100_no_ssc_rx_ln_vals = {
2800 .reg_pairs = qsgmii_100_no_ssc_rx_ln_regs,
2801 .num_regs = ARRAY_SIZE(qsgmii_100_no_ssc_rx_ln_regs),
2802 };
2803
2804 /* QSGMII 100 MHz Ref clk, internal SSC */
2805 static struct cdns_reg_pairs qsgmii_100_int_ssc_cmn_regs[] = {
2806 {0x0004, CMN_PLL0_DSM_DIAG_M0},
2807 {0x0004, CMN_PLL0_DSM_DIAG_M1},
2808 {0x0004, CMN_PLL1_DSM_DIAG_M0},
2809 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
2810 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
2811 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
2812 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
2813 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
2814 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
2815 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
2816 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
2817 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
2818 {0x0064, CMN_PLL0_INTDIV_M0},
2819 {0x0050, CMN_PLL0_INTDIV_M1},
2820 {0x0064, CMN_PLL1_INTDIV_M0},
2821 {0x0002, CMN_PLL0_FRACDIVH_M0},
2822 {0x0002, CMN_PLL0_FRACDIVH_M1},
2823 {0x0002, CMN_PLL1_FRACDIVH_M0},
2824 {0x0044, CMN_PLL0_HIGH_THR_M0},
2825 {0x0036, CMN_PLL0_HIGH_THR_M1},
2826 {0x0044, CMN_PLL1_HIGH_THR_M0},
2827 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
2828 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
2829 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
2830 {0x0001, CMN_PLL0_SS_CTRL1_M0},
2831 {0x0001, CMN_PLL0_SS_CTRL1_M1},
2832 {0x0001, CMN_PLL1_SS_CTRL1_M0},
2833 {0x011B, CMN_PLL0_SS_CTRL2_M0},
2834 {0x011B, CMN_PLL0_SS_CTRL2_M1},
2835 {0x011B, CMN_PLL1_SS_CTRL2_M0},
2836 {0x006E, CMN_PLL0_SS_CTRL3_M0},
2837 {0x0058, CMN_PLL0_SS_CTRL3_M1},
2838 {0x006E, CMN_PLL1_SS_CTRL3_M0},
2839 {0x000E, CMN_PLL0_SS_CTRL4_M0},
2840 {0x0012, CMN_PLL0_SS_CTRL4_M1},
2841 {0x000E, CMN_PLL1_SS_CTRL4_M0},
2842 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
2843 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
2844 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
2845 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
2846 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2847 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
2848 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
2849 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
2850 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
2851 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
2852 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
2853 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}
2854 };
2855
2856 static struct cdns_torrent_vals qsgmii_100_int_ssc_cmn_vals = {
2857 .reg_pairs = qsgmii_100_int_ssc_cmn_regs,
2858 .num_regs = ARRAY_SIZE(qsgmii_100_int_ssc_cmn_regs),
2859 };
2860
2861 /* Single SGMII/QSGMII link configuration */
2862 static struct cdns_reg_pairs sl_sgmii_link_cmn_regs[] = {
2863 {0x0000, PHY_PLL_CFG},
2864 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0}
2865 };
2866
2867 static struct cdns_reg_pairs sl_sgmii_xcvr_diag_ln_regs[] = {
2868 {0x0000, XCVR_DIAG_HSCLK_SEL},
2869 {0x0003, XCVR_DIAG_HSCLK_DIV},
2870 {0x0013, XCVR_DIAG_PLLDRC_CTRL}
2871 };
2872
2873 static struct cdns_torrent_vals sl_sgmii_link_cmn_vals = {
2874 .reg_pairs = sl_sgmii_link_cmn_regs,
2875 .num_regs = ARRAY_SIZE(sl_sgmii_link_cmn_regs),
2876 };
2877
2878 static struct cdns_torrent_vals sl_sgmii_xcvr_diag_ln_vals = {
2879 .reg_pairs = sl_sgmii_xcvr_diag_ln_regs,
2880 .num_regs = ARRAY_SIZE(sl_sgmii_xcvr_diag_ln_regs),
2881 };
2882
2883 /* Multi link PCIe, 100 MHz Ref clk, internal SSC */
2884 static struct cdns_reg_pairs pcie_100_int_ssc_cmn_regs[] = {
2885 {0x0004, CMN_PLL0_DSM_DIAG_M0},
2886 {0x0004, CMN_PLL0_DSM_DIAG_M1},
2887 {0x0004, CMN_PLL1_DSM_DIAG_M0},
2888 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
2889 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
2890 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
2891 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
2892 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
2893 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
2894 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
2895 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
2896 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
2897 {0x0064, CMN_PLL0_INTDIV_M0},
2898 {0x0050, CMN_PLL0_INTDIV_M1},
2899 {0x0064, CMN_PLL1_INTDIV_M0},
2900 {0x0002, CMN_PLL0_FRACDIVH_M0},
2901 {0x0002, CMN_PLL0_FRACDIVH_M1},
2902 {0x0002, CMN_PLL1_FRACDIVH_M0},
2903 {0x0044, CMN_PLL0_HIGH_THR_M0},
2904 {0x0036, CMN_PLL0_HIGH_THR_M1},
2905 {0x0044, CMN_PLL1_HIGH_THR_M0},
2906 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
2907 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
2908 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
2909 {0x0001, CMN_PLL0_SS_CTRL1_M0},
2910 {0x0001, CMN_PLL0_SS_CTRL1_M1},
2911 {0x0001, CMN_PLL1_SS_CTRL1_M0},
2912 {0x011B, CMN_PLL0_SS_CTRL2_M0},
2913 {0x011B, CMN_PLL0_SS_CTRL2_M1},
2914 {0x011B, CMN_PLL1_SS_CTRL2_M0},
2915 {0x006E, CMN_PLL0_SS_CTRL3_M0},
2916 {0x0058, CMN_PLL0_SS_CTRL3_M1},
2917 {0x006E, CMN_PLL1_SS_CTRL3_M0},
2918 {0x000E, CMN_PLL0_SS_CTRL4_M0},
2919 {0x0012, CMN_PLL0_SS_CTRL4_M1},
2920 {0x000E, CMN_PLL1_SS_CTRL4_M0},
2921 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
2922 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
2923 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
2924 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
2925 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2926 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
2927 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
2928 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
2929 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
2930 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
2931 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
2932 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}
2933 };
2934
2935 static struct cdns_torrent_vals pcie_100_int_ssc_cmn_vals = {
2936 .reg_pairs = pcie_100_int_ssc_cmn_regs,
2937 .num_regs = ARRAY_SIZE(pcie_100_int_ssc_cmn_regs),
2938 };
2939
2940 /* Single link PCIe, 100 MHz Ref clk, internal SSC */
2941 static struct cdns_reg_pairs sl_pcie_100_int_ssc_cmn_regs[] = {
2942 {0x0004, CMN_PLL0_DSM_DIAG_M0},
2943 {0x0004, CMN_PLL0_DSM_DIAG_M1},
2944 {0x0004, CMN_PLL1_DSM_DIAG_M0},
2945 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0},
2946 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1},
2947 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0},
2948 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0},
2949 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1},
2950 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0},
2951 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0},
2952 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1},
2953 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0},
2954 {0x0064, CMN_PLL0_INTDIV_M0},
2955 {0x0050, CMN_PLL0_INTDIV_M1},
2956 {0x0050, CMN_PLL1_INTDIV_M0},
2957 {0x0002, CMN_PLL0_FRACDIVH_M0},
2958 {0x0002, CMN_PLL0_FRACDIVH_M1},
2959 {0x0002, CMN_PLL1_FRACDIVH_M0},
2960 {0x0044, CMN_PLL0_HIGH_THR_M0},
2961 {0x0036, CMN_PLL0_HIGH_THR_M1},
2962 {0x0036, CMN_PLL1_HIGH_THR_M0},
2963 {0x0002, CMN_PDIAG_PLL0_CTRL_M0},
2964 {0x0002, CMN_PDIAG_PLL0_CTRL_M1},
2965 {0x0002, CMN_PDIAG_PLL1_CTRL_M0},
2966 {0x0001, CMN_PLL0_SS_CTRL1_M0},
2967 {0x0001, CMN_PLL0_SS_CTRL1_M1},
2968 {0x0001, CMN_PLL1_SS_CTRL1_M0},
2969 {0x011B, CMN_PLL0_SS_CTRL2_M0},
2970 {0x011B, CMN_PLL0_SS_CTRL2_M1},
2971 {0x011B, CMN_PLL1_SS_CTRL2_M0},
2972 {0x006E, CMN_PLL0_SS_CTRL3_M0},
2973 {0x0058, CMN_PLL0_SS_CTRL3_M1},
2974 {0x0058, CMN_PLL1_SS_CTRL3_M0},
2975 {0x000E, CMN_PLL0_SS_CTRL4_M0},
2976 {0x0012, CMN_PLL0_SS_CTRL4_M1},
2977 {0x0012, CMN_PLL1_SS_CTRL4_M0},
2978 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START},
2979 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START},
2980 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START},
2981 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START},
2982 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
2983 {0x0003, CMN_PLL1_VCOCAL_TCTRL},
2984 {0x00C7, CMN_PLL0_LOCK_REFCNT_START},
2985 {0x00C7, CMN_PLL1_LOCK_REFCNT_START},
2986 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START},
2987 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START},
2988 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR},
2989 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR}
2990 };
2991
2992 static struct cdns_torrent_vals sl_pcie_100_int_ssc_cmn_vals = {
2993 .reg_pairs = sl_pcie_100_int_ssc_cmn_regs,
2994 .num_regs = ARRAY_SIZE(sl_pcie_100_int_ssc_cmn_regs),
2995 };
2996
2997 /* PCIe, 100 MHz Ref clk, no SSC & external SSC */
2998 static struct cdns_reg_pairs pcie_100_ext_no_ssc_cmn_regs[] = {
2999 {0x0003, CMN_PLL0_VCOCAL_TCTRL},
3000 {0x0003, CMN_PLL1_VCOCAL_TCTRL}
3001 };
3002
3003 static struct cdns_reg_pairs pcie_100_ext_no_ssc_rx_ln_regs[] = {
3004 {0x0019, RX_REE_TAP1_CLIP},
3005 {0x0019, RX_REE_TAP2TON_CLIP},
3006 {0x0001, RX_DIAG_ACYA}
3007 };
3008
3009 static struct cdns_torrent_vals pcie_100_no_ssc_cmn_vals = {
3010 .reg_pairs = pcie_100_ext_no_ssc_cmn_regs,
3011 .num_regs = ARRAY_SIZE(pcie_100_ext_no_ssc_cmn_regs),
3012 };
3013
3014 static struct cdns_torrent_vals pcie_100_no_ssc_rx_ln_vals = {
3015 .reg_pairs = pcie_100_ext_no_ssc_rx_ln_regs,
3016 .num_regs = ARRAY_SIZE(pcie_100_ext_no_ssc_rx_ln_regs),
3017 };
3018
3019 static const struct cdns_torrent_data cdns_map_torrent = {
3020 .block_offset_shift = 0x2,
3021 .reg_offset_shift = 0x2,
3022 .link_cmn_vals = {
3023 [TYPE_PCIE] = {
3024 [TYPE_NONE] = {
3025 [NO_SSC] = NULL,
3026 [EXTERNAL_SSC] = NULL,
3027 [INTERNAL_SSC] = NULL,
3028 },
3029 [TYPE_SGMII] = {
3030 [NO_SSC] = &pcie_sgmii_link_cmn_vals,
3031 [EXTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3032 [INTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3033 },
3034 [TYPE_QSGMII] = {
3035 [NO_SSC] = &pcie_sgmii_link_cmn_vals,
3036 [EXTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3037 [INTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3038 },
3039 [TYPE_USB] = {
3040 [NO_SSC] = &pcie_usb_link_cmn_vals,
3041 [EXTERNAL_SSC] = &pcie_usb_link_cmn_vals,
3042 [INTERNAL_SSC] = &pcie_usb_link_cmn_vals,
3043 },
3044 },
3045 [TYPE_SGMII] = {
3046 [TYPE_NONE] = {
3047 [NO_SSC] = &sl_sgmii_link_cmn_vals,
3048 },
3049 [TYPE_PCIE] = {
3050 [NO_SSC] = &pcie_sgmii_link_cmn_vals,
3051 [EXTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3052 [INTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3053 },
3054 [TYPE_USB] = {
3055 [NO_SSC] = &usb_sgmii_link_cmn_vals,
3056 [EXTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3057 [INTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3058 },
3059 },
3060 [TYPE_QSGMII] = {
3061 [TYPE_NONE] = {
3062 [NO_SSC] = &sl_sgmii_link_cmn_vals,
3063 },
3064 [TYPE_PCIE] = {
3065 [NO_SSC] = &pcie_sgmii_link_cmn_vals,
3066 [EXTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3067 [INTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3068 },
3069 [TYPE_USB] = {
3070 [NO_SSC] = &usb_sgmii_link_cmn_vals,
3071 [EXTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3072 [INTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3073 },
3074 },
3075 [TYPE_USB] = {
3076 [TYPE_NONE] = {
3077 [NO_SSC] = &sl_usb_link_cmn_vals,
3078 [EXTERNAL_SSC] = &sl_usb_link_cmn_vals,
3079 [INTERNAL_SSC] = &sl_usb_link_cmn_vals,
3080 },
3081 [TYPE_PCIE] = {
3082 [NO_SSC] = &pcie_usb_link_cmn_vals,
3083 [EXTERNAL_SSC] = &pcie_usb_link_cmn_vals,
3084 [INTERNAL_SSC] = &pcie_usb_link_cmn_vals,
3085 },
3086 [TYPE_SGMII] = {
3087 [NO_SSC] = &usb_sgmii_link_cmn_vals,
3088 [EXTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3089 [INTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3090 },
3091 [TYPE_QSGMII] = {
3092 [NO_SSC] = &usb_sgmii_link_cmn_vals,
3093 [EXTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3094 [INTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3095 },
3096 },
3097 },
3098 .xcvr_diag_vals = {
3099 [TYPE_PCIE] = {
3100 [TYPE_NONE] = {
3101 [NO_SSC] = NULL,
3102 [EXTERNAL_SSC] = NULL,
3103 [INTERNAL_SSC] = NULL,
3104 },
3105 [TYPE_SGMII] = {
3106 [NO_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3107 [EXTERNAL_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3108 [INTERNAL_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3109 },
3110 [TYPE_QSGMII] = {
3111 [NO_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3112 [EXTERNAL_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3113 [INTERNAL_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3114 },
3115 [TYPE_USB] = {
3116 [NO_SSC] = &pcie_usb_xcvr_diag_ln_vals,
3117 [EXTERNAL_SSC] = &pcie_usb_xcvr_diag_ln_vals,
3118 [INTERNAL_SSC] = &pcie_usb_xcvr_diag_ln_vals,
3119 },
3120 },
3121 [TYPE_SGMII] = {
3122 [TYPE_NONE] = {
3123 [NO_SSC] = &sl_sgmii_xcvr_diag_ln_vals,
3124 },
3125 [TYPE_PCIE] = {
3126 [NO_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3127 [EXTERNAL_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3128 [INTERNAL_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3129 },
3130 [TYPE_USB] = {
3131 [NO_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3132 [EXTERNAL_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3133 [INTERNAL_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3134 },
3135 },
3136 [TYPE_QSGMII] = {
3137 [TYPE_NONE] = {
3138 [NO_SSC] = &sl_sgmii_xcvr_diag_ln_vals,
3139 },
3140 [TYPE_PCIE] = {
3141 [NO_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3142 [EXTERNAL_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3143 [INTERNAL_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3144 },
3145 [TYPE_USB] = {
3146 [NO_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3147 [EXTERNAL_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3148 [INTERNAL_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3149 },
3150 },
3151 [TYPE_USB] = {
3152 [TYPE_NONE] = {
3153 [NO_SSC] = &sl_usb_xcvr_diag_ln_vals,
3154 [EXTERNAL_SSC] = &sl_usb_xcvr_diag_ln_vals,
3155 [INTERNAL_SSC] = &sl_usb_xcvr_diag_ln_vals,
3156 },
3157 [TYPE_PCIE] = {
3158 [NO_SSC] = &usb_pcie_xcvr_diag_ln_vals,
3159 [EXTERNAL_SSC] = &usb_pcie_xcvr_diag_ln_vals,
3160 [INTERNAL_SSC] = &usb_pcie_xcvr_diag_ln_vals,
3161 },
3162 [TYPE_SGMII] = {
3163 [NO_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3164 [EXTERNAL_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3165 [INTERNAL_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3166 },
3167 [TYPE_QSGMII] = {
3168 [NO_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3169 [EXTERNAL_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3170 [INTERNAL_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3171 },
3172 },
3173 },
3174 .pcs_cmn_vals = {
3175 [TYPE_USB] = {
3176 [TYPE_NONE] = {
3177 [NO_SSC] = &usb_phy_pcs_cmn_vals,
3178 [EXTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3179 [INTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3180 },
3181 [TYPE_PCIE] = {
3182 [NO_SSC] = &usb_phy_pcs_cmn_vals,
3183 [EXTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3184 [INTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3185 },
3186 [TYPE_SGMII] = {
3187 [NO_SSC] = &usb_phy_pcs_cmn_vals,
3188 [EXTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3189 [INTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3190 },
3191 [TYPE_QSGMII] = {
3192 [NO_SSC] = &usb_phy_pcs_cmn_vals,
3193 [EXTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3194 [INTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3195 },
3196 },
3197 },
3198 .cmn_vals = {
3199 [TYPE_PCIE] = {
3200 [TYPE_NONE] = {
3201 [NO_SSC] = &pcie_100_no_ssc_cmn_vals,
3202 [EXTERNAL_SSC] = &pcie_100_no_ssc_cmn_vals,
3203 [INTERNAL_SSC] = &sl_pcie_100_int_ssc_cmn_vals,
3204 },
3205 [TYPE_SGMII] = {
3206 [NO_SSC] = &pcie_100_no_ssc_cmn_vals,
3207 [EXTERNAL_SSC] = &pcie_100_no_ssc_cmn_vals,
3208 [INTERNAL_SSC] = &pcie_100_int_ssc_cmn_vals,
3209 },
3210 [TYPE_QSGMII] = {
3211 [NO_SSC] = &pcie_100_no_ssc_cmn_vals,
3212 [EXTERNAL_SSC] = &pcie_100_no_ssc_cmn_vals,
3213 [INTERNAL_SSC] = &pcie_100_int_ssc_cmn_vals,
3214 },
3215 [TYPE_USB] = {
3216 [NO_SSC] = &pcie_100_no_ssc_cmn_vals,
3217 [EXTERNAL_SSC] = &pcie_100_no_ssc_cmn_vals,
3218 [INTERNAL_SSC] = &pcie_100_int_ssc_cmn_vals,
3219 },
3220 },
3221 [TYPE_SGMII] = {
3222 [TYPE_NONE] = {
3223 [NO_SSC] = &sgmii_100_no_ssc_cmn_vals,
3224 },
3225 [TYPE_PCIE] = {
3226 [NO_SSC] = &sgmii_100_no_ssc_cmn_vals,
3227 [EXTERNAL_SSC] = &sgmii_100_no_ssc_cmn_vals,
3228 [INTERNAL_SSC] = &sgmii_100_int_ssc_cmn_vals,
3229 },
3230 [TYPE_USB] = {
3231 [NO_SSC] = &sgmii_100_no_ssc_cmn_vals,
3232 [EXTERNAL_SSC] = &sgmii_100_no_ssc_cmn_vals,
3233 [INTERNAL_SSC] = &sgmii_100_no_ssc_cmn_vals,
3234 },
3235 },
3236 [TYPE_QSGMII] = {
3237 [TYPE_NONE] = {
3238 [NO_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3239 },
3240 [TYPE_PCIE] = {
3241 [NO_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3242 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3243 [INTERNAL_SSC] = &qsgmii_100_int_ssc_cmn_vals,
3244 },
3245 [TYPE_USB] = {
3246 [NO_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3247 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3248 [INTERNAL_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3249 },
3250 },
3251 [TYPE_USB] = {
3252 [TYPE_NONE] = {
3253 [NO_SSC] = &usb_100_no_ssc_cmn_vals,
3254 [EXTERNAL_SSC] = &usb_100_no_ssc_cmn_vals,
3255 [INTERNAL_SSC] = &sl_usb_100_int_ssc_cmn_vals,
3256 },
3257 [TYPE_PCIE] = {
3258 [NO_SSC] = &usb_100_no_ssc_cmn_vals,
3259 [EXTERNAL_SSC] = &usb_100_no_ssc_cmn_vals,
3260 [INTERNAL_SSC] = &usb_100_int_ssc_cmn_vals,
3261 },
3262 [TYPE_SGMII] = {
3263 [NO_SSC] = &usb_100_no_ssc_cmn_vals,
3264 [EXTERNAL_SSC] = &usb_100_no_ssc_cmn_vals,
3265 [INTERNAL_SSC] = &sl_usb_100_int_ssc_cmn_vals,
3266 },
3267 [TYPE_QSGMII] = {
3268 [NO_SSC] = &usb_100_no_ssc_cmn_vals,
3269 [EXTERNAL_SSC] = &usb_100_no_ssc_cmn_vals,
3270 [INTERNAL_SSC] = &sl_usb_100_int_ssc_cmn_vals,
3271 },
3272 },
3273 },
3274 .tx_ln_vals = {
3275 [TYPE_PCIE] = {
3276 [TYPE_NONE] = {
3277 [NO_SSC] = NULL,
3278 [EXTERNAL_SSC] = NULL,
3279 [INTERNAL_SSC] = NULL,
3280 },
3281 [TYPE_SGMII] = {
3282 [NO_SSC] = NULL,
3283 [EXTERNAL_SSC] = NULL,
3284 [INTERNAL_SSC] = NULL,
3285 },
3286 [TYPE_QSGMII] = {
3287 [NO_SSC] = NULL,
3288 [EXTERNAL_SSC] = NULL,
3289 [INTERNAL_SSC] = NULL,
3290 },
3291 [TYPE_USB] = {
3292 [NO_SSC] = NULL,
3293 [EXTERNAL_SSC] = NULL,
3294 [INTERNAL_SSC] = NULL,
3295 },
3296 },
3297 [TYPE_SGMII] = {
3298 [TYPE_NONE] = {
3299 [NO_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3300 },
3301 [TYPE_PCIE] = {
3302 [NO_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3303 [EXTERNAL_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3304 [INTERNAL_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3305 },
3306 [TYPE_USB] = {
3307 [NO_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3308 [EXTERNAL_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3309 [INTERNAL_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3310 },
3311 },
3312 [TYPE_QSGMII] = {
3313 [TYPE_NONE] = {
3314 [NO_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3315 },
3316 [TYPE_PCIE] = {
3317 [NO_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3318 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3319 [INTERNAL_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3320 },
3321 [TYPE_USB] = {
3322 [NO_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3323 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3324 [INTERNAL_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3325 },
3326 },
3327 [TYPE_USB] = {
3328 [TYPE_NONE] = {
3329 [NO_SSC] = &usb_100_no_ssc_tx_ln_vals,
3330 [EXTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3331 [INTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3332 },
3333 [TYPE_PCIE] = {
3334 [NO_SSC] = &usb_100_no_ssc_tx_ln_vals,
3335 [EXTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3336 [INTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3337 },
3338 [TYPE_SGMII] = {
3339 [NO_SSC] = &usb_100_no_ssc_tx_ln_vals,
3340 [EXTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3341 [INTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3342 },
3343 [TYPE_QSGMII] = {
3344 [NO_SSC] = &usb_100_no_ssc_tx_ln_vals,
3345 [EXTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3346 [INTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3347 },
3348 },
3349 },
3350 .rx_ln_vals = {
3351 [TYPE_PCIE] = {
3352 [TYPE_NONE] = {
3353 [NO_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3354 [EXTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3355 [INTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3356 },
3357 [TYPE_SGMII] = {
3358 [NO_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3359 [EXTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3360 [INTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3361 },
3362 [TYPE_QSGMII] = {
3363 [NO_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3364 [EXTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3365 [INTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3366 },
3367 [TYPE_USB] = {
3368 [NO_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3369 [EXTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3370 [INTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3371 },
3372 },
3373 [TYPE_SGMII] = {
3374 [TYPE_NONE] = {
3375 [NO_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3376 },
3377 [TYPE_PCIE] = {
3378 [NO_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3379 [EXTERNAL_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3380 [INTERNAL_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3381 },
3382 [TYPE_USB] = {
3383 [NO_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3384 [EXTERNAL_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3385 [INTERNAL_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3386 },
3387 },
3388 [TYPE_QSGMII] = {
3389 [TYPE_NONE] = {
3390 [NO_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3391 },
3392 [TYPE_PCIE] = {
3393 [NO_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3394 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3395 [INTERNAL_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3396 },
3397 [TYPE_USB] = {
3398 [NO_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3399 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3400 [INTERNAL_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3401 },
3402 },
3403 [TYPE_USB] = {
3404 [TYPE_NONE] = {
3405 [NO_SSC] = &usb_100_no_ssc_rx_ln_vals,
3406 [EXTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3407 [INTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3408 },
3409 [TYPE_PCIE] = {
3410 [NO_SSC] = &usb_100_no_ssc_rx_ln_vals,
3411 [EXTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3412 [INTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3413 },
3414 [TYPE_SGMII] = {
3415 [NO_SSC] = &usb_100_no_ssc_rx_ln_vals,
3416 [EXTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3417 [INTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3418 },
3419 [TYPE_QSGMII] = {
3420 [NO_SSC] = &usb_100_no_ssc_rx_ln_vals,
3421 [EXTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3422 [INTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3423 },
3424 },
3425 },
3426 };
3427
3428 static const struct cdns_torrent_data ti_j721e_map_torrent = {
3429 .block_offset_shift = 0x0,
3430 .reg_offset_shift = 0x1,
3431 .link_cmn_vals = {
3432 [TYPE_PCIE] = {
3433 [TYPE_NONE] = {
3434 [NO_SSC] = NULL,
3435 [EXTERNAL_SSC] = NULL,
3436 [INTERNAL_SSC] = NULL,
3437 },
3438 [TYPE_SGMII] = {
3439 [NO_SSC] = &pcie_sgmii_link_cmn_vals,
3440 [EXTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3441 [INTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3442 },
3443 [TYPE_QSGMII] = {
3444 [NO_SSC] = &pcie_sgmii_link_cmn_vals,
3445 [EXTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3446 [INTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3447 },
3448 [TYPE_USB] = {
3449 [NO_SSC] = &pcie_usb_link_cmn_vals,
3450 [EXTERNAL_SSC] = &pcie_usb_link_cmn_vals,
3451 [INTERNAL_SSC] = &pcie_usb_link_cmn_vals,
3452 },
3453 },
3454 [TYPE_SGMII] = {
3455 [TYPE_NONE] = {
3456 [NO_SSC] = &sl_sgmii_link_cmn_vals,
3457 },
3458 [TYPE_PCIE] = {
3459 [NO_SSC] = &pcie_sgmii_link_cmn_vals,
3460 [EXTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3461 [INTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3462 },
3463 [TYPE_USB] = {
3464 [NO_SSC] = &usb_sgmii_link_cmn_vals,
3465 [EXTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3466 [INTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3467 },
3468 },
3469 [TYPE_QSGMII] = {
3470 [TYPE_NONE] = {
3471 [NO_SSC] = &sl_sgmii_link_cmn_vals,
3472 },
3473 [TYPE_PCIE] = {
3474 [NO_SSC] = &pcie_sgmii_link_cmn_vals,
3475 [EXTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3476 [INTERNAL_SSC] = &pcie_sgmii_link_cmn_vals,
3477 },
3478 [TYPE_USB] = {
3479 [NO_SSC] = &usb_sgmii_link_cmn_vals,
3480 [EXTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3481 [INTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3482 },
3483 },
3484 [TYPE_USB] = {
3485 [TYPE_NONE] = {
3486 [NO_SSC] = &sl_usb_link_cmn_vals,
3487 [EXTERNAL_SSC] = &sl_usb_link_cmn_vals,
3488 [INTERNAL_SSC] = &sl_usb_link_cmn_vals,
3489 },
3490 [TYPE_PCIE] = {
3491 [NO_SSC] = &pcie_usb_link_cmn_vals,
3492 [EXTERNAL_SSC] = &pcie_usb_link_cmn_vals,
3493 [INTERNAL_SSC] = &pcie_usb_link_cmn_vals,
3494 },
3495 [TYPE_SGMII] = {
3496 [NO_SSC] = &usb_sgmii_link_cmn_vals,
3497 [EXTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3498 [INTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3499 },
3500 [TYPE_QSGMII] = {
3501 [NO_SSC] = &usb_sgmii_link_cmn_vals,
3502 [EXTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3503 [INTERNAL_SSC] = &usb_sgmii_link_cmn_vals,
3504 },
3505 },
3506 },
3507 .xcvr_diag_vals = {
3508 [TYPE_PCIE] = {
3509 [TYPE_NONE] = {
3510 [NO_SSC] = NULL,
3511 [EXTERNAL_SSC] = NULL,
3512 [INTERNAL_SSC] = NULL,
3513 },
3514 [TYPE_SGMII] = {
3515 [NO_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3516 [EXTERNAL_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3517 [INTERNAL_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3518 },
3519 [TYPE_QSGMII] = {
3520 [NO_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3521 [EXTERNAL_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3522 [INTERNAL_SSC] = &pcie_sgmii_xcvr_diag_ln_vals,
3523 },
3524 [TYPE_USB] = {
3525 [NO_SSC] = &pcie_usb_xcvr_diag_ln_vals,
3526 [EXTERNAL_SSC] = &pcie_usb_xcvr_diag_ln_vals,
3527 [INTERNAL_SSC] = &pcie_usb_xcvr_diag_ln_vals,
3528 },
3529 },
3530 [TYPE_SGMII] = {
3531 [TYPE_NONE] = {
3532 [NO_SSC] = &sl_sgmii_xcvr_diag_ln_vals,
3533 },
3534 [TYPE_PCIE] = {
3535 [NO_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3536 [EXTERNAL_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3537 [INTERNAL_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3538 },
3539 [TYPE_USB] = {
3540 [NO_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3541 [EXTERNAL_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3542 [INTERNAL_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3543 },
3544 },
3545 [TYPE_QSGMII] = {
3546 [TYPE_NONE] = {
3547 [NO_SSC] = &sl_sgmii_xcvr_diag_ln_vals,
3548 },
3549 [TYPE_PCIE] = {
3550 [NO_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3551 [EXTERNAL_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3552 [INTERNAL_SSC] = &sgmii_pcie_xcvr_diag_ln_vals,
3553 },
3554 [TYPE_USB] = {
3555 [NO_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3556 [EXTERNAL_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3557 [INTERNAL_SSC] = &sgmii_usb_xcvr_diag_ln_vals,
3558 },
3559 },
3560 [TYPE_USB] = {
3561 [TYPE_NONE] = {
3562 [NO_SSC] = &sl_usb_xcvr_diag_ln_vals,
3563 [EXTERNAL_SSC] = &sl_usb_xcvr_diag_ln_vals,
3564 [INTERNAL_SSC] = &sl_usb_xcvr_diag_ln_vals,
3565 },
3566 [TYPE_PCIE] = {
3567 [NO_SSC] = &usb_pcie_xcvr_diag_ln_vals,
3568 [EXTERNAL_SSC] = &usb_pcie_xcvr_diag_ln_vals,
3569 [INTERNAL_SSC] = &usb_pcie_xcvr_diag_ln_vals,
3570 },
3571 [TYPE_SGMII] = {
3572 [NO_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3573 [EXTERNAL_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3574 [INTERNAL_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3575 },
3576 [TYPE_QSGMII] = {
3577 [NO_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3578 [EXTERNAL_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3579 [INTERNAL_SSC] = &usb_sgmii_xcvr_diag_ln_vals,
3580 },
3581 },
3582 },
3583 .pcs_cmn_vals = {
3584 [TYPE_USB] = {
3585 [TYPE_NONE] = {
3586 [NO_SSC] = &usb_phy_pcs_cmn_vals,
3587 [EXTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3588 [INTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3589 },
3590 [TYPE_PCIE] = {
3591 [NO_SSC] = &usb_phy_pcs_cmn_vals,
3592 [EXTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3593 [INTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3594 },
3595 [TYPE_SGMII] = {
3596 [NO_SSC] = &usb_phy_pcs_cmn_vals,
3597 [EXTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3598 [INTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3599 },
3600 [TYPE_QSGMII] = {
3601 [NO_SSC] = &usb_phy_pcs_cmn_vals,
3602 [EXTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3603 [INTERNAL_SSC] = &usb_phy_pcs_cmn_vals,
3604 },
3605 },
3606 },
3607 .cmn_vals = {
3608 [TYPE_PCIE] = {
3609 [TYPE_NONE] = {
3610 [NO_SSC] = &pcie_100_no_ssc_cmn_vals,
3611 [EXTERNAL_SSC] = &pcie_100_no_ssc_cmn_vals,
3612 [INTERNAL_SSC] = &sl_pcie_100_int_ssc_cmn_vals,
3613 },
3614 [TYPE_SGMII] = {
3615 [NO_SSC] = &pcie_100_no_ssc_cmn_vals,
3616 [EXTERNAL_SSC] = &pcie_100_no_ssc_cmn_vals,
3617 [INTERNAL_SSC] = &pcie_100_int_ssc_cmn_vals,
3618 },
3619 [TYPE_QSGMII] = {
3620 [NO_SSC] = &pcie_100_no_ssc_cmn_vals,
3621 [EXTERNAL_SSC] = &pcie_100_no_ssc_cmn_vals,
3622 [INTERNAL_SSC] = &pcie_100_int_ssc_cmn_vals,
3623 },
3624 [TYPE_USB] = {
3625 [NO_SSC] = &pcie_100_no_ssc_cmn_vals,
3626 [EXTERNAL_SSC] = &pcie_100_no_ssc_cmn_vals,
3627 [INTERNAL_SSC] = &pcie_100_int_ssc_cmn_vals,
3628 },
3629 },
3630 [TYPE_SGMII] = {
3631 [TYPE_NONE] = {
3632 [NO_SSC] = &sgmii_100_no_ssc_cmn_vals,
3633 },
3634 [TYPE_PCIE] = {
3635 [NO_SSC] = &sgmii_100_no_ssc_cmn_vals,
3636 [EXTERNAL_SSC] = &sgmii_100_no_ssc_cmn_vals,
3637 [INTERNAL_SSC] = &sgmii_100_int_ssc_cmn_vals,
3638 },
3639 [TYPE_USB] = {
3640 [NO_SSC] = &sgmii_100_no_ssc_cmn_vals,
3641 [EXTERNAL_SSC] = &sgmii_100_no_ssc_cmn_vals,
3642 [INTERNAL_SSC] = &sgmii_100_no_ssc_cmn_vals,
3643 },
3644 },
3645 [TYPE_QSGMII] = {
3646 [TYPE_NONE] = {
3647 [NO_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3648 },
3649 [TYPE_PCIE] = {
3650 [NO_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3651 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3652 [INTERNAL_SSC] = &qsgmii_100_int_ssc_cmn_vals,
3653 },
3654 [TYPE_USB] = {
3655 [NO_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3656 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3657 [INTERNAL_SSC] = &qsgmii_100_no_ssc_cmn_vals,
3658 },
3659 },
3660 [TYPE_USB] = {
3661 [TYPE_NONE] = {
3662 [NO_SSC] = &usb_100_no_ssc_cmn_vals,
3663 [EXTERNAL_SSC] = &usb_100_no_ssc_cmn_vals,
3664 [INTERNAL_SSC] = &sl_usb_100_int_ssc_cmn_vals,
3665 },
3666 [TYPE_PCIE] = {
3667 [NO_SSC] = &usb_100_no_ssc_cmn_vals,
3668 [EXTERNAL_SSC] = &usb_100_no_ssc_cmn_vals,
3669 [INTERNAL_SSC] = &usb_100_int_ssc_cmn_vals,
3670 },
3671 [TYPE_SGMII] = {
3672 [NO_SSC] = &usb_100_no_ssc_cmn_vals,
3673 [EXTERNAL_SSC] = &usb_100_no_ssc_cmn_vals,
3674 [INTERNAL_SSC] = &sl_usb_100_int_ssc_cmn_vals,
3675 },
3676 [TYPE_QSGMII] = {
3677 [NO_SSC] = &usb_100_no_ssc_cmn_vals,
3678 [EXTERNAL_SSC] = &usb_100_no_ssc_cmn_vals,
3679 [INTERNAL_SSC] = &sl_usb_100_int_ssc_cmn_vals,
3680 },
3681 },
3682 },
3683 .tx_ln_vals = {
3684 [TYPE_PCIE] = {
3685 [TYPE_NONE] = {
3686 [NO_SSC] = NULL,
3687 [EXTERNAL_SSC] = NULL,
3688 [INTERNAL_SSC] = NULL,
3689 },
3690 [TYPE_SGMII] = {
3691 [NO_SSC] = NULL,
3692 [EXTERNAL_SSC] = NULL,
3693 [INTERNAL_SSC] = NULL,
3694 },
3695 [TYPE_QSGMII] = {
3696 [NO_SSC] = NULL,
3697 [EXTERNAL_SSC] = NULL,
3698 [INTERNAL_SSC] = NULL,
3699 },
3700 [TYPE_USB] = {
3701 [NO_SSC] = NULL,
3702 [EXTERNAL_SSC] = NULL,
3703 [INTERNAL_SSC] = NULL,
3704 },
3705 },
3706 [TYPE_SGMII] = {
3707 [TYPE_NONE] = {
3708 [NO_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3709 },
3710 [TYPE_PCIE] = {
3711 [NO_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3712 [EXTERNAL_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3713 [INTERNAL_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3714 },
3715 [TYPE_USB] = {
3716 [NO_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3717 [EXTERNAL_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3718 [INTERNAL_SSC] = &sgmii_100_no_ssc_tx_ln_vals,
3719 },
3720 },
3721 [TYPE_QSGMII] = {
3722 [TYPE_NONE] = {
3723 [NO_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3724 },
3725 [TYPE_PCIE] = {
3726 [NO_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3727 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3728 [INTERNAL_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3729 },
3730 [TYPE_USB] = {
3731 [NO_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3732 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3733 [INTERNAL_SSC] = &qsgmii_100_no_ssc_tx_ln_vals,
3734 },
3735 },
3736 [TYPE_USB] = {
3737 [TYPE_NONE] = {
3738 [NO_SSC] = &usb_100_no_ssc_tx_ln_vals,
3739 [EXTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3740 [INTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3741 },
3742 [TYPE_PCIE] = {
3743 [NO_SSC] = &usb_100_no_ssc_tx_ln_vals,
3744 [EXTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3745 [INTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3746 },
3747 [TYPE_SGMII] = {
3748 [NO_SSC] = &usb_100_no_ssc_tx_ln_vals,
3749 [EXTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3750 [INTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3751 },
3752 [TYPE_QSGMII] = {
3753 [NO_SSC] = &usb_100_no_ssc_tx_ln_vals,
3754 [EXTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3755 [INTERNAL_SSC] = &usb_100_no_ssc_tx_ln_vals,
3756 },
3757 },
3758 },
3759 .rx_ln_vals = {
3760 [TYPE_PCIE] = {
3761 [TYPE_NONE] = {
3762 [NO_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3763 [EXTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3764 [INTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3765 },
3766 [TYPE_SGMII] = {
3767 [NO_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3768 [EXTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3769 [INTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3770 },
3771 [TYPE_QSGMII] = {
3772 [NO_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3773 [EXTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3774 [INTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3775 },
3776 [TYPE_USB] = {
3777 [NO_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3778 [EXTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3779 [INTERNAL_SSC] = &pcie_100_no_ssc_rx_ln_vals,
3780 },
3781 },
3782 [TYPE_SGMII] = {
3783 [TYPE_NONE] = {
3784 [NO_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3785 },
3786 [TYPE_PCIE] = {
3787 [NO_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3788 [EXTERNAL_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3789 [INTERNAL_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3790 },
3791 [TYPE_USB] = {
3792 [NO_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3793 [EXTERNAL_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3794 [INTERNAL_SSC] = &sgmii_100_no_ssc_rx_ln_vals,
3795 },
3796 },
3797 [TYPE_QSGMII] = {
3798 [TYPE_NONE] = {
3799 [NO_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3800 },
3801 [TYPE_PCIE] = {
3802 [NO_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3803 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3804 [INTERNAL_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3805 },
3806 [TYPE_USB] = {
3807 [NO_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3808 [EXTERNAL_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3809 [INTERNAL_SSC] = &qsgmii_100_no_ssc_rx_ln_vals,
3810 },
3811 },
3812 [TYPE_USB] = {
3813 [TYPE_NONE] = {
3814 [NO_SSC] = &usb_100_no_ssc_rx_ln_vals,
3815 [EXTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3816 [INTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3817 },
3818 [TYPE_PCIE] = {
3819 [NO_SSC] = &usb_100_no_ssc_rx_ln_vals,
3820 [EXTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3821 [INTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3822 },
3823 [TYPE_SGMII] = {
3824 [NO_SSC] = &usb_100_no_ssc_rx_ln_vals,
3825 [EXTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3826 [INTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3827 },
3828 [TYPE_QSGMII] = {
3829 [NO_SSC] = &usb_100_no_ssc_rx_ln_vals,
3830 [EXTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3831 [INTERNAL_SSC] = &usb_100_no_ssc_rx_ln_vals,
3832 },
3833 },
3834 },
3835 };
3836
3837 static const struct of_device_id cdns_torrent_phy_of_match[] = {
3838 {
3839 .compatible = "cdns,torrent-phy",
3840 .data = &cdns_map_torrent,
3841 },
3842 {
3843 .compatible = "ti,j721e-serdes-10g",
3844 .data = &ti_j721e_map_torrent,
3845 },
3846 {}
3847 };
3848 MODULE_DEVICE_TABLE(of, cdns_torrent_phy_of_match);
3849
3850 static struct platform_driver cdns_torrent_phy_driver = {
3851 .probe = cdns_torrent_phy_probe,
3852 .remove = cdns_torrent_phy_remove,
3853 .driver = {
3854 .name = "cdns-torrent-phy",
3855 .of_match_table = cdns_torrent_phy_of_match,
3856 }
3857 };
3858 module_platform_driver(cdns_torrent_phy_driver);
3859
3860 MODULE_AUTHOR("Cadence Design Systems, Inc.");
3861 MODULE_DESCRIPTION("Cadence Torrent PHY driver");
3862 MODULE_LICENSE("GPL v2");
3863