提交 838ea8e8 编写于 作者: B Ben Dooks 提交者: Greg Kroah-Hartman

sysdev: fix debugging statements in registration code.

The systdev_class_register() and sysdev_register() functions have
pr_debug() statements which are enabled when the user selects the
driver core debug. Both of these routines do not produce the
correct output, as they make assumptions about data which has not
been initialised.

In sysdev_class_register() the code uses the kobject_name(&cls->kset.kobj)
at the start of the function, but this is not setup until later in the
same call. Change this to use cls->name which is passed in from the caller.

The sysdev_register() function tries to get the name of the sysdev by
kobject_name(&sysdev->kobj), but that isn't setup until later in the same
function so change this message to use the name of the sysdev's class and
add another message once the name is initialised.
Signed-off-by: NBen Dooks <ben-linux@fluff.org>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 185000fc
...@@ -130,8 +130,8 @@ static struct kset *system_kset; ...@@ -130,8 +130,8 @@ static struct kset *system_kset;
int sysdev_class_register(struct sysdev_class * cls) int sysdev_class_register(struct sysdev_class * cls)
{ {
pr_debug("Registering sysdev class '%s'\n", pr_debug("Registering sysdev class '%s'\n", cls->name);
kobject_name(&cls->kset.kobj));
INIT_LIST_HEAD(&cls->drivers); INIT_LIST_HEAD(&cls->drivers);
memset(&cls->kset.kobj, 0x00, sizeof(struct kobject)); memset(&cls->kset.kobj, 0x00, sizeof(struct kobject));
cls->kset.kobj.parent = &system_kset->kobj; cls->kset.kobj.parent = &system_kset->kobj;
...@@ -241,7 +241,8 @@ int sysdev_register(struct sys_device * sysdev) ...@@ -241,7 +241,8 @@ int sysdev_register(struct sys_device * sysdev)
if (!cls) if (!cls)
return -EINVAL; return -EINVAL;
pr_debug("Registering sys device '%s'\n", kobject_name(&sysdev->kobj)); pr_debug("Registering sys device of class '%s'\n",
kobject_name(&cls->kset.kobj));
/* initialize the kobject to 0, in case it had previously been used */ /* initialize the kobject to 0, in case it had previously been used */
memset(&sysdev->kobj, 0x00, sizeof(struct kobject)); memset(&sysdev->kobj, 0x00, sizeof(struct kobject));
...@@ -257,6 +258,9 @@ int sysdev_register(struct sys_device * sysdev) ...@@ -257,6 +258,9 @@ int sysdev_register(struct sys_device * sysdev)
if (!error) { if (!error) {
struct sysdev_driver * drv; struct sysdev_driver * drv;
pr_debug("Registering sys device '%s'\n",
kobject_name(&sysdev->kobj));
mutex_lock(&sysdev_drivers_lock); mutex_lock(&sysdev_drivers_lock);
/* Generic notification is implicit, because it's that /* Generic notification is implicit, because it's that
* code that should have called us. * code that should have called us.
...@@ -269,6 +273,7 @@ int sysdev_register(struct sys_device * sysdev) ...@@ -269,6 +273,7 @@ int sysdev_register(struct sys_device * sysdev)
} }
mutex_unlock(&sysdev_drivers_lock); mutex_unlock(&sysdev_drivers_lock);
} }
kobject_uevent(&sysdev->kobj, KOBJ_ADD); kobject_uevent(&sysdev->kobj, KOBJ_ADD);
return error; return error;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册