mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-01 21:18:52 +00:00
hlsdemux: Do not push last buffer after error
In decryption scenario, a buffer is always stored to be sent later to wait for more data or EOS to be able to strip the final bytes if requested. In case an error hapenned this buffer can be ignored and not pushed downstream.
This commit is contained in:
parent
bb8887baa7
commit
940576244c
1 changed files with 19 additions and 14 deletions
|
@ -951,23 +951,28 @@ _src_event (GstPad * pad, GstObject * parent, GstEvent * event)
|
||||||
gst_adapter_clear (demux->adapter);
|
gst_adapter_clear (demux->adapter);
|
||||||
|
|
||||||
/* pending buffer is only used for encrypted streams */
|
/* pending buffer is only used for encrypted streams */
|
||||||
if (demux->pending_buffer) {
|
if (demux->last_ret == GST_FLOW_OK) {
|
||||||
GstMapInfo info;
|
if (demux->pending_buffer) {
|
||||||
gsize unpadded_size;
|
GstMapInfo info;
|
||||||
|
gsize unpadded_size;
|
||||||
|
|
||||||
/* Handle pkcs7 unpadding here */
|
/* Handle pkcs7 unpadding here */
|
||||||
gst_buffer_map (demux->pending_buffer, &info, GST_MAP_READ);
|
gst_buffer_map (demux->pending_buffer, &info, GST_MAP_READ);
|
||||||
unpadded_size = info.size - info.data[info.size - 1];
|
unpadded_size = info.size - info.data[info.size - 1];
|
||||||
gst_buffer_unmap (demux->pending_buffer, &info);
|
gst_buffer_unmap (demux->pending_buffer, &info);
|
||||||
|
|
||||||
gst_buffer_resize (demux->pending_buffer, 0, unpadded_size);
|
gst_buffer_resize (demux->pending_buffer, 0, unpadded_size);
|
||||||
|
|
||||||
/* TODO check return */
|
demux->download_total_time +=
|
||||||
demux->download_total_time +=
|
g_get_monotonic_time () - demux->download_start_time;
|
||||||
g_get_monotonic_time () - demux->download_start_time;
|
demux->download_total_bytes +=
|
||||||
demux->download_total_bytes +=
|
gst_buffer_get_size (demux->pending_buffer);
|
||||||
gst_buffer_get_size (demux->pending_buffer);
|
demux->last_ret = gst_pad_push (demux->srcpad, demux->pending_buffer);
|
||||||
gst_pad_push (demux->srcpad, demux->pending_buffer);
|
|
||||||
|
demux->pending_buffer = NULL;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
gst_buffer_unref (demux->pending_buffer);
|
||||||
demux->pending_buffer = NULL;
|
demux->pending_buffer = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue