diff mbox series

[v2] net: stmmac: dwmac-sun8i: Use reset exclusive

Message ID 20170918183043.8028-1-clabbe.montjoie@gmail.com
State New
Headers show
Series [v2] net: stmmac: dwmac-sun8i: Use reset exclusive | expand

Commit Message

Corentin Labbe Sept. 18, 2017, 6:30 p.m. UTC
The current dwmac_sun8i module cannot be rmmod/modprobe due to that
the reset controller was not released when removed.

This patch remove ambiguity, by using of_reset_control_get_exclusive and
add the missing reset_control_put().

Note that we cannot use devm_reset_control_get, since the reset is not
in the device node.

Signed-off-by: Corentin Labbe <clabbe.montjoie@gmail.com>

---
Changes since v1:
- added a note about devm_reset_control_get in commit message

 drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

-- 
2.13.5

Comments

Maxime Ripard Sept. 19, 2017, 8:45 a.m. UTC | #1
On Mon, Sep 18, 2017 at 08:30:43PM +0200, Corentin Labbe wrote:
> The current dwmac_sun8i module cannot be rmmod/modprobe due to that

> the reset controller was not released when removed.

> 

> This patch remove ambiguity, by using of_reset_control_get_exclusive and

> add the missing reset_control_put().

> 

> Note that we cannot use devm_reset_control_get, since the reset is not

> in the device node.

> 

> Signed-off-by: Corentin Labbe <clabbe.montjoie@gmail.com>

> ---

> Changes since v1:

> - added a note about devm_reset_control_get in commit message


That comment would be better if it was in the code.

> 

>  drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c | 3 ++-

>  1 file changed, 2 insertions(+), 1 deletion(-)

> 

> diff --git a/drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c b/drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c

> index 57bb6dd7b401..1736d7cb0d96 100644

> --- a/drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c

> +++ b/drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c

> @@ -854,6 +854,7 @@ static int sun8i_dwmac_unpower_internal_phy(struct sunxi_priv_data *gmac)

>  

>  	clk_disable_unprepare(gmac->ephy_clk);

>  	reset_control_assert(gmac->rst_ephy);

> +	reset_control_put(gmac->rst_ephy);


Putting it here is weird.

What would happen if power_phy / unpower_phy is called several times?

Can't we just make it symetric and undo in remove what we do in probe?

Maxime

-- 
Maxime Ripard, Free Electrons
Embedded Linux and Kernel engineering
http://free-electrons.com
diff mbox series

Patch

diff --git a/drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c b/drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c
index 57bb6dd7b401..1736d7cb0d96 100644
--- a/drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c
+++ b/drivers/net/ethernet/stmicro/stmmac/dwmac-sun8i.c
@@ -854,6 +854,7 @@  static int sun8i_dwmac_unpower_internal_phy(struct sunxi_priv_data *gmac)
 
 	clk_disable_unprepare(gmac->ephy_clk);
 	reset_control_assert(gmac->rst_ephy);
+	reset_control_put(gmac->rst_ephy);
 	return 0;
 }
 
@@ -1010,7 +1011,7 @@  static int sun8i_dwmac_probe(struct platform_device *pdev)
 			return -EINVAL;
 		}
 
-		gmac->rst_ephy = of_reset_control_get(plat_dat->phy_node, NULL);
+		gmac->rst_ephy = of_reset_control_get_exclusive(plat_dat->phy_node, NULL);
 		if (IS_ERR(gmac->rst_ephy)) {
 			ret = PTR_ERR(gmac->rst_ephy);
 			if (ret == -EPROBE_DEFER)