mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-02-02 20:42:30 +00:00
rtpgstpay: put 0-byte at the end of events
Put a 0-byte at the end of the event string. Does not break ABI because old depayloaders will skip the 0 byte (which is included in the length). Expect a 0-byte at the end of the event string or a ; for old payloaders. See https://bugzilla.gnome.org/show_bug.cgi?id=737591
This commit is contained in:
parent
9d2902d978
commit
3d7b0f30d7
2 changed files with 8 additions and 1 deletions
|
@ -279,7 +279,12 @@ read_event (GstRtpGSTDepay * rtpgstdepay, guint type,
|
||||||
if (!read_length (rtpgstdepay, map.data, map.size, &length, &offset))
|
if (!read_length (rtpgstdepay, map.data, map.size, &length, &offset))
|
||||||
goto too_small;
|
goto too_small;
|
||||||
|
|
||||||
if (length == 0 || map.data[offset + length - 1] != ';')
|
if (length == 0)
|
||||||
|
goto invalid_buffer;
|
||||||
|
if (map.data[offset + length - 1] != '\0')
|
||||||
|
goto invalid_buffer;
|
||||||
|
/* backward compat, old payloader did not put 0-byte at the end */
|
||||||
|
if (map.data[offset + length - 1] != ';')
|
||||||
goto invalid_buffer;
|
goto invalid_buffer;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (rtpgstdepay, "parsing event %s", &map.data[offset]);
|
GST_DEBUG_OBJECT (rtpgstdepay, "parsing event %s", &map.data[offset]);
|
||||||
|
|
|
@ -483,6 +483,8 @@ gst_rtp_gst_pay_send_event (GstRtpGSTPay * rtpgstpay, guint etype,
|
||||||
|
|
||||||
estr = gst_structure_to_string (s);
|
estr = gst_structure_to_string (s);
|
||||||
elen = strlen (estr);
|
elen = strlen (estr);
|
||||||
|
/* for 0 byte */
|
||||||
|
elen++;
|
||||||
outbuf = make_data_buffer (rtpgstpay, estr, elen);
|
outbuf = make_data_buffer (rtpgstpay, estr, elen);
|
||||||
GST_DEBUG_OBJECT (rtpgstpay, "sending event=%s", estr);
|
GST_DEBUG_OBJECT (rtpgstpay, "sending event=%s", estr);
|
||||||
g_free (estr);
|
g_free (estr);
|
||||||
|
|
Loading…
Reference in a new issue