1 // SPDX-License-Identifier: GPL-2.0-only
3 * Cadence Torrent SD0801 PHY driver.
5 * Copyright 2018 Cadence Design Systems, Inc.
9 #include <dt-bindings/phy/phy.h>
10 #include <dt-bindings/phy/phy-cadence.h>
11 #include <linux/clk.h>
12 #include <linux/clk-provider.h>
13 #include <linux/delay.h>
14 #include <linux/err.h>
16 #include <linux/iopoll.h>
17 #include <linux/kernel.h>
18 #include <linux/module.h>
20 #include <linux/phy/phy.h>
21 #include <linux/platform_device.h>
22 #include <linux/reset.h>
23 #include <linux/regmap.h>
25 #define REF_CLK_19_2MHZ 19200000
26 #define REF_CLK_25MHZ 25000000
27 #define REF_CLK_100MHZ 100000000
28 #define REF_CLK_156_25MHZ 156250000
30 #define MAX_NUM_LANES 4
31 #define DEFAULT_MAX_BIT_RATE 8100 /* in Mbps */
33 #define POLL_TIMEOUT_US 5000
34 #define PLL_LOCK_TIMEOUT 100000
36 #define DP_PLL0 BIT(0)
37 #define DP_PLL1 BIT(1)
39 #define TORRENT_COMMON_CDB_OFFSET 0x0
41 #define TORRENT_TX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \
42 ((0x4000 << (block_offset)) + \
43 (((ln) << 9) << (reg_offset)))
45 #define TORRENT_RX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \
46 ((0x8000 << (block_offset)) + \
47 (((ln) << 9) << (reg_offset)))
49 #define TORRENT_PHY_PCS_COMMON_OFFSET(block_offset) \
50 (0xC000 << (block_offset))
52 #define TORRENT_PHY_PCS_LANE_CDB_OFFSET(ln, block_offset, reg_offset) \
53 ((0xD000 << (block_offset)) + \
54 (((ln) << 8) << (reg_offset)))
56 #define TORRENT_PHY_PMA_COMMON_OFFSET(block_offset) \
57 (0xE000 << (block_offset))
59 #define TORRENT_DPTX_PHY_OFFSET 0x0
62 * register offsets from DPTX PHY register block base (i.e MHDP
63 * register base + 0x30a00)
65 #define PHY_AUX_CTRL 0x04
66 #define PHY_RESET 0x20
67 #define PMA_TX_ELEC_IDLE_SHIFT 4
68 #define PHY_PMA_XCVR_PLLCLK_EN 0x24
69 #define PHY_PMA_XCVR_PLLCLK_EN_ACK 0x28
70 #define PHY_PMA_XCVR_POWER_STATE_REQ 0x2c
71 #define PHY_POWER_STATE_LN(ln) ((ln) * 8)
72 #define PMA_XCVR_POWER_STATE_REQ_LN_MASK 0x3FU
73 #define PHY_PMA_XCVR_POWER_STATE_ACK 0x30
74 #define PHY_PMA_CMN_READY 0x34
77 * register offsets from SD0801 PHY register block base (i.e MHDP
78 * register base + 0x500000)
80 #define CMN_SSM_BANDGAP_TMR 0x0021U
81 #define CMN_SSM_BIAS_TMR 0x0022U
82 #define CMN_PLLSM0_PLLPRE_TMR 0x002AU
83 #define CMN_PLLSM0_PLLLOCK_TMR 0x002CU
84 #define CMN_PLLSM1_PLLPRE_TMR 0x0032U
85 #define CMN_PLLSM1_PLLLOCK_TMR 0x0034U
86 #define CMN_CDIAG_CDB_PWRI_OVRD 0x0041U
87 #define CMN_CDIAG_XCVRC_PWRI_OVRD 0x0047U
88 #define CMN_CDIAG_REFCLK_OVRD 0x004CU
89 #define CMN_CDIAG_REFCLK_DRV0_CTRL 0x0050U
90 #define CMN_BGCAL_INIT_TMR 0x0064U
91 #define CMN_BGCAL_ITER_TMR 0x0065U
92 #define CMN_IBCAL_INIT_TMR 0x0074U
93 #define CMN_PLL0_VCOCAL_TCTRL 0x0082U
94 #define CMN_PLL0_VCOCAL_INIT_TMR 0x0084U
95 #define CMN_PLL0_VCOCAL_ITER_TMR 0x0085U
96 #define CMN_PLL0_VCOCAL_REFTIM_START 0x0086U
97 #define CMN_PLL0_VCOCAL_PLLCNT_START 0x0088U
98 #define CMN_PLL0_INTDIV_M0 0x0090U
99 #define CMN_PLL0_FRACDIVL_M0 0x0091U
100 #define CMN_PLL0_FRACDIVH_M0 0x0092U
101 #define CMN_PLL0_HIGH_THR_M0 0x0093U
102 #define CMN_PLL0_DSM_DIAG_M0 0x0094U
103 #define CMN_PLL0_DSM_FBH_OVRD_M0 0x0095U
104 #define CMN_PLL0_DSM_FBL_OVRD_M0 0x0096U
105 #define CMN_PLL0_SS_CTRL1_M0 0x0098U
106 #define CMN_PLL0_SS_CTRL2_M0 0x0099U
107 #define CMN_PLL0_SS_CTRL3_M0 0x009AU
108 #define CMN_PLL0_SS_CTRL4_M0 0x009BU
109 #define CMN_PLL0_LOCK_REFCNT_START 0x009CU
110 #define CMN_PLL0_LOCK_PLLCNT_START 0x009EU
111 #define CMN_PLL0_LOCK_PLLCNT_THR 0x009FU
112 #define CMN_PLL0_INTDIV_M1 0x00A0U
113 #define CMN_PLL0_FRACDIVH_M1 0x00A2U
114 #define CMN_PLL0_HIGH_THR_M1 0x00A3U
115 #define CMN_PLL0_DSM_DIAG_M1 0x00A4U
116 #define CMN_PLL0_SS_CTRL1_M1 0x00A8U
117 #define CMN_PLL0_SS_CTRL2_M1 0x00A9U
118 #define CMN_PLL0_SS_CTRL3_M1 0x00AAU
119 #define CMN_PLL0_SS_CTRL4_M1 0x00ABU
120 #define CMN_PLL1_VCOCAL_TCTRL 0x00C2U
121 #define CMN_PLL1_VCOCAL_INIT_TMR 0x00C4U
122 #define CMN_PLL1_VCOCAL_ITER_TMR 0x00C5U
123 #define CMN_PLL1_VCOCAL_REFTIM_START 0x00C6U
124 #define CMN_PLL1_VCOCAL_PLLCNT_START 0x00C8U
125 #define CMN_PLL1_INTDIV_M0 0x00D0U
126 #define CMN_PLL1_FRACDIVL_M0 0x00D1U
127 #define CMN_PLL1_FRACDIVH_M0 0x00D2U
128 #define CMN_PLL1_HIGH_THR_M0 0x00D3U
129 #define CMN_PLL1_DSM_DIAG_M0 0x00D4U
130 #define CMN_PLL1_DSM_FBH_OVRD_M0 0x00D5U
131 #define CMN_PLL1_DSM_FBL_OVRD_M0 0x00D6U
132 #define CMN_PLL1_SS_CTRL1_M0 0x00D8U
133 #define CMN_PLL1_SS_CTRL2_M0 0x00D9U
134 #define CMN_PLL1_SS_CTRL3_M0 0x00DAU
135 #define CMN_PLL1_SS_CTRL4_M0 0x00DBU
136 #define CMN_PLL1_LOCK_REFCNT_START 0x00DCU
137 #define CMN_PLL1_LOCK_PLLCNT_START 0x00DEU
138 #define CMN_PLL1_LOCK_PLLCNT_THR 0x00DFU
139 #define CMN_TXPUCAL_TUNE 0x0103U
140 #define CMN_TXPUCAL_INIT_TMR 0x0104U
141 #define CMN_TXPUCAL_ITER_TMR 0x0105U
142 #define CMN_TXPDCAL_TUNE 0x010BU
143 #define CMN_TXPDCAL_INIT_TMR 0x010CU
144 #define CMN_TXPDCAL_ITER_TMR 0x010DU
145 #define CMN_RXCAL_INIT_TMR 0x0114U
146 #define CMN_RXCAL_ITER_TMR 0x0115U
147 #define CMN_SD_CAL_INIT_TMR 0x0124U
148 #define CMN_SD_CAL_ITER_TMR 0x0125U
149 #define CMN_SD_CAL_REFTIM_START 0x0126U
150 #define CMN_SD_CAL_PLLCNT_START 0x0128U
151 #define CMN_PDIAG_PLL0_CTRL_M0 0x01A0U
152 #define CMN_PDIAG_PLL0_CLK_SEL_M0 0x01A1U
153 #define CMN_PDIAG_PLL0_CP_PADJ_M0 0x01A4U
154 #define CMN_PDIAG_PLL0_CP_IADJ_M0 0x01A5U
155 #define CMN_PDIAG_PLL0_FILT_PADJ_M0 0x01A6U
156 #define CMN_PDIAG_PLL0_CTRL_M1 0x01B0U
157 #define CMN_PDIAG_PLL0_CLK_SEL_M1 0x01B1U
158 #define CMN_PDIAG_PLL0_CP_PADJ_M1 0x01B4U
159 #define CMN_PDIAG_PLL0_CP_IADJ_M1 0x01B5U
160 #define CMN_PDIAG_PLL0_FILT_PADJ_M1 0x01B6U
161 #define CMN_PDIAG_PLL1_CTRL_M0 0x01C0U
162 #define CMN_PDIAG_PLL1_CLK_SEL_M0 0x01C1U
163 #define CMN_PDIAG_PLL1_CP_PADJ_M0 0x01C4U
164 #define CMN_PDIAG_PLL1_CP_IADJ_M0 0x01C5U
165 #define CMN_PDIAG_PLL1_FILT_PADJ_M0 0x01C6U
166 #define CMN_DIAG_BIAS_OVRD1 0x01E1U
168 /* PMA TX Lane registers */
169 #define TX_TXCC_CTRL 0x0040U
170 #define TX_TXCC_CPOST_MULT_00 0x004CU
171 #define TX_TXCC_CPOST_MULT_01 0x004DU
172 #define TX_TXCC_MGNFS_MULT_000 0x0050U
173 #define TX_TXCC_MGNFS_MULT_100 0x0054U
174 #define DRV_DIAG_TX_DRV 0x00C6U
175 #define XCVR_DIAG_PLLDRC_CTRL 0x00E5U
176 #define XCVR_DIAG_HSCLK_SEL 0x00E6U
177 #define XCVR_DIAG_HSCLK_DIV 0x00E7U
178 #define XCVR_DIAG_RXCLK_CTRL 0x00E9U
179 #define XCVR_DIAG_BIDI_CTRL 0x00EAU
180 #define XCVR_DIAG_PSC_OVRD 0x00EBU
181 #define TX_PSC_A0 0x0100U
182 #define TX_PSC_A1 0x0101U
183 #define TX_PSC_A2 0x0102U
184 #define TX_PSC_A3 0x0103U
185 #define TX_RCVDET_ST_TMR 0x0123U
186 #define TX_DIAG_ACYA 0x01E7U
187 #define TX_DIAG_ACYA_HBDC_MASK 0x0001U
189 /* PMA RX Lane registers */
190 #define RX_PSC_A0 0x0000U
191 #define RX_PSC_A1 0x0001U
192 #define RX_PSC_A2 0x0002U
193 #define RX_PSC_A3 0x0003U
194 #define RX_PSC_CAL 0x0006U
195 #define RX_SDCAL0_INIT_TMR 0x0044U
196 #define RX_SDCAL0_ITER_TMR 0x0045U
197 #define RX_SDCAL1_INIT_TMR 0x004CU
198 #define RX_SDCAL1_ITER_TMR 0x004DU
199 #define RX_CDRLF_CNFG 0x0080U
200 #define RX_CDRLF_CNFG3 0x0082U
201 #define RX_SIGDET_HL_FILT_TMR 0x0090U
202 #define RX_REE_GCSM1_CTRL 0x0108U
203 #define RX_REE_GCSM1_EQENM_PH1 0x0109U
204 #define RX_REE_GCSM1_EQENM_PH2 0x010AU
205 #define RX_REE_GCSM2_CTRL 0x0110U
206 #define RX_REE_PERGCSM_CTRL 0x0118U
207 #define RX_REE_ATTEN_THR 0x0149U
208 #define RX_REE_TAP1_CLIP 0x0171U
209 #define RX_REE_TAP2TON_CLIP 0x0172U
210 #define RX_REE_SMGM_CTRL1 0x0177U
211 #define RX_REE_SMGM_CTRL2 0x0178U
212 #define RX_DIAG_DFE_CTRL 0x01E0U
213 #define RX_DIAG_DFE_AMP_TUNE_2 0x01E2U
214 #define RX_DIAG_DFE_AMP_TUNE_3 0x01E3U
215 #define RX_DIAG_NQST_CTRL 0x01E5U
216 #define RX_DIAG_SIGDET_TUNE 0x01E8U
217 #define RX_DIAG_PI_RATE 0x01F4U
218 #define RX_DIAG_PI_CAP 0x01F5U
219 #define RX_DIAG_ACYA 0x01FFU
221 /* PHY PCS common registers */
222 #define PHY_PIPE_CMN_CTRL1 0x0000U
223 #define PHY_PLL_CFG 0x000EU
224 #define PHY_PIPE_USB3_GEN2_PRE_CFG0 0x0020U
225 #define PHY_PIPE_USB3_GEN2_POST_CFG0 0x0022U
226 #define PHY_PIPE_USB3_GEN2_POST_CFG1 0x0023U
228 /* PHY PCS lane registers */
229 #define PHY_PCS_ISO_LINK_CTRL 0x000BU
231 /* PHY PMA common registers */
232 #define PHY_PMA_CMN_CTRL1 0x0000U
233 #define PHY_PMA_CMN_CTRL2 0x0001U
234 #define PHY_PMA_PLL_RAW_CTRL 0x0003U
236 #define CDNS_TORRENT_OUTPUT_CLOCKS 3
238 static const char * const clk_names
[] = {
239 [CDNS_TORRENT_REFCLK_DRIVER
] = "refclk-driver",
240 [CDNS_TORRENT_DERIVED_REFCLK
] = "refclk-der",
241 [CDNS_TORRENT_RECEIVED_REFCLK
] = "refclk-rec",
244 static const struct reg_field phy_pll_cfg
=
245 REG_FIELD(PHY_PLL_CFG
, 0, 1);
247 static const struct reg_field phy_pma_cmn_ctrl_1
=
248 REG_FIELD(PHY_PMA_CMN_CTRL1
, 0, 0);
250 static const struct reg_field phy_pma_cmn_ctrl_2
=
251 REG_FIELD(PHY_PMA_CMN_CTRL2
, 0, 7);
253 static const struct reg_field phy_pma_pll_raw_ctrl
=
254 REG_FIELD(PHY_PMA_PLL_RAW_CTRL
, 0, 1);
256 static const struct reg_field phy_reset_ctrl
=
257 REG_FIELD(PHY_RESET
, 8, 8);
259 static const struct reg_field phy_pcs_iso_link_ctrl_1
=
260 REG_FIELD(PHY_PCS_ISO_LINK_CTRL
, 1, 1);
262 static const struct reg_field phy_pipe_cmn_ctrl1_0
= REG_FIELD(PHY_PIPE_CMN_CTRL1
, 0, 0);
264 static const struct reg_field cmn_cdiag_refclk_ovrd_4
=
265 REG_FIELD(CMN_CDIAG_REFCLK_OVRD
, 4, 4);
267 #define REFCLK_OUT_NUM_CMN_CONFIG 4
269 enum cdns_torrent_refclk_out_cmn
{
270 CMN_CDIAG_REFCLK_DRV0_CTRL_1
,
271 CMN_CDIAG_REFCLK_DRV0_CTRL_4
,
272 CMN_CDIAG_REFCLK_DRV0_CTRL_5
,
273 CMN_CDIAG_REFCLK_DRV0_CTRL_6
,
276 static const struct reg_field refclk_out_cmn_cfg
[] = {
277 [CMN_CDIAG_REFCLK_DRV0_CTRL_1
] = REG_FIELD(CMN_CDIAG_REFCLK_DRV0_CTRL
, 1, 1),
278 [CMN_CDIAG_REFCLK_DRV0_CTRL_4
] = REG_FIELD(CMN_CDIAG_REFCLK_DRV0_CTRL
, 4, 4),
279 [CMN_CDIAG_REFCLK_DRV0_CTRL_5
] = REG_FIELD(CMN_CDIAG_REFCLK_DRV0_CTRL
, 5, 5),
280 [CMN_CDIAG_REFCLK_DRV0_CTRL_6
] = REG_FIELD(CMN_CDIAG_REFCLK_DRV0_CTRL
, 6, 6),
283 static const int refclk_driver_parent_index
[] = {
284 CDNS_TORRENT_DERIVED_REFCLK
,
285 CDNS_TORRENT_RECEIVED_REFCLK
288 static const u32 cdns_torrent_refclk_driver_mux_table
[] = { 1, 0 };
290 enum cdns_torrent_phy_type
{
300 enum cdns_torrent_ref_clk
{
308 enum cdns_torrent_ssc_mode
{
315 /* Unique key id for vals table entry
316 * REFCLK0_RATE | REFCLK1_RATE | LINK0_TYPE | LINK1_TYPE | SSC_TYPE
318 #define REFCLK0_SHIFT 12
319 #define REFCLK0_MASK GENMASK(14, 12)
320 #define REFCLK1_SHIFT 9
321 #define REFCLK1_MASK GENMASK(11, 9)
322 #define LINK0_SHIFT 6
323 #define LINK0_MASK GENMASK(8, 6)
324 #define LINK1_SHIFT 3
325 #define LINK1_MASK GENMASK(5, 3)
327 #define SSC_MASK GENMASK(2, 0)
329 #define CDNS_TORRENT_KEY(refclk0, refclk1, link0, link1, ssc) \
330 ((((refclk0) << REFCLK0_SHIFT) & REFCLK0_MASK) | \
331 (((refclk1) << REFCLK1_SHIFT) & REFCLK1_MASK) | \
332 (((link0) << LINK0_SHIFT) & LINK0_MASK) | \
333 (((link1) << LINK1_SHIFT) & LINK1_MASK) | \
334 (((ssc) << SSC_SHIFT) & SSC_MASK))
336 #define CDNS_TORRENT_KEY_ANYCLK(link0, link1) \
337 CDNS_TORRENT_KEY(CLK_ANY, CLK_ANY, \
338 (link0), (link1), ANY_SSC)
340 struct cdns_torrent_inst
{
343 enum cdns_torrent_phy_type phy_type
;
345 struct reset_control
*lnk_rst
;
346 enum cdns_torrent_ssc_mode ssc_mode
;
349 struct cdns_torrent_phy
{
350 void __iomem
*base
; /* DPTX registers base */
351 void __iomem
*sd_base
; /* SD0801 registers base */
352 u32 max_bit_rate
; /* Maximum link bit rate to use (in Mbps) */
354 u32 protocol_bitmask
;
355 struct reset_control
*phy_rst
;
356 struct reset_control
*apb_rst
;
360 enum cdns_torrent_ref_clk ref_clk_rate
;
361 enum cdns_torrent_ref_clk ref_clk1_rate
;
362 struct cdns_torrent_inst phys
[MAX_NUM_LANES
];
364 int already_configured
;
365 const struct cdns_torrent_data
*init_data
;
366 struct regmap
*regmap_common_cdb
;
367 struct regmap
*regmap_phy_pcs_common_cdb
;
368 struct regmap
*regmap_phy_pma_common_cdb
;
369 struct regmap
*regmap_tx_lane_cdb
[MAX_NUM_LANES
];
370 struct regmap
*regmap_rx_lane_cdb
[MAX_NUM_LANES
];
371 struct regmap
*regmap_phy_pcs_lane_cdb
[MAX_NUM_LANES
];
372 struct regmap
*regmap_dptx_phy_reg
;
373 struct regmap_field
*phy_pll_cfg
;
374 struct regmap_field
*phy_pipe_cmn_ctrl1_0
;
375 struct regmap_field
*cmn_cdiag_refclk_ovrd_4
;
376 struct regmap_field
*phy_pma_cmn_ctrl_1
;
377 struct regmap_field
*phy_pma_cmn_ctrl_2
;
378 struct regmap_field
*phy_pma_pll_raw_ctrl
;
379 struct regmap_field
*phy_reset_ctrl
;
380 struct regmap_field
*phy_pcs_iso_link_ctrl_1
[MAX_NUM_LANES
];
381 struct clk_hw_onecell_data
*clk_hw_data
;
384 enum phy_powerstate
{
386 /* Powerstate A1 is unused */
391 struct cdns_torrent_refclk_driver
{
393 struct regmap_field
*cmn_fields
[REFCLK_OUT_NUM_CMN_CONFIG
];
394 struct clk_init_data clk_data
;
397 #define to_cdns_torrent_refclk_driver(_hw) \
398 container_of(_hw, struct cdns_torrent_refclk_driver, hw)
400 struct cdns_torrent_derived_refclk
{
402 struct regmap_field
*phy_pipe_cmn_ctrl1_0
;
403 struct regmap_field
*cmn_cdiag_refclk_ovrd_4
;
404 struct clk_init_data clk_data
;
407 #define to_cdns_torrent_derived_refclk(_hw) \
408 container_of(_hw, struct cdns_torrent_derived_refclk, hw)
410 struct cdns_torrent_received_refclk
{
412 struct regmap_field
*phy_pipe_cmn_ctrl1_0
;
413 struct regmap_field
*cmn_cdiag_refclk_ovrd_4
;
414 struct clk_init_data clk_data
;
417 #define to_cdns_torrent_received_refclk(_hw) \
418 container_of(_hw, struct cdns_torrent_received_refclk, hw)
420 struct cdns_reg_pairs
{
425 struct cdns_torrent_vals
{
426 const struct cdns_reg_pairs
*reg_pairs
;
430 struct cdns_torrent_vals_entry
{
432 const struct cdns_torrent_vals
*vals
;
435 struct cdns_torrent_vals_table
{
436 const struct cdns_torrent_vals_entry
*entries
;
440 struct cdns_torrent_data
{
441 u8 block_offset_shift
;
443 struct cdns_torrent_vals_table link_cmn_vals_tbl
;
444 struct cdns_torrent_vals_table xcvr_diag_vals_tbl
;
445 struct cdns_torrent_vals_table pcs_cmn_vals_tbl
;
446 struct cdns_torrent_vals_table phy_pma_cmn_vals_tbl
;
447 struct cdns_torrent_vals_table cmn_vals_tbl
;
448 struct cdns_torrent_vals_table tx_ln_vals_tbl
;
449 struct cdns_torrent_vals_table rx_ln_vals_tbl
;
452 struct cdns_regmap_cdb_context
{
458 static const struct cdns_torrent_vals
*cdns_torrent_get_tbl_vals(const struct cdns_torrent_vals_table
*tbl
,
459 enum cdns_torrent_ref_clk refclk0
,
460 enum cdns_torrent_ref_clk refclk1
,
461 enum cdns_torrent_phy_type link0
,
462 enum cdns_torrent_phy_type link1
,
463 enum cdns_torrent_ssc_mode ssc
)
466 u32 key
= CDNS_TORRENT_KEY(refclk0
, refclk1
, link0
, link1
, ssc
);
468 for (i
= 0; i
< tbl
->num_entries
; i
++) {
469 if (tbl
->entries
[i
].key
== key
)
470 return tbl
->entries
[i
].vals
;
476 static int cdns_regmap_write(void *context
, unsigned int reg
, unsigned int val
)
478 struct cdns_regmap_cdb_context
*ctx
= context
;
479 u32 offset
= reg
<< ctx
->reg_offset_shift
;
481 writew(val
, ctx
->base
+ offset
);
486 static int cdns_regmap_read(void *context
, unsigned int reg
, unsigned int *val
)
488 struct cdns_regmap_cdb_context
*ctx
= context
;
489 u32 offset
= reg
<< ctx
->reg_offset_shift
;
491 *val
= readw(ctx
->base
+ offset
);
495 static int cdns_regmap_dptx_write(void *context
, unsigned int reg
,
498 struct cdns_regmap_cdb_context
*ctx
= context
;
501 writel(val
, ctx
->base
+ offset
);
506 static int cdns_regmap_dptx_read(void *context
, unsigned int reg
,
509 struct cdns_regmap_cdb_context
*ctx
= context
;
512 *val
= readl(ctx
->base
+ offset
);
516 #define TORRENT_TX_LANE_CDB_REGMAP_CONF(n) \
518 .name = "torrent_tx_lane" n "_cdb", \
521 .reg_write = cdns_regmap_write, \
522 .reg_read = cdns_regmap_read, \
525 #define TORRENT_RX_LANE_CDB_REGMAP_CONF(n) \
527 .name = "torrent_rx_lane" n "_cdb", \
530 .reg_write = cdns_regmap_write, \
531 .reg_read = cdns_regmap_read, \
534 static const struct regmap_config cdns_torrent_tx_lane_cdb_config
[] = {
535 TORRENT_TX_LANE_CDB_REGMAP_CONF("0"),
536 TORRENT_TX_LANE_CDB_REGMAP_CONF("1"),
537 TORRENT_TX_LANE_CDB_REGMAP_CONF("2"),
538 TORRENT_TX_LANE_CDB_REGMAP_CONF("3"),
541 static const struct regmap_config cdns_torrent_rx_lane_cdb_config
[] = {
542 TORRENT_RX_LANE_CDB_REGMAP_CONF("0"),
543 TORRENT_RX_LANE_CDB_REGMAP_CONF("1"),
544 TORRENT_RX_LANE_CDB_REGMAP_CONF("2"),
545 TORRENT_RX_LANE_CDB_REGMAP_CONF("3"),
548 static const struct regmap_config cdns_torrent_common_cdb_config
= {
549 .name
= "torrent_common_cdb",
552 .reg_write
= cdns_regmap_write
,
553 .reg_read
= cdns_regmap_read
,
556 #define TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF(n) \
558 .name = "torrent_phy_pcs_lane" n "_cdb", \
561 .reg_write = cdns_regmap_write, \
562 .reg_read = cdns_regmap_read, \
565 static const struct regmap_config cdns_torrent_phy_pcs_lane_cdb_config
[] = {
566 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("0"),
567 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("1"),
568 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("2"),
569 TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF("3"),
572 static const struct regmap_config cdns_torrent_phy_pcs_cmn_cdb_config
= {
573 .name
= "torrent_phy_pcs_cmn_cdb",
576 .reg_write
= cdns_regmap_write
,
577 .reg_read
= cdns_regmap_read
,
580 static const struct regmap_config cdns_torrent_phy_pma_cmn_cdb_config
= {
581 .name
= "torrent_phy_pma_cmn_cdb",
584 .reg_write
= cdns_regmap_write
,
585 .reg_read
= cdns_regmap_read
,
588 static const struct regmap_config cdns_torrent_dptx_phy_config
= {
589 .name
= "torrent_dptx_phy",
592 .reg_write
= cdns_regmap_dptx_write
,
593 .reg_read
= cdns_regmap_dptx_read
,
596 /* PHY mmr access functions */
598 static void cdns_torrent_phy_write(struct regmap
*regmap
, u32 offset
, u32 val
)
600 regmap_write(regmap
, offset
, val
);
603 static u32
cdns_torrent_phy_read(struct regmap
*regmap
, u32 offset
)
607 regmap_read(regmap
, offset
, &val
);
611 /* DPTX mmr access functions */
613 static void cdns_torrent_dp_write(struct regmap
*regmap
, u32 offset
, u32 val
)
615 regmap_write(regmap
, offset
, val
);
618 static u32
cdns_torrent_dp_read(struct regmap
*regmap
, u32 offset
)
622 regmap_read(regmap
, offset
, &val
);
627 * Structure used to store values of PHY registers for voltage-related
628 * coefficients, for particular voltage swing and pre-emphasis level. Values
629 * are shared across all physical lanes.
631 struct coefficients
{
632 /* Value of DRV_DIAG_TX_DRV register to use */
634 /* Value of TX_TXCC_MGNFS_MULT_000 register to use */
636 /* Value of TX_TXCC_CPOST_MULT_00 register to use */
641 * Array consists of values of voltage-related registers for sd0801 PHY. A value
642 * of 0xFFFF is a placeholder for invalid combination, and will never be used.
644 static const struct coefficients vltg_coeff
[4][4] = {
645 /* voltage swing 0, pre-emphasis 0->3 */
646 { {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x002A,
647 .cpost_mult
= 0x0000},
648 {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x001F,
649 .cpost_mult
= 0x0014},
650 {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x0012,
651 .cpost_mult
= 0x0020},
652 {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x0000,
653 .cpost_mult
= 0x002A}
656 /* voltage swing 1, pre-emphasis 0->3 */
657 { {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x001F,
658 .cpost_mult
= 0x0000},
659 {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x0013,
660 .cpost_mult
= 0x0012},
661 {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x0000,
662 .cpost_mult
= 0x001F},
663 {.diag_tx_drv
= 0xFFFF, .mgnfs_mult
= 0xFFFF,
664 .cpost_mult
= 0xFFFF}
667 /* voltage swing 2, pre-emphasis 0->3 */
668 { {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x0013,
669 .cpost_mult
= 0x0000},
670 {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x0000,
671 .cpost_mult
= 0x0013},
672 {.diag_tx_drv
= 0xFFFF, .mgnfs_mult
= 0xFFFF,
673 .cpost_mult
= 0xFFFF},
674 {.diag_tx_drv
= 0xFFFF, .mgnfs_mult
= 0xFFFF,
675 .cpost_mult
= 0xFFFF}
678 /* voltage swing 3, pre-emphasis 0->3 */
679 { {.diag_tx_drv
= 0x0003, .mgnfs_mult
= 0x0000,
680 .cpost_mult
= 0x0000},
681 {.diag_tx_drv
= 0xFFFF, .mgnfs_mult
= 0xFFFF,
682 .cpost_mult
= 0xFFFF},
683 {.diag_tx_drv
= 0xFFFF, .mgnfs_mult
= 0xFFFF,
684 .cpost_mult
= 0xFFFF},
685 {.diag_tx_drv
= 0xFFFF, .mgnfs_mult
= 0xFFFF,
686 .cpost_mult
= 0xFFFF}
690 static const char *cdns_torrent_get_phy_type(enum cdns_torrent_phy_type phy_type
)
694 return "DisplayPort";
711 * Set registers responsible for enabling and configuring SSC, with second and
712 * third register values provided by parameters.
715 void cdns_torrent_dp_enable_ssc_19_2mhz(struct cdns_torrent_phy
*cdns_phy
,
716 u32 ctrl2_val
, u32 ctrl3_val
)
718 struct regmap
*regmap
= cdns_phy
->regmap_common_cdb
;
720 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL1_M0
, 0x0001);
721 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL1_M0
, ctrl2_val
);
722 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL1_M0
, ctrl3_val
);
723 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL4_M0
, 0x0003);
724 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL1_M0
, 0x0001);
725 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL1_M0
, ctrl2_val
);
726 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL1_M0
, ctrl3_val
);
727 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL4_M0
, 0x0003);
731 void cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(struct cdns_torrent_phy
*cdns_phy
,
734 struct regmap
*regmap
= cdns_phy
->regmap_common_cdb
;
736 /* Assumes 19.2 MHz refclock */
738 /* Setting VCO for 10.8GHz */
741 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x0119);
742 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0x4000);
743 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
744 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x00BC);
745 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CTRL_M0
, 0x0012);
746 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x0119);
747 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0x4000);
748 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
749 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x00BC);
750 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CTRL_M0
, 0x0012);
752 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy
, 0x033A, 0x006A);
754 /* Setting VCO for 9.72GHz */
758 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x01FA);
759 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0x4000);
760 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
761 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x0152);
762 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CTRL_M0
, 0x0002);
763 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x01FA);
764 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0x4000);
765 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
766 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x0152);
767 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CTRL_M0
, 0x0002);
769 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy
, 0x05DD, 0x0069);
771 /* Setting VCO for 8.64GHz */
774 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x01C2);
775 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0x0000);
776 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
777 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x012C);
778 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CTRL_M0
, 0x0002);
779 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x01C2);
780 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0x0000);
781 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
782 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x012C);
783 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CTRL_M0
, 0x0002);
785 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy
, 0x0536, 0x0069);
787 /* Setting VCO for 8.1GHz */
789 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x01A5);
790 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0xE000);
791 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
792 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x011A);
793 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CTRL_M0
, 0x0002);
794 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x01A5);
795 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0xE000);
796 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
797 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x011A);
798 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CTRL_M0
, 0x0002);
800 cdns_torrent_dp_enable_ssc_19_2mhz(cdns_phy
, 0x04D7, 0x006A);
805 cdns_torrent_phy_write(regmap
, CMN_PLL0_VCOCAL_PLLCNT_START
, 0x025E);
806 cdns_torrent_phy_write(regmap
, CMN_PLL0_LOCK_PLLCNT_THR
, 0x0005);
807 cdns_torrent_phy_write(regmap
, CMN_PLL1_VCOCAL_PLLCNT_START
, 0x025E);
808 cdns_torrent_phy_write(regmap
, CMN_PLL1_LOCK_PLLCNT_THR
, 0x0005);
810 cdns_torrent_phy_write(regmap
, CMN_PLL0_VCOCAL_PLLCNT_START
, 0x0260);
811 cdns_torrent_phy_write(regmap
, CMN_PLL1_VCOCAL_PLLCNT_START
, 0x0260);
812 /* Set reset register values to disable SSC */
813 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL1_M0
, 0x0002);
814 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL2_M0
, 0x0000);
815 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL3_M0
, 0x0000);
816 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL4_M0
, 0x0000);
817 cdns_torrent_phy_write(regmap
, CMN_PLL0_LOCK_PLLCNT_THR
, 0x0003);
818 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL1_M0
, 0x0002);
819 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL2_M0
, 0x0000);
820 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL3_M0
, 0x0000);
821 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL4_M0
, 0x0000);
822 cdns_torrent_phy_write(regmap
, CMN_PLL1_LOCK_PLLCNT_THR
, 0x0003);
825 cdns_torrent_phy_write(regmap
, CMN_PLL0_LOCK_REFCNT_START
, 0x0099);
826 cdns_torrent_phy_write(regmap
, CMN_PLL0_LOCK_PLLCNT_START
, 0x0099);
827 cdns_torrent_phy_write(regmap
, CMN_PLL1_LOCK_REFCNT_START
, 0x0099);
828 cdns_torrent_phy_write(regmap
, CMN_PLL1_LOCK_PLLCNT_START
, 0x0099);
832 * Set registers responsible for enabling and configuring SSC, with second
833 * register value provided by a parameter.
835 static void cdns_torrent_dp_enable_ssc_25mhz(struct cdns_torrent_phy
*cdns_phy
,
838 struct regmap
*regmap
= cdns_phy
->regmap_common_cdb
;
840 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL1_M0
, 0x0001);
841 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL1_M0
, ctrl2_val
);
842 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL1_M0
, 0x007F);
843 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL4_M0
, 0x0003);
844 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL1_M0
, 0x0001);
845 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL1_M0
, ctrl2_val
);
846 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL1_M0
, 0x007F);
847 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL4_M0
, 0x0003);
851 void cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(struct cdns_torrent_phy
*cdns_phy
,
854 struct regmap
*regmap
= cdns_phy
->regmap_common_cdb
;
856 /* Assumes 25 MHz refclock */
858 /* Setting VCO for 10.8GHz */
861 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x01B0);
862 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0x0000);
863 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
864 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x0120);
865 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x01B0);
866 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0x0000);
867 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
868 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x0120);
870 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy
, 0x0423);
872 /* Setting VCO for 9.72GHz */
876 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x0184);
877 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0xCCCD);
878 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
879 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x0104);
880 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x0184);
881 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0xCCCD);
882 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
883 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x0104);
885 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy
, 0x03B9);
887 /* Setting VCO for 8.64GHz */
890 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x0159);
891 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0x999A);
892 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
893 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x00E7);
894 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x0159);
895 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0x999A);
896 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
897 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x00E7);
899 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy
, 0x034F);
901 /* Setting VCO for 8.1GHz */
903 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x0144);
904 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0x0000);
905 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
906 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x00D8);
907 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x0144);
908 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0x0000);
909 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
910 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x00D8);
912 cdns_torrent_dp_enable_ssc_25mhz(cdns_phy
, 0x031A);
916 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CTRL_M0
, 0x0002);
917 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CTRL_M0
, 0x0002);
920 cdns_torrent_phy_write(regmap
,
921 CMN_PLL0_VCOCAL_PLLCNT_START
, 0x0315);
922 cdns_torrent_phy_write(regmap
,
923 CMN_PLL0_LOCK_PLLCNT_THR
, 0x0005);
924 cdns_torrent_phy_write(regmap
,
925 CMN_PLL1_VCOCAL_PLLCNT_START
, 0x0315);
926 cdns_torrent_phy_write(regmap
,
927 CMN_PLL1_LOCK_PLLCNT_THR
, 0x0005);
929 cdns_torrent_phy_write(regmap
,
930 CMN_PLL0_VCOCAL_PLLCNT_START
, 0x0317);
931 cdns_torrent_phy_write(regmap
,
932 CMN_PLL1_VCOCAL_PLLCNT_START
, 0x0317);
933 /* Set reset register values to disable SSC */
934 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL1_M0
, 0x0002);
935 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL2_M0
, 0x0000);
936 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL3_M0
, 0x0000);
937 cdns_torrent_phy_write(regmap
, CMN_PLL0_SS_CTRL4_M0
, 0x0000);
938 cdns_torrent_phy_write(regmap
,
939 CMN_PLL0_LOCK_PLLCNT_THR
, 0x0003);
940 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL1_M0
, 0x0002);
941 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL2_M0
, 0x0000);
942 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL3_M0
, 0x0000);
943 cdns_torrent_phy_write(regmap
, CMN_PLL1_SS_CTRL4_M0
, 0x0000);
944 cdns_torrent_phy_write(regmap
,
945 CMN_PLL1_LOCK_PLLCNT_THR
, 0x0003);
948 cdns_torrent_phy_write(regmap
, CMN_PLL0_LOCK_REFCNT_START
, 0x00C7);
949 cdns_torrent_phy_write(regmap
, CMN_PLL0_LOCK_PLLCNT_START
, 0x00C7);
950 cdns_torrent_phy_write(regmap
, CMN_PLL1_LOCK_REFCNT_START
, 0x00C7);
951 cdns_torrent_phy_write(regmap
, CMN_PLL1_LOCK_PLLCNT_START
, 0x00C7);
955 void cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(struct cdns_torrent_phy
*cdns_phy
,
958 struct regmap
*regmap
= cdns_phy
->regmap_common_cdb
;
960 /* Assumes 100 MHz refclock */
962 /* Setting VCO for 10.8GHz */
965 if (cdns_phy
->dp_pll
& DP_PLL0
)
966 cdns_torrent_phy_write(regmap
, CMN_PLL0_DSM_FBH_OVRD_M0
, 0x0022);
968 if (cdns_phy
->dp_pll
& DP_PLL1
) {
969 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CP_PADJ_M0
, 0x0028);
970 cdns_torrent_phy_write(regmap
, CMN_PLL1_DSM_FBH_OVRD_M0
, 0x0022);
971 cdns_torrent_phy_write(regmap
, CMN_PLL1_DSM_FBL_OVRD_M0
, 0x000C);
974 /* Setting VCO for 9.72GHz */
978 if (cdns_phy
->dp_pll
& DP_PLL0
) {
979 cdns_torrent_phy_write(regmap
, CMN_PLL0_DSM_DIAG_M0
, 0x0004);
980 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CP_PADJ_M0
, 0x0509);
981 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CP_IADJ_M0
, 0x0F00);
982 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_FILT_PADJ_M0
, 0x0F08);
983 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x0061);
984 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0x3333);
985 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
986 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x0042);
987 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CTRL_M0
, 0x0002);
989 if (cdns_phy
->dp_pll
& DP_PLL1
) {
990 cdns_torrent_phy_write(regmap
, CMN_PLL1_DSM_DIAG_M0
, 0x0004);
991 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CP_PADJ_M0
, 0x0509);
992 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CP_IADJ_M0
, 0x0F00);
993 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_FILT_PADJ_M0
, 0x0F08);
994 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x0061);
995 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0x3333);
996 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
997 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x0042);
998 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CTRL_M0
, 0x0002);
1001 /* Setting VCO for 8.64GHz */
1004 if (cdns_phy
->dp_pll
& DP_PLL0
) {
1005 cdns_torrent_phy_write(regmap
, CMN_PLL0_DSM_DIAG_M0
, 0x0004);
1006 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CP_PADJ_M0
, 0x0509);
1007 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CP_IADJ_M0
, 0x0F00);
1008 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_FILT_PADJ_M0
, 0x0F08);
1009 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x0056);
1010 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVL_M0
, 0x6666);
1011 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
1012 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x003A);
1013 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CTRL_M0
, 0x0002);
1015 if (cdns_phy
->dp_pll
& DP_PLL1
) {
1016 cdns_torrent_phy_write(regmap
, CMN_PLL1_DSM_DIAG_M0
, 0x0004);
1017 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CP_PADJ_M0
, 0x0509);
1018 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CP_IADJ_M0
, 0x0F00);
1019 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_FILT_PADJ_M0
, 0x0F08);
1020 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x0056);
1021 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVL_M0
, 0x6666);
1022 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
1023 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x003A);
1024 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CTRL_M0
, 0x0002);
1027 /* Setting VCO for 8.1GHz */
1029 if (cdns_phy
->dp_pll
& DP_PLL0
) {
1030 cdns_torrent_phy_write(regmap
, CMN_PLL0_DSM_DIAG_M0
, 0x0004);
1031 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CP_PADJ_M0
, 0x0509);
1032 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CP_IADJ_M0
, 0x0F00);
1033 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_FILT_PADJ_M0
, 0x0F08);
1034 cdns_torrent_phy_write(regmap
, CMN_PLL0_INTDIV_M0
, 0x0051);
1035 cdns_torrent_phy_write(regmap
, CMN_PLL0_FRACDIVH_M0
, 0x0002);
1036 cdns_torrent_phy_write(regmap
, CMN_PLL0_HIGH_THR_M0
, 0x0036);
1037 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL0_CTRL_M0
, 0x0002);
1039 if (cdns_phy
->dp_pll
& DP_PLL1
) {
1040 cdns_torrent_phy_write(regmap
, CMN_PLL1_DSM_DIAG_M0
, 0x0004);
1041 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CP_PADJ_M0
, 0x0509);
1042 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CP_IADJ_M0
, 0x0F00);
1043 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_FILT_PADJ_M0
, 0x0F08);
1044 cdns_torrent_phy_write(regmap
, CMN_PLL1_INTDIV_M0
, 0x0051);
1045 cdns_torrent_phy_write(regmap
, CMN_PLL1_FRACDIVH_M0
, 0x0002);
1046 cdns_torrent_phy_write(regmap
, CMN_PLL1_HIGH_THR_M0
, 0x0036);
1047 cdns_torrent_phy_write(regmap
, CMN_PDIAG_PLL1_CTRL_M0
, 0x0002);
1053 /* Set PLL used for DP configuration */
1054 static int cdns_torrent_dp_get_pll(struct cdns_torrent_phy
*cdns_phy
,
1055 enum cdns_torrent_phy_type phy_t2
)
1060 cdns_phy
->dp_pll
= DP_PLL1
;
1064 cdns_phy
->dp_pll
= DP_PLL0
;
1067 cdns_phy
->dp_pll
= DP_PLL0
| DP_PLL1
;
1070 dev_err(cdns_phy
->dev
, "Unsupported PHY configuration\n");
1078 * Enable or disable PLL for selected lanes.
1080 static int cdns_torrent_dp_set_pll_en(struct cdns_torrent_phy
*cdns_phy
,
1081 struct cdns_torrent_inst
*inst
,
1082 struct phy_configure_opts_dp
*dp
,
1085 struct regmap
*regmap
= cdns_phy
->regmap_dptx_phy_reg
;
1086 u32 rd_val
, pll_ack_val
;
1090 * Used to determine, which bits to check for or enable in
1091 * PHY_PMA_XCVR_PLLCLK_EN register.
1094 /* Used to enable or disable lanes. */
1097 /* Select values of registers and mask, depending on enabled lane count. */
1098 pll_val
= cdns_torrent_dp_read(regmap
, PHY_PMA_XCVR_PLLCLK_EN
);
1101 pll_bits
= ((1 << dp
->lanes
) - 1);
1102 pll_val
|= pll_bits
;
1103 pll_ack_val
= pll_bits
;
1105 pll_bits
= ((1 << inst
->num_lanes
) - 1);
1106 pll_val
&= (~pll_bits
);
1110 cdns_torrent_dp_write(regmap
, PHY_PMA_XCVR_PLLCLK_EN
, pll_val
);
1112 /* Wait for acknowledgment from PHY. */
1113 ret
= regmap_read_poll_timeout(regmap
,
1114 PHY_PMA_XCVR_PLLCLK_EN_ACK
,
1116 (rd_val
& pll_bits
) == pll_ack_val
,
1117 0, POLL_TIMEOUT_US
);
1122 static int cdns_torrent_dp_set_power_state(struct cdns_torrent_phy
*cdns_phy
,
1123 struct cdns_torrent_inst
*inst
,
1125 enum phy_powerstate powerstate
)
1127 /* Register value for power state for a single byte. */
1133 struct regmap
*regmap
= cdns_phy
->regmap_dptx_phy_reg
;
1135 switch (powerstate
) {
1136 case (POWERSTATE_A0
):
1139 case (POWERSTATE_A2
):
1148 /* Select values of registers and mask, depending on enabled lane count. */
1150 for (i
= 0; i
< num_lanes
; i
++) {
1151 value
|= (value_part
<< PHY_POWER_STATE_LN(i
));
1152 mask
|= (PMA_XCVR_POWER_STATE_REQ_LN_MASK
<< PHY_POWER_STATE_LN(i
));
1155 /* Set power state A<n>. */
1156 cdns_torrent_dp_write(regmap
, PHY_PMA_XCVR_POWER_STATE_REQ
, value
);
1157 /* Wait, until PHY acknowledges power state completion. */
1158 ret
= regmap_read_poll_timeout(regmap
, PHY_PMA_XCVR_POWER_STATE_ACK
,
1159 read_val
, (read_val
& mask
) == value
, 0,
1164 cdns_torrent_dp_write(regmap
, PHY_PMA_XCVR_POWER_STATE_REQ
, 0x00000000);
1170 static int cdns_torrent_dp_run(struct cdns_torrent_phy
*cdns_phy
,
1171 struct cdns_torrent_inst
*inst
, u32 num_lanes
)
1173 unsigned int read_val
;
1175 struct regmap
*regmap
= cdns_phy
->regmap_dptx_phy_reg
;
1178 * waiting for ACK of pma_xcvr_pllclk_en_ln_*, only for the
1181 ret
= regmap_read_poll_timeout(regmap
, PHY_PMA_XCVR_PLLCLK_EN_ACK
,
1182 read_val
, read_val
& 1,
1183 0, POLL_TIMEOUT_US
);
1184 if (ret
== -ETIMEDOUT
) {
1185 dev_err(cdns_phy
->dev
,
1186 "timeout waiting for link PLL clock enable ack\n");
1192 ret
= cdns_torrent_dp_set_power_state(cdns_phy
, inst
, num_lanes
,
1197 ret
= cdns_torrent_dp_set_power_state(cdns_phy
, inst
, num_lanes
,
1203 static int cdns_torrent_dp_wait_pma_cmn_ready(struct cdns_torrent_phy
*cdns_phy
)
1207 struct regmap
*regmap
= cdns_phy
->regmap_dptx_phy_reg
;
1209 ret
= regmap_read_poll_timeout(regmap
, PHY_PMA_CMN_READY
, reg
,
1210 reg
& 1, 0, POLL_TIMEOUT_US
);
1211 if (ret
== -ETIMEDOUT
) {
1212 dev_err(cdns_phy
->dev
,
1213 "timeout waiting for PMA common ready\n");
1220 static void cdns_torrent_dp_pma_cmn_rate(struct cdns_torrent_phy
*cdns_phy
,
1221 struct cdns_torrent_inst
*inst
,
1222 u32 rate
, u32 num_lanes
)
1224 unsigned int clk_sel_val
= 0;
1225 unsigned int hsclk_div_val
= 0;
1230 clk_sel_val
= 0x0f01;
1236 clk_sel_val
= 0x0701;
1240 clk_sel_val
= 0x0b00;
1245 clk_sel_val
= 0x0301;
1249 clk_sel_val
= 0x0200;
1254 if (cdns_phy
->dp_pll
& DP_PLL0
)
1255 cdns_torrent_phy_write(cdns_phy
->regmap_common_cdb
,
1256 CMN_PDIAG_PLL0_CLK_SEL_M0
, clk_sel_val
);
1258 if (cdns_phy
->dp_pll
& DP_PLL1
)
1259 cdns_torrent_phy_write(cdns_phy
->regmap_common_cdb
,
1260 CMN_PDIAG_PLL1_CLK_SEL_M0
, clk_sel_val
);
1262 /* PMA lane configuration to deal with multi-link operation */
1263 for (i
= 0; i
< num_lanes
; i
++)
1264 cdns_torrent_phy_write(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ i
],
1265 XCVR_DIAG_HSCLK_DIV
, hsclk_div_val
);
1269 * Perform register operations related to setting link rate, once powerstate is
1270 * set and PLL disable request was processed.
1272 static int cdns_torrent_dp_configure_rate(struct cdns_torrent_phy
*cdns_phy
,
1273 struct cdns_torrent_inst
*inst
,
1274 struct phy_configure_opts_dp
*dp
)
1276 u32 read_val
, field_val
;
1280 * Disable the associated PLL (cmn_pll0_en or cmn_pll1_en) before
1281 * re-programming the new data rate.
1283 ret
= regmap_field_read(cdns_phy
->phy_pma_pll_raw_ctrl
, &field_val
);
1286 field_val
&= ~(cdns_phy
->dp_pll
);
1287 regmap_field_write(cdns_phy
->phy_pma_pll_raw_ctrl
, field_val
);
1290 * Wait for PLL ready de-assertion.
1291 * For PLL0 - PHY_PMA_CMN_CTRL2[2] == 1
1292 * For PLL1 - PHY_PMA_CMN_CTRL2[3] == 1
1294 if (cdns_phy
->dp_pll
& DP_PLL0
) {
1295 ret
= regmap_field_read_poll_timeout(cdns_phy
->phy_pma_cmn_ctrl_2
,
1297 ((read_val
>> 2) & 0x01) != 0,
1298 0, POLL_TIMEOUT_US
);
1303 if ((cdns_phy
->dp_pll
& DP_PLL1
) && cdns_phy
->nsubnodes
!= 1) {
1304 ret
= regmap_field_read_poll_timeout(cdns_phy
->phy_pma_cmn_ctrl_2
,
1306 ((read_val
>> 3) & 0x01) != 0,
1307 0, POLL_TIMEOUT_US
);
1313 /* DP Rate Change - VCO Output settings. */
1314 if (cdns_phy
->ref_clk_rate
== CLK_19_2_MHZ
)
1315 /* PMA common configuration 19.2MHz */
1316 cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(cdns_phy
, dp
->link_rate
, dp
->ssc
);
1317 else if (cdns_phy
->ref_clk_rate
== CLK_25_MHZ
)
1318 /* PMA common configuration 25MHz */
1319 cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(cdns_phy
, dp
->link_rate
, dp
->ssc
);
1320 else if (cdns_phy
->ref_clk_rate
== CLK_100_MHZ
)
1321 /* PMA common configuration 100MHz */
1322 cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(cdns_phy
, dp
->link_rate
, dp
->ssc
);
1324 cdns_torrent_dp_pma_cmn_rate(cdns_phy
, inst
, dp
->link_rate
, dp
->lanes
);
1326 /* Enable the associated PLL (cmn_pll0_en or cmn_pll1_en) */
1327 ret
= regmap_field_read(cdns_phy
->phy_pma_pll_raw_ctrl
, &field_val
);
1330 field_val
|= cdns_phy
->dp_pll
;
1331 regmap_field_write(cdns_phy
->phy_pma_pll_raw_ctrl
, field_val
);
1334 * Wait for PLL ready assertion.
1335 * For PLL0 - PHY_PMA_CMN_CTRL2[0] == 1
1336 * For PLL1 - PHY_PMA_CMN_CTRL2[1] == 1
1338 if (cdns_phy
->dp_pll
& DP_PLL0
) {
1339 ret
= regmap_field_read_poll_timeout(cdns_phy
->phy_pma_cmn_ctrl_2
,
1341 (read_val
& 0x01) != 0,
1342 0, POLL_TIMEOUT_US
);
1347 if ((cdns_phy
->dp_pll
& DP_PLL1
) && cdns_phy
->nsubnodes
!= 1)
1348 ret
= regmap_field_read_poll_timeout(cdns_phy
->phy_pma_cmn_ctrl_2
,
1350 ((read_val
>> 1) & 0x01) != 0,
1351 0, POLL_TIMEOUT_US
);
1357 * Verify, that parameters to configure PHY with are correct.
1359 static int cdns_torrent_dp_verify_config(struct cdns_torrent_inst
*inst
,
1360 struct phy_configure_opts_dp
*dp
)
1364 /* If changing link rate was required, verify it's supported. */
1366 switch (dp
->link_rate
) {
1375 /* valid bit rate */
1382 /* Verify lane count. */
1383 switch (dp
->lanes
) {
1387 /* valid lane count. */
1393 /* Check against actual number of PHY's lanes. */
1394 if (dp
->lanes
> inst
->num_lanes
)
1398 * If changing voltages is required, check swing and pre-emphasis
1401 if (dp
->set_voltages
) {
1402 /* Lane count verified previously. */
1403 for (i
= 0; i
< dp
->lanes
; i
++) {
1404 if (dp
->voltage
[i
] > 3 || dp
->pre
[i
] > 3)
1407 /* Sum of voltage swing and pre-emphasis levels cannot
1410 if (dp
->voltage
[i
] + dp
->pre
[i
] > 3)
1418 /* Set power state A0 and PLL clock enable to 0 on enabled lanes. */
1419 static void cdns_torrent_dp_set_a0_pll(struct cdns_torrent_phy
*cdns_phy
,
1420 struct cdns_torrent_inst
*inst
,
1423 struct regmap
*regmap
= cdns_phy
->regmap_dptx_phy_reg
;
1424 u32 pwr_state
= cdns_torrent_dp_read(regmap
,
1425 PHY_PMA_XCVR_POWER_STATE_REQ
);
1426 u32 pll_clk_en
= cdns_torrent_dp_read(regmap
,
1427 PHY_PMA_XCVR_PLLCLK_EN
);
1430 for (i
= 0; i
< num_lanes
; i
++) {
1431 pwr_state
&= ~(PMA_XCVR_POWER_STATE_REQ_LN_MASK
1432 << PHY_POWER_STATE_LN(inst
->mlane
+ i
));
1434 pll_clk_en
&= ~(0x01U
<< (inst
->mlane
+ i
));
1437 cdns_torrent_dp_write(regmap
, PHY_PMA_XCVR_POWER_STATE_REQ
, pwr_state
);
1438 cdns_torrent_dp_write(regmap
, PHY_PMA_XCVR_PLLCLK_EN
, pll_clk_en
);
1441 /* Configure lane count as required. */
1442 static int cdns_torrent_dp_set_lanes(struct cdns_torrent_phy
*cdns_phy
,
1443 struct cdns_torrent_inst
*inst
,
1444 struct phy_configure_opts_dp
*dp
)
1448 struct regmap
*regmap
= cdns_phy
->regmap_dptx_phy_reg
;
1449 u8 lane_mask
= (1 << dp
->lanes
) - 1;
1450 u8 pma_tx_elec_idle_mask
= 0;
1451 u32 clane
= inst
->mlane
;
1453 lane_mask
<<= clane
;
1455 value
= cdns_torrent_dp_read(regmap
, PHY_RESET
);
1456 /* clear pma_tx_elec_idle_ln_* bits. */
1457 pma_tx_elec_idle_mask
= ((1 << inst
->num_lanes
) - 1) << clane
;
1459 pma_tx_elec_idle_mask
<<= PMA_TX_ELEC_IDLE_SHIFT
;
1461 value
&= ~pma_tx_elec_idle_mask
;
1463 /* Assert pma_tx_elec_idle_ln_* for disabled lanes. */
1464 value
|= ((~lane_mask
) << PMA_TX_ELEC_IDLE_SHIFT
) &
1465 pma_tx_elec_idle_mask
;
1467 cdns_torrent_dp_write(regmap
, PHY_RESET
, value
);
1469 /* reset the link by asserting master lane phy_l0*_reset_n low */
1470 cdns_torrent_dp_write(regmap
, PHY_RESET
,
1471 value
& (~(1 << clane
)));
1474 * Assert lane reset on unused lanes and master lane so they remain in reset
1475 * and powered down when re-enabling the link
1477 for (i
= 0; i
< inst
->num_lanes
; i
++)
1478 value
&= (~(1 << (clane
+ i
)));
1480 for (i
= 1; i
< inst
->num_lanes
; i
++)
1481 value
|= ((1 << (clane
+ i
)) & lane_mask
);
1483 cdns_torrent_dp_write(regmap
, PHY_RESET
, value
);
1485 cdns_torrent_dp_set_a0_pll(cdns_phy
, inst
, dp
->lanes
);
1487 /* release phy_l0*_reset_n based on used laneCount */
1488 for (i
= 0; i
< inst
->num_lanes
; i
++)
1489 value
&= (~(1 << (clane
+ i
)));
1491 for (i
= 0; i
< inst
->num_lanes
; i
++)
1492 value
|= ((1 << (clane
+ i
)) & lane_mask
);
1494 cdns_torrent_dp_write(regmap
, PHY_RESET
, value
);
1496 /* Wait, until PHY gets ready after releasing PHY reset signal. */
1497 ret
= cdns_torrent_dp_wait_pma_cmn_ready(cdns_phy
);
1503 /* release pma_xcvr_pllclk_en_ln_*, only for the master lane */
1504 value
= cdns_torrent_dp_read(regmap
, PHY_PMA_XCVR_PLLCLK_EN
);
1505 value
|= (1 << clane
);
1506 cdns_torrent_dp_write(regmap
, PHY_PMA_XCVR_PLLCLK_EN
, value
);
1508 ret
= cdns_torrent_dp_run(cdns_phy
, inst
, dp
->lanes
);
1513 /* Configure link rate as required. */
1514 static int cdns_torrent_dp_set_rate(struct cdns_torrent_phy
*cdns_phy
,
1515 struct cdns_torrent_inst
*inst
,
1516 struct phy_configure_opts_dp
*dp
)
1520 ret
= cdns_torrent_dp_set_power_state(cdns_phy
, inst
, dp
->lanes
,
1524 ret
= cdns_torrent_dp_set_pll_en(cdns_phy
, inst
, dp
, false);
1529 ret
= cdns_torrent_dp_configure_rate(cdns_phy
, inst
, dp
);
1534 ret
= cdns_torrent_dp_set_pll_en(cdns_phy
, inst
, dp
, true);
1537 ret
= cdns_torrent_dp_set_power_state(cdns_phy
, inst
, dp
->lanes
,
1541 ret
= cdns_torrent_dp_set_power_state(cdns_phy
, inst
, dp
->lanes
,
1550 /* Configure voltage swing and pre-emphasis for all enabled lanes. */
1551 static void cdns_torrent_dp_set_voltages(struct cdns_torrent_phy
*cdns_phy
,
1552 struct cdns_torrent_inst
*inst
,
1553 struct phy_configure_opts_dp
*dp
)
1558 for (lane
= 0; lane
< dp
->lanes
; lane
++) {
1559 val
= cdns_torrent_phy_read(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ lane
],
1562 * Write 1 to register bit TX_DIAG_ACYA[0] to freeze the
1563 * current state of the analog TX driver.
1565 val
|= TX_DIAG_ACYA_HBDC_MASK
;
1566 cdns_torrent_phy_write(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ lane
],
1569 cdns_torrent_phy_write(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ lane
],
1570 TX_TXCC_CTRL
, 0x08A4);
1571 val
= vltg_coeff
[dp
->voltage
[lane
]][dp
->pre
[lane
]].diag_tx_drv
;
1572 cdns_torrent_phy_write(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ lane
],
1573 DRV_DIAG_TX_DRV
, val
);
1574 val
= vltg_coeff
[dp
->voltage
[lane
]][dp
->pre
[lane
]].mgnfs_mult
;
1575 cdns_torrent_phy_write(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ lane
],
1576 TX_TXCC_MGNFS_MULT_000
,
1578 val
= vltg_coeff
[dp
->voltage
[lane
]][dp
->pre
[lane
]].cpost_mult
;
1579 cdns_torrent_phy_write(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ lane
],
1580 TX_TXCC_CPOST_MULT_00
,
1583 val
= cdns_torrent_phy_read(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ lane
],
1586 * Write 0 to register bit TX_DIAG_ACYA[0] to allow the state of
1587 * analog TX driver to reflect the new programmed one.
1589 val
&= ~TX_DIAG_ACYA_HBDC_MASK
;
1590 cdns_torrent_phy_write(cdns_phy
->regmap_tx_lane_cdb
[inst
->mlane
+ lane
],
1595 static int cdns_torrent_dp_configure(struct phy
*phy
,
1596 union phy_configure_opts
*opts
)
1598 struct cdns_torrent_inst
*inst
= phy_get_drvdata(phy
);
1599 struct cdns_torrent_phy
*cdns_phy
= dev_get_drvdata(phy
->dev
.parent
);
1602 if (cdns_phy
->already_configured
)
1605 ret
= cdns_torrent_dp_verify_config(inst
, &opts
->dp
);
1607 dev_err(&phy
->dev
, "invalid params for phy configure\n");
1611 if (opts
->dp
.set_lanes
) {
1612 ret
= cdns_torrent_dp_set_lanes(cdns_phy
, inst
, &opts
->dp
);
1614 dev_err(&phy
->dev
, "cdns_torrent_dp_set_lanes failed\n");
1619 if (opts
->dp
.set_rate
) {
1620 ret
= cdns_torrent_dp_set_rate(cdns_phy
, inst
, &opts
->dp
);
1622 dev_err(&phy
->dev
, "cdns_torrent_dp_set_rate failed\n");
1627 if (opts
->dp
.set_voltages
)
1628 cdns_torrent_dp_set_voltages(cdns_phy
, inst
, &opts
->dp
);
1633 static int cdns_torrent_phy_on(struct phy
*phy
)
1635 struct cdns_torrent_inst
*inst
= phy_get_drvdata(phy
);
1636 struct cdns_torrent_phy
*cdns_phy
= dev_get_drvdata(phy
->dev
.parent
);
1640 if (cdns_phy
->already_configured
) {
1641 /* Give 5ms to 10ms delay for the PIPE clock to be stable */
1642 usleep_range(5000, 10000);
1646 if (cdns_phy
->nsubnodes
== 1) {
1647 /* Take the PHY lane group out of reset */
1648 reset_control_deassert(inst
->lnk_rst
);
1650 /* Take the PHY out of reset */
1651 ret
= reset_control_deassert(cdns_phy
->phy_rst
);
1657 * Wait for cmn_ready assertion
1658 * PHY_PMA_CMN_CTRL1[0] == 1
1660 ret
= regmap_field_read_poll_timeout(cdns_phy
->phy_pma_cmn_ctrl_1
,
1661 read_val
, read_val
, 1000,
1664 dev_err(cdns_phy
->dev
, "Timeout waiting for CMN ready\n");
1668 if (inst
->phy_type
== TYPE_PCIE
|| inst
->phy_type
== TYPE_USB
) {
1669 ret
= regmap_field_read_poll_timeout(cdns_phy
->phy_pcs_iso_link_ctrl_1
[inst
->mlane
],
1670 read_val
, !read_val
, 1000,
1672 if (ret
== -ETIMEDOUT
) {
1673 dev_err(cdns_phy
->dev
, "Timeout waiting for PHY status ready\n");
1681 static int cdns_torrent_phy_off(struct phy
*phy
)
1683 struct cdns_torrent_inst
*inst
= phy_get_drvdata(phy
);
1684 struct cdns_torrent_phy
*cdns_phy
= dev_get_drvdata(phy
->dev
.parent
);
1687 if (cdns_phy
->nsubnodes
!= 1)
1690 ret
= reset_control_assert(cdns_phy
->phy_rst
);
1694 return reset_control_assert(inst
->lnk_rst
);
1697 static void cdns_torrent_dp_common_init(struct cdns_torrent_phy
*cdns_phy
,
1698 struct cdns_torrent_inst
*inst
)
1700 struct regmap
*regmap
= cdns_phy
->regmap_dptx_phy_reg
;
1701 unsigned char lane_bits
;
1704 cdns_torrent_dp_write(regmap
, PHY_AUX_CTRL
, 0x0003); /* enable AUX */
1707 * Set lines power state to A0
1708 * Set lines pll clk enable to 0
1710 cdns_torrent_dp_set_a0_pll(cdns_phy
, inst
, inst
->num_lanes
);
1713 * release phy_l0*_reset_n and pma_tx_elec_idle_ln_* based on
1716 lane_bits
= (1 << inst
->num_lanes
) - 1;
1718 val
= cdns_torrent_dp_read(regmap
, PHY_RESET
);
1719 val
|= (0xF & lane_bits
);
1720 val
&= ~(lane_bits
<< 4);
1721 cdns_torrent_dp_write(regmap
, PHY_RESET
, val
);
1723 /* release pma_xcvr_pllclk_en_ln_*, only for the master lane */
1724 val
= cdns_torrent_dp_read(regmap
, PHY_PMA_XCVR_PLLCLK_EN
);
1726 cdns_torrent_dp_write(regmap
, PHY_PMA_XCVR_PLLCLK_EN
, val
);
1729 * PHY PMA registers configuration functions
1730 * Initialize PHY with max supported link rate, without SSC.
1732 if (cdns_phy
->ref_clk_rate
== CLK_19_2_MHZ
)
1733 cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(cdns_phy
,
1734 cdns_phy
->max_bit_rate
,
1736 else if (cdns_phy
->ref_clk_rate
== CLK_25_MHZ
)
1737 cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(cdns_phy
,
1738 cdns_phy
->max_bit_rate
,
1740 else if (cdns_phy
->ref_clk_rate
== CLK_100_MHZ
)
1741 cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(cdns_phy
,
1742 cdns_phy
->max_bit_rate
,
1745 cdns_torrent_dp_pma_cmn_rate(cdns_phy
, inst
, cdns_phy
->max_bit_rate
,
1748 /* take out of reset */
1749 regmap_field_write(cdns_phy
->phy_reset_ctrl
, 0x1);
1752 static int cdns_torrent_dp_start(struct cdns_torrent_phy
*cdns_phy
,
1753 struct cdns_torrent_inst
*inst
,
1758 ret
= cdns_torrent_phy_on(phy
);
1762 ret
= cdns_torrent_dp_wait_pma_cmn_ready(cdns_phy
);
1766 ret
= cdns_torrent_dp_run(cdns_phy
, inst
, inst
->num_lanes
);
1771 static int cdns_torrent_dp_init(struct phy
*phy
)
1773 struct cdns_torrent_inst
*inst
= phy_get_drvdata(phy
);
1774 struct cdns_torrent_phy
*cdns_phy
= dev_get_drvdata(phy
->dev
.parent
);
1777 switch (cdns_phy
->ref_clk_rate
) {
1781 /* Valid Ref Clock Rate */
1784 dev_err(cdns_phy
->dev
, "Unsupported Ref Clock Rate\n");
1788 ret
= cdns_torrent_dp_get_pll(cdns_phy
, TYPE_NONE
);
1792 cdns_torrent_dp_common_init(cdns_phy
, inst
);
1794 return cdns_torrent_dp_start(cdns_phy
, inst
, phy
);
1797 static int cdns_torrent_dp_multilink_init(struct cdns_torrent_phy
*cdns_phy
,
1798 struct cdns_torrent_inst
*inst
,
1801 if (cdns_phy
->ref_clk_rate
!= CLK_100_MHZ
) {
1802 dev_err(cdns_phy
->dev
, "Unsupported Ref Clock Rate\n");
1806 cdns_torrent_dp_common_init(cdns_phy
, inst
);
1808 return cdns_torrent_dp_start(cdns_phy
, inst
, phy
);
1811 static int cdns_torrent_derived_refclk_enable(struct clk_hw
*hw
)
1813 struct cdns_torrent_derived_refclk
*derived_refclk
= to_cdns_torrent_derived_refclk(hw
);
1815 regmap_field_write(derived_refclk
->cmn_cdiag_refclk_ovrd_4
, 1);
1816 regmap_field_write(derived_refclk
->phy_pipe_cmn_ctrl1_0
, 1);
1821 static void cdns_torrent_derived_refclk_disable(struct clk_hw
*hw
)
1823 struct cdns_torrent_derived_refclk
*derived_refclk
= to_cdns_torrent_derived_refclk(hw
);
1825 regmap_field_write(derived_refclk
->phy_pipe_cmn_ctrl1_0
, 0);
1826 regmap_field_write(derived_refclk
->cmn_cdiag_refclk_ovrd_4
, 0);
1829 static int cdns_torrent_derived_refclk_is_enabled(struct clk_hw
*hw
)
1831 struct cdns_torrent_derived_refclk
*derived_refclk
= to_cdns_torrent_derived_refclk(hw
);
1834 regmap_field_read(derived_refclk
->cmn_cdiag_refclk_ovrd_4
, &val
);
1839 static const struct clk_ops cdns_torrent_derived_refclk_ops
= {
1840 .enable
= cdns_torrent_derived_refclk_enable
,
1841 .disable
= cdns_torrent_derived_refclk_disable
,
1842 .is_enabled
= cdns_torrent_derived_refclk_is_enabled
,
1845 static int cdns_torrent_derived_refclk_register(struct cdns_torrent_phy
*cdns_phy
)
1847 struct cdns_torrent_derived_refclk
*derived_refclk
;
1848 struct device
*dev
= cdns_phy
->dev
;
1849 struct clk_init_data
*init
;
1850 const char *parent_name
;
1856 derived_refclk
= devm_kzalloc(dev
, sizeof(*derived_refclk
), GFP_KERNEL
);
1857 if (!derived_refclk
)
1860 snprintf(clk_name
, sizeof(clk_name
), "%s_%s", dev_name(dev
),
1861 clk_names
[CDNS_TORRENT_DERIVED_REFCLK
]);
1863 clk
= devm_clk_get_optional(dev
, "phy_en_refclk");
1865 dev_err(dev
, "No parent clock for derived_refclk\n");
1866 return PTR_ERR(clk
);
1869 init
= &derived_refclk
->clk_data
;
1872 parent_name
= __clk_get_name(clk
);
1873 init
->parent_names
= &parent_name
;
1874 init
->num_parents
= 1;
1876 init
->ops
= &cdns_torrent_derived_refclk_ops
;
1878 init
->name
= clk_name
;
1880 derived_refclk
->phy_pipe_cmn_ctrl1_0
= cdns_phy
->phy_pipe_cmn_ctrl1_0
;
1881 derived_refclk
->cmn_cdiag_refclk_ovrd_4
= cdns_phy
->cmn_cdiag_refclk_ovrd_4
;
1883 derived_refclk
->hw
.init
= init
;
1885 hw
= &derived_refclk
->hw
;
1886 ret
= devm_clk_hw_register(dev
, hw
);
1890 cdns_phy
->clk_hw_data
->hws
[CDNS_TORRENT_DERIVED_REFCLK
] = hw
;
1895 static int cdns_torrent_received_refclk_enable(struct clk_hw
*hw
)
1897 struct cdns_torrent_received_refclk
*received_refclk
= to_cdns_torrent_received_refclk(hw
);
1899 regmap_field_write(received_refclk
->phy_pipe_cmn_ctrl1_0
, 1);
1904 static void cdns_torrent_received_refclk_disable(struct clk_hw
*hw
)
1906 struct cdns_torrent_received_refclk
*received_refclk
= to_cdns_torrent_received_refclk(hw
);
1908 regmap_field_write(received_refclk
->phy_pipe_cmn_ctrl1_0
, 0);
1911 static int cdns_torrent_received_refclk_is_enabled(struct clk_hw
*hw
)
1913 struct cdns_torrent_received_refclk
*received_refclk
= to_cdns_torrent_received_refclk(hw
);
1916 regmap_field_read(received_refclk
->phy_pipe_cmn_ctrl1_0
, &val
);
1917 regmap_field_read(received_refclk
->cmn_cdiag_refclk_ovrd_4
, &cmn_val
);
1919 return val
&& !cmn_val
;
1922 static const struct clk_ops cdns_torrent_received_refclk_ops
= {
1923 .enable
= cdns_torrent_received_refclk_enable
,
1924 .disable
= cdns_torrent_received_refclk_disable
,
1925 .is_enabled
= cdns_torrent_received_refclk_is_enabled
,
1928 static int cdns_torrent_received_refclk_register(struct cdns_torrent_phy
*cdns_phy
)
1930 struct cdns_torrent_received_refclk
*received_refclk
;
1931 struct device
*dev
= cdns_phy
->dev
;
1932 struct clk_init_data
*init
;
1933 const char *parent_name
;
1939 received_refclk
= devm_kzalloc(dev
, sizeof(*received_refclk
), GFP_KERNEL
);
1940 if (!received_refclk
)
1943 snprintf(clk_name
, sizeof(clk_name
), "%s_%s", dev_name(dev
),
1944 clk_names
[CDNS_TORRENT_RECEIVED_REFCLK
]);
1946 clk
= devm_clk_get_optional(dev
, "phy_en_refclk");
1948 dev_err(dev
, "No parent clock for received_refclk\n");
1949 return PTR_ERR(clk
);
1952 init
= &received_refclk
->clk_data
;
1955 parent_name
= __clk_get_name(clk
);
1956 init
->parent_names
= &parent_name
;
1957 init
->num_parents
= 1;
1959 init
->ops
= &cdns_torrent_received_refclk_ops
;
1961 init
->name
= clk_name
;
1963 received_refclk
->phy_pipe_cmn_ctrl1_0
= cdns_phy
->phy_pipe_cmn_ctrl1_0
;
1964 received_refclk
->cmn_cdiag_refclk_ovrd_4
= cdns_phy
->cmn_cdiag_refclk_ovrd_4
;
1966 received_refclk
->hw
.init
= init
;
1968 hw
= &received_refclk
->hw
;
1969 ret
= devm_clk_hw_register(dev
, hw
);
1973 cdns_phy
->clk_hw_data
->hws
[CDNS_TORRENT_RECEIVED_REFCLK
] = hw
;
1978 static int cdns_torrent_refclk_driver_enable(struct clk_hw
*hw
)
1980 struct cdns_torrent_refclk_driver
*refclk_driver
= to_cdns_torrent_refclk_driver(hw
);
1982 regmap_field_write(refclk_driver
->cmn_fields
[CMN_CDIAG_REFCLK_DRV0_CTRL_6
], 0);
1983 regmap_field_write(refclk_driver
->cmn_fields
[CMN_CDIAG_REFCLK_DRV0_CTRL_5
], 1);
1984 regmap_field_write(refclk_driver
->cmn_fields
[CMN_CDIAG_REFCLK_DRV0_CTRL_1
], 0);
1989 static void cdns_torrent_refclk_driver_disable(struct clk_hw
*hw
)
1991 struct cdns_torrent_refclk_driver
*refclk_driver
= to_cdns_torrent_refclk_driver(hw
);
1993 regmap_field_write(refclk_driver
->cmn_fields
[CMN_CDIAG_REFCLK_DRV0_CTRL_1
], 1);
1996 static int cdns_torrent_refclk_driver_is_enabled(struct clk_hw
*hw
)
1998 struct cdns_torrent_refclk_driver
*refclk_driver
= to_cdns_torrent_refclk_driver(hw
);
2001 regmap_field_read(refclk_driver
->cmn_fields
[CMN_CDIAG_REFCLK_DRV0_CTRL_1
], &val
);
2006 static u8
cdns_torrent_refclk_driver_get_parent(struct clk_hw
*hw
)
2008 struct cdns_torrent_refclk_driver
*refclk_driver
= to_cdns_torrent_refclk_driver(hw
);
2011 regmap_field_read(refclk_driver
->cmn_fields
[CMN_CDIAG_REFCLK_DRV0_CTRL_4
], &val
);
2012 return clk_mux_val_to_index(hw
, cdns_torrent_refclk_driver_mux_table
, 0, val
);
2015 static int cdns_torrent_refclk_driver_set_parent(struct clk_hw
*hw
, u8 index
)
2017 struct cdns_torrent_refclk_driver
*refclk_driver
= to_cdns_torrent_refclk_driver(hw
);
2020 val
= cdns_torrent_refclk_driver_mux_table
[index
];
2021 return regmap_field_write(refclk_driver
->cmn_fields
[CMN_CDIAG_REFCLK_DRV0_CTRL_4
], val
);
2024 static const struct clk_ops cdns_torrent_refclk_driver_ops
= {
2025 .enable
= cdns_torrent_refclk_driver_enable
,
2026 .disable
= cdns_torrent_refclk_driver_disable
,
2027 .is_enabled
= cdns_torrent_refclk_driver_is_enabled
,
2028 .determine_rate
= __clk_mux_determine_rate
,
2029 .set_parent
= cdns_torrent_refclk_driver_set_parent
,
2030 .get_parent
= cdns_torrent_refclk_driver_get_parent
,
2033 static int cdns_torrent_refclk_driver_register(struct cdns_torrent_phy
*cdns_phy
)
2035 struct cdns_torrent_refclk_driver
*refclk_driver
;
2036 struct device
*dev
= cdns_phy
->dev
;
2037 struct regmap_field
*field
;
2038 struct clk_init_data
*init
;
2039 const char **parent_names
;
2040 unsigned int num_parents
;
2041 struct regmap
*regmap
;
2046 refclk_driver
= devm_kzalloc(dev
, sizeof(*refclk_driver
), GFP_KERNEL
);
2050 num_parents
= ARRAY_SIZE(refclk_driver_parent_index
);
2051 parent_names
= devm_kzalloc(dev
, (sizeof(char *) * num_parents
), GFP_KERNEL
);
2055 for (i
= 0; i
< num_parents
; i
++) {
2056 hw
= cdns_phy
->clk_hw_data
->hws
[refclk_driver_parent_index
[i
]];
2057 if (IS_ERR_OR_NULL(hw
)) {
2058 dev_err(dev
, "No parent clock for refclk driver clock\n");
2059 return IS_ERR(hw
) ? PTR_ERR(hw
) : -ENOENT
;
2061 parent_names
[i
] = clk_hw_get_name(hw
);
2064 snprintf(clk_name
, sizeof(clk_name
), "%s_%s", dev_name(dev
),
2065 clk_names
[CDNS_TORRENT_REFCLK_DRIVER
]);
2067 init
= &refclk_driver
->clk_data
;
2069 init
->ops
= &cdns_torrent_refclk_driver_ops
;
2070 init
->flags
= CLK_SET_RATE_NO_REPARENT
;
2071 init
->parent_names
= parent_names
;
2072 init
->num_parents
= num_parents
;
2073 init
->name
= clk_name
;
2075 regmap
= cdns_phy
->regmap_common_cdb
;
2077 for (i
= 0; i
< REFCLK_OUT_NUM_CMN_CONFIG
; i
++) {
2078 field
= devm_regmap_field_alloc(dev
, regmap
, refclk_out_cmn_cfg
[i
]);
2079 if (IS_ERR(field
)) {
2080 dev_err(dev
, "Refclk driver CMN reg field init failed\n");
2081 return PTR_ERR(field
);
2083 refclk_driver
->cmn_fields
[i
] = field
;
2086 /* Enable Derived reference clock as default */
2087 regmap_field_write(refclk_driver
->cmn_fields
[CMN_CDIAG_REFCLK_DRV0_CTRL_4
], 1);
2089 refclk_driver
->hw
.init
= init
;
2091 hw
= &refclk_driver
->hw
;
2092 ret
= devm_clk_hw_register(dev
, hw
);
2096 cdns_phy
->clk_hw_data
->hws
[CDNS_TORRENT_REFCLK_DRIVER
] = hw
;
2101 static struct regmap
*cdns_regmap_init(struct device
*dev
, void __iomem
*base
,
2103 u8 reg_offset_shift
,
2104 const struct regmap_config
*config
)
2106 struct cdns_regmap_cdb_context
*ctx
;
2108 ctx
= devm_kzalloc(dev
, sizeof(*ctx
), GFP_KERNEL
);
2110 return ERR_PTR(-ENOMEM
);
2113 ctx
->base
= base
+ block_offset
;
2114 ctx
->reg_offset_shift
= reg_offset_shift
;
2116 return devm_regmap_init(dev
, NULL
, ctx
, config
);
2119 static int cdns_torrent_dp_regfield_init(struct cdns_torrent_phy
*cdns_phy
)
2121 struct device
*dev
= cdns_phy
->dev
;
2122 struct regmap_field
*field
;
2123 struct regmap
*regmap
;
2125 regmap
= cdns_phy
->regmap_dptx_phy_reg
;
2126 field
= devm_regmap_field_alloc(dev
, regmap
, phy_reset_ctrl
);
2127 if (IS_ERR(field
)) {
2128 dev_err(dev
, "PHY_RESET reg field init failed\n");
2129 return PTR_ERR(field
);
2131 cdns_phy
->phy_reset_ctrl
= field
;
2136 static int cdns_torrent_regfield_init(struct cdns_torrent_phy
*cdns_phy
)
2138 struct device
*dev
= cdns_phy
->dev
;
2139 struct regmap_field
*field
;
2140 struct regmap
*regmap
;
2143 regmap
= cdns_phy
->regmap_phy_pcs_common_cdb
;
2144 field
= devm_regmap_field_alloc(dev
, regmap
, phy_pll_cfg
);
2145 if (IS_ERR(field
)) {
2146 dev_err(dev
, "PHY_PLL_CFG reg field init failed\n");
2147 return PTR_ERR(field
);
2149 cdns_phy
->phy_pll_cfg
= field
;
2151 regmap
= cdns_phy
->regmap_phy_pcs_common_cdb
;
2152 field
= devm_regmap_field_alloc(dev
, regmap
, phy_pipe_cmn_ctrl1_0
);
2153 if (IS_ERR(field
)) {
2154 dev_err(dev
, "phy_pipe_cmn_ctrl1_0 reg field init failed\n");
2155 return PTR_ERR(field
);
2157 cdns_phy
->phy_pipe_cmn_ctrl1_0
= field
;
2159 regmap
= cdns_phy
->regmap_common_cdb
;
2160 field
= devm_regmap_field_alloc(dev
, regmap
, cmn_cdiag_refclk_ovrd_4
);
2161 if (IS_ERR(field
)) {
2162 dev_err(dev
, "cmn_cdiag_refclk_ovrd_4 reg field init failed\n");
2163 return PTR_ERR(field
);
2165 cdns_phy
->cmn_cdiag_refclk_ovrd_4
= field
;
2167 regmap
= cdns_phy
->regmap_phy_pma_common_cdb
;
2168 field
= devm_regmap_field_alloc(dev
, regmap
, phy_pma_cmn_ctrl_1
);
2169 if (IS_ERR(field
)) {
2170 dev_err(dev
, "PHY_PMA_CMN_CTRL1 reg field init failed\n");
2171 return PTR_ERR(field
);
2173 cdns_phy
->phy_pma_cmn_ctrl_1
= field
;
2175 regmap
= cdns_phy
->regmap_phy_pma_common_cdb
;
2176 field
= devm_regmap_field_alloc(dev
, regmap
, phy_pma_cmn_ctrl_2
);
2177 if (IS_ERR(field
)) {
2178 dev_err(dev
, "PHY_PMA_CMN_CTRL2 reg field init failed\n");
2179 return PTR_ERR(field
);
2181 cdns_phy
->phy_pma_cmn_ctrl_2
= field
;
2183 regmap
= cdns_phy
->regmap_phy_pma_common_cdb
;
2184 field
= devm_regmap_field_alloc(dev
, regmap
, phy_pma_pll_raw_ctrl
);
2185 if (IS_ERR(field
)) {
2186 dev_err(dev
, "PHY_PMA_PLL_RAW_CTRL reg field init failed\n");
2187 return PTR_ERR(field
);
2189 cdns_phy
->phy_pma_pll_raw_ctrl
= field
;
2191 for (i
= 0; i
< MAX_NUM_LANES
; i
++) {
2192 regmap
= cdns_phy
->regmap_phy_pcs_lane_cdb
[i
];
2193 field
= devm_regmap_field_alloc(dev
, regmap
, phy_pcs_iso_link_ctrl_1
);
2194 if (IS_ERR(field
)) {
2195 dev_err(dev
, "PHY_PCS_ISO_LINK_CTRL reg field init for ln %d failed\n", i
);
2196 return PTR_ERR(field
);
2198 cdns_phy
->phy_pcs_iso_link_ctrl_1
[i
] = field
;
2204 static int cdns_torrent_dp_regmap_init(struct cdns_torrent_phy
*cdns_phy
)
2206 void __iomem
*base
= cdns_phy
->base
;
2207 struct device
*dev
= cdns_phy
->dev
;
2208 struct regmap
*regmap
;
2209 u8 reg_offset_shift
;
2212 reg_offset_shift
= cdns_phy
->init_data
->reg_offset_shift
;
2214 block_offset
= TORRENT_DPTX_PHY_OFFSET
;
2215 regmap
= cdns_regmap_init(dev
, base
, block_offset
,
2217 &cdns_torrent_dptx_phy_config
);
2218 if (IS_ERR(regmap
)) {
2219 dev_err(dev
, "Failed to init DPTX PHY regmap\n");
2220 return PTR_ERR(regmap
);
2222 cdns_phy
->regmap_dptx_phy_reg
= regmap
;
2227 static int cdns_torrent_regmap_init(struct cdns_torrent_phy
*cdns_phy
)
2229 void __iomem
*sd_base
= cdns_phy
->sd_base
;
2230 u8 block_offset_shift
, reg_offset_shift
;
2231 struct device
*dev
= cdns_phy
->dev
;
2232 struct regmap
*regmap
;
2236 block_offset_shift
= cdns_phy
->init_data
->block_offset_shift
;
2237 reg_offset_shift
= cdns_phy
->init_data
->reg_offset_shift
;
2239 for (i
= 0; i
< MAX_NUM_LANES
; i
++) {
2240 block_offset
= TORRENT_TX_LANE_CDB_OFFSET(i
, block_offset_shift
,
2242 regmap
= cdns_regmap_init(dev
, sd_base
, block_offset
,
2244 &cdns_torrent_tx_lane_cdb_config
[i
]);
2245 if (IS_ERR(regmap
)) {
2246 dev_err(dev
, "Failed to init tx lane CDB regmap\n");
2247 return PTR_ERR(regmap
);
2249 cdns_phy
->regmap_tx_lane_cdb
[i
] = regmap
;
2251 block_offset
= TORRENT_RX_LANE_CDB_OFFSET(i
, block_offset_shift
,
2253 regmap
= cdns_regmap_init(dev
, sd_base
, block_offset
,
2255 &cdns_torrent_rx_lane_cdb_config
[i
]);
2256 if (IS_ERR(regmap
)) {
2257 dev_err(dev
, "Failed to init rx lane CDB regmap\n");
2258 return PTR_ERR(regmap
);
2260 cdns_phy
->regmap_rx_lane_cdb
[i
] = regmap
;
2262 block_offset
= TORRENT_PHY_PCS_LANE_CDB_OFFSET(i
, block_offset_shift
,
2264 regmap
= cdns_regmap_init(dev
, sd_base
, block_offset
,
2266 &cdns_torrent_phy_pcs_lane_cdb_config
[i
]);
2267 if (IS_ERR(regmap
)) {
2268 dev_err(dev
, "Failed to init PHY PCS lane CDB regmap\n");
2269 return PTR_ERR(regmap
);
2271 cdns_phy
->regmap_phy_pcs_lane_cdb
[i
] = regmap
;
2274 block_offset
= TORRENT_COMMON_CDB_OFFSET
;
2275 regmap
= cdns_regmap_init(dev
, sd_base
, block_offset
,
2277 &cdns_torrent_common_cdb_config
);
2278 if (IS_ERR(regmap
)) {
2279 dev_err(dev
, "Failed to init common CDB regmap\n");
2280 return PTR_ERR(regmap
);
2282 cdns_phy
->regmap_common_cdb
= regmap
;
2284 block_offset
= TORRENT_PHY_PCS_COMMON_OFFSET(block_offset_shift
);
2285 regmap
= cdns_regmap_init(dev
, sd_base
, block_offset
,
2287 &cdns_torrent_phy_pcs_cmn_cdb_config
);
2288 if (IS_ERR(regmap
)) {
2289 dev_err(dev
, "Failed to init PHY PCS common CDB regmap\n");
2290 return PTR_ERR(regmap
);
2292 cdns_phy
->regmap_phy_pcs_common_cdb
= regmap
;
2294 block_offset
= TORRENT_PHY_PMA_COMMON_OFFSET(block_offset_shift
);
2295 regmap
= cdns_regmap_init(dev
, sd_base
, block_offset
,
2297 &cdns_torrent_phy_pma_cmn_cdb_config
);
2298 if (IS_ERR(regmap
)) {
2299 dev_err(dev
, "Failed to init PHY PMA common CDB regmap\n");
2300 return PTR_ERR(regmap
);
2302 cdns_phy
->regmap_phy_pma_common_cdb
= regmap
;
2307 static int cdns_torrent_phy_init(struct phy
*phy
)
2309 struct cdns_torrent_phy
*cdns_phy
= dev_get_drvdata(phy
->dev
.parent
);
2310 const struct cdns_torrent_vals
*cmn_vals
, *tx_ln_vals
, *rx_ln_vals
;
2311 const struct cdns_torrent_data
*init_data
= cdns_phy
->init_data
;
2312 const struct cdns_torrent_vals
*link_cmn_vals
, *xcvr_diag_vals
;
2313 enum cdns_torrent_ref_clk ref_clk
= cdns_phy
->ref_clk_rate
;
2314 struct cdns_torrent_inst
*inst
= phy_get_drvdata(phy
);
2315 enum cdns_torrent_phy_type phy_type
= inst
->phy_type
;
2316 const struct cdns_torrent_vals
*phy_pma_cmn_vals
;
2317 enum cdns_torrent_ssc_mode ssc
= inst
->ssc_mode
;
2318 const struct cdns_torrent_vals
*pcs_cmn_vals
;
2319 const struct cdns_reg_pairs
*reg_pairs
;
2320 struct regmap
*regmap
;
2324 if (cdns_phy
->already_configured
)
2327 if (cdns_phy
->nsubnodes
> 1) {
2328 if (phy_type
== TYPE_DP
)
2329 return cdns_torrent_dp_multilink_init(cdns_phy
, inst
, phy
);
2334 * Spread spectrum generation is not required or supported
2335 * for SGMII/QSGMII/USXGMII
2337 if (phy_type
== TYPE_SGMII
|| phy_type
== TYPE_QSGMII
|| phy_type
== TYPE_USXGMII
)
2340 /* PHY configuration specific registers for single link */
2341 link_cmn_vals
= cdns_torrent_get_tbl_vals(&init_data
->link_cmn_vals_tbl
,
2343 phy_type
, TYPE_NONE
,
2345 if (link_cmn_vals
) {
2346 reg_pairs
= link_cmn_vals
->reg_pairs
;
2347 num_regs
= link_cmn_vals
->num_regs
;
2348 regmap
= cdns_phy
->regmap_common_cdb
;
2351 * First array value in link_cmn_vals must be of
2352 * PHY_PLL_CFG register
2354 regmap_field_write(cdns_phy
->phy_pll_cfg
, reg_pairs
[0].val
);
2356 for (i
= 1; i
< num_regs
; i
++)
2357 regmap_write(regmap
, reg_pairs
[i
].off
,
2361 xcvr_diag_vals
= cdns_torrent_get_tbl_vals(&init_data
->xcvr_diag_vals_tbl
,
2363 phy_type
, TYPE_NONE
,
2365 if (xcvr_diag_vals
) {
2366 reg_pairs
= xcvr_diag_vals
->reg_pairs
;
2367 num_regs
= xcvr_diag_vals
->num_regs
;
2368 for (i
= 0; i
< inst
->num_lanes
; i
++) {
2369 regmap
= cdns_phy
->regmap_tx_lane_cdb
[i
+ inst
->mlane
];
2370 for (j
= 0; j
< num_regs
; j
++)
2371 regmap_write(regmap
, reg_pairs
[j
].off
,
2376 /* PHY PCS common registers configurations */
2377 pcs_cmn_vals
= cdns_torrent_get_tbl_vals(&init_data
->pcs_cmn_vals_tbl
,
2379 phy_type
, TYPE_NONE
,
2382 reg_pairs
= pcs_cmn_vals
->reg_pairs
;
2383 num_regs
= pcs_cmn_vals
->num_regs
;
2384 regmap
= cdns_phy
->regmap_phy_pcs_common_cdb
;
2385 for (i
= 0; i
< num_regs
; i
++)
2386 regmap_write(regmap
, reg_pairs
[i
].off
,
2390 /* PHY PMA common registers configurations */
2391 phy_pma_cmn_vals
= cdns_torrent_get_tbl_vals(&init_data
->phy_pma_cmn_vals_tbl
,
2393 phy_type
, TYPE_NONE
,
2395 if (phy_pma_cmn_vals
) {
2396 reg_pairs
= phy_pma_cmn_vals
->reg_pairs
;
2397 num_regs
= phy_pma_cmn_vals
->num_regs
;
2398 regmap
= cdns_phy
->regmap_phy_pma_common_cdb
;
2399 for (i
= 0; i
< num_regs
; i
++)
2400 regmap_write(regmap
, reg_pairs
[i
].off
,
2404 /* PMA common registers configurations */
2405 cmn_vals
= cdns_torrent_get_tbl_vals(&init_data
->cmn_vals_tbl
,
2407 phy_type
, TYPE_NONE
,
2410 reg_pairs
= cmn_vals
->reg_pairs
;
2411 num_regs
= cmn_vals
->num_regs
;
2412 regmap
= cdns_phy
->regmap_common_cdb
;
2413 for (i
= 0; i
< num_regs
; i
++)
2414 regmap_write(regmap
, reg_pairs
[i
].off
,
2418 /* PMA TX lane registers configurations */
2419 tx_ln_vals
= cdns_torrent_get_tbl_vals(&init_data
->tx_ln_vals_tbl
,
2421 phy_type
, TYPE_NONE
,
2424 reg_pairs
= tx_ln_vals
->reg_pairs
;
2425 num_regs
= tx_ln_vals
->num_regs
;
2426 for (i
= 0; i
< inst
->num_lanes
; i
++) {
2427 regmap
= cdns_phy
->regmap_tx_lane_cdb
[i
+ inst
->mlane
];
2428 for (j
= 0; j
< num_regs
; j
++)
2429 regmap_write(regmap
, reg_pairs
[j
].off
,
2434 /* PMA RX lane registers configurations */
2435 rx_ln_vals
= cdns_torrent_get_tbl_vals(&init_data
->rx_ln_vals_tbl
,
2437 phy_type
, TYPE_NONE
,
2440 reg_pairs
= rx_ln_vals
->reg_pairs
;
2441 num_regs
= rx_ln_vals
->num_regs
;
2442 for (i
= 0; i
< inst
->num_lanes
; i
++) {
2443 regmap
= cdns_phy
->regmap_rx_lane_cdb
[i
+ inst
->mlane
];
2444 for (j
= 0; j
< num_regs
; j
++)
2445 regmap_write(regmap
, reg_pairs
[j
].off
,
2450 if (phy_type
== TYPE_DP
)
2451 return cdns_torrent_dp_init(phy
);
2456 static const struct phy_ops cdns_torrent_phy_ops
= {
2457 .init
= cdns_torrent_phy_init
,
2458 .configure
= cdns_torrent_dp_configure
,
2459 .power_on
= cdns_torrent_phy_on
,
2460 .power_off
= cdns_torrent_phy_off
,
2461 .owner
= THIS_MODULE
,
2465 int cdns_torrent_phy_configure_multilink(struct cdns_torrent_phy
*cdns_phy
)
2467 const struct cdns_torrent_vals
*cmn_vals
, *tx_ln_vals
, *rx_ln_vals
;
2468 const struct cdns_torrent_data
*init_data
= cdns_phy
->init_data
;
2469 const struct cdns_torrent_vals
*link_cmn_vals
, *xcvr_diag_vals
;
2470 enum cdns_torrent_ref_clk ref_clk1
= cdns_phy
->ref_clk1_rate
;
2471 enum cdns_torrent_ref_clk ref_clk
= cdns_phy
->ref_clk_rate
;
2472 const struct cdns_torrent_vals
*phy_pma_cmn_vals
;
2473 const struct cdns_torrent_vals
*pcs_cmn_vals
;
2474 enum cdns_torrent_phy_type phy_t1
, phy_t2
;
2475 const struct cdns_reg_pairs
*reg_pairs
;
2476 int i
, j
, node
, mlane
, num_lanes
, ret
;
2477 struct device
*dev
= cdns_phy
->dev
;
2478 enum cdns_torrent_ssc_mode ssc
;
2479 struct regmap
*regmap
;
2480 u32 num_regs
, num_protocols
, protocol
;
2482 num_protocols
= hweight32(cdns_phy
->protocol_bitmask
);
2483 /* Maximum 2 protocols are supported */
2484 if (num_protocols
> 2) {
2485 dev_err(dev
, "at most 2 protocols are supported\n");
2491 * Get PHY types directly from subnodes if only 2 subnodes exist.
2492 * It is possible for phy_t1 to be the same as phy_t2 for special
2493 * configurations such as PCIe Multilink.
2495 if (cdns_phy
->nsubnodes
== 2) {
2496 phy_t1
= cdns_phy
->phys
[0].phy_type
;
2497 phy_t2
= cdns_phy
->phys
[1].phy_type
;
2500 * Both PHY types / protocols should be unique.
2501 * If they are the same, it should be expressed with either
2502 * a) Single-Link (1 Sub-node) - handled via PHY APIs
2504 * b) Double-Link (2 Sub-nodes) - handled above
2506 if (num_protocols
!= 2) {
2507 dev_err(dev
, "incorrect representation of link\n");
2511 phy_t1
= fns(cdns_phy
->protocol_bitmask
, 0);
2512 phy_t2
= fns(cdns_phy
->protocol_bitmask
, 1);
2516 * Configure all links with the protocol phy_t1 first followed by
2517 * configuring all links with the protocol phy_t2.
2519 * When phy_t1 = phy_t2, it is a single protocol and configuration
2520 * is performed with a single iteration of the protocol and multiple
2521 * iterations over the sub-nodes (links).
2523 * When phy_t1 != phy_t2, there are two protocols and configuration
2524 * is performed by iterating over all sub-nodes matching the first
2525 * protocol and configuring them first, followed by iterating over
2526 * all sub-nodes matching the second protocol and configuring them
2529 for (protocol
= 0; protocol
< num_protocols
; protocol
++) {
2531 * For the case where num_protocols is 1,
2532 * phy_t1 = phy_t2 and the swap is unnecessary.
2534 * Swapping phy_t1 and phy_t2 is only required when the
2535 * number of protocols is 2 and there are 2 or more links.
2537 if (protocol
== 1) {
2539 * If first protocol with phy_t1 is configured, then
2540 * configure the PHY for second protocol with phy_t2.
2541 * Get the array values as [phy_t2][phy_t1][ssc].
2543 swap(phy_t1
, phy_t2
);
2544 swap(ref_clk
, ref_clk1
);
2547 for (node
= 0; node
< cdns_phy
->nsubnodes
; node
++) {
2548 if (cdns_phy
->phys
[node
].phy_type
!= phy_t1
)
2551 mlane
= cdns_phy
->phys
[node
].mlane
;
2552 ssc
= cdns_phy
->phys
[node
].ssc_mode
;
2553 num_lanes
= cdns_phy
->phys
[node
].num_lanes
;
2556 * PHY configuration specific registers:
2557 * link_cmn_vals depend on combination of PHY types being
2558 * configured and are common for both PHY types, so array
2559 * values should be same for [phy_t1][phy_t2][ssc] and
2560 * [phy_t2][phy_t1][ssc].
2561 * xcvr_diag_vals also depend on combination of PHY types
2562 * being configured, but these can be different for particular
2563 * PHY type and are per lane.
2565 link_cmn_vals
= cdns_torrent_get_tbl_vals(&init_data
->link_cmn_vals_tbl
,
2567 phy_t1
, phy_t2
, ANY_SSC
);
2568 if (link_cmn_vals
) {
2569 reg_pairs
= link_cmn_vals
->reg_pairs
;
2570 num_regs
= link_cmn_vals
->num_regs
;
2571 regmap
= cdns_phy
->regmap_common_cdb
;
2574 * First array value in link_cmn_vals must be of
2575 * PHY_PLL_CFG register
2577 regmap_field_write(cdns_phy
->phy_pll_cfg
,
2580 for (i
= 1; i
< num_regs
; i
++)
2581 regmap_write(regmap
, reg_pairs
[i
].off
,
2585 xcvr_diag_vals
= cdns_torrent_get_tbl_vals(&init_data
->xcvr_diag_vals_tbl
,
2587 phy_t1
, phy_t2
, ANY_SSC
);
2588 if (xcvr_diag_vals
) {
2589 reg_pairs
= xcvr_diag_vals
->reg_pairs
;
2590 num_regs
= xcvr_diag_vals
->num_regs
;
2591 for (i
= 0; i
< num_lanes
; i
++) {
2592 regmap
= cdns_phy
->regmap_tx_lane_cdb
[i
+ mlane
];
2593 for (j
= 0; j
< num_regs
; j
++)
2594 regmap_write(regmap
, reg_pairs
[j
].off
,
2599 /* PHY PCS common registers configurations */
2600 pcs_cmn_vals
= cdns_torrent_get_tbl_vals(&init_data
->pcs_cmn_vals_tbl
,
2602 phy_t1
, phy_t2
, ANY_SSC
);
2604 reg_pairs
= pcs_cmn_vals
->reg_pairs
;
2605 num_regs
= pcs_cmn_vals
->num_regs
;
2606 regmap
= cdns_phy
->regmap_phy_pcs_common_cdb
;
2607 for (i
= 0; i
< num_regs
; i
++)
2608 regmap_write(regmap
, reg_pairs
[i
].off
,
2612 /* PHY PMA common registers configurations */
2614 cdns_torrent_get_tbl_vals(&init_data
->phy_pma_cmn_vals_tbl
,
2615 CLK_ANY
, CLK_ANY
, phy_t1
, phy_t2
,
2617 if (phy_pma_cmn_vals
) {
2618 reg_pairs
= phy_pma_cmn_vals
->reg_pairs
;
2619 num_regs
= phy_pma_cmn_vals
->num_regs
;
2620 regmap
= cdns_phy
->regmap_phy_pma_common_cdb
;
2621 for (i
= 0; i
< num_regs
; i
++)
2622 regmap_write(regmap
, reg_pairs
[i
].off
,
2626 /* PMA common registers configurations */
2627 cmn_vals
= cdns_torrent_get_tbl_vals(&init_data
->cmn_vals_tbl
,
2629 phy_t1
, phy_t2
, ssc
);
2631 reg_pairs
= cmn_vals
->reg_pairs
;
2632 num_regs
= cmn_vals
->num_regs
;
2633 regmap
= cdns_phy
->regmap_common_cdb
;
2634 for (i
= 0; i
< num_regs
; i
++)
2635 regmap_write(regmap
, reg_pairs
[i
].off
,
2639 /* PMA TX lane registers configurations */
2640 tx_ln_vals
= cdns_torrent_get_tbl_vals(&init_data
->tx_ln_vals_tbl
,
2642 phy_t1
, phy_t2
, ssc
);
2644 reg_pairs
= tx_ln_vals
->reg_pairs
;
2645 num_regs
= tx_ln_vals
->num_regs
;
2646 for (i
= 0; i
< num_lanes
; i
++) {
2647 regmap
= cdns_phy
->regmap_tx_lane_cdb
[i
+ mlane
];
2648 for (j
= 0; j
< num_regs
; j
++)
2649 regmap_write(regmap
, reg_pairs
[j
].off
,
2654 /* PMA RX lane registers configurations */
2655 rx_ln_vals
= cdns_torrent_get_tbl_vals(&init_data
->rx_ln_vals_tbl
,
2657 phy_t1
, phy_t2
, ssc
);
2659 reg_pairs
= rx_ln_vals
->reg_pairs
;
2660 num_regs
= rx_ln_vals
->num_regs
;
2661 for (i
= 0; i
< num_lanes
; i
++) {
2662 regmap
= cdns_phy
->regmap_rx_lane_cdb
[i
+ mlane
];
2663 for (j
= 0; j
< num_regs
; j
++)
2664 regmap_write(regmap
, reg_pairs
[j
].off
,
2669 if (phy_t1
== TYPE_DP
) {
2670 ret
= cdns_torrent_dp_get_pll(cdns_phy
, phy_t2
);
2675 reset_control_deassert(cdns_phy
->phys
[node
].lnk_rst
);
2679 /* Take the PHY out of reset */
2680 ret
= reset_control_deassert(cdns_phy
->phy_rst
);
2687 static void cdns_torrent_clk_cleanup(struct cdns_torrent_phy
*cdns_phy
)
2689 struct device
*dev
= cdns_phy
->dev
;
2691 of_clk_del_provider(dev
->of_node
);
2694 static int cdns_torrent_clk_register(struct cdns_torrent_phy
*cdns_phy
)
2696 struct device
*dev
= cdns_phy
->dev
;
2697 struct device_node
*node
= dev
->of_node
;
2698 struct clk_hw_onecell_data
*data
;
2701 data
= devm_kzalloc(dev
, struct_size(data
, hws
, CDNS_TORRENT_OUTPUT_CLOCKS
), GFP_KERNEL
);
2705 data
->num
= CDNS_TORRENT_OUTPUT_CLOCKS
;
2706 cdns_phy
->clk_hw_data
= data
;
2708 ret
= cdns_torrent_derived_refclk_register(cdns_phy
);
2710 dev_err(dev
, "failed to register derived refclk\n");
2714 ret
= cdns_torrent_received_refclk_register(cdns_phy
);
2716 dev_err(dev
, "failed to register received refclk\n");
2720 ret
= cdns_torrent_refclk_driver_register(cdns_phy
);
2722 dev_err(dev
, "failed to register refclk driver\n");
2726 ret
= of_clk_add_hw_provider(node
, of_clk_hw_onecell_get
, data
);
2728 dev_err(dev
, "Failed to add clock provider: %s\n", node
->name
);
2735 static int cdns_torrent_of_get_reset(struct cdns_torrent_phy
*cdns_phy
)
2737 struct device
*dev
= cdns_phy
->dev
;
2739 cdns_phy
->phy_rst
= devm_reset_control_get_exclusive_by_index(dev
, 0);
2740 if (IS_ERR(cdns_phy
->phy_rst
)) {
2741 dev_err(dev
, "%s: failed to get reset\n",
2742 dev
->of_node
->full_name
);
2743 return PTR_ERR(cdns_phy
->phy_rst
);
2746 cdns_phy
->apb_rst
= devm_reset_control_get_optional_exclusive(dev
, "torrent_apb");
2747 if (IS_ERR(cdns_phy
->apb_rst
)) {
2748 dev_err(dev
, "%s: failed to get apb reset\n",
2749 dev
->of_node
->full_name
);
2750 return PTR_ERR(cdns_phy
->apb_rst
);
2756 static int cdns_torrent_of_get_clk(struct cdns_torrent_phy
*cdns_phy
)
2758 /* refclk: Input reference clock for PLL0 */
2759 cdns_phy
->clk
= devm_clk_get(cdns_phy
->dev
, "refclk");
2760 if (IS_ERR(cdns_phy
->clk
))
2761 return dev_err_probe(cdns_phy
->dev
, PTR_ERR(cdns_phy
->clk
),
2762 "phy ref clock not found\n");
2764 /* refclk1: Input reference clock for PLL1 */
2765 cdns_phy
->clk1
= devm_clk_get_optional(cdns_phy
->dev
, "pll1_refclk");
2766 if (IS_ERR(cdns_phy
->clk1
))
2767 return dev_err_probe(cdns_phy
->dev
, PTR_ERR(cdns_phy
->clk1
),
2768 "phy PLL1 ref clock not found\n");
2773 static int cdns_torrent_clk(struct cdns_torrent_phy
*cdns_phy
)
2775 unsigned long ref_clk1_rate
;
2776 unsigned long ref_clk_rate
;
2779 ret
= clk_prepare_enable(cdns_phy
->clk
);
2781 dev_err(cdns_phy
->dev
, "Failed to prepare ref clock: %d\n", ret
);
2785 ref_clk_rate
= clk_get_rate(cdns_phy
->clk
);
2786 if (!ref_clk_rate
) {
2787 dev_err(cdns_phy
->dev
, "Failed to get ref clock rate\n");
2792 switch (ref_clk_rate
) {
2793 case REF_CLK_19_2MHZ
:
2794 cdns_phy
->ref_clk_rate
= CLK_19_2_MHZ
;
2797 cdns_phy
->ref_clk_rate
= CLK_25_MHZ
;
2799 case REF_CLK_100MHZ
:
2800 cdns_phy
->ref_clk_rate
= CLK_100_MHZ
;
2802 case REF_CLK_156_25MHZ
:
2803 cdns_phy
->ref_clk_rate
= CLK_156_25_MHZ
;
2806 dev_err(cdns_phy
->dev
, "Invalid ref clock rate\n");
2811 if (cdns_phy
->clk1
) {
2812 ret
= clk_prepare_enable(cdns_phy
->clk1
);
2814 dev_err(cdns_phy
->dev
, "Failed to prepare PLL1 ref clock: %d\n", ret
);
2818 ref_clk1_rate
= clk_get_rate(cdns_phy
->clk1
);
2819 if (!ref_clk1_rate
) {
2820 dev_err(cdns_phy
->dev
, "Failed to get PLL1 ref clock rate\n");
2825 switch (ref_clk1_rate
) {
2826 case REF_CLK_19_2MHZ
:
2827 cdns_phy
->ref_clk1_rate
= CLK_19_2_MHZ
;
2830 cdns_phy
->ref_clk1_rate
= CLK_25_MHZ
;
2832 case REF_CLK_100MHZ
:
2833 cdns_phy
->ref_clk1_rate
= CLK_100_MHZ
;
2835 case REF_CLK_156_25MHZ
:
2836 cdns_phy
->ref_clk1_rate
= CLK_156_25_MHZ
;
2839 dev_err(cdns_phy
->dev
, "Invalid PLL1 ref clock rate\n");
2844 cdns_phy
->ref_clk1_rate
= cdns_phy
->ref_clk_rate
;
2850 clk_disable_unprepare(cdns_phy
->clk1
);
2852 clk_disable_unprepare(cdns_phy
->clk
);
2856 static int cdns_torrent_phy_probe(struct platform_device
*pdev
)
2858 struct cdns_torrent_phy
*cdns_phy
;
2859 struct device
*dev
= &pdev
->dev
;
2860 struct phy_provider
*phy_provider
;
2861 const struct cdns_torrent_data
*data
;
2862 struct device_node
*child
;
2863 int ret
, subnodes
, node
= 0, i
;
2864 u32 total_num_lanes
= 0;
2865 u8 init_dp_regmap
= 0;
2868 /* Get init data for this PHY */
2869 data
= of_device_get_match_data(dev
);
2873 cdns_phy
= devm_kzalloc(dev
, sizeof(*cdns_phy
), GFP_KERNEL
);
2877 dev_set_drvdata(dev
, cdns_phy
);
2878 cdns_phy
->dev
= dev
;
2879 cdns_phy
->init_data
= data
;
2880 cdns_phy
->protocol_bitmask
= 0;
2882 cdns_phy
->sd_base
= devm_platform_ioremap_resource(pdev
, 0);
2883 if (IS_ERR(cdns_phy
->sd_base
))
2884 return PTR_ERR(cdns_phy
->sd_base
);
2886 subnodes
= of_get_available_child_count(dev
->of_node
);
2887 if (subnodes
== 0) {
2888 dev_err(dev
, "No available link subnodes found\n");
2892 ret
= cdns_torrent_regmap_init(cdns_phy
);
2896 ret
= cdns_torrent_regfield_init(cdns_phy
);
2900 ret
= cdns_torrent_clk_register(cdns_phy
);
2904 ret
= cdns_torrent_of_get_reset(cdns_phy
);
2908 ret
= cdns_torrent_of_get_clk(cdns_phy
);
2912 regmap_field_read(cdns_phy
->phy_pma_cmn_ctrl_1
, &cdns_phy
->already_configured
);
2914 if (!cdns_phy
->already_configured
) {
2915 ret
= cdns_torrent_clk(cdns_phy
);
2920 reset_control_deassert(cdns_phy
->apb_rst
);
2923 for_each_available_child_of_node(dev
->of_node
, child
) {
2926 /* PHY subnode name must be 'phy'. */
2927 if (!(of_node_name_eq(child
, "phy")))
2930 cdns_phy
->phys
[node
].lnk_rst
=
2931 of_reset_control_array_get_exclusive(child
);
2932 if (IS_ERR(cdns_phy
->phys
[node
].lnk_rst
)) {
2933 dev_err(dev
, "%s: failed to get reset\n",
2935 ret
= PTR_ERR(cdns_phy
->phys
[node
].lnk_rst
);
2939 if (of_property_read_u32(child
, "reg",
2940 &cdns_phy
->phys
[node
].mlane
)) {
2941 dev_err(dev
, "%s: No \"reg\"-property.\n",
2947 if (of_property_read_u32(child
, "cdns,phy-type", &phy_type
)) {
2948 dev_err(dev
, "%s: No \"cdns,phy-type\"-property.\n",
2956 cdns_phy
->phys
[node
].phy_type
= TYPE_PCIE
;
2959 cdns_phy
->phys
[node
].phy_type
= TYPE_DP
;
2961 case PHY_TYPE_SGMII
:
2962 cdns_phy
->phys
[node
].phy_type
= TYPE_SGMII
;
2964 case PHY_TYPE_QSGMII
:
2965 cdns_phy
->phys
[node
].phy_type
= TYPE_QSGMII
;
2968 cdns_phy
->phys
[node
].phy_type
= TYPE_USB
;
2970 case PHY_TYPE_USXGMII
:
2971 cdns_phy
->phys
[node
].phy_type
= TYPE_USXGMII
;
2974 dev_err(dev
, "Unsupported protocol\n");
2979 if (of_property_read_u32(child
, "cdns,num-lanes",
2980 &cdns_phy
->phys
[node
].num_lanes
)) {
2981 dev_err(dev
, "%s: No \"cdns,num-lanes\"-property.\n",
2987 total_num_lanes
+= cdns_phy
->phys
[node
].num_lanes
;
2990 cdns_phy
->phys
[node
].ssc_mode
= NO_SSC
;
2991 of_property_read_u32(child
, "cdns,ssc-mode",
2992 &cdns_phy
->phys
[node
].ssc_mode
);
2994 gphy
= devm_phy_create(dev
, child
, &cdns_torrent_phy_ops
);
2996 ret
= PTR_ERR(gphy
);
3000 if (cdns_phy
->phys
[node
].phy_type
== TYPE_DP
) {
3001 switch (cdns_phy
->phys
[node
].num_lanes
) {
3005 /* valid number of lanes */
3008 dev_err(dev
, "unsupported number of lanes: %d\n",
3009 cdns_phy
->phys
[node
].num_lanes
);
3014 cdns_phy
->max_bit_rate
= DEFAULT_MAX_BIT_RATE
;
3015 of_property_read_u32(child
, "cdns,max-bit-rate",
3016 &cdns_phy
->max_bit_rate
);
3018 switch (cdns_phy
->max_bit_rate
) {
3027 /* valid bit rate */
3030 dev_err(dev
, "unsupported max bit rate: %dMbps\n",
3031 cdns_phy
->max_bit_rate
);
3036 /* DPTX registers */
3037 cdns_phy
->base
= devm_platform_ioremap_resource(pdev
, 1);
3038 if (IS_ERR(cdns_phy
->base
)) {
3039 ret
= PTR_ERR(cdns_phy
->base
);
3043 if (!init_dp_regmap
) {
3044 ret
= cdns_torrent_dp_regmap_init(cdns_phy
);
3048 ret
= cdns_torrent_dp_regfield_init(cdns_phy
);
3055 dev_dbg(dev
, "DP max bit rate %d.%03d Gbps\n",
3056 cdns_phy
->max_bit_rate
/ 1000,
3057 cdns_phy
->max_bit_rate
% 1000);
3059 gphy
->attrs
.bus_width
= cdns_phy
->phys
[node
].num_lanes
;
3060 gphy
->attrs
.max_link_rate
= cdns_phy
->max_bit_rate
;
3061 gphy
->attrs
.mode
= PHY_MODE_DP
;
3064 cdns_phy
->phys
[node
].phy
= gphy
;
3065 cdns_phy
->protocol_bitmask
|= BIT(cdns_phy
->phys
[node
].phy_type
);
3066 phy_set_drvdata(gphy
, &cdns_phy
->phys
[node
]);
3070 cdns_phy
->nsubnodes
= node
;
3072 if (total_num_lanes
> MAX_NUM_LANES
) {
3073 dev_err(dev
, "Invalid lane configuration\n");
3078 if (cdns_phy
->nsubnodes
> 1 && !cdns_phy
->already_configured
) {
3079 ret
= cdns_torrent_phy_configure_multilink(cdns_phy
);
3084 phy_provider
= devm_of_phy_provider_register(dev
, of_phy_simple_xlate
);
3085 if (IS_ERR(phy_provider
)) {
3086 ret
= PTR_ERR(phy_provider
);
3090 if (cdns_phy
->nsubnodes
> 1)
3091 dev_dbg(dev
, "Multi-link: %s (%d lanes) & %s (%d lanes)",
3092 cdns_torrent_get_phy_type(cdns_phy
->phys
[0].phy_type
),
3093 cdns_phy
->phys
[0].num_lanes
,
3094 cdns_torrent_get_phy_type(cdns_phy
->phys
[1].phy_type
),
3095 cdns_phy
->phys
[1].num_lanes
);
3097 dev_dbg(dev
, "Single link: %s (%d lanes)",
3098 cdns_torrent_get_phy_type(cdns_phy
->phys
[0].phy_type
),
3099 cdns_phy
->phys
[0].num_lanes
);
3106 for (i
= 0; i
< node
; i
++)
3107 reset_control_put(cdns_phy
->phys
[i
].lnk_rst
);
3109 reset_control_assert(cdns_phy
->apb_rst
);
3110 clk_disable_unprepare(cdns_phy
->clk1
);
3111 clk_disable_unprepare(cdns_phy
->clk
);
3113 cdns_torrent_clk_cleanup(cdns_phy
);
3117 static void cdns_torrent_phy_remove(struct platform_device
*pdev
)
3119 struct cdns_torrent_phy
*cdns_phy
= platform_get_drvdata(pdev
);
3122 reset_control_assert(cdns_phy
->phy_rst
);
3123 reset_control_assert(cdns_phy
->apb_rst
);
3124 for (i
= 0; i
< cdns_phy
->nsubnodes
; i
++) {
3125 reset_control_assert(cdns_phy
->phys
[i
].lnk_rst
);
3126 reset_control_put(cdns_phy
->phys
[i
].lnk_rst
);
3129 clk_disable_unprepare(cdns_phy
->clk1
);
3130 clk_disable_unprepare(cdns_phy
->clk
);
3131 cdns_torrent_clk_cleanup(cdns_phy
);
3134 /* SGMII and QSGMII link configuration */
3135 static const struct cdns_reg_pairs sgmii_qsgmii_link_cmn_regs
[] = {
3136 {0x0002, PHY_PLL_CFG
}
3139 static const struct cdns_reg_pairs sgmii_qsgmii_xcvr_diag_ln_regs
[] = {
3140 {0x0003, XCVR_DIAG_HSCLK_DIV
},
3141 {0x0113, XCVR_DIAG_PLLDRC_CTRL
}
3144 static const struct cdns_torrent_vals sgmii_qsgmii_link_cmn_vals
= {
3145 .reg_pairs
= sgmii_qsgmii_link_cmn_regs
,
3146 .num_regs
= ARRAY_SIZE(sgmii_qsgmii_link_cmn_regs
),
3149 static const struct cdns_torrent_vals sgmii_qsgmii_xcvr_diag_ln_vals
= {
3150 .reg_pairs
= sgmii_qsgmii_xcvr_diag_ln_regs
,
3151 .num_regs
= ARRAY_SIZE(sgmii_qsgmii_xcvr_diag_ln_regs
),
3154 static int cdns_torrent_phy_suspend_noirq(struct device
*dev
)
3156 struct cdns_torrent_phy
*cdns_phy
= dev_get_drvdata(dev
);
3159 reset_control_assert(cdns_phy
->phy_rst
);
3160 reset_control_assert(cdns_phy
->apb_rst
);
3161 for (i
= 0; i
< cdns_phy
->nsubnodes
; i
++)
3162 reset_control_assert(cdns_phy
->phys
[i
].lnk_rst
);
3164 if (cdns_phy
->already_configured
)
3165 cdns_phy
->already_configured
= 0;
3167 clk_disable_unprepare(cdns_phy
->clk1
);
3168 clk_disable_unprepare(cdns_phy
->clk
);
3174 static int cdns_torrent_phy_resume_noirq(struct device
*dev
)
3176 struct cdns_torrent_phy
*cdns_phy
= dev_get_drvdata(dev
);
3177 int node
= cdns_phy
->nsubnodes
;
3180 ret
= cdns_torrent_clk(cdns_phy
);
3185 reset_control_deassert(cdns_phy
->apb_rst
);
3187 if (cdns_phy
->nsubnodes
> 1) {
3188 ret
= cdns_torrent_phy_configure_multilink(cdns_phy
);
3196 for (i
= 0; i
< node
; i
++)
3197 reset_control_assert(cdns_phy
->phys
[i
].lnk_rst
);
3198 reset_control_assert(cdns_phy
->apb_rst
);
3200 clk_disable_unprepare(cdns_phy
->clk1
);
3201 clk_disable_unprepare(cdns_phy
->clk
);
3206 static DEFINE_NOIRQ_DEV_PM_OPS(cdns_torrent_phy_pm_ops
,
3207 cdns_torrent_phy_suspend_noirq
,
3208 cdns_torrent_phy_resume_noirq
);
3210 /* USB and DP link configuration */
3211 static const struct cdns_reg_pairs usb_dp_link_cmn_regs
[] = {
3212 {0x0002, PHY_PLL_CFG
},
3213 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0
}
3216 static const struct cdns_reg_pairs usb_dp_xcvr_diag_ln_regs
[] = {
3217 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3218 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3219 {0x0041, XCVR_DIAG_PLLDRC_CTRL
}
3222 static const struct cdns_reg_pairs dp_usb_xcvr_diag_ln_regs
[] = {
3223 {0x0001, XCVR_DIAG_HSCLK_SEL
},
3224 {0x0009, XCVR_DIAG_PLLDRC_CTRL
}
3227 static const struct cdns_torrent_vals usb_dp_link_cmn_vals
= {
3228 .reg_pairs
= usb_dp_link_cmn_regs
,
3229 .num_regs
= ARRAY_SIZE(usb_dp_link_cmn_regs
),
3232 static const struct cdns_torrent_vals usb_dp_xcvr_diag_ln_vals
= {
3233 .reg_pairs
= usb_dp_xcvr_diag_ln_regs
,
3234 .num_regs
= ARRAY_SIZE(usb_dp_xcvr_diag_ln_regs
),
3237 static const struct cdns_torrent_vals dp_usb_xcvr_diag_ln_vals
= {
3238 .reg_pairs
= dp_usb_xcvr_diag_ln_regs
,
3239 .num_regs
= ARRAY_SIZE(dp_usb_xcvr_diag_ln_regs
),
3242 /* USXGMII and SGMII/QSGMII link configuration */
3243 static const struct cdns_reg_pairs usxgmii_sgmii_link_cmn_regs
[] = {
3244 {0x0002, PHY_PLL_CFG
},
3245 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M0
},
3246 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0
}
3249 static const struct cdns_reg_pairs usxgmii_sgmii_xcvr_diag_ln_regs
[] = {
3250 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3251 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3252 {0x0001, XCVR_DIAG_PLLDRC_CTRL
}
3255 static const struct cdns_reg_pairs sgmii_usxgmii_xcvr_diag_ln_regs
[] = {
3256 {0x0111, XCVR_DIAG_HSCLK_SEL
},
3257 {0x0103, XCVR_DIAG_HSCLK_DIV
},
3258 {0x0A9B, XCVR_DIAG_PLLDRC_CTRL
}
3261 static const struct cdns_torrent_vals usxgmii_sgmii_link_cmn_vals
= {
3262 .reg_pairs
= usxgmii_sgmii_link_cmn_regs
,
3263 .num_regs
= ARRAY_SIZE(usxgmii_sgmii_link_cmn_regs
),
3266 static const struct cdns_torrent_vals usxgmii_sgmii_xcvr_diag_ln_vals
= {
3267 .reg_pairs
= usxgmii_sgmii_xcvr_diag_ln_regs
,
3268 .num_regs
= ARRAY_SIZE(usxgmii_sgmii_xcvr_diag_ln_regs
),
3271 static const struct cdns_torrent_vals sgmii_usxgmii_xcvr_diag_ln_vals
= {
3272 .reg_pairs
= sgmii_usxgmii_xcvr_diag_ln_regs
,
3273 .num_regs
= ARRAY_SIZE(sgmii_usxgmii_xcvr_diag_ln_regs
),
3276 /* Multilink USXGMII, using PLL0, 156.25 MHz Ref clk, no SSC */
3277 static const struct cdns_reg_pairs ml_usxgmii_pll0_156_25_no_ssc_cmn_regs
[] = {
3278 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0
},
3279 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0
},
3280 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR
},
3281 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR
},
3282 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START
},
3283 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START
},
3284 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
3285 {0x0138, CMN_PLL0_LOCK_REFCNT_START
},
3286 {0x0138, CMN_PLL0_LOCK_PLLCNT_START
}
3289 static const struct cdns_torrent_vals ml_usxgmii_pll0_156_25_no_ssc_cmn_vals
= {
3290 .reg_pairs
= ml_usxgmii_pll0_156_25_no_ssc_cmn_regs
,
3291 .num_regs
= ARRAY_SIZE(ml_usxgmii_pll0_156_25_no_ssc_cmn_regs
),
3294 /* Multilink SGMII/QSGMII, using PLL1, 100 MHz Ref clk, no SSC */
3295 static const struct cdns_reg_pairs ml_sgmii_pll1_100_no_ssc_cmn_regs
[] = {
3296 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0
},
3297 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0
},
3298 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0
},
3299 {0x0003, CMN_PLL1_VCOCAL_TCTRL
},
3300 {0x007F, CMN_TXPUCAL_TUNE
},
3301 {0x007F, CMN_TXPDCAL_TUNE
}
3304 static const struct cdns_torrent_vals ml_sgmii_pll1_100_no_ssc_cmn_vals
= {
3305 .reg_pairs
= ml_sgmii_pll1_100_no_ssc_cmn_regs
,
3306 .num_regs
= ARRAY_SIZE(ml_sgmii_pll1_100_no_ssc_cmn_regs
),
3309 /* TI J7200, Multilink USXGMII, using PLL0, 156.25 MHz Ref clk, no SSC */
3310 static const struct cdns_reg_pairs j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs
[] = {
3311 {0x0014, CMN_SSM_BIAS_TMR
},
3312 {0x0028, CMN_PLLSM0_PLLPRE_TMR
},
3313 {0x00A4, CMN_PLLSM0_PLLLOCK_TMR
},
3314 {0x0062, CMN_BGCAL_INIT_TMR
},
3315 {0x0062, CMN_BGCAL_ITER_TMR
},
3316 {0x0014, CMN_IBCAL_INIT_TMR
},
3317 {0x0018, CMN_TXPUCAL_INIT_TMR
},
3318 {0x0005, CMN_TXPUCAL_ITER_TMR
},
3319 {0x0018, CMN_TXPDCAL_INIT_TMR
},
3320 {0x0005, CMN_TXPDCAL_ITER_TMR
},
3321 {0x024A, CMN_RXCAL_INIT_TMR
},
3322 {0x0005, CMN_RXCAL_ITER_TMR
},
3323 {0x000B, CMN_SD_CAL_REFTIM_START
},
3324 {0x0132, CMN_SD_CAL_PLLCNT_START
},
3325 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0
},
3326 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0
},
3327 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR
},
3328 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR
},
3329 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START
},
3330 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START
},
3331 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
3332 {0x0138, CMN_PLL0_LOCK_REFCNT_START
},
3333 {0x0138, CMN_PLL0_LOCK_PLLCNT_START
}
3336 static const struct cdns_torrent_vals j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_vals
= {
3337 .reg_pairs
= j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs
,
3338 .num_regs
= ARRAY_SIZE(j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs
),
3341 /* TI J7200, Multilink SGMII/QSGMII, using PLL1, 100 MHz Ref clk, no SSC */
3342 static const struct cdns_reg_pairs j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs
[] = {
3343 {0x0028, CMN_PLLSM1_PLLPRE_TMR
},
3344 {0x00A4, CMN_PLLSM1_PLLLOCK_TMR
},
3345 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0
},
3346 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0
},
3347 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0
},
3348 {0x0003, CMN_PLL1_VCOCAL_TCTRL
},
3349 {0x007F, CMN_TXPUCAL_TUNE
},
3350 {0x007F, CMN_TXPDCAL_TUNE
}
3353 static const struct cdns_torrent_vals j7200_ml_sgmii_pll1_100_no_ssc_cmn_vals
= {
3354 .reg_pairs
= j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs
,
3355 .num_regs
= ARRAY_SIZE(j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs
),
3358 /* PCIe and USXGMII link configuration */
3359 static const struct cdns_reg_pairs pcie_usxgmii_link_cmn_regs
[] = {
3360 {0x0003, PHY_PLL_CFG
},
3361 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0
},
3362 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1
},
3363 {0x0400, CMN_PDIAG_PLL1_CLK_SEL_M0
}
3366 static const struct cdns_reg_pairs pcie_usxgmii_xcvr_diag_ln_regs
[] = {
3367 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3368 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3369 {0x0012, XCVR_DIAG_PLLDRC_CTRL
}
3372 static const struct cdns_reg_pairs usxgmii_pcie_xcvr_diag_ln_regs
[] = {
3373 {0x0011, XCVR_DIAG_HSCLK_SEL
},
3374 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3375 {0x0089, XCVR_DIAG_PLLDRC_CTRL
}
3378 static const struct cdns_torrent_vals pcie_usxgmii_link_cmn_vals
= {
3379 .reg_pairs
= pcie_usxgmii_link_cmn_regs
,
3380 .num_regs
= ARRAY_SIZE(pcie_usxgmii_link_cmn_regs
),
3383 static const struct cdns_torrent_vals pcie_usxgmii_xcvr_diag_ln_vals
= {
3384 .reg_pairs
= pcie_usxgmii_xcvr_diag_ln_regs
,
3385 .num_regs
= ARRAY_SIZE(pcie_usxgmii_xcvr_diag_ln_regs
),
3388 static const struct cdns_torrent_vals usxgmii_pcie_xcvr_diag_ln_vals
= {
3389 .reg_pairs
= usxgmii_pcie_xcvr_diag_ln_regs
,
3390 .num_regs
= ARRAY_SIZE(usxgmii_pcie_xcvr_diag_ln_regs
),
3394 * Multilink USXGMII, using PLL1, 156.25 MHz Ref clk, no SSC
3396 static const struct cdns_reg_pairs ml_usxgmii_pll1_156_25_no_ssc_cmn_regs
[] = {
3397 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0
},
3398 {0x0014, CMN_PLL1_DSM_FBH_OVRD_M0
},
3399 {0x0005, CMN_PLL1_DSM_FBL_OVRD_M0
},
3400 {0x061B, CMN_PLL1_VCOCAL_INIT_TMR
},
3401 {0x0019, CMN_PLL1_VCOCAL_ITER_TMR
},
3402 {0x1354, CMN_PLL1_VCOCAL_REFTIM_START
},
3403 {0x1354, CMN_PLL1_VCOCAL_PLLCNT_START
},
3404 {0x0003, CMN_PLL1_VCOCAL_TCTRL
},
3405 {0x0138, CMN_PLL1_LOCK_REFCNT_START
},
3406 {0x0138, CMN_PLL1_LOCK_PLLCNT_START
},
3407 {0x007F, CMN_TXPUCAL_TUNE
},
3408 {0x007F, CMN_TXPDCAL_TUNE
}
3411 static const struct cdns_reg_pairs ml_usxgmii_156_25_no_ssc_tx_ln_regs
[] = {
3412 {0x00F3, TX_PSC_A0
},
3413 {0x04A2, TX_PSC_A2
},
3414 {0x04A2, TX_PSC_A3
},
3415 {0x0000, TX_TXCC_CPOST_MULT_00
},
3416 {0x0000, XCVR_DIAG_PSC_OVRD
}
3419 static const struct cdns_reg_pairs ml_usxgmii_156_25_no_ssc_rx_ln_regs
[] = {
3420 {0x091D, RX_PSC_A0
},
3421 {0x0900, RX_PSC_A2
},
3422 {0x0100, RX_PSC_A3
},
3423 {0x0030, RX_REE_SMGM_CTRL1
},
3424 {0x03C7, RX_REE_GCSM1_EQENM_PH1
},
3425 {0x01C7, RX_REE_GCSM1_EQENM_PH2
},
3426 {0x0000, RX_DIAG_DFE_CTRL
},
3427 {0x0019, RX_REE_TAP1_CLIP
},
3428 {0x0019, RX_REE_TAP2TON_CLIP
},
3429 {0x00B9, RX_DIAG_NQST_CTRL
},
3430 {0x0C21, RX_DIAG_DFE_AMP_TUNE_2
},
3431 {0x0002, RX_DIAG_DFE_AMP_TUNE_3
},
3432 {0x0033, RX_DIAG_PI_RATE
},
3433 {0x0001, RX_DIAG_ACYA
},
3434 {0x018C, RX_CDRLF_CNFG
}
3437 static const struct cdns_torrent_vals ml_usxgmii_pll1_156_25_no_ssc_cmn_vals
= {
3438 .reg_pairs
= ml_usxgmii_pll1_156_25_no_ssc_cmn_regs
,
3439 .num_regs
= ARRAY_SIZE(ml_usxgmii_pll1_156_25_no_ssc_cmn_regs
),
3442 static const struct cdns_torrent_vals ml_usxgmii_156_25_no_ssc_tx_ln_vals
= {
3443 .reg_pairs
= ml_usxgmii_156_25_no_ssc_tx_ln_regs
,
3444 .num_regs
= ARRAY_SIZE(ml_usxgmii_156_25_no_ssc_tx_ln_regs
),
3447 static const struct cdns_torrent_vals ml_usxgmii_156_25_no_ssc_rx_ln_vals
= {
3448 .reg_pairs
= ml_usxgmii_156_25_no_ssc_rx_ln_regs
,
3449 .num_regs
= ARRAY_SIZE(ml_usxgmii_156_25_no_ssc_rx_ln_regs
),
3452 /* TI USXGMII configuration: Enable cmn_refclk_rcv_out_en */
3453 static const struct cdns_reg_pairs ti_usxgmii_phy_pma_cmn_regs
[] = {
3454 {0x0040, PHY_PMA_CMN_CTRL1
},
3457 static const struct cdns_torrent_vals ti_usxgmii_phy_pma_cmn_vals
= {
3458 .reg_pairs
= ti_usxgmii_phy_pma_cmn_regs
,
3459 .num_regs
= ARRAY_SIZE(ti_usxgmii_phy_pma_cmn_regs
),
3462 /* Single USXGMII link configuration */
3463 static const struct cdns_reg_pairs sl_usxgmii_link_cmn_regs
[] = {
3464 {0x0000, PHY_PLL_CFG
},
3465 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M0
}
3468 static const struct cdns_reg_pairs sl_usxgmii_xcvr_diag_ln_regs
[] = {
3469 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3470 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3471 {0x0001, XCVR_DIAG_PLLDRC_CTRL
}
3474 static const struct cdns_torrent_vals sl_usxgmii_link_cmn_vals
= {
3475 .reg_pairs
= sl_usxgmii_link_cmn_regs
,
3476 .num_regs
= ARRAY_SIZE(sl_usxgmii_link_cmn_regs
),
3479 static const struct cdns_torrent_vals sl_usxgmii_xcvr_diag_ln_vals
= {
3480 .reg_pairs
= sl_usxgmii_xcvr_diag_ln_regs
,
3481 .num_regs
= ARRAY_SIZE(sl_usxgmii_xcvr_diag_ln_regs
),
3484 /* Single link USXGMII, 156.25 MHz Ref clk, no SSC */
3485 static const struct cdns_reg_pairs sl_usxgmii_156_25_no_ssc_cmn_regs
[] = {
3486 {0x0014, CMN_SSM_BIAS_TMR
},
3487 {0x0028, CMN_PLLSM0_PLLPRE_TMR
},
3488 {0x00A4, CMN_PLLSM0_PLLLOCK_TMR
},
3489 {0x0028, CMN_PLLSM1_PLLPRE_TMR
},
3490 {0x00A4, CMN_PLLSM1_PLLLOCK_TMR
},
3491 {0x0062, CMN_BGCAL_INIT_TMR
},
3492 {0x0062, CMN_BGCAL_ITER_TMR
},
3493 {0x0014, CMN_IBCAL_INIT_TMR
},
3494 {0x0018, CMN_TXPUCAL_INIT_TMR
},
3495 {0x0005, CMN_TXPUCAL_ITER_TMR
},
3496 {0x0018, CMN_TXPDCAL_INIT_TMR
},
3497 {0x0005, CMN_TXPDCAL_ITER_TMR
},
3498 {0x024A, CMN_RXCAL_INIT_TMR
},
3499 {0x0005, CMN_RXCAL_ITER_TMR
},
3500 {0x000B, CMN_SD_CAL_REFTIM_START
},
3501 {0x0132, CMN_SD_CAL_PLLCNT_START
},
3502 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0
},
3503 {0x0014, CMN_PLL0_DSM_FBH_OVRD_M0
},
3504 {0x0014, CMN_PLL1_DSM_FBH_OVRD_M0
},
3505 {0x0005, CMN_PLL0_DSM_FBL_OVRD_M0
},
3506 {0x0005, CMN_PLL1_DSM_FBL_OVRD_M0
},
3507 {0x061B, CMN_PLL0_VCOCAL_INIT_TMR
},
3508 {0x061B, CMN_PLL1_VCOCAL_INIT_TMR
},
3509 {0x0019, CMN_PLL0_VCOCAL_ITER_TMR
},
3510 {0x0019, CMN_PLL1_VCOCAL_ITER_TMR
},
3511 {0x1354, CMN_PLL0_VCOCAL_REFTIM_START
},
3512 {0x1354, CMN_PLL1_VCOCAL_REFTIM_START
},
3513 {0x1354, CMN_PLL0_VCOCAL_PLLCNT_START
},
3514 {0x1354, CMN_PLL1_VCOCAL_PLLCNT_START
},
3515 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
3516 {0x0003, CMN_PLL1_VCOCAL_TCTRL
},
3517 {0x0138, CMN_PLL0_LOCK_REFCNT_START
},
3518 {0x0138, CMN_PLL1_LOCK_REFCNT_START
},
3519 {0x0138, CMN_PLL0_LOCK_PLLCNT_START
},
3520 {0x0138, CMN_PLL1_LOCK_PLLCNT_START
}
3523 static const struct cdns_reg_pairs usxgmii_156_25_no_ssc_tx_ln_regs
[] = {
3524 {0x07A2, TX_RCVDET_ST_TMR
},
3525 {0x00F3, TX_PSC_A0
},
3526 {0x04A2, TX_PSC_A2
},
3527 {0x04A2, TX_PSC_A3
},
3528 {0x0000, TX_TXCC_CPOST_MULT_00
},
3529 {0x0000, XCVR_DIAG_PSC_OVRD
}
3532 static const struct cdns_reg_pairs usxgmii_156_25_no_ssc_rx_ln_regs
[] = {
3533 {0x0014, RX_SDCAL0_INIT_TMR
},
3534 {0x0062, RX_SDCAL0_ITER_TMR
},
3535 {0x0014, RX_SDCAL1_INIT_TMR
},
3536 {0x0062, RX_SDCAL1_ITER_TMR
},
3537 {0x091D, RX_PSC_A0
},
3538 {0x0900, RX_PSC_A2
},
3539 {0x0100, RX_PSC_A3
},
3540 {0x0030, RX_REE_SMGM_CTRL1
},
3541 {0x03C7, RX_REE_GCSM1_EQENM_PH1
},
3542 {0x01C7, RX_REE_GCSM1_EQENM_PH2
},
3543 {0x0000, RX_DIAG_DFE_CTRL
},
3544 {0x0019, RX_REE_TAP1_CLIP
},
3545 {0x0019, RX_REE_TAP2TON_CLIP
},
3546 {0x00B9, RX_DIAG_NQST_CTRL
},
3547 {0x0C21, RX_DIAG_DFE_AMP_TUNE_2
},
3548 {0x0002, RX_DIAG_DFE_AMP_TUNE_3
},
3549 {0x0033, RX_DIAG_PI_RATE
},
3550 {0x0001, RX_DIAG_ACYA
},
3551 {0x018C, RX_CDRLF_CNFG
}
3554 static const struct cdns_torrent_vals sl_usxgmii_156_25_no_ssc_cmn_vals
= {
3555 .reg_pairs
= sl_usxgmii_156_25_no_ssc_cmn_regs
,
3556 .num_regs
= ARRAY_SIZE(sl_usxgmii_156_25_no_ssc_cmn_regs
),
3559 static const struct cdns_torrent_vals usxgmii_156_25_no_ssc_tx_ln_vals
= {
3560 .reg_pairs
= usxgmii_156_25_no_ssc_tx_ln_regs
,
3561 .num_regs
= ARRAY_SIZE(usxgmii_156_25_no_ssc_tx_ln_regs
),
3564 static const struct cdns_torrent_vals usxgmii_156_25_no_ssc_rx_ln_vals
= {
3565 .reg_pairs
= usxgmii_156_25_no_ssc_rx_ln_regs
,
3566 .num_regs
= ARRAY_SIZE(usxgmii_156_25_no_ssc_rx_ln_regs
),
3569 /* PCIe and DP link configuration */
3570 static const struct cdns_reg_pairs pcie_dp_link_cmn_regs
[] = {
3571 {0x0003, PHY_PLL_CFG
},
3572 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0
},
3573 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1
}
3576 static const struct cdns_reg_pairs pcie_dp_xcvr_diag_ln_regs
[] = {
3577 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3578 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3579 {0x0012, XCVR_DIAG_PLLDRC_CTRL
}
3582 static const struct cdns_reg_pairs dp_pcie_xcvr_diag_ln_regs
[] = {
3583 {0x0001, XCVR_DIAG_HSCLK_SEL
},
3584 {0x0009, XCVR_DIAG_PLLDRC_CTRL
}
3587 static const struct cdns_torrent_vals pcie_dp_link_cmn_vals
= {
3588 .reg_pairs
= pcie_dp_link_cmn_regs
,
3589 .num_regs
= ARRAY_SIZE(pcie_dp_link_cmn_regs
),
3592 static const struct cdns_torrent_vals pcie_dp_xcvr_diag_ln_vals
= {
3593 .reg_pairs
= pcie_dp_xcvr_diag_ln_regs
,
3594 .num_regs
= ARRAY_SIZE(pcie_dp_xcvr_diag_ln_regs
),
3597 static const struct cdns_torrent_vals dp_pcie_xcvr_diag_ln_vals
= {
3598 .reg_pairs
= dp_pcie_xcvr_diag_ln_regs
,
3599 .num_regs
= ARRAY_SIZE(dp_pcie_xcvr_diag_ln_regs
),
3602 /* DP Multilink, 100 MHz Ref clk, no SSC */
3603 static const struct cdns_reg_pairs dp_100_no_ssc_cmn_regs
[] = {
3604 {0x007F, CMN_TXPUCAL_TUNE
},
3605 {0x007F, CMN_TXPDCAL_TUNE
}
3608 static const struct cdns_reg_pairs dp_100_no_ssc_tx_ln_regs
[] = {
3609 {0x00FB, TX_PSC_A0
},
3610 {0x04AA, TX_PSC_A2
},
3611 {0x04AA, TX_PSC_A3
},
3612 {0x000F, XCVR_DIAG_BIDI_CTRL
}
3615 static const struct cdns_reg_pairs dp_100_no_ssc_rx_ln_regs
[] = {
3616 {0x0000, RX_PSC_A0
},
3617 {0x0000, RX_PSC_A2
},
3618 {0x0000, RX_PSC_A3
},
3619 {0x0000, RX_PSC_CAL
},
3620 {0x0000, RX_REE_GCSM1_CTRL
},
3621 {0x0000, RX_REE_GCSM2_CTRL
},
3622 {0x0000, RX_REE_PERGCSM_CTRL
}
3625 static const struct cdns_torrent_vals dp_100_no_ssc_cmn_vals
= {
3626 .reg_pairs
= dp_100_no_ssc_cmn_regs
,
3627 .num_regs
= ARRAY_SIZE(dp_100_no_ssc_cmn_regs
),
3630 static const struct cdns_torrent_vals dp_100_no_ssc_tx_ln_vals
= {
3631 .reg_pairs
= dp_100_no_ssc_tx_ln_regs
,
3632 .num_regs
= ARRAY_SIZE(dp_100_no_ssc_tx_ln_regs
),
3635 static const struct cdns_torrent_vals dp_100_no_ssc_rx_ln_vals
= {
3636 .reg_pairs
= dp_100_no_ssc_rx_ln_regs
,
3637 .num_regs
= ARRAY_SIZE(dp_100_no_ssc_rx_ln_regs
),
3640 /* Single DisplayPort(DP) link configuration */
3641 static const struct cdns_reg_pairs sl_dp_link_cmn_regs
[] = {
3642 {0x0000, PHY_PLL_CFG
},
3645 static const struct cdns_reg_pairs sl_dp_xcvr_diag_ln_regs
[] = {
3646 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3647 {0x0001, XCVR_DIAG_PLLDRC_CTRL
}
3650 static const struct cdns_torrent_vals sl_dp_link_cmn_vals
= {
3651 .reg_pairs
= sl_dp_link_cmn_regs
,
3652 .num_regs
= ARRAY_SIZE(sl_dp_link_cmn_regs
),
3655 static const struct cdns_torrent_vals sl_dp_xcvr_diag_ln_vals
= {
3656 .reg_pairs
= sl_dp_xcvr_diag_ln_regs
,
3657 .num_regs
= ARRAY_SIZE(sl_dp_xcvr_diag_ln_regs
),
3660 /* Single DP, 19.2 MHz Ref clk, no SSC */
3661 static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_cmn_regs
[] = {
3662 {0x0014, CMN_SSM_BIAS_TMR
},
3663 {0x0027, CMN_PLLSM0_PLLPRE_TMR
},
3664 {0x00A1, CMN_PLLSM0_PLLLOCK_TMR
},
3665 {0x0027, CMN_PLLSM1_PLLPRE_TMR
},
3666 {0x00A1, CMN_PLLSM1_PLLLOCK_TMR
},
3667 {0x0060, CMN_BGCAL_INIT_TMR
},
3668 {0x0060, CMN_BGCAL_ITER_TMR
},
3669 {0x0014, CMN_IBCAL_INIT_TMR
},
3670 {0x0018, CMN_TXPUCAL_INIT_TMR
},
3671 {0x0005, CMN_TXPUCAL_ITER_TMR
},
3672 {0x0018, CMN_TXPDCAL_INIT_TMR
},
3673 {0x0005, CMN_TXPDCAL_ITER_TMR
},
3674 {0x0240, CMN_RXCAL_INIT_TMR
},
3675 {0x0005, CMN_RXCAL_ITER_TMR
},
3676 {0x0002, CMN_SD_CAL_INIT_TMR
},
3677 {0x0002, CMN_SD_CAL_ITER_TMR
},
3678 {0x000B, CMN_SD_CAL_REFTIM_START
},
3679 {0x0137, CMN_SD_CAL_PLLCNT_START
},
3680 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0
},
3681 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0
},
3682 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0
},
3683 {0x0004, CMN_PLL0_DSM_DIAG_M0
},
3684 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0
},
3685 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0
},
3686 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0
},
3687 {0x0004, CMN_PLL1_DSM_DIAG_M0
},
3688 {0x00C0, CMN_PLL0_VCOCAL_INIT_TMR
},
3689 {0x0004, CMN_PLL0_VCOCAL_ITER_TMR
},
3690 {0x00C0, CMN_PLL1_VCOCAL_INIT_TMR
},
3691 {0x0004, CMN_PLL1_VCOCAL_ITER_TMR
},
3692 {0x0260, CMN_PLL0_VCOCAL_REFTIM_START
},
3693 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
3694 {0x0260, CMN_PLL1_VCOCAL_REFTIM_START
},
3695 {0x0003, CMN_PLL1_VCOCAL_TCTRL
}
3698 static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_tx_ln_regs
[] = {
3699 {0x0780, TX_RCVDET_ST_TMR
},
3700 {0x00FB, TX_PSC_A0
},
3701 {0x04AA, TX_PSC_A2
},
3702 {0x04AA, TX_PSC_A3
},
3703 {0x000F, XCVR_DIAG_BIDI_CTRL
}
3706 static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_rx_ln_regs
[] = {
3707 {0x0000, RX_PSC_A0
},
3708 {0x0000, RX_PSC_A2
},
3709 {0x0000, RX_PSC_A3
},
3710 {0x0000, RX_PSC_CAL
},
3711 {0x0000, RX_REE_GCSM1_CTRL
},
3712 {0x0000, RX_REE_GCSM2_CTRL
},
3713 {0x0000, RX_REE_PERGCSM_CTRL
}
3716 static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_cmn_vals
= {
3717 .reg_pairs
= sl_dp_19_2_no_ssc_cmn_regs
,
3718 .num_regs
= ARRAY_SIZE(sl_dp_19_2_no_ssc_cmn_regs
),
3721 static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_tx_ln_vals
= {
3722 .reg_pairs
= sl_dp_19_2_no_ssc_tx_ln_regs
,
3723 .num_regs
= ARRAY_SIZE(sl_dp_19_2_no_ssc_tx_ln_regs
),
3726 static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_rx_ln_vals
= {
3727 .reg_pairs
= sl_dp_19_2_no_ssc_rx_ln_regs
,
3728 .num_regs
= ARRAY_SIZE(sl_dp_19_2_no_ssc_rx_ln_regs
),
3731 /* Single DP, 25 MHz Ref clk, no SSC */
3732 static const struct cdns_reg_pairs sl_dp_25_no_ssc_cmn_regs
[] = {
3733 {0x0019, CMN_SSM_BIAS_TMR
},
3734 {0x0032, CMN_PLLSM0_PLLPRE_TMR
},
3735 {0x00D1, CMN_PLLSM0_PLLLOCK_TMR
},
3736 {0x0032, CMN_PLLSM1_PLLPRE_TMR
},
3737 {0x00D1, CMN_PLLSM1_PLLLOCK_TMR
},
3738 {0x007D, CMN_BGCAL_INIT_TMR
},
3739 {0x007D, CMN_BGCAL_ITER_TMR
},
3740 {0x0019, CMN_IBCAL_INIT_TMR
},
3741 {0x001E, CMN_TXPUCAL_INIT_TMR
},
3742 {0x0006, CMN_TXPUCAL_ITER_TMR
},
3743 {0x001E, CMN_TXPDCAL_INIT_TMR
},
3744 {0x0006, CMN_TXPDCAL_ITER_TMR
},
3745 {0x02EE, CMN_RXCAL_INIT_TMR
},
3746 {0x0006, CMN_RXCAL_ITER_TMR
},
3747 {0x0002, CMN_SD_CAL_INIT_TMR
},
3748 {0x0002, CMN_SD_CAL_ITER_TMR
},
3749 {0x000E, CMN_SD_CAL_REFTIM_START
},
3750 {0x012B, CMN_SD_CAL_PLLCNT_START
},
3751 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0
},
3752 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0
},
3753 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0
},
3754 {0x0004, CMN_PLL0_DSM_DIAG_M0
},
3755 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0
},
3756 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0
},
3757 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0
},
3758 {0x0004, CMN_PLL1_DSM_DIAG_M0
},
3759 {0x00FA, CMN_PLL0_VCOCAL_INIT_TMR
},
3760 {0x0004, CMN_PLL0_VCOCAL_ITER_TMR
},
3761 {0x00FA, CMN_PLL1_VCOCAL_INIT_TMR
},
3762 {0x0004, CMN_PLL1_VCOCAL_ITER_TMR
},
3763 {0x0317, CMN_PLL0_VCOCAL_REFTIM_START
},
3764 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
3765 {0x0317, CMN_PLL1_VCOCAL_REFTIM_START
},
3766 {0x0003, CMN_PLL1_VCOCAL_TCTRL
}
3769 static const struct cdns_reg_pairs sl_dp_25_no_ssc_tx_ln_regs
[] = {
3770 {0x09C4, TX_RCVDET_ST_TMR
},
3771 {0x00FB, TX_PSC_A0
},
3772 {0x04AA, TX_PSC_A2
},
3773 {0x04AA, TX_PSC_A3
},
3774 {0x000F, XCVR_DIAG_BIDI_CTRL
}
3777 static const struct cdns_reg_pairs sl_dp_25_no_ssc_rx_ln_regs
[] = {
3778 {0x0000, RX_PSC_A0
},
3779 {0x0000, RX_PSC_A2
},
3780 {0x0000, RX_PSC_A3
},
3781 {0x0000, RX_PSC_CAL
},
3782 {0x0000, RX_REE_GCSM1_CTRL
},
3783 {0x0000, RX_REE_GCSM2_CTRL
},
3784 {0x0000, RX_REE_PERGCSM_CTRL
}
3787 static const struct cdns_torrent_vals sl_dp_25_no_ssc_cmn_vals
= {
3788 .reg_pairs
= sl_dp_25_no_ssc_cmn_regs
,
3789 .num_regs
= ARRAY_SIZE(sl_dp_25_no_ssc_cmn_regs
),
3792 static const struct cdns_torrent_vals sl_dp_25_no_ssc_tx_ln_vals
= {
3793 .reg_pairs
= sl_dp_25_no_ssc_tx_ln_regs
,
3794 .num_regs
= ARRAY_SIZE(sl_dp_25_no_ssc_tx_ln_regs
),
3797 static const struct cdns_torrent_vals sl_dp_25_no_ssc_rx_ln_vals
= {
3798 .reg_pairs
= sl_dp_25_no_ssc_rx_ln_regs
,
3799 .num_regs
= ARRAY_SIZE(sl_dp_25_no_ssc_rx_ln_regs
),
3802 /* Single DP, 100 MHz Ref clk, no SSC */
3803 static const struct cdns_reg_pairs sl_dp_100_no_ssc_cmn_regs
[] = {
3804 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
3805 {0x0003, CMN_PLL1_VCOCAL_TCTRL
}
3808 static const struct cdns_reg_pairs sl_dp_100_no_ssc_tx_ln_regs
[] = {
3809 {0x00FB, TX_PSC_A0
},
3810 {0x04AA, TX_PSC_A2
},
3811 {0x04AA, TX_PSC_A3
},
3812 {0x000F, XCVR_DIAG_BIDI_CTRL
}
3815 static const struct cdns_reg_pairs sl_dp_100_no_ssc_rx_ln_regs
[] = {
3816 {0x0000, RX_PSC_A0
},
3817 {0x0000, RX_PSC_A2
},
3818 {0x0000, RX_PSC_A3
},
3819 {0x0000, RX_PSC_CAL
},
3820 {0x0000, RX_REE_GCSM1_CTRL
},
3821 {0x0000, RX_REE_GCSM2_CTRL
},
3822 {0x0000, RX_REE_PERGCSM_CTRL
}
3825 static const struct cdns_torrent_vals sl_dp_100_no_ssc_cmn_vals
= {
3826 .reg_pairs
= sl_dp_100_no_ssc_cmn_regs
,
3827 .num_regs
= ARRAY_SIZE(sl_dp_100_no_ssc_cmn_regs
),
3830 static const struct cdns_torrent_vals sl_dp_100_no_ssc_tx_ln_vals
= {
3831 .reg_pairs
= sl_dp_100_no_ssc_tx_ln_regs
,
3832 .num_regs
= ARRAY_SIZE(sl_dp_100_no_ssc_tx_ln_regs
),
3835 static const struct cdns_torrent_vals sl_dp_100_no_ssc_rx_ln_vals
= {
3836 .reg_pairs
= sl_dp_100_no_ssc_rx_ln_regs
,
3837 .num_regs
= ARRAY_SIZE(sl_dp_100_no_ssc_rx_ln_regs
),
3840 /* USB and SGMII/QSGMII link configuration */
3841 static const struct cdns_reg_pairs usb_sgmii_link_cmn_regs
[] = {
3842 {0x0002, PHY_PLL_CFG
},
3843 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0
},
3844 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0
}
3847 static const struct cdns_reg_pairs usb_sgmii_xcvr_diag_ln_regs
[] = {
3848 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3849 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3850 {0x0041, XCVR_DIAG_PLLDRC_CTRL
}
3853 static const struct cdns_reg_pairs sgmii_usb_xcvr_diag_ln_regs
[] = {
3854 {0x0011, XCVR_DIAG_HSCLK_SEL
},
3855 {0x0003, XCVR_DIAG_HSCLK_DIV
},
3856 {0x009B, XCVR_DIAG_PLLDRC_CTRL
}
3859 static const struct cdns_torrent_vals usb_sgmii_link_cmn_vals
= {
3860 .reg_pairs
= usb_sgmii_link_cmn_regs
,
3861 .num_regs
= ARRAY_SIZE(usb_sgmii_link_cmn_regs
),
3864 static const struct cdns_torrent_vals usb_sgmii_xcvr_diag_ln_vals
= {
3865 .reg_pairs
= usb_sgmii_xcvr_diag_ln_regs
,
3866 .num_regs
= ARRAY_SIZE(usb_sgmii_xcvr_diag_ln_regs
),
3869 static const struct cdns_torrent_vals sgmii_usb_xcvr_diag_ln_vals
= {
3870 .reg_pairs
= sgmii_usb_xcvr_diag_ln_regs
,
3871 .num_regs
= ARRAY_SIZE(sgmii_usb_xcvr_diag_ln_regs
),
3874 /* PCIe and USB Unique SSC link configuration */
3875 static const struct cdns_reg_pairs pcie_usb_link_cmn_regs
[] = {
3876 {0x0003, PHY_PLL_CFG
},
3877 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0
},
3878 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1
},
3879 {0x8600, CMN_PDIAG_PLL1_CLK_SEL_M0
}
3882 static const struct cdns_reg_pairs pcie_usb_xcvr_diag_ln_regs
[] = {
3883 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3884 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3885 {0x0012, XCVR_DIAG_PLLDRC_CTRL
}
3888 static const struct cdns_reg_pairs usb_pcie_xcvr_diag_ln_regs
[] = {
3889 {0x0011, XCVR_DIAG_HSCLK_SEL
},
3890 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3891 {0x00C9, XCVR_DIAG_PLLDRC_CTRL
}
3894 static const struct cdns_torrent_vals pcie_usb_link_cmn_vals
= {
3895 .reg_pairs
= pcie_usb_link_cmn_regs
,
3896 .num_regs
= ARRAY_SIZE(pcie_usb_link_cmn_regs
),
3899 static const struct cdns_torrent_vals pcie_usb_xcvr_diag_ln_vals
= {
3900 .reg_pairs
= pcie_usb_xcvr_diag_ln_regs
,
3901 .num_regs
= ARRAY_SIZE(pcie_usb_xcvr_diag_ln_regs
),
3904 static const struct cdns_torrent_vals usb_pcie_xcvr_diag_ln_vals
= {
3905 .reg_pairs
= usb_pcie_xcvr_diag_ln_regs
,
3906 .num_regs
= ARRAY_SIZE(usb_pcie_xcvr_diag_ln_regs
),
3909 /* USB 100 MHz Ref clk, internal SSC */
3910 static const struct cdns_reg_pairs usb_100_int_ssc_cmn_regs
[] = {
3911 {0x0004, CMN_PLL0_DSM_DIAG_M0
},
3912 {0x0004, CMN_PLL0_DSM_DIAG_M1
},
3913 {0x0004, CMN_PLL1_DSM_DIAG_M0
},
3914 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0
},
3915 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1
},
3916 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0
},
3917 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0
},
3918 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1
},
3919 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0
},
3920 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0
},
3921 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1
},
3922 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0
},
3923 {0x0064, CMN_PLL0_INTDIV_M0
},
3924 {0x0050, CMN_PLL0_INTDIV_M1
},
3925 {0x0064, CMN_PLL1_INTDIV_M0
},
3926 {0x0002, CMN_PLL0_FRACDIVH_M0
},
3927 {0x0002, CMN_PLL0_FRACDIVH_M1
},
3928 {0x0002, CMN_PLL1_FRACDIVH_M0
},
3929 {0x0044, CMN_PLL0_HIGH_THR_M0
},
3930 {0x0036, CMN_PLL0_HIGH_THR_M1
},
3931 {0x0044, CMN_PLL1_HIGH_THR_M0
},
3932 {0x0002, CMN_PDIAG_PLL0_CTRL_M0
},
3933 {0x0002, CMN_PDIAG_PLL0_CTRL_M1
},
3934 {0x0002, CMN_PDIAG_PLL1_CTRL_M0
},
3935 {0x0001, CMN_PLL0_SS_CTRL1_M0
},
3936 {0x0001, CMN_PLL0_SS_CTRL1_M1
},
3937 {0x0001, CMN_PLL1_SS_CTRL1_M0
},
3938 {0x011B, CMN_PLL0_SS_CTRL2_M0
},
3939 {0x011B, CMN_PLL0_SS_CTRL2_M1
},
3940 {0x011B, CMN_PLL1_SS_CTRL2_M0
},
3941 {0x006E, CMN_PLL0_SS_CTRL3_M0
},
3942 {0x0058, CMN_PLL0_SS_CTRL3_M1
},
3943 {0x006E, CMN_PLL1_SS_CTRL3_M0
},
3944 {0x000E, CMN_PLL0_SS_CTRL4_M0
},
3945 {0x0012, CMN_PLL0_SS_CTRL4_M1
},
3946 {0x000E, CMN_PLL1_SS_CTRL4_M0
},
3947 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START
},
3948 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START
},
3949 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START
},
3950 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START
},
3951 {0x00C7, CMN_PLL0_LOCK_REFCNT_START
},
3952 {0x00C7, CMN_PLL1_LOCK_REFCNT_START
},
3953 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START
},
3954 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START
},
3955 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR
},
3956 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR
},
3957 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD
},
3958 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD
},
3959 {0x007F, CMN_TXPUCAL_TUNE
},
3960 {0x007F, CMN_TXPDCAL_TUNE
}
3963 static const struct cdns_torrent_vals usb_100_int_ssc_cmn_vals
= {
3964 .reg_pairs
= usb_100_int_ssc_cmn_regs
,
3965 .num_regs
= ARRAY_SIZE(usb_100_int_ssc_cmn_regs
),
3968 /* Single USB link configuration */
3969 static const struct cdns_reg_pairs sl_usb_link_cmn_regs
[] = {
3970 {0x0000, PHY_PLL_CFG
},
3971 {0x8600, CMN_PDIAG_PLL0_CLK_SEL_M0
}
3974 static const struct cdns_reg_pairs sl_usb_xcvr_diag_ln_regs
[] = {
3975 {0x0000, XCVR_DIAG_HSCLK_SEL
},
3976 {0x0001, XCVR_DIAG_HSCLK_DIV
},
3977 {0x0041, XCVR_DIAG_PLLDRC_CTRL
}
3980 static const struct cdns_torrent_vals sl_usb_link_cmn_vals
= {
3981 .reg_pairs
= sl_usb_link_cmn_regs
,
3982 .num_regs
= ARRAY_SIZE(sl_usb_link_cmn_regs
),
3985 static const struct cdns_torrent_vals sl_usb_xcvr_diag_ln_vals
= {
3986 .reg_pairs
= sl_usb_xcvr_diag_ln_regs
,
3987 .num_regs
= ARRAY_SIZE(sl_usb_xcvr_diag_ln_regs
),
3990 /* USB PHY PCS common configuration */
3991 static const struct cdns_reg_pairs usb_phy_pcs_cmn_regs
[] = {
3992 {0x0A0A, PHY_PIPE_USB3_GEN2_PRE_CFG0
},
3993 {0x1000, PHY_PIPE_USB3_GEN2_POST_CFG0
},
3994 {0x0010, PHY_PIPE_USB3_GEN2_POST_CFG1
}
3997 static const struct cdns_torrent_vals usb_phy_pcs_cmn_vals
= {
3998 .reg_pairs
= usb_phy_pcs_cmn_regs
,
3999 .num_regs
= ARRAY_SIZE(usb_phy_pcs_cmn_regs
),
4002 /* USB 100 MHz Ref clk, no SSC */
4003 static const struct cdns_reg_pairs sl_usb_100_no_ssc_cmn_regs
[] = {
4004 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4005 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0
},
4006 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0
},
4007 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
4008 {0x0003, CMN_PLL1_VCOCAL_TCTRL
},
4009 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD
},
4010 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD
}
4013 static const struct cdns_torrent_vals sl_usb_100_no_ssc_cmn_vals
= {
4014 .reg_pairs
= sl_usb_100_no_ssc_cmn_regs
,
4015 .num_regs
= ARRAY_SIZE(sl_usb_100_no_ssc_cmn_regs
),
4018 static const struct cdns_reg_pairs usb_100_no_ssc_cmn_regs
[] = {
4019 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD
},
4020 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD
},
4021 {0x007F, CMN_TXPUCAL_TUNE
},
4022 {0x007F, CMN_TXPDCAL_TUNE
}
4025 static const struct cdns_reg_pairs usb_100_no_ssc_tx_ln_regs
[] = {
4026 {0x02FF, TX_PSC_A0
},
4027 {0x06AF, TX_PSC_A1
},
4028 {0x06AE, TX_PSC_A2
},
4029 {0x06AE, TX_PSC_A3
},
4030 {0x2A82, TX_TXCC_CTRL
},
4031 {0x0014, TX_TXCC_CPOST_MULT_01
},
4032 {0x0003, XCVR_DIAG_PSC_OVRD
}
4035 static const struct cdns_reg_pairs usb_100_no_ssc_rx_ln_regs
[] = {
4036 {0x0D1D, RX_PSC_A0
},
4037 {0x0D1D, RX_PSC_A1
},
4038 {0x0D00, RX_PSC_A2
},
4039 {0x0500, RX_PSC_A3
},
4040 {0x0013, RX_SIGDET_HL_FILT_TMR
},
4041 {0x0000, RX_REE_GCSM1_CTRL
},
4042 {0x0C02, RX_REE_ATTEN_THR
},
4043 {0x0330, RX_REE_SMGM_CTRL1
},
4044 {0x0300, RX_REE_SMGM_CTRL2
},
4045 {0x0019, RX_REE_TAP1_CLIP
},
4046 {0x0019, RX_REE_TAP2TON_CLIP
},
4047 {0x1004, RX_DIAG_SIGDET_TUNE
},
4048 {0x00F9, RX_DIAG_NQST_CTRL
},
4049 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2
},
4050 {0x0002, RX_DIAG_DFE_AMP_TUNE_3
},
4051 {0x0000, RX_DIAG_PI_CAP
},
4052 {0x0031, RX_DIAG_PI_RATE
},
4053 {0x0001, RX_DIAG_ACYA
},
4054 {0x018C, RX_CDRLF_CNFG
},
4055 {0x0003, RX_CDRLF_CNFG3
}
4058 static const struct cdns_torrent_vals usb_100_no_ssc_cmn_vals
= {
4059 .reg_pairs
= usb_100_no_ssc_cmn_regs
,
4060 .num_regs
= ARRAY_SIZE(usb_100_no_ssc_cmn_regs
),
4063 static const struct cdns_torrent_vals usb_100_no_ssc_tx_ln_vals
= {
4064 .reg_pairs
= usb_100_no_ssc_tx_ln_regs
,
4065 .num_regs
= ARRAY_SIZE(usb_100_no_ssc_tx_ln_regs
),
4068 static const struct cdns_torrent_vals usb_100_no_ssc_rx_ln_vals
= {
4069 .reg_pairs
= usb_100_no_ssc_rx_ln_regs
,
4070 .num_regs
= ARRAY_SIZE(usb_100_no_ssc_rx_ln_regs
),
4073 /* Single link USB, 100 MHz Ref clk, internal SSC */
4074 static const struct cdns_reg_pairs sl_usb_100_int_ssc_cmn_regs
[] = {
4075 {0x0004, CMN_PLL0_DSM_DIAG_M0
},
4076 {0x0004, CMN_PLL1_DSM_DIAG_M0
},
4077 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0
},
4078 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4079 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0
},
4080 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0
},
4081 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0
},
4082 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0
},
4083 {0x0064, CMN_PLL0_INTDIV_M0
},
4084 {0x0064, CMN_PLL1_INTDIV_M0
},
4085 {0x0002, CMN_PLL0_FRACDIVH_M0
},
4086 {0x0002, CMN_PLL1_FRACDIVH_M0
},
4087 {0x0044, CMN_PLL0_HIGH_THR_M0
},
4088 {0x0044, CMN_PLL1_HIGH_THR_M0
},
4089 {0x0002, CMN_PDIAG_PLL0_CTRL_M0
},
4090 {0x0002, CMN_PDIAG_PLL1_CTRL_M0
},
4091 {0x0001, CMN_PLL0_SS_CTRL1_M0
},
4092 {0x0001, CMN_PLL1_SS_CTRL1_M0
},
4093 {0x011B, CMN_PLL0_SS_CTRL2_M0
},
4094 {0x011B, CMN_PLL1_SS_CTRL2_M0
},
4095 {0x006E, CMN_PLL0_SS_CTRL3_M0
},
4096 {0x006E, CMN_PLL1_SS_CTRL3_M0
},
4097 {0x000E, CMN_PLL0_SS_CTRL4_M0
},
4098 {0x000E, CMN_PLL1_SS_CTRL4_M0
},
4099 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START
},
4100 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START
},
4101 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START
},
4102 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START
},
4103 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
4104 {0x0003, CMN_PLL1_VCOCAL_TCTRL
},
4105 {0x00C7, CMN_PLL0_LOCK_REFCNT_START
},
4106 {0x00C7, CMN_PLL1_LOCK_REFCNT_START
},
4107 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START
},
4108 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START
},
4109 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR
},
4110 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR
},
4111 {0x8200, CMN_CDIAG_CDB_PWRI_OVRD
},
4112 {0x8200, CMN_CDIAG_XCVRC_PWRI_OVRD
}
4115 static const struct cdns_torrent_vals sl_usb_100_int_ssc_cmn_vals
= {
4116 .reg_pairs
= sl_usb_100_int_ssc_cmn_regs
,
4117 .num_regs
= ARRAY_SIZE(sl_usb_100_int_ssc_cmn_regs
),
4120 /* PCIe and SGMII/QSGMII Unique SSC link configuration */
4121 static const struct cdns_reg_pairs pcie_sgmii_link_cmn_regs
[] = {
4122 {0x0003, PHY_PLL_CFG
},
4123 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0
},
4124 {0x0400, CMN_PDIAG_PLL0_CLK_SEL_M1
},
4125 {0x0601, CMN_PDIAG_PLL1_CLK_SEL_M0
}
4128 static const struct cdns_reg_pairs pcie_sgmii_xcvr_diag_ln_regs
[] = {
4129 {0x0000, XCVR_DIAG_HSCLK_SEL
},
4130 {0x0001, XCVR_DIAG_HSCLK_DIV
},
4131 {0x0012, XCVR_DIAG_PLLDRC_CTRL
}
4134 static const struct cdns_reg_pairs sgmii_pcie_xcvr_diag_ln_regs
[] = {
4135 {0x0011, XCVR_DIAG_HSCLK_SEL
},
4136 {0x0003, XCVR_DIAG_HSCLK_DIV
},
4137 {0x009B, XCVR_DIAG_PLLDRC_CTRL
}
4140 static const struct cdns_torrent_vals pcie_sgmii_link_cmn_vals
= {
4141 .reg_pairs
= pcie_sgmii_link_cmn_regs
,
4142 .num_regs
= ARRAY_SIZE(pcie_sgmii_link_cmn_regs
),
4145 static const struct cdns_torrent_vals pcie_sgmii_xcvr_diag_ln_vals
= {
4146 .reg_pairs
= pcie_sgmii_xcvr_diag_ln_regs
,
4147 .num_regs
= ARRAY_SIZE(pcie_sgmii_xcvr_diag_ln_regs
),
4150 static const struct cdns_torrent_vals sgmii_pcie_xcvr_diag_ln_vals
= {
4151 .reg_pairs
= sgmii_pcie_xcvr_diag_ln_regs
,
4152 .num_regs
= ARRAY_SIZE(sgmii_pcie_xcvr_diag_ln_regs
),
4155 /* SGMII 100 MHz Ref clk, no SSC */
4156 static const struct cdns_reg_pairs sl_sgmii_100_no_ssc_cmn_regs
[] = {
4157 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4158 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0
},
4159 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0
},
4160 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
4161 {0x0003, CMN_PLL1_VCOCAL_TCTRL
}
4164 static const struct cdns_torrent_vals sl_sgmii_100_no_ssc_cmn_vals
= {
4165 .reg_pairs
= sl_sgmii_100_no_ssc_cmn_regs
,
4166 .num_regs
= ARRAY_SIZE(sl_sgmii_100_no_ssc_cmn_regs
),
4169 static const struct cdns_reg_pairs sgmii_100_no_ssc_cmn_regs
[] = {
4170 {0x007F, CMN_TXPUCAL_TUNE
},
4171 {0x007F, CMN_TXPDCAL_TUNE
}
4174 static const struct cdns_reg_pairs sgmii_100_no_ssc_tx_ln_regs
[] = {
4175 {0x00F3, TX_PSC_A0
},
4176 {0x04A2, TX_PSC_A2
},
4177 {0x04A2, TX_PSC_A3
},
4178 {0x0000, TX_TXCC_CPOST_MULT_00
},
4179 {0x00B3, DRV_DIAG_TX_DRV
},
4180 {0x0002, XCVR_DIAG_PSC_OVRD
}
4183 static const struct cdns_reg_pairs ti_sgmii_100_no_ssc_tx_ln_regs
[] = {
4184 {0x00F3, TX_PSC_A0
},
4185 {0x04A2, TX_PSC_A2
},
4186 {0x04A2, TX_PSC_A3
},
4187 {0x0000, TX_TXCC_CPOST_MULT_00
},
4188 {0x00B3, DRV_DIAG_TX_DRV
},
4189 {0x0002, XCVR_DIAG_PSC_OVRD
},
4190 {0x4000, XCVR_DIAG_RXCLK_CTRL
}
4193 static const struct cdns_reg_pairs sgmii_100_no_ssc_rx_ln_regs
[] = {
4194 {0x091D, RX_PSC_A0
},
4195 {0x0900, RX_PSC_A2
},
4196 {0x0100, RX_PSC_A3
},
4197 {0x03C7, RX_REE_GCSM1_EQENM_PH1
},
4198 {0x01C7, RX_REE_GCSM1_EQENM_PH2
},
4199 {0x0000, RX_DIAG_DFE_CTRL
},
4200 {0x0019, RX_REE_TAP1_CLIP
},
4201 {0x0019, RX_REE_TAP2TON_CLIP
},
4202 {0x0098, RX_DIAG_NQST_CTRL
},
4203 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2
},
4204 {0x0000, RX_DIAG_DFE_AMP_TUNE_3
},
4205 {0x0000, RX_DIAG_PI_CAP
},
4206 {0x0010, RX_DIAG_PI_RATE
},
4207 {0x0001, RX_DIAG_ACYA
},
4208 {0x018C, RX_CDRLF_CNFG
},
4211 static const struct cdns_torrent_vals sgmii_100_no_ssc_cmn_vals
= {
4212 .reg_pairs
= sgmii_100_no_ssc_cmn_regs
,
4213 .num_regs
= ARRAY_SIZE(sgmii_100_no_ssc_cmn_regs
),
4216 static const struct cdns_torrent_vals sgmii_100_no_ssc_tx_ln_vals
= {
4217 .reg_pairs
= sgmii_100_no_ssc_tx_ln_regs
,
4218 .num_regs
= ARRAY_SIZE(sgmii_100_no_ssc_tx_ln_regs
),
4221 static const struct cdns_torrent_vals ti_sgmii_100_no_ssc_tx_ln_vals
= {
4222 .reg_pairs
= ti_sgmii_100_no_ssc_tx_ln_regs
,
4223 .num_regs
= ARRAY_SIZE(ti_sgmii_100_no_ssc_tx_ln_regs
),
4226 static const struct cdns_torrent_vals sgmii_100_no_ssc_rx_ln_vals
= {
4227 .reg_pairs
= sgmii_100_no_ssc_rx_ln_regs
,
4228 .num_regs
= ARRAY_SIZE(sgmii_100_no_ssc_rx_ln_regs
),
4231 /* TI J7200, multilink SGMII */
4232 static const struct cdns_reg_pairs j7200_sgmii_100_no_ssc_tx_ln_regs
[] = {
4233 {0x07A2, TX_RCVDET_ST_TMR
},
4234 {0x00F3, TX_PSC_A0
},
4235 {0x04A2, TX_PSC_A2
},
4236 {0x04A2, TX_PSC_A3
},
4237 {0x0000, TX_TXCC_CPOST_MULT_00
},
4238 {0x00B3, DRV_DIAG_TX_DRV
},
4239 {0x0002, XCVR_DIAG_PSC_OVRD
},
4240 {0x4000, XCVR_DIAG_RXCLK_CTRL
}
4243 static const struct cdns_torrent_vals j7200_sgmii_100_no_ssc_tx_ln_vals
= {
4244 .reg_pairs
= j7200_sgmii_100_no_ssc_tx_ln_regs
,
4245 .num_regs
= ARRAY_SIZE(j7200_sgmii_100_no_ssc_tx_ln_regs
),
4248 static const struct cdns_reg_pairs j7200_sgmii_100_no_ssc_rx_ln_regs
[] = {
4249 {0x0014, RX_SDCAL0_INIT_TMR
},
4250 {0x0062, RX_SDCAL0_ITER_TMR
},
4251 {0x0014, RX_SDCAL1_INIT_TMR
},
4252 {0x0062, RX_SDCAL1_ITER_TMR
},
4253 {0x091D, RX_PSC_A0
},
4254 {0x0900, RX_PSC_A2
},
4255 {0x0100, RX_PSC_A3
},
4256 {0x03C7, RX_REE_GCSM1_EQENM_PH1
},
4257 {0x01C7, RX_REE_GCSM1_EQENM_PH2
},
4258 {0x0000, RX_DIAG_DFE_CTRL
},
4259 {0x0019, RX_REE_TAP1_CLIP
},
4260 {0x0019, RX_REE_TAP2TON_CLIP
},
4261 {0x0098, RX_DIAG_NQST_CTRL
},
4262 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2
},
4263 {0x0000, RX_DIAG_DFE_AMP_TUNE_3
},
4264 {0x0000, RX_DIAG_PI_CAP
},
4265 {0x0010, RX_DIAG_PI_RATE
},
4266 {0x0001, RX_DIAG_ACYA
},
4267 {0x018C, RX_CDRLF_CNFG
}
4270 static const struct cdns_torrent_vals j7200_sgmii_100_no_ssc_rx_ln_vals
= {
4271 .reg_pairs
= j7200_sgmii_100_no_ssc_rx_ln_regs
,
4272 .num_regs
= ARRAY_SIZE(j7200_sgmii_100_no_ssc_rx_ln_regs
),
4275 /* SGMII 100 MHz Ref clk, internal SSC */
4276 static const struct cdns_reg_pairs sgmii_100_int_ssc_cmn_regs
[] = {
4277 {0x0004, CMN_PLL0_DSM_DIAG_M0
},
4278 {0x0004, CMN_PLL0_DSM_DIAG_M1
},
4279 {0x0004, CMN_PLL1_DSM_DIAG_M0
},
4280 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0
},
4281 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1
},
4282 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4283 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0
},
4284 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1
},
4285 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0
},
4286 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0
},
4287 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1
},
4288 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0
},
4289 {0x0064, CMN_PLL0_INTDIV_M0
},
4290 {0x0050, CMN_PLL0_INTDIV_M1
},
4291 {0x0064, CMN_PLL1_INTDIV_M0
},
4292 {0x0002, CMN_PLL0_FRACDIVH_M0
},
4293 {0x0002, CMN_PLL0_FRACDIVH_M1
},
4294 {0x0002, CMN_PLL1_FRACDIVH_M0
},
4295 {0x0044, CMN_PLL0_HIGH_THR_M0
},
4296 {0x0036, CMN_PLL0_HIGH_THR_M1
},
4297 {0x0044, CMN_PLL1_HIGH_THR_M0
},
4298 {0x0002, CMN_PDIAG_PLL0_CTRL_M0
},
4299 {0x0002, CMN_PDIAG_PLL0_CTRL_M1
},
4300 {0x0002, CMN_PDIAG_PLL1_CTRL_M0
},
4301 {0x0001, CMN_PLL0_SS_CTRL1_M0
},
4302 {0x0001, CMN_PLL0_SS_CTRL1_M1
},
4303 {0x0001, CMN_PLL1_SS_CTRL1_M0
},
4304 {0x011B, CMN_PLL0_SS_CTRL2_M0
},
4305 {0x011B, CMN_PLL0_SS_CTRL2_M1
},
4306 {0x011B, CMN_PLL1_SS_CTRL2_M0
},
4307 {0x006E, CMN_PLL0_SS_CTRL3_M0
},
4308 {0x0058, CMN_PLL0_SS_CTRL3_M1
},
4309 {0x006E, CMN_PLL1_SS_CTRL3_M0
},
4310 {0x000E, CMN_PLL0_SS_CTRL4_M0
},
4311 {0x0012, CMN_PLL0_SS_CTRL4_M1
},
4312 {0x000E, CMN_PLL1_SS_CTRL4_M0
},
4313 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START
},
4314 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START
},
4315 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START
},
4316 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START
},
4317 {0x00C7, CMN_PLL0_LOCK_REFCNT_START
},
4318 {0x00C7, CMN_PLL1_LOCK_REFCNT_START
},
4319 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START
},
4320 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START
},
4321 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR
},
4322 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR
},
4323 {0x007F, CMN_TXPUCAL_TUNE
},
4324 {0x007F, CMN_TXPDCAL_TUNE
}
4327 static const struct cdns_torrent_vals sgmii_100_int_ssc_cmn_vals
= {
4328 .reg_pairs
= sgmii_100_int_ssc_cmn_regs
,
4329 .num_regs
= ARRAY_SIZE(sgmii_100_int_ssc_cmn_regs
),
4332 /* QSGMII 100 MHz Ref clk, no SSC */
4333 static const struct cdns_reg_pairs sl_qsgmii_100_no_ssc_cmn_regs
[] = {
4334 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4335 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0
},
4336 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0
},
4337 {0x0003, CMN_PLL0_VCOCAL_TCTRL
},
4338 {0x0003, CMN_PLL1_VCOCAL_TCTRL
}
4341 static const struct cdns_torrent_vals sl_qsgmii_100_no_ssc_cmn_vals
= {
4342 .reg_pairs
= sl_qsgmii_100_no_ssc_cmn_regs
,
4343 .num_regs
= ARRAY_SIZE(sl_qsgmii_100_no_ssc_cmn_regs
),
4346 static const struct cdns_reg_pairs qsgmii_100_no_ssc_cmn_regs
[] = {
4347 {0x007F, CMN_TXPUCAL_TUNE
},
4348 {0x007F, CMN_TXPDCAL_TUNE
}
4351 static const struct cdns_reg_pairs qsgmii_100_no_ssc_tx_ln_regs
[] = {
4352 {0x00F3, TX_PSC_A0
},
4353 {0x04A2, TX_PSC_A2
},
4354 {0x04A2, TX_PSC_A3
},
4355 {0x0000, TX_TXCC_CPOST_MULT_00
},
4356 {0x0011, TX_TXCC_MGNFS_MULT_100
},
4357 {0x0003, DRV_DIAG_TX_DRV
},
4358 {0x0002, XCVR_DIAG_PSC_OVRD
}
4361 static const struct cdns_reg_pairs ti_qsgmii_100_no_ssc_tx_ln_regs
[] = {
4362 {0x00F3, TX_PSC_A0
},
4363 {0x04A2, TX_PSC_A2
},
4364 {0x04A2, TX_PSC_A3
},
4365 {0x0000, TX_TXCC_CPOST_MULT_00
},
4366 {0x0011, TX_TXCC_MGNFS_MULT_100
},
4367 {0x0003, DRV_DIAG_TX_DRV
},
4368 {0x0002, XCVR_DIAG_PSC_OVRD
},
4369 {0x4000, XCVR_DIAG_RXCLK_CTRL
}
4372 static const struct cdns_reg_pairs qsgmii_100_no_ssc_rx_ln_regs
[] = {
4373 {0x091D, RX_PSC_A0
},
4374 {0x0900, RX_PSC_A2
},
4375 {0x0100, RX_PSC_A3
},
4376 {0x03C7, RX_REE_GCSM1_EQENM_PH1
},
4377 {0x01C7, RX_REE_GCSM1_EQENM_PH2
},
4378 {0x0000, RX_DIAG_DFE_CTRL
},
4379 {0x0019, RX_REE_TAP1_CLIP
},
4380 {0x0019, RX_REE_TAP2TON_CLIP
},
4381 {0x0098, RX_DIAG_NQST_CTRL
},
4382 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2
},
4383 {0x0000, RX_DIAG_DFE_AMP_TUNE_3
},
4384 {0x0000, RX_DIAG_PI_CAP
},
4385 {0x0010, RX_DIAG_PI_RATE
},
4386 {0x0001, RX_DIAG_ACYA
},
4387 {0x018C, RX_CDRLF_CNFG
},
4390 static const struct cdns_torrent_vals qsgmii_100_no_ssc_cmn_vals
= {
4391 .reg_pairs
= qsgmii_100_no_ssc_cmn_regs
,
4392 .num_regs
= ARRAY_SIZE(qsgmii_100_no_ssc_cmn_regs
),
4395 static const struct cdns_torrent_vals qsgmii_100_no_ssc_tx_ln_vals
= {
4396 .reg_pairs
= qsgmii_100_no_ssc_tx_ln_regs
,
4397 .num_regs
= ARRAY_SIZE(qsgmii_100_no_ssc_tx_ln_regs
),
4400 static const struct cdns_torrent_vals ti_qsgmii_100_no_ssc_tx_ln_vals
= {
4401 .reg_pairs
= ti_qsgmii_100_no_ssc_tx_ln_regs
,
4402 .num_regs
= ARRAY_SIZE(ti_qsgmii_100_no_ssc_tx_ln_regs
),
4405 static const struct cdns_torrent_vals qsgmii_100_no_ssc_rx_ln_vals
= {
4406 .reg_pairs
= qsgmii_100_no_ssc_rx_ln_regs
,
4407 .num_regs
= ARRAY_SIZE(qsgmii_100_no_ssc_rx_ln_regs
),
4410 /* TI J7200, multilink QSGMII */
4411 static const struct cdns_reg_pairs j7200_qsgmii_100_no_ssc_tx_ln_regs
[] = {
4412 {0x07A2, TX_RCVDET_ST_TMR
},
4413 {0x00F3, TX_PSC_A0
},
4414 {0x04A2, TX_PSC_A2
},
4415 {0x04A2, TX_PSC_A3
},
4416 {0x0000, TX_TXCC_CPOST_MULT_00
},
4417 {0x0011, TX_TXCC_MGNFS_MULT_100
},
4418 {0x0003, DRV_DIAG_TX_DRV
},
4419 {0x0002, XCVR_DIAG_PSC_OVRD
},
4420 {0x4000, XCVR_DIAG_RXCLK_CTRL
}
4423 static const struct cdns_torrent_vals j7200_qsgmii_100_no_ssc_tx_ln_vals
= {
4424 .reg_pairs
= j7200_qsgmii_100_no_ssc_tx_ln_regs
,
4425 .num_regs
= ARRAY_SIZE(j7200_qsgmii_100_no_ssc_tx_ln_regs
),
4428 static const struct cdns_reg_pairs j7200_qsgmii_100_no_ssc_rx_ln_regs
[] = {
4429 {0x0014, RX_SDCAL0_INIT_TMR
},
4430 {0x0062, RX_SDCAL0_ITER_TMR
},
4431 {0x0014, RX_SDCAL1_INIT_TMR
},
4432 {0x0062, RX_SDCAL1_ITER_TMR
},
4433 {0x091D, RX_PSC_A0
},
4434 {0x0900, RX_PSC_A2
},
4435 {0x0100, RX_PSC_A3
},
4436 {0x03C7, RX_REE_GCSM1_EQENM_PH1
},
4437 {0x01C7, RX_REE_GCSM1_EQENM_PH2
},
4438 {0x0000, RX_DIAG_DFE_CTRL
},
4439 {0x0019, RX_REE_TAP1_CLIP
},
4440 {0x0019, RX_REE_TAP2TON_CLIP
},
4441 {0x0098, RX_DIAG_NQST_CTRL
},
4442 {0x0C01, RX_DIAG_DFE_AMP_TUNE_2
},
4443 {0x0000, RX_DIAG_DFE_AMP_TUNE_3
},
4444 {0x0000, RX_DIAG_PI_CAP
},
4445 {0x0010, RX_DIAG_PI_RATE
},
4446 {0x0001, RX_DIAG_ACYA
},
4447 {0x018C, RX_CDRLF_CNFG
}
4450 static const struct cdns_torrent_vals j7200_qsgmii_100_no_ssc_rx_ln_vals
= {
4451 .reg_pairs
= j7200_qsgmii_100_no_ssc_rx_ln_regs
,
4452 .num_regs
= ARRAY_SIZE(j7200_qsgmii_100_no_ssc_rx_ln_regs
),
4455 /* QSGMII 100 MHz Ref clk, internal SSC */
4456 static const struct cdns_reg_pairs qsgmii_100_int_ssc_cmn_regs
[] = {
4457 {0x0004, CMN_PLL0_DSM_DIAG_M0
},
4458 {0x0004, CMN_PLL0_DSM_DIAG_M1
},
4459 {0x0004, CMN_PLL1_DSM_DIAG_M0
},
4460 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0
},
4461 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1
},
4462 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4463 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0
},
4464 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1
},
4465 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0
},
4466 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0
},
4467 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1
},
4468 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0
},
4469 {0x0064, CMN_PLL0_INTDIV_M0
},
4470 {0x0050, CMN_PLL0_INTDIV_M1
},
4471 {0x0064, CMN_PLL1_INTDIV_M0
},
4472 {0x0002, CMN_PLL0_FRACDIVH_M0
},
4473 {0x0002, CMN_PLL0_FRACDIVH_M1
},
4474 {0x0002, CMN_PLL1_FRACDIVH_M0
},
4475 {0x0044, CMN_PLL0_HIGH_THR_M0
},
4476 {0x0036, CMN_PLL0_HIGH_THR_M1
},
4477 {0x0044, CMN_PLL1_HIGH_THR_M0
},
4478 {0x0002, CMN_PDIAG_PLL0_CTRL_M0
},
4479 {0x0002, CMN_PDIAG_PLL0_CTRL_M1
},
4480 {0x0002, CMN_PDIAG_PLL1_CTRL_M0
},
4481 {0x0001, CMN_PLL0_SS_CTRL1_M0
},
4482 {0x0001, CMN_PLL0_SS_CTRL1_M1
},
4483 {0x0001, CMN_PLL1_SS_CTRL1_M0
},
4484 {0x011B, CMN_PLL0_SS_CTRL2_M0
},
4485 {0x011B, CMN_PLL0_SS_CTRL2_M1
},
4486 {0x011B, CMN_PLL1_SS_CTRL2_M0
},
4487 {0x006E, CMN_PLL0_SS_CTRL3_M0
},
4488 {0x0058, CMN_PLL0_SS_CTRL3_M1
},
4489 {0x006E, CMN_PLL1_SS_CTRL3_M0
},
4490 {0x000E, CMN_PLL0_SS_CTRL4_M0
},
4491 {0x0012, CMN_PLL0_SS_CTRL4_M1
},
4492 {0x000E, CMN_PLL1_SS_CTRL4_M0
},
4493 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START
},
4494 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START
},
4495 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START
},
4496 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START
},
4497 {0x00C7, CMN_PLL0_LOCK_REFCNT_START
},
4498 {0x00C7, CMN_PLL1_LOCK_REFCNT_START
},
4499 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START
},
4500 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START
},
4501 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR
},
4502 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR
},
4503 {0x007F, CMN_TXPUCAL_TUNE
},
4504 {0x007F, CMN_TXPDCAL_TUNE
}
4507 static const struct cdns_torrent_vals qsgmii_100_int_ssc_cmn_vals
= {
4508 .reg_pairs
= qsgmii_100_int_ssc_cmn_regs
,
4509 .num_regs
= ARRAY_SIZE(qsgmii_100_int_ssc_cmn_regs
),
4512 /* Single SGMII/QSGMII link configuration */
4513 static const struct cdns_reg_pairs sl_sgmii_link_cmn_regs
[] = {
4514 {0x0000, PHY_PLL_CFG
},
4515 {0x0601, CMN_PDIAG_PLL0_CLK_SEL_M0
}
4518 static const struct cdns_reg_pairs sl_sgmii_xcvr_diag_ln_regs
[] = {
4519 {0x0000, XCVR_DIAG_HSCLK_SEL
},
4520 {0x0003, XCVR_DIAG_HSCLK_DIV
},
4521 {0x0013, XCVR_DIAG_PLLDRC_CTRL
}
4524 static const struct cdns_torrent_vals sl_sgmii_link_cmn_vals
= {
4525 .reg_pairs
= sl_sgmii_link_cmn_regs
,
4526 .num_regs
= ARRAY_SIZE(sl_sgmii_link_cmn_regs
),
4529 static const struct cdns_torrent_vals sl_sgmii_xcvr_diag_ln_vals
= {
4530 .reg_pairs
= sl_sgmii_xcvr_diag_ln_regs
,
4531 .num_regs
= ARRAY_SIZE(sl_sgmii_xcvr_diag_ln_regs
),
4534 /* Multi link PCIe, 100 MHz Ref clk, internal SSC */
4535 static const struct cdns_reg_pairs pcie_100_int_ssc_cmn_regs
[] = {
4536 {0x0004, CMN_PLL0_DSM_DIAG_M0
},
4537 {0x0004, CMN_PLL0_DSM_DIAG_M1
},
4538 {0x0004, CMN_PLL1_DSM_DIAG_M0
},
4539 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0
},
4540 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1
},
4541 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4542 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0
},
4543 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1
},
4544 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0
},
4545 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0
},
4546 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1
},
4547 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0
},
4548 {0x0064, CMN_PLL0_INTDIV_M0
},
4549 {0x0050, CMN_PLL0_INTDIV_M1
},
4550 {0x0064, CMN_PLL1_INTDIV_M0
},
4551 {0x0002, CMN_PLL0_FRACDIVH_M0
},
4552 {0x0002, CMN_PLL0_FRACDIVH_M1
},
4553 {0x0002, CMN_PLL1_FRACDIVH_M0
},
4554 {0x0044, CMN_PLL0_HIGH_THR_M0
},
4555 {0x0036, CMN_PLL0_HIGH_THR_M1
},
4556 {0x0044, CMN_PLL1_HIGH_THR_M0
},
4557 {0x0002, CMN_PDIAG_PLL0_CTRL_M0
},
4558 {0x0002, CMN_PDIAG_PLL0_CTRL_M1
},
4559 {0x0002, CMN_PDIAG_PLL1_CTRL_M0
},
4560 {0x0001, CMN_PLL0_SS_CTRL1_M0
},
4561 {0x0001, CMN_PLL0_SS_CTRL1_M1
},
4562 {0x0001, CMN_PLL1_SS_CTRL1_M0
},
4563 {0x011B, CMN_PLL0_SS_CTRL2_M0
},
4564 {0x011B, CMN_PLL0_SS_CTRL2_M1
},
4565 {0x011B, CMN_PLL1_SS_CTRL2_M0
},
4566 {0x006E, CMN_PLL0_SS_CTRL3_M0
},
4567 {0x0058, CMN_PLL0_SS_CTRL3_M1
},
4568 {0x006E, CMN_PLL1_SS_CTRL3_M0
},
4569 {0x000E, CMN_PLL0_SS_CTRL4_M0
},
4570 {0x0012, CMN_PLL0_SS_CTRL4_M1
},
4571 {0x000E, CMN_PLL1_SS_CTRL4_M0
},
4572 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START
},
4573 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START
},
4574 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START
},
4575 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START
},
4576 {0x00C7, CMN_PLL0_LOCK_REFCNT_START
},
4577 {0x00C7, CMN_PLL1_LOCK_REFCNT_START
},
4578 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START
},
4579 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START
},
4580 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR
},
4581 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR
}
4584 static const struct cdns_torrent_vals pcie_100_int_ssc_cmn_vals
= {
4585 .reg_pairs
= pcie_100_int_ssc_cmn_regs
,
4586 .num_regs
= ARRAY_SIZE(pcie_100_int_ssc_cmn_regs
),
4589 /* Single link PCIe, 100 MHz Ref clk, internal SSC */
4590 static const struct cdns_reg_pairs sl_pcie_100_int_ssc_cmn_regs
[] = {
4591 {0x0004, CMN_PLL0_DSM_DIAG_M0
},
4592 {0x0004, CMN_PLL0_DSM_DIAG_M1
},
4593 {0x0004, CMN_PLL1_DSM_DIAG_M0
},
4594 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M0
},
4595 {0x0509, CMN_PDIAG_PLL0_CP_PADJ_M1
},
4596 {0x0509, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4597 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M0
},
4598 {0x0F00, CMN_PDIAG_PLL0_CP_IADJ_M1
},
4599 {0x0F00, CMN_PDIAG_PLL1_CP_IADJ_M0
},
4600 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M0
},
4601 {0x0F08, CMN_PDIAG_PLL0_FILT_PADJ_M1
},
4602 {0x0F08, CMN_PDIAG_PLL1_FILT_PADJ_M0
},
4603 {0x0064, CMN_PLL0_INTDIV_M0
},
4604 {0x0050, CMN_PLL0_INTDIV_M1
},
4605 {0x0050, CMN_PLL1_INTDIV_M0
},
4606 {0x0002, CMN_PLL0_FRACDIVH_M0
},
4607 {0x0002, CMN_PLL0_FRACDIVH_M1
},
4608 {0x0002, CMN_PLL1_FRACDIVH_M0
},
4609 {0x0044, CMN_PLL0_HIGH_THR_M0
},
4610 {0x0036, CMN_PLL0_HIGH_THR_M1
},
4611 {0x0036, CMN_PLL1_HIGH_THR_M0
},
4612 {0x0002, CMN_PDIAG_PLL0_CTRL_M0
},
4613 {0x0002, CMN_PDIAG_PLL0_CTRL_M1
},
4614 {0x0002, CMN_PDIAG_PLL1_CTRL_M0
},
4615 {0x0001, CMN_PLL0_SS_CTRL1_M0
},
4616 {0x0001, CMN_PLL0_SS_CTRL1_M1
},
4617 {0x0001, CMN_PLL1_SS_CTRL1_M0
},
4618 {0x011B, CMN_PLL0_SS_CTRL2_M0
},
4619 {0x011B, CMN_PLL0_SS_CTRL2_M1
},
4620 {0x011B, CMN_PLL1_SS_CTRL2_M0
},
4621 {0x006E, CMN_PLL0_SS_CTRL3_M0
},
4622 {0x0058, CMN_PLL0_SS_CTRL3_M1
},
4623 {0x0058, CMN_PLL1_SS_CTRL3_M0
},
4624 {0x000E, CMN_PLL0_SS_CTRL4_M0
},
4625 {0x0012, CMN_PLL0_SS_CTRL4_M1
},
4626 {0x0012, CMN_PLL1_SS_CTRL4_M0
},
4627 {0x0C5E, CMN_PLL0_VCOCAL_REFTIM_START
},
4628 {0x0C5E, CMN_PLL1_VCOCAL_REFTIM_START
},
4629 {0x0C56, CMN_PLL0_VCOCAL_PLLCNT_START
},
4630 {0x0C56, CMN_PLL1_VCOCAL_PLLCNT_START
},
4631 {0x00C7, CMN_PLL0_LOCK_REFCNT_START
},
4632 {0x00C7, CMN_PLL1_LOCK_REFCNT_START
},
4633 {0x00C7, CMN_PLL0_LOCK_PLLCNT_START
},
4634 {0x00C7, CMN_PLL1_LOCK_PLLCNT_START
},
4635 {0x0005, CMN_PLL0_LOCK_PLLCNT_THR
},
4636 {0x0005, CMN_PLL1_LOCK_PLLCNT_THR
}
4639 static const struct cdns_torrent_vals sl_pcie_100_int_ssc_cmn_vals
= {
4640 .reg_pairs
= sl_pcie_100_int_ssc_cmn_regs
,
4641 .num_regs
= ARRAY_SIZE(sl_pcie_100_int_ssc_cmn_regs
),
4644 /* PCIe, 100 MHz Ref clk, no SSC & external SSC */
4645 static const struct cdns_reg_pairs pcie_100_ext_no_ssc_cmn_regs
[] = {
4646 {0x0028, CMN_PDIAG_PLL1_CP_PADJ_M0
},
4647 {0x001E, CMN_PLL1_DSM_FBH_OVRD_M0
},
4648 {0x000C, CMN_PLL1_DSM_FBL_OVRD_M0
}
4651 static const struct cdns_reg_pairs pcie_100_ext_no_ssc_rx_ln_regs
[] = {
4652 {0x0019, RX_REE_TAP1_CLIP
},
4653 {0x0019, RX_REE_TAP2TON_CLIP
},
4654 {0x0001, RX_DIAG_ACYA
}
4657 static const struct cdns_torrent_vals pcie_100_no_ssc_cmn_vals
= {
4658 .reg_pairs
= pcie_100_ext_no_ssc_cmn_regs
,
4659 .num_regs
= ARRAY_SIZE(pcie_100_ext_no_ssc_cmn_regs
),
4662 static const struct cdns_torrent_vals pcie_100_no_ssc_rx_ln_vals
= {
4663 .reg_pairs
= pcie_100_ext_no_ssc_rx_ln_regs
,
4664 .num_regs
= ARRAY_SIZE(pcie_100_ext_no_ssc_rx_ln_regs
),
4667 static const struct cdns_torrent_vals_entry link_cmn_vals_entries
[] = {
4668 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP
, TYPE_NONE
), &sl_dp_link_cmn_vals
},
4669 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP
, TYPE_PCIE
), &pcie_dp_link_cmn_vals
},
4670 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP
, TYPE_USB
), &usb_dp_link_cmn_vals
},
4672 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_NONE
), NULL
},
4673 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_SGMII
), &pcie_sgmii_link_cmn_vals
},
4674 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_QSGMII
), &pcie_sgmii_link_cmn_vals
},
4675 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_USB
), &pcie_usb_link_cmn_vals
},
4676 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_DP
), &pcie_dp_link_cmn_vals
},
4677 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_USXGMII
), &pcie_usxgmii_link_cmn_vals
},
4679 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_NONE
), &sl_sgmii_link_cmn_vals
},
4680 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_PCIE
), &pcie_sgmii_link_cmn_vals
},
4681 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_QSGMII
), &sgmii_qsgmii_link_cmn_vals
},
4682 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_USB
), &usb_sgmii_link_cmn_vals
},
4683 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_USXGMII
), &usxgmii_sgmii_link_cmn_vals
},
4685 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_NONE
), &sl_sgmii_link_cmn_vals
},
4686 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_PCIE
), &pcie_sgmii_link_cmn_vals
},
4687 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_SGMII
), &sgmii_qsgmii_link_cmn_vals
},
4688 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_USB
), &usb_sgmii_link_cmn_vals
},
4689 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_USXGMII
), &usxgmii_sgmii_link_cmn_vals
},
4691 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_NONE
), &sl_usb_link_cmn_vals
},
4692 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_PCIE
), &pcie_usb_link_cmn_vals
},
4693 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_SGMII
), &usb_sgmii_link_cmn_vals
},
4694 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_QSGMII
), &usb_sgmii_link_cmn_vals
},
4695 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_DP
), &usb_dp_link_cmn_vals
},
4697 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_NONE
), &sl_usxgmii_link_cmn_vals
},
4698 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_PCIE
), &pcie_usxgmii_link_cmn_vals
},
4699 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_SGMII
), &usxgmii_sgmii_link_cmn_vals
},
4700 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_QSGMII
), &usxgmii_sgmii_link_cmn_vals
},
4703 static const struct cdns_torrent_vals_entry xcvr_diag_vals_entries
[] = {
4704 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP
, TYPE_NONE
), &sl_dp_xcvr_diag_ln_vals
},
4705 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP
, TYPE_PCIE
), &dp_pcie_xcvr_diag_ln_vals
},
4706 {CDNS_TORRENT_KEY_ANYCLK(TYPE_DP
, TYPE_USB
), &dp_usb_xcvr_diag_ln_vals
},
4708 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_NONE
), NULL
},
4709 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_SGMII
), &pcie_sgmii_xcvr_diag_ln_vals
},
4710 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_QSGMII
), &pcie_sgmii_xcvr_diag_ln_vals
},
4711 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_USB
), &pcie_usb_xcvr_diag_ln_vals
},
4712 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_DP
), &pcie_dp_xcvr_diag_ln_vals
},
4713 {CDNS_TORRENT_KEY_ANYCLK(TYPE_PCIE
, TYPE_USXGMII
), &pcie_usxgmii_xcvr_diag_ln_vals
},
4715 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_NONE
), &sl_sgmii_xcvr_diag_ln_vals
},
4716 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_PCIE
), &sgmii_pcie_xcvr_diag_ln_vals
},
4717 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_QSGMII
), &sgmii_qsgmii_xcvr_diag_ln_vals
},
4718 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_USB
), &sgmii_usb_xcvr_diag_ln_vals
},
4719 {CDNS_TORRENT_KEY_ANYCLK(TYPE_SGMII
, TYPE_USXGMII
), &sgmii_usxgmii_xcvr_diag_ln_vals
},
4721 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_NONE
), &sl_sgmii_xcvr_diag_ln_vals
},
4722 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_PCIE
), &sgmii_pcie_xcvr_diag_ln_vals
},
4723 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_SGMII
), &sgmii_qsgmii_xcvr_diag_ln_vals
},
4724 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_USB
), &sgmii_usb_xcvr_diag_ln_vals
},
4725 {CDNS_TORRENT_KEY_ANYCLK(TYPE_QSGMII
, TYPE_USXGMII
), &sgmii_usxgmii_xcvr_diag_ln_vals
},
4727 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_NONE
), &sl_usb_xcvr_diag_ln_vals
},
4728 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_PCIE
), &usb_pcie_xcvr_diag_ln_vals
},
4729 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_SGMII
), &usb_sgmii_xcvr_diag_ln_vals
},
4730 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_QSGMII
), &usb_sgmii_xcvr_diag_ln_vals
},
4731 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_DP
), &usb_dp_xcvr_diag_ln_vals
},
4733 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_NONE
), &sl_usxgmii_xcvr_diag_ln_vals
},
4734 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_PCIE
), &usxgmii_pcie_xcvr_diag_ln_vals
},
4735 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_SGMII
), &usxgmii_sgmii_xcvr_diag_ln_vals
},
4736 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_QSGMII
), &usxgmii_sgmii_xcvr_diag_ln_vals
},
4739 static const struct cdns_torrent_vals_entry pcs_cmn_vals_entries
[] = {
4740 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_NONE
), &usb_phy_pcs_cmn_vals
},
4741 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_PCIE
), &usb_phy_pcs_cmn_vals
},
4742 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_SGMII
), &usb_phy_pcs_cmn_vals
},
4743 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_QSGMII
), &usb_phy_pcs_cmn_vals
},
4744 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USB
, TYPE_DP
), &usb_phy_pcs_cmn_vals
},
4747 static const struct cdns_torrent_vals_entry cmn_vals_entries
[] = {
4748 {CDNS_TORRENT_KEY(CLK_19_2_MHZ
, CLK_19_2_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_19_2_no_ssc_cmn_vals
},
4749 {CDNS_TORRENT_KEY(CLK_25_MHZ
, CLK_25_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_25_no_ssc_cmn_vals
},
4751 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_100_no_ssc_cmn_vals
},
4752 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_PCIE
, NO_SSC
), &dp_100_no_ssc_cmn_vals
},
4753 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_USB
, NO_SSC
), &sl_dp_100_no_ssc_cmn_vals
},
4755 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, NO_SSC
), NULL
},
4756 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, EXTERNAL_SSC
), NULL
},
4757 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, INTERNAL_SSC
), &sl_pcie_100_int_ssc_cmn_vals
},
4759 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, NO_SSC
), &pcie_100_no_ssc_cmn_vals
},
4760 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, EXTERNAL_SSC
), &pcie_100_no_ssc_cmn_vals
},
4761 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, INTERNAL_SSC
), &pcie_100_int_ssc_cmn_vals
},
4763 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, NO_SSC
), &pcie_100_no_ssc_cmn_vals
},
4764 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, EXTERNAL_SSC
), &pcie_100_no_ssc_cmn_vals
},
4765 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, INTERNAL_SSC
), &pcie_100_int_ssc_cmn_vals
},
4767 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, NO_SSC
), &pcie_100_no_ssc_cmn_vals
},
4768 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, EXTERNAL_SSC
), &pcie_100_no_ssc_cmn_vals
},
4769 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, INTERNAL_SSC
), &pcie_100_int_ssc_cmn_vals
},
4771 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_DP
, NO_SSC
), NULL
},
4773 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_NONE
, NO_SSC
), &sl_sgmii_100_no_ssc_cmn_vals
},
4775 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, NO_SSC
), &sgmii_100_no_ssc_cmn_vals
},
4776 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &sgmii_100_no_ssc_cmn_vals
},
4777 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, INTERNAL_SSC
), &sgmii_100_int_ssc_cmn_vals
},
4779 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_QSGMII
, NO_SSC
), &sl_sgmii_100_no_ssc_cmn_vals
},
4781 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, NO_SSC
), &sgmii_100_no_ssc_cmn_vals
},
4782 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, EXTERNAL_SSC
), &sgmii_100_no_ssc_cmn_vals
},
4783 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, INTERNAL_SSC
), &sgmii_100_no_ssc_cmn_vals
},
4785 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_NONE
, NO_SSC
), &sl_qsgmii_100_no_ssc_cmn_vals
},
4787 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, NO_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
4788 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
4789 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, INTERNAL_SSC
), &qsgmii_100_int_ssc_cmn_vals
},
4791 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_SGMII
, NO_SSC
), &sl_qsgmii_100_no_ssc_cmn_vals
},
4793 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, NO_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
4794 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
4795 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, INTERNAL_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
4797 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, NO_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
4798 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, EXTERNAL_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
4799 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, INTERNAL_SSC
), &sl_usb_100_int_ssc_cmn_vals
},
4801 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, NO_SSC
), &usb_100_no_ssc_cmn_vals
},
4802 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, EXTERNAL_SSC
), &usb_100_no_ssc_cmn_vals
},
4803 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, INTERNAL_SSC
), &usb_100_int_ssc_cmn_vals
},
4805 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, NO_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
4806 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, EXTERNAL_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
4807 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, INTERNAL_SSC
), &sl_usb_100_int_ssc_cmn_vals
},
4809 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, NO_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
4810 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, EXTERNAL_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
4811 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, INTERNAL_SSC
), &sl_usb_100_int_ssc_cmn_vals
},
4813 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_DP
, NO_SSC
), &usb_100_no_ssc_cmn_vals
},
4815 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_156_25_MHZ
, TYPE_USXGMII
, TYPE_NONE
, NO_SSC
), &sl_usxgmii_156_25_no_ssc_cmn_vals
},
4818 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_PCIE
, TYPE_USXGMII
, NO_SSC
), NULL
},
4820 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_SGMII
, TYPE_USXGMII
, NO_SSC
), &ml_sgmii_pll1_100_no_ssc_cmn_vals
},
4822 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_QSGMII
, TYPE_USXGMII
, NO_SSC
), &ml_sgmii_pll1_100_no_ssc_cmn_vals
},
4824 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_PCIE
, NO_SSC
), &ml_usxgmii_pll1_156_25_no_ssc_cmn_vals
},
4825 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_SGMII
, NO_SSC
), &ml_usxgmii_pll0_156_25_no_ssc_cmn_vals
},
4826 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_QSGMII
, NO_SSC
), &ml_usxgmii_pll0_156_25_no_ssc_cmn_vals
},
4829 static const struct cdns_torrent_vals_entry cdns_tx_ln_vals_entries
[] = {
4830 {CDNS_TORRENT_KEY(CLK_19_2_MHZ
, CLK_19_2_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_19_2_no_ssc_tx_ln_vals
},
4831 {CDNS_TORRENT_KEY(CLK_25_MHZ
, CLK_25_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_25_no_ssc_tx_ln_vals
},
4833 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_100_no_ssc_tx_ln_vals
},
4834 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_PCIE
, NO_SSC
), &dp_100_no_ssc_tx_ln_vals
},
4835 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_USB
, NO_SSC
), &dp_100_no_ssc_tx_ln_vals
},
4837 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, NO_SSC
), NULL
},
4838 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, EXTERNAL_SSC
), NULL
},
4839 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, INTERNAL_SSC
), NULL
},
4841 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, NO_SSC
), NULL
},
4842 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, EXTERNAL_SSC
), NULL
},
4843 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, INTERNAL_SSC
), NULL
},
4845 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, NO_SSC
), NULL
},
4846 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, EXTERNAL_SSC
), NULL
},
4847 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, INTERNAL_SSC
), NULL
},
4849 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, NO_SSC
), NULL
},
4850 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, EXTERNAL_SSC
), NULL
},
4851 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, INTERNAL_SSC
), NULL
},
4853 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_DP
, NO_SSC
), NULL
},
4855 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_NONE
, NO_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4857 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, NO_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4858 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4859 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, INTERNAL_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4861 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_QSGMII
, NO_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4863 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, NO_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4864 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, EXTERNAL_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4865 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, INTERNAL_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4867 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_NONE
, NO_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4869 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, NO_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4870 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4871 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, INTERNAL_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4873 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_SGMII
, NO_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4875 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, NO_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4876 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4877 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, INTERNAL_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4879 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4880 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4881 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4883 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4884 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4885 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4887 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4888 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4889 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4891 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4892 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4893 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4895 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_DP
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
4897 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_156_25_MHZ
, TYPE_USXGMII
, TYPE_NONE
, NO_SSC
), &usxgmii_156_25_no_ssc_tx_ln_vals
},
4900 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_PCIE
, TYPE_USXGMII
, NO_SSC
), NULL
},
4902 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_SGMII
, TYPE_USXGMII
, NO_SSC
), &sgmii_100_no_ssc_tx_ln_vals
},
4904 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_QSGMII
, TYPE_USXGMII
, NO_SSC
), &qsgmii_100_no_ssc_tx_ln_vals
},
4906 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_PCIE
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_tx_ln_vals
},
4907 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_SGMII
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_tx_ln_vals
},
4908 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_QSGMII
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_tx_ln_vals
},
4911 static const struct cdns_torrent_vals_entry cdns_rx_ln_vals_entries
[] = {
4912 {CDNS_TORRENT_KEY(CLK_19_2_MHZ
, CLK_19_2_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_19_2_no_ssc_rx_ln_vals
},
4913 {CDNS_TORRENT_KEY(CLK_25_MHZ
, CLK_25_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_25_no_ssc_rx_ln_vals
},
4915 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_100_no_ssc_rx_ln_vals
},
4916 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_PCIE
, NO_SSC
), &dp_100_no_ssc_rx_ln_vals
},
4917 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_USB
, NO_SSC
), &dp_100_no_ssc_rx_ln_vals
},
4919 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4920 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, EXTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4921 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, INTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4923 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4924 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, EXTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4925 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, INTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4927 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4928 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, EXTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4929 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, INTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4931 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4932 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, EXTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4933 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, INTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4935 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_DP
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4937 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_NONE
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4939 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4940 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4941 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, INTERNAL_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4943 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_QSGMII
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4945 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4946 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, EXTERNAL_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4947 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, INTERNAL_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4949 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_NONE
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4951 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4952 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4953 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, INTERNAL_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4955 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_SGMII
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4957 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4958 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4959 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, INTERNAL_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4961 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4962 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, EXTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4963 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, INTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4965 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4966 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, EXTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4967 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, INTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4969 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4970 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4971 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, INTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4973 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4974 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4975 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, INTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4977 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_DP
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
4979 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_156_25_MHZ
, TYPE_USXGMII
, TYPE_NONE
, NO_SSC
), &usxgmii_156_25_no_ssc_rx_ln_vals
},
4982 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_PCIE
, TYPE_USXGMII
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
4984 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_SGMII
, TYPE_USXGMII
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
4986 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_QSGMII
, TYPE_USXGMII
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
4988 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_PCIE
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_rx_ln_vals
},
4989 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_SGMII
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_rx_ln_vals
},
4990 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_QSGMII
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_rx_ln_vals
},
4993 static const struct cdns_torrent_data cdns_map_torrent
= {
4994 .block_offset_shift
= 0x2,
4995 .reg_offset_shift
= 0x2,
4996 .link_cmn_vals_tbl
= {
4997 .entries
= link_cmn_vals_entries
,
4998 .num_entries
= ARRAY_SIZE(link_cmn_vals_entries
),
5000 .xcvr_diag_vals_tbl
= {
5001 .entries
= xcvr_diag_vals_entries
,
5002 .num_entries
= ARRAY_SIZE(xcvr_diag_vals_entries
),
5004 .pcs_cmn_vals_tbl
= {
5005 .entries
= pcs_cmn_vals_entries
,
5006 .num_entries
= ARRAY_SIZE(pcs_cmn_vals_entries
),
5009 .entries
= cmn_vals_entries
,
5010 .num_entries
= ARRAY_SIZE(cmn_vals_entries
),
5013 .entries
= cdns_tx_ln_vals_entries
,
5014 .num_entries
= ARRAY_SIZE(cdns_tx_ln_vals_entries
),
5017 .entries
= cdns_rx_ln_vals_entries
,
5018 .num_entries
= ARRAY_SIZE(cdns_rx_ln_vals_entries
),
5022 static const struct cdns_torrent_vals_entry j721e_phy_pma_cmn_vals_entries
[] = {
5023 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_NONE
), &ti_usxgmii_phy_pma_cmn_vals
},
5024 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_PCIE
), &ti_usxgmii_phy_pma_cmn_vals
},
5025 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_SGMII
), &ti_usxgmii_phy_pma_cmn_vals
},
5026 {CDNS_TORRENT_KEY_ANYCLK(TYPE_USXGMII
, TYPE_QSGMII
), &ti_usxgmii_phy_pma_cmn_vals
},
5029 static const struct cdns_torrent_vals_entry ti_tx_ln_vals_entries
[] = {
5030 {CDNS_TORRENT_KEY(CLK_19_2_MHZ
, CLK_19_2_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_19_2_no_ssc_tx_ln_vals
},
5031 {CDNS_TORRENT_KEY(CLK_25_MHZ
, CLK_25_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_25_no_ssc_tx_ln_vals
},
5033 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_100_no_ssc_tx_ln_vals
},
5034 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_PCIE
, NO_SSC
), &dp_100_no_ssc_tx_ln_vals
},
5035 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_USB
, NO_SSC
), &dp_100_no_ssc_tx_ln_vals
},
5037 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, NO_SSC
), NULL
},
5038 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, EXTERNAL_SSC
), NULL
},
5039 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, INTERNAL_SSC
), NULL
},
5041 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, NO_SSC
), NULL
},
5042 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, EXTERNAL_SSC
), NULL
},
5043 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, INTERNAL_SSC
), NULL
},
5045 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, NO_SSC
), NULL
},
5046 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, EXTERNAL_SSC
), NULL
},
5047 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, INTERNAL_SSC
), NULL
},
5049 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, NO_SSC
), NULL
},
5050 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, EXTERNAL_SSC
), NULL
},
5051 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, INTERNAL_SSC
), NULL
},
5053 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_DP
, NO_SSC
), NULL
},
5055 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_NONE
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5057 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5058 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5059 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, INTERNAL_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5061 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_QSGMII
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5063 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5064 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, EXTERNAL_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5065 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, INTERNAL_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5067 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_NONE
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5069 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5070 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5071 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, INTERNAL_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5073 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_SGMII
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5075 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5076 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, EXTERNAL_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5077 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, INTERNAL_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5079 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5080 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5081 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5083 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5084 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5085 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5087 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5088 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5089 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5091 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5092 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5093 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5095 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_DP
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5097 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_156_25_MHZ
, TYPE_USXGMII
, TYPE_NONE
, NO_SSC
), &usxgmii_156_25_no_ssc_tx_ln_vals
},
5100 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_PCIE
, TYPE_USXGMII
, NO_SSC
), NULL
},
5102 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_SGMII
, TYPE_USXGMII
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5104 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_QSGMII
, TYPE_USXGMII
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5106 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_PCIE
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_tx_ln_vals
},
5107 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_SGMII
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_tx_ln_vals
},
5108 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_QSGMII
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_tx_ln_vals
},
5111 static const struct cdns_torrent_data ti_j721e_map_torrent
= {
5112 .block_offset_shift
= 0x0,
5113 .reg_offset_shift
= 0x1,
5114 .link_cmn_vals_tbl
= {
5115 .entries
= link_cmn_vals_entries
,
5116 .num_entries
= ARRAY_SIZE(link_cmn_vals_entries
),
5118 .xcvr_diag_vals_tbl
= {
5119 .entries
= xcvr_diag_vals_entries
,
5120 .num_entries
= ARRAY_SIZE(xcvr_diag_vals_entries
),
5122 .pcs_cmn_vals_tbl
= {
5123 .entries
= pcs_cmn_vals_entries
,
5124 .num_entries
= ARRAY_SIZE(pcs_cmn_vals_entries
),
5126 .phy_pma_cmn_vals_tbl
= {
5127 .entries
= j721e_phy_pma_cmn_vals_entries
,
5128 .num_entries
= ARRAY_SIZE(j721e_phy_pma_cmn_vals_entries
),
5131 .entries
= cmn_vals_entries
,
5132 .num_entries
= ARRAY_SIZE(cmn_vals_entries
),
5135 .entries
= ti_tx_ln_vals_entries
,
5136 .num_entries
= ARRAY_SIZE(ti_tx_ln_vals_entries
),
5139 .entries
= cdns_rx_ln_vals_entries
,
5140 .num_entries
= ARRAY_SIZE(cdns_rx_ln_vals_entries
),
5144 /* TI J7200 (Torrent SD0805) */
5145 static const struct cdns_torrent_vals_entry ti_j7200_cmn_vals_entries
[] = {
5146 {CDNS_TORRENT_KEY(CLK_19_2_MHZ
, CLK_19_2_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_19_2_no_ssc_cmn_vals
},
5147 {CDNS_TORRENT_KEY(CLK_25_MHZ
, CLK_25_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_25_no_ssc_cmn_vals
},
5149 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_100_no_ssc_cmn_vals
},
5150 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_PCIE
, NO_SSC
), &dp_100_no_ssc_cmn_vals
},
5151 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_USB
, NO_SSC
), &sl_dp_100_no_ssc_cmn_vals
},
5153 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, NO_SSC
), NULL
},
5154 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, EXTERNAL_SSC
), NULL
},
5155 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, INTERNAL_SSC
), &sl_pcie_100_int_ssc_cmn_vals
},
5157 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, NO_SSC
), &pcie_100_no_ssc_cmn_vals
},
5158 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, EXTERNAL_SSC
), &pcie_100_no_ssc_cmn_vals
},
5159 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, INTERNAL_SSC
), &pcie_100_int_ssc_cmn_vals
},
5161 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, NO_SSC
), &pcie_100_no_ssc_cmn_vals
},
5162 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, EXTERNAL_SSC
), &pcie_100_no_ssc_cmn_vals
},
5163 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, INTERNAL_SSC
), &pcie_100_int_ssc_cmn_vals
},
5165 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, NO_SSC
), &pcie_100_no_ssc_cmn_vals
},
5166 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, EXTERNAL_SSC
), &pcie_100_no_ssc_cmn_vals
},
5167 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, INTERNAL_SSC
), &pcie_100_int_ssc_cmn_vals
},
5169 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_DP
, NO_SSC
), NULL
},
5171 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_NONE
, NO_SSC
), &sl_sgmii_100_no_ssc_cmn_vals
},
5173 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, NO_SSC
), &sgmii_100_no_ssc_cmn_vals
},
5174 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &sgmii_100_no_ssc_cmn_vals
},
5175 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, INTERNAL_SSC
), &sgmii_100_int_ssc_cmn_vals
},
5177 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_QSGMII
, NO_SSC
), &sl_sgmii_100_no_ssc_cmn_vals
},
5179 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, NO_SSC
), &sgmii_100_no_ssc_cmn_vals
},
5180 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, EXTERNAL_SSC
), &sgmii_100_no_ssc_cmn_vals
},
5181 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, INTERNAL_SSC
), &sgmii_100_no_ssc_cmn_vals
},
5183 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_NONE
, NO_SSC
), &sl_qsgmii_100_no_ssc_cmn_vals
},
5185 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, NO_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
5186 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
5187 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, INTERNAL_SSC
), &qsgmii_100_int_ssc_cmn_vals
},
5189 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_SGMII
, NO_SSC
), &sl_qsgmii_100_no_ssc_cmn_vals
},
5191 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, NO_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
5192 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
5193 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, INTERNAL_SSC
), &qsgmii_100_no_ssc_cmn_vals
},
5195 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, NO_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
5196 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, EXTERNAL_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
5197 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, INTERNAL_SSC
), &sl_usb_100_int_ssc_cmn_vals
},
5199 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, NO_SSC
), &usb_100_no_ssc_cmn_vals
},
5200 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, EXTERNAL_SSC
), &usb_100_no_ssc_cmn_vals
},
5201 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, INTERNAL_SSC
), &usb_100_int_ssc_cmn_vals
},
5203 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, NO_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
5204 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, EXTERNAL_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
5205 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, INTERNAL_SSC
), &sl_usb_100_int_ssc_cmn_vals
},
5207 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, NO_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
5208 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, EXTERNAL_SSC
), &sl_usb_100_no_ssc_cmn_vals
},
5209 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, INTERNAL_SSC
), &sl_usb_100_int_ssc_cmn_vals
},
5211 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_DP
, NO_SSC
), &usb_100_no_ssc_cmn_vals
},
5213 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_156_25_MHZ
, TYPE_USXGMII
, TYPE_NONE
, NO_SSC
), &sl_usxgmii_156_25_no_ssc_cmn_vals
},
5216 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_PCIE
, TYPE_USXGMII
, NO_SSC
), NULL
},
5218 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_SGMII
, TYPE_USXGMII
, NO_SSC
), &j7200_ml_sgmii_pll1_100_no_ssc_cmn_vals
},
5220 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_QSGMII
, TYPE_USXGMII
, NO_SSC
), &j7200_ml_sgmii_pll1_100_no_ssc_cmn_vals
},
5222 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_PCIE
, NO_SSC
), &ml_usxgmii_pll1_156_25_no_ssc_cmn_vals
},
5223 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_SGMII
, NO_SSC
), &j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_vals
},
5224 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_QSGMII
, NO_SSC
), &j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_vals
},
5227 static const struct cdns_torrent_vals_entry ti_j7200_tx_ln_vals_entries
[] = {
5228 {CDNS_TORRENT_KEY(CLK_19_2_MHZ
, CLK_19_2_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_19_2_no_ssc_tx_ln_vals
},
5229 {CDNS_TORRENT_KEY(CLK_25_MHZ
, CLK_25_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_25_no_ssc_tx_ln_vals
},
5231 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_100_no_ssc_tx_ln_vals
},
5232 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_PCIE
, NO_SSC
), &dp_100_no_ssc_tx_ln_vals
},
5233 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_USB
, NO_SSC
), &dp_100_no_ssc_tx_ln_vals
},
5235 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, NO_SSC
), NULL
},
5236 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, EXTERNAL_SSC
), NULL
},
5237 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, INTERNAL_SSC
), NULL
},
5239 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, NO_SSC
), NULL
},
5240 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, EXTERNAL_SSC
), NULL
},
5241 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, INTERNAL_SSC
), NULL
},
5243 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, NO_SSC
), NULL
},
5244 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, EXTERNAL_SSC
), NULL
},
5245 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, INTERNAL_SSC
), NULL
},
5247 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, NO_SSC
), NULL
},
5248 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, EXTERNAL_SSC
), NULL
},
5249 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, INTERNAL_SSC
), NULL
},
5251 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_DP
, NO_SSC
), NULL
},
5253 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_NONE
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5255 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5256 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5257 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, INTERNAL_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5259 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_QSGMII
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5261 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, NO_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5262 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, EXTERNAL_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5263 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, INTERNAL_SSC
), &ti_sgmii_100_no_ssc_tx_ln_vals
},
5265 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_NONE
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5267 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5268 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5269 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, INTERNAL_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5271 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_SGMII
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5273 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, NO_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5274 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, EXTERNAL_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5275 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, INTERNAL_SSC
), &ti_qsgmii_100_no_ssc_tx_ln_vals
},
5277 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5278 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5279 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5281 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5282 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5283 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5285 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5286 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5287 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5289 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5290 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5291 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, INTERNAL_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5293 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_DP
, NO_SSC
), &usb_100_no_ssc_tx_ln_vals
},
5295 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_156_25_MHZ
, TYPE_USXGMII
, TYPE_NONE
, NO_SSC
), &usxgmii_156_25_no_ssc_tx_ln_vals
},
5298 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_PCIE
, TYPE_USXGMII
, NO_SSC
), NULL
},
5300 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_SGMII
, TYPE_USXGMII
, NO_SSC
), &j7200_sgmii_100_no_ssc_tx_ln_vals
},
5302 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_QSGMII
, TYPE_USXGMII
, NO_SSC
), &j7200_qsgmii_100_no_ssc_tx_ln_vals
},
5304 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_PCIE
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_tx_ln_vals
},
5305 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_SGMII
, NO_SSC
), &usxgmii_156_25_no_ssc_tx_ln_vals
},
5306 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_QSGMII
, NO_SSC
), &usxgmii_156_25_no_ssc_tx_ln_vals
},
5309 static const struct cdns_torrent_vals_entry ti_j7200_rx_ln_vals_entries
[] = {
5310 {CDNS_TORRENT_KEY(CLK_19_2_MHZ
, CLK_19_2_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_19_2_no_ssc_rx_ln_vals
},
5311 {CDNS_TORRENT_KEY(CLK_25_MHZ
, CLK_25_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_25_no_ssc_rx_ln_vals
},
5313 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_NONE
, NO_SSC
), &sl_dp_100_no_ssc_rx_ln_vals
},
5314 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_PCIE
, NO_SSC
), &dp_100_no_ssc_rx_ln_vals
},
5315 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_DP
, TYPE_USB
, NO_SSC
), &dp_100_no_ssc_rx_ln_vals
},
5317 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5318 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, EXTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5319 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_NONE
, INTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5321 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5322 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, EXTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5323 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_SGMII
, INTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5325 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5326 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, EXTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5327 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_QSGMII
, INTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5329 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5330 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, EXTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5331 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_USB
, INTERNAL_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5333 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_PCIE
, TYPE_DP
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5335 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_NONE
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
5337 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
5338 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
5339 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_PCIE
, INTERNAL_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
5341 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_QSGMII
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
5343 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, NO_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
5344 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, EXTERNAL_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
5345 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_SGMII
, TYPE_USB
, INTERNAL_SSC
), &sgmii_100_no_ssc_rx_ln_vals
},
5347 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_NONE
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
5349 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
5350 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
5351 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_PCIE
, INTERNAL_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
5353 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_SGMII
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
5355 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, NO_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
5356 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, EXTERNAL_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
5357 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_QSGMII
, TYPE_USB
, INTERNAL_SSC
), &qsgmii_100_no_ssc_rx_ln_vals
},
5359 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5360 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, EXTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5361 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_NONE
, INTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5363 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5364 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, EXTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5365 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_PCIE
, INTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5367 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5368 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5369 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_SGMII
, INTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5371 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5372 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, EXTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5373 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_QSGMII
, INTERNAL_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5375 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_100_MHZ
, TYPE_USB
, TYPE_DP
, NO_SSC
), &usb_100_no_ssc_rx_ln_vals
},
5377 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_156_25_MHZ
, TYPE_USXGMII
, TYPE_NONE
, NO_SSC
), &usxgmii_156_25_no_ssc_rx_ln_vals
},
5380 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_PCIE
, TYPE_USXGMII
, NO_SSC
), &pcie_100_no_ssc_rx_ln_vals
},
5382 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_SGMII
, TYPE_USXGMII
, NO_SSC
), &j7200_sgmii_100_no_ssc_rx_ln_vals
},
5384 {CDNS_TORRENT_KEY(CLK_100_MHZ
, CLK_156_25_MHZ
, TYPE_QSGMII
, TYPE_USXGMII
, NO_SSC
), &j7200_qsgmii_100_no_ssc_rx_ln_vals
},
5386 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_PCIE
, NO_SSC
), &ml_usxgmii_156_25_no_ssc_rx_ln_vals
},
5387 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_SGMII
, NO_SSC
), &usxgmii_156_25_no_ssc_rx_ln_vals
},
5388 {CDNS_TORRENT_KEY(CLK_156_25_MHZ
, CLK_100_MHZ
, TYPE_USXGMII
, TYPE_QSGMII
, NO_SSC
), &usxgmii_156_25_no_ssc_rx_ln_vals
},
5391 static const struct cdns_torrent_data ti_j7200_map_torrent
= {
5392 .block_offset_shift
= 0x0,
5393 .reg_offset_shift
= 0x1,
5394 .link_cmn_vals_tbl
= {
5395 .entries
= link_cmn_vals_entries
,
5396 .num_entries
= ARRAY_SIZE(link_cmn_vals_entries
),
5398 .xcvr_diag_vals_tbl
= {
5399 .entries
= xcvr_diag_vals_entries
,
5400 .num_entries
= ARRAY_SIZE(xcvr_diag_vals_entries
),
5402 .pcs_cmn_vals_tbl
= {
5403 .entries
= pcs_cmn_vals_entries
,
5404 .num_entries
= ARRAY_SIZE(pcs_cmn_vals_entries
),
5406 .phy_pma_cmn_vals_tbl
= {
5407 .entries
= j721e_phy_pma_cmn_vals_entries
,
5408 .num_entries
= ARRAY_SIZE(j721e_phy_pma_cmn_vals_entries
),
5411 .entries
= ti_j7200_cmn_vals_entries
,
5412 .num_entries
= ARRAY_SIZE(ti_j7200_cmn_vals_entries
),
5415 .entries
= ti_j7200_tx_ln_vals_entries
,
5416 .num_entries
= ARRAY_SIZE(ti_j7200_tx_ln_vals_entries
),
5419 .entries
= ti_j7200_rx_ln_vals_entries
,
5420 .num_entries
= ARRAY_SIZE(ti_j7200_rx_ln_vals_entries
),
5424 static const struct of_device_id cdns_torrent_phy_of_match
[] = {
5426 .compatible
= "cdns,torrent-phy",
5427 .data
= &cdns_map_torrent
,
5430 .compatible
= "ti,j721e-serdes-10g",
5431 .data
= &ti_j721e_map_torrent
,
5434 .compatible
= "ti,j7200-serdes-10g",
5435 .data
= &ti_j7200_map_torrent
,
5439 MODULE_DEVICE_TABLE(of
, cdns_torrent_phy_of_match
);
5441 static struct platform_driver cdns_torrent_phy_driver
= {
5442 .probe
= cdns_torrent_phy_probe
,
5443 .remove
= cdns_torrent_phy_remove
,
5445 .name
= "cdns-torrent-phy",
5446 .of_match_table
= cdns_torrent_phy_of_match
,
5447 .pm
= pm_sleep_ptr(&cdns_torrent_phy_pm_ops
),
5450 module_platform_driver(cdns_torrent_phy_driver
);
5452 MODULE_AUTHOR("Cadence Design Systems, Inc.");
5453 MODULE_DESCRIPTION("Cadence Torrent PHY driver");
5454 MODULE_LICENSE("GPL v2");