diff options
author | Peter Chen <peter.chen@nxp.com> | 2016-08-01 03:02:42 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-08-02 00:43:49 -0400 |
commit | 4613b279bee7954f1378c6339618641fdc4a675f (patch) | |
tree | 869893e846d9ab85e10d0b512381553eff475718 | |
parent | f7113b3af1ab5218882a79ac1bbeeaad4f46fbc3 (diff) |
ethernet: stmicro: stmmac: add missing of_node_put after calling of_parse_phandle
of_node_put needs to be called when the device node which is got
from of_parse_phandle has finished using.
This commit fixes both local (in stmmac_axi_setup) and global
(plat->phy_node) device_node for this issue, and using the
correct device node when tries to put node at stmmac_probe_config_dt
for error path.
Signed-off-by: Peter Chen <peter.chen@nxp.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 1 | ||||
-rw-r--r-- | drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c | 7 |
2 files changed, 6 insertions, 2 deletions
diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c index c23ccabc2d8a..4c8c60af7985 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | |||
@@ -3397,6 +3397,7 @@ int stmmac_dvr_remove(struct device *dev) | |||
3397 | stmmac_set_mac(priv->ioaddr, false); | 3397 | stmmac_set_mac(priv->ioaddr, false); |
3398 | netif_carrier_off(ndev); | 3398 | netif_carrier_off(ndev); |
3399 | unregister_netdev(ndev); | 3399 | unregister_netdev(ndev); |
3400 | of_node_put(priv->plat->phy_node); | ||
3400 | if (priv->stmmac_rst) | 3401 | if (priv->stmmac_rst) |
3401 | reset_control_assert(priv->stmmac_rst); | 3402 | reset_control_assert(priv->stmmac_rst); |
3402 | clk_disable_unprepare(priv->pclk); | 3403 | clk_disable_unprepare(priv->pclk); |
diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c index f7dfc0ae8e9c..756bb548e81a 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c | |||
@@ -113,8 +113,10 @@ static struct stmmac_axi *stmmac_axi_setup(struct platform_device *pdev) | |||
113 | return NULL; | 113 | return NULL; |
114 | 114 | ||
115 | axi = kzalloc(sizeof(*axi), GFP_KERNEL); | 115 | axi = kzalloc(sizeof(*axi), GFP_KERNEL); |
116 | if (!axi) | 116 | if (!axi) { |
117 | of_node_put(np); | ||
117 | return ERR_PTR(-ENOMEM); | 118 | return ERR_PTR(-ENOMEM); |
119 | } | ||
118 | 120 | ||
119 | axi->axi_lpi_en = of_property_read_bool(np, "snps,lpi_en"); | 121 | axi->axi_lpi_en = of_property_read_bool(np, "snps,lpi_en"); |
120 | axi->axi_xit_frm = of_property_read_bool(np, "snps,xit_frm"); | 122 | axi->axi_xit_frm = of_property_read_bool(np, "snps,xit_frm"); |
@@ -127,6 +129,7 @@ static struct stmmac_axi *stmmac_axi_setup(struct platform_device *pdev) | |||
127 | of_property_read_u32(np, "snps,wr_osr_lmt", &axi->axi_wr_osr_lmt); | 129 | of_property_read_u32(np, "snps,wr_osr_lmt", &axi->axi_wr_osr_lmt); |
128 | of_property_read_u32(np, "snps,rd_osr_lmt", &axi->axi_rd_osr_lmt); | 130 | of_property_read_u32(np, "snps,rd_osr_lmt", &axi->axi_rd_osr_lmt); |
129 | of_property_read_u32_array(np, "snps,blen", axi->axi_blen, AXI_BLEN); | 131 | of_property_read_u32_array(np, "snps,blen", axi->axi_blen, AXI_BLEN); |
132 | of_node_put(np); | ||
130 | 133 | ||
131 | return axi; | 134 | return axi; |
132 | } | 135 | } |
@@ -302,7 +305,7 @@ stmmac_probe_config_dt(struct platform_device *pdev, const char **mac) | |||
302 | dma_cfg = devm_kzalloc(&pdev->dev, sizeof(*dma_cfg), | 305 | dma_cfg = devm_kzalloc(&pdev->dev, sizeof(*dma_cfg), |
303 | GFP_KERNEL); | 306 | GFP_KERNEL); |
304 | if (!dma_cfg) { | 307 | if (!dma_cfg) { |
305 | of_node_put(np); | 308 | of_node_put(plat->phy_node); |
306 | return ERR_PTR(-ENOMEM); | 309 | return ERR_PTR(-ENOMEM); |
307 | } | 310 | } |
308 | plat->dma_cfg = dma_cfg; | 311 | plat->dma_cfg = dma_cfg; |