fix some edge cases
This commit is contained in:
parent
fadcbd9268
commit
3bb90ac41c
|
@ -2580,7 +2580,10 @@ static void conference_loop_output(conference_member_t *member)
|
||||||
if (member->fnode) {
|
if (member->fnode) {
|
||||||
member_add_file_data(member, write_frame.data, write_frame.datalen);
|
member_add_file_data(member, write_frame.data, write_frame.datalen);
|
||||||
}
|
}
|
||||||
switch_core_session_write_frame(member->session, &write_frame, SWITCH_IO_FLAG_NONE, 0);
|
if (switch_core_session_write_frame(member->session, &write_frame, SWITCH_IO_FLAG_NONE, 0) != SWITCH_STATUS_SUCCESS) {
|
||||||
|
switch_channel_hangup(channel, SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2590,7 +2593,10 @@ static void conference_loop_output(conference_member_t *member)
|
||||||
write_frame.samples = samples;
|
write_frame.samples = samples;
|
||||||
memset(write_frame.data, 255, write_frame.datalen);
|
memset(write_frame.data, 255, write_frame.datalen);
|
||||||
member_add_file_data(member, write_frame.data, write_frame.datalen);
|
member_add_file_data(member, write_frame.data, write_frame.datalen);
|
||||||
switch_core_session_write_frame(member->session, &write_frame, SWITCH_IO_FLAG_NONE, 0);
|
if (switch_core_session_write_frame(member->session, &write_frame, SWITCH_IO_FLAG_NONE, 0) != SWITCH_STATUS_SUCCESS) {
|
||||||
|
switch_channel_hangup(channel, SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER);
|
||||||
|
break;
|
||||||
|
}
|
||||||
} else if (!switch_test_flag(member->conference, CFLAG_WASTE_BANDWIDTH)) {
|
} else if (!switch_test_flag(member->conference, CFLAG_WASTE_BANDWIDTH)) {
|
||||||
if (switch_test_flag(member, MFLAG_WASTE_BANDWIDTH)) {
|
if (switch_test_flag(member, MFLAG_WASTE_BANDWIDTH)) {
|
||||||
if (member->conference->comfort_noise_level) {
|
if (member->conference->comfort_noise_level) {
|
||||||
|
@ -2603,7 +2609,10 @@ static void conference_loop_output(conference_member_t *member)
|
||||||
write_frame.samples = samples;
|
write_frame.samples = samples;
|
||||||
write_frame.timestamp = timer.samplecount;
|
write_frame.timestamp = timer.samplecount;
|
||||||
|
|
||||||
switch_core_session_write_frame(member->session, &write_frame, SWITCH_IO_FLAG_NONE, 0);
|
if (switch_core_session_write_frame(member->session, &write_frame, SWITCH_IO_FLAG_NONE, 0) != SWITCH_STATUS_SUCCESS) {
|
||||||
|
switch_channel_hangup(channel, SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -137,9 +137,11 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_set_read_codec(switch_core_s
|
||||||
memset(&session->read_impl, 0, sizeof(session->read_impl));
|
memset(&session->read_impl, 0, sizeof(session->read_impl));
|
||||||
}
|
}
|
||||||
old->next = NULL;
|
old->next = NULL;
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "%s Restore previous codec %s:%d.\n",
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "%s Restore previous codec %s:%d.\n",
|
||||||
switch_channel_get_name(session->channel),
|
switch_channel_get_name(session->channel),
|
||||||
session->read_codec->implementation->iananame, session->read_codec->implementation->ianacode);
|
session->read_impl.iananame ? session->read_impl.iananame : "N/A", session->read_impl.ianacode);
|
||||||
|
|
||||||
|
|
||||||
} else if (session->real_read_codec) {
|
} else if (session->real_read_codec) {
|
||||||
session->read_codec = session->real_read_codec;
|
session->read_codec = session->real_read_codec;
|
||||||
|
|
Loading…
Reference in New Issue