diff options
Diffstat (limited to 'channels')
-rw-r--r-- | channels/chan_misdn.c | 32 |
1 files changed, 5 insertions, 27 deletions
diff --git a/channels/chan_misdn.c b/channels/chan_misdn.c index ea1cecd9d..8a3b22c2e 100644 --- a/channels/chan_misdn.c +++ b/channels/chan_misdn.c @@ -296,13 +296,6 @@ struct chan_list { struct ast_dsp *dsp; /*! - * \brief Allocated audio frame sample translator - * \note ast_translator_build_path() creates the translator path. - * \note Must use ast_translator_free_path() to clean up. - */ - struct ast_trans_pvt *trans; - - /*! * \brief Associated Asterisk channel structure. */ struct ast_channel * ast; @@ -2334,8 +2327,6 @@ static int read_config(struct chan_list *ch, int orig) else ast_dsp_set_features(ch->dsp, DSP_FEATURE_DTMF_DETECT ); } - if (!ch->trans) - ch->trans = ast_translator_build_path(AST_FORMAT_SLINEAR, AST_FORMAT_ALAW); } /* AOCD initialization */ @@ -2574,11 +2565,6 @@ static int misdn_digit_end(struct ast_channel *ast, char digit, unsigned int dur misdn_lib_send_event( bc, EVENT_INFORMATION); break; default: - /* Do not send Digits in CONNECTED State, when - * the other side is too mISDN. */ - if (p->other_ch ) - return 0; - if ( bc->send_dtmf ) send_digit_to_chan(p,digit); break; @@ -2903,21 +2889,17 @@ static int misdn_hangup(struct ast_channel *ast) static struct ast_frame *process_ast_dsp(struct chan_list *tmp, struct ast_frame *frame) { - struct ast_frame *f,*f2; + struct ast_frame *f; - if (tmp->trans) { - f2 = ast_translate(tmp->trans, frame, 0); - f = ast_dsp_process(tmp->ast, tmp->dsp, f2); + if (tmp->dsp) { + f = ast_dsp_process(tmp->ast, tmp->dsp, frame); } else { - chan_misdn_log(0, tmp->bc->port, "No T-Path found\n"); + chan_misdn_log(0, tmp->bc->port, "No DSP-Path found\n"); return NULL; } if (!f || (f->frametype != AST_FRAME_DTMF)) { - if (f) { - ast_frfree(f); - } - return frame; + return f; } ast_debug(1, "Detected inband DTMF digit: %c\n", f->subclass); @@ -3823,8 +3805,6 @@ static void cl_dequeue_chan(struct chan_list **list, struct chan_list *chan) if (chan->dsp) ast_dsp_free(chan->dsp); - if (chan->trans) - ast_translator_free_path(chan->trans); ast_mutex_lock(&cl_te_lock); if (!*list) { @@ -5872,8 +5852,6 @@ static int misdn_set_opt_exec(struct ast_channel *chan, void *data) ch->dsp = ast_dsp_new(); if (ch->dsp) ast_dsp_set_features(ch->dsp, DSP_FEATURE_DTMF_DETECT | DSP_FEATURE_FAX_DETECT); - if (!ch->trans) - ch->trans = ast_translator_build_path(AST_FORMAT_SLINEAR, AST_FORMAT_ALAW); } if (ch->ast_dsp) { |