[dahdi-commits] sruffell: linux/trunk r10110 - /linux/trunk/drivers/dahdi/dahdi_dynamic.c
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Wed Aug 10 14:22:04 CDT 2011
Author: sruffell
Date: Wed Aug 10 14:22:01 2011
New Revision: 10110
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=10110
Log:
dahdi_dynamic: Call dahdi_receive in rx packet handler.
Currently dahdi_receive is called on all channels in the context of the
master dynamic span. If one span (not the master) receive two packets
before the master span received a packet, the older packet on the
dynamic span would end up lost because the "readchunk" for the
channels would be overwritten by the new packet. DAHLIN-245
Signed-off-by: Wagner Gegler <wagner at aligera.com.br> (License #6268)
Changed dahdi_ec_chunk to dahdi_ec_span.
Signed-off-by: Shaun Ruffell <sruffell 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=10110&r1=10109&r2=10110
==============================================================================
--- linux/trunk/drivers/dahdi/dahdi_dynamic.c (original)
+++ linux/trunk/drivers/dahdi/dahdi_dynamic.c Wed Aug 10 14:22:01 2011
@@ -200,16 +200,9 @@
{
struct dahdi_dynamic *d;
struct dahdi_dynamic_driver *drv;
- int y;
rcu_read_lock();
list_for_each_entry_rcu(d, &dspan_list, list) {
- for (y = 0; y < d->span.channels; y++) {
- struct dahdi_chan *const c = d->span.chans[y];
- /* Echo cancel double buffered data */
- dahdi_ec_chunk(c, c->readchunk, c->writechunk);
- }
- dahdi_receive(&d->span);
dahdi_transmit(&d->span);
/* Handle all transmissions now */
dahdi_dynamic_sendmessage(d);
@@ -369,6 +362,9 @@
/* note if we had a missing packet */
if (unlikely(rxpos != rxcnt))
printk(KERN_NOTICE "Span %s: Expected seq no %d, but received %d instead\n", span->name, rxcnt, rxpos);
+
+ dahdi_ec_span(span);
+ dahdi_receive(span);
/* If this is our master span, then run everything */
if (master)
More information about the dahdi-commits
mailing list