From 1eb2822b3bde253ef8f5b829cb78eec791114b5c Mon Sep 17 00:00:00 2001 From: Russell Bryant Date: Sun, 18 Jun 2006 21:03:58 +0000 Subject: [PATCH] don't set state to BUSY if the channel is already in the UP state (issue #7376, backported from trunk) git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.2@34655 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- pbx.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/pbx.c b/pbx.c index c45ec8e3b9..ad57810a9d 100644 --- a/pbx.c +++ b/pbx.c @@ -5432,7 +5432,8 @@ static int pbx_builtin_ringing(struct ast_channel *chan, void *data) static int pbx_builtin_busy(struct ast_channel *chan, void *data) { ast_indicate(chan, AST_CONTROL_BUSY); - ast_setstate(chan, AST_STATE_BUSY); + if (chan->_state != AST_STATE_UP) + ast_setstate(chan, AST_STATE_BUSY); wait_for_hangup(chan, data); return -1; } @@ -5443,7 +5444,8 @@ static int pbx_builtin_busy(struct ast_channel *chan, void *data) static int pbx_builtin_congestion(struct ast_channel *chan, void *data) { ast_indicate(chan, AST_CONTROL_CONGESTION); - ast_setstate(chan, AST_STATE_BUSY); + if (chan->_state != AST_STATE_UP) + ast_setstate(chan, AST_STATE_BUSY); wait_for_hangup(chan, data); return -1; } -- 2.47.2