input_clock.h 2.58 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
/*****************************************************************************
 * clock.h: clocks synchronisation
 *****************************************************************************
 * Copyright (C) 2008 the VideoLAN team
 * Copyright (C) 2008 Laurent Aimar
 * $Id$
 *
 * Authors: Laurent Aimar < fenrir _AT_ videolan _DOT_ org >
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
 *****************************************************************************/

#if defined(__PLUGIN__) || defined(__BUILTIN__) || !defined(__LIBVLC__)
# error This header file can only be included from LibVLC.
#endif

#ifndef _INPUT_CLOCK_H
#define _INPUT_CLOCK_H 1

#include <vlc_common.h>

34 35 36
/**
 * This structure is used to manage clock drift and reception jitters
 */
37 38
typedef struct input_clock_t input_clock_t;

39 40 41 42
/**
 * This function creates a new input_clock_t.
 * You must use input_clock_Delete to delete it once unused.
 */
43
input_clock_t *input_clock_New( int i_cr_average, int i_rate );
44 45 46
/**
 * This function destroys a input_clock_t created by input_clock_New.
 */
47 48
void           input_clock_Delete( input_clock_t * );

49 50 51 52
/**
 * This function will update a input_clock_t with a new clock reference point.
 */
void    input_clock_Update( input_clock_t *, vlc_object_t *p_log,
53
                            bool b_can_pace_control, mtime_t i_clock, mtime_t i_system );
54 55 56 57 58 59 60 61 62 63
/**
 * This function will reset the drift of a input_clock_t.
 *
 * The actual jitter estimation will not be reseted by it.
 */
void    input_clock_Reset( input_clock_t * );

/**
 * This functions will return a deadline used to control the reading speed.
 */
64
mtime_t input_clock_GetWakeup( input_clock_t *cl );
65

66 67 68 69
/**
 * This functions allows to change the actual reading speed.
 */
void    input_clock_ChangeRate( input_clock_t *cl, int i_rate );
70

71
/**
72
 * This function converts a timestamp from stream clock to system clock.
73
 */
74
mtime_t input_clock_GetTS( input_clock_t *, mtime_t i_pts_delay, mtime_t );
75 76 77

#endif