提交 6142df2a 编写于 作者: D Dan Carpenter 提交者: Zheng Zengkai

node: fix device cleanups in error handling code

stable inclusion
from stable-5.10.37
commit c703ef8289dce715a012d038412030b49bfbf049
bugzilla: 51868
CVE: NA

--------------------------------

[ Upstream commit 4ce535ec ]

We can't use kfree() to free device managed resources so the kfree(dev)
is against the rules.

It's easier to write this code if we open code the device_register() as
a device_initialize() and device_add().  That way if dev_set_name() set
name fails we can call put_device() and it will clean up correctly.

Fixes: acc02a10 ("node: Add memory-side caching attributes")
Signed-off-by: NDan Carpenter <dan.carpenter@oracle.com>
Link: https://lore.kernel.org/r/YHA0JUra+F64+NpB@mwandaSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: NSasha Levin <sashal@kernel.org>
Signed-off-by: NChen Jun <chenjun102@huawei.com>
Acked-by: NWeilong Chen <chenweilong@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 a30fb429
...@@ -268,21 +268,20 @@ static void node_init_cache_dev(struct node *node) ...@@ -268,21 +268,20 @@ static void node_init_cache_dev(struct node *node)
if (!dev) if (!dev)
return; return;
device_initialize(dev);
dev->parent = &node->dev; dev->parent = &node->dev;
dev->release = node_cache_release; dev->release = node_cache_release;
if (dev_set_name(dev, "memory_side_cache")) if (dev_set_name(dev, "memory_side_cache"))
goto free_dev; goto put_device;
if (device_register(dev)) if (device_add(dev))
goto free_name; goto put_device;
pm_runtime_no_callbacks(dev); pm_runtime_no_callbacks(dev);
node->cache_dev = dev; node->cache_dev = dev;
return; return;
free_name: put_device:
kfree_const(dev->kobj.name); put_device(dev);
free_dev:
kfree(dev);
} }
/** /**
...@@ -319,25 +318,24 @@ void node_add_cache(unsigned int nid, struct node_cache_attrs *cache_attrs) ...@@ -319,25 +318,24 @@ void node_add_cache(unsigned int nid, struct node_cache_attrs *cache_attrs)
return; return;
dev = &info->dev; dev = &info->dev;
device_initialize(dev);
dev->parent = node->cache_dev; dev->parent = node->cache_dev;
dev->release = node_cacheinfo_release; dev->release = node_cacheinfo_release;
dev->groups = cache_groups; dev->groups = cache_groups;
if (dev_set_name(dev, "index%d", cache_attrs->level)) if (dev_set_name(dev, "index%d", cache_attrs->level))
goto free_cache; goto put_device;
info->cache_attrs = *cache_attrs; info->cache_attrs = *cache_attrs;
if (device_register(dev)) { if (device_add(dev)) {
dev_warn(&node->dev, "failed to add cache level:%d\n", dev_warn(&node->dev, "failed to add cache level:%d\n",
cache_attrs->level); cache_attrs->level);
goto free_name; goto put_device;
} }
pm_runtime_no_callbacks(dev); pm_runtime_no_callbacks(dev);
list_add_tail(&info->node, &node->cache_attrs); list_add_tail(&info->node, &node->cache_attrs);
return; return;
free_name: put_device:
kfree_const(dev->kobj.name); put_device(dev);
free_cache:
kfree(info);
} }
static void node_remove_caches(struct node *node) static void node_remove_caches(struct node *node)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册