aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/base/class.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/base/class.c')
-rw-r--r--drivers/base/class.c23
1 files changed, 12 insertions, 11 deletions
diff --git a/drivers/base/class.c b/drivers/base/class.c
index 48b518e66bfc..86778b86496e 100644
--- a/drivers/base/class.c
+++ b/drivers/base/class.c
@@ -70,7 +70,7 @@ static struct kobj_type class_ktype = {
70 .release = class_release, 70 .release = class_release,
71}; 71};
72 72
73/* Hotplug events for classes go to the class_obj subsys */ 73/* Hotplug events for classes go to the class class_subsys */
74static struct kset *class_kset; 74static struct kset *class_kset;
75 75
76 76
@@ -78,7 +78,8 @@ int class_create_file(struct class *cls, const struct class_attribute *attr)
78{ 78{
79 int error; 79 int error;
80 if (cls) 80 if (cls)
81 error = sysfs_create_file(&cls->p->subsys.kobj, &attr->attr); 81 error = sysfs_create_file(&cls->p->class_subsys.kobj,
82 &attr->attr);
82 else 83 else
83 error = -EINVAL; 84 error = -EINVAL;
84 return error; 85 return error;
@@ -87,20 +88,20 @@ int class_create_file(struct class *cls, const struct class_attribute *attr)
87void class_remove_file(struct class *cls, const struct class_attribute *attr) 88void class_remove_file(struct class *cls, const struct class_attribute *attr)
88{ 89{
89 if (cls) 90 if (cls)
90 sysfs_remove_file(&cls->p->subsys.kobj, &attr->attr); 91 sysfs_remove_file(&cls->p->class_subsys.kobj, &attr->attr);
91} 92}
92 93
93static struct class *class_get(struct class *cls) 94static struct class *class_get(struct class *cls)
94{ 95{
95 if (cls) 96 if (cls)
96 kset_get(&cls->p->subsys); 97 kset_get(&cls->p->class_subsys);
97 return cls; 98 return cls;
98} 99}
99 100
100static void class_put(struct class *cls) 101static void class_put(struct class *cls)
101{ 102{
102 if (cls) 103 if (cls)
103 kset_put(&cls->p->subsys); 104 kset_put(&cls->p->class_subsys);
104} 105}
105 106
106static int add_class_attrs(struct class *cls) 107static int add_class_attrs(struct class *cls)
@@ -147,7 +148,7 @@ int class_register(struct class *cls)
147 INIT_LIST_HEAD(&cp->class_interfaces); 148 INIT_LIST_HEAD(&cp->class_interfaces);
148 kset_init(&cp->class_dirs); 149 kset_init(&cp->class_dirs);
149 init_MUTEX(&cp->sem); 150 init_MUTEX(&cp->sem);
150 error = kobject_set_name(&cp->subsys.kobj, "%s", cls->name); 151 error = kobject_set_name(&cp->class_subsys.kobj, "%s", cls->name);
151 if (error) { 152 if (error) {
152 kfree(cp); 153 kfree(cp);
153 return error; 154 return error;
@@ -160,15 +161,15 @@ int class_register(struct class *cls)
160#if defined(CONFIG_SYSFS_DEPRECATED) && defined(CONFIG_BLOCK) 161#if defined(CONFIG_SYSFS_DEPRECATED) && defined(CONFIG_BLOCK)
161 /* let the block class directory show up in the root of sysfs */ 162 /* let the block class directory show up in the root of sysfs */
162 if (cls != &block_class) 163 if (cls != &block_class)
163 cp->subsys.kobj.kset = class_kset; 164 cp->class_subsys.kobj.kset = class_kset;
164#else 165#else
165 cp->subsys.kobj.kset = class_kset; 166 cp->class_subsys.kobj.kset = class_kset;
166#endif 167#endif
167 cp->subsys.kobj.ktype = &class_ktype; 168 cp->class_subsys.kobj.ktype = &class_ktype;
168 cp->class = cls; 169 cp->class = cls;
169 cls->p = cp; 170 cls->p = cp;
170 171
171 error = kset_register(&cp->subsys); 172 error = kset_register(&cp->class_subsys);
172 if (error) { 173 if (error) {
173 kfree(cp); 174 kfree(cp);
174 return error; 175 return error;
@@ -182,7 +183,7 @@ void class_unregister(struct class *cls)
182{ 183{
183 pr_debug("device class '%s': unregistering\n", cls->name); 184 pr_debug("device class '%s': unregistering\n", cls->name);
184 remove_class_attrs(cls); 185 remove_class_attrs(cls);
185 kset_unregister(&cls->p->subsys); 186 kset_unregister(&cls->p->class_subsys);
186} 187}
187 188
188static void class_create_release(struct class *cls) 189static void class_create_release(struct class *cls)