Commit 7adcf5f7 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

input: do not update timings & stats if paused

The values will typically not change while waiting for control requests
and not processing the demux and outputs. Even if the values do change
(e.g. due to a seek request), the demux needs to be called to recompute
the updated values: see demux_Control() calls in MainLoopStatistics().

Note that the intrinsic computational savings from this commit are
probably negligible. The interesting aspect is the removal of one
wake-up source within the input control loop. This commit does not
remove nor add any wake-up however.
parent 327ea9c1
...@@ -686,7 +686,6 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive ) ...@@ -686,7 +686,6 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive )
{ {
mtime_t i_wakeup = 0; mtime_t i_wakeup = 0;
bool b_demux_polled = true; bool b_demux_polled = true;
bool b_force_update = false;
bool b_paused = p_input->p->i_state == PAUSE_S; bool b_paused = p_input->p->i_state == PAUSE_S;
/* FIXME if p_input->p->i_state == PAUSE_S the access/access_demux /* FIXME if p_input->p->i_state == PAUSE_S the access/access_demux
* is paused -> this may cause problem with some of them * is paused -> this may cause problem with some of them
...@@ -698,9 +697,14 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive ) ...@@ -698,9 +697,14 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive )
{ {
if( !p_input->p->input.b_eof ) if( !p_input->p->input.b_eof )
{ {
MainLoopDemux( p_input, &b_force_update, &b_demux_polled, i_start_mdate ); bool b_force_update = false;
MainLoopDemux( p_input, &b_force_update, &b_demux_polled,
i_start_mdate );
i_wakeup = es_out_GetWakeup( p_input->p->p_es_out ); i_wakeup = es_out_GetWakeup( p_input->p->p_es_out );
if( b_force_update )
i_intf_update = 0;
} }
else if( !es_out_GetEmpty( p_input->p->p_es_out ) ) else if( !es_out_GetEmpty( p_input->p->p_es_out ) )
{ {
...@@ -724,6 +728,14 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive ) ...@@ -724,6 +728,14 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive )
break; break;
b_pause_after_eof = var_GetBool( p_input, "play-and-pause" ); b_pause_after_eof = var_GetBool( p_input, "play-and-pause" );
} }
/* Update interface and statistics */
mtime_t now = mdate();
if( now >= i_intf_update )
{
MainLoopStatistics( p_input );
i_intf_update = now + INT64_C(250000);
}
} }
/* */ /* */
...@@ -732,7 +744,8 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive ) ...@@ -732,7 +744,8 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive )
do { do {
mtime_t i_deadline = i_wakeup; mtime_t i_deadline = i_wakeup;
if( b_paused || !b_demux_polled ) if( b_paused || !b_demux_polled )
i_deadline = i_intf_update; /* FIXME: remove this polling */
i_deadline = mdate() + INT64_C(250000);
/* Handle control */ /* Handle control */
for( ;; ) for( ;; )
...@@ -771,20 +784,12 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive ) ...@@ -771,20 +784,12 @@ static void MainLoop( input_thread_t *p_input, bool b_interactive )
{ {
if( ControlIsSeekRequest( i_type ) ) if( ControlIsSeekRequest( i_type ) )
i_last_seek_mdate = mdate(); i_last_seek_mdate = mdate();
b_force_update = true; i_intf_update = 0;
} }
} }
/* Update interface and statistics */
now = mdate();
if( now >= i_intf_update || b_force_update )
{
MainLoopStatistics( p_input );
i_intf_update = now + INT64_C(250000);
b_force_update = false;
}
/* Update the wakeup time */ /* Update the wakeup time */
now = mdate();
if( i_wakeup != 0 ) if( i_wakeup != 0 )
i_wakeup = es_out_GetWakeup( p_input->p->p_es_out ); i_wakeup = es_out_GetWakeup( p_input->p->p_es_out );
} while( now < i_wakeup ); } while( now < i_wakeup );
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment