Commit 3733a1ab authored by Jan Kara's avatar Jan Kara Committed by Thadeu Lima de Souza Cascardo

kobject: Export kobject_get_unless_zero()

BugLink: http://bugs.launchpad.net/bugs/1659111

Make the function available for outside use and fortify it against NULL
kobject.

CC: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Reviewed-by: default avatarBart Van Assche <bart.vanassche@sandisk.com>
Acked-by: default avatarTejun Heo <tj@kernel.org>
Signed-off-by: default avatarJan Kara <jack@suse.cz>
Signed-off-by: default avatarJens Axboe <axboe@fb.com>
(cherry picked from commit c70c176f)
Signed-off-by: default avatarThiago Jung Bauermann <bauerman@linux.vnet.ibm.com>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
Acked-by: default avatarSeth Forshee <seth.forshee@canonical.com>
Acked-by: default avatarBrad Figg <brad.figg@canonical.com>
Signed-off-by: default avatarThadeu Lima de Souza Cascardo <cascardo@canonical.com>
parent 3b9d0678
...@@ -108,6 +108,8 @@ extern int __must_check kobject_rename(struct kobject *, const char *new_name); ...@@ -108,6 +108,8 @@ extern int __must_check kobject_rename(struct kobject *, const char *new_name);
extern int __must_check kobject_move(struct kobject *, struct kobject *); extern int __must_check kobject_move(struct kobject *, struct kobject *);
extern struct kobject *kobject_get(struct kobject *kobj); extern struct kobject *kobject_get(struct kobject *kobj);
extern struct kobject * __must_check kobject_get_unless_zero(
struct kobject *kobj);
extern void kobject_put(struct kobject *kobj); extern void kobject_put(struct kobject *kobj);
extern const void *kobject_namespace(struct kobject *kobj); extern const void *kobject_namespace(struct kobject *kobj);
......
...@@ -601,12 +601,15 @@ struct kobject *kobject_get(struct kobject *kobj) ...@@ -601,12 +601,15 @@ struct kobject *kobject_get(struct kobject *kobj)
} }
EXPORT_SYMBOL(kobject_get); EXPORT_SYMBOL(kobject_get);
static struct kobject * __must_check kobject_get_unless_zero(struct kobject *kobj) struct kobject * __must_check kobject_get_unless_zero(struct kobject *kobj)
{ {
if (!kobj)
return NULL;
if (!kref_get_unless_zero(&kobj->kref)) if (!kref_get_unless_zero(&kobj->kref))
kobj = NULL; kobj = NULL;
return kobj; return kobj;
} }
EXPORT_SYMBOL(kobject_get_unless_zero);
/* /*
* kobject_cleanup - free kobject resources. * kobject_cleanup - free kobject resources.
......
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