2 * Copyright (C) <2007> Wim Taymans <wim.taymans@gmail.com>
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Library General Public License for more details.
14 * You should have received a copy of the GNU Library General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
17 * Boston, MA 02110-1301, USA.
20 #ifndef __RTP_JITTER_BUFFER_H__
21 #define __RTP_JITTER_BUFFER_H__
24 #include <gst/rtp/gstrtcpbuffer.h>
26 typedef struct _RTPJitterBuffer RTPJitterBuffer;
27 typedef struct _RTPJitterBufferClass RTPJitterBufferClass;
28 typedef struct _RTPJitterBufferItem RTPJitterBufferItem;
30 #define RTP_TYPE_JITTER_BUFFER (rtp_jitter_buffer_get_type())
31 #define RTP_JITTER_BUFFER(src) (G_TYPE_CHECK_INSTANCE_CAST((src),RTP_TYPE_JITTER_BUFFER,RTPJitterBuffer))
32 #define RTP_JITTER_BUFFER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass),RTP_TYPE_JITTER_BUFFER,RTPJitterBufferClass))
33 #define RTP_IS_JITTER_BUFFER(src) (G_TYPE_CHECK_INSTANCE_TYPE((src),RTP_TYPE_JITTER_BUFFER))
34 #define RTP_IS_JITTER_BUFFER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),RTP_TYPE_JITTER_BUFFER))
35 #define RTP_JITTER_BUFFER_CAST(src) ((RTPJitterBuffer *)(src))
38 * RTPJitterBufferMode:
40 * RTP_JITTER_BUFFER_MODE_NONE: don't do any skew correction, outgoing
41 * timestamps are calculated directly from the RTP timestamps. This mode is
42 * good for recording but not for real-time applications.
43 * RTP_JITTER_BUFFER_MODE_SLAVE: calculate the skew between sender and receiver
44 * and produce smoothed adjusted outgoing timestamps. This mode is good for
45 * low latency communications.
46 * RTP_JITTER_BUFFER_MODE_BUFFER: buffer packets between low/high watermarks.
47 * This mode is good for streaming communication.
48 * RTP_JITTER_BUFFER_MODE_LAST: last buffer mode.
50 * The different buffer modes for a jitterbuffer.
53 RTP_JITTER_BUFFER_MODE_NONE = 0,
54 RTP_JITTER_BUFFER_MODE_SLAVE = 1,
55 RTP_JITTER_BUFFER_MODE_BUFFER = 2,
56 RTP_JITTER_BUFFER_MODE_LAST
57 } RTPJitterBufferMode;
59 #define RTP_TYPE_JITTER_BUFFER_MODE (rtp_jitter_buffer_mode_get_type())
60 GType rtp_jitter_buffer_mode_get_type (void);
62 #define RTP_JITTER_BUFFER_MAX_WINDOW 512
66 * A JitterBuffer in the #RTPSession
68 struct _RTPJitterBuffer {
73 RTPJitterBufferMode mode;
82 /* for calculating skew */
83 GstClockTime base_time;
84 GstClockTime base_rtptime;
86 GstClockTime base_extrtp;
87 GstClockTime prev_out_time;
90 gint64 window[RTP_JITTER_BUFFER_MAX_WINDOW];
93 gboolean window_filling;
96 gint64 prev_send_diff;
99 struct _RTPJitterBufferClass {
100 GObjectClass parent_class;
104 * RTPJitterBufferItem:
105 * @data: the data of the item
106 * @next: pointer to next item
107 * @prev: pointer to previous item
108 * @type: the type of @data
112 * @count: amount of seqnum in this item
113 * @rtptime: rtp timestamp
115 * An object containing an RTP packet or event.
117 struct _RTPJitterBufferItem {
129 GType rtp_jitter_buffer_get_type (void);
131 /* managing lifetime */
132 RTPJitterBuffer* rtp_jitter_buffer_new (void);
134 RTPJitterBufferMode rtp_jitter_buffer_get_mode (RTPJitterBuffer *jbuf);
135 void rtp_jitter_buffer_set_mode (RTPJitterBuffer *jbuf, RTPJitterBufferMode mode);
137 GstClockTime rtp_jitter_buffer_get_delay (RTPJitterBuffer *jbuf);
138 void rtp_jitter_buffer_set_delay (RTPJitterBuffer *jbuf, GstClockTime delay);
140 void rtp_jitter_buffer_set_clock_rate (RTPJitterBuffer *jbuf, guint32 clock_rate);
141 guint32 rtp_jitter_buffer_get_clock_rate (RTPJitterBuffer *jbuf);
143 void rtp_jitter_buffer_reset_skew (RTPJitterBuffer *jbuf);
145 gboolean rtp_jitter_buffer_insert (RTPJitterBuffer *jbuf,
146 RTPJitterBufferItem *item,
147 gboolean *tail, gint *percent);
148 RTPJitterBufferItem * rtp_jitter_buffer_peek (RTPJitterBuffer *jbuf);
149 RTPJitterBufferItem * rtp_jitter_buffer_pop (RTPJitterBuffer *jbuf, gint *percent);
151 void rtp_jitter_buffer_flush (RTPJitterBuffer *jbuf,
152 GFunc free_func, gpointer user_data);
154 gboolean rtp_jitter_buffer_is_buffering (RTPJitterBuffer * jbuf);
155 void rtp_jitter_buffer_set_buffering (RTPJitterBuffer * jbuf, gboolean buffering);
156 gint rtp_jitter_buffer_get_percent (RTPJitterBuffer * jbuf);
158 guint rtp_jitter_buffer_num_packets (RTPJitterBuffer *jbuf);
159 guint32 rtp_jitter_buffer_get_ts_diff (RTPJitterBuffer *jbuf);
161 void rtp_jitter_buffer_get_sync (RTPJitterBuffer *jbuf, guint64 *rtptime,
162 guint64 *timestamp, guint32 *clock_rate,
163 guint64 *last_rtptime);
165 #endif /* __RTP_JITTER_BUFFER_H__ */