diff options
| -rw-r--r-- | drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c index 6e6ee226de04..b0c1521e08a3 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | |||
| @@ -2786,8 +2786,15 @@ struct stmmac_priv *stmmac_dvr_probe(struct device *device, | |||
| 2786 | if (IS_ERR(priv->stmmac_clk)) { | 2786 | if (IS_ERR(priv->stmmac_clk)) { |
| 2787 | dev_warn(priv->device, "%s: warning: cannot get CSR clock\n", | 2787 | dev_warn(priv->device, "%s: warning: cannot get CSR clock\n", |
| 2788 | __func__); | 2788 | __func__); |
| 2789 | ret = PTR_ERR(priv->stmmac_clk); | 2789 | /* If failed to obtain stmmac_clk and specific clk_csr value |
| 2790 | goto error_clk_get; | 2790 | * is NOT passed from the platform, probe fail. |
| 2791 | */ | ||
| 2792 | if (!priv->plat->clk_csr) { | ||
| 2793 | ret = PTR_ERR(priv->stmmac_clk); | ||
| 2794 | goto error_clk_get; | ||
| 2795 | } else { | ||
| 2796 | priv->stmmac_clk = NULL; | ||
| 2797 | } | ||
| 2791 | } | 2798 | } |
| 2792 | clk_prepare_enable(priv->stmmac_clk); | 2799 | clk_prepare_enable(priv->stmmac_clk); |
| 2793 | 2800 | ||
