aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/message/i2o/iop.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/message/i2o/iop.c')
-rw-r--r--drivers/message/i2o/iop.c34
1 files changed, 5 insertions, 29 deletions
diff --git a/drivers/message/i2o/iop.c b/drivers/message/i2o/iop.c
index f86abb42bf89..7411a0504bf2 100644
--- a/drivers/message/i2o/iop.c
+++ b/drivers/message/i2o/iop.c
@@ -806,7 +806,6 @@ void i2o_iop_remove(struct i2o_controller *c)
806 list_for_each_entry_safe(dev, tmp, &c->devices, list) 806 list_for_each_entry_safe(dev, tmp, &c->devices, list)
807 i2o_device_remove(dev); 807 i2o_device_remove(dev);
808 808
809 class_device_unregister(c->classdev);
810 device_del(&c->device); 809 device_del(&c->device);
811 810
812 /* Ask the IOP to switch to RESET state */ 811 /* Ask the IOP to switch to RESET state */
@@ -1050,9 +1049,6 @@ static void i2o_iop_release(struct device *dev)
1050 i2o_iop_free(c); 1049 i2o_iop_free(c);
1051}; 1050};
1052 1051
1053/* I2O controller class */
1054static struct class *i2o_controller_class;
1055
1056/** 1052/**
1057 * i2o_iop_alloc - Allocate and initialize a i2o_controller struct 1053 * i2o_iop_alloc - Allocate and initialize a i2o_controller struct
1058 * 1054 *
@@ -1124,36 +1120,29 @@ int i2o_iop_add(struct i2o_controller *c)
1124 goto iop_reset; 1120 goto iop_reset;
1125 } 1121 }
1126 1122
1127 c->classdev = class_device_create(i2o_controller_class, NULL, MKDEV(0,0),
1128 &c->device, "iop%d", c->unit);
1129 if (IS_ERR(c->classdev)) {
1130 osm_err("%s: could not add controller class\n", c->name);
1131 goto device_del;
1132 }
1133
1134 osm_info("%s: Activating I2O controller...\n", c->name); 1123 osm_info("%s: Activating I2O controller...\n", c->name);
1135 osm_info("%s: This may take a few minutes if there are many devices\n", 1124 osm_info("%s: This may take a few minutes if there are many devices\n",
1136 c->name); 1125 c->name);
1137 1126
1138 if ((rc = i2o_iop_activate(c))) { 1127 if ((rc = i2o_iop_activate(c))) {
1139 osm_err("%s: could not activate controller\n", c->name); 1128 osm_err("%s: could not activate controller\n", c->name);
1140 goto class_del; 1129 goto device_del;
1141 } 1130 }
1142 1131
1143 osm_debug("%s: building sys table...\n", c->name); 1132 osm_debug("%s: building sys table...\n", c->name);
1144 1133
1145 if ((rc = i2o_systab_build())) 1134 if ((rc = i2o_systab_build()))
1146 goto class_del; 1135 goto device_del;
1147 1136
1148 osm_debug("%s: online controller...\n", c->name); 1137 osm_debug("%s: online controller...\n", c->name);
1149 1138
1150 if ((rc = i2o_iop_online(c))) 1139 if ((rc = i2o_iop_online(c)))
1151 goto class_del; 1140 goto device_del;
1152 1141
1153 osm_debug("%s: getting LCT...\n", c->name); 1142 osm_debug("%s: getting LCT...\n", c->name);
1154 1143
1155 if ((rc = i2o_exec_lct_get(c))) 1144 if ((rc = i2o_exec_lct_get(c)))
1156 goto class_del; 1145 goto device_del;
1157 1146
1158 list_add(&c->list, &i2o_controllers); 1147 list_add(&c->list, &i2o_controllers);
1159 1148
@@ -1163,9 +1152,6 @@ int i2o_iop_add(struct i2o_controller *c)
1163 1152
1164 return 0; 1153 return 0;
1165 1154
1166 class_del:
1167 class_device_unregister(c->classdev);
1168
1169 device_del: 1155 device_del:
1170 device_del(&c->device); 1156 device_del(&c->device);
1171 1157
@@ -1225,14 +1211,8 @@ static int __init i2o_iop_init(void)
1225 1211
1226 printk(KERN_INFO OSM_DESCRIPTION " v" OSM_VERSION "\n"); 1212 printk(KERN_INFO OSM_DESCRIPTION " v" OSM_VERSION "\n");
1227 1213
1228 i2o_controller_class = class_create(THIS_MODULE, "i2o_controller");
1229 if (IS_ERR(i2o_controller_class)) {
1230 osm_err("can't register class i2o_controller\n");
1231 goto exit;
1232 }
1233
1234 if ((rc = i2o_driver_init())) 1214 if ((rc = i2o_driver_init()))
1235 goto class_exit; 1215 goto exit;
1236 1216
1237 if ((rc = i2o_exec_init())) 1217 if ((rc = i2o_exec_init()))
1238 goto driver_exit; 1218 goto driver_exit;
@@ -1248,9 +1228,6 @@ static int __init i2o_iop_init(void)
1248 driver_exit: 1228 driver_exit:
1249 i2o_driver_exit(); 1229 i2o_driver_exit();
1250 1230
1251 class_exit:
1252 class_destroy(i2o_controller_class);
1253
1254 exit: 1231 exit:
1255 return rc; 1232 return rc;
1256} 1233}
@@ -1265,7 +1242,6 @@ static void __exit i2o_iop_exit(void)
1265 i2o_pci_exit(); 1242 i2o_pci_exit();
1266 i2o_exec_exit(); 1243 i2o_exec_exit();
1267 i2o_driver_exit(); 1244 i2o_driver_exit();
1268 class_destroy(i2o_controller_class);
1269}; 1245};
1270 1246
1271module_init(i2o_iop_init); 1247module_init(i2o_iop_init);