|
@@ -97,20 +97,17 @@ void cx231xx_add_into_devlist(struct cx231xx *dev)
|
|
|
};
|
|
|
|
|
|
static LIST_HEAD(cx231xx_extension_devlist);
|
|
|
-static DEFINE_MUTEX(cx231xx_extension_devlist_lock);
|
|
|
|
|
|
int cx231xx_register_extension(struct cx231xx_ops *ops)
|
|
|
{
|
|
|
struct cx231xx *dev = NULL;
|
|
|
|
|
|
mutex_lock(&cx231xx_devlist_mutex);
|
|
|
- mutex_lock(&cx231xx_extension_devlist_lock);
|
|
|
list_add_tail(&ops->next, &cx231xx_extension_devlist);
|
|
|
list_for_each_entry(dev, &cx231xx_devlist, devlist)
|
|
|
ops->init(dev);
|
|
|
|
|
|
printk(KERN_INFO DRIVER_NAME ": %s initialized\n", ops->name);
|
|
|
- mutex_unlock(&cx231xx_extension_devlist_lock);
|
|
|
mutex_unlock(&cx231xx_devlist_mutex);
|
|
|
return 0;
|
|
|
}
|
|
@@ -125,10 +122,8 @@ void cx231xx_unregister_extension(struct cx231xx_ops *ops)
|
|
|
ops->fini(dev);
|
|
|
|
|
|
|
|
|
- mutex_lock(&cx231xx_extension_devlist_lock);
|
|
|
printk(KERN_INFO DRIVER_NAME ": %s removed\n", ops->name);
|
|
|
list_del(&ops->next);
|
|
|
- mutex_unlock(&cx231xx_extension_devlist_lock);
|
|
|
mutex_unlock(&cx231xx_devlist_mutex);
|
|
|
}
|
|
|
EXPORT_SYMBOL(cx231xx_unregister_extension);
|
|
@@ -137,28 +132,28 @@ void cx231xx_init_extension(struct cx231xx *dev)
|
|
|
{
|
|
|
struct cx231xx_ops *ops = NULL;
|
|
|
|
|
|
- mutex_lock(&cx231xx_extension_devlist_lock);
|
|
|
+ mutex_lock(&cx231xx_devlist_mutex);
|
|
|
if (!list_empty(&cx231xx_extension_devlist)) {
|
|
|
list_for_each_entry(ops, &cx231xx_extension_devlist, next) {
|
|
|
if (ops->init)
|
|
|
ops->init(dev);
|
|
|
}
|
|
|
}
|
|
|
- mutex_unlock(&cx231xx_extension_devlist_lock);
|
|
|
+ mutex_unlock(&cx231xx_devlist_mutex);
|
|
|
}
|
|
|
|
|
|
void cx231xx_close_extension(struct cx231xx *dev)
|
|
|
{
|
|
|
struct cx231xx_ops *ops = NULL;
|
|
|
|
|
|
- mutex_lock(&cx231xx_extension_devlist_lock);
|
|
|
+ mutex_lock(&cx231xx_devlist_mutex);
|
|
|
if (!list_empty(&cx231xx_extension_devlist)) {
|
|
|
list_for_each_entry(ops, &cx231xx_extension_devlist, next) {
|
|
|
if (ops->fini)
|
|
|
ops->fini(dev);
|
|
|
}
|
|
|
}
|
|
|
- mutex_unlock(&cx231xx_extension_devlist_lock);
|
|
|
+ mutex_unlock(&cx231xx_devlist_mutex);
|
|
|
}
|
|
|
|
|
|
/****************************************************************
|