| From fadc1053627d764d13481d8bb320444f45a470b6 Mon Sep 17 00:00:00 2001 |
| From: Sasha Levin <sashal@kernel.org> |
| Date: Wed, 20 May 2020 15:04:14 +0300 |
| Subject: of: Fix a refcounting bug in __of_attach_node_sysfs() |
| |
| From: Dan Carpenter <dan.carpenter@oracle.com> |
| |
| [ Upstream commit 8a325dd06f2358ea0888e4ff1c9ca4bc23bd53f3 ] |
| |
| The problem in this code is that if kobject_add() fails, then it should |
| call of_node_put(np) to drop the reference count. I've actually moved |
| the of_node_get(np) later in the function to avoid needing to do clean |
| up. |
| |
| Fixes: 5b2c2f5a0ea3 ("of: overlay: add missing of_node_get() in __of_attach_node_sysfs") |
| Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> |
| Signed-off-by: Rob Herring <robh@kernel.org> |
| Signed-off-by: Sasha Levin <sashal@kernel.org> |
| --- |
| drivers/of/kobj.c | 3 +-- |
| 1 file changed, 1 insertion(+), 2 deletions(-) |
| |
| diff --git a/drivers/of/kobj.c b/drivers/of/kobj.c |
| index c72eef9880417..a32e60b024b8d 100644 |
| --- a/drivers/of/kobj.c |
| +++ b/drivers/of/kobj.c |
| @@ -134,8 +134,6 @@ int __of_attach_node_sysfs(struct device_node *np) |
| if (!name) |
| return -ENOMEM; |
| |
| - of_node_get(np); |
| - |
| rc = kobject_add(&np->kobj, parent, "%s", name); |
| kfree(name); |
| if (rc) |
| @@ -144,6 +142,7 @@ int __of_attach_node_sysfs(struct device_node *np) |
| for_each_property_of_node(np, pp) |
| __of_add_property_sysfs(np, pp); |
| |
| + of_node_get(np); |
| return 0; |
| } |
| |
| -- |
| 2.25.1 |
| |