VLC 4.0.0-dev
Loading...
Searching...
No Matches
input_clock.h
Go to the documentation of this file.
1/*****************************************************************************
2 * input_clock.h: Input clocks synchronisation
3 *****************************************************************************
4 * Copyright (C) 2008-2018 VLC authors and VideoLAN
5 * Copyright (C) 2008 Laurent Aimar
6 *
7 * Authors: Laurent Aimar < fenrir _AT_ videolan _DOT_ org >
8 *
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.
13 *
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.
18 *
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 *****************************************************************************/
23
24#ifndef LIBVLC_INPUT_CLOCK_H
25#define LIBVLC_INPUT_CLOCK_H 1
26
27#include <vlc_common.h>
28#include <vlc_input.h> /* FIXME Needed for input_clock_t */
29#include "clock.h"
30
31/** @struct input_clock_t
32 * This structure is used to manage clock drift and reception jitters
33 *
34 * This API is reentrant but not thread-safe.
35 */
37
38/**
39 * Callbacks for the input_clock_t listener.
40 *
41 * \see input_clock_AttachListener
42 */
44 /**
45 * Notify the listener that the buffering made progress.
46 *
47 * \param opaque listener private data set from
48 * \ref input_clock_AttachListener
49 * \param ck_system time reference for the buffering progress
50 * \param ck_stream progress of the buffering in tick
51 * \param rate current playback rate for the buffering
52 *
53 * \return how much time the playback has drifted from
54 * the main clock
55 */
56 vlc_tick_t (*update)(void *opaque, vlc_tick_t ck_system,
57 vlc_tick_t ck_stream, double rate);
58
59 /**
60 * Notify the listener that the buffering needed a reset.
61 *
62 * \param opaque listener private data set from
63 * \ref input_clock_AttachListener
64 */
65 void (*reset)(void *opaque);
66};
67
68/**
69 * This function creates a new input_clock_t.
70 *
71 * You must use input_clock_Delete to delete it once unused.
72 */
73input_clock_t *input_clock_New( float rate );
74
75/**
76 * This function attach a clock listener to the input clock
77 *
78 * It can be called only one time, with a valid clock, before the first update
79 * (input_clock_Update()).
80 *
81 * \param clock the input clock to attach the listener to
82 * \param listener an input clock listener virtual table
83 * \param opaque an opaque pointer forwarded to the listener
84 *
85 */
87 const struct vlc_input_clock_cbs *clock_listener,
88 void *opaque);
89
90/**
91 * This function destroys a input_clock_t created by input_clock_New.
92 */
94
95/**
96 * This function will update a input_clock_t with a new clock reference point.
97 * It will also tell if the clock point is late regarding our buffering.
98 *
99 * \param clock the input clock object to update with the new point
100 * \param p_log the logger object to use
101 * \param b_can_pace_control whether the input can control the speed of playback
102 * \param b_buffering_allowed tells if we are allowed to bufferize more data in
103 advanced (if possible).
104 * \param i_clock the new clock reference value
105 * \param i_system the timestmap at which the new reference has been reported
106 *
107 * \return clock update delay
108 */
110 bool b_can_pace_control, bool b_buffering_allowed,
111 vlc_tick_t i_clock, vlc_tick_t i_system );
112/**
113 * This function will reset the drift of a input_clock_t.
114 *
115 * The actual jitter estimation will not be reset by it.
116 */
118
119/**
120 * This functions will return a deadline used to control the reading speed.
121 */
123
124/**
125 * This functions allows changing the actual reading speed.
126 */
127void input_clock_ChangeRate(input_clock_t *, float rate);
128
129/**
130 * This function allows changing the pause status.
131 */
132void input_clock_ChangePause(input_clock_t *, bool b_paused, vlc_tick_t i_date);
133
134/**
135 * This function allows rebasing the original system value date (a valid
136 * reference point must have been set).
137 * When using the absolute mode, it will create a discontinuity unless
138 * called immediately after a input_clock_Update.
139 */
140void input_clock_ChangeSystemOrigin(input_clock_t *, bool b_absolute, vlc_tick_t i_system);
141
142/**
143 * This function returns the current rate.
144 */
146
147/**
148 * This function returns current clock state or VLC_EGENERIC if there is not a
149 * reference point.
150 */
152 vlc_tick_t *pi_stream_start, vlc_tick_t *pi_system_start,
153 vlc_tick_t *pi_stream_duration, vlc_tick_t *pi_system_duration );
154
155/**
156 * This function allows the set the minimal configuration for the jitter estimation algo.
157 */
159 vlc_tick_t i_pts_delay, int i_cr_average );
160
161/**
162 * This function returns an estimation of the pts_delay needed to avoid rebufferization.
163 * XXX in the current implementation, the pts_delay will never be decreased.
164 */
166
167#endif
void input_clock_ChangeSystemOrigin(input_clock_t *, bool b_absolute, vlc_tick_t i_system)
This function allows rebasing the original system value date (a valid reference point must have been ...
Definition input_clock.c:400
int input_clock_GetState(input_clock_t *, vlc_tick_t *pi_stream_start, vlc_tick_t *pi_system_start, vlc_tick_t *pi_stream_duration, vlc_tick_t *pi_system_duration)
This function returns current clock state or VLC_EGENERIC if there is not a reference point.
Definition input_clock.c:384
void input_clock_AttachListener(input_clock_t *clock, const struct vlc_input_clock_cbs *clock_listener, void *opaque)
This function attach a clock listener to the input clock.
Definition input_clock.c:205
void input_clock_Reset(input_clock_t *)
This function will reset the drift of a input_clock_t.
Definition input_clock.c:312
void input_clock_ChangePause(input_clock_t *, bool b_paused, vlc_tick_t i_date)
This function allows changing the pause status.
Definition input_clock.c:342
vlc_tick_t input_clock_GetWakeup(input_clock_t *)
This functions will return a deadline used to control the reading speed.
Definition input_clock.c:365
void input_clock_Delete(input_clock_t *)
This function destroys a input_clock_t created by input_clock_New.
Definition input_clock.c:199
input_clock_t * input_clock_New(float rate)
This function creates a new input_clock_t.
Definition input_clock.c:165
void input_clock_ChangeRate(input_clock_t *, float rate)
This functions allows changing the actual reading speed.
Definition input_clock.c:326
vlc_tick_t input_clock_GetJitter(input_clock_t *)
This function returns an estimation of the pts_delay needed to avoid rebufferization.
Definition input_clock.c:460
float input_clock_GetRate(input_clock_t *)
This function returns the current rate.
Definition input_clock.c:379
void input_clock_SetJitter(input_clock_t *, vlc_tick_t i_pts_delay, int i_cr_average)
This function allows the set the minimal configuration for the jitter estimation algo.
Definition input_clock.c:425
vlc_tick_t input_clock_Update(input_clock_t *clock, vlc_object_t *p_log, bool b_can_pace_control, bool b_buffering_allowed, vlc_tick_t i_clock, vlc_tick_t i_system)
This function will update a input_clock_t with a new clock reference point.
Definition input_clock.c:222
This structure is used to manage clock drift and reception jitters.
Definition input_clock.c:103
Callbacks for the input_clock_t listener.
Definition input_clock.h:43
vlc_tick_t(* update)(void *opaque, vlc_tick_t ck_system, vlc_tick_t ck_stream, double rate)
Notify the listener that the buffering made progress.
Definition input_clock.h:56
void(* reset)(void *opaque)
Notify the listener that the buffering needed a reset.
Definition input_clock.h:65
VLC object common members.
Definition vlc_objects.h:53
This file is a collection of common definitions and types.
Input thread interface.
int64_t vlc_tick_t
High precision date or time interval.
Definition vlc_tick.h:48