2005-04-16 15:20:36 -07:00
|
|
|
/*
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
i2c-isa.c - an i2c-core-like thing for ISA hardware monitoring chips
|
|
|
|
Copyright (C) 2005 Jean Delvare <khali@linux-fr.org>
|
|
|
|
|
|
|
|
Based on the i2c-isa pseudo-adapter from the lm_sensors project
|
2005-04-16 15:20:36 -07:00
|
|
|
Copyright (c) 1998, 1999 Frodo Looijaard <frodol@dds.nl>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
*/
|
|
|
|
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
/* This implements an i2c-core-like thing for ISA hardware monitoring
|
|
|
|
chips. Such chips are linked to the i2c subsystem for historical
|
|
|
|
reasons (because the early ISA hardware monitoring chips such as the
|
|
|
|
LM78 had both an I2C and an ISA interface). They used to be
|
|
|
|
registered with the main i2c-core, but as a first step in the
|
|
|
|
direction of a clean separation between I2C and ISA chip drivers,
|
|
|
|
we now have this separate core for ISA ones. It is significantly
|
|
|
|
more simple than the real one, of course, because we don't have to
|
|
|
|
handle multiple busses: there is only one (fake) ISA adapter.
|
|
|
|
It is worth noting that we still rely on i2c-core for some things
|
|
|
|
at the moment - but hopefully this won't last. */
|
2005-04-16 15:20:36 -07:00
|
|
|
|
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/module.h>
|
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <linux/errno.h>
|
|
|
|
#include <linux/i2c.h>
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
#include <linux/i2c-isa.h>
|
2005-10-29 19:07:23 +01:00
|
|
|
#include <linux/platform_device.h>
|
2007-02-13 22:09:00 +01:00
|
|
|
#include <linux/completion.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
|
2007-05-01 23:26:32 +02:00
|
|
|
/* Exported by i2c-core for i2c-isa only */
|
|
|
|
extern void i2c_adapter_dev_release(struct device *dev);
|
|
|
|
extern struct class i2c_adapter_class;
|
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
static u32 isa_func(struct i2c_adapter *adapter);
|
|
|
|
|
|
|
|
/* This is the actual algorithm we define */
|
2006-09-03 22:39:46 +02:00
|
|
|
static const struct i2c_algorithm isa_algorithm = {
|
2005-04-16 15:20:36 -07:00
|
|
|
.functionality = isa_func,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* There can only be one... */
|
|
|
|
static struct i2c_adapter isa_adapter = {
|
|
|
|
.owner = THIS_MODULE,
|
2005-08-11 23:41:56 +02:00
|
|
|
.id = I2C_HW_ISA,
|
2005-04-16 15:20:36 -07:00
|
|
|
.class = I2C_CLASS_HWMON,
|
|
|
|
.algo = &isa_algorithm,
|
|
|
|
.name = "ISA main adapter",
|
|
|
|
};
|
|
|
|
|
|
|
|
/* We can't do a thing... */
|
|
|
|
static u32 isa_func(struct i2c_adapter *adapter)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
|
|
|
|
/* We implement an interface which resembles i2c_{add,del}_driver,
|
|
|
|
but for i2c-isa drivers. We don't have to remember and handle lists
|
|
|
|
of drivers and adapters so this is much more simple, of course. */
|
|
|
|
|
|
|
|
int i2c_isa_add_driver(struct i2c_driver *driver)
|
|
|
|
{
|
|
|
|
int res;
|
|
|
|
|
|
|
|
/* Add the driver to the list of i2c drivers in the driver core */
|
|
|
|
driver->driver.bus = &i2c_bus_type;
|
|
|
|
res = driver_register(&driver->driver);
|
|
|
|
if (res)
|
|
|
|
return res;
|
2005-11-30 16:35:09 -08:00
|
|
|
dev_dbg(&isa_adapter.dev, "Driver %s registered\n", driver->driver.name);
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
|
|
|
|
/* Now look for clients */
|
2006-09-03 22:21:20 +02:00
|
|
|
res = driver->attach_adapter(&isa_adapter);
|
|
|
|
if (res) {
|
2006-10-13 16:56:28 +02:00
|
|
|
dev_dbg(&isa_adapter.dev,
|
2006-09-03 22:21:20 +02:00
|
|
|
"Driver %s failed to attach adapter, unregistering\n",
|
|
|
|
driver->driver.name);
|
|
|
|
driver_unregister(&driver->driver);
|
|
|
|
}
|
|
|
|
return res;
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
int i2c_isa_del_driver(struct i2c_driver *driver)
|
|
|
|
{
|
|
|
|
struct list_head *item, *_n;
|
|
|
|
struct i2c_client *client;
|
|
|
|
int res;
|
|
|
|
|
|
|
|
/* Detach all clients belonging to this one driver */
|
|
|
|
list_for_each_safe(item, _n, &isa_adapter.clients) {
|
|
|
|
client = list_entry(item, struct i2c_client, list);
|
|
|
|
if (client->driver != driver)
|
|
|
|
continue;
|
|
|
|
dev_dbg(&isa_adapter.dev, "Detaching client %s at 0x%x\n",
|
|
|
|
client->name, client->addr);
|
|
|
|
if ((res = driver->detach_client(client))) {
|
|
|
|
dev_err(&isa_adapter.dev, "Failed, driver "
|
|
|
|
"%s not unregistered!\n",
|
2005-11-26 20:34:05 +01:00
|
|
|
driver->driver.name);
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Get the driver off the core list */
|
|
|
|
driver_unregister(&driver->driver);
|
2005-11-30 16:35:09 -08:00
|
|
|
dev_dbg(&isa_adapter.dev, "Driver %s unregistered\n", driver->driver.name);
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
static int __init i2c_isa_init(void)
|
|
|
|
{
|
2006-08-15 18:26:30 +02:00
|
|
|
int err;
|
|
|
|
|
2006-01-18 23:16:04 +01:00
|
|
|
mutex_init(&isa_adapter.clist_lock);
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
INIT_LIST_HEAD(&isa_adapter.clients);
|
|
|
|
|
|
|
|
isa_adapter.nr = ANY_I2C_ISA_BUS;
|
|
|
|
isa_adapter.dev.parent = &platform_bus;
|
|
|
|
sprintf(isa_adapter.dev.bus_id, "i2c-%d", isa_adapter.nr);
|
|
|
|
isa_adapter.dev.release = &i2c_adapter_dev_release;
|
2007-05-01 23:26:27 +02:00
|
|
|
isa_adapter.dev.class = &i2c_adapter_class;
|
2006-08-15 18:26:30 +02:00
|
|
|
err = device_register(&isa_adapter.dev);
|
|
|
|
if (err) {
|
|
|
|
printk(KERN_ERR "i2c-isa: Failed to register device\n");
|
|
|
|
goto exit;
|
|
|
|
}
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
|
|
|
|
dev_dbg(&isa_adapter.dev, "%s registered\n", isa_adapter.name);
|
|
|
|
|
|
|
|
return 0;
|
2006-08-15 18:26:30 +02:00
|
|
|
|
|
|
|
exit:
|
|
|
|
return err;
|
2005-04-16 15:20:36 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
static void __exit i2c_isa_exit(void)
|
|
|
|
{
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
#ifdef DEBUG
|
|
|
|
struct list_head *item, *_n;
|
|
|
|
struct i2c_client *client = NULL;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* There should be no more active client */
|
|
|
|
#ifdef DEBUG
|
|
|
|
dev_dbg(&isa_adapter.dev, "Looking for clients\n");
|
|
|
|
list_for_each_safe(item, _n, &isa_adapter.clients) {
|
|
|
|
client = list_entry(item, struct i2c_client, list);
|
|
|
|
dev_err(&isa_adapter.dev, "Driver %s still has an active "
|
2005-11-30 16:35:09 -08:00
|
|
|
"ISA client at 0x%x\n", client->driver->driver.name,
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
client->addr);
|
|
|
|
}
|
|
|
|
if (client != NULL)
|
|
|
|
return;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Clean up the sysfs representation */
|
|
|
|
dev_dbg(&isa_adapter.dev, "Unregistering from sysfs\n");
|
|
|
|
init_completion(&isa_adapter.dev_released);
|
|
|
|
device_unregister(&isa_adapter.dev);
|
|
|
|
|
|
|
|
/* Wait for sysfs to drop all references */
|
|
|
|
dev_dbg(&isa_adapter.dev, "Waiting for sysfs completion\n");
|
|
|
|
wait_for_completion(&isa_adapter.dev_released);
|
|
|
|
|
|
|
|
dev_dbg(&isa_adapter.dev, "%s unregistered\n", isa_adapter.name);
|
2005-04-16 15:20:36 -07:00
|
|
|
}
|
|
|
|
|
[PATCH] I2C: Separate non-i2c hwmon drivers from i2c-core (2/9)
Convert i2c-isa from a dumb i2c_adapter into a pseudo i2c-core for ISA
hardware monitoring drivers. The isa i2c_adapter is no more registered
with i2c-core, drivers have to explicitely connect to it using the new
i2c_isa_{add,del}_driver interface.
At this point, all ISA chip drivers are useless, because they still
register with i2c-core in the hope i2c-isa is registered there as well,
but it isn't anymore.
The fake bus will be named i2c-9191 in sysfs. This is the number it
already had internally in various places, so it's not exactly new,
except that now the number is seen in userspace as well. This shouldn't
be a problem until someone really has 9192 I2C busses in a given system
;)
The fake bus will no more show in "i2cdetect -l", as it won't be seen by
i2c-dev anymore (not being registered with i2c-core), which is a good
thing, as i2cdetect/i2cdump/i2cset cannot operate on this fake bus
anyway.
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2005-07-19 23:48:43 +02:00
|
|
|
EXPORT_SYMBOL(i2c_isa_add_driver);
|
|
|
|
EXPORT_SYMBOL(i2c_isa_del_driver);
|
|
|
|
|
|
|
|
MODULE_AUTHOR("Jean Delvare <khali@linux-fr.org>");
|
2005-04-16 15:20:36 -07:00
|
|
|
MODULE_DESCRIPTION("ISA bus access through i2c");
|
|
|
|
MODULE_LICENSE("GPL");
|
|
|
|
|
|
|
|
module_init(i2c_isa_init);
|
|
|
|
module_exit(i2c_isa_exit);
|