提交 ecbaa83e 编写于 作者: G Greg Kroah-Hartman

driver core: remove class_attrs from struct class

This field is no longer used or needed (use class_groups instead), so it
can be removed along with the driver core functionality that created and
removed these files.
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 dc307f92
...@@ -119,36 +119,6 @@ static void class_put(struct class *cls) ...@@ -119,36 +119,6 @@ static void class_put(struct class *cls)
kset_put(&cls->p->subsys); kset_put(&cls->p->subsys);
} }
static int add_class_attrs(struct class *cls)
{
int i;
int error = 0;
if (cls->class_attrs) {
for (i = 0; cls->class_attrs[i].attr.name; i++) {
error = class_create_file(cls, &cls->class_attrs[i]);
if (error)
goto error;
}
}
done:
return error;
error:
while (--i >= 0)
class_remove_file(cls, &cls->class_attrs[i]);
goto done;
}
static void remove_class_attrs(struct class *cls)
{
int i;
if (cls->class_attrs) {
for (i = 0; cls->class_attrs[i].attr.name; i++)
class_remove_file(cls, &cls->class_attrs[i]);
}
}
static void klist_class_dev_get(struct klist_node *n) static void klist_class_dev_get(struct klist_node *n)
{ {
struct device *dev = container_of(n, struct device, knode_class); struct device *dev = container_of(n, struct device, knode_class);
...@@ -217,8 +187,6 @@ int __class_register(struct class *cls, struct lock_class_key *key) ...@@ -217,8 +187,6 @@ int __class_register(struct class *cls, struct lock_class_key *key)
} }
error = class_add_groups(class_get(cls), cls->class_groups); error = class_add_groups(class_get(cls), cls->class_groups);
class_put(cls); class_put(cls);
error = add_class_attrs(class_get(cls));
class_put(cls);
return error; return error;
} }
EXPORT_SYMBOL_GPL(__class_register); EXPORT_SYMBOL_GPL(__class_register);
...@@ -226,7 +194,6 @@ EXPORT_SYMBOL_GPL(__class_register); ...@@ -226,7 +194,6 @@ EXPORT_SYMBOL_GPL(__class_register);
void class_unregister(struct class *cls) void class_unregister(struct class *cls)
{ {
pr_debug("device class '%s': unregistering\n", cls->name); pr_debug("device class '%s': unregistering\n", cls->name);
remove_class_attrs(cls);
class_remove_groups(cls, cls->class_groups); class_remove_groups(cls, cls->class_groups);
kset_unregister(&cls->p->subsys); kset_unregister(&cls->p->subsys);
} }
......
...@@ -365,7 +365,6 @@ int subsys_virtual_register(struct bus_type *subsys, ...@@ -365,7 +365,6 @@ int subsys_virtual_register(struct bus_type *subsys,
* struct class - device classes * struct class - device classes
* @name: Name of the class. * @name: Name of the class.
* @owner: The module owner. * @owner: The module owner.
* @class_attrs: Default attributes of this class.
* @class_groups: Default attributes of this class. * @class_groups: Default attributes of this class.
* @dev_groups: Default attributes of the devices that belong to the class. * @dev_groups: Default attributes of the devices that belong to the class.
* @dev_kobj: The kobject that represents this class and links it into the hierarchy. * @dev_kobj: The kobject that represents this class and links it into the hierarchy.
...@@ -394,7 +393,6 @@ struct class { ...@@ -394,7 +393,6 @@ struct class {
const char *name; const char *name;
struct module *owner; struct module *owner;
struct class_attribute *class_attrs;
const struct attribute_group **class_groups; const struct attribute_group **class_groups;
const struct attribute_group **dev_groups; const struct attribute_group **dev_groups;
struct kobject *dev_kobj; struct kobject *dev_kobj;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册