mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-09 00:45:56 +00:00
rtpsession: avoid buffer ref/unref pairs for CSRCs
We ref the buffer before pushing it downstream in order to get the CSRCs of it after pushing. This causes performance problems when downstream elements want to change the metadata because the buffer needs to be subbuffered. Instead, read and store the CSRCs of the buffer in an array before pushing it and process the array after pushing the buffer. This allows us to remove the ref/unref pair. Fixes #603376
This commit is contained in:
parent
4519bdc983
commit
07f27f0efd
1 changed files with 11 additions and 7 deletions
|
@ -1432,6 +1432,8 @@ rtp_session_process_rtp (RTPSession * sess, GstBuffer * buffer,
|
||||||
gboolean created;
|
gboolean created;
|
||||||
gboolean prevsender, prevactive;
|
gboolean prevsender, prevactive;
|
||||||
RTPArrivalStats arrival;
|
RTPArrivalStats arrival;
|
||||||
|
guint32 csrcs[16];
|
||||||
|
guint8 i, count;
|
||||||
|
|
||||||
g_return_val_if_fail (RTP_IS_SESSION (sess), GST_FLOW_ERROR);
|
g_return_val_if_fail (RTP_IS_SESSION (sess), GST_FLOW_ERROR);
|
||||||
g_return_val_if_fail (GST_IS_BUFFER (buffer), GST_FLOW_ERROR);
|
g_return_val_if_fail (GST_IS_BUFFER (buffer), GST_FLOW_ERROR);
|
||||||
|
@ -1457,8 +1459,14 @@ rtp_session_process_rtp (RTPSession * sess, GstBuffer * buffer,
|
||||||
prevsender = RTP_SOURCE_IS_SENDER (source);
|
prevsender = RTP_SOURCE_IS_SENDER (source);
|
||||||
prevactive = RTP_SOURCE_IS_ACTIVE (source);
|
prevactive = RTP_SOURCE_IS_ACTIVE (source);
|
||||||
|
|
||||||
/* we need to ref so that we can process the CSRCs later */
|
/* copy available csrc for later */
|
||||||
gst_buffer_ref (buffer);
|
count = gst_rtp_buffer_get_csrc_count (buffer);
|
||||||
|
/* make sure to not overflow our array. An RTP buffer can maximally contain
|
||||||
|
* 16 CSRCs */
|
||||||
|
count = MIN (count, 16);
|
||||||
|
|
||||||
|
for (i = 0; i < count; i++)
|
||||||
|
csrcs[i] = gst_rtp_buffer_get_csrc (buffer, i);
|
||||||
|
|
||||||
/* let source process the packet */
|
/* let source process the packet */
|
||||||
result = rtp_source_process_rtp (source, buffer, &arrival);
|
result = rtp_source_process_rtp (source, buffer, &arrival);
|
||||||
|
@ -1480,17 +1488,14 @@ rtp_session_process_rtp (RTPSession * sess, GstBuffer * buffer,
|
||||||
on_new_ssrc (sess, source);
|
on_new_ssrc (sess, source);
|
||||||
|
|
||||||
if (source->validated) {
|
if (source->validated) {
|
||||||
guint8 i, count;
|
|
||||||
gboolean created;
|
gboolean created;
|
||||||
|
|
||||||
/* for validated sources, we add the CSRCs as well */
|
/* for validated sources, we add the CSRCs as well */
|
||||||
count = gst_rtp_buffer_get_csrc_count (buffer);
|
|
||||||
|
|
||||||
for (i = 0; i < count; i++) {
|
for (i = 0; i < count; i++) {
|
||||||
guint32 csrc;
|
guint32 csrc;
|
||||||
RTPSource *csrc_src;
|
RTPSource *csrc_src;
|
||||||
|
|
||||||
csrc = gst_rtp_buffer_get_csrc (buffer, i);
|
csrc = csrcs[i];
|
||||||
|
|
||||||
/* get source */
|
/* get source */
|
||||||
csrc_src = obtain_source (sess, csrc, &created, &arrival, TRUE);
|
csrc_src = obtain_source (sess, csrc, &created, &arrival, TRUE);
|
||||||
|
@ -1508,7 +1513,6 @@ rtp_session_process_rtp (RTPSession * sess, GstBuffer * buffer,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
g_object_unref (source);
|
g_object_unref (source);
|
||||||
gst_buffer_unref (buffer);
|
|
||||||
|
|
||||||
RTP_SESSION_UNLOCK (sess);
|
RTP_SESSION_UNLOCK (sess);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue