未验证 提交 021a011f 编写于 作者: O openeuler-ci-bot 提交者: Gitee

!972 [sync] PR-969: kobject: Fix slab-out-of-bounds in fill_kobj_path()

Merge Pull Request from: @openeuler-sync-bot 
 

Origin pull request: 
https://gitee.com/openeuler/kernel/pulls/969 
 
PR sync from:  Xia Fukun <xiafukun@huawei.com>
 https://mailweb.openeuler.org/hyperkitty/list/kernel@openeuler.org/thread/BKNZ3SWVHTMMTKLWPREORX4R6EEUURB6/ 
 
 
Link:https://gitee.com/openeuler/kernel/pulls/972 

Reviewed-by: Zucheng Zheng <zhengzucheng@huawei.com> 
Signed-off-by: Jialin Zhang <zhangjialin11@huawei.com> 
...@@ -144,7 +144,7 @@ static int get_kobj_path_length(struct kobject *kobj) ...@@ -144,7 +144,7 @@ static int get_kobj_path_length(struct kobject *kobj)
return length; return length;
} }
static void fill_kobj_path(struct kobject *kobj, char *path, int length) static int fill_kobj_path(struct kobject *kobj, char *path, int length)
{ {
struct kobject *parent; struct kobject *parent;
...@@ -153,12 +153,16 @@ static void fill_kobj_path(struct kobject *kobj, char *path, int length) ...@@ -153,12 +153,16 @@ static void fill_kobj_path(struct kobject *kobj, char *path, int length)
int cur = strlen(kobject_name(parent)); int cur = strlen(kobject_name(parent));
/* back up enough to print this name with '/' */ /* back up enough to print this name with '/' */
length -= cur; length -= cur;
if (length <= 0)
return -EINVAL;
memcpy(path + length, kobject_name(parent), cur); memcpy(path + length, kobject_name(parent), cur);
*(path + --length) = '/'; *(path + --length) = '/';
} }
pr_debug("kobject: '%s' (%p): %s: path = '%s'\n", kobject_name(kobj), pr_debug("kobject: '%s' (%p): %s: path = '%s'\n", kobject_name(kobj),
kobj, __func__, path); kobj, __func__, path);
return 0;
} }
/** /**
...@@ -173,13 +177,17 @@ char *kobject_get_path(struct kobject *kobj, gfp_t gfp_mask) ...@@ -173,13 +177,17 @@ char *kobject_get_path(struct kobject *kobj, gfp_t gfp_mask)
char *path; char *path;
int len; int len;
retry:
len = get_kobj_path_length(kobj); len = get_kobj_path_length(kobj);
if (len == 0) if (len == 0)
return NULL; return NULL;
path = kzalloc(len, gfp_mask); path = kzalloc(len, gfp_mask);
if (!path) if (!path)
return NULL; return NULL;
fill_kobj_path(kobj, path, len); if (fill_kobj_path(kobj, path, len)) {
kfree(path);
goto retry;
}
return path; return path;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册