From c12438b06b0d123291dbc3801219edbce3bf2892 Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Sun, 31 Dec 2006 21:06:03 +0000 Subject: [PATCH] fix hold issue reported by irate anonymous guy on irc git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@3879 d0543943-73ff-0310-b7d9-9358b9ac24b2 --- src/switch_ivr.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/switch_ivr.c b/src/switch_ivr.c index 2e154cba7c..fbc65ebaa3 100644 --- a/src/switch_ivr.c +++ b/src/switch_ivr.c @@ -1301,7 +1301,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_play_file(switch_core_session_t *sess } else { /* time off the channel (if you must) */ switch_frame_t *read_frame; switch_status_t status; - while (switch_channel_test_flag(channel, CF_HOLD)) { + while (switch_channel_ready(channel) && switch_channel_test_flag(channel, CF_HOLD)) { switch_yield(10000); } status = switch_core_session_read_frame(session, &read_frame, -1, 0); @@ -1604,7 +1604,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_speak_text_handle(switch_core_session switch_frame_t *read_frame; switch_status_t status = switch_core_session_read_frame(session, &read_frame, -1, 0); - while (switch_channel_test_flag(channel, CF_HOLD)) { + while (switch_channel_ready(channel) && switch_channel_test_flag(channel, CF_HOLD)) { switch_yield(10000); } @@ -1661,7 +1661,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_speak_text_handle(switch_core_session switch_frame_t *read_frame; switch_status_t status = switch_core_session_read_frame(session, &read_frame, -1, 0); - while (switch_channel_test_flag(channel, CF_HOLD)) { + while (switch_channel_ready(channel) && switch_channel_test_flag(channel, CF_HOLD)) { switch_yield(10000); }