Kobject: change drivers/block/pktcdvd.c to use kobject_init_and_add
Stop using kobject_register, as this way we can control the sending of the uevent properly, after everything is properly initialized. Cc: Jens Axboe <axboe@kernel.dk> Cc: Kay Sievers <kay.sievers@vrfy.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
Родитель
a77aa28a2d
Коммит
89c4260664
|
@ -110,17 +110,18 @@ static struct pktcdvd_kobj* pkt_kobj_create(struct pktcdvd_device *pd,
|
||||||
struct kobj_type* ktype)
|
struct kobj_type* ktype)
|
||||||
{
|
{
|
||||||
struct pktcdvd_kobj *p;
|
struct pktcdvd_kobj *p;
|
||||||
|
int error;
|
||||||
|
|
||||||
p = kzalloc(sizeof(*p), GFP_KERNEL);
|
p = kzalloc(sizeof(*p), GFP_KERNEL);
|
||||||
if (!p)
|
if (!p)
|
||||||
return NULL;
|
return NULL;
|
||||||
kobject_set_name(&p->kobj, "%s", name);
|
|
||||||
p->kobj.parent = parent;
|
|
||||||
p->kobj.ktype = ktype;
|
|
||||||
p->pd = pd;
|
p->pd = pd;
|
||||||
if (kobject_register(&p->kobj) != 0) {
|
error = kobject_init_and_add(&p->kobj, ktype, parent, "%s", name);
|
||||||
|
if (error) {
|
||||||
kobject_put(&p->kobj);
|
kobject_put(&p->kobj);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
kobject_uevent(&p->kobj, KOBJ_ADD);
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
|
|
Загрузка…
Ссылка в новой задаче