]> git.sesse.net Git - vlc/commitdiff
decoder: add input_DecoderFlush()
authorRémi Denis-Courmont <remi@remlab.net>
Sat, 21 Mar 2015 15:57:46 +0000 (17:57 +0200)
committerRémi Denis-Courmont <remi@remlab.net>
Sat, 21 Mar 2015 16:52:00 +0000 (18:52 +0200)
include/vlc_input.h
src/input/decoder.c
src/libvlccore.sym

index c18bea6710908a66eab6148840f727ebd878dec7..a6ea43296f7a6ab4f1e410063e6477f2ac1ee3f9 100644 (file)
@@ -617,6 +617,7 @@ static inline int input_ModifyPcrSystem( input_thread_t *p_input, bool b_absolut
 VLC_API decoder_t * input_DecoderCreate( vlc_object_t *, const es_format_t *, input_resource_t * ) VLC_USED;
 VLC_API void input_DecoderDelete( decoder_t * );
 VLC_API void input_DecoderDecode( decoder_t *, block_t *, bool b_do_pace );
+VLC_API void input_DecoderFlush( decoder_t * );
 
 /**
  * This function creates a sane filename path.
index b5ac4646de10381bc6927fccecc58f30336c4783..8cb162c4d3f476d0fc54b4fdca037392b66d5466 100644 (file)
@@ -514,15 +514,28 @@ void input_DecoderChangeDelay( decoder_t *p_dec, mtime_t i_delay )
     vlc_mutex_unlock( &p_owner->lock );
 }
 
+/**
+ * Requests that the decoder immediately discard all pending buffers.
+ * This is useful at end of stream, when seeking or when deselecting a stream.
+ */
+void input_DecoderFlush( decoder_t *p_dec )
+{
+    decoder_owner_sys_t *p_owner = p_dec->p_owner;
+
+    vlc_mutex_lock( &p_owner->lock );
+    DecoderFlush( p_dec );
+    vlc_mutex_unlock( &p_owner->lock );
+}
+
 void input_DecoderStartWait( decoder_t *p_dec )
 {
     decoder_owner_sys_t *p_owner = p_dec->p_owner;
 
     assert( !p_owner->b_waiting );
 
-    vlc_mutex_lock( &p_owner->lock );
-    DecoderFlush( p_dec );
+    input_DecoderFlush( p_dec );
 
+    vlc_mutex_lock( &p_owner->lock );
     p_owner->b_first = true;
     p_owner->b_has_data = false;
     p_owner->b_waiting = true;
@@ -579,6 +592,7 @@ void input_DecoderFrameNext( decoder_t *p_dec, mtime_t *pi_duration )
     else
     {
         /* TODO subtitle should not be flushed */
+        p_owner->b_waiting = false;
         DecoderFlush( p_dec );
     }
     vlc_mutex_unlock( &p_owner->lock );
@@ -942,7 +956,6 @@ static void DecoderFlush( decoder_t *p_dec )
     /* Empty the fifo */
     block_FifoEmpty( p_owner->p_fifo );
 
-    p_owner->b_waiting = false;
     /* Monitor for flush end */
     p_owner->b_flushing = true;
     vlc_cond_signal( &p_owner->wait_request );
index 13427baa3a12089c1f566588065ed4ddd77864a2..3cc89b56f8dac4a8bab41543159d3cc2625f4dde 100644 (file)
@@ -174,9 +174,10 @@ input_Control
 input_Create
 input_CreateAndStart
 input_CreateFilename
-input_DecoderDecode
-input_DecoderDelete
 input_DecoderCreate
+input_DecoderDelete
+input_DecoderDecode
+input_DecoderFlush
 input_GetItem
 input_item_AddInfo
 input_item_AddOption