[dahdi-commits] fjoe: freebsd/trunk r7801 - /freebsd/trunk/drivers/dahdi/dahdi_dynamic.c

SVN commits to the DAHDI project dahdi-commits at lists.digium.com
Sat Jan 9 17:16:01 CST 2010


Author: fjoe
Date: Sat Jan  9 17:15:58 2010
New Revision: 7801

URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=7801
Log:
Fix lock recursion.

Modified:
    freebsd/trunk/drivers/dahdi/dahdi_dynamic.c

Modified: freebsd/trunk/drivers/dahdi/dahdi_dynamic.c
URL: http://svnview.digium.com/svn/dahdi/freebsd/trunk/drivers/dahdi/dahdi_dynamic.c?view=diff&rev=7801&r1=7800&r2=7801
==============================================================================
--- freebsd/trunk/drivers/dahdi/dahdi_dynamic.c (original)
+++ freebsd/trunk/drivers/dahdi/dahdi_dynamic.c Sat Jan  9 17:15:58 2010
@@ -34,6 +34,26 @@
 #include <sys/taskqueue.h>
 
 #include <machine/stdarg.h>
+
+#if 0
+static void
+rlprintf(int pps, const char *fmt, ...)
+	__printflike(2, 3);
+
+static void
+rlprintf(int pps, const char *fmt, ...)
+{
+	va_list ap;
+	static struct timeval last_printf;
+	static int count;
+
+	if (ppsratecheck(&last_printf, &count, pps)) {
+		va_start(ap, fmt);
+		vprintf(fmt, ap);
+		va_end(ap);
+	}
+}
+#endif
 #else /* !__FreeBSD__ */
 #include <linux/kernel.h>
 #include <linux/errno.h>
@@ -902,9 +922,11 @@
 				zp->next = z->next;
 			else
 				dspans = z->next;
-			if (!z->usecount)
+			if (!z->usecount) {
+				spin_unlock_irqrestore(&dlock, flags);
 				dynamic_destroy(z);
-			else
+				spin_lock_irqsave(&dlock, flags);
+			} else
 				z->dead = 1;
 		} else {
 			zp = z;




More information about the dahdi-commits mailing list