Merge branch 'master' into smgmaster
This commit is contained in:
commit
4c714895f6
|
@ -4259,7 +4259,9 @@ SWITCH_MODULE_LOAD_FUNCTION(mod_freetdm_load)
|
||||||
switch_console_set_complete("add ftdm gains");
|
switch_console_set_complete("add ftdm gains");
|
||||||
switch_console_set_complete("add ftdm dtmf on");
|
switch_console_set_complete("add ftdm dtmf on");
|
||||||
switch_console_set_complete("add ftdm dtmf off");
|
switch_console_set_complete("add ftdm dtmf off");
|
||||||
|
switch_console_set_complete("add ftdm core state");
|
||||||
|
switch_console_set_complete("add ftdm core flag");
|
||||||
|
switch_console_set_complete("add ftdm core calls");
|
||||||
|
|
||||||
SWITCH_ADD_APP(app_interface, "disable_ec", "Disable Echo Canceller", "Disable Echo Canceller", disable_ec_function, "", SAF_NONE);
|
SWITCH_ADD_APP(app_interface, "disable_ec", "Disable Echo Canceller", "Disable Echo Canceller", disable_ec_function, "", SAF_NONE);
|
||||||
SWITCH_ADD_APP(app_interface, "disable_dtmf", "Disable DTMF Detection", "Disable DTMF Detection", disable_dtmf_function, "", SAF_NONE);
|
SWITCH_ADD_APP(app_interface, "disable_dtmf", "Disable DTMF Detection", "Disable DTMF Detection", disable_dtmf_function, "", SAF_NONE);
|
||||||
|
|
|
@ -5532,6 +5532,7 @@ FT_DECLARE(ftdm_status_t) ftdm_span_send_signal(ftdm_span_t *span, ftdm_sigmsg_t
|
||||||
sigmsg->chan_id = sigmsg->channel->chan_id;
|
sigmsg->chan_id = sigmsg->channel->chan_id;
|
||||||
sigmsg->span_id = sigmsg->channel->span_id;
|
sigmsg->span_id = sigmsg->channel->span_id;
|
||||||
sigmsg->call_id = sigmsg->channel->caller_data.call_id;
|
sigmsg->call_id = sigmsg->channel->caller_data.call_id;
|
||||||
|
sigmsg->call_priv = sigmsg->channel->caller_data.priv;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* some core things to do on special events */
|
/* some core things to do on special events */
|
||||||
|
@ -5563,10 +5564,6 @@ FT_DECLARE(ftdm_status_t) ftdm_span_send_signal(ftdm_span_t *span, ftdm_sigmsg_t
|
||||||
}
|
}
|
||||||
ftdm_set_flag(sigmsg->channel, FTDM_CHANNEL_CALL_STARTED);
|
ftdm_set_flag(sigmsg->channel, FTDM_CHANNEL_CALL_STARTED);
|
||||||
ftdm_call_set_call_id(sigmsg->channel, &sigmsg->channel->caller_data);
|
ftdm_call_set_call_id(sigmsg->channel, &sigmsg->channel->caller_data);
|
||||||
if (sigmsg->channel->dtmfdbg.requested) {
|
|
||||||
ftdm_channel_command(sigmsg->channel, FTDM_COMMAND_ENABLE_DEBUG_DTMF, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* when cleaning up the public API I added this because mod_freetdm.c on_fxs_signal was
|
/* when cleaning up the public API I added this because mod_freetdm.c on_fxs_signal was
|
||||||
* doing it during SIGEVENT_START, but now that flags are private they can't, wonder if
|
* doing it during SIGEVENT_START, but now that flags are private they can't, wonder if
|
||||||
* is needed at all?
|
* is needed at all?
|
||||||
|
|
|
@ -676,12 +676,6 @@ static void ftdm_r2_on_call_offered(openr2_chan_t *r2chan, const char *ani, cons
|
||||||
ftdm_log_chan(ftdmchan, FTDM_LOG_NOTICE, "Call offered with ANI = %s, DNIS = %s, Category = %d, ANI restricted = %s\n",
|
ftdm_log_chan(ftdmchan, FTDM_LOG_NOTICE, "Call offered with ANI = %s, DNIS = %s, Category = %d, ANI restricted = %s\n",
|
||||||
ani, dnis, category, ani_restricted ? "Yes" : "No");
|
ani, dnis, category, ani_restricted ? "Yes" : "No");
|
||||||
|
|
||||||
/* nothing went wrong during call setup, MF has ended, we can and must disable the MF dump */
|
|
||||||
if (r2data->mf_dump_size) {
|
|
||||||
ftdm_channel_command(ftdmchan, FTDM_COMMAND_DISABLE_INPUT_DUMP, NULL);
|
|
||||||
ftdm_channel_command(ftdmchan, FTDM_COMMAND_DISABLE_OUTPUT_DUMP, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* check if this is a collect call and if we should accept it */
|
/* check if this is a collect call and if we should accept it */
|
||||||
if (!r2data->allow_collect_calls && category == OR2_CALLING_PARTY_CATEGORY_COLLECT_CALL) {
|
if (!r2data->allow_collect_calls && category == OR2_CALLING_PARTY_CATEGORY_COLLECT_CALL) {
|
||||||
ftdm_log_chan_msg(ftdmchan, FTDM_LOG_NOTICE, "Rejecting collect call\n");
|
ftdm_log_chan_msg(ftdmchan, FTDM_LOG_NOTICE, "Rejecting collect call\n");
|
||||||
|
@ -725,9 +719,10 @@ static void dump_mf(openr2_chan_t *r2chan)
|
||||||
if (r2data->mf_dump_size) {
|
if (r2data->mf_dump_size) {
|
||||||
char *logname = R2CALL(ftdmchan)->logname;
|
char *logname = R2CALL(ftdmchan)->logname;
|
||||||
|
|
||||||
ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Dumping IO output in prefix %s\n", logname);
|
ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Dumping IO output in prefix %s\n", !ftdm_strlen_zero(logname)
|
||||||
snprintf(dfile, sizeof(dfile), logname ? "%s.s%dc%d.input.alaw" : "%s/s%dc%d.input.alaw",
|
? logname : r2data->logdir);
|
||||||
logname ? logname : r2data->logdir, ftdmchan->span_id, ftdmchan->chan_id);
|
snprintf(dfile, sizeof(dfile), !ftdm_strlen_zero(logname) ? "%s.s%dc%d.input.alaw" : "%s/s%dc%d.input.alaw",
|
||||||
|
!ftdm_strlen_zero(logname) ? logname : r2data->logdir, ftdmchan->span_id, ftdmchan->chan_id);
|
||||||
f = fopen(dfile, "wb");
|
f = fopen(dfile, "wb");
|
||||||
if (f) {
|
if (f) {
|
||||||
ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Dumping IO input in file %s\n", dfile);
|
ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Dumping IO input in file %s\n", dfile);
|
||||||
|
@ -737,8 +732,8 @@ static void dump_mf(openr2_chan_t *r2chan)
|
||||||
ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Could not dump IO input in file %s, error: %s", dfile, strerror(errno));
|
ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Could not dump IO input in file %s, error: %s", dfile, strerror(errno));
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(dfile, sizeof(dfile), logname ? "%s.s%dc%d.output.alaw" : "%s/s%dc%d.output.alaw",
|
snprintf(dfile, sizeof(dfile), !ftdm_strlen_zero(logname) ? "%s.s%dc%d.output.alaw" : "%s/s%dc%d.output.alaw",
|
||||||
logname ? logname : r2data->logdir, ftdmchan->span_id, ftdmchan->chan_id);
|
!ftdm_strlen_zero(logname) ? logname : r2data->logdir, ftdmchan->span_id, ftdmchan->chan_id);
|
||||||
f = fopen(dfile, "wb");
|
f = fopen(dfile, "wb");
|
||||||
if (f) {
|
if (f) {
|
||||||
ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Dumping IO output in file %s\n", dfile);
|
ftdm_log_chan(ftdmchan, FTDM_LOG_ERROR, "Dumping IO output in file %s\n", dfile);
|
||||||
|
@ -769,6 +764,12 @@ static void ftdm_r2_on_call_accepted(openr2_chan_t *r2chan, openr2_call_mode_t m
|
||||||
|
|
||||||
R2CALL(ftdmchan)->accepted = 1;
|
R2CALL(ftdmchan)->accepted = 1;
|
||||||
|
|
||||||
|
/* nothing went wrong during call setup, MF has ended, we can and must disable the MF dump */
|
||||||
|
if (r2data->mf_dump_size) {
|
||||||
|
ftdm_channel_command(ftdmchan, FTDM_COMMAND_DISABLE_INPUT_DUMP, NULL);
|
||||||
|
ftdm_channel_command(ftdmchan, FTDM_COMMAND_DISABLE_OUTPUT_DUMP, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
if (OR2_DIR_BACKWARD == openr2_chan_get_direction(r2chan)) {
|
if (OR2_DIR_BACKWARD == openr2_chan_get_direction(r2chan)) {
|
||||||
if (R2CALL(ftdmchan)->answer_pending) {
|
if (R2CALL(ftdmchan)->answer_pending) {
|
||||||
ftdm_log_chan_msg(ftdmchan, FTDM_LOG_DEBUG, "Answer was pending, answering now.\n");
|
ftdm_log_chan_msg(ftdmchan, FTDM_LOG_DEBUG, "Answer was pending, answering now.\n");
|
||||||
|
@ -777,11 +778,6 @@ static void ftdm_r2_on_call_accepted(openr2_chan_t *r2chan, openr2_call_mode_t m
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* nothing went wrong during call setup, MF has ended, we can and must disable the MF dump */
|
|
||||||
if (r2data->mf_dump_size) {
|
|
||||||
ftdm_channel_command(ftdmchan, FTDM_COMMAND_DISABLE_INPUT_DUMP, NULL);
|
|
||||||
ftdm_channel_command(ftdmchan, FTDM_COMMAND_DISABLE_OUTPUT_DUMP, NULL);
|
|
||||||
}
|
|
||||||
ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_PROGRESS_MEDIA);
|
ftdm_set_state(ftdmchan, FTDM_CHANNEL_STATE_PROGRESS_MEDIA);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -912,9 +912,6 @@ static FIO_CHANNEL_OUTGOING_CALL_FUNCTION(ftdm_sangoma_isdn_outgoing_call)
|
||||||
sngisdn_chan_data_t *sngisdn_info = ftdmchan->call_data;
|
sngisdn_chan_data_t *sngisdn_info = ftdmchan->call_data;
|
||||||
ftdm_status_t status = FTDM_FAIL;
|
ftdm_status_t status = FTDM_FAIL;
|
||||||
|
|
||||||
/* lock the channel while we check whether it is availble */
|
|
||||||
ftdm_channel_lock(ftdmchan);
|
|
||||||
|
|
||||||
switch (ftdmchan->state) {
|
switch (ftdmchan->state) {
|
||||||
|
|
||||||
case FTDM_CHANNEL_STATE_DOWN:
|
case FTDM_CHANNEL_STATE_DOWN:
|
||||||
|
@ -942,7 +939,6 @@ static FIO_CHANNEL_OUTGOING_CALL_FUNCTION(ftdm_sangoma_isdn_outgoing_call)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
ftdm_channel_unlock(ftdmchan);
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
static FIO_CHANNEL_GET_SIG_STATUS_FUNCTION(ftdm_sangoma_isdn_get_chan_sig_status)
|
static FIO_CHANNEL_GET_SIG_STATUS_FUNCTION(ftdm_sangoma_isdn_get_chan_sig_status)
|
||||||
|
|
|
@ -680,8 +680,8 @@ static ftdm_status_t handle_print_usuage(ftdm_stream_handle_t *stream)
|
||||||
stream->write_function(stream, "ftdm ss7 set mtrace X Y\n");
|
stream->write_function(stream, "ftdm ss7 set mtrace X Y\n");
|
||||||
stream->write_function(stream, "\n");
|
stream->write_function(stream, "\n");
|
||||||
stream->write_function(stream, "Ftmod_sangoma_ss7 information:\n");
|
stream->write_function(stream, "Ftmod_sangoma_ss7 information:\n");
|
||||||
stream->write_function(stream, "ftdm ss7 show status link X\n");
|
stream->write_function(stream, "ftdm ss7 show status mtp3 X\n");
|
||||||
stream->write_function(stream, "ftdm ss7 show status linkset X\n");
|
stream->write_function(stream, "ftdm ss7 show status mtp2 X\n");
|
||||||
stream->write_function(stream, "ftdm ss7 show status span X chan Y\n");
|
stream->write_function(stream, "ftdm ss7 show status span X chan Y\n");
|
||||||
stream->write_function(stream, "ftdm ss7 show free span X chan Y\n");
|
stream->write_function(stream, "ftdm ss7 show free span X chan Y\n");
|
||||||
stream->write_function(stream, "ftdm ss7 show inuse span X chan Y\n");
|
stream->write_function(stream, "ftdm ss7 show inuse span X chan Y\n");
|
||||||
|
|
|
@ -554,6 +554,7 @@ struct ftdm_sigmsg {
|
||||||
uint32_t chan_id; /*!< easy access to chan id */
|
uint32_t chan_id; /*!< easy access to chan id */
|
||||||
uint32_t span_id; /*!< easy access to span_id */
|
uint32_t span_id; /*!< easy access to span_id */
|
||||||
uint32_t call_id; /*!< unique call id for this call */
|
uint32_t call_id; /*!< unique call id for this call */
|
||||||
|
void *call_priv; /*!< Private data for the FreeTDM user from ftdm_caller_data->priv */
|
||||||
union {
|
union {
|
||||||
ftdm_event_sigstatus_t sigstatus; /*!< valid if event_id is FTDM_SIGEVENT_SIGSTATUS_CHANGED */
|
ftdm_event_sigstatus_t sigstatus; /*!< valid if event_id is FTDM_SIGEVENT_SIGSTATUS_CHANGED */
|
||||||
ftdm_event_trace_t trace; /*!< valid if event_id is FTDM_SIGEVENT_TRACE or FTDM_SIGEVENT_TRACE_RAW */
|
ftdm_event_trace_t trace; /*!< valid if event_id is FTDM_SIGEVENT_TRACE or FTDM_SIGEVENT_TRACE_RAW */
|
||||||
|
|
|
@ -688,6 +688,9 @@ FT_DECLARE(void) ftdm_set_echocancel_call_end(ftdm_channel_t *chan);
|
||||||
if (!ftdm_test_flag((fchan), FTDM_CHANNEL_MEDIA)) { \
|
if (!ftdm_test_flag((fchan), FTDM_CHANNEL_MEDIA)) { \
|
||||||
ftdm_set_flag((fchan), FTDM_CHANNEL_MEDIA); \
|
ftdm_set_flag((fchan), FTDM_CHANNEL_MEDIA); \
|
||||||
ftdm_set_echocancel_call_begin((fchan)); \
|
ftdm_set_echocancel_call_begin((fchan)); \
|
||||||
|
if ((fchan)->dtmfdbg.requested) { \
|
||||||
|
ftdm_channel_command((fchan), FTDM_COMMAND_ENABLE_DEBUG_DTMF, NULL); \
|
||||||
|
} \
|
||||||
} \
|
} \
|
||||||
} while (0);
|
} while (0);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue