[svn-commits] kpfleming: branch kpfleming/battery_alarms r3894 - in /team/kpfleming/battery...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Thu Feb 28 07:07:46 CST 2008
Author: kpfleming
Date: Thu Feb 28 07:07:45 2008
New Revision: 3894
URL: http://svn.digium.com/view/zaptel?view=rev&rev=3894
Log:
make a branch to improve FXO port battery alarm generation code
Added:
team/kpfleming/battery_alarms/
- copied from r3893, branches/1.4/
Modified:
team/kpfleming/battery_alarms/kernel/wctdm.c
Modified: team/kpfleming/battery_alarms/kernel/wctdm.c
URL: http://svn.digium.com/view/zaptel/team/kpfleming/battery_alarms/kernel/wctdm.c?view=diff&rev=3894&r1=3893&r2=3894
==============================================================================
--- team/kpfleming/battery_alarms/kernel/wctdm.c (original)
+++ team/kpfleming/battery_alarms/kernel/wctdm.c Thu Feb 28 07:07:45 2008
@@ -251,10 +251,11 @@
/* the constants below control the 'debounce' periods enforced by the
check_hook routines; these routines are called once every 4 interrupts
- (the interrupt cycles around the four modules), so the periods are
- specified in _4 millisecond_ increments
+ (the interrupt cycles around the four modules), but each function is only performed
+ once every four cycles, so the periods are specified in _16 millisecond_ increments
*/
#define DEFAULT_BATT_DEBOUNCE 4 /* Battery debounce (64 ms) */
+#define DEFAULT_BATT_ALARM 62 /* Battery alarm debounce (992 ms) */
#define POLARITY_DEBOUNCE 4 /* Polarity debounce (64 ms) */
#define DEFAULT_BATT_THRESH 3 /* Anything under this is "no battery" */
@@ -283,6 +284,12 @@
PROSLIC_POWER_UNKNOWN = 0,
PROSLIC_POWER_ON,
PROSLIC_POWER_WARNED,
+};
+
+enum battery_state {
+ BATTERY_UNKNOWN,
+ BATTERY_PRESENT,
+ BATTERY_LOST,
};
struct wctdm {
@@ -316,8 +323,8 @@
int ringdebounce;
int offhook;
int battdebounce;
- int nobatttimer;
- int battery;
+ int battalarm;
+ enum battery_state battery;
int lastpol;
int polarity;
int polaritydebounce;
@@ -365,6 +372,7 @@
static void wctdm_release(struct wctdm *wc);
static int battdebounce = DEFAULT_BATT_DEBOUNCE;
+static int battalarm = DEFAULT_BATT_ALARM;
static int battthresh = DEFAULT_BATT_THRESH;
static int ringdebounce = DEFAULT_RING_DEBOUNCE;
static int fwringdetect = 0;
@@ -862,7 +870,8 @@
if (fwringdetect) {
res = wc->reg0shadow[card] & 0x60;
if (wc->mod[card].fxo.ringdebounce--) {
- if (res && (res != wc->mod[card].fxo.lastrdtx) && (wc->mod[card].fxo.battery == 1)) {
+ if (res && (res != wc->mod[card].fxo.lastrdtx) &&
+ (wc->mod[card].fxo.battery == BATTERY_PRESENT)) {
if (!wc->mod[card].fxo.wasringing) {
wc->mod[card].fxo.wasringing = 1;
if (debug)
@@ -879,13 +888,13 @@
zt_hooksig(&wc->chans[card], ZT_RXSIG_OFFHOOK);
}
}
- } else if (res && (wc->mod[card].fxo.battery == 1)) {
+ } else if (res && (wc->mod[card].fxo.battery == BATTERY_PRESENT)) {
wc->mod[card].fxo.lastrdtx = res;
wc->mod[card].fxo.ringdebounce = 10;
}
} else {
res = wc->reg0shadow[card];
- if ((res & 0x60) && (wc->mod[card].fxo.battery == 1)) {
+ if ((res & 0x60) && (wc->mod[card].fxo.battery == BATTERY_PRESENT)) {
wc->mod[card].fxo.ringdebounce += (ZT_CHUNKSIZE * 16);
if (wc->mod[card].fxo.ringdebounce >= ZT_CHUNKSIZE * ringdebounce) {
if (!wc->mod[card].fxo.wasringing) {
@@ -922,15 +931,15 @@
}
#endif
if (abs(b) < battthresh) {
- wc->mod[card].fxo.nobatttimer++;
#if 0
- if (wc->mod[card].fxo.battery == 1)
+ if (wc->mod[card].fxo.battery == BATTERY_PRESENT)
printk("Battery loss: %d (%d debounce)\n", b, wc->mod[card].fxo.battdebounce);
#endif
- if (wc->mod[card].fxo.battery && !wc->mod[card].fxo.battdebounce) {
+ if ((wc->mod[card].fxo.battery != BATTERY_LOST) &&
+ (wc->mod[card].fxo.battdebounce == 0)) {
if (debug)
printk("NO BATTERY on %d/%d!\n", wc->span.spanno, card + 1);
- wc->mod[card].fxo.battery = 0;
+ wc->mod[card].fxo.battery = BATTERY_LOST;
#ifdef JAPAN
if ((!wc->ohdebounce) && wc->offhook) {
zt_hooksig(&wc->chans[card], ZT_RXSIG_ONHOOK);
@@ -942,13 +951,17 @@
}
#else
zt_hooksig(&wc->chans[card], ZT_RXSIG_ONHOOK);
- zt_alarm_channel(&wc->chans[card], ZT_ALARM_RED);
+// zt_alarm_channel(&wc->chans[card], ZT_ALARM_RED);
#endif
wc->mod[card].fxo.battdebounce = battdebounce;
- } else if (!wc->mod[card].fxo.battery)
+ wc->mod[card].fxo.battalarm = battalarm;
+ } else if (wc->mod[card].fxo.battery == BATTERY_LOST) {
wc->mod[card].fxo.battdebounce = battdebounce;
+ wc->mod[card].fxo.battalarm = battalarm;
+ }
} else if (abs(b) > battthresh) {
- if ((wc->mod[card].fxo.battery < 1) && !wc->mod[card].fxo.battdebounce) {
+ if ((wc->mod[card].fxo.battery != BATTERY_PRESENT) &&
+ !wc->mod[card].fxo.battdebounce) {
if (debug)
printk("BATTERY on %d/%d (%s)!\n", wc->span.spanno, card + 1,
(b < 0) ? "-" : "+");
@@ -961,13 +974,15 @@
}
#else
zt_hooksig(&wc->chans[card], ZT_RXSIG_OFFHOOK);
- zt_alarm_channel(&wc->chans[card], ZT_ALARM_NONE);
-#endif
- wc->mod[card].fxo.battery = 1;
- wc->mod[card].fxo.nobatttimer = 0;
+// zt_alarm_channel(&wc->chans[card], ZT_ALARM_NONE);
+#endif
+ wc->mod[card].fxo.battery = BATTERY_PRESENT;
wc->mod[card].fxo.battdebounce = battdebounce;
- } else if (wc->mod[card].fxo.battery == 1)
+ wc->mod[card].fxo.battalarm = battalarm;
+ } else if (wc->mod[card].fxo.battery == BATTERY_PRESENT) {
wc->mod[card].fxo.battdebounce = battdebounce;
+ wc->mod[card].fxo.battalarm = battalarm;
+ }
if (wc->mod[card].fxo.lastpol >= 0) {
if (b < 0) {
@@ -984,9 +999,17 @@
} else {
/* It's something else... */
wc->mod[card].fxo.battdebounce = battdebounce;
- }
- if (wc->mod[card].fxo.battdebounce)
+ wc->mod[card].fxo.battalarm = battalarm;
+ }
+
+ if (wc->mod[card].fxo.battdebounce) {
wc->mod[card].fxo.battdebounce--;
+ }
+
+ if (wc->mod[card].fxo.battalarm) {
+ wc->mod[card].fxo.battalarm--;
+ }
+
if (wc->mod[card].fxo.polaritydebounce) {
wc->mod[card].fxo.polaritydebounce--;
if (wc->mod[card].fxo.polaritydebounce < 1) {
@@ -1608,7 +1631,7 @@
printk("DEBUG fxotxgain:%i.%i fxorxgain:%i.%i\n", (wctdm_getreg(wc, card, 38)/16)?-(wctdm_getreg(wc, card, 38) - 16) : wctdm_getreg(wc, card, 38), (wctdm_getreg(wc, card, 40)/16)? -(wctdm_getreg(wc, card, 40) - 16):wctdm_getreg(wc, card, 40), (wctdm_getreg(wc, card, 39)/16)? -(wctdm_getreg(wc, card, 39) - 16) : wctdm_getreg(wc, card, 39),(wctdm_getreg(wc, card, 41)/16)?-(wctdm_getreg(wc, card, 41) - 16):wctdm_getreg(wc, card, 41));
/* battery state still unknown */
- wc->mod[card].fxo.battery = -1;
+ wc->mod[card].fxo.battery = BATTERY_UNKNOWN;
return 0;
@@ -2557,6 +2580,7 @@
module_param(fastringer, int, 0600);
module_param(fxshonormode, int, 0600);
module_param(battdebounce, int, 0600);
+module_param(battalarm, int, 0600);
module_param(battthresh, int, 0600);
module_param(ringdebounce, int, 0600);
module_param(fwringdetect, int, 0600);
@@ -2579,6 +2603,7 @@
MODULE_PARM(fastringer, "i");
MODULE_PARM(fxshonormode, "i");
MODULE_PARM(battdebounce, "i");
+MODULE_PARM(battalarm, "i");
MODULE_PARM(battthresh, "i");
MODULE_PARM(ringdebounce, "i");
MODULE_PARM(fwringdetect, "i");
More information about the svn-commits
mailing list