mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-04-16 08:49:01 +00:00
only pass 2833 while bridged and while bridged to another channel that uses our RTP stack
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@13131 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
7ec599500c
commit
0071cedcd0
@ -301,6 +301,8 @@ SWITCH_DECLARE(switch_bool_t) switch_channel_set_flag_partner(switch_channel_t *
|
|||||||
*/
|
*/
|
||||||
SWITCH_DECLARE(switch_bool_t) switch_channel_clear_flag_partner(switch_channel_t *channel, switch_channel_flag_t flag);
|
SWITCH_DECLARE(switch_bool_t) switch_channel_clear_flag_partner(switch_channel_t *channel, switch_channel_flag_t flag);
|
||||||
|
|
||||||
|
SWITCH_DECLARE(uint32_t) switch_channel_test_flag_partner(switch_channel_t *channel, switch_channel_flag_t flag);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Set given flag(s) on a given channel to be applied on the next state change
|
\brief Set given flag(s) on a given channel to be applied on the next state change
|
||||||
\param channel channel on which to set flag(s)
|
\param channel channel on which to set flag(s)
|
||||||
|
@ -883,6 +883,7 @@ typedef enum {
|
|||||||
CF_PAUSE_BUGS,
|
CF_PAUSE_BUGS,
|
||||||
CF_DIVERT_EVENTS,
|
CF_DIVERT_EVENTS,
|
||||||
CF_BLOCK_STATE,
|
CF_BLOCK_STATE,
|
||||||
|
CF_FS_RTP,
|
||||||
/* WARNING: DO NOT ADD ANY FLAGS BELOW THIS LINE */
|
/* WARNING: DO NOT ADD ANY FLAGS BELOW THIS LINE */
|
||||||
CF_FLAG_MAX
|
CF_FLAG_MAX
|
||||||
} switch_channel_flag_t;
|
} switch_channel_flag_t;
|
||||||
|
@ -1024,11 +1024,20 @@ static switch_status_t sofia_receive_message(switch_core_session_t *session, swi
|
|||||||
|
|
||||||
case SWITCH_MESSAGE_INDICATE_BRIDGE:
|
case SWITCH_MESSAGE_INDICATE_BRIDGE:
|
||||||
if (switch_rtp_ready(tech_pvt->rtp_session)) {
|
if (switch_rtp_ready(tech_pvt->rtp_session)) {
|
||||||
|
if (sofia_test_flag(tech_pvt, TFLAG_PASS_RFC2833) && switch_channel_test_flag_partner(channel, CF_FS_RTP)) {
|
||||||
|
switch_rtp_set_flag(tech_pvt->rtp_session, SWITCH_RTP_FLAG_PASS_RFC2833);
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "%s activate passthru 2833 mode.\n", switch_channel_get_name(channel));
|
||||||
|
}
|
||||||
|
|
||||||
rtp_flush_read_buffer(tech_pvt->rtp_session, SWITCH_RTP_FLUSH_STICK);
|
rtp_flush_read_buffer(tech_pvt->rtp_session, SWITCH_RTP_FLUSH_STICK);
|
||||||
}
|
}
|
||||||
goto end;
|
goto end;
|
||||||
case SWITCH_MESSAGE_INDICATE_UNBRIDGE:
|
case SWITCH_MESSAGE_INDICATE_UNBRIDGE:
|
||||||
if (switch_rtp_ready(tech_pvt->rtp_session)) {
|
if (switch_rtp_ready(tech_pvt->rtp_session)) {
|
||||||
|
if (switch_rtp_test_flag(tech_pvt->rtp_session, SWITCH_RTP_FLAG_PASS_RFC2833)) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "%s deactivate passthru 2833 mode.\n", switch_channel_get_name(channel));
|
||||||
|
switch_rtp_clear_flag(tech_pvt->rtp_session, SWITCH_RTP_FLAG_PASS_RFC2833);
|
||||||
|
}
|
||||||
rtp_flush_read_buffer(tech_pvt->rtp_session, SWITCH_RTP_FLUSH_UNSTICK);
|
rtp_flush_read_buffer(tech_pvt->rtp_session, SWITCH_RTP_FLUSH_UNSTICK);
|
||||||
}
|
}
|
||||||
goto end;
|
goto end;
|
||||||
|
@ -233,6 +233,7 @@ typedef enum {
|
|||||||
TFLAG_PROXY_MEDIA,
|
TFLAG_PROXY_MEDIA,
|
||||||
TFLAG_HOLD_LOCK,
|
TFLAG_HOLD_LOCK,
|
||||||
TFLAG_3PCC_HAS_ACK,
|
TFLAG_3PCC_HAS_ACK,
|
||||||
|
TFLAG_PASS_RFC2833,
|
||||||
|
|
||||||
/* No new flags below this line */
|
/* No new flags below this line */
|
||||||
TFLAG_MAX
|
TFLAG_MAX
|
||||||
|
@ -2106,7 +2106,7 @@ switch_status_t sofia_glue_activate_rtp(private_object_t *tech_pvt, switch_rtp_f
|
|||||||
|
|
||||||
if (sofia_test_pflag(tech_pvt->profile, PFLAG_PASS_RFC2833)
|
if (sofia_test_pflag(tech_pvt->profile, PFLAG_PASS_RFC2833)
|
||||||
|| ((val = switch_channel_get_variable(tech_pvt->channel, "pass_rfc2833")) && switch_true(val))) {
|
|| ((val = switch_channel_get_variable(tech_pvt->channel, "pass_rfc2833")) && switch_true(val))) {
|
||||||
flags |= SWITCH_RTP_FLAG_PASS_RFC2833;
|
sofia_set_flag(tech_pvt, TFLAG_PASS_RFC2833);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -2220,6 +2220,8 @@ switch_status_t sofia_glue_activate_rtp(private_object_t *tech_pvt, switch_rtp_f
|
|||||||
uint8_t inb = sofia_test_flag(tech_pvt, TFLAG_OUTBOUND) ? 0 : 1;
|
uint8_t inb = sofia_test_flag(tech_pvt, TFLAG_OUTBOUND) ? 0 : 1;
|
||||||
uint32_t stun_ping = 0;
|
uint32_t stun_ping = 0;
|
||||||
|
|
||||||
|
switch_channel_set_flag(tech_pvt->channel, CF_FS_RTP);
|
||||||
|
|
||||||
if ((val = switch_channel_get_variable(tech_pvt->channel, "rtp_enable_vad_in")) && switch_true(val)) {
|
if ((val = switch_channel_get_variable(tech_pvt->channel, "rtp_enable_vad_in")) && switch_true(val)) {
|
||||||
vad_in = 1;
|
vad_in = 1;
|
||||||
}
|
}
|
||||||
|
@ -719,6 +719,24 @@ SWITCH_DECLARE(switch_bool_t) switch_channel_set_flag_partner(switch_channel_t *
|
|||||||
return SWITCH_FALSE;
|
return SWITCH_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SWITCH_DECLARE(uint32_t) switch_channel_test_flag_partner(switch_channel_t *channel, switch_channel_flag_t flag)
|
||||||
|
{
|
||||||
|
const char *uuid;
|
||||||
|
int r = 0;
|
||||||
|
|
||||||
|
switch_assert(channel != NULL);
|
||||||
|
|
||||||
|
if ((uuid = switch_channel_get_variable(channel, SWITCH_SIGNAL_BOND_VARIABLE))) {
|
||||||
|
switch_core_session_t *session;
|
||||||
|
if ((session = switch_core_session_locate(uuid))) {
|
||||||
|
r = switch_channel_test_flag(switch_core_session_get_channel(session), flag);
|
||||||
|
switch_core_session_rwunlock(session);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
SWITCH_DECLARE(switch_bool_t) switch_channel_clear_flag_partner(switch_channel_t *channel, switch_channel_flag_t flag)
|
SWITCH_DECLARE(switch_bool_t) switch_channel_clear_flag_partner(switch_channel_t *channel, switch_channel_flag_t flag)
|
||||||
{
|
{
|
||||||
const char *uuid;
|
const char *uuid;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user