1 Description: Backport changes for the libav 9 API
2 Also replace loading of libavcodec and libavutil via dlopen by linking against
4 Author: Sebastian Ramacher <sramacher@debian.org>
5 Bug-Debian: http://bugs.debian.org/720824
6 Last-Update: 2013-09-12
8 --- a/plugins/video/H.263-1998/h263-1998.cxx
9 +++ b/plugins/video/H.263-1998/h263-1998.cxx
14 - m_context = FFMPEGLibraryInstance.AvcodecAllocContext();
15 + m_context = FFMPEGLibraryInstance.AvcodecAllocContext(m_codec);
16 if (m_context == NULL) {
17 PTRACE(1, m_prefix, "Failed to allocate context for encoder");
23 +#ifdef CODEC_FLAG_H263P_UMV
24 if (STRCMPI(option, H263_ANNEX_D) == 0) {
25 // Annex D: Unrestructed Motion Vectors
28 m_context->flags &= ~CODEC_FLAG_H263P_UMV;
33 #if 0 // DO NOT ENABLE THIS FLAG. FFMPEG IS NOT THREAD_SAFE WHEN THIS FLAG IS SET
34 if (STRCMPI(option, H263_ANNEX_F) == 0) {
39 +#ifdef CODEC_FLAG_H263P_SLICE_STRUCT
40 if (STRCMPI(option, H263_ANNEX_K) == 0) {
41 // Annex K: Slice Structure
42 // does not work with eyeBeam
44 m_context->flags &= ~CODEC_FLAG_H263P_SLICE_STRUCT;
49 +#ifdef CODEC_FLAG_H263P_AIV
50 if (STRCMPI(option, H263_ANNEX_S) == 0) {
51 // Annex S: Alternative INTER VLC mode
52 // does not work with eyeBeam
54 m_context->flags &= ~CODEC_FLAG_H263P_AIV;
59 if (STRCMPI(option, PLUGINCODEC_MEDIA_PACKETIZATION) == 0 ||
60 STRCMPI(option, PLUGINCODEC_MEDIA_PACKETIZATIONS) == 0) {
62 PTRACE(5, m_prefix, "qmax set to " << m_context->qmax);
63 PTRACE(5, m_prefix, "payload size set to " << m_context->rtp_payload_size);
65 - #define CODEC_TRACER_FLAG(tracer, flag) \
66 - PTRACE(4, m_prefix, #flag " is " << ((m_context->flags & flag) ? "enabled" : "disabled"));
67 - CODEC_TRACER_FLAG(tracer, CODEC_FLAG_H263P_UMV);
68 - CODEC_TRACER_FLAG(tracer, CODEC_FLAG_OBMC);
69 - CODEC_TRACER_FLAG(tracer, CODEC_FLAG_AC_PRED);
70 - CODEC_TRACER_FLAG(tracer, CODEC_FLAG_H263P_SLICE_STRUCT)
71 - CODEC_TRACER_FLAG(tracer, CODEC_FLAG_LOOP_FILTER);
72 - CODEC_TRACER_FLAG(tracer, CODEC_FLAG_H263P_AIV);
74 return FFMPEGLibraryInstance.AvcodecOpen(m_context, m_codec) == 0;
79 // Need to copy to local buffer to guarantee 16 byte alignment
80 memcpy(m_inputFrame->data[0], OPAL_VIDEO_FRAME_DATA_PTR(header), header->width*header->height*3/2);
81 - m_inputFrame->pict_type = (flags & PluginCodec_CoderForceIFrame) ? FF_I_TYPE : AV_PICTURE_TYPE_NONE;
82 + m_inputFrame->pict_type = (flags & PluginCodec_CoderForceIFrame) ? AV_PICTURE_TYPE_I : AV_PICTURE_TYPE_NONE;
85 m_inputFrame->pts = (int64_t)srcRTP.GetTimestamp()*m_context->time_base.den/m_context->time_base.num/VIDEO_CLOCKRATE;
87 m_context->rtp_callback = &H263_RFC2190_EncoderContext::RTPCallBack;
88 m_context->opaque = this; // used to separate out packets from different encode threads
90 +#ifdef CODEC_FLAG_H263P_UMV
91 m_context->flags &= ~CODEC_FLAG_H263P_UMV;
93 m_context->flags &= ~CODEC_FLAG_4MV;
94 #if LIBAVCODEC_RTP_MODE
95 m_context->flags &= ~CODEC_FLAG_H263P_AIC;
97 +#ifdef CODEC_FLAG_H263P_AIV
98 m_context->flags &= ~CODEC_FLAG_H263P_AIV;
100 +#ifdef CODEC_FLAG_H263P_SLICE_STRUCT
101 m_context->flags &= ~CODEC_FLAG_H263P_SLICE_STRUCT;
110 - m_context = FFMPEGLibraryInstance.AvcodecAllocContext();
111 + m_context = FFMPEGLibraryInstance.AvcodecAllocContext(m_codec);
112 if (m_context == NULL) {
113 PTRACE(1, m_prefix, "Failed to allocate context for decoder");
115 --- a/plugins/video/H.264/h264-x264.cxx
116 +++ b/plugins/video/H.264/h264-x264.cxx
118 #include "shared/h264frame.h"
119 #include "shared/x264wrap.h"
123 #define MY_CODEC x264 // Name of codec (use C variable characters)
124 #define MY_CODEC_LOG "x264"
125 @@ -1067,18 +1068,17 @@
126 if ((m_codec = FFMPEGLibraryInstance.AvcodecFindDecoder(CODEC_ID_H264)) == NULL)
129 - if ((m_context = FFMPEGLibraryInstance.AvcodecAllocContext()) == NULL)
130 + if ((m_context = FFMPEGLibraryInstance.AvcodecAllocContext(m_codec)) == NULL)
133 m_context->workaround_bugs = FF_BUG_AUTODETECT;
134 - m_context->error_recognition = FF_ER_AGGRESSIVE;
135 m_context->idct_algo = FF_IDCT_H264;
136 m_context->error_concealment = FF_EC_GUESS_MVS | FF_EC_DEBLOCK;
137 m_context->flags = CODEC_FLAG_INPUT_PRESERVED | CODEC_FLAG_EMU_EDGE;
138 - m_context->flags2 = CODEC_FLAG2_BRDO |
139 - CODEC_FLAG2_MEMC_ONLY |
140 + m_context->flags2 = CODEC_FLAG2_SKIP_RD |
141 +#ifdef CODEC_FLAG2_DROP_FRAME_TIMECODE
142 CODEC_FLAG2_DROP_FRAME_TIMECODE |
143 - CODEC_FLAG2_SKIP_RD |
147 if ((m_picture = FFMPEGLibraryInstance.AvcodecAllocFrame()) == NULL)
148 --- a/plugins/video/MPEG4-ffmpeg/mpeg4.cxx
149 +++ b/plugins/video/MPEG4-ffmpeg/mpeg4.cxx
150 @@ -589,17 +589,14 @@
151 m_avpicture->quality = m_videoQMin;
154 - m_avcontext->flags |= CODEC_FLAG_PART; // data partitioning
155 m_avcontext->flags |= CODEC_FLAG_4MV; // 4 motion vectors
157 m_avcontext->max_b_frames=0; /*don't use b frames*/
158 m_avcontext->flags|=CODEC_FLAG_AC_PRED;
159 - m_avcontext->flags|=CODEC_FLAG_H263P_UMV;
160 /*c->flags|=CODEC_FLAG_QPEL;*/ /*don't enable this one: this forces profile_level to advanced simple profile */
161 m_avcontext->flags|=CODEC_FLAG_4MV;
162 m_avcontext->flags|=CODEC_FLAG_GMC;
163 m_avcontext->flags|=CODEC_FLAG_LOOP_FILTER;
164 - m_avcontext->flags|=CODEC_FLAG_H263P_SLICE_STRUCT;
166 m_avcontext->opaque = this; // for use in RTP callback
170 bool MPEG4EncoderContext::OpenCodec()
172 - m_avcontext = FFMPEGLibraryInstance.AvcodecAllocContext();
173 + if((m_avcodec = FFMPEGLibraryInstance.AvcodecFindEncoder(CODEC_ID_MPEG4)) == NULL){
174 + PTRACE(1, "MPEG4", "Encoder not found");
178 + m_avcontext = FFMPEGLibraryInstance.AvcodecAllocContext(m_avcodec);
179 if (m_avcontext == NULL) {
180 PTRACE(1, "MPEG4", "Encoder failed to allocate context for encoder");
186 - if((m_avcodec = FFMPEGLibraryInstance.AvcodecFindEncoder(CODEC_ID_MPEG4)) == NULL){
187 - PTRACE(1, "MPEG4", "Encoder not found");
191 #if PLUGINCODEC_TRACING
193 if (PTRACE_CHECK(4)) {
195 // Should the next frame be an I-Frame?
196 if ((flags & PluginCodec_CoderForceIFrame) || (m_frameNum == 0))
198 - m_avpicture->pict_type = FF_I_TYPE;
199 + m_avpicture->pict_type = AV_PICTURE_TYPE_I;
201 else // No IFrame requested, let avcodec decide what to do
203 @@ -1325,7 +1322,6 @@
205 void MPEG4DecoderContext::SetStaticDecodingParams() {
206 m_avcontext->flags |= CODEC_FLAG_4MV;
207 - m_avcontext->flags |= CODEC_FLAG_PART;
208 m_avcontext->workaround_bugs = 0; // no workaround for buggy implementations
211 @@ -1399,7 +1395,7 @@
215 - m_avcontext = FFMPEGLibraryInstance.AvcodecAllocContext();
216 + m_avcontext = FFMPEGLibraryInstance.AvcodecAllocContext(m_avcodec);
217 if (m_avcontext == NULL) {
218 PTRACE(1, "MPEG4", "Decoder failed to allocate context");
220 --- a/plugins/video/common/dyna.cxx
221 +++ b/plugins/video/common/dyna.cxx
223 * Matthias Schneider (ma30002000@yahoo.de)
230 +#include <libavcodec/avcodec.h>
231 +#include <libavutil/mem.h>
234 bool DynaLink::Open(const char *name)
236 @@ -228,101 +235,15 @@
240 -#define CHECK_AVUTIL(name, func) \
241 - (seperateLibAvutil ? \
242 - m_libAvutil.GetFunction(name, (DynaLink::Function &)func) : \
243 - m_libAvcodec.GetFunction(name, (DynaLink::Function &)func) \
247 bool FFMPEGLibrary::Load()
249 WaitAndSignal m(processLock);
253 - bool seperateLibAvutil = false;
255 -#ifdef LIBAVCODEC_LIB_NAME
256 - if (m_libAvcodec.Open(LIBAVCODEC_LIB_NAME))
257 - seperateLibAvutil = true;
260 - if (m_libAvcodec.Open("libavcodec"))
261 - seperateLibAvutil = false;
262 - else if (m_libAvcodec.Open("avcodec-" AV_STRINGIFY(LIBAVCODEC_VERSION_MAJOR)))
263 - seperateLibAvutil = true;
265 - PTRACE(1, m_codecString, "Failed to load FFMPEG libavcodec library");
269 - if (seperateLibAvutil &&
271 -#ifdef LIBAVUTIL_LIB_NAME
272 - m_libAvutil.Open(LIBAVUTIL_LIB_NAME) ||
274 - m_libAvutil.Open("libavutil") ||
275 - m_libAvutil.Open("avutil-" AV_STRINGIFY(LIBAVUTIL_VERSION_MAJOR))
277 - PTRACE(1, m_codecString, "Failed to load FFMPEG libavutil library");
281 - strcpy(m_libAvcodec.m_codecString, m_codecString);
282 - strcpy(m_libAvutil.m_codecString, m_codecString);
284 - if (!m_libAvcodec.GetFunction("avcodec_init", (DynaLink::Function &)Favcodec_init))
287 - if (!m_libAvcodec.GetFunction("av_init_packet", (DynaLink::Function &)Fav_init_packet))
290 - if (!m_libAvcodec.GetFunction("avcodec_register_all", (DynaLink::Function &)Favcodec_register_all))
293 - if (!m_libAvcodec.GetFunction("avcodec_find_encoder", (DynaLink::Function &)Favcodec_find_encoder))
296 - if (!m_libAvcodec.GetFunction("avcodec_find_decoder", (DynaLink::Function &)Favcodec_find_decoder))
299 - if (!m_libAvcodec.GetFunction("avcodec_alloc_context", (DynaLink::Function &)Favcodec_alloc_context))
302 - if (!m_libAvcodec.GetFunction("avcodec_alloc_frame", (DynaLink::Function &)Favcodec_alloc_frame))
305 - if (!m_libAvcodec.GetFunction("avcodec_open", (DynaLink::Function &)Favcodec_open))
308 - if (!m_libAvcodec.GetFunction("avcodec_close", (DynaLink::Function &)Favcodec_close))
311 - if (!m_libAvcodec.GetFunction("avcodec_encode_video", (DynaLink::Function &)Favcodec_encode_video))
314 - if (!m_libAvcodec.GetFunction("avcodec_decode_video2", (DynaLink::Function &)Favcodec_decode_video))
317 - if (!m_libAvcodec.GetFunction("avcodec_set_dimensions", (DynaLink::Function &)Favcodec_set_dimensions))
320 - if (!CHECK_AVUTIL("av_free", Favcodec_free))
323 - if(!m_libAvcodec.GetFunction("avcodec_version", (DynaLink::Function &)Favcodec_version))
326 - if (!CHECK_AVUTIL("av_log_set_level", FAv_log_set_level))
329 - if (!CHECK_AVUTIL("av_log_set_callback", FAv_log_set_callback))
332 // must be called before using avcodec lib
334 - unsigned libVer = Favcodec_version();
335 + unsigned libVer = avcodec_version();
336 if (libVer != LIBAVCODEC_VERSION_INT) {
337 PTRACE(2, m_codecString, "Warning: compiled against libavcodec headers from version "
338 << LIBAVCODEC_VERSION_MAJOR << '.' << LIBAVCODEC_VERSION_MINOR << '.' << LIBAVCODEC_VERSION_MICRO
340 << (libVer >> 16) << ((libVer>>8) & 0xff) << (libVer & 0xff));
344 - Favcodec_register_all ();
345 + avcodec_register_all();
347 #if PLUGINCODEC_TRACING
348 AvLogSetLevel(AV_LOG_DEBUG);
349 @@ -350,49 +270,49 @@
351 AVCodec *FFMPEGLibrary::AvcodecFindEncoder(enum CodecID id)
353 - return Favcodec_find_encoder(id);
354 + return avcodec_find_encoder(id);
357 AVCodec *FFMPEGLibrary::AvcodecFindDecoder(enum CodecID id)
359 WaitAndSignal m(processLock);
361 - return Favcodec_find_decoder(id);
362 + return avcodec_find_decoder(id);
365 -AVCodecContext *FFMPEGLibrary::AvcodecAllocContext(void)
366 +AVCodecContext *FFMPEGLibrary::AvcodecAllocContext(AVCodec *codec)
368 WaitAndSignal m(processLock);
370 - return Favcodec_alloc_context();
371 + return avcodec_alloc_context3(codec);
374 AVFrame *FFMPEGLibrary::AvcodecAllocFrame(void)
376 WaitAndSignal m(processLock);
378 - return Favcodec_alloc_frame();
379 + return avcodec_alloc_frame();
382 int FFMPEGLibrary::AvcodecOpen(AVCodecContext *ctx, AVCodec *codec)
384 WaitAndSignal m(processLock);
386 - return Favcodec_open(ctx, codec);
387 + return avcodec_open2(ctx, codec, NULL);
390 int FFMPEGLibrary::AvcodecClose(AVCodecContext *ctx)
392 WaitAndSignal m(processLock);
394 - return Favcodec_close(ctx);
395 + return avcodec_close(ctx);
398 int FFMPEGLibrary::AvcodecEncodeVideo(AVCodecContext *ctx, BYTE *buf, int buf_size, const AVFrame *pict)
402 - res = Favcodec_encode_video(ctx, buf, buf_size, pict);
403 + res = avcodec_encode_video(ctx, buf, buf_size, pict);
405 PTRACE(6, m_codecString, "DYNA\tEncoded into " << res << " bytes, max " << buf_size);
407 @@ -401,35 +321,35 @@
408 int FFMPEGLibrary::AvcodecDecodeVideo(AVCodecContext *ctx, AVFrame *pict, int *got_picture_ptr, BYTE *buf, int buf_size)
411 - Fav_init_packet(&avpkt);
412 + av_init_packet(&avpkt);
414 avpkt.size = buf_size;
416 - return Favcodec_decode_video(ctx, pict, got_picture_ptr, &avpkt);
417 + return avcodec_decode_video2(ctx, pict, got_picture_ptr, &avpkt);
420 void FFMPEGLibrary::AvcodecFree(void * ptr)
422 WaitAndSignal m(processLock);
424 - Favcodec_free(ptr);
428 void FFMPEGLibrary::AvSetDimensions(AVCodecContext *s, int width, int height)
430 WaitAndSignal m(processLock);
432 - Favcodec_set_dimensions(s, width, height);
433 + avcodec_set_dimensions(s, width, height);
436 void FFMPEGLibrary::AvLogSetLevel(int level)
438 - FAv_log_set_level(level);
439 + av_log_set_level(level);
442 void FFMPEGLibrary::AvLogSetCallback(void (*callback)(void*, int, const char*, va_list))
444 - FAv_log_set_callback(callback);
445 + av_log_set_callback(callback);
448 bool FFMPEGLibrary::IsLoaded()
449 --- a/plugins/video/common/dyna.h
450 +++ b/plugins/video/common/dyna.h
453 AVCodec *AvcodecFindEncoder(enum CodecID id);
454 AVCodec *AvcodecFindDecoder(enum CodecID id);
455 - AVCodecContext *AvcodecAllocContext(void);
456 + AVCodecContext *AvcodecAllocContext(AVCodec*);
457 AVFrame *AvcodecAllocFrame(void);
458 int AvcodecOpen(AVCodecContext *ctx, AVCodec *codec);
459 int AvcodecClose(AVCodecContext *ctx);
462 char m_codecString[32];
464 - void (*Favcodec_init)(void);
465 - void (*Fav_init_packet)(AVPacket *pkt);
467 - void (*Favcodec_register_all)(void);
468 - AVCodec *(*Favcodec_find_encoder)(enum CodecID id);
469 - AVCodec *(*Favcodec_find_decoder)(enum CodecID id);
470 - AVCodecContext *(*Favcodec_alloc_context)(void);
471 - AVFrame *(*Favcodec_alloc_frame)(void);
472 - int (*Favcodec_open)(AVCodecContext *ctx, AVCodec *codec);
473 - int (*Favcodec_close)(AVCodecContext *ctx);
474 - int (*Favcodec_encode_video)(AVCodecContext *ctx, BYTE *buf, int buf_size, const AVFrame *pict);
475 - int (*Favcodec_decode_video)(AVCodecContext *ctx, AVFrame *pict, int *got_picture_ptr, AVPacket *avpkt);
476 - unsigned (*Favcodec_version)(void);
477 - void (*Favcodec_set_dimensions)(AVCodecContext *ctx, int width, int height);
479 - void (*Favcodec_free)(void *);
481 - void (*FAv_log_set_level)(int level);
482 - void (*FAv_log_set_callback)(void (*callback)(void*, int, const char*, va_list));
487 --- a/plugins/video/common/ffmpeg.h
488 +++ b/plugins/video/common/ffmpeg.h
491 #include "platform.h"
493 -#include "libavcodec/avcodec.h"
495 +#include <libavcodec/avcodec.h>
496 // AVPacket was declared in avformat.h before April 2009
497 #if LIBAVCODEC_VERSION_INT <= AV_VERSION_INT(52, 25, 0)
498 -#include "libavformat/avformat.h"
499 +#include <libavformat/avformat.h>
503 #ifndef LIBAVCODEC_VERSION_INT
504 #error Libavcodec include is not correct
505 --- a/plugins/video/H.263-1998/Makefile.in
506 +++ b/plugins/video/H.263-1998/Makefile.in
508 $(COMMONDIR)/mpi.cxx \
509 $(COMMONDIR)/dyna.cxx
511 -CFLAGS += @LIBAVCODEC_CFLAGS@ -I$(COMMONDIR)
513 +CFLAGS += @LIBAVCODEC_CFLAGS@ @LIBAVUTIL_CFLAGS@ -I$(COMMONDIR)
514 +LIBS += @DL_LIBS@ @LIBAVCODEC_LIBS@ @LIBAVUTIL_LIBS@
516 HAVE_LIBAVCODEC_RTP_MODE=@HAVE_LIBAVCODEC_RTP_MODE@
517 ifeq ($(HAVE_LIBAVCODEC_RTP_MODE),yes)
518 --- a/plugins/video/H.264/Makefile.in
519 +++ b/plugins/video/H.264/Makefile.in
521 $(SHAREDDIR)/x264wrap.cxx \
522 $(COMMONDIR)/dyna.cxx \
524 -CFLAGS += @LIBAVCODEC_CFLAGS@ -I$(COMMONDIR) -DLIB_DIR='"$(libdir)"' -DVC_PLUGIN_DIR='"@VC_PLUGIN_DIR@"'
526 +CFLAGS += @LIBAVCODEC_CFLAGS@ @LIBAVUTIL_CFLAGS@ -I$(COMMONDIR) -DLIB_DIR='"$(libdir)"' -DVC_PLUGIN_DIR='"@VC_PLUGIN_DIR@"'
527 +LIBS += @DL_LIBS@ @LIBAVCODEC_LIBS@ @LIBAVUTIL_LIBS@
529 IS_H264_LICENSED:=@IS_H264_LICENSED@
530 ifeq ($(IS_H264_LICENSED),yes)
531 --- a/plugins/video/MPEG4-ffmpeg/Makefile.in
532 +++ b/plugins/video/MPEG4-ffmpeg/Makefile.in
535 SRCS := mpeg4.cxx $(COMMONDIR)/dyna.cxx
537 -CFLAGS += @LIBAVCODEC_CFLAGS@ -I$(COMMONDIR)
539 +CFLAGS += @LIBAVCODEC_CFLAGS@ @LIBAVUTIL_CFLAGS@ -I$(COMMONDIR)
540 +LIBS += @DL_LIBS@ @LIBAVCODEC_LIBS@ @LIBAVUTIL_LIBS@
542 # Add LIBAVCODEC_SOURCE_DIR to the include path so we can #include <libavcodec/...h>
543 # Also add libavutil, so ffmpeg headers can #include "log.h".