diff options
-rwxr-xr-x | zaptel.c | 8 | ||||
-rwxr-xr-x | zaptel.h | 3 |
2 files changed, 8 insertions, 3 deletions
@@ -5242,10 +5242,14 @@ static void __zt_hooksig_pvt(struct zt_chan *chan, zt_rxsig_t rxsig) if (chan->txstate != ZT_TXSTATE_OFFHOOK) break; #ifdef FXSFLASH if (rxsig == ZT_RXSIG_ONHOOK) { - chan->itimer = ZT_FXSFLASHTIME * ZT_CHUNKSIZE; + chan->itimer = ZT_FXSFLASHMAXTIME * ZT_CHUNKSIZE; break; } else if (rxsig == ZT_RXSIG_OFFHOOK) { - if (chan->itimer) __qevent(chan, ZT_EVENT_WINKFLASH); + if (chan->itimer) { + /* did the offhook occur in the window? if not, ignore both events */ + if (chan->itimer <= ((ZT_FXSFLASHMAXTIME - ZTFXSFLASHMINTIME) * ZT_CHUNKSIZE)) + __qevent(chan, ZT_EVENT_WINKFLASH); + } chan->itimer = 0; break; } @@ -906,7 +906,8 @@ struct zt_tone_def { /* Structure for zone programming */ #define ZT_MAX_CONF 1024 /* Max, 1024 conferences */ #ifdef FXSFLASH -#define ZT_FXSFLASHTIME 550 /* max 550ms */ +#define ZT_FXSFLASHMINTIME 450 /* min 450ms */ +#define ZT_FXSFLASHMAXTIME 550 /* max 550ms */ #endif #ifdef __KERNEL__ |