[dahdi-commits] dahdi/linux.git branch "master" updated.
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Tue May 14 12:24:39 CDT 2013
branch "master" has been updated
via a3ad32c370dac9fb8d196db7f4d53e2a3f59d1ba (commit)
via 9a7db0943b5402a92069ac8857fd1a3b1a0d6979 (commit)
from db040e5cd7004e6aad4074908f314235a4fc316d (commit)
Summary of changes:
drivers/dahdi/dahdi-base.c | 2 +-
drivers/dahdi/wcte12xp/base.c | 13 +++++++++----
2 files changed, 10 insertions(+), 5 deletions(-)
- Log -----------------------------------------------------------------
commit a3ad32c370dac9fb8d196db7f4d53e2a3f59d1ba
Author: Shaun Ruffell <sruffell at digium.com>
Date: Fri May 10 14:24:11 2013 -0500
dahdi: Prevent potential error when only switching spantype of single span.
If you have a multiple span system configured for t1 mode, and you try to change
only the first span from t1 to e1 via sysfs, you could get an error in the
kernel log about trying to create duplicate channel.
The problem is that the check for whether there was enough room for the all the
channels of the switched span was wrong.
Reported-by: James Brown <jbrown at digium.com>
Signed-off-by: Shaun Ruffell <sruffell at digium.com>
Signed-off-by: Russ Meyerriecks <rmeyerriecks at digium.com>
diff --git a/drivers/dahdi/dahdi-base.c b/drivers/dahdi/dahdi-base.c
index a3540d1..dda06ef 100644
--- a/drivers/dahdi/dahdi-base.c
+++ b/drivers/dahdi/dahdi-base.c
@@ -7018,7 +7018,7 @@ static int _assign_spanno_and_basechan(struct dahdi_span *span)
}
next_channo = _get_next_channo(pos);
- if ((basechan + span->channels) >= next_channo)
+ if ((basechan + span->channels) <= next_channo)
break;
/* We can't fit here, let's look at the next location. */
commit 9a7db0943b5402a92069ac8857fd1a3b1a0d6979
Author: Shaun Ruffell <sruffell at digium.com>
Date: Thu May 9 15:10:11 2013 -0500
wcte12xp: Look for multiple loopup codes before setting looping up the framer.
This brings the wcte12xp driver in line with the wct4xxp driver. It also
eliminates the chance that the local side will errouneously go into loopup when
switched from E1 to T1 mode via the spantype sysfs attribute.
Internal-Issue-ID: DAHDI-1038
Signed-off-by: Shaun Ruffell <sruffell at digium.com>
Signed-off-by: Russ Meyerriecks <rmeyerriecks at digium.com>
diff --git a/drivers/dahdi/wcte12xp/base.c b/drivers/dahdi/wcte12xp/base.c
index 18f1129..22bd450 100644
--- a/drivers/dahdi/wcte12xp/base.c
+++ b/drivers/dahdi/wcte12xp/base.c
@@ -2206,27 +2206,32 @@ static void t1_check_alarms(struct t1 *wc)
/* Detect loopup code if we're not sending one */
if ((!wc->span.mainttimer) && (d & 0x08)) {
/* Loop-up code detected */
- if ((wc->span.maintstat != DAHDI_MAINT_REMOTELOOP)) {
+ if ((++wc->loopupcnt > 80) &&
+ (wc->span.maintstat != DAHDI_MAINT_REMOTELOOP)) {
t1_notice(wc, "Loopup detected,"\
" enabling remote loop\n");
t1_setreg(wc, 0x36, 0x08); /* LIM0: Disable any local loop */
t1_setreg(wc, 0x37, 0xf6); /* LIM1: Enable remote loop */
wc->span.maintstat = DAHDI_MAINT_REMOTELOOP;
}
- } else
+ } else {
wc->loopupcnt = 0;
+ }
+
/* Same for loopdown code */
if ((!wc->span.mainttimer) && (d & 0x10)) {
/* Loop-down code detected */
- if ((wc->span.maintstat == DAHDI_MAINT_REMOTELOOP)) {
+ if ((++wc->loopdowncnt > 80) &&
+ (wc->span.maintstat == DAHDI_MAINT_REMOTELOOP)) {
t1_notice(wc, "Loopdown detected,"\
" disabling remote loop\n");
t1_setreg(wc, 0x36, 0x08); /* LIM0: Disable any local loop */
t1_setreg(wc, 0x37, 0xf0); /* LIM1: Disable remote loop */
wc->span.maintstat = DAHDI_MAINT_NONE;
}
- } else
+ } else {
wc->loopdowncnt = 0;
+ }
}
if (wc->span.lineconfig & DAHDI_CONFIG_NOTOPEN) {
-----------------------------------------------------------------------
--
dahdi/linux.git
More information about the dahdi-commits
mailing list