VLC  4.0.0-dev
input_clock.h
Go to the documentation of this file.
1 /*****************************************************************************
2  * input_clock.h: Input clocks synchronisation
3  *****************************************************************************
4  * Copyright (C) 2008-2018 VLC authors and VideoLAN
5  * Copyright (C) 2008 Laurent Aimar
6  *
7  * Authors: Laurent Aimar < fenrir _AT_ videolan _DOT_ org >
8  *
9  * This program is free software; you can redistribute it and/or modify it
10  * under the terms of the GNU Lesser General Public License as published by
11  * the Free Software Foundation; either version 2.1 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  * GNU Lesser General Public License for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public License
20  * along with this program; if not, write to the Free Software Foundation,
21  * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
22  *****************************************************************************/
23 
24 #ifndef LIBVLC_INPUT_CLOCK_H
25 #define LIBVLC_INPUT_CLOCK_H 1
26 
27 #include <vlc_common.h>
28 #include <vlc_input.h> /* FIXME Needed for input_clock_t */
29 
30 /** @struct input_clock_t
31  * This structure is used to manage clock drift and reception jitters
32  *
33  * XXX input_clock_ConvertTS can be called from any threads. All others functions
34  * MUST be called from one and only one thread.
35  */
37 
38 /**
39  * This function creates a new input_clock_t.
40  * You must use input_clock_Delete to delete it once unused.
41  */
43 
44 /**
45  * This function destroys a input_clock_t created by input_clock_New.
46  */
48 
49 /**
50  * This function will update a input_clock_t with a new clock reference point.
51  * It will also tell if the clock point is late regarding our buffering.
52  *
53  * \param b_buffering_allowed tells if we are allowed to bufferize more data in
54  * advanced (if possible).
55  * \return clock update delay
56  */
58  bool b_can_pace_control, bool b_buffering_allowed,
59  vlc_tick_t i_clock, vlc_tick_t i_system );
60 /**
61  * This function will reset the drift of a input_clock_t.
62  *
63  * The actual jitter estimation will not be reseted by it.
64  */
66 
67 /**
68  * This functions will return a deadline used to control the reading speed.
69  */
71 
72 /**
73  * This functions allows changing the actual reading speed.
74  */
76 
77 /**
78  * This function allows changing the pause status.
79  */
81 
82 /**
83  * This function returns the original system value date and the delay for the current
84  * reference point (a valid reference point must have been set).
85  */
86 void input_clock_GetSystemOrigin( input_clock_t *, vlc_tick_t *pi_system, vlc_tick_t *pi_delay );
87 
88 /**
89  * This function allows rebasing the original system value date (a valid
90  * reference point must have been set).
91  * When using the absolute mode, it will create a discontinuity unless
92  * called imediatly after a input_clock_Update.
93  */
94 void input_clock_ChangeSystemOrigin( input_clock_t *, bool b_absolute, vlc_tick_t i_system );
95 
96 /**
97  * This function converts a pair of timestamp from stream clock to system clock.
98  *
99  * If p_rate is provided it will be filled with the rate value used for
100  * the conversion.
101  * p_ts0 is a pointer to a timestamp to be converted (in place) and must be non NULL.
102  * p_ts1 is a pointer to a timestamp to be converted (in place) and can be NULL.
103  *
104  * It will return VLC_EGENERIC if i_ts_bound is not INT64_MAX and if the value *p_ts0
105  * after conversion is not before the deadline vlc_tick_now() + i_pts_delay + i_ts_bound.
106  * It will also return VLC_EGENERIC if the conversion cannot be done successfully. In
107  * this case, *p_ts0 and *p_ts1 will hold an invalid timestamp.
108  * Otherwise it will return VLC_SUCCESS.
109  */
110 int input_clock_ConvertTS( vlc_object_t *, input_clock_t *, float *p_rate,
111  vlc_tick_t *pi_ts0, vlc_tick_t *pi_ts1, vlc_tick_t i_ts_bound );
112 
113 /**
114  * This function returns the current rate.
115  */
117 
118 /**
119  * This function returns current clock state or VLC_EGENERIC if there is not a
120  * reference point.
121  */
123  vlc_tick_t *pi_stream_start, vlc_tick_t *pi_system_start,
124  vlc_tick_t *pi_stream_duration, vlc_tick_t *pi_system_duration );
125 
126 /**
127  * This function allows the set the minimal configuration for the jitter estimation algo.
128  */
130  vlc_tick_t i_pts_delay, int i_cr_average );
131 
132 /**
133  * This function returns an estimation of the pts_delay needed to avoid rebufferization.
134  * XXX in the current implementation, the pts_delay will never be decreased.
135  */
137 
138 #endif
void input_clock_SetJitter(input_clock_t *, vlc_tick_t i_pts_delay, int i_cr_average)
This function allows the set the minimal configuration for the jitter estimation algo.
Definition: input_clock.c:500
int input_clock_ConvertTS(vlc_object_t *, input_clock_t *, float *p_rate, vlc_tick_t *pi_ts0, vlc_tick_t *pi_ts1, vlc_tick_t i_ts_bound)
This function converts a pair of timestamp from stream clock to system clock.
Definition: input_clock.c:369
void input_clock_GetSystemOrigin(input_clock_t *, vlc_tick_t *pi_system, vlc_tick_t *pi_delay)
This function returns the original system value date and the delay for the current reference point (a...
Definition: input_clock.c:486
This file is a collection of common definitions and types.
void input_clock_ChangePause(input_clock_t *, bool b_paused, vlc_tick_t i_date)
This function allows changing the pause status.
Definition: input_clock.c:327
void input_clock_ChangeRate(input_clock_t *, float rate)
This functions allows changing the actual reading speed.
Definition: input_clock.c:309
void input_clock_ChangeSystemOrigin(input_clock_t *, bool b_absolute, vlc_tick_t i_system)
This function allows rebasing the original system value date (a valid reference point must have been ...
Definition: input_clock.c:460
vlc_tick_t i_pts_delay
Definition: input_clock.c:142
void input_clock_Reset(input_clock_t *)
This function will reset the drift of a input_clock_t.
Definition: input_clock.c:294
void input_clock_Delete(input_clock_t *)
This function destroys a input_clock_t created by input_clock_New.
Definition: input_clock.c:189
int64_t vlc_tick_t
High precision date or time interval.
Definition: vlc_tick.h:45
vlc_tick_t input_clock_Update(input_clock_t *, vlc_object_t *p_log, bool b_can_pace_control, bool b_buffering_allowed, vlc_tick_t i_clock, vlc_tick_t i_system)
This function will update a input_clock_t with a new clock reference point.
Definition: input_clock.c:201
vlc_tick_t input_clock_GetWakeup(input_clock_t *)
This functions will return a deadline used to control the reading speed.
Definition: input_clock.c:351
vlc_tick_t input_clock_GetJitter(input_clock_t *)
This function returns an estimation of the pts_delay needed to avoid rebufferization.
Definition: input_clock.c:539
float rate
Definition: input_clock.c:141
input_clock_t * input_clock_New(float rate)
This function creates a new input_clock_t.
Definition: input_clock.c:154
int input_clock_GetState(input_clock_t *, vlc_tick_t *pi_stream_start, vlc_tick_t *pi_system_start, vlc_tick_t *pi_stream_duration, vlc_tick_t *pi_system_duration)
This function returns current clock state or VLC_EGENERIC if there is not a reference point...
Definition: input_clock.c:437
bool b_paused
Definition: input_clock.c:140
Input thread interface.
VLC object common members.
Definition: vlc_objects.h:43
This structure is used to manage clock drift and reception jitters.
Definition: input_clock.c:105
float input_clock_GetRate(input_clock_t *)
This function returns the current rate.
Definition: input_clock.c:428