mirror of https://code.videolan.org/videolan/vlc
input_clock: remove useless mutex
It is now always accessed from es_out.c and protected with the es_out mutex.
This commit is contained in:
parent
0b68f2cf79
commit
e0930c2b65
|
@ -104,9 +104,6 @@
|
|||
/* */
|
||||
struct input_clock_t
|
||||
{
|
||||
/* */
|
||||
vlc_mutex_t lock;
|
||||
|
||||
/* Last point
|
||||
* It is used to detect unexpected stream discontinuities */
|
||||
clock_point_t last;
|
||||
|
@ -154,7 +151,6 @@ input_clock_t *input_clock_New( float rate )
|
|||
if( !cl )
|
||||
return NULL;
|
||||
|
||||
vlc_mutex_init( &cl->lock );
|
||||
cl->b_has_reference = false;
|
||||
cl->ref = clock_point_Create( VLC_TICK_INVALID, VLC_TICK_INVALID );
|
||||
cl->b_has_external_clock = false;
|
||||
|
@ -201,8 +197,6 @@ vlc_tick_t input_clock_Update( input_clock_t *cl, vlc_object_t *p_log,
|
|||
|
||||
assert( i_ck_stream != VLC_TICK_INVALID && i_ck_system != VLC_TICK_INVALID );
|
||||
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
if( !cl->b_has_reference )
|
||||
{
|
||||
/* */
|
||||
|
@ -277,8 +271,6 @@ vlc_tick_t input_clock_Update( input_clock_t *cl, vlc_object_t *p_log,
|
|||
cl->late.i_index = ( cl->late.i_index + 1 ) % INPUT_CLOCK_LATE_COUNT;
|
||||
}
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
|
||||
return i_late;
|
||||
}
|
||||
|
||||
|
@ -287,13 +279,9 @@ vlc_tick_t input_clock_Update( input_clock_t *cl, vlc_object_t *p_log,
|
|||
*****************************************************************************/
|
||||
void input_clock_Reset( input_clock_t *cl )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
cl->b_has_reference = false;
|
||||
cl->ref = clock_point_Create( VLC_TICK_INVALID, VLC_TICK_INVALID );
|
||||
cl->b_has_external_clock = false;
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
|
@ -301,8 +289,6 @@ void input_clock_Reset( input_clock_t *cl )
|
|||
*****************************************************************************/
|
||||
void input_clock_ChangeRate( input_clock_t *cl, float rate )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
if( cl->b_has_reference )
|
||||
{
|
||||
/* Move the reference point (as if we were playing at the new rate
|
||||
|
@ -310,8 +296,6 @@ void input_clock_ChangeRate( input_clock_t *cl, float rate )
|
|||
cl->ref.system = cl->last.system - (vlc_tick_t) ((cl->last.system - cl->ref.system) / rate * cl->rate);
|
||||
}
|
||||
cl->rate = rate;
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
|
@ -319,7 +303,6 @@ void input_clock_ChangeRate( input_clock_t *cl, float rate )
|
|||
*****************************************************************************/
|
||||
void input_clock_ChangePause( input_clock_t *cl, bool b_paused, vlc_tick_t i_date )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
assert( (!cl->b_paused) != (!b_paused) );
|
||||
|
||||
if( cl->b_paused )
|
||||
|
@ -334,8 +317,6 @@ void input_clock_ChangePause( input_clock_t *cl, bool b_paused, vlc_tick_t i_dat
|
|||
}
|
||||
cl->i_pause_date = i_date;
|
||||
cl->b_paused = b_paused;
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
|
@ -345,14 +326,10 @@ vlc_tick_t input_clock_GetWakeup( input_clock_t *cl )
|
|||
{
|
||||
vlc_tick_t i_wakeup = 0;
|
||||
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
/* Synchronized, we can wait */
|
||||
if( cl->b_has_reference )
|
||||
i_wakeup = ClockStreamToSystem( cl, cl->last.stream + AvgGet( &cl->drift ) - cl->i_buffering_duration );
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
|
||||
return i_wakeup;
|
||||
}
|
||||
|
||||
|
@ -361,24 +338,15 @@ vlc_tick_t input_clock_GetWakeup( input_clock_t *cl )
|
|||
*****************************************************************************/
|
||||
float input_clock_GetRate( input_clock_t *cl )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
float rate = cl->rate;
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
|
||||
return rate;
|
||||
return cl->rate;
|
||||
}
|
||||
|
||||
int input_clock_GetState( input_clock_t *cl,
|
||||
vlc_tick_t *pi_stream_start, vlc_tick_t *pi_system_start,
|
||||
vlc_tick_t *pi_stream_duration, vlc_tick_t *pi_system_duration )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
if( !cl->b_has_reference )
|
||||
{
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
return VLC_EGENERIC;
|
||||
}
|
||||
|
||||
*pi_stream_start = cl->ref.stream;
|
||||
*pi_system_start = cl->ref.system;
|
||||
|
@ -386,15 +354,11 @@ int input_clock_GetState( input_clock_t *cl,
|
|||
*pi_stream_duration = cl->last.stream - cl->ref.stream;
|
||||
*pi_system_duration = cl->last.system - cl->ref.system;
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
|
||||
return VLC_SUCCESS;
|
||||
}
|
||||
|
||||
void input_clock_ChangeSystemOrigin( input_clock_t *cl, bool b_absolute, vlc_tick_t i_system )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
assert( cl->b_has_reference );
|
||||
vlc_tick_t i_offset;
|
||||
if( b_absolute )
|
||||
|
@ -413,29 +377,21 @@ void input_clock_ChangeSystemOrigin( input_clock_t *cl, bool b_absolute, vlc_tic
|
|||
|
||||
cl->ref.system += i_offset;
|
||||
cl->last.system += i_offset;
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
}
|
||||
|
||||
void input_clock_GetSystemOrigin( input_clock_t *cl, vlc_tick_t *pi_system, vlc_tick_t *pi_delay )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
assert( cl->b_has_reference );
|
||||
|
||||
*pi_system = cl->ref.system;
|
||||
if( pi_delay )
|
||||
*pi_delay = cl->i_pts_delay;
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
}
|
||||
|
||||
#warning "input_clock_SetJitter needs more work"
|
||||
void input_clock_SetJitter( input_clock_t *cl,
|
||||
vlc_tick_t i_pts_delay, int i_cr_average )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
/* Update late observations */
|
||||
const vlc_tick_t i_delay_delta = i_pts_delay - cl->i_pts_delay;
|
||||
vlc_tick_t pi_late[INPUT_CLOCK_LATE_COUNT];
|
||||
|
@ -466,14 +422,10 @@ void input_clock_SetJitter( input_clock_t *cl,
|
|||
|
||||
if( cl->drift.range != i_cr_average )
|
||||
AvgRescale( &cl->drift, i_cr_average );
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
}
|
||||
|
||||
vlc_tick_t input_clock_GetJitter( input_clock_t *cl )
|
||||
{
|
||||
vlc_mutex_lock( &cl->lock );
|
||||
|
||||
#if INPUT_CLOCK_LATE_COUNT != 3
|
||||
# error "unsupported INPUT_CLOCK_LATE_COUNT"
|
||||
#endif
|
||||
|
@ -487,8 +439,6 @@ vlc_tick_t input_clock_GetJitter( input_clock_t *cl )
|
|||
vlc_tick_t i_late_median = p[0] + p[1] + p[2] - __MIN(__MIN(p[0],p[1]),p[2]) - __MAX(__MAX(p[0],p[1]),p[2]);
|
||||
vlc_tick_t i_pts_delay = cl->i_pts_delay ;
|
||||
|
||||
vlc_mutex_unlock( &cl->lock );
|
||||
|
||||
return i_pts_delay + i_late_median;
|
||||
}
|
||||
|
||||
|
|
|
@ -30,7 +30,7 @@
|
|||
/** @struct input_clock_t
|
||||
* This structure is used to manage clock drift and reception jitters
|
||||
*
|
||||
* All functions MUST be called from one and only one thread.
|
||||
* This API is reentrant but not thread-safe.
|
||||
*/
|
||||
typedef struct input_clock_t input_clock_t;
|
||||
|
||||
|
|
Loading…
Reference in New Issue