diff --git a/[refs] b/[refs] index 29032ce80641..9b6f766f9696 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: d91dfbb41bb2e9bdbfbd2cc7078ed7436eab027a +refs/heads/master: 8a577ffc75d9194fe8cdb7479236f2081c26ca1f diff --git a/trunk/drivers/base/core.c b/trunk/drivers/base/core.c index d230ff4b3eec..4aa527b8a913 100644 --- a/trunk/drivers/base/core.c +++ b/trunk/drivers/base/core.c @@ -891,7 +891,8 @@ int device_add(struct device *dev) set_dev_node(dev, dev_to_node(parent)); /* first, register with generic layer. */ - error = kobject_add(&dev->kobj, dev->kobj.parent, "%s", dev_name(dev)); + /* we require the name to be set before, and pass NULL */ + error = kobject_add(&dev->kobj, dev->kobj.parent, NULL); if (error) goto Error; diff --git a/trunk/lib/kobject.c b/trunk/lib/kobject.c index a6dec32f2ddd..bacf6fe4f7a0 100644 --- a/trunk/lib/kobject.c +++ b/trunk/lib/kobject.c @@ -218,6 +218,9 @@ int kobject_set_name_vargs(struct kobject *kobj, const char *fmt, const char *old_name = kobj->name; char *s; + if (kobj->name && !fmt) + return 0; + kobj->name = kvasprintf(GFP_KERNEL, fmt, vargs); if (!kobj->name) return -ENOMEM;