[dahdi-commits] sruffell: linux/trunk r9566 - /linux/trunk/drivers/dahdi/dahdi_dynamic_loc.c

SVN commits to the DAHDI project dahdi-commits at lists.digium.com
Mon Jan 3 18:25:04 UTC 2011


Author: sruffell
Date: Mon Jan  3 12:25:00 2011
New Revision: 9566

URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=9566
Log:
dahdi_dynamic_loc: Do not call dahdi_dynamic_receive on peers before reg.

It's possible for dahdi_dynamic_loc spans to be "peered" before the
dahdi_span is fully register.  Do not call dahdi_dynamic_receive on any
peers before they are fully registered.

Signed-off-by: Shaun Ruffell <sruffell at digium.com>
Acked-by: Kinsey Moore <kmoore at digium.com>

Modified:
    linux/trunk/drivers/dahdi/dahdi_dynamic_loc.c

Modified: linux/trunk/drivers/dahdi/dahdi_dynamic_loc.c
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/dahdi_dynamic_loc.c?view=diff&rev=9566&r1=9565&r2=9566
==============================================================================
--- linux/trunk/drivers/dahdi/dahdi_dynamic_loc.c (original)
+++ linux/trunk/drivers/dahdi/dahdi_dynamic_loc.c Mon Jan  3 12:25:00 2011
@@ -82,10 +82,17 @@
 	unsigned long flags;
 
 	spin_lock_irqsave(&local_lock, flags);
-	if (d->peer && d->peer->span)
-		dahdi_dynamic_receive(d->peer->span, msg, msglen);
-	if (d->monitor_rx_peer && d->monitor_rx_peer->span)
-		dahdi_dynamic_receive(d->monitor_rx_peer->span, msg, msglen);
+	if (d->peer && d->peer->span) {
+		if (test_bit(DAHDI_FLAGBIT_REGISTERED, &d->peer->span->flags))
+			dahdi_dynamic_receive(d->peer->span, msg, msglen);
+	}
+	if (d->monitor_rx_peer && d->monitor_rx_peer->span) {
+		if (test_bit(DAHDI_FLAGBIT_REGISTERED,
+			     &d->monitor_rx_peer->span->flags))  {
+			dahdi_dynamic_receive(d->monitor_rx_peer->span,
+					      msg, msglen);
+		}
+	}
 	spin_unlock_irqrestore(&local_lock, flags);
 	return 0;
 }




More information about the dahdi-commits mailing list