fallbackswitch: add support for buffers without pts

Re-use the previously seen PTS.

Fix #186
This commit is contained in:
Guillaume Desmottes 2022-02-28 13:52:05 +01:00
parent ac1c6e513e
commit e097feea1f

View file

@ -231,11 +231,6 @@ impl FallbackSwitch {
buffer buffer
); );
if buffer.pts().is_none() {
gst_error!(CAT, obj: preferred_pad, "Only buffers with PTS supported");
return Err(gst::FlowError::Error);
}
let segment = preferred_pad let segment = preferred_pad
.segment() .segment()
.downcast::<gst::ClockTime>() .downcast::<gst::ClockTime>()
@ -244,12 +239,29 @@ impl FallbackSwitch {
gst::FlowError::Error gst::FlowError::Error
})?; })?;
let running_time = segment.to_running_time(buffer.dts_or_pts()); let running_time = if buffer.pts().is_none() {
// re-use ts from previous buffer
let running_time = state
.primary
.last_sinkpad_time
.max(state.fallback.last_sinkpad_time);
gst_debug!(
CAT,
obj: preferred_pad,
"Buffer does not have PTS, re-use ts from previous buffer: {}",
running_time.display()
);
running_time
} else {
segment.to_running_time(buffer.pts())
};
{ {
// FIXME: This will not work correctly for negative DTS // FIXME: This will not work correctly for negative DTS
let buffer = buffer.make_mut(); let buffer = buffer.make_mut();
buffer.set_pts(segment.to_running_time(buffer.pts())); buffer.set_pts(running_time);
buffer.set_dts(segment.to_running_time(buffer.dts())); buffer.set_dts(segment.to_running_time(buffer.dts()));
} }
@ -363,11 +375,6 @@ impl FallbackSwitch {
buffer buffer
); );
if buffer.pts().is_none() {
gst_error!(CAT, obj: backup_pad, "Only buffers with PTS supported");
return Err(gst::FlowError::Error);
}
let backup_segment = let backup_segment =
backup_pad backup_pad
.segment() .segment()
@ -376,12 +383,30 @@ impl FallbackSwitch {
gst_error!(CAT, obj: backup_pad, "Only TIME segments supported"); gst_error!(CAT, obj: backup_pad, "Only TIME segments supported");
gst::FlowError::Error gst::FlowError::Error
})?; })?;
let running_time = backup_segment.to_running_time(buffer.dts_or_pts());
let running_time = if buffer.pts().is_none() {
// re-use ts from previous buffer
let running_time = state
.primary
.last_sinkpad_time
.max(state.fallback.last_sinkpad_time);
gst_debug!(
CAT,
obj: backup_pad,
"Buffer does not have PTS, re-use ts from previous buffer: {}",
running_time.display()
);
running_time
} else {
backup_segment.to_running_time(buffer.pts())
};
{ {
// FIXME: This will not work correctly for negative DTS // FIXME: This will not work correctly for negative DTS
let buffer = buffer.make_mut(); let buffer = buffer.make_mut();
buffer.set_pts(backup_segment.to_running_time(buffer.pts())); buffer.set_pts(running_time);
buffer.set_dts(backup_segment.to_running_time(buffer.dts())); buffer.set_dts(backup_segment.to_running_time(buffer.dts()));
} }
@ -1049,12 +1074,6 @@ impl AggregatorImpl for FallbackSwitch {
.as_ref() .as_ref()
.and_then(|p| p.peek_buffer().map(|buffer| (buffer, p))) .and_then(|p| p.peek_buffer().map(|buffer| (buffer, p)))
{ {
if buffer.pts().is_none() {
gst_error!(CAT, obj: agg, "Only buffers with PTS supported");
// Trigger aggregate immediately to error out immediately
return Some(gst::ClockTime::ZERO);
}
let segment = match backup_sinkpad.segment().downcast::<gst::ClockTime>() { let segment = match backup_sinkpad.segment().downcast::<gst::ClockTime>() {
Ok(segment) => segment, Ok(segment) => segment,
Err(_) => { Err(_) => {
@ -1064,7 +1083,26 @@ impl AggregatorImpl for FallbackSwitch {
} }
}; };
let running_time = segment.to_running_time(buffer.dts_or_pts()); let running_time = if buffer.pts().is_none() {
// re-use ts from previous buffer
let state = self.output_state.lock().unwrap();
let running_time = state
.primary
.last_sinkpad_time
.max(state.fallback.last_sinkpad_time);
gst_debug!(
CAT,
obj: agg,
"Buffer does not have PTS, re-use ts from previous buffer: {}",
running_time.display(),
);
running_time
} else {
segment.to_running_time(buffer.pts())
};
gst_debug!( gst_debug!(
CAT, CAT,
obj: agg, obj: agg,
@ -1097,7 +1135,7 @@ impl AggregatorImpl for FallbackSwitch {
let pts = buffer.pts(); let pts = buffer.pts();
if pts.is_none() { if pts.is_none() {
gst_error!(CAT, obj: agg, "Only buffers with PTS supported"); gst_debug!(CAT, obj: agg, "Only clipping buffers with PTS supported");
return Some(buffer); return Some(buffer);
} }