Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 28296
b: refs/heads/master
c: aa49b91
h: refs/heads/master
v: v3
  • Loading branch information
Greg Kroah-Hartman committed Jun 21, 2006
1 parent 514cbe9 commit d159122
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 15 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: cad1e55d4d19a49c2b82b74562a6e4e555b05f38
refs/heads/master: aa49b9136e3d44cc264811d77eef4ded88456717
1 change: 1 addition & 0 deletions trunk/drivers/base/base.h
Original file line number Diff line number Diff line change
Expand Up @@ -42,4 +42,5 @@ struct class_device_attribute *to_class_dev_attr(struct attribute *_attr)
return container_of(_attr, struct class_device_attribute, attr);
}

extern char *make_class_name(const char *name, struct kobject *kobj);

31 changes: 17 additions & 14 deletions trunk/drivers/base/class.c
Original file line number Diff line number Diff line change
Expand Up @@ -504,22 +504,21 @@ void class_device_initialize(struct class_device *class_dev)
INIT_LIST_HEAD(&class_dev->node);
}

static char *make_class_name(struct class_device *class_dev)
char *make_class_name(const char *name, struct kobject *kobj)
{
char *name;
char *class_name;
int size;

size = strlen(class_dev->class->name) +
strlen(kobject_name(&class_dev->kobj)) + 2;
size = strlen(name) + strlen(kobject_name(kobj)) + 2;

name = kmalloc(size, GFP_KERNEL);
if (!name)
class_name = kmalloc(size, GFP_KERNEL);
if (!class_name)
return ERR_PTR(-ENOMEM);

strcpy(name, class_dev->class->name);
strcat(name, ":");
strcat(name, kobject_name(&class_dev->kobj));
return name;
strcpy(class_name, name);
strcat(class_name, ":");
strcat(class_name, kobject_name(kobj));
return class_name;
}

int class_device_add(struct class_device *class_dev)
Expand Down Expand Up @@ -594,7 +593,8 @@ int class_device_add(struct class_device *class_dev)
goto out5;

if (class_dev->dev) {
class_name = make_class_name(class_dev);
class_name = make_class_name(class_dev->class->name,
&class_dev->kobj);
error = sysfs_create_link(&class_dev->kobj,
&class_dev->dev->kobj, "device");
if (error)
Expand Down Expand Up @@ -731,7 +731,8 @@ void class_device_del(struct class_device *class_dev)
}

if (class_dev->dev) {
class_name = make_class_name(class_dev);
class_name = make_class_name(class_dev->class->name,
&class_dev->kobj);
sysfs_remove_link(&class_dev->kobj, "device");
sysfs_remove_link(&class_dev->dev->kobj, class_name);
}
Expand Down Expand Up @@ -796,14 +797,16 @@ int class_device_rename(struct class_device *class_dev, char *new_name)
new_name);

if (class_dev->dev)
old_class_name = make_class_name(class_dev);
old_class_name = make_class_name(class_dev->class->name,
&class_dev->kobj);

strlcpy(class_dev->class_id, new_name, KOBJ_NAME_LEN);

error = kobject_rename(&class_dev->kobj, new_name);

if (class_dev->dev) {
new_class_name = make_class_name(class_dev);
new_class_name = make_class_name(class_dev->class->name,
&class_dev->kobj);
sysfs_create_link(&class_dev->dev->kobj, &class_dev->kobj,
new_class_name);
sysfs_remove_link(&class_dev->dev->kobj, old_class_name);
Expand Down

0 comments on commit d159122

Please sign in to comment.