From 2826212827b04ab9a9e26c2f057e45f0e6d6e14b Mon Sep 17 00:00:00 2001 From: Wim Taymans Date: Wed, 13 Jun 2007 17:11:24 +0000 Subject: gst/rtp/gstrtph264depay.c: Make sure we allocate enough memory for the codec_data. Original commit message from CVS: * gst/rtp/gstrtph264depay.c: (gst_rtp_h264_depay_setcaps): Make sure we allocate enough memory for the codec_data. Fixes #447210. --- gst/rtp/gstrtph264depay.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'gst/rtp') diff --git a/gst/rtp/gstrtph264depay.c b/gst/rtp/gstrtph264depay.c index 1b1fffbd..164ef56c 100644 --- a/gst/rtp/gstrtph264depay.c +++ b/gst/rtp/gstrtph264depay.c @@ -237,10 +237,12 @@ gst_rtp_h264_depay_setcaps (GstBaseRTPDepayload * depayload, GstCaps * caps) ps = gst_structure_get_string (structure, "sprop-parameter-sets"); params = g_strsplit (ps, ",", 0); - /* count total number of bytes in base64 */ + /* count total number of bytes in base64. Also include the sync bytes in + * front of the params. */ len = 0; for (i = 0; params[i]; i++) { len += strlen (params[i]); + len += sizeof (sync_bytes); } /* we seriously overshoot the length, but it's fine. */ codec_data = gst_buffer_new_and_alloc (len); -- cgit