mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-09-30 06:10:56 +00:00
phy: qcom-qmp-combo: shorten function prefixes
The driver function prefix has gotten unnecessarily long and hurts readability. Shorten "qcom_qmp_phy_" to "qmp_" (which likely stands for "Qualcomm Multi PHY" or similar anyway). Signed-off-by: Johan Hovold <johan+linaro@kernel.org> Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> Link: https://lore.kernel.org/r/20220907110728.19092-13-johan+linaro@kernel.org Signed-off-by: Vinod Koul <vkoul@kernel.org>
This commit is contained in:
parent
d44c3e1a1e
commit
e5cedefa72
1 changed files with 79 additions and 86 deletions
|
@ -1384,7 +1384,7 @@ static const struct qmp_phy_combo_cfg sm8250_usb3dpphy_cfg = {
|
||||||
.dp_cfg = &sm8250_dpphy_cfg,
|
.dp_cfg = &sm8250_dpphy_cfg,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void qcom_qmp_phy_combo_configure_lane(void __iomem *base,
|
static void qmp_combo_configure_lane(void __iomem *base,
|
||||||
const unsigned int *regs,
|
const unsigned int *regs,
|
||||||
const struct qmp_phy_init_tbl tbl[],
|
const struct qmp_phy_init_tbl tbl[],
|
||||||
int num,
|
int num,
|
||||||
|
@ -1407,15 +1407,15 @@ static void qcom_qmp_phy_combo_configure_lane(void __iomem *base,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qcom_qmp_phy_combo_configure(void __iomem *base,
|
static void qmp_combo_configure(void __iomem *base,
|
||||||
const unsigned int *regs,
|
const unsigned int *regs,
|
||||||
const struct qmp_phy_init_tbl tbl[],
|
const struct qmp_phy_init_tbl tbl[],
|
||||||
int num)
|
int num)
|
||||||
{
|
{
|
||||||
qcom_qmp_phy_combo_configure_lane(base, regs, tbl, num, 0xff);
|
qmp_combo_configure_lane(base, regs, tbl, num, 0xff);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_serdes_init(struct qmp_phy *qphy)
|
static int qmp_combo_serdes_init(struct qmp_phy *qphy)
|
||||||
{
|
{
|
||||||
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
||||||
void __iomem *serdes = qphy->serdes;
|
void __iomem *serdes = qphy->serdes;
|
||||||
|
@ -1423,27 +1423,27 @@ static int qcom_qmp_phy_combo_serdes_init(struct qmp_phy *qphy)
|
||||||
const struct qmp_phy_init_tbl *serdes_tbl = cfg->serdes_tbl;
|
const struct qmp_phy_init_tbl *serdes_tbl = cfg->serdes_tbl;
|
||||||
int serdes_tbl_num = cfg->serdes_tbl_num;
|
int serdes_tbl_num = cfg->serdes_tbl_num;
|
||||||
|
|
||||||
qcom_qmp_phy_combo_configure(serdes, cfg->regs, serdes_tbl, serdes_tbl_num);
|
qmp_combo_configure(serdes, cfg->regs, serdes_tbl, serdes_tbl_num);
|
||||||
|
|
||||||
if (cfg->type == PHY_TYPE_DP) {
|
if (cfg->type == PHY_TYPE_DP) {
|
||||||
switch (dp_opts->link_rate) {
|
switch (dp_opts->link_rate) {
|
||||||
case 1620:
|
case 1620:
|
||||||
qcom_qmp_phy_combo_configure(serdes, cfg->regs,
|
qmp_combo_configure(serdes, cfg->regs,
|
||||||
cfg->serdes_tbl_rbr,
|
cfg->serdes_tbl_rbr,
|
||||||
cfg->serdes_tbl_rbr_num);
|
cfg->serdes_tbl_rbr_num);
|
||||||
break;
|
break;
|
||||||
case 2700:
|
case 2700:
|
||||||
qcom_qmp_phy_combo_configure(serdes, cfg->regs,
|
qmp_combo_configure(serdes, cfg->regs,
|
||||||
cfg->serdes_tbl_hbr,
|
cfg->serdes_tbl_hbr,
|
||||||
cfg->serdes_tbl_hbr_num);
|
cfg->serdes_tbl_hbr_num);
|
||||||
break;
|
break;
|
||||||
case 5400:
|
case 5400:
|
||||||
qcom_qmp_phy_combo_configure(serdes, cfg->regs,
|
qmp_combo_configure(serdes, cfg->regs,
|
||||||
cfg->serdes_tbl_hbr2,
|
cfg->serdes_tbl_hbr2,
|
||||||
cfg->serdes_tbl_hbr2_num);
|
cfg->serdes_tbl_hbr2_num);
|
||||||
break;
|
break;
|
||||||
case 8100:
|
case 8100:
|
||||||
qcom_qmp_phy_combo_configure(serdes, cfg->regs,
|
qmp_combo_configure(serdes, cfg->regs,
|
||||||
cfg->serdes_tbl_hbr3,
|
cfg->serdes_tbl_hbr3,
|
||||||
cfg->serdes_tbl_hbr3_num);
|
cfg->serdes_tbl_hbr3_num);
|
||||||
break;
|
break;
|
||||||
|
@ -1499,7 +1499,7 @@ static void qcom_qmp_v3_phy_dp_aux_init(struct qmp_phy *qphy)
|
||||||
qphy->pcs + QSERDES_V3_DP_PHY_AUX_INTERRUPT_MASK);
|
qphy->pcs + QSERDES_V3_DP_PHY_AUX_INTERRUPT_MASK);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_configure_dp_swing(struct qmp_phy *qphy,
|
static int qmp_combo_configure_dp_swing(struct qmp_phy *qphy,
|
||||||
unsigned int drv_lvl_reg, unsigned int emp_post_reg)
|
unsigned int drv_lvl_reg, unsigned int emp_post_reg)
|
||||||
{
|
{
|
||||||
const struct phy_configure_opts_dp *dp_opts = &qphy->dp_opts;
|
const struct phy_configure_opts_dp *dp_opts = &qphy->dp_opts;
|
||||||
|
@ -1542,8 +1542,7 @@ static void qcom_qmp_v3_phy_configure_dp_tx(struct qmp_phy *qphy)
|
||||||
const struct phy_configure_opts_dp *dp_opts = &qphy->dp_opts;
|
const struct phy_configure_opts_dp *dp_opts = &qphy->dp_opts;
|
||||||
u32 bias_en, drvr_en;
|
u32 bias_en, drvr_en;
|
||||||
|
|
||||||
if (qcom_qmp_phy_combo_configure_dp_swing(qphy,
|
if (qmp_combo_configure_dp_swing(qphy, QSERDES_V3_TX_TX_DRV_LVL,
|
||||||
QSERDES_V3_TX_TX_DRV_LVL,
|
|
||||||
QSERDES_V3_TX_TX_EMP_POST1_LVL) < 0)
|
QSERDES_V3_TX_TX_EMP_POST1_LVL) < 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -1561,7 +1560,7 @@ static void qcom_qmp_v3_phy_configure_dp_tx(struct qmp_phy *qphy)
|
||||||
writel(bias_en, qphy->tx2 + QSERDES_V3_TX_TRANSCEIVER_BIAS_EN);
|
writel(bias_en, qphy->tx2 + QSERDES_V3_TX_TRANSCEIVER_BIAS_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool qcom_qmp_phy_combo_configure_dp_mode(struct qmp_phy *qphy)
|
static bool qmp_combo_configure_dp_mode(struct qmp_phy *qphy)
|
||||||
{
|
{
|
||||||
u32 val;
|
u32 val;
|
||||||
bool reverse = false;
|
bool reverse = false;
|
||||||
|
@ -1598,7 +1597,7 @@ static int qcom_qmp_v3_phy_configure_dp_phy(struct qmp_phy *qphy)
|
||||||
u32 phy_vco_div, status;
|
u32 phy_vco_div, status;
|
||||||
unsigned long pixel_freq;
|
unsigned long pixel_freq;
|
||||||
|
|
||||||
qcom_qmp_phy_combo_configure_dp_mode(qphy);
|
qmp_combo_configure_dp_mode(qphy);
|
||||||
|
|
||||||
writel(0x05, qphy->pcs + QSERDES_V3_DP_PHY_TX0_TX1_LANE_CTL);
|
writel(0x05, qphy->pcs + QSERDES_V3_DP_PHY_TX0_TX1_LANE_CTL);
|
||||||
writel(0x05, qphy->pcs + QSERDES_V3_DP_PHY_TX2_TX3_LANE_CTL);
|
writel(0x05, qphy->pcs + QSERDES_V3_DP_PHY_TX2_TX3_LANE_CTL);
|
||||||
|
@ -1718,8 +1717,7 @@ static void qcom_qmp_v4_phy_configure_dp_tx(struct qmp_phy *qphy)
|
||||||
writel(0x20, qphy->tx + QSERDES_V4_TX_TX_EMP_POST1_LVL);
|
writel(0x20, qphy->tx + QSERDES_V4_TX_TX_EMP_POST1_LVL);
|
||||||
writel(0x20, qphy->tx2 + QSERDES_V4_TX_TX_EMP_POST1_LVL);
|
writel(0x20, qphy->tx2 + QSERDES_V4_TX_TX_EMP_POST1_LVL);
|
||||||
|
|
||||||
qcom_qmp_phy_combo_configure_dp_swing(qphy,
|
qmp_combo_configure_dp_swing(qphy, QSERDES_V4_TX_TX_DRV_LVL,
|
||||||
QSERDES_V4_TX_TX_DRV_LVL,
|
|
||||||
QSERDES_V4_TX_TX_EMP_POST1_LVL);
|
QSERDES_V4_TX_TX_EMP_POST1_LVL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1732,7 +1730,7 @@ static int qcom_qmp_v45_phy_configure_dp_phy(struct qmp_phy *qphy)
|
||||||
|
|
||||||
writel(0x0f, qphy->pcs + QSERDES_V4_DP_PHY_CFG_1);
|
writel(0x0f, qphy->pcs + QSERDES_V4_DP_PHY_CFG_1);
|
||||||
|
|
||||||
qcom_qmp_phy_combo_configure_dp_mode(qphy);
|
qmp_combo_configure_dp_mode(qphy);
|
||||||
|
|
||||||
writel(0x13, qphy->pcs + QSERDES_DP_PHY_AUX_CFG1);
|
writel(0x13, qphy->pcs + QSERDES_DP_PHY_AUX_CFG1);
|
||||||
writel(0xa4, qphy->pcs + QSERDES_DP_PHY_AUX_CFG2);
|
writel(0xa4, qphy->pcs + QSERDES_DP_PHY_AUX_CFG2);
|
||||||
|
@ -1976,7 +1974,7 @@ static int qcom_qmp_dp_phy_calibrate(struct phy *phy)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_com_init(struct qmp_phy *qphy)
|
static int qmp_combo_com_init(struct qmp_phy *qphy)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp = qphy->qmp;
|
struct qcom_qmp *qmp = qphy->qmp;
|
||||||
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
||||||
|
@ -2058,7 +2056,7 @@ static int qcom_qmp_phy_combo_com_init(struct qmp_phy *qphy)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_com_exit(struct qmp_phy *qphy)
|
static int qmp_combo_com_exit(struct qmp_phy *qphy)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp = qphy->qmp;
|
struct qcom_qmp *qmp = qphy->qmp;
|
||||||
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
||||||
|
@ -2082,7 +2080,7 @@ static int qcom_qmp_phy_combo_com_exit(struct qmp_phy *qphy)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_init(struct phy *phy)
|
static int qmp_combo_init(struct phy *phy)
|
||||||
{
|
{
|
||||||
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
||||||
struct qcom_qmp *qmp = qphy->qmp;
|
struct qcom_qmp *qmp = qphy->qmp;
|
||||||
|
@ -2090,7 +2088,7 @@ static int qcom_qmp_phy_combo_init(struct phy *phy)
|
||||||
int ret;
|
int ret;
|
||||||
dev_vdbg(qmp->dev, "Initializing QMP phy\n");
|
dev_vdbg(qmp->dev, "Initializing QMP phy\n");
|
||||||
|
|
||||||
ret = qcom_qmp_phy_combo_com_init(qphy);
|
ret = qmp_combo_com_init(qphy);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
@ -2100,7 +2098,7 @@ static int qcom_qmp_phy_combo_init(struct phy *phy)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_power_on(struct phy *phy)
|
static int qmp_combo_power_on(struct phy *phy)
|
||||||
{
|
{
|
||||||
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
||||||
struct qcom_qmp *qmp = qphy->qmp;
|
struct qcom_qmp *qmp = qphy->qmp;
|
||||||
|
@ -2112,7 +2110,7 @@ static int qcom_qmp_phy_combo_power_on(struct phy *phy)
|
||||||
unsigned int mask, val, ready;
|
unsigned int mask, val, ready;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
qcom_qmp_phy_combo_serdes_init(qphy);
|
qmp_combo_serdes_init(qphy);
|
||||||
|
|
||||||
ret = clk_prepare_enable(qphy->pipe_clk);
|
ret = clk_prepare_enable(qphy->pipe_clk);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
@ -2121,32 +2119,29 @@ static int qcom_qmp_phy_combo_power_on(struct phy *phy)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Tx, Rx, and PCS configurations */
|
/* Tx, Rx, and PCS configurations */
|
||||||
qcom_qmp_phy_combo_configure_lane(tx, cfg->regs,
|
qmp_combo_configure_lane(tx, cfg->regs, cfg->tx_tbl, cfg->tx_tbl_num, 1);
|
||||||
cfg->tx_tbl, cfg->tx_tbl_num, 1);
|
|
||||||
|
|
||||||
if (cfg->is_dual_lane_phy) {
|
if (cfg->is_dual_lane_phy) {
|
||||||
qcom_qmp_phy_combo_configure_lane(qphy->tx2, cfg->regs,
|
qmp_combo_configure_lane(qphy->tx2, cfg->regs, cfg->tx_tbl,
|
||||||
cfg->tx_tbl, cfg->tx_tbl_num, 2);
|
cfg->tx_tbl_num, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Configure special DP tx tunings */
|
/* Configure special DP tx tunings */
|
||||||
if (cfg->type == PHY_TYPE_DP)
|
if (cfg->type == PHY_TYPE_DP)
|
||||||
cfg->configure_dp_tx(qphy);
|
cfg->configure_dp_tx(qphy);
|
||||||
|
|
||||||
qcom_qmp_phy_combo_configure_lane(rx, cfg->regs,
|
qmp_combo_configure_lane(rx, cfg->regs, cfg->rx_tbl, cfg->rx_tbl_num, 1);
|
||||||
cfg->rx_tbl, cfg->rx_tbl_num, 1);
|
|
||||||
|
|
||||||
if (cfg->is_dual_lane_phy) {
|
if (cfg->is_dual_lane_phy) {
|
||||||
qcom_qmp_phy_combo_configure_lane(qphy->rx2, cfg->regs,
|
qmp_combo_configure_lane(qphy->rx2, cfg->regs, cfg->rx_tbl,
|
||||||
cfg->rx_tbl, cfg->rx_tbl_num, 2);
|
cfg->rx_tbl_num, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Configure link rate, swing, etc. */
|
/* Configure link rate, swing, etc. */
|
||||||
if (cfg->type == PHY_TYPE_DP) {
|
if (cfg->type == PHY_TYPE_DP)
|
||||||
cfg->configure_dp_phy(qphy);
|
cfg->configure_dp_phy(qphy);
|
||||||
} else {
|
else
|
||||||
qcom_qmp_phy_combo_configure(pcs, cfg->regs, cfg->pcs_tbl, cfg->pcs_tbl_num);
|
qmp_combo_configure(pcs, cfg->regs, cfg->pcs_tbl, cfg->pcs_tbl_num);
|
||||||
}
|
|
||||||
|
|
||||||
ret = reset_control_deassert(qmp->ufs_reset);
|
ret = reset_control_deassert(qmp->ufs_reset);
|
||||||
if (ret)
|
if (ret)
|
||||||
|
@ -2180,7 +2175,7 @@ static int qcom_qmp_phy_combo_power_on(struct phy *phy)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_power_off(struct phy *phy)
|
static int qmp_combo_power_off(struct phy *phy)
|
||||||
{
|
{
|
||||||
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
||||||
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
||||||
|
@ -2210,42 +2205,41 @@ static int qcom_qmp_phy_combo_power_off(struct phy *phy)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_exit(struct phy *phy)
|
static int qmp_combo_exit(struct phy *phy)
|
||||||
{
|
{
|
||||||
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
||||||
|
|
||||||
qcom_qmp_phy_combo_com_exit(qphy);
|
qmp_combo_com_exit(qphy);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_enable(struct phy *phy)
|
static int qmp_combo_enable(struct phy *phy)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = qcom_qmp_phy_combo_init(phy);
|
ret = qmp_combo_init(phy);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
ret = qcom_qmp_phy_combo_power_on(phy);
|
ret = qmp_combo_power_on(phy);
|
||||||
if (ret)
|
if (ret)
|
||||||
qcom_qmp_phy_combo_exit(phy);
|
qmp_combo_exit(phy);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_disable(struct phy *phy)
|
static int qmp_combo_disable(struct phy *phy)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = qcom_qmp_phy_combo_power_off(phy);
|
ret = qmp_combo_power_off(phy);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
return qcom_qmp_phy_combo_exit(phy);
|
return qmp_combo_exit(phy);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_set_mode(struct phy *phy,
|
static int qmp_combo_set_mode(struct phy *phy, enum phy_mode mode, int submode)
|
||||||
enum phy_mode mode, int submode)
|
|
||||||
{
|
{
|
||||||
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
struct qmp_phy *qphy = phy_get_drvdata(phy);
|
||||||
|
|
||||||
|
@ -2254,7 +2248,7 @@ static int qcom_qmp_phy_combo_set_mode(struct phy *phy,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qcom_qmp_phy_combo_enable_autonomous_mode(struct qmp_phy *qphy)
|
static void qmp_combo_enable_autonomous_mode(struct qmp_phy *qphy)
|
||||||
{
|
{
|
||||||
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
||||||
void __iomem *pcs_usb = qphy->pcs_usb ?: qphy->pcs;
|
void __iomem *pcs_usb = qphy->pcs_usb ?: qphy->pcs;
|
||||||
|
@ -2283,7 +2277,7 @@ static void qcom_qmp_phy_combo_enable_autonomous_mode(struct qmp_phy *qphy)
|
||||||
qphy_clrbits(pcs_misc, QPHY_V3_PCS_MISC_CLAMP_ENABLE, CLAMP_EN);
|
qphy_clrbits(pcs_misc, QPHY_V3_PCS_MISC_CLAMP_ENABLE, CLAMP_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qcom_qmp_phy_combo_disable_autonomous_mode(struct qmp_phy *qphy)
|
static void qmp_combo_disable_autonomous_mode(struct qmp_phy *qphy)
|
||||||
{
|
{
|
||||||
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
const struct qmp_phy_cfg *cfg = qphy->cfg;
|
||||||
void __iomem *pcs_usb = qphy->pcs_usb ?: qphy->pcs_usb;
|
void __iomem *pcs_usb = qphy->pcs_usb ?: qphy->pcs_usb;
|
||||||
|
@ -2301,7 +2295,7 @@ static void qcom_qmp_phy_combo_disable_autonomous_mode(struct qmp_phy *qphy)
|
||||||
qphy_clrbits(pcs_usb, cfg->regs[QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR], IRQ_CLEAR);
|
qphy_clrbits(pcs_usb, cfg->regs[QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR], IRQ_CLEAR);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __maybe_unused qcom_qmp_phy_combo_runtime_suspend(struct device *dev)
|
static int __maybe_unused qmp_combo_runtime_suspend(struct device *dev)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
||||||
struct qmp_phy *qphy = qmp->phys[0];
|
struct qmp_phy *qphy = qmp->phys[0];
|
||||||
|
@ -2318,7 +2312,7 @@ static int __maybe_unused qcom_qmp_phy_combo_runtime_suspend(struct device *dev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
qcom_qmp_phy_combo_enable_autonomous_mode(qphy);
|
qmp_combo_enable_autonomous_mode(qphy);
|
||||||
|
|
||||||
clk_disable_unprepare(qphy->pipe_clk);
|
clk_disable_unprepare(qphy->pipe_clk);
|
||||||
clk_bulk_disable_unprepare(cfg->num_clks, qmp->clks);
|
clk_bulk_disable_unprepare(cfg->num_clks, qmp->clks);
|
||||||
|
@ -2326,7 +2320,7 @@ static int __maybe_unused qcom_qmp_phy_combo_runtime_suspend(struct device *dev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __maybe_unused qcom_qmp_phy_combo_runtime_resume(struct device *dev)
|
static int __maybe_unused qmp_combo_runtime_resume(struct device *dev)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
||||||
struct qmp_phy *qphy = qmp->phys[0];
|
struct qmp_phy *qphy = qmp->phys[0];
|
||||||
|
@ -2355,12 +2349,12 @@ static int __maybe_unused qcom_qmp_phy_combo_runtime_resume(struct device *dev)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
qcom_qmp_phy_combo_disable_autonomous_mode(qphy);
|
qmp_combo_disable_autonomous_mode(qphy);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_vreg_init(struct device *dev, const struct qmp_phy_cfg *cfg)
|
static int qmp_combo_vreg_init(struct device *dev, const struct qmp_phy_cfg *cfg)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
||||||
int num = cfg->num_vregs;
|
int num = cfg->num_vregs;
|
||||||
|
@ -2392,7 +2386,7 @@ static int qcom_qmp_phy_combo_vreg_init(struct device *dev, const struct qmp_phy
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_reset_init(struct device *dev, const struct qmp_phy_cfg *cfg)
|
static int qmp_combo_reset_init(struct device *dev, const struct qmp_phy_cfg *cfg)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
||||||
int i;
|
int i;
|
||||||
|
@ -2413,7 +2407,7 @@ static int qcom_qmp_phy_combo_reset_init(struct device *dev, const struct qmp_ph
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_clk_init(struct device *dev, const struct qmp_phy_cfg *cfg)
|
static int qmp_combo_clk_init(struct device *dev, const struct qmp_phy_cfg *cfg)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
||||||
int num = cfg->num_clks;
|
int num = cfg->num_clks;
|
||||||
|
@ -2681,26 +2675,25 @@ static int phy_dp_clks_register(struct qcom_qmp *qmp, struct qmp_phy *qphy,
|
||||||
return devm_add_action_or_reset(qmp->dev, phy_clk_release_provider, np);
|
return devm_add_action_or_reset(qmp->dev, phy_clk_release_provider, np);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct phy_ops qcom_qmp_phy_combo_usb_ops = {
|
static const struct phy_ops qmp_combo_usb_ops = {
|
||||||
.init = qcom_qmp_phy_combo_enable,
|
.init = qmp_combo_enable,
|
||||||
.exit = qcom_qmp_phy_combo_disable,
|
.exit = qmp_combo_disable,
|
||||||
.set_mode = qcom_qmp_phy_combo_set_mode,
|
.set_mode = qmp_combo_set_mode,
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct phy_ops qcom_qmp_phy_combo_dp_ops = {
|
static const struct phy_ops qmp_combo_dp_ops = {
|
||||||
.init = qcom_qmp_phy_combo_init,
|
.init = qmp_combo_init,
|
||||||
.configure = qcom_qmp_dp_phy_configure,
|
.configure = qcom_qmp_dp_phy_configure,
|
||||||
.power_on = qcom_qmp_phy_combo_power_on,
|
.power_on = qmp_combo_power_on,
|
||||||
.calibrate = qcom_qmp_dp_phy_calibrate,
|
.calibrate = qcom_qmp_dp_phy_calibrate,
|
||||||
.power_off = qcom_qmp_phy_combo_power_off,
|
.power_off = qmp_combo_power_off,
|
||||||
.exit = qcom_qmp_phy_combo_exit,
|
.exit = qmp_combo_exit,
|
||||||
.set_mode = qcom_qmp_phy_combo_set_mode,
|
.set_mode = qmp_combo_set_mode,
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
};
|
};
|
||||||
|
|
||||||
static
|
static int qmp_combo_create(struct device *dev, struct device_node *np, int id,
|
||||||
int qcom_qmp_phy_combo_create(struct device *dev, struct device_node *np, int id,
|
|
||||||
void __iomem *serdes, const struct qmp_phy_cfg *cfg)
|
void __iomem *serdes, const struct qmp_phy_cfg *cfg)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
struct qcom_qmp *qmp = dev_get_drvdata(dev);
|
||||||
|
@ -2786,9 +2779,9 @@ int qcom_qmp_phy_combo_create(struct device *dev, struct device_node *np, int id
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cfg->type == PHY_TYPE_DP)
|
if (cfg->type == PHY_TYPE_DP)
|
||||||
ops = &qcom_qmp_phy_combo_dp_ops;
|
ops = &qmp_combo_dp_ops;
|
||||||
else
|
else
|
||||||
ops = &qcom_qmp_phy_combo_usb_ops;
|
ops = &qmp_combo_usb_ops;
|
||||||
|
|
||||||
generic_phy = devm_phy_create(dev, np, ops);
|
generic_phy = devm_phy_create(dev, np, ops);
|
||||||
if (IS_ERR(generic_phy)) {
|
if (IS_ERR(generic_phy)) {
|
||||||
|
@ -2806,7 +2799,7 @@ int qcom_qmp_phy_combo_create(struct device *dev, struct device_node *np, int id
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct of_device_id qcom_qmp_combo_phy_of_match_table[] = {
|
static const struct of_device_id qmp_combo_of_match_table[] = {
|
||||||
{
|
{
|
||||||
.compatible = "qcom,sc7180-qmp-usb3-dp-phy",
|
.compatible = "qcom,sc7180-qmp-usb3-dp-phy",
|
||||||
.data = &sc7180_usb3dpphy_cfg,
|
.data = &sc7180_usb3dpphy_cfg,
|
||||||
|
@ -2829,14 +2822,14 @@ static const struct of_device_id qcom_qmp_combo_phy_of_match_table[] = {
|
||||||
},
|
},
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(of, qcom_qmp_combo_phy_of_match_table);
|
MODULE_DEVICE_TABLE(of, qmp_combo_of_match_table);
|
||||||
|
|
||||||
static const struct dev_pm_ops qcom_qmp_phy_combo_pm_ops = {
|
static const struct dev_pm_ops qmp_combo_pm_ops = {
|
||||||
SET_RUNTIME_PM_OPS(qcom_qmp_phy_combo_runtime_suspend,
|
SET_RUNTIME_PM_OPS(qmp_combo_runtime_suspend,
|
||||||
qcom_qmp_phy_combo_runtime_resume, NULL)
|
qmp_combo_runtime_resume, NULL)
|
||||||
};
|
};
|
||||||
|
|
||||||
static int qcom_qmp_phy_combo_probe(struct platform_device *pdev)
|
static int qmp_combo_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct qcom_qmp *qmp;
|
struct qcom_qmp *qmp;
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
|
@ -2889,15 +2882,15 @@ static int qcom_qmp_phy_combo_probe(struct platform_device *pdev)
|
||||||
|
|
||||||
mutex_init(&qmp->phy_mutex);
|
mutex_init(&qmp->phy_mutex);
|
||||||
|
|
||||||
ret = qcom_qmp_phy_combo_clk_init(dev, cfg);
|
ret = qmp_combo_clk_init(dev, cfg);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
ret = qcom_qmp_phy_combo_reset_init(dev, cfg);
|
ret = qmp_combo_reset_init(dev, cfg);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
ret = qcom_qmp_phy_combo_vreg_init(dev, cfg);
|
ret = qmp_combo_vreg_init(dev, cfg);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
if (ret != -EPROBE_DEFER)
|
if (ret != -EPROBE_DEFER)
|
||||||
dev_err(dev, "failed to get regulator supplies: %d\n",
|
dev_err(dev, "failed to get regulator supplies: %d\n",
|
||||||
|
@ -2931,7 +2924,7 @@ static int qcom_qmp_phy_combo_probe(struct platform_device *pdev)
|
||||||
serdes = dp_serdes;
|
serdes = dp_serdes;
|
||||||
|
|
||||||
/* Create per-lane phy */
|
/* Create per-lane phy */
|
||||||
ret = qcom_qmp_phy_combo_create(dev, child, id, serdes, cfg);
|
ret = qmp_combo_create(dev, child, id, serdes, cfg);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(dev, "failed to create lane%d phy, %d\n",
|
dev_err(dev, "failed to create lane%d phy, %d\n",
|
||||||
id, ret);
|
id, ret);
|
||||||
|
@ -2949,7 +2942,7 @@ static int qcom_qmp_phy_combo_probe(struct platform_device *pdev)
|
||||||
serdes = usb_serdes;
|
serdes = usb_serdes;
|
||||||
|
|
||||||
/* Create per-lane phy */
|
/* Create per-lane phy */
|
||||||
ret = qcom_qmp_phy_combo_create(dev, child, id, serdes, cfg);
|
ret = qmp_combo_create(dev, child, id, serdes, cfg);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(dev, "failed to create lane%d phy, %d\n",
|
dev_err(dev, "failed to create lane%d phy, %d\n",
|
||||||
id, ret);
|
id, ret);
|
||||||
|
@ -2980,16 +2973,16 @@ static int qcom_qmp_phy_combo_probe(struct platform_device *pdev)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct platform_driver qcom_qmp_phy_combo_driver = {
|
static struct platform_driver qmp_combo_driver = {
|
||||||
.probe = qcom_qmp_phy_combo_probe,
|
.probe = qmp_combo_probe,
|
||||||
.driver = {
|
.driver = {
|
||||||
.name = "qcom-qmp-combo-phy",
|
.name = "qcom-qmp-combo-phy",
|
||||||
.pm = &qcom_qmp_phy_combo_pm_ops,
|
.pm = &qmp_combo_pm_ops,
|
||||||
.of_match_table = qcom_qmp_combo_phy_of_match_table,
|
.of_match_table = qmp_combo_of_match_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
module_platform_driver(qcom_qmp_phy_combo_driver);
|
module_platform_driver(qmp_combo_driver);
|
||||||
|
|
||||||
MODULE_AUTHOR("Vivek Gautam <vivek.gautam@codeaurora.org>");
|
MODULE_AUTHOR("Vivek Gautam <vivek.gautam@codeaurora.org>");
|
||||||
MODULE_DESCRIPTION("Qualcomm QMP USB+DP combo PHY driver");
|
MODULE_DESCRIPTION("Qualcomm QMP USB+DP combo PHY driver");
|
||||||
|
|
Loading…
Reference in a new issue