mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-05 15:08:48 +00:00
rtpvorbisdepay: Enabled header extension aggregation
Because this depayloader may build several output buffers within one process run we push them all into a GstBufferList and push them out at once to make sure that each buffer gets notified about each header extension. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5378>
This commit is contained in:
parent
e1e7421982
commit
3fffcd021a
1 changed files with 33 additions and 11 deletions
|
@ -110,6 +110,8 @@ gst_rtp_vorbis_depay_class_init (GstRtpVorbisDepayClass * klass)
|
||||||
static void
|
static void
|
||||||
gst_rtp_vorbis_depay_init (GstRtpVorbisDepay * rtpvorbisdepay)
|
gst_rtp_vorbis_depay_init (GstRtpVorbisDepay * rtpvorbisdepay)
|
||||||
{
|
{
|
||||||
|
gst_rtp_base_depayload_set_aggregate_hdrext_enabled (GST_RTP_BASE_DEPAYLOAD
|
||||||
|
(rtpvorbisdepay), TRUE);
|
||||||
rtpvorbisdepay->adapter = gst_adapter_new ();
|
rtpvorbisdepay->adapter = gst_adapter_new ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -417,7 +419,7 @@ no_rate:
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_rtp_vorbis_depay_switch_codebook (GstRtpVorbisDepay * rtpvorbisdepay,
|
gst_rtp_vorbis_depay_switch_codebook (GstRtpVorbisDepay * rtpvorbisdepay,
|
||||||
guint32 ident)
|
guint32 ident, GstBufferList * outbufs)
|
||||||
{
|
{
|
||||||
GList *walk;
|
GList *walk;
|
||||||
gboolean res = FALSE;
|
gboolean res = FALSE;
|
||||||
|
@ -436,8 +438,7 @@ gst_rtp_vorbis_depay_switch_codebook (GstRtpVorbisDepay * rtpvorbisdepay,
|
||||||
GstBuffer *header = GST_BUFFER_CAST (headers->data);
|
GstBuffer *header = GST_BUFFER_CAST (headers->data);
|
||||||
|
|
||||||
gst_buffer_ref (header);
|
gst_buffer_ref (header);
|
||||||
gst_rtp_base_depayload_push (GST_RTP_BASE_DEPAYLOAD (rtpvorbisdepay),
|
gst_buffer_list_add (outbufs, header);
|
||||||
header);
|
|
||||||
}
|
}
|
||||||
/* remember the current config */
|
/* remember the current config */
|
||||||
rtpvorbisdepay->config = conf;
|
rtpvorbisdepay->config = conf;
|
||||||
|
@ -457,9 +458,9 @@ gst_rtp_vorbis_depay_process (GstRTPBaseDepayload * depayload,
|
||||||
{
|
{
|
||||||
GstRtpVorbisDepay *rtpvorbisdepay;
|
GstRtpVorbisDepay *rtpvorbisdepay;
|
||||||
GstBuffer *outbuf;
|
GstBuffer *outbuf;
|
||||||
GstFlowReturn ret;
|
|
||||||
gint payload_len;
|
gint payload_len;
|
||||||
GstBuffer *payload_buffer = NULL;
|
GstBuffer *payload_buffer = NULL;
|
||||||
|
GstBufferList *outbufs = NULL;
|
||||||
guint8 *payload;
|
guint8 *payload;
|
||||||
GstMapInfo map;
|
GstMapInfo map;
|
||||||
guint32 header, ident;
|
guint32 header, ident;
|
||||||
|
@ -498,6 +499,8 @@ gst_rtp_vorbis_depay_process (GstRTPBaseDepayload * depayload,
|
||||||
F = (header & 0xc0) >> 6;
|
F = (header & 0xc0) >> 6;
|
||||||
packets = (header & 0xf);
|
packets = (header & 0xf);
|
||||||
|
|
||||||
|
outbufs = gst_buffer_list_new ();
|
||||||
|
|
||||||
if (VDT == 0) {
|
if (VDT == 0) {
|
||||||
gboolean do_switch = FALSE;
|
gboolean do_switch = FALSE;
|
||||||
|
|
||||||
|
@ -513,7 +516,8 @@ gst_rtp_vorbis_depay_process (GstRTPBaseDepayload * depayload,
|
||||||
do_switch = TRUE;
|
do_switch = TRUE;
|
||||||
}
|
}
|
||||||
if (do_switch) {
|
if (do_switch) {
|
||||||
if (!gst_rtp_vorbis_depay_switch_codebook (rtpvorbisdepay, ident))
|
if (!gst_rtp_vorbis_depay_switch_codebook (rtpvorbisdepay,
|
||||||
|
ident, outbufs))
|
||||||
goto switch_failed;
|
goto switch_failed;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -532,8 +536,10 @@ gst_rtp_vorbis_depay_process (GstRTPBaseDepayload * depayload,
|
||||||
rtpvorbisdepay->assembling = TRUE;
|
rtpvorbisdepay->assembling = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!rtpvorbisdepay->assembling)
|
if (!rtpvorbisdepay->assembling) {
|
||||||
goto no_output;
|
gst_rtp_base_depayload_dropped (depayload);
|
||||||
|
goto no_data_output;
|
||||||
|
}
|
||||||
|
|
||||||
/* skip header and length. */
|
/* skip header and length. */
|
||||||
vdata = gst_rtp_buffer_get_payload_subbuffer (rtp, 6, -1);
|
vdata = gst_rtp_buffer_get_payload_subbuffer (rtp, 6, -1);
|
||||||
|
@ -543,7 +549,7 @@ gst_rtp_vorbis_depay_process (GstRTPBaseDepayload * depayload,
|
||||||
|
|
||||||
/* packet is not complete, we are done */
|
/* packet is not complete, we are done */
|
||||||
if (F != 3)
|
if (F != 3)
|
||||||
goto no_output;
|
goto no_data_output;
|
||||||
|
|
||||||
/* construct assembled buffer */
|
/* construct assembled buffer */
|
||||||
length = gst_adapter_available (rtpvorbisdepay->adapter);
|
length = gst_adapter_available (rtpvorbisdepay->adapter);
|
||||||
|
@ -599,6 +605,12 @@ gst_rtp_vorbis_depay_process (GstRTPBaseDepayload * depayload,
|
||||||
/* handle in-band configuration */
|
/* handle in-band configuration */
|
||||||
if (G_UNLIKELY (VDT == 1)) {
|
if (G_UNLIKELY (VDT == 1)) {
|
||||||
GST_DEBUG_OBJECT (rtpvorbisdepay, "in-band configuration");
|
GST_DEBUG_OBJECT (rtpvorbisdepay, "in-band configuration");
|
||||||
|
|
||||||
|
/* push all buffers we found so far and clear the cached header
|
||||||
|
extensions if any */
|
||||||
|
gst_rtp_base_depayload_push_list (depayload, outbufs);
|
||||||
|
gst_rtp_base_depayload_flush (depayload, FALSE);
|
||||||
|
|
||||||
if (!gst_rtp_vorbis_depay_parse_inband_configuration (rtpvorbisdepay,
|
if (!gst_rtp_vorbis_depay_parse_inband_configuration (rtpvorbisdepay,
|
||||||
ident, payload, payload_len, length))
|
ident, payload, payload_len, length))
|
||||||
goto invalid_configuration;
|
goto invalid_configuration;
|
||||||
|
@ -615,16 +627,20 @@ gst_rtp_vorbis_depay_process (GstRTPBaseDepayload * depayload,
|
||||||
/* make sure to read next length */
|
/* make sure to read next length */
|
||||||
length = 0;
|
length = 0;
|
||||||
|
|
||||||
ret = gst_rtp_base_depayload_push (depayload, outbuf);
|
gst_buffer_list_add (outbufs, outbuf);
|
||||||
if (ret != GST_FLOW_OK)
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gst_rtp_base_depayload_push_list (depayload, outbufs);
|
||||||
|
|
||||||
gst_buffer_unmap (payload_buffer, &map);
|
gst_buffer_unmap (payload_buffer, &map);
|
||||||
gst_buffer_unref (payload_buffer);
|
gst_buffer_unref (payload_buffer);
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
no_data_output:
|
||||||
|
/* we may have the headers from a codebook switch that should be
|
||||||
|
pushed */
|
||||||
|
gst_rtp_base_depayload_push_list (depayload, outbufs);
|
||||||
no_output:
|
no_output:
|
||||||
{
|
{
|
||||||
if (payload_buffer) {
|
if (payload_buffer) {
|
||||||
|
@ -638,17 +654,21 @@ switch_failed:
|
||||||
{
|
{
|
||||||
GST_ELEMENT_WARNING (rtpvorbisdepay, STREAM, DECODE,
|
GST_ELEMENT_WARNING (rtpvorbisdepay, STREAM, DECODE,
|
||||||
(NULL), ("Could not switch codebooks"));
|
(NULL), ("Could not switch codebooks"));
|
||||||
|
gst_buffer_list_unref (outbufs);
|
||||||
|
gst_rtp_base_depayload_dropped (depayload);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
packet_short:
|
packet_short:
|
||||||
{
|
{
|
||||||
GST_ELEMENT_WARNING (rtpvorbisdepay, STREAM, DECODE,
|
GST_ELEMENT_WARNING (rtpvorbisdepay, STREAM, DECODE,
|
||||||
(NULL), ("Packet was too short (%d < 4)", payload_len));
|
(NULL), ("Packet was too short (%d < 4)", payload_len));
|
||||||
|
gst_rtp_base_depayload_dropped (depayload);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
ignore_reserved:
|
ignore_reserved:
|
||||||
{
|
{
|
||||||
GST_WARNING_OBJECT (rtpvorbisdepay, "reserved VDT ignored");
|
GST_WARNING_OBJECT (rtpvorbisdepay, "reserved VDT ignored");
|
||||||
|
gst_rtp_base_depayload_dropped (depayload);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
length_short:
|
length_short:
|
||||||
|
@ -659,6 +679,8 @@ length_short:
|
||||||
gst_buffer_unmap (payload_buffer, &map);
|
gst_buffer_unmap (payload_buffer, &map);
|
||||||
gst_buffer_unref (payload_buffer);
|
gst_buffer_unref (payload_buffer);
|
||||||
}
|
}
|
||||||
|
gst_rtp_base_depayload_push_list (depayload, outbufs);
|
||||||
|
gst_rtp_base_depayload_flush (depayload, FALSE);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
invalid_configuration:
|
invalid_configuration:
|
||||||
|
|
Loading…
Reference in a new issue