mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-26 06:26:41 +00:00 
			
		
		
		
	core: Reduce video update queueing.
A video update frame is used to indicate that a channel with video negotiated should provide a full frame so the decoder decoding the stream is able to do so. In situations where a queue is used to store frames it makes no sense for the queue to contain multiple video update frames. One is sufficient to have a full frame be sent. ASTERISK-27222 Change-Id: Id3f40a6f51b740ae4704003a1800185c0c658ee7
This commit is contained in:
		| @@ -58,6 +58,7 @@ struct asent { | ||||
| 	 *  it gets stopped for the last time. */ | ||||
| 	unsigned int use_count; | ||||
| 	unsigned int orig_end_dtmf_flag:1; | ||||
| 	unsigned int video_update:1; | ||||
| 	unsigned int ignore_frame_types; | ||||
| 	/*! Frames go on at the head of deferred_frames, so we have the frames | ||||
| 	 *  from newest to oldest.  As we put them at the head of the readq, we'll | ||||
| @@ -161,6 +162,17 @@ static void *autoservice_run(void *ign) | ||||
| 					AST_LIST_INSERT_HEAD(&ents[i]->deferred_frames, dup_f, frame_list); | ||||
| 				} | ||||
| 			} else { | ||||
| 				if (defer_frame->frametype == AST_FRAME_CONTROL && | ||||
| 					defer_frame->subclass.integer == AST_CONTROL_VIDUPDATE) { | ||||
|  | ||||
| 					/* If a video update is already queued don't needlessly queue another */ | ||||
| 					if (ents[i]->video_update) { | ||||
| 						ast_frfree(defer_frame); | ||||
| 						break; | ||||
| 					} | ||||
|  | ||||
| 					ents[i]->video_update = 1; | ||||
| 				} | ||||
| 				if ((dup_f = ast_frisolate(defer_frame))) { | ||||
| 					AST_LIST_INSERT_HEAD(&ents[i]->deferred_frames, dup_f, frame_list); | ||||
| 				} | ||||
|   | ||||
| @@ -330,7 +330,8 @@ int ast_unreal_write(struct ast_channel *ast, struct ast_frame *f) | ||||
| 		if (!ast_channel_get_default_stream(ast, AST_MEDIA_TYPE_AUDIO)) { | ||||
| 			return 0; | ||||
| 		} | ||||
| 	} else if (f->frametype == AST_FRAME_VIDEO) { | ||||
| 	} else if (f->frametype == AST_FRAME_VIDEO || | ||||
| 		(f->frametype == AST_FRAME_CONTROL && f->subclass.integer == AST_CONTROL_VIDUPDATE)) { | ||||
| 		if (!ast_channel_get_default_stream(ast, AST_MEDIA_TYPE_VIDEO)) { | ||||
| 			return 0; | ||||
| 		} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user