tg_owt/tg_owt-0.1+20240804git.dc17143-ffmpeg-7.patch

59 lines
2.3 KiB
Diff

From c08682eda2d03bec1648cf5c779241ac0f14cde3 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Robert-Andr=C3=A9=20Mauchin?= <zebob.m@gmail.com>
Date: Sat, 11 May 2024 19:11:07 +0200
Subject: [PATCH] Add compatibility with FFMPEG 7.0
avutil: remove deprecated FF_API_REORDERED_OPAQUE
Ref: https://github.com/FFmpeg/FFmpeg/commit/67e7f0b05eeee37eee1357769038270fda08fe32
---
.../video_coding/codecs/h264/h264_decoder_impl.cc | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/src/modules/video_coding/codecs/h264/h264_decoder_impl.cc b/src/modules/video_coding/codecs/h264/h264_decoder_impl.cc
index 76d04e418..bc3917c52 100644
--- a/src/modules/video_coding/codecs/h264/h264_decoder_impl.cc
+++ b/src/modules/video_coding/codecs/h264/h264_decoder_impl.cc
@@ -14,6 +14,9 @@
// #ifdef unless needed and tested.
#ifdef WEBRTC_USE_H264
+#define HAVE_FFMPEG_REORDERED_OPAQUE (LIBAVFORMAT_VERSION_INT < \
+ AV_VERSION_INT(59, 8, 100))
+
#include "modules/video_coding/codecs/h264/h264_decoder_impl.h"
#include <algorithm>
@@ -212,7 +215,9 @@ int H264DecoderImpl::AVGetBuffer2(AVCodecContext* context,
int total_size = y_size + 2 * uv_size;
av_frame->format = context->pix_fmt;
+#if HAVE_FFMPEG_REORDERED_OPAQUE
av_frame->reordered_opaque = context->reordered_opaque;
+#endif
// Create a VideoFrame object, to keep a reference to the buffer.
// TODO(nisse): The VideoFrame's timestamp and rotation info is not used.
@@ -361,7 +366,9 @@ int32_t H264DecoderImpl::Decode(const EncodedImage& input_image,
}
packet->size = static_cast<int>(input_image.size());
int64_t frame_timestamp_us = input_image.ntp_time_ms_ * 1000; // ms -> μs
+#if HAVE_FFMPEG_REORDERED_OPAQUE
av_context_->reordered_opaque = frame_timestamp_us;
+#endif
int result = avcodec_send_packet(av_context_.get(), packet.get());
@@ -378,9 +385,11 @@ int32_t H264DecoderImpl::Decode(const EncodedImage& input_image,
return WEBRTC_VIDEO_CODEC_ERROR;
}
+#if HAVE_FFMPEG_REORDERED_OPAQUE
// We don't expect reordering. Decoded frame timestamp should match
// the input one.
RTC_DCHECK_EQ(av_frame_->reordered_opaque, frame_timestamp_us);
+#endif
// TODO(sakal): Maybe it is possible to get QP directly from FFmpeg.
h264_bitstream_parser_.ParseBitstream(input_image);