X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=blobdiff_plain;f=gsm_bs.cpp;h=ee4bf045439c2f97a609d428cabcfb1e020618a4;hp=3a9ab7d00db29dd6e66c07c7979b215ebbd7ca53;hb=a698197188e22f42a5483bcb775f66522863d871;hpb=ec40766edc4b55496be56d3123b266900e15dc29 diff --git a/gsm_bs.cpp b/gsm_bs.cpp index 3a9ab7d..ee4bf04 100644 --- a/gsm_bs.cpp +++ b/gsm_bs.cpp @@ -179,15 +179,24 @@ void Pgsm_bs::start_dtmf_ind(unsigned int msg_type, unsigned int callref, struct send_and_free_mncc(p_g_lcr_gsm, resp->msg_type, resp); if (p_g_rtp_bridge) { - class Port *remote = bridge_remote(); - - if (remote) { - struct lcr_msg *message; - - /* send dtmf information, because we bridge RTP directly */ - message = message_create(0, remote->p_serial, EPOINT_TO_PORT, MESSAGE_DTMF); - message->param.dtmf = mncc->keypad; - message_put(message); + /* if two members are bridged */ + if (p_bridge && p_bridge->first && p_bridge->first->next && !p_bridge->first->next->next) { + class Port *remote = NULL; + + /* select other member */ + if (p_bridge->first->port == this) + remote = p_bridge->first->next->port; + if (p_bridge->first->next->port == this) + remote = p_bridge->first->port; + + if (remote) { + struct lcr_msg *message; + + /* send dtmf information, because we bridge RTP directly */ + message = message_create(0, remote->p_serial, EPOINT_TO_PORT, MESSAGE_DTMF); + message->param.dtmf = mncc->keypad; + message_put(message); + } } } else { /* generate DTMF tones, since we do audio forwarding inside LCR */