mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-27 01:28:34 +00:00
audioresample: Take the output offsets from the input if possible
Fixes bug #588915.
This commit is contained in:
parent
b69f5e2c66
commit
4689acd68f
1 changed files with 30 additions and 7 deletions
|
@ -845,12 +845,18 @@ gst_audio_resample_push_drain (GstAudioResample * resample)
|
||||||
out_processed * resample->channels * (resample->width / 8);
|
out_processed * resample->channels * (resample->width / 8);
|
||||||
|
|
||||||
if (GST_CLOCK_TIME_IS_VALID (resample->next_ts)) {
|
if (GST_CLOCK_TIME_IS_VALID (resample->next_ts)) {
|
||||||
|
GST_BUFFER_TIMESTAMP (buf) = resample->next_ts;
|
||||||
|
resample->next_ts += GST_BUFFER_DURATION (buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (resample->next_offset != -1) {
|
||||||
GST_BUFFER_OFFSET (buf) = resample->next_offset;
|
GST_BUFFER_OFFSET (buf) = resample->next_offset;
|
||||||
GST_BUFFER_OFFSET_END (buf) = resample->next_offset + out_processed;
|
GST_BUFFER_OFFSET_END (buf) = resample->next_offset + out_processed;
|
||||||
GST_BUFFER_TIMESTAMP (buf) = resample->next_ts;
|
|
||||||
|
|
||||||
resample->next_ts += GST_BUFFER_DURATION (buf);
|
|
||||||
resample->next_offset += out_processed;
|
resample->next_offset += out_processed;
|
||||||
|
} else {
|
||||||
|
/* should be impossible, but just incase */
|
||||||
|
GST_BUFFER_OFFSET (buf) = GST_BUFFER_OFFSET_NONE;
|
||||||
|
GST_BUFFER_OFFSET_END (buf) = GST_BUFFER_OFFSET_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_LOG_OBJECT (resample,
|
GST_LOG_OBJECT (resample,
|
||||||
|
@ -1009,11 +1015,17 @@ gst_audio_resample_process (GstAudioResample * resample, GstBuffer * inbuf,
|
||||||
|
|
||||||
if (GST_CLOCK_TIME_IS_VALID (resample->next_ts)) {
|
if (GST_CLOCK_TIME_IS_VALID (resample->next_ts)) {
|
||||||
GST_BUFFER_TIMESTAMP (outbuf) = resample->next_ts;
|
GST_BUFFER_TIMESTAMP (outbuf) = resample->next_ts;
|
||||||
|
resample->next_ts += GST_BUFFER_DURATION (outbuf);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (resample->next_offset != -1) {
|
||||||
GST_BUFFER_OFFSET (outbuf) = resample->next_offset;
|
GST_BUFFER_OFFSET (outbuf) = resample->next_offset;
|
||||||
GST_BUFFER_OFFSET_END (outbuf) = resample->next_offset + out_processed;
|
GST_BUFFER_OFFSET_END (outbuf) = resample->next_offset + out_processed;
|
||||||
|
|
||||||
resample->next_ts += GST_BUFFER_DURATION (outbuf);
|
|
||||||
resample->next_offset += out_processed;
|
resample->next_offset += out_processed;
|
||||||
|
} else {
|
||||||
|
/* should be impossible, but just incase */
|
||||||
|
GST_BUFFER_OFFSET (outbuf) = GST_BUFFER_OFFSET_NONE;
|
||||||
|
GST_BUFFER_OFFSET_END (outbuf) = GST_BUFFER_OFFSET_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_LOG_OBJECT (resample,
|
GST_LOG_OBJECT (resample,
|
||||||
|
@ -1083,8 +1095,19 @@ gst_audio_resample_transform (GstBaseTransform * base, GstBuffer * inbuf,
|
||||||
if (GST_CLOCK_TIME_IS_VALID (timestamp)
|
if (GST_CLOCK_TIME_IS_VALID (timestamp)
|
||||||
&& !GST_CLOCK_TIME_IS_VALID (resample->next_ts)) {
|
&& !GST_CLOCK_TIME_IS_VALID (resample->next_ts)) {
|
||||||
resample->next_ts = timestamp;
|
resample->next_ts = timestamp;
|
||||||
resample->next_offset =
|
}
|
||||||
GST_CLOCK_TIME_TO_FRAMES (timestamp, resample->outrate);
|
|
||||||
|
if (resample->next_offset == -1) {
|
||||||
|
if (GST_BUFFER_OFFSET_IS_VALID (inbuf)) {
|
||||||
|
resample->next_offset =
|
||||||
|
gst_util_uint64_scale_int (GST_BUFFER_OFFSET (inbuf),
|
||||||
|
resample->outrate, resample->inrate);
|
||||||
|
} else if (GST_CLOCK_TIME_IS_VALID (timestamp)) {
|
||||||
|
resample->next_offset =
|
||||||
|
GST_CLOCK_TIME_TO_FRAMES (timestamp, resample->outrate);
|
||||||
|
} else {
|
||||||
|
resample->next_offset = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (G_UNLIKELY (resample->need_discont)) {
|
if (G_UNLIKELY (resample->need_discont)) {
|
||||||
|
|
Loading…
Reference in a new issue