]> git.sesse.net Git - vlc/blob - src/input/input_clock.h
Fix potential memleak (CID 196)
[vlc] / src / input / input_clock.h
1 /*****************************************************************************
2  * clock.h: clocks synchronisation
3  *****************************************************************************
4  * Copyright (C) 2008 the VideoLAN team
5  * Copyright (C) 2008 Laurent Aimar
6  * $Id$
7  *
8  * Authors: Laurent Aimar < fenrir _AT_ videolan _DOT_ org >
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program; if not, write to the Free Software
22  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23  *****************************************************************************/
24
25 #if defined(__PLUGIN__) || defined(__BUILTIN__) || !defined(__LIBVLC__)
26 # error This header file can only be included from LibVLC.
27 #endif
28
29 #ifndef _INPUT_CLOCK_H
30 #define _INPUT_CLOCK_H 1
31
32 #include <vlc_common.h>
33
34 /** @struct input_clock_t
35  * This structure is used to manage clock drift and reception jitters
36  *
37  * XXX input_clock_GetTS can be called from any threads. All others functions
38  * MUST be called from one and only one thread.
39  */
40
41 /**
42  * This function creates a new input_clock_t.
43  * You must use input_clock_Delete to delete it once unused.
44  */
45 input_clock_t *input_clock_New( int i_cr_average, int i_rate );
46 /**
47  * This function destroys a input_clock_t created by input_clock_New.
48  */
49 void           input_clock_Delete( input_clock_t * );
50
51 /**
52  * This function will update a input_clock_t with a new clock reference point.
53  */
54 void    input_clock_Update( input_clock_t *, vlc_object_t *p_log,
55                             bool b_can_pace_control, mtime_t i_clock, mtime_t i_system );
56 /**
57  * This function will reset the drift of a input_clock_t.
58  *
59  * The actual jitter estimation will not be reseted by it.
60  */
61 void    input_clock_Reset( input_clock_t * );
62
63 /**
64  * This functions will return a deadline used to control the reading speed.
65  */
66 mtime_t input_clock_GetWakeup( input_clock_t * );
67
68 /**
69  * This functions allows to change the actual reading speed.
70  */
71 void    input_clock_ChangeRate( input_clock_t *, int i_rate );
72
73 /**
74  * This function allows to change the pause status.
75  */
76 void    input_clock_ChangePause( input_clock_t *, bool b_paused, mtime_t i_date );
77
78 /**
79  * This function allows to rebase the original system value date.
80  * It can be called only imediatly after a input_clock_Update call.
81  * FIXME ugly
82  */
83 void    input_clock_ChangeSystemOrigin( input_clock_t *, mtime_t i_system );
84
85 /**
86  * This function converts a timestamp from stream clock to system clock.
87  *
88  * If pi_rate is provided it will be field with the rate value used for
89  * the conversion.
90  */
91 mtime_t input_clock_GetTS( input_clock_t *, int *pi_rate, mtime_t i_pts_delay, mtime_t );
92
93 /**
94  * This function returns the current rate.
95  */
96 int input_clock_GetRate( input_clock_t * );
97
98 /**
99  * This function returns current clock state or VLC_EGENERIC if there is not a
100  * reference point.
101  */
102 int input_clock_GetState( input_clock_t *,
103                           mtime_t *pi_stream_start, mtime_t *pi_system_start,
104                           mtime_t *pi_stream_duration, mtime_t *pi_system_duration );
105
106 #endif
107