diff options
| author | Neil Armstrong <[email protected]> | 2015-12-07 12:57:34 +0000 |
|---|---|---|
| committer | David S. Miller <[email protected]> | 2015-12-07 21:35:50 +0000 |
| commit | 679fb46c57859b59a70257477bfbdfc7edfac4f5 (patch) | |
| tree | 0d1641f0b9a16999ae1a72b084c9e62cc51c0091 /net/dsa/dsa.c | |
| parent | net: dsa: cleanup resources upon module removal (diff) | |
| download | kernel-679fb46c57859b59a70257477bfbdfc7edfac4f5.tar.gz kernel-679fb46c57859b59a70257477bfbdfc7edfac4f5.zip | |
net: dsa: Add missing master netdev dev_put() calls
Upon probe failure or unbinding, add missing dev_put() calls.
Signed-off-by: Neil Armstrong <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'net/dsa/dsa.c')
| -rw-r--r-- | net/dsa/dsa.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/net/dsa/dsa.c b/net/dsa/dsa.c index d9e0172116b6..d22d303efd5c 100644 --- a/net/dsa/dsa.c +++ b/net/dsa/dsa.c @@ -919,8 +919,10 @@ static int dsa_probe(struct platform_device *pdev) platform_set_drvdata(pdev, dst); ret = dsa_setup_dst(dst, dev, &pdev->dev, pd); - if (ret) + if (ret) { + dev_put(dev); goto out; + } return 0; @@ -940,6 +942,8 @@ static void dsa_remove_dst(struct dsa_switch_tree *dst) if (ds) dsa_switch_destroy(ds); } + + dev_put(dst->master_netdev); } static int dsa_remove(struct platform_device *pdev) |
