clock.h

Go to the documentation of this file.
00001 /*****************************************************************************
00002  * clock.h: clocks synchronisation
00003  *****************************************************************************
00004  * Copyright (C) 2008 VLC authors and VideoLAN
00005  * Copyright (C) 2008 Laurent Aimar
00006  * $Id: ee1492ba7af8eba578a8ce822e3a223817609ab4 $
00007  *
00008  * Authors: Laurent Aimar < fenrir _AT_ videolan _DOT_ org >
00009  *
00010  * This program is free software; you can redistribute it and/or modify it
00011  * under the terms of the GNU Lesser General Public License as published by
00012  * the Free Software Foundation; either version 2.1 of the License, or
00013  * (at your option) any later version.
00014  *
00015  * This program is distributed in the hope that it will be useful,
00016  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00017  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
00018  * GNU Lesser General Public License for more details.
00019  *
00020  * You should have received a copy of the GNU Lesser General Public License
00021  * along with this program; if not, write to the Free Software Foundation,
00022  * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
00023  *****************************************************************************/
00024 
00025 #ifndef LIBVLC_INPUT_CLOCK_H
00026 #define LIBVLC_INPUT_CLOCK_H 1
00027 
00028 #include <vlc_common.h>
00029 #include <vlc_input.h> /* FIXME Needed for input_clock_t */
00030 
00031 /** @struct input_clock_t
00032  * This structure is used to manage clock drift and reception jitters
00033  *
00034  * XXX input_clock_GetTS can be called from any threads. All others functions
00035  * MUST be called from one and only one thread.
00036  */
00037 typedef struct input_clock_t input_clock_t;
00038 
00039 /**
00040  * This function creates a new input_clock_t.
00041  * You must use input_clock_Delete to delete it once unused.
00042  */
00043 input_clock_t *input_clock_New( int i_rate );
00044 
00045 /**
00046  * This function destroys a input_clock_t created by input_clock_New.
00047  */
00048 void           input_clock_Delete( input_clock_t * );
00049 
00050 /**
00051  * This function will update a input_clock_t with a new clock reference point.
00052  * It will also tell if the clock point is late regarding our buffering.
00053  *
00054  * \param b_buffering_allowed tells if we are allowed to bufferize more data in
00055  * advanced (if possible).
00056  */
00057 void    input_clock_Update( input_clock_t *, vlc_object_t *p_log,
00058                             bool *pb_late,
00059                             bool b_can_pace_control, bool b_buffering_allowed,
00060                             mtime_t i_clock, mtime_t i_system );
00061 /**
00062  * This function will reset the drift of a input_clock_t.
00063  *
00064  * The actual jitter estimation will not be reseted by it.
00065  */
00066 void    input_clock_Reset( input_clock_t * );
00067 
00068 /**
00069  * This functions will return a deadline used to control the reading speed.
00070  */
00071 mtime_t input_clock_GetWakeup( input_clock_t * );
00072 
00073 /**
00074  * This functions allows changing the actual reading speed.
00075  */
00076 void    input_clock_ChangeRate( input_clock_t *, int i_rate );
00077 
00078 /**
00079  * This function allows changing the pause status.
00080  */
00081 void    input_clock_ChangePause( input_clock_t *, bool b_paused, mtime_t i_date );
00082 
00083 /**
00084  * This function returns the original system value date and the delay for the current
00085  * reference point (a valid reference point must have been set).
00086  */
00087 void    input_clock_GetSystemOrigin( input_clock_t *, mtime_t *pi_system, mtime_t *pi_delay );
00088 
00089 /**
00090  * This function allows rebasing the original system value date (a valid
00091  * reference point must have been set).
00092  * When using the absolute mode, it will create a discontinuity unless
00093  * called imediatly after a input_clock_Update.
00094  */
00095 void    input_clock_ChangeSystemOrigin( input_clock_t *, bool b_absolute, mtime_t i_system );
00096 
00097 /**
00098  * This function converts a pair of timestamp from stream clock to system clock.
00099  *
00100  * If pi_rate is provided it will be filled with the rate value used for
00101  * the conversion.
00102  * p_ts0 is a pointer to a timestamp to be converted (in place) and must be non NULL.
00103  * p_ts1 is a pointer to a timestamp to be converted (in place) and can be NULL.
00104  *
00105  * It will return VLC_EGENERIC if i_ts_bound is not INT64_MAX and if the value *p_ts0
00106  * after conversion is not before the deadline mdate() + i_pts_delay + i_ts_bound.
00107  * It will also return VLC_EGENERIC if the conversion cannot be done successfully. In
00108  * this case, *p_ts0 and *p_ts1 will hold an invalid timestamp.
00109  * Otherwise it will return VLC_SUCCESS.
00110  */
00111 int input_clock_ConvertTS( input_clock_t *, int *pi_rate, mtime_t *pi_ts0, mtime_t *pi_ts1, mtime_t i_ts_bound );
00112 
00113 /**
00114  * This function returns the current rate.
00115  */
00116 int input_clock_GetRate( input_clock_t * );
00117 
00118 /**
00119  * This function returns current clock state or VLC_EGENERIC if there is not a
00120  * reference point.
00121  */
00122 int input_clock_GetState( input_clock_t *,
00123                           mtime_t *pi_stream_start, mtime_t *pi_system_start,
00124                           mtime_t *pi_stream_duration, mtime_t *pi_system_duration );
00125 
00126 /**
00127  * This function allows the set the minimal configuration for the jitter estimation algo.
00128  */
00129 void input_clock_SetJitter( input_clock_t *,
00130                             mtime_t i_pts_delay, int i_cr_average );
00131 
00132 /**
00133  * This function returns an estimation of the pts_delay needed to avoid rebufferization.
00134  * XXX in the current implementation, the pts_delay will never be decreased.
00135  */
00136 mtime_t input_clock_GetJitter( input_clock_t * );
00137 
00138 #endif
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Defines