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
1.7.1