[dahdi-commits] sruffell: linux/trunk r9580 - /linux/trunk/drivers/dahdi/dahdi_dynamic.c
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Mon Jan 3 18:26:08 UTC 2011
Author: sruffell
Date: Mon Jan 3 12:26:04 2011
New Revision: 9580
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=9580
Log:
dahdi_dynamic: Do not depend on BKL for serialization of dspan creation.
Also makes it safe to unregister a dynamic driver when there aren't any
open channels on the dynamic spans.
Signed-off-by: Shaun Ruffell <sruffell at digium.com>
Acked-by: Kinsey Moore <kmoore at digium.com>
Modified:
linux/trunk/drivers/dahdi/dahdi_dynamic.c
Modified: linux/trunk/drivers/dahdi/dahdi_dynamic.c
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/dahdi_dynamic.c?view=diff&rev=9580&r1=9579&r2=9580
==============================================================================
--- linux/trunk/drivers/dahdi/dahdi_dynamic.c (original)
+++ linux/trunk/drivers/dahdi/dahdi_dynamic.c Mon Jan 3 12:26:04 2011
@@ -90,6 +90,7 @@
static void dahdi_dynamic_tasklet(unsigned long data);
#endif
+static DEFINE_MUTEX(dspan_mutex);
static DEFINE_SPINLOCK(dspan_lock);
static DEFINE_SPINLOCK(driver_lock);
@@ -456,7 +457,7 @@
return found;
}
-static int destroy_dynamic(struct dahdi_dynamic_span *dds)
+static int _destroy_dynamic(struct dahdi_dynamic_span *dds)
{
unsigned long flags;
struct dahdi_dynamic *d;
@@ -484,6 +485,15 @@
/* ...and one for find_dynamic. */
dynamic_put(d);
return 0;
+}
+
+static int destroy_dynamic(struct dahdi_dynamic_span *dds)
+{
+ int ret;
+ mutex_lock(&dspan_mutex);
+ ret = _destroy_dynamic(dds);
+ mutex_unlock(&dspan_mutex);
+ return ret;
}
static int dahdi_dynamic_rbsbits(struct dahdi_chan *chan, int bits)
@@ -541,7 +551,7 @@
.sync_tick = dahdi_dynamic_sync_tick,
};
-static int create_dynamic(struct dahdi_dynamic_span *dds)
+static int _create_dynamic(struct dahdi_dynamic_span *dds)
{
int res = 0;
struct dahdi_dynamic *d;
@@ -671,6 +681,15 @@
module_put(dtd->owner);
return x;
+}
+
+static int create_dynamic(struct dahdi_dynamic_span *dds)
+{
+ int ret;
+ mutex_lock(&dspan_mutex);
+ ret = _create_dynamic(dds);
+ mutex_unlock(&dspan_mutex);
+ return ret;
}
#ifdef ENABLE_TASKLETS
@@ -740,6 +759,8 @@
struct dahdi_dynamic *d, *n;
unsigned long flags;
+ mutex_lock(&dspan_mutex);
+
list_for_each_entry_safe(d, n, &dspan_list, list) {
if (d->driver == dri) {
if (d->pvt) {
@@ -764,6 +785,8 @@
list_del_rcu(&dri->list);
spin_unlock_irqrestore(&driver_lock, flags);
synchronize_rcu();
+
+ mutex_unlock(&dspan_mutex);
}
EXPORT_SYMBOL(dahdi_dynamic_unregister_driver);
More information about the dahdi-commits
mailing list