[svn-commits] tzafrir: trunk r1381 - in /trunk/xpp: card_fxo.c
card_fxo.h init_data_4_20.cmd
svn-commits at lists.digium.com
svn-commits at lists.digium.com
Sat Sep 2 14:36:25 MST 2006
Author: tzafrir
Date: Sat Sep 2 16:36:25 2006
New Revision: 1381
URL: http://svn.digium.com/view/zaptel?rev=1381&view=rev
Log:
Fix problems with battery voltage fluctuations:
- Use a higher voltage.
- Add a software debounce counter.
Modified:
trunk/xpp/card_fxo.c
trunk/xpp/card_fxo.h
trunk/xpp/init_data_4_20.cmd
Modified: trunk/xpp/card_fxo.c
URL: http://svn.digium.com/view/zaptel/trunk/xpp/card_fxo.c?rev=1381&r1=1380&r2=1381&view=diff
==============================================================================
--- trunk/xpp/card_fxo.c (original)
+++ trunk/xpp/card_fxo.c Sat Sep 2 16:36:25 2006
@@ -51,6 +51,9 @@
#define NUM_LEDS 1
#define DELAY_UNTIL_DIALTONE 3000
+#define BAT_THRESHOLD 3
+#define BAT_DEBOUNCE 3 /* compensate for battery voltage fluctuation (in poll_battery_interval's) */
+
/*---------------- FXO Protocol Commands ----------------------------------*/
static /* 0x0F */ DECLARE_CMD(FXO, CHAN_ENABLE, xpp_line_t lines, bool on);
@@ -83,6 +86,7 @@
slic_reply_t requested_reply;
slic_reply_t last_reply;
xpp_line_t battery;
+ ushort battery_debounce[CHANNELS_PERXPD];
xpp_line_t ledstate[NUM_LEDS]; /* 0 - OFF, 1 - ON */
xpp_line_t ledcontrol[NUM_LEDS]; /* 0 - OFF, 1 - ON */
int blinking[NUM_LEDS][CHANNELS_PERXPD];
@@ -699,22 +703,28 @@
priv = xpd->priv;
BUG_ON(!priv);
if(!info->indirect && info->reg_num == DAA_VBAT_REGISTER) {
- xpp_line_t last_batt_on = priv->battery;
- xpp_line_t changed_lines;
- signed char bat = info->data_low;
+ byte bat = abs((signed char)info->data_low);
int i;
- if(abs(bat) < BAT_THRESHOLD) {
- priv->battery &= ~lines;
- // DBG("%s/%s: BATTERY OFF (%04X) = %d\n", xpd->xbus->busname, xpd->xpdname, lines, bat);
- } else {
- priv->battery |= lines;
- // DBG("%s/%s: BATTERY ON (%04X) = %d\n", xpd->xbus->busname, xpd->xpdname, lines, bat);
- }
- changed_lines = last_batt_on ^ priv->battery;
for_each_line(xpd, i) {
- if(IS_SET(changed_lines, i)) {
- update_line_status(xpd, i, IS_SET(priv->battery, i));
+ if(!IS_SET(lines, i))
+ continue;
+ if(bat < BAT_THRESHOLD) {
+ /*
+ * Check for battery voltage fluctuations
+ */
+ if(IS_SET(priv->battery, i) && priv->battery_debounce[i]++ > BAT_DEBOUNCE) {
+ DBG("%s/%s: BATTERY OFF (%04X) voltage=%d\n", xpd->xbus->busname, xpd->xpdname, lines, bat);
+ priv->battery &= ~lines;
+ update_line_status(xpd, i, 0);
+ }
+ } else {
+ priv->battery_debounce[i] = 0;
+ if(!IS_SET(priv->battery, i)) {
+ DBG("%s/%s: BATTERY ON (%04X) voltage=%d\n", xpd->xbus->busname, xpd->xpdname, lines, bat);
+ priv->battery |= lines;
+ update_line_status(xpd, i, 1);
+ }
}
}
}
@@ -824,38 +834,42 @@
len += sprintf(page + len, "\t%-17s: ", "Channel");
for_each_line(xpd, i) {
if(!IS_SET(xpd->digital_outputs, i) && !IS_SET(xpd->digital_inputs, i))
- len += sprintf(page + len, "%d ", i % 10);
+ len += sprintf(page + len, "%2d ", i % 10);
}
len += sprintf(page + len, "\n\t%-17s: ", "ledstate");
for_each_line(xpd, i) {
if(!IS_SET(xpd->digital_outputs, i) && !IS_SET(xpd->digital_inputs, i))
- len += sprintf(page + len, "%d ", IS_SET(priv->ledstate[LED_GREEN], i));
+ len += sprintf(page + len, "%2d ", IS_SET(priv->ledstate[LED_GREEN], i));
}
len += sprintf(page + len, "\n\t%-17s: ", "ledcontrol");
for_each_line(xpd, i) {
if(!IS_SET(xpd->digital_outputs, i) && !IS_SET(xpd->digital_inputs, i))
- len += sprintf(page + len, "%d ", IS_SET(priv->ledcontrol[LED_GREEN], i));
+ len += sprintf(page + len, "%2d ", IS_SET(priv->ledcontrol[LED_GREEN], i));
}
len += sprintf(page + len, "\n\t%-17s: ", "blinking");
for_each_line(xpd, i) {
if(!IS_SET(xpd->digital_outputs, i) && !IS_SET(xpd->digital_inputs, i))
- len += sprintf(page + len, "%d ", IS_BLINKING(priv,i,LED_GREEN));
+ len += sprintf(page + len, "%2d ", IS_BLINKING(priv,i,LED_GREEN));
}
#ifdef SOFT_RING
len += sprintf(page + len, "\n\t%-17s: ", "ring_thresh");
for_each_line(xpd, i) {
if(!IS_SET(xpd->digital_outputs, i) && !IS_SET(xpd->digital_inputs, i))
- len += sprintf(page + len, "%d ", priv->ring_thresh[i]);
+ len += sprintf(page + len, "%2d ", priv->ring_thresh[i]);
}
len += sprintf(page + len, "\n\t%-17s: ", "noring_thresh");
for_each_line(xpd, i) {
if(!IS_SET(xpd->digital_outputs, i) && !IS_SET(xpd->digital_inputs, i))
- len += sprintf(page + len, "%d ", priv->noring_thresh[i]);
+ len += sprintf(page + len, "%2d ", priv->noring_thresh[i]);
}
#endif
len += sprintf(page + len, "\n\t%-17s: ", "battery");
for_each_line(xpd, i) {
- len += sprintf(page + len, "%d ", IS_SET(priv->battery, i));
+ len += sprintf(page + len, "%2d ", IS_SET(priv->battery, i));
+ }
+ len += sprintf(page + len, "\n\t%-17s: ", "battery_debounce");
+ for_each_line(xpd, i) {
+ len += sprintf(page + len, "%2d ", priv->battery_debounce[i]);
}
len += sprintf(page + len, "\n");
spin_unlock_irqrestore(&xpd->lock, flags);
Modified: trunk/xpp/card_fxo.h
URL: http://svn.digium.com/view/zaptel/trunk/xpp/card_fxo.h?rev=1381&r1=1380&r2=1381&view=diff
==============================================================================
--- trunk/xpp/card_fxo.h (original)
+++ trunk/xpp/card_fxo.h Sat Sep 2 16:36:25 2006
@@ -56,6 +56,5 @@
);
#define DAA_VBAT_REGISTER 29
-#define BAT_THRESHOLD 3
#endif /* CARD_FXO_H */
Modified: trunk/xpp/init_data_4_20.cmd
URL: http://svn.digium.com/view/zaptel/trunk/xpp/init_data_4_20.cmd?rev=1381&r1=1380&r2=1381&view=diff
==============================================================================
--- trunk/xpp/init_data_4_20.cmd (original)
+++ trunk/xpp/init_data_4_20.cmd Sat Sep 2 16:36:25 2006
@@ -58,3 +58,7 @@
; ----------- DAA ONHOOK --------------------
FF FF 00 00 WD 05 08
+
+; Set tip to ring voltage to 3.5 volts while off-hook
+; instead of default of 3.1
+FF FF 00 00 WD 1A C0
More information about the svn-commits
mailing list