diff options
author | russell <russell@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-03-17 15:31:14 +0000 |
---|---|---|
committer | russell <russell@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-03-17 15:31:14 +0000 |
commit | e0ab45a3ceb7ab1044a10cf6d3fd980da1593e3a (patch) | |
tree | 3ed32a3b3dceb247cd6c8fe5d53831d4565a8da8 /main | |
parent | 1c6243cf61ec6ac26774af840090910f57667592 (diff) |
Merged revisions 182553 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk
........
r182553 | russell | 2009-03-17 10:22:12 -0500 (Tue, 17 Mar 2009) | 5 lines
Tweak the handling of the frame list inside of ast_answer().
This does not change any behavior, but moves the frames from the local frame
list back to the channel read queue using an O(n) algorithm instead of O(n^2).
........
git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.6.1@182570 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'main')
-rw-r--r-- | main/channel.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/main/channel.c b/main/channel.c index 699d49568..bfdcee894 100644 --- a/main/channel.c +++ b/main/channel.c @@ -1776,7 +1776,7 @@ int __ast_answer(struct ast_channel *chan, unsigned int delay, int cdr_answer) ast_frfree(cur); } - AST_LIST_INSERT_TAIL(&frames, new, frame_list); + AST_LIST_INSERT_HEAD(&frames, new, frame_list); /* if a specific delay period was requested, continue * until that delay has passed. don't stop just because @@ -1812,8 +1812,7 @@ int __ast_answer(struct ast_channel *chan, unsigned int delay, int cdr_answer) if (res == 0) { ast_channel_lock(chan); - while ((cur = AST_LIST_LAST(&frames))) { - AST_LIST_REMOVE(&frames, cur, frame_list); + while ((cur = AST_LIST_REMOVE_HEAD(&frames, frame_list))) { ast_queue_frame_head(chan, cur); ast_frfree(cur); } |