From: Sébastien Escudier Date: Wed, 20 May 2009 07:32:57 +0000 (+0200) Subject: Free rtsp commands on close X-Git-Tag: 1.1.0-ff~5867^2~1 X-Git-Url: https://git.sesse.net/?a=commitdiff_plain;h=fe19e10c0db5b0e558d531a860d52f8248e071fe;p=vlc Free rtsp commands on close Signed-off-by: Rémi Denis-Courmont --- diff --git a/modules/misc/rtsp.c b/modules/misc/rtsp.c index 0dd3e93cce..ee23ed54d3 100644 --- a/modules/misc/rtsp.c +++ b/modules/misc/rtsp.c @@ -221,6 +221,17 @@ typedef enum RTSP_CMD_TYPE_FORWARD, } rtsp_cmd_type_t; +/* */ +typedef struct +{ + int i_type; + int i_media_id; + //vod_media_t *p_media; + char *psz_session; + char *psz_arg; + double f_arg; +} rtsp_cmd_t; + static vod_media_t *MediaNew( vod_t *, const char *, input_item_t * ); static void MediaDel( vod_t *, vod_media_t * ); static int MediaAddES( vod_t *, vod_media_t *, es_format_t * ); @@ -337,12 +348,22 @@ static void Close( vlc_object_t * p_this ) { vod_t *p_vod = (vod_t *)p_this; vod_sys_t *p_sys = p_vod->p_sys; + block_t *p_block_cmd; + rtsp_cmd_t cmd; /* Stop command thread */ vlc_object_kill( p_vod ); CommandPush( p_vod, RTSP_CMD_TYPE_NONE, NULL, NULL, 0.0, NULL ); vlc_thread_join( p_vod ); + while( block_FifoCount( p_sys->p_fifo_cmd ) > 0 ) + { + p_block_cmd = block_FifoGet( p_sys->p_fifo_cmd ); + memcpy( &cmd, p_block_cmd->p_buffer, sizeof(cmd) ); + block_Release( p_block_cmd ); + free( cmd.psz_session ); + free( cmd.psz_arg ); + } block_FifoRelease( p_sys->p_fifo_cmd ); httpd_HostDelete( p_sys->p_rtsp_host ); @@ -780,17 +801,6 @@ static void MediaDelES( vod_t *p_vod, vod_media_t *p_media, es_format_t *p_fmt) free( p_es ); } -/* */ -typedef struct -{ - int i_type; - int i_media_id; - //vod_media_t *p_media; - char *psz_session; - char *psz_arg; - double f_arg; -} rtsp_cmd_t; - static void CommandPush( vod_t *p_vod, rtsp_cmd_type_t i_type, vod_media_t *p_media, const char *psz_session, double f_arg, const char *psz_arg ) {