|
Denis Kirjanov |
ec0085 |
From 1f9f11b5c0bb6ed67e8263bcb9dc7e836ac78d2d Mon Sep 17 00:00:00 2001
|
|
Denis Kirjanov |
ec0085 |
From: Andy Shevchenko <andy.shevchenko@gmail.com>
|
|
Denis Kirjanov |
ec0085 |
Date: Mon, 10 May 2021 12:58:05 +0300
|
|
Denis Kirjanov |
ec0085 |
Subject: [PATCH 18/19] net: mvpp2: Put fwnode in error case during ->probe()
|
|
Denis Kirjanov |
ec0085 |
Git-commit: 71f0891c84dfdc448736082ab0a00acd29853896
|
|
Denis Kirjanov |
ec0085 |
Patch-mainline: v5.14-rc1
|
|
Denis Kirjanov |
ec0085 |
References: git-fixes
|
|
Denis Kirjanov |
ec0085 |
|
|
Denis Kirjanov |
ec0085 |
In each iteration fwnode_for_each_available_child_node() bumps a reference
|
|
Denis Kirjanov |
ec0085 |
counting of a loop variable followed by dropping in on a next iteration,
|
|
Denis Kirjanov |
ec0085 |
|
|
Denis Kirjanov |
ec0085 |
Since in error case the loop is broken, we have to drop a reference count
|
|
Denis Kirjanov |
ec0085 |
by ourselves. Do it for port_fwnode in error case during ->probe().
|
|
Denis Kirjanov |
ec0085 |
|
|
Denis Kirjanov |
ec0085 |
Fixes: 248122212f68 ("net: mvpp2: use device_*/fwnode_* APIs instead of of_*")
|
|
Denis Kirjanov |
ec0085 |
Cc: Marcin Wojtas <mw@semihalf.com>
|
|
Denis Kirjanov |
ec0085 |
Signed-off-by: Andy Shevchenko <andy.shevchenko@gmail.com>
|
|
Denis Kirjanov |
ec0085 |
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
Denis Kirjanov |
ec0085 |
Signed-off-by: Denis Kirjanov <denis.kirjanov@suse.com>
|
|
Denis Kirjanov |
ec0085 |
---
|
|
Denis Kirjanov |
ec0085 |
drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c | 2 ++
|
|
Denis Kirjanov |
ec0085 |
1 file changed, 2 insertions(+)
|
|
Denis Kirjanov |
ec0085 |
|
|
Denis Kirjanov |
ec0085 |
diff --git a/drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c b/drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c
|
|
Denis Kirjanov |
ec0085 |
index f54316fa2bf0..8f77fe7800c6 100644
|
|
Denis Kirjanov |
ec0085 |
--- a/drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c
|
|
Denis Kirjanov |
ec0085 |
+++ b/drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c
|
|
Denis Kirjanov |
ec0085 |
@@ -5448,6 +5448,8 @@ static int mvpp2_probe(struct platform_device *pdev)
|
|
Denis Kirjanov |
ec0085 |
return 0;
|
|
Denis Kirjanov |
ec0085 |
|
|
Denis Kirjanov |
ec0085 |
err_port_probe:
|
|
Denis Kirjanov |
ec0085 |
+ fwnode_handle_put(port_fwnode);
|
|
Denis Kirjanov |
ec0085 |
+
|
|
Denis Kirjanov |
ec0085 |
i = 0;
|
|
Denis Kirjanov |
ec0085 |
fwnode_for_each_available_child_node(fwnode, port_fwnode) {
|
|
Denis Kirjanov |
ec0085 |
if (priv->port_list[i])
|
|
Denis Kirjanov |
ec0085 |
--
|
|
Denis Kirjanov |
ec0085 |
2.16.4
|
|
Denis Kirjanov |
ec0085 |
|