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 * Copyright (C) 2023-2025 Alexandre Janniaux <ajanni@videolabs.io>
7 *
8 * Authors: Laurent Aimar < fenrir _AT_ videolan _DOT_ org >
9 *
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU Lesser General Public License as published by
12 * the Free Software Foundation; either version 2.1 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License for more details.
19 *
20 * You should have received a copy of the GNU Lesser General Public License
21 * along with this program; if not, write to the Free Software Foundation,
22 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
24
25#ifndef LIBVLC_INPUT_CLOCK_H
26#define LIBVLC_INPUT_CLOCK_H 1
27
28#include <vlc_common.h>
29#include <vlc_input.h> /* FIXME Needed for input_clock_t */
30#include "clock.h"
31
32/** @struct input_clock_t
33 * This structure is used to manage clock drift and reception jitters
34 *
35 * This API is reentrant but not thread-safe.
36 */
38
39/**
40 * Callbacks for the input_clock_t listener.
41 *
42 * \see input_clock_AttachListener
43 */
45 /**
46 * Notify the listener that the buffering made progress.
47 *
48 * \param opaque listener private data set from
49 * \ref input_clock_AttachListener
50 * \param ck_system time reference for the buffering progress
51 * \param ck_stream progress of the buffering in tick
52 * \param rate current playback rate for the buffering
53 * \param discontinuity PCR discontinuity with the previous update
54 *
55 * \return how much time the playback has drifted from
56 * the main clock
57 */
58 vlc_tick_t (*update)(void *opaque, vlc_tick_t ck_system,
59 vlc_tick_t ck_stream, double rate, bool discontinuity);
60
61 /**
62 * Notify the listener that the buffering needed a reset.
63 *
64 * \param opaque listener private data set from
65 * \ref input_clock_AttachListener
66 */
67 void (*reset)(void *opaque);
68};
69
70/**
71 * This function creates a new input_clock_t.
72 *
73 * You must use input_clock_Delete to delete it once unused.
74 */
75input_clock_t *input_clock_New(struct vlc_logger *logger, float rate);
76
77/**
78 * This function attach a clock listener to the input clock
79 *
80 * It can be called only one time, with a valid clock, before the first update
81 * (input_clock_Update()).
82 *
83 * \param clock the input clock to attach the listener to
84 * \param listener an input clock listener virtual table
85 * \param opaque an opaque pointer forwarded to the listener
86 *
87 */
89 const struct vlc_input_clock_cbs *clock_listener,
90 void *opaque);
91
92/**
93 * This function destroys a input_clock_t created by input_clock_New.
94 */
96
97/**
98 * This function will update a input_clock_t with a new clock reference point.
99 * It will also tell if the clock point is late regarding our buffering.
100 *
101 * \param clock the input clock object to update with the new point
102 * \param b_can_pace_control whether the input can control the speed of playback
103 * \param b_buffering whether the input is buffering
104 * \param b_extra_buffering_allowed tells if we are allowed to bufferize more
105 * data in advance (if possible).
106 * \param i_clock the new clock reference value
107 * \param i_system the timestmap at which the new reference has been reported
108 *
109 * \return clock update delay
110 */
112 bool b_can_pace_control, bool b_buffering,
113 bool b_extra_buffering_allowed,
114 vlc_tick_t i_clock, vlc_tick_t i_system );
115
116/**
117 * This function will reset the drift of a input_clock_t.
118 *
119 * The actual jitter estimation will not be reset by it.
120 */
122
123/**
124 * This functions will return a deadline used to control the reading speed.
125 */
127
128/**
129 * This functions allows changing the actual reading speed.
130 */
131void input_clock_ChangeRate(input_clock_t *, float rate);
132
133/**
134 * This function allows changing the pause status.
135 */
136void input_clock_ChangePause(input_clock_t *, bool b_paused, vlc_tick_t i_date);
137
138/**
139 * This function allows rebasing the original system value date (a valid
140 * reference point must have been set).
141 */
143
144/**
145 * This function returns the current rate.
146 */
148
149/**
150 * This function returns current clock state or VLC_EGENERIC if there is not a
151 * reference point.
152 */
154 vlc_tick_t *pi_stream_start, vlc_tick_t *pi_system_start,
155 vlc_tick_t *pi_stream_duration, vlc_tick_t *pi_system_duration );
156
157/**
158 * Return the duration of stream buffered as well as for how long the
159 * buffering has been started.
160 *
161 * @param clock An input clock with valid references
162 * @param stream_duration the available buffering duration
163 * @param system_duration the time spent in buffering
164 */
166 const input_clock_t *clock,
167 vlc_tick_t *stream_duration,
168 vlc_tick_t *system_duration);
169
170/**
171 * Return for how long the buffering would be running up to the system
172 * reference given.
173 */
175 const input_clock_t *clock,
176 vlc_tick_t system_reference);
177
178/**
179 * This function allows the set the minimal configuration for the jitter estimation algo.
180 */
182 vlc_tick_t i_pts_delay, int i_cr_average );
183
184/**
185 * This function returns an estimation of the pts_delay needed to avoid rebufferization.
186 * XXX in the current implementation, the pts_delay will never be decreased.
187 */
189
190#endif
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:409
vlc_tick_t input_clock_Update(input_clock_t *clock, bool b_can_pace_control, bool b_buffering, bool b_extra_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:225
vlc_tick_t input_clock_GetSystemDuration(const input_clock_t *clock, vlc_tick_t system_reference)
Return for how long the buffering would be running up to the system reference given.
Definition input_clock.c:439
int input_clock_GetBufferingDuration(const input_clock_t *clock, vlc_tick_t *stream_duration, vlc_tick_t *system_duration)
Return the duration of stream buffered as well as for how long the buffering has been started.
Definition input_clock.c:425
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:208
void input_clock_Reset(input_clock_t *)
This function will reset the drift of a input_clock_t.
Definition input_clock.c:334
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:367
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:390
void input_clock_Delete(input_clock_t *)
This function destroys a input_clock_t created by input_clock_New.
Definition input_clock.c:202
void input_clock_ChangeRate(input_clock_t *, float rate)
This functions allows changing the actual reading speed.
Definition input_clock.c:348
input_clock_t * input_clock_New(struct vlc_logger *logger, float rate)
This function creates a new input_clock_t.
Definition input_clock.c:167
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:499
float input_clock_GetRate(input_clock_t *)
This function returns the current rate.
Definition input_clock.c:404
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:464
void input_clock_ChangeSystemOrigin(input_clock_t *, 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:450
This structure is used to manage clock drift and reception jitters.
Definition input_clock.c:106
Callbacks for the input_clock_t listener.
Definition input_clock.h:44
vlc_tick_t(* update)(void *opaque, vlc_tick_t ck_system, vlc_tick_t ck_stream, double rate, bool discontinuity)
Notify the listener that the buffering made progress.
Definition input_clock.h:58
void(* reset)(void *opaque)
Notify the listener that the buffering needed a reset.
Definition input_clock.h:67
Definition vlc_messages.h:125
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