}
sngisdn_info->suInstId = get_unique_suInstId(suId);
- sngisdn_info->spInstId = spInstId;
+ sngisdn_info->spInstId = spInstId;
/* If this is a glared call that was previously saved, we moved
all the info to the current call, so clear the glared saved data */
clear_call_glare_data(sngisdn_info);
}
- ftdm_assert(g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] == NULL, "Con Ind on busy spInstId");
-
ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
- g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
g_sngisdn_data.ccs[suId].active_suInstIds[sngisdn_info->suInstId] = sngisdn_info;
ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
ftdmchan->caller_data.bearer_layer1 = sngisdn_get_infoTranCap_from_stack(conEvnt->bearCap[0].usrInfoLyr1Prot.val);
ftdmchan->caller_data.bearer_capability = sngisdn_get_infoTranCap_from_stack(conEvnt->bearCap[0].infoTranCap.val);
}
-
+
if (signal_data->switchtype == SNGISDN_SWITCH_NI2) {
if (conEvnt->shift11.eh.pres && conEvnt->ni2OctStr.eh.pres) {
if (conEvnt->ni2OctStr.str.len == 4 && conEvnt->ni2OctStr.str.val[0] == 0x37) {
break;
case FTDM_CHANNEL_STATE_TERMINATING:
ftdm_log_chan_msg(ftdmchan, FTDM_LOG_INFO, "Processing SETUP in TERMINATING state, saving SETUP info for later processing\n");
- ftdm_assert(!sngisdn_test_flag(sngisdn_info, FLAG_GLARE), "Trying to save GLARE info, but we already had a glare");
+ ftdm_assert(!sngisdn_test_flag(sngisdn_info, FLAG_GLARE), "Trying to save GLARE info, but we already had a glare\n");
sngisdn_set_flag(sngisdn_info, FLAG_GLARE);
sngisdn_info->glare.dChan = dChan;
sngisdn_info->glare.ces = ces;
- /* We need to register the spInstId in case we get a release for that call while it is still stored in sngisdn_info->glare */
- ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
- g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
- ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
-
break;
case FTDM_CHANNEL_STATE_DIALING: /* glare */
if (signal_data->signalling == SNGISDN_SIGNALING_NET) {
sngisdn_info->glare.suInstId = get_unique_suInstId(suId);
sngisdn_info->glare.spInstId = spInstId;
- ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
- g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
- g_sngisdn_data.ccs[suId].active_suInstIds[sngisdn_info->suInstId] = sngisdn_info;
- ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
-
sngisdn_info->glare.dChan = dChan;
sngisdn_info->glare.ces = ces;
ftdmchan->caller_data.hangup_cause = 0x2C; /* Channel requested not available */
sngisdn_info->glare.dChan = dChan;
sngisdn_info->glare.ces = ces;
- /* We need to register the spInstId in case we get a release for that call while it is still stored in sngisdn_info->glare */
- ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
- g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
- ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_TERMINATING);
}
break;
ftdm_assert(!ftdm_test_flag(ftdmchan, FTDM_CHANNEL_STATE_CHANGE), "State change flag pending\n");
ftdm_log_chan(ftdmchan, FTDM_LOG_DEBUG, "Processing CONNECT/CONNECT ACK (suId:%u suInstId:%u spInstId:%u ces:%d)\n", suId, suInstId, spInstId, ces);
-
- if (!sngisdn_info->spInstId) {
- ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
- sngisdn_info->spInstId = spInstId;
- g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
- ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
- }
if (ftdmchan->span->trunk_type == FTDM_TRUNK_BRI_PTMP &&
((sngisdn_span_data_t*)ftdmchan->span->signal_data)->signalling == SNGISDN_SIGNALING_NET) {
CnStEvnt *cnStEvnt = &sngisdn_event->event.cnStEvnt;
- if (!sngisdn_info->spInstId) {
- ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
- sngisdn_info->spInstId = spInstId;
- g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
- ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
- }
-
ftdm_assert(!ftdm_test_flag(ftdmchan, FTDM_CHANNEL_STATE_CHANGE), "State change flag pending\n");
ftdm_log_chan(ftdmchan, FTDM_LOG_DEBUG, "Processing %s (suId:%u suInstId:%u spInstId:%u ces:%d)\n",
DiscEvnt *discEvnt = &sngisdn_event->event.discEvnt;
- if (!sngisdn_info->spInstId) {
- ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
- sngisdn_info->spInstId = spInstId;
- g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
- ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
- }
-
ftdm_log_chan(ftdmchan, FTDM_LOG_DEBUG, "Processing DISCONNECT (suId:%u suInstId:%u spInstId:%u)\n", suId, suInstId, spInstId);
ftdm_assert(!ftdm_test_flag(ftdmchan, FTDM_CHANNEL_STATE_CHANGE), "State change flag pending\n");
ftdm_log_chan_msg(ftdmchan, FTDM_LOG_WARNING, "Failed to retrieve Caller Name from Facility IE\n");
}
}
+
ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_RING);
break;
default:
case 9:
switch (ftdmchan->state) {
case FTDM_CHANNEL_STATE_PROGRESS:
+ case FTDM_CHANNEL_STATE_PROGRESS_MEDIA:
/* Do nothing */
break;
default:
sngisdn_event->event_id = SNGISDN_EVENT_CON_IND;
sngisdn_event->sngisdn_info = sngisdn_info;
sngisdn_event->suId = suId;
- sngisdn_event->suInstId = suInstId;
sngisdn_event->spInstId = spInstId;
sngisdn_event->dChan = dChan;
sngisdn_event->ces = ces;
+ ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
+ g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
+ ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
+
memcpy(&sngisdn_event->event.conEvnt, conEvnt, sizeof(*conEvnt));
ftdm_queue_enqueue(((sngisdn_span_data_t*)sngisdn_info->ftdmchan->span->signal_data)->event_queue, sngisdn_event);
return;
}
+ if (!sngisdn_info->spInstId) {
+ ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
+ sngisdn_info->spInstId = spInstId;
+ g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
+ ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
+ }
+
+
ftdm_log_chan(sngisdn_info->ftdmchan, FTDM_LOG_INFO, "Received CONNECT/CONNECT ACK (suId:%u suInstId:%u spInstId:%u ces:%d)\n", suId, suInstId, spInstId, ces);
sngisdn_event = ftdm_malloc(sizeof(*sngisdn_event));
sngisdn_event->spInstId = spInstId;
sngisdn_event->dChan = dChan;
sngisdn_event->ces = ces;
-
memcpy(&sngisdn_event->event.cnStEvnt, cnStEvnt, sizeof(*cnStEvnt));
ftdm_queue_enqueue(((sngisdn_span_data_t*)sngisdn_info->ftdmchan->span->signal_data)->event_queue, sngisdn_event);
return;
}
+ if (!sngisdn_info->spInstId) {
+ ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
+ sngisdn_info->spInstId = spInstId;
+ g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
+ ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
+ }
+
ftdm_log_chan(sngisdn_info->ftdmchan, FTDM_LOG_INFO, "Received %s (suId:%u suInstId:%u spInstId:%u ces:%d)\n",
(evntType == MI_ALERTING)?"ALERT":
(evntType == MI_CALLPROC)?"PROCEED":
return;
}
+ if (!sngisdn_info->spInstId) {
+ ftdm_mutex_lock(g_sngisdn_data.ccs[suId].mutex);
+ sngisdn_info->spInstId = spInstId;
+ g_sngisdn_data.ccs[suId].active_spInstIds[spInstId] = sngisdn_info;
+ ftdm_mutex_unlock(g_sngisdn_data.ccs[suId].mutex);
+ }
+
ftdm_log_chan(sngisdn_info->ftdmchan, FTDM_LOG_INFO, "Received DISCONNECT (suId:%u suInstId:%u spInstId:%u)\n", suId, suInstId, spInstId);
sngisdn_event = ftdm_malloc(sizeof(*sngisdn_event));
}
}
}
- ftdm_assert(ftdmspan != NULL, "Received q921 status on unconfigured span\n");
+ if (ftdmspan == NULL) {
+ ftdm_log(FTDM_LOG_WARNING, "Received q921 status on unconfigured span (lnkNmb:%d)\n", status->t.usta.lnkNmb);
+ return;
+ }
switch (status->t.usta.alarm.category) {
case (LCM_CATEGORY_INTERFACE):