aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/i2c/i2c-core.c33
-rw-r--r--include/linux/i2c.h7
2 files changed, 12 insertions, 28 deletions
diff --git a/drivers/i2c/i2c-core.c b/drivers/i2c/i2c-core.c
index 0d873ba2e82e..f7cd05b4f327 100644
--- a/drivers/i2c/i2c-core.c
+++ b/drivers/i2c/i2c-core.c
@@ -49,7 +49,7 @@
49 49
50/* core_lock protects i2c_adapter_idr, and guarantees 50/* core_lock protects i2c_adapter_idr, and guarantees
51 that device detection, deletion of detected devices, and attach_adapter 51 that device detection, deletion of detected devices, and attach_adapter
52 and detach_adapter calls are serialized */ 52 calls are serialized */
53static DEFINE_MUTEX(core_lock); 53static DEFINE_MUTEX(core_lock);
54static DEFINE_IDR(i2c_adapter_idr); 54static DEFINE_IDR(i2c_adapter_idr);
55 55
@@ -1172,11 +1172,10 @@ int i2c_add_numbered_adapter(struct i2c_adapter *adap)
1172} 1172}
1173EXPORT_SYMBOL_GPL(i2c_add_numbered_adapter); 1173EXPORT_SYMBOL_GPL(i2c_add_numbered_adapter);
1174 1174
1175static int i2c_do_del_adapter(struct i2c_driver *driver, 1175static void i2c_do_del_adapter(struct i2c_driver *driver,
1176 struct i2c_adapter *adapter) 1176 struct i2c_adapter *adapter)
1177{ 1177{
1178 struct i2c_client *client, *_n; 1178 struct i2c_client *client, *_n;
1179 int res;
1180 1179
1181 /* Remove the devices we created ourselves as the result of hardware 1180 /* Remove the devices we created ourselves as the result of hardware
1182 * probing (using a driver's detect method) */ 1181 * probing (using a driver's detect method) */
@@ -1188,16 +1187,6 @@ static int i2c_do_del_adapter(struct i2c_driver *driver,
1188 i2c_unregister_device(client); 1187 i2c_unregister_device(client);
1189 } 1188 }
1190 } 1189 }
1191
1192 if (!driver->detach_adapter)
1193 return 0;
1194 dev_warn(&adapter->dev, "%s: detach_adapter method is deprecated\n",
1195 driver->driver.name);
1196 res = driver->detach_adapter(adapter);
1197 if (res)
1198 dev_err(&adapter->dev, "detach_adapter failed (%d) "
1199 "for driver [%s]\n", res, driver->driver.name);
1200 return res;
1201} 1190}
1202 1191
1203static int __unregister_client(struct device *dev, void *dummy) 1192static int __unregister_client(struct device *dev, void *dummy)
@@ -1218,7 +1207,8 @@ static int __unregister_dummy(struct device *dev, void *dummy)
1218 1207
1219static int __process_removed_adapter(struct device_driver *d, void *data) 1208static int __process_removed_adapter(struct device_driver *d, void *data)
1220{ 1209{
1221 return i2c_do_del_adapter(to_i2c_driver(d), data); 1210 i2c_do_del_adapter(to_i2c_driver(d), data);
1211 return 0;
1222} 1212}
1223 1213
1224/** 1214/**
@@ -1231,7 +1221,6 @@ static int __process_removed_adapter(struct device_driver *d, void *data)
1231 */ 1221 */
1232int i2c_del_adapter(struct i2c_adapter *adap) 1222int i2c_del_adapter(struct i2c_adapter *adap)
1233{ 1223{
1234 int res = 0;
1235 struct i2c_adapter *found; 1224 struct i2c_adapter *found;
1236 struct i2c_client *client, *next; 1225 struct i2c_client *client, *next;
1237 1226
@@ -1247,11 +1236,9 @@ int i2c_del_adapter(struct i2c_adapter *adap)
1247 1236
1248 /* Tell drivers about this removal */ 1237 /* Tell drivers about this removal */
1249 mutex_lock(&core_lock); 1238 mutex_lock(&core_lock);
1250 res = bus_for_each_drv(&i2c_bus_type, NULL, adap, 1239 bus_for_each_drv(&i2c_bus_type, NULL, adap,
1251 __process_removed_adapter); 1240 __process_removed_adapter);
1252 mutex_unlock(&core_lock); 1241 mutex_unlock(&core_lock);
1253 if (res)
1254 return res;
1255 1242
1256 /* Remove devices instantiated from sysfs */ 1243 /* Remove devices instantiated from sysfs */
1257 mutex_lock_nested(&adap->userspace_clients_lock, 1244 mutex_lock_nested(&adap->userspace_clients_lock,
@@ -1270,8 +1257,8 @@ int i2c_del_adapter(struct i2c_adapter *adap)
1270 * we can't remove the dummy devices during the first pass: they 1257 * we can't remove the dummy devices during the first pass: they
1271 * could have been instantiated by real devices wishing to clean 1258 * could have been instantiated by real devices wishing to clean
1272 * them up properly, so we give them a chance to do that first. */ 1259 * them up properly, so we give them a chance to do that first. */
1273 res = device_for_each_child(&adap->dev, NULL, __unregister_client); 1260 device_for_each_child(&adap->dev, NULL, __unregister_client);
1274 res = device_for_each_child(&adap->dev, NULL, __unregister_dummy); 1261 device_for_each_child(&adap->dev, NULL, __unregister_dummy);
1275 1262
1276#ifdef CONFIG_I2C_COMPAT 1263#ifdef CONFIG_I2C_COMPAT
1277 class_compat_remove_link(i2c_adapter_compat_class, &adap->dev, 1264 class_compat_remove_link(i2c_adapter_compat_class, &adap->dev,
@@ -1367,9 +1354,9 @@ EXPORT_SYMBOL(i2c_register_driver);
1367 1354
1368static int __process_removed_driver(struct device *dev, void *data) 1355static int __process_removed_driver(struct device *dev, void *data)
1369{ 1356{
1370 if (dev->type != &i2c_adapter_type) 1357 if (dev->type == &i2c_adapter_type)
1371 return 0; 1358 i2c_do_del_adapter(data, to_i2c_adapter(dev));
1372 return i2c_do_del_adapter(data, to_i2c_adapter(dev)); 1359 return 0;
1373} 1360}
1374 1361
1375/** 1362/**
diff --git a/include/linux/i2c.h b/include/linux/i2c.h
index 2eca3860b77f..f2bcd46ce194 100644
--- a/include/linux/i2c.h
+++ b/include/linux/i2c.h
@@ -125,7 +125,6 @@ extern s32 i2c_smbus_write_i2c_block_data(const struct i2c_client *client,
125 * struct i2c_driver - represent an I2C device driver 125 * struct i2c_driver - represent an I2C device driver
126 * @class: What kind of i2c device we instantiate (for detect) 126 * @class: What kind of i2c device we instantiate (for detect)
127 * @attach_adapter: Callback for bus addition (deprecated) 127 * @attach_adapter: Callback for bus addition (deprecated)
128 * @detach_adapter: Callback for bus removal (deprecated)
129 * @probe: Callback for device binding 128 * @probe: Callback for device binding
130 * @remove: Callback for device unbinding 129 * @remove: Callback for device unbinding
131 * @shutdown: Callback for device shutdown 130 * @shutdown: Callback for device shutdown
@@ -162,12 +161,10 @@ extern s32 i2c_smbus_write_i2c_block_data(const struct i2c_client *client,
162struct i2c_driver { 161struct i2c_driver {
163 unsigned int class; 162 unsigned int class;
164 163
165 /* Notifies the driver that a new bus has appeared or is about to be 164 /* Notifies the driver that a new bus has appeared. You should avoid
166 * removed. You should avoid using this, it will be removed in a 165 * using this, it will be removed in a near future.
167 * near future.
168 */ 166 */
169 int (*attach_adapter)(struct i2c_adapter *) __deprecated; 167 int (*attach_adapter)(struct i2c_adapter *) __deprecated;
170 int (*detach_adapter)(struct i2c_adapter *) __deprecated;
171 168
172 /* Standard driver model interfaces */ 169 /* Standard driver model interfaces */
173 int (*probe)(struct i2c_client *, const struct i2c_device_id *); 170 int (*probe)(struct i2c_client *, const struct i2c_device_id *);