freetdm: Fix SS7 ISUP T10 (Overlap digit timeout) - issue #1445

This commit is contained in:
Moises Silva 2011-09-28 19:15:35 -04:00
parent 1aad77a0d3
commit b828442052
5 changed files with 87 additions and 19 deletions

View File

@ -405,6 +405,8 @@ ftdm_status_t handle_con_sta(uint32_t suInstId, uint32_t spInstId, uint32_t circ
append_tknStr_from_sngss7(siCnStEvnt->subNum.addrSig, append_tknStr_from_sngss7(siCnStEvnt->subNum.addrSig,
ftdmchan->caller_data.dnis.digits, ftdmchan->caller_data.dnis.digits,
siCnStEvnt->subNum.oddEven); siCnStEvnt->subNum.oddEven);
SS7_DEBUG_CHAN(ftdmchan,"[CIC:%d]Rx SAM (digits = %s)\n", sngss7_info->circuit->cic,
ftdmchan->caller_data.dnis.digits);
} else { } else {
SS7_INFO_CHAN(ftdmchan,"No Called party (DNIS) information in SAM!%s\n", " "); SS7_INFO_CHAN(ftdmchan,"No Called party (DNIS) information in SAM!%s\n", " ");
} }

View File

@ -592,6 +592,11 @@ ftdm_status_t ftdm_sangoma_ss7_process_state_change (ftdm_channel_t * ftdmchan)
i++; i++;
} }
/* kill t10 if active */
if (sngss7_info->t10.hb_timer_id) {
ftdm_sched_cancel_timer (sngss7_info->t10.sched, sngss7_info->t10.hb_timer_id);
}
/* check if the end of pulsing (ST) character has arrived or the right number of digits */ /* check if the end of pulsing (ST) character has arrived or the right number of digits */
if (ftdmchan->caller_data.dnis.digits[i-1] == 'F') { if (ftdmchan->caller_data.dnis.digits[i-1] == 'F') {
SS7_DEBUG_CHAN(ftdmchan, "Received the end of pulsing character %s\n", ""); SS7_DEBUG_CHAN(ftdmchan, "Received the end of pulsing character %s\n", "");
@ -613,7 +618,7 @@ ftdm_status_t ftdm_sangoma_ss7_process_state_change (ftdm_channel_t * ftdmchan)
} else { } else {
/* if we are coming from idle state then we have already been here once before */ /* if we are coming from idle state then we have already been here once before */
if (ftdmchan->last_state != FTDM_CHANNEL_STATE_IDLE) { if (ftdmchan->last_state != FTDM_CHANNEL_STATE_IDLE) {
SS7_INFO_CHAN(ftdmchan,"Received %d out of %d so far: %s...starting T35\n", SS7_INFO_CHAN(ftdmchan, "Received %d out of %d so far: %s...starting T35\n",
i, i,
sngss7_info->circuit->min_digits, sngss7_info->circuit->min_digits,
ftdmchan->caller_data.dnis.digits); ftdmchan->caller_data.dnis.digits);
@ -628,7 +633,7 @@ ftdm_status_t ftdm_sangoma_ss7_process_state_change (ftdm_channel_t * ftdmchan)
SS7_ERROR ("Unable to schedule timer, hanging up call!\n"); SS7_ERROR ("Unable to schedule timer, hanging up call!\n");
ftdmchan->caller_data.hangup_cause = 41; ftdmchan->caller_data.hangup_cause = FTDM_CAUSE_NORMAL_TEMPORARY_FAILURE;
/* set the flag to indicate this hangup is started from the local side */ /* set the flag to indicate this hangup is started from the local side */
sngss7_set_ckt_flag (sngss7_info, FLAG_LOCAL_REL); sngss7_set_ckt_flag (sngss7_info, FLAG_LOCAL_REL);
@ -636,9 +641,29 @@ ftdm_status_t ftdm_sangoma_ss7_process_state_change (ftdm_channel_t * ftdmchan)
/* end the call */ /* end the call */
state_flag = 0; state_flag = 0;
ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_CANCEL); ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_CANCEL);
} /* if (ftdm_sched_timer(sngss7_info->t35.sched, */ }
} /* if (ftdmchan->last_state != FTDM_CHANNEL_STATE_IDLE) */ }
} /* checking ST/#digits */
/* start ISUP t10 */
if (ftdm_sched_timer (sngss7_info->t10.sched,
"t10",
sngss7_info->t10.beat,
sngss7_info->t10.callback,
&sngss7_info->t10,
&sngss7_info->t10.hb_timer_id)) {
SS7_ERROR ("Unable to schedule timer, hanging up call!\n");
ftdmchan->caller_data.hangup_cause = FTDM_CAUSE_NORMAL_TEMPORARY_FAILURE;
/* set the flag to indicate this hangup is started from the local side */
sngss7_set_ckt_flag (sngss7_info, FLAG_LOCAL_REL);
/* end the call */
state_flag = 0;
ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_CANCEL);
}
}
break; break;

