[FFmpeg-cvslog] [ffmpeg] branch master updated. a7c8c4ee1c lavc/mfenc: set output packet duration
ffmpeg-git at ffmpeg.org
ffmpeg-git at ffmpeg.org
Thu Aug 14 17:14:14 EEST 2025
The branch, master has been updated
via a7c8c4ee1ce1f0d66953ec1d924ab9c48ee14199 (commit)
from 1532caaab09a257dda8207c8e3d4f7c9679ce18c (commit)
- Log -----------------------------------------------------------------
commit a7c8c4ee1ce1f0d66953ec1d924ab9c48ee14199
Author: Pavel Koshevoy <pkoshevoy at gmail.com>
AuthorDate: Mon Aug 4 13:50:26 2025 -0600
Commit: James Almer <jamrial at gmail.com>
CommitDate: Thu Aug 14 11:13:09 2025 -0300
lavc/mfenc: set output packet duration
Signed-off-by: James Almer <jamrial at gmail.com>
diff --git a/libavcodec/mfenc.c b/libavcodec/mfenc.c
index 30531fe3e8..942c75cb9d 100644
--- a/libavcodec/mfenc.c
+++ b/libavcodec/mfenc.c
@@ -148,6 +148,15 @@ static int64_t mf_sample_get_pts(AVCodecContext *avctx, IMFSample *sample)
return mf_from_mf_time(avctx, pts);
}
+static int64_t mf_sample_get_duration(AVCodecContext *avctx, IMFSample *sample)
+{
+ LONGLONG duration;
+ HRESULT hr = IMFSample_GetSampleDuration(sample, &duration);
+ if (FAILED(hr))
+ return 0;
+ return mf_from_mf_time(avctx, duration);
+}
+
static int mf_enca_output_type_get(AVCodecContext *avctx, IMFMediaType *type)
{
MFContext *c = avctx->priv_data;
@@ -275,6 +284,7 @@ static int mf_sample_to_avpacket(AVCodecContext *avctx, IMFSample *sample, AVPac
IMFMediaBuffer_Release(buffer);
avpkt->pts = avpkt->dts = mf_sample_get_pts(avctx, sample);
+ avpkt->duration = mf_sample_get_duration(avctx, sample);
hr = IMFAttributes_GetUINT32(sample, &MFSampleExtension_CleanPoint, &t32);
if (c->is_audio || (!FAILED(hr) && t32 != 0))
-----------------------------------------------------------------------
Summary of changes:
libavcodec/mfenc.c | 10 ++++++++++
1 file changed, 10 insertions(+)
hooks/post-receive
--
More information about the ffmpeg-cvslog
mailing list