mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2024-12-28 00:33:16 +00:00
phy fixes for 6.13
- devm_phy_xxx fixes for few APIs in the phy core - qmp driver register name config - init sequence fix for usb driver - rockchip driver setting drvdata correctly in samsung hdptx and reset fix for naneng combophy - regulator dependency fix for mediatek hdmi driver - overflow assertion fix for stm32 driver -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEE+vs47OPLdNbVcHzyfBQHDyUjg0cFAmdtV8cACgkQfBQHDyUj g0f7/BAApmyGATxMukoP1JPVoL7zTsoqFqzyX5RIz4rlrLMdPTFsF2luldVyslZq YXWUVROGZdrZ3vAv5Tu9UZLpX4P5gBidKA7mcRWP9oqgtICF97ChTU9sH6jmLX/B s3pY8DtzP51xpplDyMyj/iIAtMNurLj23Z1O+PflrXzL2XSxNNUBoH3BKohP4GGp bd1qdFg+nnDWdmD3pxYrGSDX74m49Ww7JHWtzH/VxASL0je9qmCPaS1IwNnSbeuR wnLjDE92X5wV70q1ZlWTsiaQoTmS2RyOMD+Xeh1d7Rw8cLvx0zXYOY2MsYn1ywcG Z2F0vtOxEUjXXwRGDAy0InmDZGTw4y7oncLI7D9LwAoWEoYHD43SYPyTQT2zHpew /ezT1As0l8K5O0XpYWslqviR6tMuLy3SPQFxU2LfPCPDj6pI05BldiMhVXXCEY90 OPaNjcSyTn9/tznUbx6ftH7mqJp01enMQfbdKs9ozKgHF02Nj69LcD10UQ8lDUUM sXID7nQKmwbC3YIPjvTjcyNIhkdySRtZtyMgRLebooL7fXdm+qbieR6P5gT584x3 Y9CehUySMt/KMh3knRJA4O3j9tV84Zyf5GvgBTQu/SSHCSUA1UlqtL08yEmg2IMk vQMoua5S5qDlhHDY1JICm58Lzfl8BNfWQy+10SheIb2pEw5J48Q= =W42y -----END PGP SIGNATURE----- Merge tag 'phy-fixes-6.13' of git://git.kernel.org/pub/scm/linux/kernel/git/phy/linux-phy Pull phy fixes from Vinod Koul: "A few core API fixes for devm calls and bunch of driver fixes as usual: - devm_phy_xxx fixes for few APIs in the phy core - qmp driver register name config - init sequence fix for usb driver - rockchip driver setting drvdata correctly in samsung hdptx and reset fix for naneng combophy - regulator dependency fix for mediatek hdmi driver - overflow assertion fix for stm32 driver" * tag 'phy-fixes-6.13' of git://git.kernel.org/pub/scm/linux/kernel/git/phy/linux-phy: phy: mediatek: phy-mtk-hdmi: add regulator dependency phy: freescale: fsl-samsung-hdmi: Fix 64-by-32 division cocci warnings phy: core: Fix an OF node refcount leakage in of_phy_provider_lookup() phy: core: Fix an OF node refcount leakage in _of_phy_get() phy: core: Fix that API devm_phy_destroy() fails to destroy the phy phy: core: Fix that API devm_of_phy_provider_unregister() fails to unregister the phy provider phy: core: Fix that API devm_phy_put() fails to release the phy phy: rockchip: samsung-hdptx: Set drvdata before enabling runtime PM phy: stm32: work around constant-value overflow assertion phy: qcom-qmp: Fix register name in RX Lane config of SC8280XP phy: rockchip: naneng-combphy: fix phy reset phy: usb: Toggle the PHY power during init
This commit is contained in:
commit
6fcb22ef50
@ -325,6 +325,12 @@ static void usb_init_common_7216(struct brcm_usb_init_params *params)
|
||||
void __iomem *ctrl = params->regs[BRCM_REGS_CTRL];
|
||||
|
||||
USB_CTRL_UNSET(ctrl, USB_PM, XHC_S2_CLK_SWITCH_EN);
|
||||
|
||||
/*
|
||||
* The PHY might be in a bad state if it is already powered
|
||||
* up. Toggle the power just in case.
|
||||
*/
|
||||
USB_CTRL_SET(ctrl, USB_PM, USB_PWRDN);
|
||||
USB_CTRL_UNSET(ctrl, USB_PM, USB_PWRDN);
|
||||
|
||||
/* 1 millisecond - for USB clocks to settle down */
|
||||
|
@ -424,8 +424,7 @@ static unsigned long fsl_samsung_hdmi_phy_find_pms(unsigned long fout, u8 *p, u1
|
||||
* Fvco = (M * f_ref) / P,
|
||||
* where f_ref is 24MHz.
|
||||
*/
|
||||
tmp = (u64)_m * 24 * MHZ;
|
||||
do_div(tmp, _p);
|
||||
tmp = div64_ul((u64)_m * 24 * MHZ, _p);
|
||||
if (tmp < 750 * MHZ ||
|
||||
tmp > 3000 * MHZ)
|
||||
continue;
|
||||
|
@ -65,6 +65,7 @@ config PHY_MTK_HDMI
|
||||
depends on ARCH_MEDIATEK || COMPILE_TEST
|
||||
depends on COMMON_CLK
|
||||
depends on OF
|
||||
depends on REGULATOR
|
||||
select GENERIC_PHY
|
||||
help
|
||||
Support HDMI PHY for Mediatek SoCs.
|
||||
|
@ -145,8 +145,10 @@ static struct phy_provider *of_phy_provider_lookup(struct device_node *node)
|
||||
return phy_provider;
|
||||
|
||||
for_each_child_of_node(phy_provider->children, child)
|
||||
if (child == node)
|
||||
if (child == node) {
|
||||
of_node_put(child);
|
||||
return phy_provider;
|
||||
}
|
||||
}
|
||||
|
||||
return ERR_PTR(-EPROBE_DEFER);
|
||||
@ -629,8 +631,10 @@ static struct phy *_of_phy_get(struct device_node *np, int index)
|
||||
return ERR_PTR(-ENODEV);
|
||||
|
||||
/* This phy type handled by the usb-phy subsystem for now */
|
||||
if (of_device_is_compatible(args.np, "usb-nop-xceiv"))
|
||||
return ERR_PTR(-ENODEV);
|
||||
if (of_device_is_compatible(args.np, "usb-nop-xceiv")) {
|
||||
phy = ERR_PTR(-ENODEV);
|
||||
goto out_put_node;
|
||||
}
|
||||
|
||||
mutex_lock(&phy_provider_mutex);
|
||||
phy_provider = of_phy_provider_lookup(args.np);
|
||||
@ -652,6 +656,7 @@ static struct phy *_of_phy_get(struct device_node *np, int index)
|
||||
|
||||
out_unlock:
|
||||
mutex_unlock(&phy_provider_mutex);
|
||||
out_put_node:
|
||||
of_node_put(args.np);
|
||||
|
||||
return phy;
|
||||
@ -737,7 +742,7 @@ void devm_phy_put(struct device *dev, struct phy *phy)
|
||||
if (!phy)
|
||||
return;
|
||||
|
||||
r = devres_destroy(dev, devm_phy_release, devm_phy_match, phy);
|
||||
r = devres_release(dev, devm_phy_release, devm_phy_match, phy);
|
||||
dev_WARN_ONCE(dev, r, "couldn't find PHY resource\n");
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(devm_phy_put);
|
||||
@ -1121,7 +1126,7 @@ void devm_phy_destroy(struct device *dev, struct phy *phy)
|
||||
{
|
||||
int r;
|
||||
|
||||
r = devres_destroy(dev, devm_phy_consume, devm_phy_match, phy);
|
||||
r = devres_release(dev, devm_phy_consume, devm_phy_match, phy);
|
||||
dev_WARN_ONCE(dev, r, "couldn't find PHY resource\n");
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(devm_phy_destroy);
|
||||
@ -1259,12 +1264,12 @@ EXPORT_SYMBOL_GPL(of_phy_provider_unregister);
|
||||
* of_phy_provider_unregister to unregister the phy provider.
|
||||
*/
|
||||
void devm_of_phy_provider_unregister(struct device *dev,
|
||||
struct phy_provider *phy_provider)
|
||||
struct phy_provider *phy_provider)
|
||||
{
|
||||
int r;
|
||||
|
||||
r = devres_destroy(dev, devm_phy_provider_release, devm_phy_match,
|
||||
phy_provider);
|
||||
r = devres_release(dev, devm_phy_provider_release, devm_phy_match,
|
||||
phy_provider);
|
||||
dev_WARN_ONCE(dev, r, "couldn't find PHY provider device resource\n");
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(devm_of_phy_provider_unregister);
|
||||
|
@ -1052,7 +1052,7 @@ static const struct qmp_phy_init_tbl sc8280xp_usb3_uniphy_rx_tbl[] = {
|
||||
QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
|
||||
QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
|
||||
QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
|
||||
QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SO_GAIN, 0x0a),
|
||||
QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FO_GAIN, 0x0a),
|
||||
QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL1, 0x54),
|
||||
QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL2, 0x0f),
|
||||
QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
|
||||
|
@ -309,7 +309,7 @@ static int rockchip_combphy_parse_dt(struct device *dev, struct rockchip_combphy
|
||||
|
||||
priv->ext_refclk = device_property_present(dev, "rockchip,ext-refclk");
|
||||
|
||||
priv->phy_rst = devm_reset_control_array_get_exclusive(dev);
|
||||
priv->phy_rst = devm_reset_control_get(dev, "phy");
|
||||
if (IS_ERR(priv->phy_rst))
|
||||
return dev_err_probe(dev, PTR_ERR(priv->phy_rst), "failed to get phy reset\n");
|
||||
|
||||
|
@ -1101,6 +1101,8 @@ static int rk_hdptx_phy_probe(struct platform_device *pdev)
|
||||
return dev_err_probe(dev, PTR_ERR(hdptx->grf),
|
||||
"Could not get GRF syscon\n");
|
||||
|
||||
platform_set_drvdata(pdev, hdptx);
|
||||
|
||||
ret = devm_pm_runtime_enable(dev);
|
||||
if (ret)
|
||||
return dev_err_probe(dev, ret, "Failed to enable runtime PM\n");
|
||||
@ -1110,7 +1112,6 @@ static int rk_hdptx_phy_probe(struct platform_device *pdev)
|
||||
return dev_err_probe(dev, PTR_ERR(hdptx->phy),
|
||||
"Failed to create HDMI PHY\n");
|
||||
|
||||
platform_set_drvdata(pdev, hdptx);
|
||||
phy_set_drvdata(hdptx->phy, hdptx);
|
||||
phy_set_bus_width(hdptx->phy, 8);
|
||||
|
||||
|
@ -122,6 +122,7 @@ static int stm32_impedance_tune(struct stm32_combophy *combophy)
|
||||
u32 max_vswing = imp_lookup[imp_size - 1].vswing[vswing_size - 1];
|
||||
u32 min_vswing = imp_lookup[0].vswing[0];
|
||||
u32 val;
|
||||
u32 regval;
|
||||
|
||||
if (!of_property_read_u32(combophy->dev->of_node, "st,output-micro-ohms", &val)) {
|
||||
if (val < min_imp || val > max_imp) {
|
||||
@ -129,16 +130,20 @@ static int stm32_impedance_tune(struct stm32_combophy *combophy)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
for (imp_of = 0; imp_of < ARRAY_SIZE(imp_lookup); imp_of++)
|
||||
if (imp_lookup[imp_of].microohm <= val)
|
||||
regval = 0;
|
||||
for (imp_of = 0; imp_of < ARRAY_SIZE(imp_lookup); imp_of++) {
|
||||
if (imp_lookup[imp_of].microohm <= val) {
|
||||
regval = FIELD_PREP(STM32MP25_PCIEPRG_IMPCTRL_OHM, imp_of);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
dev_dbg(combophy->dev, "Set %u micro-ohms output impedance\n",
|
||||
imp_lookup[imp_of].microohm);
|
||||
|
||||
regmap_update_bits(combophy->regmap, SYSCFG_PCIEPRGCR,
|
||||
STM32MP25_PCIEPRG_IMPCTRL_OHM,
|
||||
FIELD_PREP(STM32MP25_PCIEPRG_IMPCTRL_OHM, imp_of));
|
||||
regval);
|
||||
} else {
|
||||
regmap_read(combophy->regmap, SYSCFG_PCIEPRGCR, &val);
|
||||
imp_of = FIELD_GET(STM32MP25_PCIEPRG_IMPCTRL_OHM, val);
|
||||
@ -150,16 +155,20 @@ static int stm32_impedance_tune(struct stm32_combophy *combophy)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
for (vswing_of = 0; vswing_of < ARRAY_SIZE(imp_lookup[imp_of].vswing); vswing_of++)
|
||||
if (imp_lookup[imp_of].vswing[vswing_of] >= val)
|
||||
regval = 0;
|
||||
for (vswing_of = 0; vswing_of < ARRAY_SIZE(imp_lookup[imp_of].vswing); vswing_of++) {
|
||||
if (imp_lookup[imp_of].vswing[vswing_of] >= val) {
|
||||
regval = FIELD_PREP(STM32MP25_PCIEPRG_IMPCTRL_VSWING, vswing_of);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
dev_dbg(combophy->dev, "Set %u microvolt swing\n",
|
||||
imp_lookup[imp_of].vswing[vswing_of]);
|
||||
|
||||
regmap_update_bits(combophy->regmap, SYSCFG_PCIEPRGCR,
|
||||
STM32MP25_PCIEPRG_IMPCTRL_VSWING,
|
||||
FIELD_PREP(STM32MP25_PCIEPRG_IMPCTRL_VSWING, vswing_of));
|
||||
regval);
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
Loading…
Reference in New Issue
Block a user