|
@@ -363,6 +363,60 @@ struct device *get_cpu_device(unsigned cpu)
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(get_cpu_device);
|
|
|
|
|
|
+static void device_create_release(struct device *dev)
|
|
|
+{
|
|
|
+ kfree(dev);
|
|
|
+}
|
|
|
+
|
|
|
+static struct device *
|
|
|
+__cpu_device_create(struct device *parent, void *drvdata,
|
|
|
+ const struct attribute_group **groups,
|
|
|
+ const char *fmt, va_list args)
|
|
|
+{
|
|
|
+ struct device *dev = NULL;
|
|
|
+ int retval = -ENODEV;
|
|
|
+
|
|
|
+ dev = kzalloc(sizeof(*dev), GFP_KERNEL);
|
|
|
+ if (!dev) {
|
|
|
+ retval = -ENOMEM;
|
|
|
+ goto error;
|
|
|
+ }
|
|
|
+
|
|
|
+ device_initialize(dev);
|
|
|
+ dev->parent = parent;
|
|
|
+ dev->groups = groups;
|
|
|
+ dev->release = device_create_release;
|
|
|
+ dev_set_drvdata(dev, drvdata);
|
|
|
+
|
|
|
+ retval = kobject_set_name_vargs(&dev->kobj, fmt, args);
|
|
|
+ if (retval)
|
|
|
+ goto error;
|
|
|
+
|
|
|
+ retval = device_add(dev);
|
|
|
+ if (retval)
|
|
|
+ goto error;
|
|
|
+
|
|
|
+ return dev;
|
|
|
+
|
|
|
+error:
|
|
|
+ put_device(dev);
|
|
|
+ return ERR_PTR(retval);
|
|
|
+}
|
|
|
+
|
|
|
+struct device *cpu_device_create(struct device *parent, void *drvdata,
|
|
|
+ const struct attribute_group **groups,
|
|
|
+ const char *fmt, ...)
|
|
|
+{
|
|
|
+ va_list vargs;
|
|
|
+ struct device *dev;
|
|
|
+
|
|
|
+ va_start(vargs, fmt);
|
|
|
+ dev = __cpu_device_create(parent, drvdata, groups, fmt, vargs);
|
|
|
+ va_end(vargs);
|
|
|
+ return dev;
|
|
|
+}
|
|
|
+EXPORT_SYMBOL_GPL(cpu_device_create);
|
|
|
+
|
|
|
#ifdef CONFIG_GENERIC_CPU_AUTOPROBE
|
|
|
static DEVICE_ATTR(modalias, 0444, print_cpu_modalias, NULL);
|
|
|
#endif
|