mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-14 03:15:47 +00:00
rtpst2022-1-fec-*: protect additional RTP header fields
While the standard is a bit vague about whether the padding, extension and marker bits should be protected: > The usage, by senders and receivers, of the following bits shall > be defined by the associated video/audio transport standards: It is obviously necessary and useful for some formats (eg VP8) that those indeed be protected. Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/-/merge_requests/839>
This commit is contained in:
parent
2d24a45c89
commit
081509e030
2 changed files with 35 additions and 8 deletions
|
@ -168,6 +168,9 @@ typedef struct
|
||||||
guint8 seq_ext;
|
guint8 seq_ext;
|
||||||
guint8 *payload;
|
guint8 *payload;
|
||||||
guint payload_len;
|
guint payload_len;
|
||||||
|
gboolean marker;
|
||||||
|
gboolean padding;
|
||||||
|
gboolean extension;
|
||||||
} Rtp2DFecHeader;
|
} Rtp2DFecHeader;
|
||||||
|
|
||||||
static GstStaticPadTemplate fec_sink_template =
|
static GstStaticPadTemplate fec_sink_template =
|
||||||
|
@ -280,16 +283,21 @@ lookup_media_packet (GstRTPST_2022_1_FecDec * dec, guint16 seqnum)
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
parse_header (Rtp2DFecHeader * fec, guint8 * data, guint len)
|
parse_header (GstRTPBuffer * rtp, Rtp2DFecHeader * fec)
|
||||||
{
|
{
|
||||||
gboolean ret = FALSE;
|
gboolean ret = FALSE;
|
||||||
GstBitReader bits;
|
GstBitReader bits;
|
||||||
|
guint8 *data = gst_rtp_buffer_get_payload (rtp);
|
||||||
|
guint len = gst_rtp_buffer_get_payload_len (rtp);
|
||||||
|
|
||||||
if (len < 16)
|
if (len < 16)
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
gst_bit_reader_init (&bits, data, len);
|
gst_bit_reader_init (&bits, data, len);
|
||||||
|
|
||||||
|
fec->marker = gst_rtp_buffer_get_marker (rtp);
|
||||||
|
fec->padding = gst_rtp_buffer_get_padding (rtp);
|
||||||
|
fec->extension = gst_rtp_buffer_get_extension (rtp);
|
||||||
fec->seq = gst_bit_reader_get_bits_uint16_unchecked (&bits, 16);
|
fec->seq = gst_bit_reader_get_bits_uint16_unchecked (&bits, 16);
|
||||||
fec->len = gst_bit_reader_get_bits_uint16_unchecked (&bits, 16);
|
fec->len = gst_bit_reader_get_bits_uint16_unchecked (&bits, 16);
|
||||||
fec->E = gst_bit_reader_get_bits_uint8_unchecked (&bits, 1);
|
fec->E = gst_bit_reader_get_bits_uint8_unchecked (&bits, 1);
|
||||||
|
@ -392,6 +400,9 @@ xor_items (GstRTPST_2022_1_FecDec * dec, Rtp2DFecHeader * fec, GList * packets,
|
||||||
GList *tmp;
|
GList *tmp;
|
||||||
GstFlowReturn ret = GST_FLOW_OK;
|
GstFlowReturn ret = GST_FLOW_OK;
|
||||||
GstBuffer *buffer;
|
GstBuffer *buffer;
|
||||||
|
gboolean xored_marker;
|
||||||
|
gboolean xored_padding;
|
||||||
|
gboolean xored_extension;
|
||||||
|
|
||||||
/* Figure out the recovered packet length first */
|
/* Figure out the recovered packet length first */
|
||||||
xored_payload_len = fec->len;
|
xored_payload_len = fec->len;
|
||||||
|
@ -419,6 +430,9 @@ xor_items (GstRTPST_2022_1_FecDec * dec, Rtp2DFecHeader * fec, GList * packets,
|
||||||
memcpy (xored, fec->payload, xored_payload_len);
|
memcpy (xored, fec->payload, xored_payload_len);
|
||||||
xored_timestamp = fec->timestamp;
|
xored_timestamp = fec->timestamp;
|
||||||
xored_pt = fec->pt;
|
xored_pt = fec->pt;
|
||||||
|
xored_marker = fec->marker;
|
||||||
|
xored_padding = fec->padding;
|
||||||
|
xored_extension = fec->extension;
|
||||||
|
|
||||||
for (tmp = packets; tmp; tmp = tmp->next) {
|
for (tmp = packets; tmp; tmp = tmp->next) {
|
||||||
GstRTPBuffer media_rtp = GST_RTP_BUFFER_INIT;
|
GstRTPBuffer media_rtp = GST_RTP_BUFFER_INIT;
|
||||||
|
@ -429,6 +443,9 @@ xor_items (GstRTPST_2022_1_FecDec * dec, Rtp2DFecHeader * fec, GList * packets,
|
||||||
gst_rtp_buffer_get_payload_len (&media_rtp));
|
gst_rtp_buffer_get_payload_len (&media_rtp));
|
||||||
xored_timestamp ^= gst_rtp_buffer_get_timestamp (&media_rtp);
|
xored_timestamp ^= gst_rtp_buffer_get_timestamp (&media_rtp);
|
||||||
xored_pt ^= gst_rtp_buffer_get_payload_type (&media_rtp);
|
xored_pt ^= gst_rtp_buffer_get_payload_type (&media_rtp);
|
||||||
|
xored_marker ^= gst_rtp_buffer_get_marker (&media_rtp);
|
||||||
|
xored_padding ^= gst_rtp_buffer_get_padding (&media_rtp);
|
||||||
|
xored_extension ^= gst_rtp_buffer_get_extension (&media_rtp);
|
||||||
|
|
||||||
gst_rtp_buffer_unmap (&media_rtp);
|
gst_rtp_buffer_unmap (&media_rtp);
|
||||||
}
|
}
|
||||||
|
@ -442,6 +459,9 @@ xor_items (GstRTPST_2022_1_FecDec * dec, Rtp2DFecHeader * fec, GList * packets,
|
||||||
gst_rtp_buffer_set_timestamp (&rtp, xored_timestamp);
|
gst_rtp_buffer_set_timestamp (&rtp, xored_timestamp);
|
||||||
gst_rtp_buffer_set_seq (&rtp, seqnum);
|
gst_rtp_buffer_set_seq (&rtp, seqnum);
|
||||||
gst_rtp_buffer_set_payload_type (&rtp, xored_pt);
|
gst_rtp_buffer_set_payload_type (&rtp, xored_pt);
|
||||||
|
gst_rtp_buffer_set_marker (&rtp, xored_marker);
|
||||||
|
gst_rtp_buffer_set_padding (&rtp, xored_padding);
|
||||||
|
gst_rtp_buffer_set_extension (&rtp, xored_extension);
|
||||||
|
|
||||||
gst_rtp_buffer_unmap (&rtp);
|
gst_rtp_buffer_unmap (&rtp);
|
||||||
|
|
||||||
|
@ -535,16 +555,11 @@ check_fec_item (GstRTPST_2022_1_FecDec * dec, Item * item)
|
||||||
{
|
{
|
||||||
Rtp2DFecHeader fec;
|
Rtp2DFecHeader fec;
|
||||||
GstRTPBuffer rtp = GST_RTP_BUFFER_INIT;
|
GstRTPBuffer rtp = GST_RTP_BUFFER_INIT;
|
||||||
guint payload_len;
|
|
||||||
guint8 *payload;
|
|
||||||
GstFlowReturn ret;
|
GstFlowReturn ret;
|
||||||
|
|
||||||
gst_rtp_buffer_map (item->buffer, GST_MAP_READ, &rtp);
|
gst_rtp_buffer_map (item->buffer, GST_MAP_READ, &rtp);
|
||||||
|
|
||||||
payload_len = gst_rtp_buffer_get_payload_len (&rtp);
|
parse_header (&rtp, &fec);
|
||||||
payload = gst_rtp_buffer_get_payload (&rtp);
|
|
||||||
|
|
||||||
parse_header (&fec, payload, payload_len);
|
|
||||||
|
|
||||||
ret = check_fec (dec, &fec);
|
ret = check_fec (dec, &fec);
|
||||||
|
|
||||||
|
@ -617,7 +632,7 @@ gst_rtpst_2022_1_fecdec_sink_chain_fec (GstPad * pad, GstObject * parent,
|
||||||
payload_len = gst_rtp_buffer_get_payload_len (&rtp);
|
payload_len = gst_rtp_buffer_get_payload_len (&rtp);
|
||||||
payload = gst_rtp_buffer_get_payload (&rtp);
|
payload = gst_rtp_buffer_get_payload (&rtp);
|
||||||
|
|
||||||
if (!parse_header (&fec, payload, payload_len)) {
|
if (!parse_header (&rtp, &fec)) {
|
||||||
GST_WARNING_OBJECT (pad, "Failed to parse FEC header (payload len: %d)",
|
GST_WARNING_OBJECT (pad, "Failed to parse FEC header (payload len: %d)",
|
||||||
payload_len);
|
payload_len);
|
||||||
GST_MEMDUMP_OBJECT (pad, "Invalid payload", payload, payload_len);
|
GST_MEMDUMP_OBJECT (pad, "Invalid payload", payload, payload_len);
|
||||||
|
|
|
@ -114,6 +114,9 @@ typedef struct
|
||||||
guint32 xored_timestamp;
|
guint32 xored_timestamp;
|
||||||
guint8 xored_pt;
|
guint8 xored_pt;
|
||||||
guint16 xored_payload_len;
|
guint16 xored_payload_len;
|
||||||
|
gboolean xored_marker;
|
||||||
|
gboolean xored_padding;
|
||||||
|
gboolean xored_extension;
|
||||||
|
|
||||||
guint16 seq_base;
|
guint16 seq_base;
|
||||||
|
|
||||||
|
@ -256,6 +259,9 @@ fec_packet_update (FecPacket * fec, GstRTPBuffer * rtp)
|
||||||
fec->xored_payload_len = gst_rtp_buffer_get_payload_len (rtp);
|
fec->xored_payload_len = gst_rtp_buffer_get_payload_len (rtp);
|
||||||
fec->xored_pt = gst_rtp_buffer_get_payload_type (rtp);
|
fec->xored_pt = gst_rtp_buffer_get_payload_type (rtp);
|
||||||
fec->xored_timestamp = gst_rtp_buffer_get_timestamp (rtp);
|
fec->xored_timestamp = gst_rtp_buffer_get_timestamp (rtp);
|
||||||
|
fec->xored_marker = gst_rtp_buffer_get_marker (rtp);
|
||||||
|
fec->xored_padding = gst_rtp_buffer_get_padding (rtp);
|
||||||
|
fec->xored_extension = gst_rtp_buffer_get_extension (rtp);
|
||||||
fec->xored_payload = g_malloc (sizeof (guint8) * fec->payload_len);
|
fec->xored_payload = g_malloc (sizeof (guint8) * fec->payload_len);
|
||||||
memcpy (fec->xored_payload, gst_rtp_buffer_get_payload (rtp),
|
memcpy (fec->xored_payload, gst_rtp_buffer_get_payload (rtp),
|
||||||
fec->payload_len);
|
fec->payload_len);
|
||||||
|
@ -271,6 +277,9 @@ fec_packet_update (FecPacket * fec, GstRTPBuffer * rtp)
|
||||||
fec->xored_timestamp ^= gst_rtp_buffer_get_timestamp (rtp);
|
fec->xored_timestamp ^= gst_rtp_buffer_get_timestamp (rtp);
|
||||||
_xor_mem (fec->xored_payload, gst_rtp_buffer_get_payload (rtp),
|
_xor_mem (fec->xored_payload, gst_rtp_buffer_get_payload (rtp),
|
||||||
gst_rtp_buffer_get_payload_len (rtp));
|
gst_rtp_buffer_get_payload_len (rtp));
|
||||||
|
fec->xored_marker ^= gst_rtp_buffer_get_marker (rtp);
|
||||||
|
fec->xored_padding ^= gst_rtp_buffer_get_padding (rtp);
|
||||||
|
fec->xored_extension ^= gst_rtp_buffer_get_extension (rtp);
|
||||||
}
|
}
|
||||||
|
|
||||||
fec->n_packets += 1;
|
fec->n_packets += 1;
|
||||||
|
@ -331,6 +340,9 @@ queue_fec_packet (GstRTPST_2022_1_FecEnc * enc, FecPacket * fec, gboolean row)
|
||||||
|
|
||||||
gst_rtp_buffer_set_payload_type (&rtp, enc->pt);
|
gst_rtp_buffer_set_payload_type (&rtp, enc->pt);
|
||||||
gst_rtp_buffer_set_seq (&rtp, row ? enc->row_seq++ : enc->column_seq++);
|
gst_rtp_buffer_set_seq (&rtp, row ? enc->row_seq++ : enc->column_seq++);
|
||||||
|
gst_rtp_buffer_set_marker (&rtp, fec->xored_marker);
|
||||||
|
gst_rtp_buffer_set_padding (&rtp, fec->xored_padding);
|
||||||
|
gst_rtp_buffer_set_extension (&rtp, fec->xored_extension);
|
||||||
|
|
||||||
/* We're sending it out immediately */
|
/* We're sending it out immediately */
|
||||||
if (row)
|
if (row)
|
||||||
|
|
Loading…
Reference in a new issue