提交 7bd7b091 编写于 作者: D Dmitry Torokhov 提交者: Greg Kroah-Hartman

[PATCH] I2O: remove i2o_device_class

I2O: cleanup - remove i2o_device_class

I2O devices reside on their own bus so there should be no reason
to also have i2c_device class that mirros i2o bus.
Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 607cf4d9
...@@ -36,9 +36,6 @@ extern void __exit i2o_pci_exit(void); ...@@ -36,9 +36,6 @@ extern void __exit i2o_pci_exit(void);
extern void i2o_device_remove(struct i2o_device *); extern void i2o_device_remove(struct i2o_device *);
extern int i2o_device_parse_lct(struct i2o_controller *); extern int i2o_device_parse_lct(struct i2o_controller *);
extern int i2o_device_init(void);
extern void i2o_device_exit(void);
/* IOP */ /* IOP */
extern struct i2o_controller *i2o_iop_alloc(void); extern struct i2o_controller *i2o_iop_alloc(void);
extern void i2o_iop_free(struct i2o_controller *); extern void i2o_iop_free(struct i2o_controller *);
......
...@@ -138,17 +138,6 @@ static void i2o_device_release(struct device *dev) ...@@ -138,17 +138,6 @@ static void i2o_device_release(struct device *dev)
kfree(i2o_dev); kfree(i2o_dev);
} }
/**
* i2o_device_class_release - I2O class device release function
* @cd: I2O class device which is added to the I2O device class
*
* The function is just a stub - memory will be freed when
* associated I2O device is released.
*/
static void i2o_device_class_release(struct class_device *cd)
{
/* empty */
}
/** /**
* i2o_device_class_show_class_id - Displays class id of I2O device * i2o_device_class_show_class_id - Displays class id of I2O device
...@@ -157,12 +146,13 @@ static void i2o_device_class_release(struct class_device *cd) ...@@ -157,12 +146,13 @@ static void i2o_device_class_release(struct class_device *cd)
* *
* Returns the number of bytes which are printed into the buffer. * Returns the number of bytes which are printed into the buffer.
*/ */
static ssize_t i2o_device_class_show_class_id(struct class_device *cd, static ssize_t i2o_device_show_class_id(struct device *dev,
struct device_attribute *attr,
char *buf) char *buf)
{ {
struct i2o_device *dev = to_i2o_device(cd->dev); struct i2o_device *i2o_dev = to_i2o_device(dev);
sprintf(buf, "0x%03x\n", dev->lct_data.class_id); sprintf(buf, "0x%03x\n", i2o_dev->lct_data.class_id);
return strlen(buf) + 1; return strlen(buf) + 1;
} }
...@@ -173,27 +163,22 @@ static ssize_t i2o_device_class_show_class_id(struct class_device *cd, ...@@ -173,27 +163,22 @@ static ssize_t i2o_device_class_show_class_id(struct class_device *cd,
* *
* Returns the number of bytes which are printed into the buffer. * Returns the number of bytes which are printed into the buffer.
*/ */
static ssize_t i2o_device_class_show_tid(struct class_device *cd, char *buf) static ssize_t i2o_device_show_tid(struct device *dev,
struct device_attribute *attr,
char *buf)
{ {
struct i2o_device *dev = to_i2o_device(cd->dev); struct i2o_device *i2o_dev = to_i2o_device(dev);
sprintf(buf, "0x%03x\n", dev->lct_data.tid); sprintf(buf, "0x%03x\n", i2o_dev->lct_data.tid);
return strlen(buf) + 1; return strlen(buf) + 1;
} }
static struct class_device_attribute i2o_device_class_attrs[] = { struct device_attribute i2o_device_attrs[] = {
__ATTR(class_id, S_IRUGO, i2o_device_class_show_class_id, NULL), __ATTR(class_id, S_IRUGO, i2o_device_show_class_id, NULL),
__ATTR(tid, S_IRUGO, i2o_device_class_show_tid, NULL), __ATTR(tid, S_IRUGO, i2o_device_show_tid, NULL),
__ATTR_NULL __ATTR_NULL
}; };
/* I2O device class */
static struct class i2o_device_class = {
.name = "i2o_device",
.release = i2o_device_class_release,
.class_dev_attrs = i2o_device_class_attrs,
};
/** /**
* i2o_device_alloc - Allocate a I2O device and initialize it * i2o_device_alloc - Allocate a I2O device and initialize it
* *
...@@ -217,8 +202,6 @@ static struct i2o_device *i2o_device_alloc(void) ...@@ -217,8 +202,6 @@ static struct i2o_device *i2o_device_alloc(void)
dev->device.bus = &i2o_bus_type; dev->device.bus = &i2o_bus_type;
dev->device.release = &i2o_device_release; dev->device.release = &i2o_device_release;
dev->classdev.class = &i2o_device_class;
dev->classdev.dev = &dev->device;
return dev; return dev;
} }
...@@ -311,17 +294,12 @@ static struct i2o_device *i2o_device_add(struct i2o_controller *c, ...@@ -311,17 +294,12 @@ static struct i2o_device *i2o_device_add(struct i2o_controller *c,
snprintf(dev->device.bus_id, BUS_ID_SIZE, "%d:%03x", c->unit, snprintf(dev->device.bus_id, BUS_ID_SIZE, "%d:%03x", c->unit,
dev->lct_data.tid); dev->lct_data.tid);
snprintf(dev->classdev.class_id, BUS_ID_SIZE, "%d:%03x", c->unit,
dev->lct_data.tid);
dev->device.parent = &c->device; dev->device.parent = &c->device;
device_register(&dev->device); device_register(&dev->device);
list_add_tail(&dev->list, &c->devices); list_add_tail(&dev->list, &c->devices);
class_device_register(&dev->classdev);
i2o_setup_sysfs_links(dev); i2o_setup_sysfs_links(dev);
i2o_driver_notify_device_add_all(dev); i2o_driver_notify_device_add_all(dev);
...@@ -343,7 +321,6 @@ void i2o_device_remove(struct i2o_device *i2o_dev) ...@@ -343,7 +321,6 @@ void i2o_device_remove(struct i2o_device *i2o_dev)
{ {
i2o_driver_notify_device_remove_all(i2o_dev); i2o_driver_notify_device_remove_all(i2o_dev);
i2o_remove_sysfs_links(i2o_dev); i2o_remove_sysfs_links(i2o_dev);
class_device_unregister(&i2o_dev->classdev);
list_del(&i2o_dev->list); list_del(&i2o_dev->list);
device_unregister(&i2o_dev->device); device_unregister(&i2o_dev->device);
} }
...@@ -598,28 +575,6 @@ int i2o_parm_table_get(struct i2o_device *dev, int oper, int group, ...@@ -598,28 +575,6 @@ int i2o_parm_table_get(struct i2o_device *dev, int oper, int group,
return size; return size;
} }
/**
* i2o_device_init - Initialize I2O devices
*
* Registers the I2O device class.
*
* Returns 0 on success or negative error code on failure.
*/
int i2o_device_init(void)
{
return class_register(&i2o_device_class);
}
/**
* i2o_device_exit - I2O devices exit function
*
* Unregisters the I2O device class.
*/
void i2o_device_exit(void)
{
class_unregister(&i2o_device_class);
}
EXPORT_SYMBOL(i2o_device_claim); EXPORT_SYMBOL(i2o_device_claim);
EXPORT_SYMBOL(i2o_device_claim_release); EXPORT_SYMBOL(i2o_device_claim_release);
EXPORT_SYMBOL(i2o_parm_field_get); EXPORT_SYMBOL(i2o_parm_field_get);
......
...@@ -58,9 +58,12 @@ static int i2o_bus_match(struct device *dev, struct device_driver *drv) ...@@ -58,9 +58,12 @@ static int i2o_bus_match(struct device *dev, struct device_driver *drv)
}; };
/* I2O bus type */ /* I2O bus type */
extern struct device_attribute i2o_device_attrs[];
struct bus_type i2o_bus_type = { struct bus_type i2o_bus_type = {
.name = "i2o", .name = "i2o",
.match = i2o_bus_match, .match = i2o_bus_match,
.dev_attrs = i2o_device_attrs,
}; };
/** /**
......
...@@ -1243,14 +1243,10 @@ static int __init i2o_iop_init(void) ...@@ -1243,14 +1243,10 @@ static int __init i2o_iop_init(void)
printk(KERN_INFO OSM_DESCRIPTION " v" OSM_VERSION "\n"); printk(KERN_INFO OSM_DESCRIPTION " v" OSM_VERSION "\n");
rc = i2o_device_init();
if (rc)
goto exit;
i2o_controller_class = class_create(THIS_MODULE, "i2o_controller"); i2o_controller_class = class_create(THIS_MODULE, "i2o_controller");
if (IS_ERR(i2o_controller_class)) { if (IS_ERR(i2o_controller_class)) {
osm_err("can't register class i2o_controller\n"); osm_err("can't register class i2o_controller\n");
goto device_exit; goto exit;
} }
if ((rc = i2o_driver_init())) if ((rc = i2o_driver_init()))
...@@ -1273,9 +1269,6 @@ static int __init i2o_iop_init(void) ...@@ -1273,9 +1269,6 @@ static int __init i2o_iop_init(void)
class_exit: class_exit:
class_destroy(i2o_controller_class); class_destroy(i2o_controller_class);
device_exit:
i2o_device_exit();
exit: exit:
return rc; return rc;
} }
...@@ -1291,7 +1284,6 @@ static void __exit i2o_iop_exit(void) ...@@ -1291,7 +1284,6 @@ static void __exit i2o_iop_exit(void)
i2o_exec_exit(); i2o_exec_exit();
i2o_driver_exit(); i2o_driver_exit();
class_destroy(i2o_controller_class); class_destroy(i2o_controller_class);
i2o_device_exit();
}; };
module_init(i2o_iop_init); module_init(i2o_iop_init);
......
...@@ -66,8 +66,6 @@ struct i2o_device { ...@@ -66,8 +66,6 @@ struct i2o_device {
struct device device; struct device device;
struct semaphore lock; /* device lock */ struct semaphore lock; /* device lock */
struct class_device classdev; /* i2o device class */
}; };
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册