demux: mp4: remove unused chunk sample index
[vlc.git] / src / clock / input_clock.h
blobf9a74f08096449744012c041e69bc9efb1fb1aca
1 /*****************************************************************************
2 * input_clock.h: Input clocks synchronisation
3 *****************************************************************************
4 * Copyright (C) 2008-2018 VLC authors and VideoLAN
5 * Copyright (C) 2008 Laurent Aimar
7 * Authors: Laurent Aimar < fenrir _AT_ videolan _DOT_ org >
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.
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.
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 *****************************************************************************/
24 #ifndef LIBVLC_INPUT_CLOCK_H
25 #define LIBVLC_INPUT_CLOCK_H 1
27 #include <vlc_common.h>
28 #include <vlc_input.h> /* FIXME Needed for input_clock_t */
30 /** @struct input_clock_t
31 * This structure is used to manage clock drift and reception jitters
33 * This API is reentrant but not thread-safe.
35 typedef struct input_clock_t input_clock_t;
37 /**
38 * This function creates a new input_clock_t.
39 * You must use input_clock_Delete to delete it once unused.
41 input_clock_t *input_clock_New( float rate );
43 /**
44 * This function destroys a input_clock_t created by input_clock_New.
46 void input_clock_Delete( input_clock_t * );
48 /**
49 * This function will update a input_clock_t with a new clock reference point.
50 * It will also tell if the clock point is late regarding our buffering.
52 * \param b_buffering_allowed tells if we are allowed to bufferize more data in
53 * advanced (if possible).
54 * \return clock update delay
56 vlc_tick_t input_clock_Update( input_clock_t *, vlc_object_t *p_log,
57 bool b_can_pace_control, bool b_buffering_allowed,
58 vlc_tick_t i_clock, vlc_tick_t i_system );
59 /**
60 * This function will reset the drift of a input_clock_t.
62 * The actual jitter estimation will not be reseted by it.
64 void input_clock_Reset( input_clock_t * );
66 /**
67 * This functions will return a deadline used to control the reading speed.
69 vlc_tick_t input_clock_GetWakeup( input_clock_t * );
71 /**
72 * This functions allows changing the actual reading speed.
74 void input_clock_ChangeRate( input_clock_t *, float rate );
76 /**
77 * This function allows changing the pause status.
79 void input_clock_ChangePause( input_clock_t *, bool b_paused, vlc_tick_t i_date );
81 /**
82 * This function returns the original system value date and the delay for the current
83 * reference point (a valid reference point must have been set).
85 void input_clock_GetSystemOrigin( input_clock_t *, vlc_tick_t *pi_system, vlc_tick_t *pi_delay );
87 /**
88 * This function allows rebasing the original system value date (a valid
89 * reference point must have been set).
90 * When using the absolute mode, it will create a discontinuity unless
91 * called imediatly after a input_clock_Update.
93 void input_clock_ChangeSystemOrigin( input_clock_t *, bool b_absolute, vlc_tick_t i_system );
95 /**
96 * This function returns the current rate.
98 float input_clock_GetRate( input_clock_t * );
101 * This function returns current clock state or VLC_EGENERIC if there is not a
102 * reference point.
104 int input_clock_GetState( input_clock_t *,
105 vlc_tick_t *pi_stream_start, vlc_tick_t *pi_system_start,
106 vlc_tick_t *pi_stream_duration, vlc_tick_t *pi_system_duration );
109 * This function allows the set the minimal configuration for the jitter estimation algo.
111 void input_clock_SetJitter( input_clock_t *,
112 vlc_tick_t i_pts_delay, int i_cr_average );
115 * This function returns an estimation of the pts_delay needed to avoid rebufferization.
116 * XXX in the current implementation, the pts_delay will never be decreased.
118 vlc_tick_t input_clock_GetJitter( input_clock_t * );
120 #endif