View File

@ -288,7 +288,6 @@ typedef struct sng_isup_intf {
uint32_t ssf; uint32_t ssf;
uint32_t isap; uint32_t isap;
uint16_t t4; uint16_t t4;
uint32_t t10;
uint32_t t11; uint32_t t11;
uint32_t t18; uint32_t t18;
uint32_t t19; uint32_t t19;
@ -344,6 +343,7 @@ typedef struct sng_isup_ckt {
uint8_t transparent_iam; uint8_t transparent_iam;
void *obj; void *obj;
uint16_t t3; uint16_t t3;
uint32_t t10;
uint16_t t12; uint16_t t12;
uint16_t t13; uint16_t t13;
uint16_t t14; uint16_t t14;
@ -471,6 +471,7 @@ typedef struct sngss7_chan_data {
void *raw_data; /* send on next sigevent */ void *raw_data; /* send on next sigevent */
sngss7_glare_data_t glare; sngss7_glare_data_t glare;
sngss7_timer_data_t t35; sngss7_timer_data_t t35;
sngss7_timer_data_t t10;
sngss7_group_data_t rx_grs; sngss7_group_data_t rx_grs;
sngss7_group_data_t rx_gra; sngss7_group_data_t rx_gra;
sngss7_group_data_t tx_grs; sngss7_group_data_t tx_grs;
@ -887,6 +888,7 @@ ftdm_status_t sngss7_add_raw_data(sngss7_chan_data_t *sngss7_info, uint8_t* data
/* in ftmod_sangoma_ss7_timers.c */ /* in ftmod_sangoma_ss7_timers.c */
void handle_isup_t35(void *userdata); void handle_isup_t35(void *userdata);
void handle_isup_t10(void *userdata);
/******************************************************************************/ /******************************************************************************/

View File

@ -1,5 +1,6 @@
/* /*
* Copyright (c) 2009, Konrad Hammel <konrad@sangoma.com> * Copyright (c) 2009, Sangoma Technologies
* Konrad Hammel <konrad@sangoma.com>
* All rights reserved. * All rights reserved.
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
@ -29,6 +30,11 @@
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* Contributors:
*
* Moises Silva <moy@sangoma.com>
*
*/ */
/* INCLUDE ********************************************************************/ /* INCLUDE ********************************************************************/
@ -70,12 +76,39 @@ void handle_isup_t35(void *userdata)
/* end the call */ /* end the call */
ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_CANCEL); ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_CANCEL);
/* kill t10 if active */
if (sngss7_info->t10.hb_timer_id) {
ftdm_sched_cancel_timer (sngss7_info->t10.sched, sngss7_info->t10.hb_timer_id);
}
/*unlock*/ /*unlock*/
ftdm_channel_unlock(ftdmchan); ftdm_channel_unlock(ftdmchan);
SS7_FUNC_TRACE_EXIT(__FUNCTION__); SS7_FUNC_TRACE_EXIT(__FUNCTION__);
return; return;
} }
void handle_isup_t10(void *userdata)
{
SS7_FUNC_TRACE_ENTER(__FUNCTION__);
sngss7_timer_data_t *timer = userdata;
sngss7_chan_data_t *sngss7_info = timer->sngss7_info;
ftdm_channel_t *ftdmchan = sngss7_info->ftdmchan;
ftdm_channel_lock(ftdmchan);
SS7_DEBUG("[Call-Control] Timer 10 expired on CIC = %d\n", sngss7_info->circuit->cic);
/* send the call to the user */
ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_RING);
ftdm_channel_unlock(ftdmchan);
SS7_FUNC_TRACE_EXIT(__FUNCTION__);
}
/******************************************************************************/ /******************************************************************************/
/* For Emacs: /* For Emacs:
* Local Variables: * Local Variables:

View File

@ -127,6 +127,7 @@ typedef struct sng_ccSpan
uint8_t itx_auto_reply; uint8_t itx_auto_reply;
uint8_t transparent_iam; uint8_t transparent_iam;
uint32_t t3; uint32_t t3;
uint32_t t10;
uint32_t t12; uint32_t t12;
uint32_t t13; uint32_t t13;
uint32_t t14; uint32_t t14;
@ -1570,11 +1571,6 @@ static int ftmod_ss7_parse_isup_interface(ftdm_conf_node_t *isup_interface)
sng_isap.t9 = atoi(parm->val); sng_isap.t9 = atoi(parm->val);
SS7_DEBUG("Found isup t9 = %d\n",sng_isap.t9); SS7_DEBUG("Found isup t9 = %d\n",sng_isap.t9);
/**********************************************************************/ /**********************************************************************/
} else if (!strcasecmp(parm->var, "isup.t10")) {
/**********************************************************************/
sng_isup.t10 = atoi(parm->val);
SS7_DEBUG("Found isup t10 = %d\n",sng_isup.t10);
/**********************************************************************/
} else if (!strcasecmp(parm->var, "isup.t11")) { } else if (!strcasecmp(parm->var, "isup.t11")) {
/**********************************************************************/ /**********************************************************************/
sng_isup.t11 = atoi(parm->val); sng_isup.t11 = atoi(parm->val);
@ -1965,6 +1961,10 @@ static int ftmod_ss7_parse_cc_span(ftdm_conf_node_t *cc_span)
/**********************************************************************/ /**********************************************************************/
sng_ccSpan.t3 = atoi(parm->val); sng_ccSpan.t3 = atoi(parm->val);
SS7_DEBUG("Found isup t3 = %d\n", sng_ccSpan.t3); SS7_DEBUG("Found isup t3 = %d\n", sng_ccSpan.t3);
} else if (!strcasecmp(parm->var, "isup.t10")) {
/**********************************************************************/
sng_ccSpan.t10 = atoi(parm->val);
SS7_DEBUG("Found isup t10 = %d\n", sng_ccSpan.t10);
/**********************************************************************/ /**********************************************************************/
} else if (!strcasecmp(parm->var, "isup.t12")) { } else if (!strcasecmp(parm->var, "isup.t12")) {
/**********************************************************************/ /**********************************************************************/
@ -2584,11 +2584,6 @@ static int ftmod_ss7_fill_in_isup_interface(sng_isup_inf_t *sng_isup)
} else { } else {
g_ftdm_sngss7_data.cfg.isupIntf[i].t4 = 3000; g_ftdm_sngss7_data.cfg.isupIntf[i].t4 = 3000;
} }
if (sng_isup->t10 != 0) {
g_ftdm_sngss7_data.cfg.isupIntf[i].t10 = sng_isup->t10;
} else {
g_ftdm_sngss7_data.cfg.isupIntf[i].t10 = 50;
}
if (sng_isup->t11 != 0) { if (sng_isup->t11 != 0) {
g_ftdm_sngss7_data.cfg.isupIntf[i].t11 = sng_isup->t11; g_ftdm_sngss7_data.cfg.isupIntf[i].t11 = sng_isup->t11;
} else { } else {
@ -2935,6 +2930,11 @@ static int ftmod_ss7_fill_in_ccSpan(sng_ccSpan_t *ccSpan)
} else { } else {
g_ftdm_sngss7_data.cfg.isupCkt[x].t3 = ccSpan->t3; g_ftdm_sngss7_data.cfg.isupCkt[x].t3 = ccSpan->t3;
} }
if (ccSpan->t10 == 0) {
g_ftdm_sngss7_data.cfg.isupCkt[x].t10 = 50;
} else {
g_ftdm_sngss7_data.cfg.isupCkt[x].t10 = ccSpan->t10;
}
if (ccSpan->t12 == 0) { if (ccSpan->t12 == 0) {
g_ftdm_sngss7_data.cfg.isupCkt[x].t12 = 300; g_ftdm_sngss7_data.cfg.isupCkt[x].t12 = 300;
} else { } else {
@ -3069,6 +3069,12 @@ static int ftmod_ss7_fill_in_circuits(sng_span_t *sngSpan)
ss7_info->t35.callback = handle_isup_t35; ss7_info->t35.callback = handle_isup_t35;
ss7_info->t35.sngss7_info = ss7_info; ss7_info->t35.sngss7_info = ss7_info;
ss7_info->t10.sched = ((sngss7_span_data_t *)(ftdmspan->signal_data))->sched;
ss7_info->t10.counter = 1;
ss7_info->t10.beat = (isupCkt->t10) * 100; /* beat is in ms, t10 is in 100ms */
ss7_info->t10.callback = handle_isup_t10;
ss7_info->t10.sngss7_info = ss7_info;
/**************************************************************************/ /**************************************************************************/
} /* for (i == 1; i < ftdmspan->chan_count; i++) */ } /* for (i == 1; i < ftdmspan->chan_count; i++) */