Commit 7e803979 authored by Tobin C. Harding's avatar Tobin C. Harding Committed by Michael Ellerman

powerpc/cacheinfo: Fix kobject memleak

Currently error return from kobject_init_and_add() is not followed by
a call to kobject_put(). This means there is a memory leak.

Add call to kobject_put() in error path of kobject_init_and_add().
Signed-off-by: default avatarTobin C. Harding <tobin@kernel.org>
Reviewed-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Reviewed-by: default avatarTyrel Datwyler <tyreld@linux.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent 33dda8c3
...@@ -759,23 +759,22 @@ static void cacheinfo_create_index_dir(struct cache *cache, int index, ...@@ -759,23 +759,22 @@ static void cacheinfo_create_index_dir(struct cache *cache, int index,
index_dir = kzalloc(sizeof(*index_dir), GFP_KERNEL); index_dir = kzalloc(sizeof(*index_dir), GFP_KERNEL);
if (!index_dir) if (!index_dir)
goto err; return;
index_dir->cache = cache; index_dir->cache = cache;
rc = kobject_init_and_add(&index_dir->kobj, &cache_index_type, rc = kobject_init_and_add(&index_dir->kobj, &cache_index_type,
cache_dir->kobj, "index%d", index); cache_dir->kobj, "index%d", index);
if (rc) if (rc) {
goto err; kobject_put(&index_dir->kobj);
kfree(index_dir);
return;
}
index_dir->next = cache_dir->index; index_dir->next = cache_dir->index;
cache_dir->index = index_dir; cache_dir->index = index_dir;
cacheinfo_create_index_opt_attrs(index_dir); cacheinfo_create_index_opt_attrs(index_dir);
return;
err:
kfree(index_dir);
} }
static void cacheinfo_sysfs_populate(unsigned int cpu_id, static void cacheinfo_sysfs_populate(unsigned int cpu_id,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment