[svn-commits] russell: branch 1.6.0 r182569 - in /branches/1.6.0:	./ main/channel.c
    SVN commits to the Digium repositories 
    svn-commits at lists.digium.com
       
    Tue Mar 17 10:27:34 CDT 2009
    
    
  
Author: russell
Date: Tue Mar 17 10:27:27 2009
New Revision: 182569
URL: http://svn.digium.com/svn-view/asterisk?view=rev&rev=182569
Log:
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).
........
Modified:
    branches/1.6.0/   (props changed)
    branches/1.6.0/main/channel.c
Propchange: branches/1.6.0/
------------------------------------------------------------------------------
Binary property 'trunk-merged' - no diff available.
Modified: branches/1.6.0/main/channel.c
URL: http://svn.digium.com/svn-view/asterisk/branches/1.6.0/main/channel.c?view=diff&rev=182569&r1=182568&r2=182569
==============================================================================
--- branches/1.6.0/main/channel.c (original)
+++ branches/1.6.0/main/channel.c Tue Mar 17 10:27:27 2009
@@ -1788,7 +1788,7 @@
 					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
@@ -1824,8 +1824,7 @@
 
 			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);
 				}
    
    
More information about the svn-commits
mailing list