summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOlivier CrĂȘte <olivier.crete@collabora.com>2012-09-20 18:41:24 -0400
committerOlivier CrĂȘte <olivier.crete@collabora.com>2012-09-22 14:58:52 -0400
commitdf0525de11695c50fc9a1a671aa8f6e2cf876694 (patch)
tree595e1146b7ea96f9643bbf13ddeeb403410a20cf
parent4b465e6de4bd8e5c7d02b55a0e66b873130c3424 (diff)
rtpopuspay: Allocate the rtp buffer correctly
Use the right functions to allocate the rtp buffer
-rw-r--r--ext/opus/gstrtpopuspay.c20
1 files changed, 3 insertions, 17 deletions
diff --git a/ext/opus/gstrtpopuspay.c b/ext/opus/gstrtpopuspay.c
index 9eee96066..e1781e1b0 100644
--- a/ext/opus/gstrtpopuspay.c
+++ b/ext/opus/gstrtpopuspay.c
@@ -112,24 +112,10 @@ static GstFlowReturn
gst_rtp_opus_pay_handle_buffer (GstRTPBasePayload * basepayload,
GstBuffer * buffer)
{
- GstRTPBuffer rtpbuf = { NULL, };
GstBuffer *outbuf;
- GstMapInfo map;
-
- /* Copy data and timestamp to a new output buffer
- * FIXME : Don't we have a convenience function for this ? */
- gst_buffer_map (buffer, &map, GST_MAP_READ);
- outbuf = gst_rtp_buffer_new_copy_data (map.data, map.size);
- GST_BUFFER_TIMESTAMP (outbuf) = GST_BUFFER_TIMESTAMP (buffer);
-
- /* Unmap and free input buffer */
- gst_buffer_unmap (buffer, &map);
- gst_buffer_unref (buffer);
-
- /* Remove marker from RTP buffer */
- gst_rtp_buffer_map (outbuf, GST_MAP_WRITE, &rtpbuf);
- gst_rtp_buffer_set_marker (&rtpbuf, FALSE);
- gst_rtp_buffer_unmap (&rtpbuf);
+
+ outbuf = gst_rtp_buffer_new_allocate (0, 0, 0);
+ outbuf = gst_buffer_append (outbuf, gst_buffer_ref (buffer));
/* Push out */
return gst_rtp_base_payload_push (basepayload, outbuf);