]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
don't set state to BUSY if the channel is already in the UP state
authorRussell Bryant <russell@russellbryant.com>
Sun, 18 Jun 2006 21:03:58 +0000 (21:03 +0000)
committerRussell Bryant <russell@russellbryant.com>
Sun, 18 Jun 2006 21:03:58 +0000 (21:03 +0000)
(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

diff --git a/pbx.c b/pbx.c
index c45ec8e3b9299162f840941e7ebed0da30162059..ad57810a9da72bcbf3f8ccc9471f0e044e405d16 100644 (file)
--- 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;
 }