freetdm:Bug fixes in freetdm queue mode
freetdm:Added freetdm to compile/install list
This commit is contained in:
parent
dcb9c0ca52
commit
8aebc016d0
|
@ -4,7 +4,7 @@ echo "bootstrap: checking installation..."
|
||||||
BASEDIR=`pwd`;
|
BASEDIR=`pwd`;
|
||||||
LIBDIR=${BASEDIR}/libs;
|
LIBDIR=${BASEDIR}/libs;
|
||||||
SUBDIRS="ilbc curl iksemel js js/nsprpub libdingaling libedit libsndfile pcre sofia-sip \
|
SUBDIRS="ilbc curl iksemel js js/nsprpub libdingaling libedit libsndfile pcre sofia-sip \
|
||||||
speex sqlite srtp openzap spandsp libg722_1 portaudio unimrcp tiff-3.8.2 broadvoice silk";
|
speex sqlite srtp openzap freetdm spandsp libg722_1 portaudio unimrcp tiff-3.8.2 broadvoice silk";
|
||||||
|
|
||||||
if [ ! -f modules.conf ]; then
|
if [ ! -f modules.conf ]; then
|
||||||
cp build/modules.conf.in modules.conf
|
cp build/modules.conf.in modules.conf
|
||||||
|
|
|
@ -954,6 +954,7 @@ AC_CONFIG_SUBDIRS([libs/sofia-sip])
|
||||||
AC_CONFIG_SUBDIRS([libs/speex])
|
AC_CONFIG_SUBDIRS([libs/speex])
|
||||||
AC_CONFIG_SUBDIRS([libs/portaudio])
|
AC_CONFIG_SUBDIRS([libs/portaudio])
|
||||||
AC_CONFIG_SUBDIRS([libs/openzap])
|
AC_CONFIG_SUBDIRS([libs/openzap])
|
||||||
|
AC_CONFIG_SUBDIRS([libs/freetdm])
|
||||||
AC_CONFIG_SUBDIRS([libs/unimrcp])
|
AC_CONFIG_SUBDIRS([libs/unimrcp])
|
||||||
AC_CONFIG_SUBDIRS([libs/tiff-3.8.2])
|
AC_CONFIG_SUBDIRS([libs/tiff-3.8.2])
|
||||||
AC_CONFIG_SUBDIRS([libs/spandsp])
|
AC_CONFIG_SUBDIRS([libs/spandsp])
|
||||||
|
|
|
@ -691,13 +691,13 @@ static void handle_call_start_ack(sangomabc_connection_t *mcon, sangomabc_short_
|
||||||
if (ftdmchan->state == FTDM_CHANNEL_STATE_UP ||
|
if (ftdmchan->state == FTDM_CHANNEL_STATE_UP ||
|
||||||
ftdmchan->state == FTDM_CHANNEL_STATE_PROGRESS_MEDIA ||
|
ftdmchan->state == FTDM_CHANNEL_STATE_PROGRESS_MEDIA ||
|
||||||
ftdmchan->state == FTDM_CHANNEL_STATE_PROGRESS) {
|
ftdmchan->state == FTDM_CHANNEL_STATE_PROGRESS) {
|
||||||
ftdm_log(FTDM_LOG_CRIT, "ZCHAN CALL ACK STATE UP -> Changed to TERMINATING %d:%d\n", event->span+1,event->chan+1);
|
ftdm_log(FTDM_LOG_CRIT, "FTDMCHAN CALL ACK STATE UP -> Changed to TERMINATING %d:%d\n", event->span+1,event->chan+1);
|
||||||
ftdm_set_state_r(ftdmchan, FTDM_CHANNEL_STATE_TERMINATING, 0, r);
|
ftdm_set_state_r(ftdmchan, FTDM_CHANNEL_STATE_TERMINATING, 0, r);
|
||||||
} else if (ftdmchan->state == FTDM_CHANNEL_STATE_HANGUP || ftdm_test_sflag(ftdmchan, SFLAG_HANGUP)) {
|
} else if (ftdmchan->state == FTDM_CHANNEL_STATE_HANGUP || ftdm_test_sflag(ftdmchan, SFLAG_HANGUP)) {
|
||||||
ftdm_log(FTDM_LOG_CRIT, "ZCHAN CALL ACK STATE HANGUP -> Changed to HANGUP COMPLETE %d:%d\n", event->span+1,event->chan+1);
|
ftdm_log(FTDM_LOG_CRIT, "FTDMCHAN CALL ACK STATE HANGUP -> Changed to HANGUP COMPLETE %d:%d\n", event->span+1,event->chan+1);
|
||||||
ftdm_set_state_r(ftdmchan, FTDM_CHANNEL_STATE_HANGUP_COMPLETE, 0, r);
|
ftdm_set_state_r(ftdmchan, FTDM_CHANNEL_STATE_HANGUP_COMPLETE, 0, r);
|
||||||
} else {
|
} else {
|
||||||
ftdm_log(FTDM_LOG_CRIT, "ZCHAN STATE INVALID State %s on IN CALL ACK %d:%d\n",
|
ftdm_log(FTDM_LOG_CRIT, "FTDMCHAN STATE INVALID State %s on IN CALL ACK %d:%d\n",
|
||||||
ftdm_channel_state2str(ftdmchan->state),event->span+1,event->chan+1);
|
ftdm_channel_state2str(ftdmchan->state),event->span+1,event->chan+1);
|
||||||
}
|
}
|
||||||
ftdm_set_sflag(ftdmchan, SFLAG_SENT_FINAL_MSG);
|
ftdm_set_sflag(ftdmchan, SFLAG_SENT_FINAL_MSG);
|
||||||
|
@ -817,7 +817,9 @@ static void handle_call_start_nack(ftdm_span_t *span, sangomabc_connection_t *mc
|
||||||
if (sangoma_boost_data->sigmod) {
|
if (sangoma_boost_data->sigmod) {
|
||||||
ftdmchan = OUTBOUND_REQUESTS[event->call_setup_id].ftdmchan;
|
ftdmchan = OUTBOUND_REQUESTS[event->call_setup_id].ftdmchan;
|
||||||
CALL_DATA(ftdmchan)->last_event_id = event->event_id;
|
CALL_DATA(ftdmchan)->last_event_id = event->event_id;
|
||||||
|
CALL_DATA(ftdmchan)->call_setup_id = event->call_setup_id;
|
||||||
ftdm_set_state_locked(ftdmchan, FTDM_CHANNEL_STATE_TERMINATING);
|
ftdm_set_state_locked(ftdmchan, FTDM_CHANNEL_STATE_TERMINATING);
|
||||||
|
ftdm_clear_sflag_locked(ftdmchan, SFLAG_SENT_FINAL_MSG);
|
||||||
} else {
|
} else {
|
||||||
sangomabc_exec_command(mcon,
|
sangomabc_exec_command(mcon,
|
||||||
0,
|
0,
|
||||||
|
@ -859,7 +861,7 @@ static void handle_call_start_nack(ftdm_span_t *span, sangomabc_connection_t *mc
|
||||||
sangomabc_exec_command(mcon,
|
sangomabc_exec_command(mcon,
|
||||||
event->span,
|
event->span,
|
||||||
event->chan,
|
event->chan,
|
||||||
0,
|
event->call_setup_id,
|
||||||
SIGBOOST_EVENT_CALL_START_NACK_ACK,
|
SIGBOOST_EVENT_CALL_START_NACK_ACK,
|
||||||
0, 0);
|
0, 0);
|
||||||
}
|
}
|
||||||
|
@ -1004,23 +1006,25 @@ static void handle_call_start(ftdm_span_t *span, sangomabc_connection_t *mcon, s
|
||||||
if (ftdmchan->state == FTDM_CHANNEL_STATE_UP ||
|
if (ftdmchan->state == FTDM_CHANNEL_STATE_UP ||
|
||||||
ftdmchan->state == FTDM_CHANNEL_STATE_PROGRESS_MEDIA ||
|
ftdmchan->state == FTDM_CHANNEL_STATE_PROGRESS_MEDIA ||
|
||||||
ftdmchan->state == FTDM_CHANNEL_STATE_PROGRESS) {
|
ftdmchan->state == FTDM_CHANNEL_STATE_PROGRESS) {
|
||||||
ftdm_log(FTDM_LOG_CRIT, "ZCHAN STATE UP -> Changed to TERMINATING %d:%d\n", event->span+1,event->chan+1);
|
ftdm_log(FTDM_LOG_CRIT, "s%dc%d:FTDMCHAN STATE UP -> Changed to TERMINATING\n", BOOST_EVENT_SPAN(mcon->sigmod, event), BOOST_EVENT_CHAN(mcon->sigmod, event));
|
||||||
ftdm_set_state_r(ftdmchan, FTDM_CHANNEL_STATE_TERMINATING, 0, r);
|
ftdm_set_state_r(ftdmchan, FTDM_CHANNEL_STATE_TERMINATING, 0, r);
|
||||||
} else if (ftdmchan->state == FTDM_CHANNEL_STATE_HANGUP || ftdm_test_sflag(ftdmchan, SFLAG_HANGUP)) {
|
} else if (ftdmchan->state == FTDM_CHANNEL_STATE_HANGUP || ftdm_test_sflag(ftdmchan, SFLAG_HANGUP)) {
|
||||||
ftdm_log(FTDM_LOG_CRIT, "ZCHAN STATE HANGUP -> Changed to HANGUP COMPLETE %d:%d\n", event->span+1,event->chan+1);
|
ftdm_log(FTDM_LOG_CRIT, "s%dc%d:FTDMCHAN STATE HANGUP -> Changed to HANGUP COMPLETE\n", BOOST_EVENT_SPAN(mcon->sigmod, event), BOOST_EVENT_CHAN(mcon->sigmod, event));
|
||||||
ftdm_set_state_r(ftdmchan, FTDM_CHANNEL_STATE_HANGUP_COMPLETE, 0, r);
|
ftdm_set_state_r(ftdmchan, FTDM_CHANNEL_STATE_HANGUP_COMPLETE, 0, r);
|
||||||
|
} else if (ftdmchan->state == FTDM_CHANNEL_STATE_DIALING) {
|
||||||
|
ftdm_log(FTDM_LOG_WARNING, "s%dc%d:Collision, hanging up incoming call\n", BOOST_EVENT_SPAN(mcon->sigmod, event), BOOST_EVENT_CHAN(mcon->sigmod, event));
|
||||||
} else {
|
} else {
|
||||||
ftdm_log(FTDM_LOG_CRIT, "ZCHAN STATE INVALID %s on IN CALL %d:%d\n", ftdm_channel_state2str(ftdmchan->state),event->span+1,event->chan+1);
|
ftdm_log(FTDM_LOG_CRIT, "s%dc%d:FTDMCHAN STATE INVALID %s on IN CALL\n", BOOST_EVENT_SPAN(mcon->sigmod, event), BOOST_EVENT_CHAN(mcon->sigmod, event), ftdm_channel_state2str(ftdmchan->state));
|
||||||
}
|
}
|
||||||
ftdm_set_sflag(ftdmchan, SFLAG_SENT_FINAL_MSG);
|
ftdm_set_sflag(ftdmchan, SFLAG_SENT_FINAL_MSG);
|
||||||
ftdmchan = NULL;
|
ftdmchan = NULL;
|
||||||
}
|
}
|
||||||
ftdm_log(FTDM_LOG_CRIT, "START CANT FIND CHAN %d:%d\n", BOOST_EVENT_SPAN(mcon->sigmod, event), BOOST_EVENT_CHAN(mcon->sigmod, event));
|
ftdm_log(FTDM_LOG_CRIT, "s%dc%d:START CANT FIND CHAN\n", BOOST_EVENT_SPAN(mcon->sigmod, event), BOOST_EVENT_CHAN(mcon->sigmod, event));
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ftdm_channel_open_chan(ftdmchan) != FTDM_SUCCESS) {
|
if (ftdm_channel_open_chan(ftdmchan) != FTDM_SUCCESS) {
|
||||||
ftdm_log(FTDM_LOG_CRIT, "START CANT OPEN CHAN %d:%d\n", BOOST_EVENT_SPAN(mcon->sigmod, event), BOOST_EVENT_CHAN(mcon->sigmod, event));
|
ftdm_log(FTDM_LOG_CRIT, "s%dc%d:START CANT OPEN CHAN\n", BOOST_EVENT_SPAN(mcon->sigmod, event), BOOST_EVENT_CHAN(mcon->sigmod, event));
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1074,7 +1078,7 @@ static void handle_call_start(ftdm_span_t *span, sangomabc_connection_t *mcon, s
|
||||||
sangomabc_exec_command(mcon,
|
sangomabc_exec_command(mcon,
|
||||||
event->span,
|
event->span,
|
||||||
event->chan,
|
event->chan,
|
||||||
0,
|
event->call_setup_id,
|
||||||
SIGBOOST_EVENT_CALL_START_NACK,
|
SIGBOOST_EVENT_CALL_START_NACK,
|
||||||
hangup_cause, 0);
|
hangup_cause, 0);
|
||||||
|
|
||||||
|
@ -1375,7 +1379,7 @@ static __inline__ void state_advance(ftdm_channel_t *ftdmchan)
|
||||||
sangomabc_exec_command(mcon,
|
sangomabc_exec_command(mcon,
|
||||||
BOOST_SPAN(ftdmchan),
|
BOOST_SPAN(ftdmchan),
|
||||||
BOOST_CHAN(ftdmchan),
|
BOOST_CHAN(ftdmchan),
|
||||||
0,
|
CALL_DATA(ftdmchan)->call_setup_id,
|
||||||
SIGBOOST_EVENT_CALL_START_NACK_ACK,
|
SIGBOOST_EVENT_CALL_START_NACK_ACK,
|
||||||
0, 0);
|
0, 0);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue