try to pass cause code on calls ended during early media

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@5682 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2007-08-30 15:38:21 +00:00
parent ad1bd7bf61
commit 38ffa90005

View File

@ -84,12 +84,14 @@ static void *audio_bridge_thread(switch_thread_t * thread, void *obj)
switch_event_t *event; switch_event_t *event;
loop_count++; loop_count++;
/* if you really want to make sure it's not ready, test it twice because it might be just a break */ if (!switch_channel_ready(chan_a)) {
if (!switch_channel_ready(chan_a) && !switch_channel_ready(chan_a)) {
break; break;
} }
if ((b_state = switch_channel_get_state(chan_b)) >= CS_HANGUP) { if ((b_state = switch_channel_get_state(chan_b)) >= CS_HANGUP) {
if (originator && !ans_a && !ans_b) {
switch_channel_hangup(chan_a, switch_channel_get_cause(chan_b));
}
break; break;
} }
@ -163,8 +165,7 @@ static void *audio_bridge_thread(switch_thread_t * thread, void *obj)
continue; continue;
} }
} }
/* read audio from 1 channel and write it to the other */ /* read audio from 1 channel and write it to the other */
status = switch_core_session_read_frame(session_a, &read_frame, -1, stream_id); status = switch_core_session_read_frame(session_a, &read_frame, -1, stream_id);