From 4aaaf7619014e925d57309bc04ea9685da7a5e55 Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Thu, 22 Sep 2016 14:00:12 -0500 Subject: [PATCH] FS-9525 #resolve [Client initiated REINVITE with different audio codec into conference causes choppy audio] --- src/mod/applications/mod_conference/conference_loop.c | 9 +++++---- src/switch_core_codec.c | 2 ++ 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/src/mod/applications/mod_conference/conference_loop.c b/src/mod/applications/mod_conference/conference_loop.c index c6b1a526bc..9df033de80 100644 --- a/src/mod/applications/mod_conference/conference_loop.c +++ b/src/mod/applications/mod_conference/conference_loop.c @@ -1108,18 +1108,19 @@ void conference_loop_output(conference_member_t *member) uint32_t flush_len; uint32_t low_count, bytes; call_list_t *call_list, *cp; - switch_codec_implementation_t read_impl = { 0 }; + switch_codec_implementation_t read_impl = { 0 }, real_read_impl = { 0 }; int sanity; switch_status_t st; switch_core_session_get_read_impl(member->session, &read_impl); + switch_core_session_get_real_read_impl(member->session, &real_read_impl); channel = switch_core_session_get_channel(member->session); interval = read_impl.microseconds_per_packet / 1000; samples = switch_samples_per_packet(member->conference->rate, interval); //csamples = samples; - tsamples = member->orig_read_impl.samples_per_packet; + tsamples = real_read_impl.samples_per_packet; low_count = 0; bytes = samples * 2 * member->conference->channels; call_list = NULL; @@ -1136,8 +1137,8 @@ void conference_loop_output(conference_member_t *member) return; } - switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(member->session), SWITCH_LOG_DEBUG, "Setup timer %s success interval: %u samples: %u\n", - member->conference->timer_name, interval, tsamples); + switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(member->session), SWITCH_LOG_DEBUG, "Setup timer %s success interval: %u samples: %u from codec %s\n", + member->conference->timer_name, interval, tsamples, real_read_impl.iananame); write_frame.data = data = switch_core_session_alloc(member->session, SWITCH_RECOMMENDED_BUFFER_SIZE); diff --git a/src/switch_core_codec.c b/src/switch_core_codec.c index 93750aabb6..c25357a74d 100644 --- a/src/switch_core_codec.c +++ b/src/switch_core_codec.c @@ -132,6 +132,8 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_set_real_read_codec(switch_c cur_codec = cur_codec->next; } session->real_read_codec = codec; + session->real_read_impl = *codec->implementation; + /* set read_codec with real_read_codec if it no longer is ready */ if (!switch_core_codec_ready(session->read_codec)) { session->read_codec = codec;