mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-15 17:43:59 +00:00
Merge branch 'ARM-imx6ul-14x14-evk-Fix-suspend-over-nfs-by-phy'
Leonard Crestez says: ==================== ARM: imx6ul-14x14-evk: Fix suspend over nfs by phy Right now attempting doing suspend/resume while root is mounted over NFS hangs on imx6ul-14x14-evk. This is happening because ksz8081 phy fixups are lost on resume. Fix this by using equivalent devicetree properties instead of a phy fixup and handling those properties on resume in the micrel driver. In theory it might now be possible to remove the phy fixup from mach-imx6ul entirely but it is possible that this would break other imx6ul boards which use the same phy. The solution would be to patch their dts but it's not clear how to identify affected boards. This code is shared with imx6ull-14x14-evk but 6ull suspend needs an unrelated patch: https://lkml.org/lkml/2017/5/30/584 This is something of a corner case so there is no CC: stable. Changes since v1: https://lkml.org/lkml/2017/5/30/672 * Split a kszphy_config_reset function for stuff shared between config_init and resume. Calling config_init directly could be an option but on some HW variants it does extra stuff like parsing devicetree options. That would not be appropriate for resume code. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
58a6960663
@ -120,10 +120,16 @@
|
|||||||
|
|
||||||
ethphy0: ethernet-phy@2 {
|
ethphy0: ethernet-phy@2 {
|
||||||
reg = <2>;
|
reg = <2>;
|
||||||
|
micrel,led-mode = <1>;
|
||||||
|
clocks = <&clks IMX6UL_CLK_ENET_REF>;
|
||||||
|
clock-names = "rmii-ref";
|
||||||
};
|
};
|
||||||
|
|
||||||
ethphy1: ethernet-phy@1 {
|
ethphy1: ethernet-phy@1 {
|
||||||
reg = <1>;
|
reg = <1>;
|
||||||
|
micrel,led-mode = <1>;
|
||||||
|
clocks = <&clks IMX6UL_CLK_ENET2_REF>;
|
||||||
|
clock-names = "rmii-ref";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -268,11 +268,31 @@ out:
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Some config bits need to be set again on resume, handle them here. */
|
||||||
|
static int kszphy_config_reset(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
struct kszphy_priv *priv = phydev->priv;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (priv->rmii_ref_clk_sel) {
|
||||||
|
ret = kszphy_rmii_clk_sel(phydev, priv->rmii_ref_clk_sel_val);
|
||||||
|
if (ret) {
|
||||||
|
phydev_err(phydev,
|
||||||
|
"failed to set rmii reference clock\n");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (priv->led_mode >= 0)
|
||||||
|
kszphy_setup_led(phydev, priv->type->led_mode_reg, priv->led_mode);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int kszphy_config_init(struct phy_device *phydev)
|
static int kszphy_config_init(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
struct kszphy_priv *priv = phydev->priv;
|
struct kszphy_priv *priv = phydev->priv;
|
||||||
const struct kszphy_type *type;
|
const struct kszphy_type *type;
|
||||||
int ret;
|
|
||||||
|
|
||||||
if (!priv)
|
if (!priv)
|
||||||
return 0;
|
return 0;
|
||||||
@ -285,19 +305,7 @@ static int kszphy_config_init(struct phy_device *phydev)
|
|||||||
if (type->has_nand_tree_disable)
|
if (type->has_nand_tree_disable)
|
||||||
kszphy_nand_tree_disable(phydev);
|
kszphy_nand_tree_disable(phydev);
|
||||||
|
|
||||||
if (priv->rmii_ref_clk_sel) {
|
return kszphy_config_reset(phydev);
|
||||||
ret = kszphy_rmii_clk_sel(phydev, priv->rmii_ref_clk_sel_val);
|
|
||||||
if (ret) {
|
|
||||||
phydev_err(phydev,
|
|
||||||
"failed to set rmii reference clock\n");
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (priv->led_mode >= 0)
|
|
||||||
kszphy_setup_led(phydev, type->led_mode_reg, priv->led_mode);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ksz8041_config_init(struct phy_device *phydev)
|
static int ksz8041_config_init(struct phy_device *phydev)
|
||||||
@ -700,8 +708,14 @@ static int kszphy_suspend(struct phy_device *phydev)
|
|||||||
|
|
||||||
static int kszphy_resume(struct phy_device *phydev)
|
static int kszphy_resume(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
genphy_resume(phydev);
|
genphy_resume(phydev);
|
||||||
|
|
||||||
|
ret = kszphy_config_reset(phydev);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
/* Enable PHY Interrupts */
|
/* Enable PHY Interrupts */
|
||||||
if (phy_interrupt_is_valid(phydev)) {
|
if (phy_interrupt_is_valid(phydev)) {
|
||||||
phydev->interrupts = PHY_INTERRUPT_ENABLED;
|
phydev->interrupts = PHY_INTERRUPT_ENABLED;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user