[FFmpeg-devel] [PATCH] lavc/mfenc: set output packet duration
James Almer
jamrial at gmail.com
Tue Aug 12 16:58:46 EEST 2025
On 8/4/2025 4:50 PM, Pavel Koshevoy wrote:
> ---
> libavcodec/mfenc.c | 10 ++++++++++
> 1 file changed, 10 insertions(+)
>
> 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))
Will apply.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: OpenPGP_signature.asc
Type: application/pgp-signature
Size: 495 bytes
Desc: OpenPGP digital signature
URL: <https://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20250812/d190998a/attachment.sig>
More information about the ffmpeg-devel
mailing list