#include <dt-bindings/phy/phy.h>
#include <dt-bindings/phy/phy-cadence.h>
#include <linux/clk.h>
#include <linux/clk-provider.h>
#include <linux/delay.h>
#include <linux/err.h>
#include <linux/io.h>
#include <linux/iopoll.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/phy/phy.h>
#include <linux/platform_device.h>
#include <linux/reset.h>
#include <linux/regmap.h>
#define REF_CLK_19_2MHZ …
#define REF_CLK_25MHZ …
#define REF_CLK_100MHZ …
#define REF_CLK_156_25MHZ …
#define MAX_NUM_LANES …
#define DEFAULT_MAX_BIT_RATE …
#define POLL_TIMEOUT_US …
#define PLL_LOCK_TIMEOUT …
#define DP_PLL0 …
#define DP_PLL1 …
#define TORRENT_COMMON_CDB_OFFSET …
#define TORRENT_TX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) …
#define TORRENT_RX_LANE_CDB_OFFSET(ln, block_offset, reg_offset) …
#define TORRENT_PHY_PCS_COMMON_OFFSET(block_offset) …
#define TORRENT_PHY_PCS_LANE_CDB_OFFSET(ln, block_offset, reg_offset) …
#define TORRENT_PHY_PMA_COMMON_OFFSET(block_offset) …
#define TORRENT_DPTX_PHY_OFFSET …
#define PHY_AUX_CTRL …
#define PHY_RESET …
#define PMA_TX_ELEC_IDLE_SHIFT …
#define PHY_PMA_XCVR_PLLCLK_EN …
#define PHY_PMA_XCVR_PLLCLK_EN_ACK …
#define PHY_PMA_XCVR_POWER_STATE_REQ …
#define PHY_POWER_STATE_LN(ln) …
#define PMA_XCVR_POWER_STATE_REQ_LN_MASK …
#define PHY_PMA_XCVR_POWER_STATE_ACK …
#define PHY_PMA_CMN_READY …
#define CMN_SSM_BANDGAP_TMR …
#define CMN_SSM_BIAS_TMR …
#define CMN_PLLSM0_PLLPRE_TMR …
#define CMN_PLLSM0_PLLLOCK_TMR …
#define CMN_PLLSM1_PLLPRE_TMR …
#define CMN_PLLSM1_PLLLOCK_TMR …
#define CMN_CDIAG_CDB_PWRI_OVRD …
#define CMN_CDIAG_XCVRC_PWRI_OVRD …
#define CMN_CDIAG_REFCLK_OVRD …
#define CMN_CDIAG_REFCLK_DRV0_CTRL …
#define CMN_BGCAL_INIT_TMR …
#define CMN_BGCAL_ITER_TMR …
#define CMN_IBCAL_INIT_TMR …
#define CMN_PLL0_VCOCAL_TCTRL …
#define CMN_PLL0_VCOCAL_INIT_TMR …
#define CMN_PLL0_VCOCAL_ITER_TMR …
#define CMN_PLL0_VCOCAL_REFTIM_START …
#define CMN_PLL0_VCOCAL_PLLCNT_START …
#define CMN_PLL0_INTDIV_M0 …
#define CMN_PLL0_FRACDIVL_M0 …
#define CMN_PLL0_FRACDIVH_M0 …
#define CMN_PLL0_HIGH_THR_M0 …
#define CMN_PLL0_DSM_DIAG_M0 …
#define CMN_PLL0_DSM_FBH_OVRD_M0 …
#define CMN_PLL0_DSM_FBL_OVRD_M0 …
#define CMN_PLL0_SS_CTRL1_M0 …
#define CMN_PLL0_SS_CTRL2_M0 …
#define CMN_PLL0_SS_CTRL3_M0 …
#define CMN_PLL0_SS_CTRL4_M0 …
#define CMN_PLL0_LOCK_REFCNT_START …
#define CMN_PLL0_LOCK_PLLCNT_START …
#define CMN_PLL0_LOCK_PLLCNT_THR …
#define CMN_PLL0_INTDIV_M1 …
#define CMN_PLL0_FRACDIVH_M1 …
#define CMN_PLL0_HIGH_THR_M1 …
#define CMN_PLL0_DSM_DIAG_M1 …
#define CMN_PLL0_SS_CTRL1_M1 …
#define CMN_PLL0_SS_CTRL2_M1 …
#define CMN_PLL0_SS_CTRL3_M1 …
#define CMN_PLL0_SS_CTRL4_M1 …
#define CMN_PLL1_VCOCAL_TCTRL …
#define CMN_PLL1_VCOCAL_INIT_TMR …
#define CMN_PLL1_VCOCAL_ITER_TMR …
#define CMN_PLL1_VCOCAL_REFTIM_START …
#define CMN_PLL1_VCOCAL_PLLCNT_START …
#define CMN_PLL1_INTDIV_M0 …
#define CMN_PLL1_FRACDIVL_M0 …
#define CMN_PLL1_FRACDIVH_M0 …
#define CMN_PLL1_HIGH_THR_M0 …
#define CMN_PLL1_DSM_DIAG_M0 …
#define CMN_PLL1_DSM_FBH_OVRD_M0 …
#define CMN_PLL1_DSM_FBL_OVRD_M0 …
#define CMN_PLL1_SS_CTRL1_M0 …
#define CMN_PLL1_SS_CTRL2_M0 …
#define CMN_PLL1_SS_CTRL3_M0 …
#define CMN_PLL1_SS_CTRL4_M0 …
#define CMN_PLL1_LOCK_REFCNT_START …
#define CMN_PLL1_LOCK_PLLCNT_START …
#define CMN_PLL1_LOCK_PLLCNT_THR …
#define CMN_TXPUCAL_TUNE …
#define CMN_TXPUCAL_INIT_TMR …
#define CMN_TXPUCAL_ITER_TMR …
#define CMN_TXPDCAL_TUNE …
#define CMN_TXPDCAL_INIT_TMR …
#define CMN_TXPDCAL_ITER_TMR …
#define CMN_RXCAL_INIT_TMR …
#define CMN_RXCAL_ITER_TMR …
#define CMN_SD_CAL_INIT_TMR …
#define CMN_SD_CAL_ITER_TMR …
#define CMN_SD_CAL_REFTIM_START …
#define CMN_SD_CAL_PLLCNT_START …
#define CMN_PDIAG_PLL0_CTRL_M0 …
#define CMN_PDIAG_PLL0_CLK_SEL_M0 …
#define CMN_PDIAG_PLL0_CP_PADJ_M0 …
#define CMN_PDIAG_PLL0_CP_IADJ_M0 …
#define CMN_PDIAG_PLL0_FILT_PADJ_M0 …
#define CMN_PDIAG_PLL0_CTRL_M1 …
#define CMN_PDIAG_PLL0_CLK_SEL_M1 …
#define CMN_PDIAG_PLL0_CP_PADJ_M1 …
#define CMN_PDIAG_PLL0_CP_IADJ_M1 …
#define CMN_PDIAG_PLL0_FILT_PADJ_M1 …
#define CMN_PDIAG_PLL1_CTRL_M0 …
#define CMN_PDIAG_PLL1_CLK_SEL_M0 …
#define CMN_PDIAG_PLL1_CP_PADJ_M0 …
#define CMN_PDIAG_PLL1_CP_IADJ_M0 …
#define CMN_PDIAG_PLL1_FILT_PADJ_M0 …
#define CMN_DIAG_BIAS_OVRD1 …
#define TX_TXCC_CTRL …
#define TX_TXCC_CPOST_MULT_00 …
#define TX_TXCC_CPOST_MULT_01 …
#define TX_TXCC_MGNFS_MULT_000 …
#define TX_TXCC_MGNFS_MULT_100 …
#define DRV_DIAG_TX_DRV …
#define XCVR_DIAG_PLLDRC_CTRL …
#define XCVR_DIAG_HSCLK_SEL …
#define XCVR_DIAG_HSCLK_DIV …
#define XCVR_DIAG_RXCLK_CTRL …
#define XCVR_DIAG_BIDI_CTRL …
#define XCVR_DIAG_PSC_OVRD …
#define TX_PSC_A0 …
#define TX_PSC_A1 …
#define TX_PSC_A2 …
#define TX_PSC_A3 …
#define TX_RCVDET_ST_TMR …
#define TX_DIAG_ACYA …
#define TX_DIAG_ACYA_HBDC_MASK …
#define RX_PSC_A0 …
#define RX_PSC_A1 …
#define RX_PSC_A2 …
#define RX_PSC_A3 …
#define RX_PSC_CAL …
#define RX_SDCAL0_INIT_TMR …
#define RX_SDCAL0_ITER_TMR …
#define RX_SDCAL1_INIT_TMR …
#define RX_SDCAL1_ITER_TMR …
#define RX_CDRLF_CNFG …
#define RX_CDRLF_CNFG3 …
#define RX_SIGDET_HL_FILT_TMR …
#define RX_REE_GCSM1_CTRL …
#define RX_REE_GCSM1_EQENM_PH1 …
#define RX_REE_GCSM1_EQENM_PH2 …
#define RX_REE_GCSM2_CTRL …
#define RX_REE_PERGCSM_CTRL …
#define RX_REE_ATTEN_THR …
#define RX_REE_TAP1_CLIP …
#define RX_REE_TAP2TON_CLIP …
#define RX_REE_SMGM_CTRL1 …
#define RX_REE_SMGM_CTRL2 …
#define RX_DIAG_DFE_CTRL …
#define RX_DIAG_DFE_AMP_TUNE_2 …
#define RX_DIAG_DFE_AMP_TUNE_3 …
#define RX_DIAG_NQST_CTRL …
#define RX_DIAG_SIGDET_TUNE …
#define RX_DIAG_PI_RATE …
#define RX_DIAG_PI_CAP …
#define RX_DIAG_ACYA …
#define PHY_PIPE_CMN_CTRL1 …
#define PHY_PLL_CFG …
#define PHY_PIPE_USB3_GEN2_PRE_CFG0 …
#define PHY_PIPE_USB3_GEN2_POST_CFG0 …
#define PHY_PIPE_USB3_GEN2_POST_CFG1 …
#define PHY_PCS_ISO_LINK_CTRL …
#define PHY_PMA_CMN_CTRL1 …
#define PHY_PMA_CMN_CTRL2 …
#define PHY_PMA_PLL_RAW_CTRL …
#define CDNS_TORRENT_OUTPUT_CLOCKS …
static const char * const clk_names[] = …;
static const struct reg_field phy_pll_cfg = …;
static const struct reg_field phy_pma_cmn_ctrl_1 = …;
static const struct reg_field phy_pma_cmn_ctrl_2 = …;
static const struct reg_field phy_pma_pll_raw_ctrl = …;
static const struct reg_field phy_reset_ctrl = …;
static const struct reg_field phy_pcs_iso_link_ctrl_1 = …;
static const struct reg_field phy_pipe_cmn_ctrl1_0 = …;
static const struct reg_field cmn_cdiag_refclk_ovrd_4 = …;
#define REFCLK_OUT_NUM_CMN_CONFIG …
enum cdns_torrent_refclk_out_cmn { … };
static const struct reg_field refclk_out_cmn_cfg[] = …;
static const int refclk_driver_parent_index[] = …;
static const u32 cdns_torrent_refclk_driver_mux_table[] = …;
enum cdns_torrent_phy_type { … };
enum cdns_torrent_ref_clk { … };
enum cdns_torrent_ssc_mode { … };
#define REFCLK0_SHIFT …
#define REFCLK0_MASK …
#define REFCLK1_SHIFT …
#define REFCLK1_MASK …
#define LINK0_SHIFT …
#define LINK0_MASK …
#define LINK1_SHIFT …
#define LINK1_MASK …
#define SSC_SHIFT …
#define SSC_MASK …
#define CDNS_TORRENT_KEY(refclk0, refclk1, link0, link1, ssc) …
#define CDNS_TORRENT_KEY_ANYCLK(link0, link1) …
struct cdns_torrent_inst { … };
struct cdns_torrent_phy { … };
enum phy_powerstate { … };
struct cdns_torrent_refclk_driver { … };
#define to_cdns_torrent_refclk_driver(_hw) …
struct cdns_torrent_derived_refclk { … };
#define to_cdns_torrent_derived_refclk(_hw) …
struct cdns_torrent_received_refclk { … };
#define to_cdns_torrent_received_refclk(_hw) …
struct cdns_reg_pairs { … };
struct cdns_torrent_vals { … };
struct cdns_torrent_vals_entry { … };
struct cdns_torrent_vals_table { … };
struct cdns_torrent_data { … };
struct cdns_regmap_cdb_context { … };
static const struct cdns_torrent_vals *cdns_torrent_get_tbl_vals(const struct cdns_torrent_vals_table *tbl,
enum cdns_torrent_ref_clk refclk0,
enum cdns_torrent_ref_clk refclk1,
enum cdns_torrent_phy_type link0,
enum cdns_torrent_phy_type link1,
enum cdns_torrent_ssc_mode ssc)
{ … }
static int cdns_regmap_write(void *context, unsigned int reg, unsigned int val)
{ … }
static int cdns_regmap_read(void *context, unsigned int reg, unsigned int *val)
{ … }
static int cdns_regmap_dptx_write(void *context, unsigned int reg,
unsigned int val)
{ … }
static int cdns_regmap_dptx_read(void *context, unsigned int reg,
unsigned int *val)
{ … }
#define TORRENT_TX_LANE_CDB_REGMAP_CONF(n) …
#define TORRENT_RX_LANE_CDB_REGMAP_CONF(n) …
static const struct regmap_config cdns_torrent_tx_lane_cdb_config[] = …;
static const struct regmap_config cdns_torrent_rx_lane_cdb_config[] = …;
static const struct regmap_config cdns_torrent_common_cdb_config = …;
#define TORRENT_PHY_PCS_LANE_CDB_REGMAP_CONF(n) …
static const struct regmap_config cdns_torrent_phy_pcs_lane_cdb_config[] = …;
static const struct regmap_config cdns_torrent_phy_pcs_cmn_cdb_config = …;
static const struct regmap_config cdns_torrent_phy_pma_cmn_cdb_config = …;
static const struct regmap_config cdns_torrent_dptx_phy_config = …;
static void cdns_torrent_phy_write(struct regmap *regmap, u32 offset, u32 val)
{ … }
static u32 cdns_torrent_phy_read(struct regmap *regmap, u32 offset)
{ … }
static void cdns_torrent_dp_write(struct regmap *regmap, u32 offset, u32 val)
{ … }
static u32 cdns_torrent_dp_read(struct regmap *regmap, u32 offset)
{ … }
struct coefficients { … };
static const struct coefficients vltg_coeff[4][4] = …;
static const char *cdns_torrent_get_phy_type(enum cdns_torrent_phy_type phy_type)
{ … }
static
void cdns_torrent_dp_enable_ssc_19_2mhz(struct cdns_torrent_phy *cdns_phy,
u32 ctrl2_val, u32 ctrl3_val)
{ … }
static
void cdns_torrent_dp_pma_cmn_vco_cfg_19_2mhz(struct cdns_torrent_phy *cdns_phy,
u32 rate, bool ssc)
{ … }
static void cdns_torrent_dp_enable_ssc_25mhz(struct cdns_torrent_phy *cdns_phy,
u32 ctrl2_val)
{ … }
static
void cdns_torrent_dp_pma_cmn_vco_cfg_25mhz(struct cdns_torrent_phy *cdns_phy,
u32 rate, bool ssc)
{ … }
static
void cdns_torrent_dp_pma_cmn_vco_cfg_100mhz(struct cdns_torrent_phy *cdns_phy,
u32 rate, bool ssc)
{ … }
static int cdns_torrent_dp_get_pll(struct cdns_torrent_phy *cdns_phy,
enum cdns_torrent_phy_type phy_t2)
{ … }
static int cdns_torrent_dp_set_pll_en(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
struct phy_configure_opts_dp *dp,
bool enable)
{ … }
static int cdns_torrent_dp_set_power_state(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
u32 num_lanes,
enum phy_powerstate powerstate)
{ … }
static int cdns_torrent_dp_run(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst, u32 num_lanes)
{ … }
static int cdns_torrent_dp_wait_pma_cmn_ready(struct cdns_torrent_phy *cdns_phy)
{ … }
static void cdns_torrent_dp_pma_cmn_rate(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
u32 rate, u32 num_lanes)
{ … }
static int cdns_torrent_dp_configure_rate(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
struct phy_configure_opts_dp *dp)
{ … }
static int cdns_torrent_dp_verify_config(struct cdns_torrent_inst *inst,
struct phy_configure_opts_dp *dp)
{ … }
static void cdns_torrent_dp_set_a0_pll(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
u32 num_lanes)
{ … }
static int cdns_torrent_dp_set_lanes(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
struct phy_configure_opts_dp *dp)
{ … }
static int cdns_torrent_dp_set_rate(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
struct phy_configure_opts_dp *dp)
{ … }
static void cdns_torrent_dp_set_voltages(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
struct phy_configure_opts_dp *dp)
{
u8 lane;
u16 val;
for (lane = 0; lane < dp->lanes; lane++) {
val = cdns_torrent_phy_read(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
TX_DIAG_ACYA);
val |= TX_DIAG_ACYA_HBDC_MASK;
cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
TX_DIAG_ACYA, val);
cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
TX_TXCC_CTRL, 0x08A4);
val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].diag_tx_drv;
cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
DRV_DIAG_TX_DRV, val);
val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].mgnfs_mult;
cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
TX_TXCC_MGNFS_MULT_000,
val);
val = vltg_coeff[dp->voltage[lane]][dp->pre[lane]].cpost_mult;
cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
TX_TXCC_CPOST_MULT_00,
val);
val = cdns_torrent_phy_read(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
TX_DIAG_ACYA);
val &= ~TX_DIAG_ACYA_HBDC_MASK;
cdns_torrent_phy_write(cdns_phy->regmap_tx_lane_cdb[inst->mlane + lane],
TX_DIAG_ACYA, val);
}
};
static int cdns_torrent_dp_configure(struct phy *phy,
union phy_configure_opts *opts)
{ … }
static int cdns_torrent_phy_on(struct phy *phy)
{ … }
static int cdns_torrent_phy_off(struct phy *phy)
{ … }
static void cdns_torrent_dp_common_init(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst)
{ … }
static int cdns_torrent_dp_start(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
struct phy *phy)
{ … }
static int cdns_torrent_dp_init(struct phy *phy)
{ … }
static int cdns_torrent_dp_multilink_init(struct cdns_torrent_phy *cdns_phy,
struct cdns_torrent_inst *inst,
struct phy *phy)
{ … }
static int cdns_torrent_derived_refclk_enable(struct clk_hw *hw)
{ … }
static void cdns_torrent_derived_refclk_disable(struct clk_hw *hw)
{ … }
static int cdns_torrent_derived_refclk_is_enabled(struct clk_hw *hw)
{ … }
static const struct clk_ops cdns_torrent_derived_refclk_ops = …;
static int cdns_torrent_derived_refclk_register(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_received_refclk_enable(struct clk_hw *hw)
{ … }
static void cdns_torrent_received_refclk_disable(struct clk_hw *hw)
{ … }
static int cdns_torrent_received_refclk_is_enabled(struct clk_hw *hw)
{ … }
static const struct clk_ops cdns_torrent_received_refclk_ops = …;
static int cdns_torrent_received_refclk_register(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_refclk_driver_enable(struct clk_hw *hw)
{ … }
static void cdns_torrent_refclk_driver_disable(struct clk_hw *hw)
{ … }
static int cdns_torrent_refclk_driver_is_enabled(struct clk_hw *hw)
{ … }
static u8 cdns_torrent_refclk_driver_get_parent(struct clk_hw *hw)
{ … }
static int cdns_torrent_refclk_driver_set_parent(struct clk_hw *hw, u8 index)
{ … }
static const struct clk_ops cdns_torrent_refclk_driver_ops = …;
static int cdns_torrent_refclk_driver_register(struct cdns_torrent_phy *cdns_phy)
{ … }
static struct regmap *cdns_regmap_init(struct device *dev, void __iomem *base,
u32 block_offset,
u8 reg_offset_shift,
const struct regmap_config *config)
{ … }
static int cdns_torrent_dp_regfield_init(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_regfield_init(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_dp_regmap_init(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_regmap_init(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_phy_init(struct phy *phy)
{ … }
static const struct phy_ops cdns_torrent_phy_ops = …;
static
int cdns_torrent_phy_configure_multilink(struct cdns_torrent_phy *cdns_phy)
{ … }
static void cdns_torrent_clk_cleanup(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_clk_register(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_of_get_reset(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_of_get_clk(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_clk(struct cdns_torrent_phy *cdns_phy)
{ … }
static int cdns_torrent_phy_probe(struct platform_device *pdev)
{ … }
static void cdns_torrent_phy_remove(struct platform_device *pdev)
{ … }
static const struct cdns_reg_pairs sgmii_qsgmii_link_cmn_regs[] = …;
static const struct cdns_reg_pairs sgmii_qsgmii_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals sgmii_qsgmii_link_cmn_vals = …;
static const struct cdns_torrent_vals sgmii_qsgmii_xcvr_diag_ln_vals = …;
static int cdns_torrent_phy_suspend_noirq(struct device *dev)
{ … }
static int cdns_torrent_phy_resume_noirq(struct device *dev)
{ … }
static DEFINE_NOIRQ_DEV_PM_OPS(cdns_torrent_phy_pm_ops,
cdns_torrent_phy_suspend_noirq,
cdns_torrent_phy_resume_noirq);
static const struct cdns_reg_pairs usb_dp_link_cmn_regs[] = …;
static const struct cdns_reg_pairs usb_dp_xcvr_diag_ln_regs[] = …;
static const struct cdns_reg_pairs dp_usb_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals usb_dp_link_cmn_vals = …;
static const struct cdns_torrent_vals usb_dp_xcvr_diag_ln_vals = …;
static const struct cdns_torrent_vals dp_usb_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs usxgmii_sgmii_link_cmn_regs[] = …;
static const struct cdns_reg_pairs usxgmii_sgmii_xcvr_diag_ln_regs[] = …;
static const struct cdns_reg_pairs sgmii_usxgmii_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals usxgmii_sgmii_link_cmn_vals = …;
static const struct cdns_torrent_vals usxgmii_sgmii_xcvr_diag_ln_vals = …;
static const struct cdns_torrent_vals sgmii_usxgmii_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs ml_usxgmii_pll0_156_25_no_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals ml_usxgmii_pll0_156_25_no_ssc_cmn_vals = …;
static const struct cdns_reg_pairs ml_sgmii_pll1_100_no_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals ml_sgmii_pll1_100_no_ssc_cmn_vals = …;
static const struct cdns_reg_pairs j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals j7200_ml_usxgmii_pll0_156_25_no_ssc_cmn_vals = …;
static const struct cdns_reg_pairs j7200_ml_sgmii_pll1_100_no_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals j7200_ml_sgmii_pll1_100_no_ssc_cmn_vals = …;
static const struct cdns_reg_pairs pcie_usxgmii_link_cmn_regs[] = …;
static const struct cdns_reg_pairs pcie_usxgmii_xcvr_diag_ln_regs[] = …;
static const struct cdns_reg_pairs usxgmii_pcie_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals pcie_usxgmii_link_cmn_vals = …;
static const struct cdns_torrent_vals pcie_usxgmii_xcvr_diag_ln_vals = …;
static const struct cdns_torrent_vals usxgmii_pcie_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs ml_usxgmii_pll1_156_25_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs ml_usxgmii_156_25_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs ml_usxgmii_156_25_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals ml_usxgmii_pll1_156_25_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals ml_usxgmii_156_25_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals ml_usxgmii_156_25_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs ti_usxgmii_phy_pma_cmn_regs[] = …;
static const struct cdns_torrent_vals ti_usxgmii_phy_pma_cmn_vals = …;
static const struct cdns_reg_pairs sl_usxgmii_link_cmn_regs[] = …;
static const struct cdns_reg_pairs sl_usxgmii_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals sl_usxgmii_link_cmn_vals = …;
static const struct cdns_torrent_vals sl_usxgmii_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs sl_usxgmii_156_25_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs usxgmii_156_25_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs usxgmii_156_25_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals sl_usxgmii_156_25_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals usxgmii_156_25_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals usxgmii_156_25_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs pcie_dp_link_cmn_regs[] = …;
static const struct cdns_reg_pairs pcie_dp_xcvr_diag_ln_regs[] = …;
static const struct cdns_reg_pairs dp_pcie_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals pcie_dp_link_cmn_vals = …;
static const struct cdns_torrent_vals pcie_dp_xcvr_diag_ln_vals = …;
static const struct cdns_torrent_vals dp_pcie_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs dp_100_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs dp_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs dp_100_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals dp_100_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals dp_100_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals dp_100_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs sl_dp_link_cmn_regs[] = …;
static const struct cdns_reg_pairs sl_dp_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals sl_dp_link_cmn_vals = …;
static const struct cdns_torrent_vals sl_dp_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs sl_dp_19_2_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals sl_dp_19_2_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs sl_dp_25_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs sl_dp_25_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs sl_dp_25_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals sl_dp_25_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals sl_dp_25_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals sl_dp_25_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs sl_dp_100_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs sl_dp_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs sl_dp_100_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals sl_dp_100_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals sl_dp_100_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals sl_dp_100_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs usb_sgmii_link_cmn_regs[] = …;
static const struct cdns_reg_pairs usb_sgmii_xcvr_diag_ln_regs[] = …;
static const struct cdns_reg_pairs sgmii_usb_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals usb_sgmii_link_cmn_vals = …;
static const struct cdns_torrent_vals usb_sgmii_xcvr_diag_ln_vals = …;
static const struct cdns_torrent_vals sgmii_usb_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs pcie_usb_link_cmn_regs[] = …;
static const struct cdns_reg_pairs pcie_usb_xcvr_diag_ln_regs[] = …;
static const struct cdns_reg_pairs usb_pcie_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals pcie_usb_link_cmn_vals = …;
static const struct cdns_torrent_vals pcie_usb_xcvr_diag_ln_vals = …;
static const struct cdns_torrent_vals usb_pcie_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs usb_100_int_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals usb_100_int_ssc_cmn_vals = …;
static const struct cdns_reg_pairs sl_usb_link_cmn_regs[] = …;
static const struct cdns_reg_pairs sl_usb_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals sl_usb_link_cmn_vals = …;
static const struct cdns_torrent_vals sl_usb_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs usb_phy_pcs_cmn_regs[] = …;
static const struct cdns_torrent_vals usb_phy_pcs_cmn_vals = …;
static const struct cdns_reg_pairs sl_usb_100_no_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals sl_usb_100_no_ssc_cmn_vals = …;
static const struct cdns_reg_pairs usb_100_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs usb_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs usb_100_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals usb_100_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals usb_100_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals usb_100_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs sl_usb_100_int_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals sl_usb_100_int_ssc_cmn_vals = …;
static const struct cdns_reg_pairs pcie_sgmii_link_cmn_regs[] = …;
static const struct cdns_reg_pairs pcie_sgmii_xcvr_diag_ln_regs[] = …;
static const struct cdns_reg_pairs sgmii_pcie_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals pcie_sgmii_link_cmn_vals = …;
static const struct cdns_torrent_vals pcie_sgmii_xcvr_diag_ln_vals = …;
static const struct cdns_torrent_vals sgmii_pcie_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs sl_sgmii_100_no_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals sl_sgmii_100_no_ssc_cmn_vals = …;
static const struct cdns_reg_pairs sgmii_100_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs sgmii_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs ti_sgmii_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs sgmii_100_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals sgmii_100_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals sgmii_100_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals ti_sgmii_100_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals sgmii_100_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs j7200_sgmii_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_torrent_vals j7200_sgmii_100_no_ssc_tx_ln_vals = …;
static const struct cdns_reg_pairs j7200_sgmii_100_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals j7200_sgmii_100_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs sgmii_100_int_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals sgmii_100_int_ssc_cmn_vals = …;
static const struct cdns_reg_pairs sl_qsgmii_100_no_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals sl_qsgmii_100_no_ssc_cmn_vals = …;
static const struct cdns_reg_pairs qsgmii_100_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs qsgmii_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs ti_qsgmii_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_reg_pairs qsgmii_100_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals qsgmii_100_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals qsgmii_100_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals ti_qsgmii_100_no_ssc_tx_ln_vals = …;
static const struct cdns_torrent_vals qsgmii_100_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs j7200_qsgmii_100_no_ssc_tx_ln_regs[] = …;
static const struct cdns_torrent_vals j7200_qsgmii_100_no_ssc_tx_ln_vals = …;
static const struct cdns_reg_pairs j7200_qsgmii_100_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals j7200_qsgmii_100_no_ssc_rx_ln_vals = …;
static const struct cdns_reg_pairs qsgmii_100_int_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals qsgmii_100_int_ssc_cmn_vals = …;
static const struct cdns_reg_pairs sl_sgmii_link_cmn_regs[] = …;
static const struct cdns_reg_pairs sl_sgmii_xcvr_diag_ln_regs[] = …;
static const struct cdns_torrent_vals sl_sgmii_link_cmn_vals = …;
static const struct cdns_torrent_vals sl_sgmii_xcvr_diag_ln_vals = …;
static const struct cdns_reg_pairs pcie_100_int_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals pcie_100_int_ssc_cmn_vals = …;
static const struct cdns_reg_pairs sl_pcie_100_int_ssc_cmn_regs[] = …;
static const struct cdns_torrent_vals sl_pcie_100_int_ssc_cmn_vals = …;
static const struct cdns_reg_pairs pcie_100_ext_no_ssc_cmn_regs[] = …;
static const struct cdns_reg_pairs pcie_100_ext_no_ssc_rx_ln_regs[] = …;
static const struct cdns_torrent_vals pcie_100_no_ssc_cmn_vals = …;
static const struct cdns_torrent_vals pcie_100_no_ssc_rx_ln_vals = …;
static const struct cdns_torrent_vals_entry link_cmn_vals_entries[] = …;
static const struct cdns_torrent_vals_entry xcvr_diag_vals_entries[] = …;
static const struct cdns_torrent_vals_entry pcs_cmn_vals_entries[] = …;
static const struct cdns_torrent_vals_entry cmn_vals_entries[] = …;
static const struct cdns_torrent_vals_entry cdns_tx_ln_vals_entries[] = …;
static const struct cdns_torrent_vals_entry cdns_rx_ln_vals_entries[] = …;
static const struct cdns_torrent_data cdns_map_torrent = …;
static const struct cdns_torrent_vals_entry j721e_phy_pma_cmn_vals_entries[] = …;
static const struct cdns_torrent_vals_entry ti_tx_ln_vals_entries[] = …;
static const struct cdns_torrent_data ti_j721e_map_torrent = …;
static const struct cdns_torrent_vals_entry ti_j7200_cmn_vals_entries[] = …;
static const struct cdns_torrent_vals_entry ti_j7200_tx_ln_vals_entries[] = …;
static const struct cdns_torrent_vals_entry ti_j7200_rx_ln_vals_entries[] = …;
static const struct cdns_torrent_data ti_j7200_map_torrent = …;
static const struct of_device_id cdns_torrent_phy_of_match[] = …;
MODULE_DEVICE_TABLE(of, cdns_torrent_phy_of_match);
static struct platform_driver cdns_torrent_phy_driver = …;
module_platform_driver(…) …;
MODULE_AUTHOR(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;