gstbasertpdepayload.h 5.34 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
/* GStreamer
 * Copyright (C) <2005> Philippe Khalaf <burger@speedy.org> 
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Library General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) any later version.
 *
 * This library 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
 * Library General Public License for more details.
 *
 * You should have received a copy of the GNU Library General Public
 * License along with this library; if not, write to the
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 * Boston, MA 02111-1307, USA.
 */

#ifndef __GST_BASE_RTP_DEPAYLOAD_H__
#define __GST_BASE_RTP_DEPAYLOAD_H__

#include <gst/gst.h>
#include <gst/rtp/gstrtpbuffer.h>

G_BEGIN_DECLS

#define GST_TYPE_BASE_RTP_DEPAYLOAD (gst_base_rtp_depayload_get_type())
#define GST_BASE_RTP_DEPAYLOAD(obj) \
  (G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_BASE_RTP_DEPAYLOAD,GstBaseRTPDepayload))
#define GST_BASE_RTP_DEPAYLOAD_CLASS(klass) \
Stefan Kost's avatar
Stefan Kost committed
32
  (G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_BASE_RTP_DEPAYLOAD,GstBaseRTPDepayloadClass))
33
#define GST_BASE_RTP_DEPAYLOAD_GET_CLASS(obj) \
Thomas Vander Stichele's avatar
Thomas Vander Stichele committed
34
        (G_TYPE_INSTANCE_GET_CLASS ((obj),GST_TYPE_BASE_RTP_DEPAYLOAD,GstBaseRTPDepayloadClass))
35
36
#define GST_IS_BASE_RTP_DEPAYLOAD(obj) \
  (G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_BASE_RTP_DEPAYLOAD))
Stefan Kost's avatar
Stefan Kost committed
37
#define GST_IS_BASE_RTP_DEPAYLOAD_CLASS(klass) \
38
39
  (G_TYPE_CHECK_CLASS_TYPE((klass),GST_TYPE_BASE_RTP_DEPAYLOAD))

40
41
42
#define GST_BASE_RTP_DEPAYLOAD_SINKPAD(depayload) (GST_BASE_RTP_DEPAYLOAD (depayload)->sinkpad)
#define GST_BASE_RTP_DEPAYLOAD_SRCPAD(depayload)  (GST_BASE_RTP_DEPAYLOAD (depayload)->srcpad)

43
44
45
#ifndef GST_DISABLE_DEPRECATED
/* this was presumably never meant to be public API, or should at least
 * have been prefixed if it was. Don't use. (FIXME: remove in 0.11) */
Thomas Vander Stichele's avatar
Thomas Vander Stichele committed
46
47
#define QUEUE_LOCK_INIT(base)   (g_static_rec_mutex_init(&base->queuelock))
#define QUEUE_LOCK_FREE(base)   (g_static_rec_mutex_free(&base->queuelock))
48
49
50
#define QUEUE_LOCK(base)        (g_static_rec_mutex_lock(&base->queuelock))
#define QUEUE_UNLOCK(base)      (g_static_rec_mutex_unlock(&base->queuelock))
#endif
51

52
53
typedef struct _GstBaseRTPDepayload      GstBaseRTPDepayload;
typedef struct _GstBaseRTPDepayloadClass GstBaseRTPDepayloadClass;
54
typedef struct _GstBaseRTPDepayloadPrivate GstBaseRTPDepayloadPrivate;
55
56
57
58
59
60
61

struct _GstBaseRTPDepayload
{
  GstElement parent;

  GstPad *sinkpad, *srcpad;

62
#ifndef GST_REMOVE_DEPRECATED
63
  /* lock to protect the queue, deprecated */
64
65
  GStaticRecMutex queuelock;

66
  /* deprecated */
67
  gboolean thread_running;
68
  /* the releaser thread, deprecated */
69
  GThread *thread;
70
#endif
71

72
  /* this attribute must be set by the child */
73
74
  guint clock_rate;

75
#ifndef GST_REMOVE_DEPRECATED
76
  /* this value can be modified by the child if needed, deprecated */
77
  guint queue_delay;
78
#endif
79

80
81
82
  /* we will queue up to RTP_QUEUEDELAY ms of packets,
   * reordering them if necessary
   * dropping any packets that are more than
83
   * RTP_QUEUEDELAY ms late, deprecated */
84
  GQueue *queue;
85

86
87
88
  GstSegment segment;
  gboolean need_newsegment;

89
  /*< private >*/
90
91
92
  GstBaseRTPDepayloadPrivate *priv;

  gpointer _gst_reserved[GST_PADDING-1];
93
94
95
96
97
98
};

struct _GstBaseRTPDepayloadClass
{
  GstElementClass parent_class;

99
  /* virtuals, inform the subclass of the caps. */
100
101
  gboolean (*set_caps) (GstBaseRTPDepayload *filter, GstCaps *caps);

102
  /* non-pure function, default implementation in base class
103
   * this does buffering, reordering and dropping, deprecated */
104
  GstFlowReturn (*add_to_queue) (GstBaseRTPDepayload *filter, GstBuffer *in);
105

106
  /* pure virtual function, child must use this to process incoming
107
108
109
110
   * rtp packets. If the child returns a buffer without a valid timestamp,
   * the timestamp of @in will be applied to the result buffer and the
   * buffer will be pushed. If this function returns %NULL, nothing is
   * pushed.  */
111
  GstBuffer * (*process) (GstBaseRTPDepayload *base, GstBuffer *in);
112

113
  /* non-pure function used to convert from RTP timestamp to GST timestamp
114
   * this function is used by the child class before gst_pad_pushing */
115
  void (*set_gst_timestamp) (GstBaseRTPDepayload *filter, guint32 timestamp, GstBuffer *buf);
116

117
118
119
120
121
  /* non-pure function used to to signal the depayloader about packet loss. the
   * timestamp and duration are the estimated values of the lost packet.
   * The default implementation of this message pushes a segment update. */
  gboolean (*packet_lost) (GstBaseRTPDepayload *filter, GstEvent *event);

122
  /* the default implementation does the default actions for events but
Wim Taymans's avatar
Wim Taymans committed
123
124
   * implementation can override.
   * Since: 0.10.32   */
125
126
  gboolean (*handle_event) (GstBaseRTPDepayload * filter, GstEvent * event);

127
  /*< private >*/
128
  gpointer _gst_reserved[GST_PADDING-2];
129
130
131
132
};

GType gst_base_rtp_depayload_get_type (void);

133
134
135
GstFlowReturn   gst_base_rtp_depayload_push              (GstBaseRTPDepayload *filter, GstBuffer *out_buf);
GstFlowReturn   gst_base_rtp_depayload_push_ts           (GstBaseRTPDepayload *filter,
		                                          guint32 timestamp, GstBuffer *out_buf);
136
137
GstFlowReturn   gst_base_rtp_depayload_push_list         (GstBaseRTPDepayload *filter, GstBufferList *out_list);

138

139
140
141
G_END_DECLS

#endif /* __GST_BASE_RTP_DEPAYLOAD_H__ */