diff options
Diffstat (limited to 'multimedia')
-rw-r--r-- | multimedia/xbmc/README | 10 | ||||
-rw-r--r-- | multimedia/xbmc/patches/0001-Revert-drop-support-for-external-ffmpeg.patch | 53 | ||||
-rw-r--r-- | multimedia/xbmc/patches/0002-Revert-linux-link-ffmpeg-statically.patch | 293 | ||||
-rw-r--r-- | multimedia/xbmc/patches/0003-makefile-include.patch | 14 | ||||
-rw-r--r-- | multimedia/xbmc/patches/samba-4.0.patch | 24 | ||||
-rw-r--r-- | multimedia/xbmc/patches/xbmc-12.2-ffmpeg-2.0.patch | 2102 | ||||
-rw-r--r-- | multimedia/xbmc/patches/xbmc-Gotham-rtmpdump-build.patch | 13 | ||||
-rw-r--r-- | multimedia/xbmc/patches/xbmc-Gotham-samba-4.0.patch | 24 | ||||
-rw-r--r-- | multimedia/xbmc/patches/xbmc-pvr-addons-ffmpeg-2.0.patch | 14 | ||||
-rw-r--r-- | multimedia/xbmc/patches/xbmc-rtmpdump-build.patch | 13 | ||||
-rw-r--r-- | multimedia/xbmc/xbmc.SlackBuild | 36 | ||||
-rw-r--r-- | multimedia/xbmc/xbmc.info | 12 |
12 files changed, 428 insertions, 2180 deletions
diff --git a/multimedia/xbmc/README b/multimedia/xbmc/README index 123ba2fa88ee6..0f810d3619845 100644 --- a/multimedia/xbmc/README +++ b/multimedia/xbmc/README @@ -5,11 +5,11 @@ viewing and playing a vast library of audio, video and image formats. XBMC has a sophisticated library management system that allows you to organize all your media to give you quick and immediate access. -Optional dependencies are: libcec, pulseaudio, libbluray, libnfs, +Optional dependencies: libcec, pulseaudio, libbluray, libnfs, libva, libdvdcss, lirc, cwiid, pybluez, id3lib, libvdpau, rtmpdump, afpfs-ng, -libmicrohttpd, libva, avahi, lame, ffmpeg, libshairport +libmicrohttpd, avahi, lame, ffmpeg -Optional: libcrystalhd (not available at slackbuilds.org) +Optional: libcrystalhd and libshairport (not available at slackbuilds.org) Below are some paramaters that can be passed to the slackbuild to turn on some optional components. @@ -22,3 +22,7 @@ PULSE=yes|no (Default is no), requires pulseaudio Note: The use of external ffmpeg is discouraged by the XBMC developers. PVR information: http://wiki.xbmc.org/index.php?title=PVR + +NOTE: +Please remove or rename /etc/oss.conf if it exists on your system +prior building this package or it will fail to build. diff --git a/multimedia/xbmc/patches/0001-Revert-drop-support-for-external-ffmpeg.patch b/multimedia/xbmc/patches/0001-Revert-drop-support-for-external-ffmpeg.patch new file mode 100644 index 0000000000000..d0920b3bd6bd2 --- /dev/null +++ b/multimedia/xbmc/patches/0001-Revert-drop-support-for-external-ffmpeg.patch @@ -0,0 +1,53 @@ +From e55766aa8da7265bea129c70cfd445ad66191fd0 Mon Sep 17 00:00:00 2001 +From: Michael Cronenworth <mike@cchtml.com> +Date: Sun, 16 Mar 2014 17:14:03 -0500 +Subject: [PATCH 1/2] Revert "drop support for external ffmpeg" + +This reverts commit e211654714b2266b80ba65361bda8f715d47933a. + +Conflicts: + configure.in +--- + configure.in | 12 +++++++++--- + 1 file changed, 9 insertions(+), 3 deletions(-) + +diff --git a/configure.in b/configure.in +index f9f5693..c389b76 100644 +--- a/configure.in ++++ b/configure.in +@@ -191,6 +191,9 @@ libcec_disabled="== libcec disabled. CEC adapter support will not be available. + # External library message strings + external_libraries_enabled="== Use of all supported external libraries enabled. ==" + external_libraries_disabled="== Use of all supported external libraries disabled. ==" ++external_ffmpeg_enabled="== Use of external ffmpeg enabled. ==" ++external_ffmpeg_disabled="== Use of external ffmpeg disabled. ==" ++ffmpeg_vdpau_not_supported="== External ffmpeg doesn't support VDPAU. VDPAU support disabled. ==" + dashes="------------------------" + final_message="\n XBMC Configuration:" + final_message="\n$dashes$final_message\n$dashes" +@@ -569,6 +572,12 @@ AC_ARG_ENABLE([external-libraries], + [use_external_libraries=$enableval], + [use_external_libraries=no]) + ++AC_ARG_ENABLE([external-ffmpeg], ++ [AS_HELP_STRING([--enable-external-ffmpeg], ++ [enable use of external ffmpeg libraries (default is no) 'Linux only'])], ++ [use_external_ffmpeg=$enableval], ++ [use_external_ffmpeg=$use_external_libraries]) ++ + AC_ARG_ENABLE([libav-compat], + [AS_HELP_STRING([--enable-libav-compat], + [build a wrapper around libav to provide the functions needed by XBMC. This is +@@ -600,9 +609,6 @@ PKG_PROG_PKG_CONFIG + MAKE="${MAKE:-make}" + OBJDUMP="${OBJDUMP:-objdump}" + +-use_external_ffmpeg=no +-use_static_ffmpeg=no +- + # ffmpeg needs the output of uname -s (e.x. linux, darwin) for the target_os + # there is no autoconf variable which will give + # the correct output format when doing cross compilation +-- +1.8.5.3 + diff --git a/multimedia/xbmc/patches/0002-Revert-linux-link-ffmpeg-statically.patch b/multimedia/xbmc/patches/0002-Revert-linux-link-ffmpeg-statically.patch new file mode 100644 index 0000000000000..a610aa9f4c03f --- /dev/null +++ b/multimedia/xbmc/patches/0002-Revert-linux-link-ffmpeg-statically.patch @@ -0,0 +1,293 @@ +From 6df5c168c9de11fa6fdec250ba2b1c732ff3e9a2 Mon Sep 17 00:00:00 2001 +From: Michael Cronenworth <mike@cchtml.com> +Date: Sun, 16 Mar 2014 17:23:51 -0500 +Subject: [PATCH 2/2] Revert "linux: link ffmpeg statically" + +This reverts commit 974a3c0e97b817ca358a959a026db95330673642. + +Conflicts: + Makefile.in + configure.in +--- + Makefile.in | 14 --------------- + configure.in | 13 +------------ + lib/DllAvCodec.h | 4 ++-- + lib/DllAvFilter.h | 2 +- + lib/DllAvFormat.h | 8 ++++---- + lib/DllAvUtil.h | 4 ++-- + lib/DllPostProc.h | 2 +- + lib/DllSwResample.h | 4 ++-- + lib/DllSwScale.h | 4 ++-- + lib/Makefile.in | 14 -------------- + 10 files changed, 15 insertions(+), 54 deletions(-) + +diff --git a/Makefile.in b/Makefile.in +index 6f689cf..bfadbe6 100644 +--- a/Makefile.in ++++ b/Makefile.in +@@ -472,20 +472,6 @@ ifeq ($(findstring freebsd,@ARCH@),freebsd) + DYNOBJSXBMC+= xbmc/freebsd/freebsd.a + endif + +-ifeq (@USE_STATIC_FFMPEG@,1) +-FFMPEGOBJS = lib/ffmpeg/libavcodec/libavcodec.a \ +- lib/ffmpeg/libavfilter/libavfilter.a \ +- lib/ffmpeg/libswresample/libswresample.a \ +- lib/ffmpeg/libavformat/libavformat.a \ +- lib/ffmpeg/libavutil/libavutil.a \ +- lib/ffmpeg/libpostproc/libpostproc.a \ +- lib/ffmpeg/libswscale/libswscale.a +-DYNOBJSXBMC+= $(FFMPEGOBJS) +-LIBS+= @GNUTLS_ALL_LIBS@ @VORBISENC_ALL_LIBS@ +- +-$(FFMPEGOBJS): dvdpcodecs +-endif +- + ifneq (@USE_LIBXBMC@,1) + MAINOBJS+=xbmc/main/main.a + else +diff --git a/configure.in b/configure.in +index c389b76..0c6fc47 100644 +--- a/configure.in ++++ b/configure.in +@@ -874,14 +874,6 @@ elif test "$use_arch" = "arm"; then + fi + fi + fi +-if test "$use_static_ffmpeg" = "yes"; then +- USE_STATIC_FFMPEG=1 +- AC_DEFINE([USE_STATIC_FFMPEG], [1], [link ffmpeg statically]) +- # ffmpeg may depend on gnutls and vorbisenc, we add those libs at the end of linker +- # command in order to resolve any missing symbols +- GNUTLS_ALL_LIBS=`${PKG_CONFIG} --static --libs-only-l --silence-errors gnutls` +- VORBISENC_ALL_LIBS=`${PKG_CONFIG} --static --libs-only-l --silence-errors vorbisenc` +-fi + + # Checks for library functions. + AC_FUNC_ALLOCA +@@ -2619,7 +2618,6 @@ AC_SUBST(DISABLE_FISHBMC) + AC_SUBST(DISABLE_PROJECTM) + AC_SUBST(USE_SKIN_TOUCHED) + AC_SUBST(USE_EXTERNAL_FFMPEG) +-AC_SUBST(USE_STATIC_FFMPEG) + AC_SUBST(USE_LIBAV_HACKS) + AC_SUBST(PYTHON_VERSION) + AC_SUBST(OUTPUT_FILES) +@@ -2666,8 +2663,6 @@ AC_SUBST(USE_ANDROID) + AC_SUBST(GTEST_CONFIGURED) + AC_SUBST(USE_DOXYGEN) + AC_SUBST(USE_PVR_ADDONS) +-AC_SUBST(GNUTLS_ALL_LIBS) +-AC_SUBST(VORBISENC_ALL_LIBS) + + # pushd and popd are not available in other shells besides bash, so implement + # our own pushd/popd functions +@@ -2832,7 +2819,7 @@ XB_CONFIG_MODULE([lib/ffmpeg], [ + --disable-ffserver \ + --disable-ffmpeg \ + --disable-crystalhd \ +- `if test "$use_static_ffmpeg" = "yes"; then echo --enable-static --disable-shared; else echo --disable-static --enable-shared; fi` \ ++ --enable-shared \ + --disable-doc \ + --enable-postproc \ + --enable-gpl \ +diff --git a/lib/DllAvCodec.h b/lib/DllAvCodec.h +index af13a15..5cef736 100644 +--- a/lib/DllAvCodec.h ++++ b/lib/DllAvCodec.h +@@ -94,7 +94,7 @@ public: + virtual AVDictionary* av_frame_get_metadata(const AVFrame* frame)=0; + }; + +-#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) || (defined USE_STATIC_FFMPEG) ++#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) + + // Use direct layer + class DllAvCodec : public DllDynamic, DllAvCodecInterface +@@ -166,7 +166,7 @@ public: + // DLL faking. + virtual bool ResolveExports() { return true; } + virtual bool Load() { +-#if !defined(TARGET_DARWIN) && !defined(USE_STATIC_FFMPEG) ++#if !defined(TARGET_DARWIN) + CLog::Log(LOGDEBUG, "DllAvCodec: Using libavcodec system library"); + #endif + return true; +diff --git a/lib/DllAvFilter.h b/lib/DllAvFilter.h +index 05e5c6f..2200bfa 100644 +--- a/lib/DllAvFilter.h ++++ b/lib/DllAvFilter.h +@@ -104,7 +104,7 @@ public: + #endif + }; + +-#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) || (defined USE_STATIC_FFMPEG) ++#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) + // Use direct mapping + class DllAvFilter : public DllDynamic, DllAvFilterInterface + { +diff --git a/lib/DllAvFormat.h b/lib/DllAvFormat.h +index fc7e166..0016c0b 100644 +--- a/lib/DllAvFormat.h ++++ b/lib/DllAvFormat.h +@@ -41,7 +41,7 @@ extern "C" { + void xbmc_read_frame_flush(AVFormatContext *s); + #else + #include "libavformat/avformat.h" +- #if defined(TARGET_DARWIN) || defined(USE_STATIC_FFMPEG) ++ #if defined(TARGET_DARWIN) + void ff_read_frame_flush(AVFormatContext *s); // internal replacement + #define xbmc_read_frame_flush ff_read_frame_flush + #endif +@@ -73,7 +73,7 @@ public: + virtual int av_read_play(AVFormatContext *s)=0; + virtual int av_read_pause(AVFormatContext *s)=0; + virtual int av_seek_frame(AVFormatContext *s, int stream_index, int64_t timestamp, int flags)=0; +-#if (!defined USE_EXTERNAL_FFMPEG) && (!defined TARGET_DARWIN) && (!defined USE_STATIC_FFMPEG) ++#if (!defined USE_EXTERNAL_FFMPEG) && (!defined TARGET_DARWIN) + virtual int avformat_find_stream_info_dont_call(AVFormatContext *ic, AVDictionary **options)=0; + #endif + virtual int avformat_open_input(AVFormatContext **ps, const char *filename, AVInputFormat *fmt, AVDictionary **options)=0; +@@ -108,7 +108,7 @@ public: + #endif + }; + +-#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) || (defined USE_STATIC_FFMPEG) ++#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) + + // Use direct mapping + class DllAvFormat : public DllDynamic, DllAvFormatInterface +@@ -170,7 +170,7 @@ public: + // DLL faking. + virtual bool ResolveExports() { return true; } + virtual bool Load() { +-#if !defined(TARGET_DARWIN) && !defined(USE_STATIC_FFMPEG) ++#if !defined(TARGET_DARWIN) + CLog::Log(LOGDEBUG, "DllAvFormat: Using libavformat system library"); + #endif + CSingleLock lock(DllAvCodec::m_critSection); +diff --git a/lib/DllAvUtil.h b/lib/DllAvUtil.h +index 0fcdf10..ce5889b 100644 +--- a/lib/DllAvUtil.h ++++ b/lib/DllAvUtil.h +@@ -116,7 +116,7 @@ public: + #endif + }; + +-#if defined (USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) || (defined USE_STATIC_FFMPEG) ++#if defined (USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) + // Use direct layer + class DllAvUtilBase : public DllDynamic, DllAvUtilInterface + { +@@ -174,7 +174,7 @@ public: + // DLL faking. + virtual bool ResolveExports() { return true; } + virtual bool Load() { +-#if !defined(TARGET_DARWIN) && !defined(USE_STATIC_FFMPEG) ++#if !defined(TARGET_DARWIN) + CLog::Log(LOGDEBUG, "DllAvUtilBase: Using libavutil system library"); + #endif + return true; +diff --git a/lib/DllPostProc.h b/lib/DllPostProc.h +index e9542eb..0265651 100644 +--- a/lib/DllPostProc.h ++++ b/lib/DllPostProc.h +@@ -78,7 +78,7 @@ public: + virtual void pp_free_context(pp_context *ppContext)=0; + }; + +-#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) || (defined USE_STATIC_FFMPEG) ++#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) + + // We call directly. + class DllPostProc : public DllDynamic, DllPostProcInterface +diff --git a/lib/DllSwResample.h b/lib/DllSwResample.h +index cd1452b..854d250 100644 +--- a/lib/DllSwResample.h ++++ b/lib/DllSwResample.h +@@ -60,7 +60,7 @@ public: + virtual int swr_set_compensation(struct SwrContext *s, int sample_delta, int compensation_distance) = 0; + }; + +-#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) || (defined USE_STATIC_FFMPEG) ++#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) + + // Use direct mapping + class DllSwResample : public DllDynamic, DllSwResampleInterface +@@ -71,7 +71,7 @@ public: + // DLL faking. + virtual bool ResolveExports() { return true; } + virtual bool Load() { +-#if !defined(TARGET_DARWIN) && !defined(USE_STATIC_FFMPEG) ++#if !defined(TARGET_DARWIN) + CLog::Log(LOGDEBUG, "DllAvFormat: Using libswresample system library"); + #endif + return true; +diff --git a/lib/DllSwScale.h b/lib/DllSwScale.h +index 97e3b40..36bb616 100644 +--- a/lib/DllSwScale.h ++++ b/lib/DllSwScale.h +@@ -87,7 +87,7 @@ public: + virtual void sws_freeContext(struct SwsContext *context)=0; + }; + +-#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) || (defined USE_STATIC_FFMPEG) ++#if (defined USE_EXTERNAL_FFMPEG) || (defined TARGET_DARWIN) + + // We call into this library directly. + class DllSwScale : public DllDynamic, public DllSwScaleInterface +@@ -111,7 +111,7 @@ public: + // DLL faking. + virtual bool ResolveExports() { return true; } + virtual bool Load() { +-#if !defined(TARGET_DARWIN) && !defined(USE_STATIC_FFMPEG) ++#if !defined(TARGET_DARWIN) + CLog::Log(LOGDEBUG, "DllSwScale: Using libswscale system library"); + #endif + return true; +diff --git a/lib/Makefile.in b/lib/Makefile.in +index ca18a4a..906219c 100644 +--- a/lib/Makefile.in ++++ b/lib/Makefile.in +@@ -27,7 +27,6 @@ endif + + LIBS= + ifneq (@USE_EXTERNAL_FFMPEG@,1) +-ifneq (@USE_STATIC_FFMPEG@,1) + LIBS+=$(AVUTIL_SO) \ + $(AVCODEC_SO) \ + $(AVFORMAT_SO) \ +@@ -36,12 +35,10 @@ ifneq (@USE_STATIC_FFMPEG@,1) + $(SWSCALE_SO) \ + $(SWRESAMPLE_SO) + endif +-endif + + .PHONY: $(DIRS) codecs + + ifneq ($(findstring osx,$(ARCH)), osx) +-ifneq (@USE_STATIC_FFMPEG@,1) + + codecs: $(addprefix $(SYSDIR)/, $(LIBS)); + +@@ -74,17 +71,6 @@ ffmpeg/libswscale/libswscale.so : ffmpeg; + ffmpeg/libpostproc/libpostproc.so : ffmpeg; + ffmpeg/libswresample/libswresample.so : ffmpeg; + endif +-endif +- +-ifeq (@USE_STATIC_FFMPEG@,1) +-ffmpeg/libavutil/libavutil.a : ffmpeg; +-ffmpeg/libavcodec/libavcodec.a : ffmpeg; +-ffmpeg/libavformat/libavformat.a : ffmpeg; +-ffmpeg/libavfilter/libavfilter.a : ffmpeg; +-ffmpeg/libswscale/libswscale.a : ffmpeg; +-ffmpeg/libpostproc/libpostproc.a : ffmpeg; +-ffmpeg/libswresample/libswresample.a : ffmpeg; +-endif + + ffmpeg: + $(MAKE) -C $@ +-- +1.8.5.3 + diff --git a/multimedia/xbmc/patches/0003-makefile-include.patch b/multimedia/xbmc/patches/0003-makefile-include.patch new file mode 100644 index 0000000000000..d3687e640aaa8 --- /dev/null +++ b/multimedia/xbmc/patches/0003-makefile-include.patch @@ -0,0 +1,14 @@ +--- a/Makefile.include.in 2014-03-16 15:34:08.479015885 -0500 ++++ b/Makefile.include.in 2014-03-16 18:58:00.770693019 -0500 +@@ -58,6 +58,11 @@ + @SDL_DEFINES@ \ + @DEFS@ \ + ++ifeq (@USE_EXTERNAL_FFMPEG@,1) ++ DEFINES+=-DUSE_EXTERNAL_FFMPEG \ ++ ++endif ++ + ifeq ($(findstring osx,$(ARCH)), osx) + INCLUDES+=-I@abs_top_srcdir@/xbmc/osx + endif diff --git a/multimedia/xbmc/patches/samba-4.0.patch b/multimedia/xbmc/patches/samba-4.0.patch deleted file mode 100644 index ea1dc7010e809..0000000000000 --- a/multimedia/xbmc/patches/samba-4.0.patch +++ /dev/null @@ -1,24 +0,0 @@ -diff -Naur xbmc-12.2.orig/xbmc/filesystem/SMBDirectory.cpp xbmc-12.2/xbmc/filesystem/SMBDirectory.cpp ---- xbmc-12.2.orig/xbmc/filesystem/SMBDirectory.cpp 2013-05-03 05:57:41.000000000 +0000 -+++ xbmc-12.2/xbmc/filesystem/SMBDirectory.cpp 2013-11-12 00:30:28.143499083 +0000 -@@ -44,7 +44,7 @@ - #include "threads/SingleLock.h" - #include "PasswordManager.h" - --#include <libsmbclient.h> -+#include <samba-4.0/libsmbclient.h> - - #if defined(TARGET_DARWIN) - #define XBMC_SMB_MOUNT_PATH "Library/Application Support/XBMC/Mounts/" -diff -Naur xbmc-12.2.orig/xbmc/filesystem/SmbFile.cpp xbmc-12.2/xbmc/filesystem/SmbFile.cpp ---- xbmc-12.2.orig/xbmc/filesystem/SmbFile.cpp 2013-05-03 05:57:41.000000000 +0000 -+++ xbmc-12.2/xbmc/filesystem/SmbFile.cpp 2013-11-12 00:30:59.577499442 +0000 -@@ -27,7 +27,7 @@ - #include "PasswordManager.h" - #include "SMBDirectory.h" - #include "Util.h" --#include <libsmbclient.h> -+#include <samba-4.0/libsmbclient.h> - #include "settings/AdvancedSettings.h" - #include "settings/GUISettings.h" - #include "threads/SingleLock.h" diff --git a/multimedia/xbmc/patches/xbmc-12.2-ffmpeg-2.0.patch b/multimedia/xbmc/patches/xbmc-12.2-ffmpeg-2.0.patch deleted file mode 100644 index d5e70cd446816..0000000000000 --- a/multimedia/xbmc/patches/xbmc-12.2-ffmpeg-2.0.patch +++ /dev/null @@ -1,2102 +0,0 @@ -diff -urN xbmc-12.2-orig/lib/DllAvCodec.h xbmc-12.2-avcodec/lib/DllAvCodec.h ---- xbmc-12.2-orig/lib/DllAvCodec.h 2013-05-03 16:57:40.000000000 +1100 -+++ xbmc-12.2-avcodec/lib/DllAvCodec.h 2013-08-03 15:17:18.828959790 +1100 -@@ -72,8 +72,8 @@ - virtual void avcodec_register_all(void)=0; - virtual void avcodec_flush_buffers(AVCodecContext *avctx)=0; - virtual int avcodec_open2_dont_call(AVCodecContext *avctx, AVCodec *codec, AVDictionary **options)=0; -- virtual AVCodec *avcodec_find_decoder(enum CodecID id)=0; -- virtual AVCodec *avcodec_find_encoder(enum CodecID id)=0; -+ virtual AVCodec *avcodec_find_decoder(enum AVCodecID id)=0; -+ virtual AVCodec *avcodec_find_encoder(enum AVCodecID id)=0; - virtual int avcodec_close_dont_call(AVCodecContext *avctx)=0; - virtual AVFrame *avcodec_alloc_frame(void)=0; - virtual int avpicture_fill(AVPicture *picture, uint8_t *ptr, PixelFormat pix_fmt, int width, int height)=0; -@@ -129,8 +129,8 @@ - } - virtual int avcodec_open2_dont_call(AVCodecContext *avctx, AVCodec *codec, AVDictionary **options) { *(volatile int *)0x0 = 0; return 0; } - virtual int avcodec_close_dont_call(AVCodecContext *avctx) { *(volatile int *)0x0 = 0; return 0; } -- virtual AVCodec *avcodec_find_decoder(enum CodecID id) { return ::avcodec_find_decoder(id); } -- virtual AVCodec *avcodec_find_encoder(enum CodecID id) { return ::avcodec_find_encoder(id); } -+ virtual AVCodec *avcodec_find_decoder(enum AVCodecID id) { return ::avcodec_find_decoder(id); } -+ virtual AVCodec *avcodec_find_encoder(enum AVCodecID id) { return ::avcodec_find_encoder(id); } - virtual int avcodec_close(AVCodecContext *avctx) - { - CSingleLock lock(DllAvCodec::m_critSection); -@@ -203,8 +203,8 @@ - LOAD_SYMBOLS(); - - DEFINE_METHOD0(void, avcodec_register_all_dont_call) -- DEFINE_METHOD1(AVCodec*, avcodec_find_decoder, (enum CodecID p1)) -- DEFINE_METHOD1(AVCodec*, avcodec_find_encoder, (enum CodecID p1)) -+ DEFINE_METHOD1(AVCodec*, avcodec_find_decoder, (enum AVCodecID p1)) -+ DEFINE_METHOD1(AVCodec*, avcodec_find_encoder, (enum AVCodecID p1)) - DEFINE_METHOD1(int, avcodec_close_dont_call, (AVCodecContext *p1)) - DEFINE_METHOD0(AVFrame*, avcodec_alloc_frame) - DEFINE_METHOD5(int, avpicture_fill, (AVPicture *p1, uint8_t *p2, PixelFormat p3, int p4, int p5)) -diff -urN xbmc-12.2-orig/xbmc/cdrip/EncoderFFmpeg.cpp xbmc-12.2-avcodec/xbmc/cdrip/EncoderFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cdrip/EncoderFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cdrip/EncoderFFmpeg.cpp 2013-08-03 15:17:18.828959790 +1100 -@@ -67,7 +67,7 @@ - - AVCodec *codec; - codec = m_dllAvCodec.avcodec_find_encoder( -- strcmp(fmt->name, "ogg") == 0 ? CODEC_ID_VORBIS : fmt->audio_codec -+ strcmp(fmt->name, "ogg") == 0 ? AV_CODEC_ID_VORBIS : fmt->audio_codec - ); - - if (!codec) -diff -urN xbmc-12.2-orig/xbmc/cores/amlplayer/AMLPlayer.cpp xbmc-12.2-avcodec/xbmc/cores/amlplayer/AMLPlayer.cpp ---- xbmc-12.2-orig/xbmc/cores/amlplayer/AMLPlayer.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/amlplayer/AMLPlayer.cpp 2013-08-03 15:17:18.830959823 +1100 -@@ -387,16 +387,16 @@ - - /* TODO: handle other subtitle codec types - // subtitle codecs -- CODEC_ID_DVD_SUBTITLE= 0x17000, -- CODEC_ID_DVB_SUBTITLE, -- CODEC_ID_TEXT, ///< raw UTF-8 text -- CODEC_ID_XSUB, -- CODEC_ID_SSA, -- CODEC_ID_MOV_TEXT, -- CODEC_ID_HDMV_PGS_SUBTITLE, -- CODEC_ID_DVB_TELETEXT, -- CODEC_ID_SRT, -- CODEC_ID_MICRODVD, -+ AV_CODEC_ID_DVD_SUBTITLE= 0x17000, -+ AV_CODEC_ID_DVB_SUBTITLE, -+ AV_CODEC_ID_TEXT, ///< raw UTF-8 text -+ AV_CODEC_ID_XSUB, -+ AV_CODEC_ID_SSA, -+ AV_CODEC_ID_MOV_TEXT, -+ AV_CODEC_ID_HDMV_PGS_SUBTITLE, -+ AV_CODEC_ID_DVB_TELETEXT, -+ AV_CODEC_ID_SRT, -+ AV_CODEC_ID_MICRODVD, - */ - switch(sub_type) - { -@@ -405,12 +405,12 @@ - "sub_type(0x%x), size(%d), bgntime(%lld), endtime(%lld), string(%s)", - sub_type, sub_size-20, subtitle->bgntime, subtitle->endtime, &sub_buffer[20]); - break; -- case CODEC_ID_TEXT: -+ case AV_CODEC_ID_TEXT: - subtitle->bgntime = sub_pts/ 90; - subtitle->endtime = subtitle->bgntime + 4000; - subtitle->string = &sub_buffer[20]; - break; -- case CODEC_ID_SSA: -+ case AV_CODEC_ID_SSA: - if (strncmp((const char*)&sub_buffer[20], "Dialogue:", 9) == 0) - { - int vars_found, hour1, min1, sec1, hunsec1, hour2, min2, sec2, hunsec2, nothing; -diff -urN xbmc-12.2-orig/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp xbmc-12.2-avcodec/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp 2013-08-03 15:17:18.829959807 +1100 -@@ -109,7 +109,7 @@ - if (dts && (!ac3 || g_advancedSettings.m_audioTranscodeTo.Equals("dts"))) - { - m_CodecName = "DTS"; -- m_CodecID = CODEC_ID_DTS; -+ m_CodecID = AV_CODEC_ID_DTS; - m_PackFunc = &CAEPackIEC61937::PackDTS_1024; - m_BitRate = DTS_ENCODE_BITRATE; - codec = m_dllAvCodec.avcodec_find_encoder(m_CodecID); -@@ -120,7 +120,7 @@ - if (!codec && ac3) - { - m_CodecName = "AC3"; -- m_CodecID = CODEC_ID_AC3; -+ m_CodecID = AV_CODEC_ID_AC3; - m_PackFunc = &CAEPackIEC61937::PackAC3; - m_BitRate = AC3_ENCODE_BITRATE; - codec = m_dllAvCodec.avcodec_find_encoder(m_CodecID); -@@ -226,7 +226,7 @@ - return m_BitRate; - } - --CodecID CAEEncoderFFmpeg::GetCodecID() -+AVCodecID CAEEncoderFFmpeg::GetCodecID() - { - return m_CodecID; - } -diff -urN xbmc-12.2-orig/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h xbmc-12.2-avcodec/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h ---- xbmc-12.2-orig/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h 2013-08-03 15:17:18.829959807 +1100 -@@ -39,7 +39,7 @@ - virtual void Reset(); - - virtual unsigned int GetBitRate (); -- virtual CodecID GetCodecID (); -+ virtual AVCodecID GetCodecID (); - virtual unsigned int GetFrames (); - - virtual int Encode (float *data, unsigned int frames); -@@ -51,7 +51,7 @@ - DllAvUtil m_dllAvUtil; - - std::string m_CodecName; -- CodecID m_CodecID; -+ AVCodecID m_CodecID; - unsigned int m_BitRate; - CAEPackIEC61937::PackFunc m_PackFunc; - -diff -urN xbmc-12.2-orig/xbmc/cores/AudioEngine/Interfaces/AEEncoder.h xbmc-12.2-avcodec/xbmc/cores/AudioEngine/Interfaces/AEEncoder.h ---- xbmc-12.2-orig/xbmc/cores/AudioEngine/Interfaces/AEEncoder.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/AudioEngine/Interfaces/AEEncoder.h 2013-08-03 15:17:18.829959807 +1100 -@@ -64,10 +64,10 @@ - virtual unsigned int GetBitRate() = 0; - - /** -- * Returns the CodecID of the encoder -+ * Returns the AVCodecID of the encoder - * @return the ffmpeg codec id - */ -- virtual CodecID GetCodecID() = 0; -+ virtual AVCodecID GetCodecID() = 0; - - /** - * Return the number of frames needed to encode -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDAudio.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDAudio.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDAudio.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDAudio.cpp 2013-08-03 15:17:18.830959823 +1100 -@@ -116,7 +116,7 @@ - free(m_pBuffer); - } - --bool CDVDAudio::Create(const DVDAudioFrame &audioframe, CodecID codec, bool needresampler) -+bool CDVDAudio::Create(const DVDAudioFrame &audioframe, AVCodecID codec, bool needresampler) - { - CLog::Log(LOGNOTICE, - "Creating audio stream (codec id: %i, channels: %i, sample rate: %i, %s)", -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDAudio.h xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDAudio.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDAudio.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDAudio.h 2013-08-03 15:17:18.830959823 +1100 -@@ -80,7 +80,7 @@ - float GetCurrentAttenuation(); - void Pause(); - void Resume(); -- bool Create(const DVDAudioFrame &audioframe, CodecID codec, bool needresampler); -+ bool Create(const DVDAudioFrame &audioframe, AVCodecID codec, bool needresampler); - bool IsValidFormat(const DVDAudioFrame &audioframe); - void Destroy(); - DWORD AddPackets(const DVDAudioFrame &audioframe); -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.cpp 2013-08-03 15:17:18.831959839 +1100 -@@ -23,7 +23,7 @@ - - CDVDAudioCodecLPcm::CDVDAudioCodecLPcm() : CDVDAudioCodecPcm() - { -- m_codecID = CODEC_ID_NONE; -+ m_codecID = AV_CODEC_ID_NONE; - m_bufferSize = LPCM_BUFFER_SIZE; - memset(m_buffer, 0, sizeof(m_buffer)); - } -@@ -33,11 +33,11 @@ - m_codecID = hints.codec; - - CDVDStreamInfo hints2(hints, true); -- hints2.codec = CODEC_ID_NONE; -+ hints2.codec = AV_CODEC_ID_NONE; - #if 0 -- if (hints.codecID = CODEC_ID_LPCM_S24BE) hints2.codec = CODEC_ID_PCM_S24BE; -+ if (hints.codecID = AV_CODEC_ID_LPCM_S24BE) hints2.codec = AV_CODEC_ID_PCM_S24BE; - #endif -- if (hints2.codec != CODEC_ID_NONE) -+ if (hints2.codec != AV_CODEC_ID_NONE) - return CDVDAudioCodecPcm::Open(hints2, options); - - return false; -@@ -54,7 +54,7 @@ - if (iSize >= 12) - { - #if 0 -- if (m_codecID == CODEC_ID_LPCM_S24BE) -+ if (m_codecID == AV_CODEC_ID_LPCM_S24BE) - #endif - { - for (iDecoded = 0; iDecoded <= (iSize - 12); iDecoded += 12) -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.h xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.h 2013-08-03 15:17:18.831959839 +1100 -@@ -40,5 +40,5 @@ - int m_bufferSize; - BYTE m_buffer[LPCM_BUFFER_SIZE]; - -- CodecID m_codecID; -+ AVCodecID m_codecID; - }; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthrough.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthrough.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthrough.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthrough.cpp 2013-08-03 15:17:18.831959839 +1100 -@@ -67,12 +67,12 @@ - m_bufferSize = 0; - - if ( -- (hints.codec == CODEC_ID_AC3 && bSupportsAC3Out) || -- (hints.codec == CODEC_ID_DTS && bSupportsDTSOut) || -+ (hints.codec == AV_CODEC_ID_AC3 && bSupportsAC3Out) || -+ (hints.codec == AV_CODEC_ID_DTS && bSupportsDTSOut) || - (audioMode == AUDIO_HDMI && - ( -- (hints.codec == CODEC_ID_EAC3 && bSupportsAC3Out ) || -- (hints.codec == CODEC_ID_TRUEHD && bSupportsTrueHDOut) -+ (hints.codec == AV_CODEC_ID_EAC3 && bSupportsAC3Out ) || -+ (hints.codec == AV_CODEC_ID_TRUEHD && bSupportsTrueHDOut) - ) - ) - ) -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.cpp 2013-08-03 15:17:18.832959856 +1100 -@@ -139,7 +139,7 @@ - - /* set the stream's parameters */ - m_SampleRate = hints.samplerate; -- if(!m_SampleRate && hints.codec == CODEC_ID_AC3) -+ if(!m_SampleRate && hints.codec == AV_CODEC_ID_AC3) - m_SampleRate = 48000; - - AVCodecContext *codec = muxer.m_pStream->codec; -@@ -277,9 +277,9 @@ - { - m_pSyncFrame = NULL; - -- if (m_bSupportsAC3Out && hints.codec == CODEC_ID_AC3) m_pSyncFrame = &CDVDAudioCodecPassthroughFFmpeg::SyncAC3; -- else if (m_bSupportsDTSOut && hints.codec == CODEC_ID_DTS) m_pSyncFrame = &CDVDAudioCodecPassthroughFFmpeg::SyncDTS; -- else if (m_bSupportsAACOut && hints.codec == CODEC_ID_AAC) m_pSyncFrame = &CDVDAudioCodecPassthroughFFmpeg::SyncAAC; -+ if (m_bSupportsAC3Out && hints.codec == AV_CODEC_ID_AC3) m_pSyncFrame = &CDVDAudioCodecPassthroughFFmpeg::SyncAC3; -+ else if (m_bSupportsDTSOut && hints.codec == AV_CODEC_ID_DTS) m_pSyncFrame = &CDVDAudioCodecPassthroughFFmpeg::SyncDTS; -+ else if (m_bSupportsAACOut && hints.codec == AV_CODEC_ID_AAC) m_pSyncFrame = &CDVDAudioCodecPassthroughFFmpeg::SyncAAC; - else return false; - - return true; -@@ -328,7 +328,7 @@ - else - { - /* aac needs to be wrapped into ADTS frames */ -- if (hints.codec == CODEC_ID_AAC) -+ if (hints.codec == AV_CODEC_ID_AAC) - if (!SetupMuxer(hints, "adts", m_ADTS)) - { - CLog::Log(LOGERROR, "CDVDAudioCodecPassthroughFFmpeg::Open - Unable to setup ADTS muxer"); -@@ -481,8 +481,8 @@ - { - switch(m_codec) - { -- case CODEC_ID_AC3: return AE_FMT_AC3; -- case CODEC_ID_DTS: return AE_FMT_DTS; -+ case AV_CODEC_ID_AC3: return AE_FMT_AC3; -+ case AV_CODEC_ID_DTS: return AE_FMT_DTS; - default: - return AE_FMT_INVALID; //Unknown stream type - } -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.h xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.h 2013-08-03 15:17:18.832959856 +1100 -@@ -94,7 +94,7 @@ - unsigned int m_Needed; - bool m_LostSync; - int m_SampleRate; -- CodecID m_codec; -+ AVCodecID m_codec; - - unsigned int (CDVDAudioCodecPassthroughFFmpeg::*m_pSyncFrame)(BYTE* pData, unsigned int iSize, unsigned int *fSize); - unsigned int SyncAC3(BYTE* pData, unsigned int iSize, unsigned int *fSize); -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.cpp 2013-08-03 15:17:18.832959856 +1100 -@@ -113,7 +113,7 @@ - m_iSourceSampleRate = 0; - m_iSourceBitrate = 0; - m_decodedDataSize = 0; -- m_codecID = CODEC_ID_NONE; -+ m_codecID = AV_CODEC_ID_NONE; - m_iOutputChannels = 0; - - memset(m_decodedData, 0, sizeof(m_decodedData)); -@@ -136,12 +136,12 @@ - - switch (m_codecID) - { -- case CODEC_ID_PCM_ALAW: -+ case AV_CODEC_ID_PCM_ALAW: - { - for (int i = 0; i < 256; i++) table[i] = alaw2linear(i); - break; - } -- case CODEC_ID_PCM_MULAW: -+ case AV_CODEC_ID_PCM_MULAW: - { - for (int i = 0; i < 256; i++) table[i] = ulaw2linear(i); - break; -@@ -177,31 +177,31 @@ - - switch (m_codecID) - { -- case CODEC_ID_PCM_S32LE: -+ case AV_CODEC_ID_PCM_S32LE: - decode_to16(4, 1, 0, &src, &samples, buf_size); - break; -- case CODEC_ID_PCM_S32BE: -+ case AV_CODEC_ID_PCM_S32BE: - decode_to16(4, 0, 0, &src, &samples, buf_size); - break; -- case CODEC_ID_PCM_U32LE: -+ case AV_CODEC_ID_PCM_U32LE: - decode_to16(4, 1, 1, &src, &samples, buf_size); - break; -- case CODEC_ID_PCM_U32BE: -+ case AV_CODEC_ID_PCM_U32BE: - decode_to16(4, 0, 1, &src, &samples, buf_size); - break; -- case CODEC_ID_PCM_S24LE: -+ case AV_CODEC_ID_PCM_S24LE: - decode_to16(3, 1, 0, &src, &samples, buf_size); - break; -- case CODEC_ID_PCM_S24BE: -+ case AV_CODEC_ID_PCM_S24BE: - decode_to16(3, 0, 0, &src, &samples, buf_size); - break; -- case CODEC_ID_PCM_U24LE: -+ case AV_CODEC_ID_PCM_U24LE: - decode_to16(3, 1, 1, &src, &samples, buf_size); - break; -- case CODEC_ID_PCM_U24BE: -+ case AV_CODEC_ID_PCM_U24BE: - decode_to16(3, 0, 1, &src, &samples, buf_size); - break; -- case CODEC_ID_PCM_S24DAUD: -+ case AV_CODEC_ID_PCM_S24DAUD: - n = buf_size / 3; - for(;n>0;n--) { - uint32_t v = src[0] << 16 | src[1] << 8 | src[2]; -@@ -211,50 +211,50 @@ - src += 3; - } - break; -- case CODEC_ID_PCM_S16LE: -+ case AV_CODEC_ID_PCM_S16LE: - n = buf_size >> 1; - for(;n>0;n--) { - *samples++ = src[0] | (src[1] << 8); - src += 2; - } - break; -- case CODEC_ID_PCM_S16BE: -+ case AV_CODEC_ID_PCM_S16BE: - n = buf_size >> 1; - for(;n>0;n--) { - *samples++ = (src[0] << 8) | src[1]; - src += 2; - } - break; -- case CODEC_ID_PCM_U16LE: -+ case AV_CODEC_ID_PCM_U16LE: - n = buf_size >> 1; - for(;n>0;n--) { - *samples++ = (src[0] | (src[1] << 8)) - 0x8000; - src += 2; - } - break; -- case CODEC_ID_PCM_U16BE: -+ case AV_CODEC_ID_PCM_U16BE: - n = buf_size >> 1; - for(;n>0;n--) { - *samples++ = ((src[0] << 8) | src[1]) - 0x8000; - src += 2; - } - break; -- case CODEC_ID_PCM_S8: -+ case AV_CODEC_ID_PCM_S8: - n = buf_size; - for(;n>0;n--) { - *samples++ = src[0] << 8; - src++; - } - break; -- case CODEC_ID_PCM_U8: -+ case AV_CODEC_ID_PCM_U8: - n = buf_size; - for(;n>0;n--) { - *samples++ = ((int)src[0] - 128) << 8; - src++; - } - break; -- case CODEC_ID_PCM_ALAW: -- case CODEC_ID_PCM_MULAW: -+ case AV_CODEC_ID_PCM_ALAW: -+ case AV_CODEC_ID_PCM_MULAW: - n = buf_size; - for(;n>0;n--) { - *samples++ = table[src[0]]; -@@ -281,7 +281,7 @@ - m_iSourceSampleRate = 0; - m_iSourceBitrate = 0; - m_decodedDataSize = 0; -- m_codecID = CODEC_ID_NONE; -+ m_codecID = AV_CODEC_ID_NONE; - } - - void CDVDAudioCodecPcm::Reset() -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.h xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.h 2013-08-03 15:17:18.832959856 +1100 -@@ -44,7 +44,7 @@ - short m_decodedData[131072]; // could be a bit to big - int m_decodedDataSize; - -- CodecID m_codecID; -+ AVCodecID m_codecID; - int m_iSourceSampleRate; - int m_iSourceChannels; - int m_iSourceBitrate; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/DVDFactoryCodec.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/DVDFactoryCodec.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/DVDFactoryCodec.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/DVDFactoryCodec.cpp 2013-08-03 15:21:00.992633897 +1100 -@@ -173,7 +173,7 @@ - CLog::Log(LOGDEBUG, "CDVDFactoryCodec: compiled in hardware support: %s", hwSupport.c_str()); - - // dvd's have weird still-frames in it, which is not fully supported in ffmpeg -- if(hint.stills && (hint.codec == CODEC_ID_MPEG2VIDEO || hint.codec == CODEC_ID_MPEG1VIDEO)) -+ if(hint.stills && (hint.codec == AV_CODEC_ID_MPEG2VIDEO || hint.codec == AV_CODEC_ID_MPEG1VIDEO)) - { - if( (pCodec = OpenCodec(new CDVDVideoCodecLibMpeg2(), hint, options)) ) return pCodec; - } -@@ -182,7 +182,7 @@ - { - if (g_sysinfo.HasVDADecoder()) - { -- if (hint.codec == CODEC_ID_H264 && !hint.ptsinvalid) -+ if (hint.codec == AV_CODEC_ID_H264 && !hint.ptsinvalid) - { - if ( (pCodec = OpenCodec(new CDVDVideoCodecVDA(), hint, options)) ) return pCodec; - } -@@ -197,8 +197,8 @@ - { - switch(hint.codec) - { -- case CODEC_ID_H264: -- if (hint.codec == CODEC_ID_H264 && hint.ptsinvalid) -+ case AV_CODEC_ID_H264: -+ if (hint.codec == AV_CODEC_ID_H264 && hint.ptsinvalid) - break; - if ( (pCodec = OpenCodec(new CDVDVideoCodecVideoToolBox(), hint, options)) ) return pCodec; - break; -@@ -216,13 +216,13 @@ - { - switch(hint.codec) - { -- case CODEC_ID_VC1: -- case CODEC_ID_WMV3: -- case CODEC_ID_H264: -- case CODEC_ID_MPEG2VIDEO: -- if (hint.codec == CODEC_ID_H264 && hint.ptsinvalid) -+ case AV_CODEC_ID_VC1: -+ case AV_CODEC_ID_WMV3: -+ case AV_CODEC_ID_H264: -+ case AV_CODEC_ID_MPEG2VIDEO: -+ if (hint.codec == AV_CODEC_ID_H264 && hint.ptsinvalid) - break; -- if (hint.codec == CODEC_ID_MPEG2VIDEO && hint.width <= 720) -+ if (hint.codec == AV_CODEC_ID_MPEG2VIDEO && hint.width <= 720) - break; - if ( (pCodec = OpenCodec(new CDVDVideoCodecCrystalHD(), hint, options)) ) return pCodec; - break; -@@ -236,7 +236,7 @@ - #if defined(HAVE_LIBOPENMAX) - if (g_guiSettings.GetBool("videoplayer.useomx") && !hint.software ) - { -- if (hint.codec == CODEC_ID_H264 || hint.codec == CODEC_ID_MPEG2VIDEO || hint.codec == CODEC_ID_VC1) -+ if (hint.codec == AV_CODEC_ID_H264 || hint.codec == AV_CODEC_ID_MPEG2VIDEO || hint.codec == AV_CODEC_ID_VC1) - { - if ( (pCodec = OpenCodec(new CDVDVideoCodecOpenMax(), hint, options)) ) return pCodec; - } -@@ -271,8 +271,8 @@ - #if defined(TARGET_DARWIN_OSX) || defined(TARGET_DARWIN_IOS) - switch(hint.codec) - { -- case CODEC_ID_AC3: -- case CODEC_ID_DTS: -+ case AV_CODEC_ID_AC3: -+ case AV_CODEC_ID_DTS: - pCodec = OpenCodec( new CDVDAudioCodecPassthroughFFmpeg(), hint, options ); - if( pCodec ) return pCodec; - break; -@@ -286,39 +286,39 @@ - - switch (hint.codec) - { -- case CODEC_ID_MP2: -- case CODEC_ID_MP3: -+ case AV_CODEC_ID_MP2: -+ case AV_CODEC_ID_MP3: - { - pCodec = OpenCodec( new CDVDAudioCodecLibMad(), hint, options ); - if( pCodec ) return pCodec; - break; - } -- case CODEC_ID_PCM_S32LE: -- case CODEC_ID_PCM_S32BE: -- case CODEC_ID_PCM_U32LE: -- case CODEC_ID_PCM_U32BE: -- case CODEC_ID_PCM_S24LE: -- case CODEC_ID_PCM_S24BE: -- case CODEC_ID_PCM_U24LE: -- case CODEC_ID_PCM_U24BE: -- case CODEC_ID_PCM_S24DAUD: -- case CODEC_ID_PCM_S16LE: -- case CODEC_ID_PCM_S16BE: -- case CODEC_ID_PCM_U16LE: -- case CODEC_ID_PCM_U16BE: -- case CODEC_ID_PCM_S8: -- case CODEC_ID_PCM_U8: -- case CODEC_ID_PCM_ALAW: -- case CODEC_ID_PCM_MULAW: -+ case AV_CODEC_ID_PCM_S32LE: -+ case AV_CODEC_ID_PCM_S32BE: -+ case AV_CODEC_ID_PCM_U32LE: -+ case AV_CODEC_ID_PCM_U32BE: -+ case AV_CODEC_ID_PCM_S24LE: -+ case AV_CODEC_ID_PCM_S24BE: -+ case AV_CODEC_ID_PCM_U24LE: -+ case AV_CODEC_ID_PCM_U24BE: -+ case AV_CODEC_ID_PCM_S24DAUD: -+ case AV_CODEC_ID_PCM_S16LE: -+ case AV_CODEC_ID_PCM_S16BE: -+ case AV_CODEC_ID_PCM_U16LE: -+ case AV_CODEC_ID_PCM_U16BE: -+ case AV_CODEC_ID_PCM_S8: -+ case AV_CODEC_ID_PCM_U8: -+ case AV_CODEC_ID_PCM_ALAW: -+ case AV_CODEC_ID_PCM_MULAW: - { - pCodec = OpenCodec( new CDVDAudioCodecPcm(), hint, options ); - if( pCodec ) return pCodec; - break; - } - #if 0 -- //case CODEC_ID_LPCM_S16BE: -- //case CODEC_ID_LPCM_S20BE: -- case CODEC_ID_LPCM_S24BE: -+ //case AV_CODEC_ID_LPCM_S16BE: -+ //case AV_CODEC_ID_LPCM_S20BE: -+ case AV_CODEC_ID_LPCM_S24BE: - { - pCodec = OpenCodec( new CDVDAudioCodecLPcm(), hint, options ); - if( pCodec ) return pCodec; -@@ -345,12 +345,12 @@ - - switch (hint.codec) - { -- case CODEC_ID_TEXT: -+ case AV_CODEC_ID_TEXT: - pCodec = OpenCodec(new CDVDOverlayCodecText(), hint, options); - if( pCodec ) return pCodec; - break; - -- case CODEC_ID_SSA: -+ case AV_CODEC_ID_SSA: - pCodec = OpenCodec(new CDVDOverlayCodecSSA(), hint, options); - if( pCodec ) return pCodec; - -@@ -358,7 +358,7 @@ - if( pCodec ) return pCodec; - break; - -- case CODEC_ID_MOV_TEXT: -+ case AV_CODEC_ID_MOV_TEXT: - pCodec = OpenCodec(new CDVDOverlayCodecTX3G(), hint, options); - if( pCodec ) return pCodec; - break; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecFFmpeg.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecFFmpeg.cpp 2013-08-03 15:17:18.833959872 +1100 -@@ -182,7 +182,7 @@ - - double pts_offset = 0.0; - -- if (m_pCodecContext->codec_id == CODEC_ID_HDMV_PGS_SUBTITLE && m_Subtitle.format == 0) -+ if (m_pCodecContext->codec_id == AV_CODEC_ID_HDMV_PGS_SUBTITLE && m_Subtitle.format == 0) - { - // for pgs subtitles the packet pts of the end_segments are wrong - // instead use the subtitle pts to calc the offset here -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecSSA.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecSSA.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecSSA.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecSSA.cpp 2013-08-03 15:17:18.834959888 +1100 -@@ -44,7 +44,7 @@ - - bool CDVDOverlayCodecSSA::Open(CDVDStreamInfo &hints, CDVDCodecOptions &options) - { -- if(hints.codec != CODEC_ID_SSA) -+ if(hints.codec != AV_CODEC_ID_SSA) - return false; - - Dispose(); -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecText.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecText.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecText.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecText.cpp 2013-08-03 15:17:18.834959888 +1100 -@@ -41,8 +41,8 @@ - - bool CDVDOverlayCodecText::Open(CDVDStreamInfo &hints, CDVDCodecOptions &options) - { -- m_bIsSSA = (hints.codec == CODEC_ID_SSA); -- if(hints.codec == CODEC_ID_TEXT || hints.codec == CODEC_ID_SSA) -+ m_bIsSSA = (hints.codec == AV_CODEC_ID_SSA); -+ if(hints.codec == AV_CODEC_ID_TEXT || hints.codec == AV_CODEC_ID_SSA) - return true; - return false; - } -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecTX3G.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecTX3G.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecTX3G.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecTX3G.cpp 2013-08-03 15:17:18.834959888 +1100 -@@ -75,7 +75,7 @@ - - bool CDVDOverlayCodecTX3G::Open(CDVDStreamInfo &hints, CDVDCodecOptions &options) - { -- if (hints.codec == CODEC_ID_MOV_TEXT) -+ if (hints.codec == AV_CODEC_ID_MOV_TEXT) - return true; - return false; - } -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecCrystalHD.cpp 2013-08-03 15:17:37.594265411 +1100 -@@ -55,11 +55,11 @@ - { - switch (hints.codec) - { -- case CODEC_ID_MPEG2VIDEO: -+ case AV_CODEC_ID_MPEG2VIDEO: - m_CodecType = CRYSTALHD_CODEC_ID_MPEG2; - m_pFormatName = "chd-mpeg2"; - break; -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - switch(hints.profile) - { - case FF_PROFILE_H264_HIGH_10: -@@ -86,11 +86,11 @@ - - m_pFormatName = "chd-h264"; - break; -- case CODEC_ID_VC1: -+ case AV_CODEC_ID_VC1: - m_CodecType = CRYSTALHD_CODEC_ID_VC1; - m_pFormatName = "chd-vc1"; - break; -- case CODEC_ID_WMV3: -+ case AV_CODEC_ID_WMV3: - m_CodecType = CRYSTALHD_CODEC_ID_WMV3; - m_pFormatName = "chd-wmv3"; - break; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp 2013-08-03 15:24:40.439297445 +1100 -@@ -103,7 +103,7 @@ - #ifdef HAVE_LIBVA - // mpeg4 vaapi decoding is disabled - if(*cur == PIX_FMT_VAAPI_VLD && g_guiSettings.GetBool("videoplayer.usevaapi") -- && (avctx->codec_id != CODEC_ID_MPEG4 || g_advancedSettings.m_videoAllowMpeg4VAAPI)) -+ && (avctx->codec_id != AV_CODEC_ID_MPEG4 || g_advancedSettings.m_videoAllowMpeg4VAAPI)) - { - VAAPI::CDecoder* dec = new VAAPI::CDecoder(); - if(dec->Open(avctx, *cur)) -@@ -176,7 +176,7 @@ - pCodec = NULL; - m_pCodecContext = NULL; - -- if (hints.codec == CODEC_ID_H264) -+ if (hints.codec == AV_CODEC_ID_H264) - { - switch(hints.profile) - { -@@ -200,7 +200,7 @@ - if(pCodec->id == hints.codec - && pCodec->capabilities & CODEC_CAP_HWACCEL_VDPAU) - { -- if ((pCodec->id == CODEC_ID_MPEG4) && !g_advancedSettings.m_videoAllowMpeg4VDPAU) -+ if ((pCodec->id == AV_CODEC_ID_MPEG4) && !g_advancedSettings.m_videoAllowMpeg4VDPAU) - continue; - - CLog::Log(LOGNOTICE,"CDVDVideoCodecFFmpeg::Open() Creating VDPAU(%ix%i, %d)",hints.width, hints.height, hints.codec); -@@ -214,7 +214,7 @@ - if(vdp->Open(m_pCodecContext, pCodec->pix_fmts ? pCodec->pix_fmts[0] : PIX_FMT_NONE)) - { - m_pHardware = vdp; -- m_pCodecContext->codec_id = CODEC_ID_NONE; // ffmpeg will complain if this has been set -+ m_pCodecContext->codec_id = AV_CODEC_ID_NONE; // ffmpeg will complain if this has been set - break; - } - m_dllAvUtil.av_freep(&m_pCodecContext); -@@ -254,8 +254,8 @@ - // ffmpeg with enabled neon will crash and burn if this is enabled - m_pCodecContext->flags &= CODEC_FLAG_EMU_EDGE; - #else -- if (pCodec->id != CODEC_ID_H264 && pCodec->capabilities & CODEC_CAP_DR1 -- && pCodec->id != CODEC_ID_VP8 -+ if (pCodec->id != AV_CODEC_ID_H264 && pCodec->capabilities & CODEC_CAP_DR1 -+ && pCodec->id != AV_CODEC_ID_VP8 - ) - m_pCodecContext->flags |= CODEC_FLAG_EMU_EDGE; - #endif -@@ -293,8 +293,8 @@ - - int num_threads = std::min(8 /*MAX_THREADS*/, g_cpuInfo.getCPUCount()); - if( num_threads > 1 && !hints.software && m_pHardware == NULL // thumbnail extraction fails when run threaded -- && ( pCodec->id == CODEC_ID_H264 -- || pCodec->id == CODEC_ID_MPEG4 )) -+ && ( pCodec->id == AV_CODEC_ID_H264 -+ || pCodec->id == AV_CODEC_ID_MPEG4 )) - m_pCodecContext->thread_count = num_threads; - - if (m_dllAvCodec.avcodec_open2(m_pCodecContext, pCodec, NULL) < 0) -@@ -492,8 +492,8 @@ - m_iLastKeyframe = 300; - - /* h264 doesn't always have keyframes + won't output before first keyframe anyway */ -- if(m_pCodecContext->codec_id == CODEC_ID_H264 -- || m_pCodecContext->codec_id == CODEC_ID_SVQ3) -+ if(m_pCodecContext->codec_id == AV_CODEC_ID_H264 -+ || m_pCodecContext->codec_id == AV_CODEC_ID_SVQ3) - m_started = true; - - if(m_pHardware == NULL) -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecOpenMax.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecOpenMax.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecOpenMax.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecOpenMax.cpp 2013-08-03 15:17:37.595265431 +1100 -@@ -58,7 +58,7 @@ - - switch (hints.codec) - { -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - { - m_pFormatName = "omx-h264"; - if (hints.extrasize < 7 || hints.extradata == NULL) -@@ -72,13 +72,13 @@ - m_convert_bitstream = bitstream_convert_init(hints.extradata, hints.extrasize); - } - break; -- case CODEC_ID_MPEG4: -+ case AV_CODEC_ID_MPEG4: - m_pFormatName = "omx-mpeg4"; - break; -- case CODEC_ID_MPEG2VIDEO: -+ case AV_CODEC_ID_MPEG2VIDEO: - m_pFormatName = "omx-mpeg2"; - break; -- case CODEC_ID_VC1: -+ case AV_CODEC_ID_VC1: - m_pFormatName = "omx-vc1"; - break; - default: -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecVDA.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecVDA.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecVDA.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecVDA.cpp 2013-08-03 15:24:54.727535919 +1100 -@@ -697,7 +697,7 @@ - - switch (hints.codec) - { -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - // source must be H.264 with valid avcC atom data in extradata - if (extrasize < 7 || extradata == NULL) - { -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecVideoToolBox.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecVideoToolBox.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecVideoToolBox.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecVideoToolBox.cpp 2013-08-03 15:17:37.597265487 +1100 -@@ -538,7 +538,7 @@ - esds->esid = 0; - esds->stream_priority = 0; // 16 ? 0x1f - -- esds->objectTypeId = 32; // 32 = CODEC_ID_MPEG4, 33 = CODEC_ID_H264 -+ esds->objectTypeId = 32; // 32 = AV_CODEC_ID_MPEG4, 33 = AV_CODEC_ID_H264 - // the following fields is made of 6 bits to identify the streamtype (4 for video, 5 for audio) - // plus 1 bit to indicate upstream and 1 bit set to 1 (reserved) - esds->streamType = 0x11; -@@ -1095,7 +1095,7 @@ - - switch (hints.codec) - { -- case CODEC_ID_MPEG4: -+ case AV_CODEC_ID_MPEG4: - if (extrasize) - { - AVIOContext *pb; -@@ -1127,12 +1127,12 @@ - m_pFormatName = "vtb-mpeg4"; - break; - -- case CODEC_ID_MPEG2VIDEO: -+ case AV_CODEC_ID_MPEG2VIDEO: - m_fmt_desc = CreateFormatDescription(kVTFormatMPEG2Video, width, height); - m_pFormatName = "vtb-mpeg2"; - break; - -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - if (extrasize < 7 || extradata == NULL) - { - //m_fmt_desc = CreateFormatDescription(kVTFormatH264, width, height); -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DXVA.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DXVA.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DXVA.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/DXVA.cpp 2013-08-03 15:17:37.597265487 +1100 -@@ -95,19 +95,19 @@ - - /* XXX Prefered modes must come first */ - static const dxva2_mode_t dxva2_modes[] = { -- { "MPEG2 VLD", &DXVA2_ModeMPEG2_VLD, CODEC_ID_MPEG2VIDEO }, -- { "MPEG1/2 VLD", &DXVA_ModeMPEG2and1_VLD, CODEC_ID_MPEG2VIDEO }, -+ { "MPEG2 VLD", &DXVA2_ModeMPEG2_VLD, AV_CODEC_ID_MPEG2VIDEO }, -+ { "MPEG1/2 VLD", &DXVA_ModeMPEG2and1_VLD, AV_CODEC_ID_MPEG2VIDEO }, - { "MPEG2 MoComp", &DXVA2_ModeMPEG2_MoComp, 0 }, - { "MPEG2 IDCT", &DXVA2_ModeMPEG2_IDCT, 0 }, - - // Intel drivers return standard modes in addition to the Intel specific ones. Try the Intel specific first, they work better for Sandy Bridges. -- { "Intel H.264 VLD, no FGT", &DXVADDI_Intel_ModeH264_E, CODEC_ID_H264 }, -+ { "Intel H.264 VLD, no FGT", &DXVADDI_Intel_ModeH264_E, AV_CODEC_ID_H264 }, - { "Intel H.264 inverse discrete cosine transform (IDCT), no FGT", &DXVADDI_Intel_ModeH264_C, 0 }, - { "Intel H.264 motion compensation (MoComp), no FGT", &DXVADDI_Intel_ModeH264_A, 0 }, - { "Intel VC-1 VLD", &DXVADDI_Intel_ModeVC1_E, 0 }, - -- { "H.264 variable-length decoder (VLD), FGT", &DXVA2_ModeH264_F, CODEC_ID_H264 }, -- { "H.264 VLD, no FGT", &DXVA2_ModeH264_E, CODEC_ID_H264 }, -+ { "H.264 variable-length decoder (VLD), FGT", &DXVA2_ModeH264_F, AV_CODEC_ID_H264 }, -+ { "H.264 VLD, no FGT", &DXVA2_ModeH264_E, AV_CODEC_ID_H264 }, - { "H.264 IDCT, FGT", &DXVA2_ModeH264_D, 0, }, - { "H.264 inverse discrete cosine transform (IDCT), no FGT", &DXVA2_ModeH264_C, 0, }, - { "H.264 MoComp, FGT", &DXVA2_ModeH264_B, 0, }, -@@ -120,10 +120,10 @@ - { "Windows Media Video 9 MoComp", &DXVA2_ModeWMV9_B, 0 }, - { "Windows Media Video 9 post processing", &DXVA2_ModeWMV9_A, 0 }, - -- { "VC-1 VLD", &DXVA2_ModeVC1_D, CODEC_ID_VC1 }, -- { "VC-1 VLD", &DXVA2_ModeVC1_D, CODEC_ID_WMV3 }, -- { "VC-1 VLD 2010", &DXVA_ModeVC1_D2010, CODEC_ID_VC1 }, -- { "VC-1 VLD 2010", &DXVA_ModeVC1_D2010, CODEC_ID_WMV3 }, -+ { "VC-1 VLD", &DXVA2_ModeVC1_D, AV_CODEC_ID_VC1 }, -+ { "VC-1 VLD", &DXVA2_ModeVC1_D, AV_CODEC_ID_WMV3 }, -+ { "VC-1 VLD 2010", &DXVA_ModeVC1_D2010, AV_CODEC_ID_VC1 }, -+ { "VC-1 VLD 2010", &DXVA_ModeVC1_D2010, AV_CODEC_ID_WMV3 }, - { "VC-1 IDCT", &DXVA2_ModeVC1_C, 0 }, - { "VC-1 MoComp", &DXVA2_ModeVC1_B, 0 }, - { "VC-1 post processing", &DXVA2_ModeVC1_A, 0 }, -@@ -435,7 +435,7 @@ - static bool CheckCompatibility(AVCodecContext *avctx) - { - // The incompatibilities are all for H264 -- if(avctx->codec_id != CODEC_ID_H264) -+ if(avctx->codec_id != AV_CODEC_ID_H264) - return true; - - // Macroblock width incompatibility -@@ -626,7 +626,7 @@ - - if(m_refs == 0) - { -- if(avctx->codec_id == CODEC_ID_H264) -+ if(avctx->codec_id == AV_CODEC_ID_H264) - m_refs = 16; - else - m_refs = 2; -@@ -771,9 +771,9 @@ - } - - // Status reports are available only for the DXVA2_ModeH264 and DXVA2_ModeVC1 modes -- if(avctx->codec_id != CODEC_ID_H264 -- && avctx->codec_id != CODEC_ID_VC1 -- && avctx->codec_id != CODEC_ID_WMV3) -+ if(avctx->codec_id != AV_CODEC_ID_H264 -+ && avctx->codec_id != AV_CODEC_ID_VC1 -+ && avctx->codec_id != AV_CODEC_ID_WMV3) - return 0; - - DXVA2_DecodeExecuteParams params = {}; -@@ -786,7 +786,7 @@ - params.pExtensionData = &data; - data.Function = DXVA_STATUS_REPORTING_FUNCTION; - data.pPrivateOutputData = &status; -- data.PrivateOutputDataSize = avctx->codec_id == CODEC_ID_H264 ? sizeof(DXVA_Status_H264) : sizeof(DXVA_Status_VC1); -+ data.PrivateOutputDataSize = avctx->codec_id == AV_CODEC_ID_H264 ? sizeof(DXVA_Status_H264) : sizeof(DXVA_Status_VC1); - HRESULT hr; - if(FAILED( hr = m_decoder->Execute(¶ms))) - { -@@ -794,7 +794,7 @@ - return VC_ERROR; - } - -- if(avctx->codec_id == CODEC_ID_H264) -+ if(avctx->codec_id == AV_CODEC_ID_H264) - { - if(status.h264.bStatus) - CLog::Log(LOGWARNING, "DXVA - decoder problem of status %d with %d", status.h264.bStatus, status.h264.bBufType); -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/OpenMaxVideo.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/OpenMaxVideo.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/OpenMaxVideo.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/OpenMaxVideo.cpp 2013-08-03 15:17:37.598265512 +1100 -@@ -115,7 +115,7 @@ - - switch (hints.codec) - { -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - { - switch(hints.profile) - { -@@ -140,7 +140,7 @@ - } - } - break; -- case CODEC_ID_MPEG4: -+ case AV_CODEC_ID_MPEG4: - // (role name) video_decoder.mpeg4 - // MPEG-4, DivX 4/5 and Xvid compatible - decoder_name = OMX_MPEG4_DECODER; -@@ -154,12 +154,12 @@ - m_pFormatName = "omx-mpeg4"; - break; - */ -- case CODEC_ID_MPEG2VIDEO: -+ case AV_CODEC_ID_MPEG2VIDEO: - // (role name) video_decoder.mpeg2 - // MPEG-2 - decoder_name = OMX_MPEG2V_DECODER; - break; -- case CODEC_ID_VC1: -+ case AV_CODEC_ID_VC1: - // (role name) video_decoder.vc1 - // VC-1, WMV9 - decoder_name = OMX_VC1_DECODER; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/VAAPI.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/VAAPI.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/VAAPI.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/VAAPI.cpp 2013-08-03 15:17:37.598265512 +1100 -@@ -268,14 +268,14 @@ - - vector<VAProfile> accepted; - switch (avctx->codec_id) { -- case CODEC_ID_MPEG2VIDEO: -+ case AV_CODEC_ID_MPEG2VIDEO: - accepted.push_back(VAProfileMPEG2Main); - break; -- case CODEC_ID_MPEG4: -- case CODEC_ID_H263: -+ case AV_CODEC_ID_MPEG4: -+ case AV_CODEC_ID_H263: - accepted.push_back(VAProfileMPEG4AdvancedSimple); - break; -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - { - #ifdef FF_PROFILE_H264_BASELINE - if (avctx->profile == FF_PROFILE_H264_BASELINE) -@@ -294,10 +294,10 @@ - } - break; - } -- case CODEC_ID_WMV3: -+ case AV_CODEC_ID_WMV3: - accepted.push_back(VAProfileVC1Main); - break; -- case CODEC_ID_VC1: -+ case AV_CODEC_ID_VC1: - accepted.push_back(VAProfileVC1Advanced); - break; - default: -@@ -383,7 +383,7 @@ - m_refs = avctx->refs; - if(m_refs == 0) - { -- if(avctx->codec_id == CODEC_ID_H264) -+ if(avctx->codec_id == AV_CODEC_ID_H264) - m_refs = 16; - else - m_refs = 2; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/VDPAU.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/VDPAU.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/VDPAU.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDCodecs/Video/VDPAU.cpp 2013-08-03 15:25:15.336879885 +1100 -@@ -184,10 +184,10 @@ - SpewHardwareAvailable(); - - VdpDecoderProfile profile = 0; -- if(avctx->codec_id == CODEC_ID_H264) -+ if(avctx->codec_id == AV_CODEC_ID_H264) - profile = VDP_DECODER_PROFILE_H264_HIGH; - #ifdef VDP_DECODER_PROFILE_MPEG4_PART2_ASP -- else if(avctx->codec_id == CODEC_ID_MPEG4) -+ else if(avctx->codec_id == AV_CODEC_ID_MPEG4) - profile = VDP_DECODER_PROFILE_MPEG4_PART2_ASP; - #endif - if(profile) -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxBXA.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxBXA.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxBXA.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxBXA.cpp 2013-08-03 15:17:37.600265539 +1100 -@@ -90,7 +90,7 @@ - m_stream->iBitRate = m_header.sampleRate * m_header.channels * m_header.bitsPerSample; - m_stream->iChannels = m_header.channels; - m_stream->type = STREAM_AUDIO; -- m_stream->codec = CODEC_ID_PCM_S16LE; -+ m_stream->codec = AV_CODEC_ID_PCM_S16LE; - - return true; - } -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.cpp 2013-08-03 15:21:18.031918421 +1100 -@@ -31,8 +31,8 @@ - { - char sInfo[64]; - -- if (codec == CODEC_ID_AC3) strcpy(sInfo, "AC3 "); -- else if (codec == CODEC_ID_DTS) -+ if (codec == AV_CODEC_ID_AC3) strcpy(sInfo, "AC3 "); -+ else if (codec == AV_CODEC_ID_DTS) - { - #ifdef FF_PROFILE_DTS_HD_MA - if (profile == FF_PROFILE_DTS_HD_MA) -@@ -43,7 +43,7 @@ - #endif - strcpy(sInfo, "DTS "); - } -- else if (codec == CODEC_ID_MP2) strcpy(sInfo, "MP2 "); -+ else if (codec == AV_CODEC_ID_MP2) strcpy(sInfo, "MP2 "); - else strcpy(sInfo, ""); - - if (iChannels == 1) strcat(sInfo, "Mono"); -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxFFmpeg.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxFFmpeg.cpp 2013-08-03 15:23:36.700233526 +1100 -@@ -450,7 +450,7 @@ - if (iErr < 0) - { - CLog::Log(LOGWARNING,"could not find codec parameters for %s", strFile.c_str()); -- if (m_pInput->IsStreamType(DVDSTREAM_TYPE_DVD) || (m_pFormatContext->nb_streams == 1 && m_pFormatContext->streams[0]->codec->codec_id == CODEC_ID_AC3)) -+ if (m_pInput->IsStreamType(DVDSTREAM_TYPE_DVD) || (m_pFormatContext->nb_streams == 1 && m_pFormatContext->streams[0]->codec->codec_id == AV_CODEC_ID_AC3)) - { - // special case, our codecs can still handle it. - } -@@ -715,7 +715,7 @@ - } - - // we need to get duration slightly different for matroska embedded text subtitels -- if(m_bMatroska && stream->codec->codec_id == CODEC_ID_TEXT && pkt.convergence_duration != 0) -+ if(m_bMatroska && stream->codec->codec_id == AV_CODEC_ID_TEXT && pkt.convergence_duration != 0) - pkt.duration = pkt.convergence_duration; - - if(m_bAVI && stream->codec && stream->codec->codec_type == AVMEDIA_TYPE_VIDEO) -@@ -967,7 +967,7 @@ - st->bVFR = false; - - // never trust pts in avi files with h264. -- if (m_bAVI && pStream->codec->codec_id == CODEC_ID_H264) -+ if (m_bAVI && pStream->codec->codec_id == AV_CODEC_ID_H264) - st->bPTSInvalid = true; - - //average fps is more accurate for mkv files -@@ -1008,15 +1008,15 @@ - - if ( m_pInput->IsStreamType(DVDSTREAM_TYPE_DVD) ) - { -- if (pStream->codec->codec_id == CODEC_ID_PROBE) -+ if (pStream->codec->codec_id == AV_CODEC_ID_PROBE) - { -- // fix MPEG-1/MPEG-2 video stream probe returning CODEC_ID_PROBE for still frames. -+ // fix MPEG-1/MPEG-2 video stream probe returning AV_CODEC_ID_PROBE for still frames. - // ffmpeg issue 1871, regression from ffmpeg r22831. - if ((pStream->id & 0xF0) == 0xE0) - { -- pStream->codec->codec_id = CODEC_ID_MPEG2VIDEO; -+ pStream->codec->codec_id = AV_CODEC_ID_MPEG2VIDEO; - pStream->codec->codec_tag = MKTAG('M','P','2','V'); -- CLog::Log(LOGERROR, "%s - CODEC_ID_PROBE detected, forcing CODEC_ID_MPEG2VIDEO", __FUNCTION__); -+ CLog::Log(LOGERROR, "%s - AV_CODEC_ID_PROBE detected, forcing AV_CODEC_ID_MPEG2VIDEO", __FUNCTION__); - } - } - } -@@ -1053,9 +1053,9 @@ - } - case AVMEDIA_TYPE_ATTACHMENT: - { //mkv attachments. Only bothering with fonts for now. -- if(pStream->codec->codec_id == CODEC_ID_TTF -+ if(pStream->codec->codec_id == AV_CODEC_ID_TTF - #if (!defined USE_EXTERNAL_FFMPEG) -- || pStream->codec->codec_id == CODEC_ID_OTF -+ || pStream->codec->codec_id == AV_CODEC_ID_OTF - #endif - ) - { -@@ -1137,19 +1137,19 @@ - // id's reported from libdvdnav - switch(m_streams[iId]->codec) - { -- case CODEC_ID_AC3: -+ case AV_CODEC_ID_AC3: - m_streams[iId]->iPhysicalId = pStream->id - 128; - break; -- case CODEC_ID_DTS: -+ case AV_CODEC_ID_DTS: - m_streams[iId]->iPhysicalId = pStream->id - 136; - break; -- case CODEC_ID_MP2: -+ case AV_CODEC_ID_MP2: - m_streams[iId]->iPhysicalId = pStream->id - 448; - break; -- case CODEC_ID_PCM_S16BE: -+ case AV_CODEC_ID_PCM_S16BE: - m_streams[iId]->iPhysicalId = pStream->id - 160; - break; -- case CODEC_ID_DVD_SUBTITLE: -+ case AV_CODEC_ID_DVD_SUBTITLE: - m_streams[iId]->iPhysicalId = pStream->id - 0x20; - break; - default: -@@ -1300,7 +1300,7 @@ - - #ifdef FF_PROFILE_DTS_HD_MA - /* use profile to determine the DTS type */ -- if (stream->codec == CODEC_ID_DTS) -+ if (stream->codec == AV_CODEC_ID_DTS) - { - if (stream->profile == FF_PROFILE_DTS_HD_MA) - strName = "dtshd_ma"; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.h xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.h 2013-08-03 15:22:13.480844244 +1100 -@@ -35,7 +35,7 @@ - #include "config.h" - #endif - #ifndef _LINUX --enum CodecID; -+enum AVCodecID; - #include <libavcodec/avcodec.h> - #else - extern "C" { -@@ -88,7 +88,7 @@ - { - iId = 0; - iPhysicalId = 0; -- codec = (CodecID)0; // CODEC_ID_NONE -+ codec = (AVCodecID)0; // AV_CODEC_ID_NONE - codec_fourcc = 0; - profile = FF_PROFILE_UNKNOWN; - level = 0; -@@ -118,7 +118,7 @@ - - int iId; // most of the time starting from 0 - int iPhysicalId; // id -- CodecID codec; -+ AVCodecID codec; - unsigned int codec_fourcc; // if available - int profile; // encoder profile of the stream reported by the decoder. used to qualify hw decoders. - int level; // encoder level of the stream reported by the decoder. used to qualify hw decoders. -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxHTSP.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxHTSP.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxHTSP.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxHTSP.cpp 2013-08-03 15:17:39.181291285 +1100 -@@ -290,39 +290,39 @@ - - if(!strcmp(type, "AC3")) { - st.a = new CDemuxStreamAudioHTSP(this, type); -- st.a->codec = CODEC_ID_AC3; -+ st.a->codec = AV_CODEC_ID_AC3; - } else if(!strcmp(type, "EAC3")) { - st.a = new CDemuxStreamAudioHTSP(this, type); -- st.a->codec = CODEC_ID_EAC3; -+ st.a->codec = AV_CODEC_ID_EAC3; - } else if(!strcmp(type, "MPEG2AUDIO")) { - st.a = new CDemuxStreamAudioHTSP(this, type); -- st.a->codec = CODEC_ID_MP2; -+ st.a->codec = AV_CODEC_ID_MP2; - } else if(!strcmp(type, "AAC")) { - st.a = new CDemuxStreamAudioHTSP(this, type); -- st.a->codec = CODEC_ID_AAC; -+ st.a->codec = AV_CODEC_ID_AAC; - } else if(!strcmp(type, "MPEG2VIDEO")) { - st.v = new CDemuxStreamVideoHTSP(this, type); -- st.v->codec = CODEC_ID_MPEG2VIDEO; -+ st.v->codec = AV_CODEC_ID_MPEG2VIDEO; - st.v->iWidth = htsmsg_get_u32_or_default(sub, "width" , 0); - st.v->iHeight = htsmsg_get_u32_or_default(sub, "height", 0); - } else if(!strcmp(type, "H264")) { - st.v = new CDemuxStreamVideoHTSP(this, type); -- st.v->codec = CODEC_ID_H264; -+ st.v->codec = AV_CODEC_ID_H264; - st.v->iWidth = htsmsg_get_u32_or_default(sub, "width" , 0); - st.v->iHeight = htsmsg_get_u32_or_default(sub, "height", 0); - } else if(!strcmp(type, "DVBSUB")) { - st.s = new CDemuxStreamSubtitle(); -- st.s->codec = CODEC_ID_DVB_SUBTITLE; -+ st.s->codec = AV_CODEC_ID_DVB_SUBTITLE; - uint32_t composition_id = 0, ancillary_id = 0; - htsmsg_get_u32(sub, "composition_id", &composition_id); - htsmsg_get_u32(sub, "ancillary_id" , &ancillary_id); - st.s->identifier = (composition_id & 0xffff) | ((ancillary_id & 0xffff) << 16); - } else if(!strcmp(type, "TEXTSUB")) { - st.s = new CDemuxStreamSubtitle(); -- st.s->codec = CODEC_ID_TEXT; -+ st.s->codec = AV_CODEC_ID_TEXT; - } else if(!strcmp(type, "TELETEXT")) { - st.t = new CDemuxStreamTeletext(); -- st.t->codec = CODEC_ID_DVB_TELETEXT; -+ st.t->codec = AV_CODEC_ID_DVB_TELETEXT; - } else { - continue; - } -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxPVRClient.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxPVRClient.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxPVRClient.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxPVRClient.cpp 2013-08-03 15:17:39.181291285 +1100 -@@ -60,10 +60,10 @@ - { - switch (codec) - { -- case CODEC_ID_MPEG2VIDEO: -+ case AV_CODEC_ID_MPEG2VIDEO: - strInfo = "mpeg2video"; - break; -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - strInfo = "h264"; - break; - default: -@@ -75,19 +75,19 @@ - { - switch (codec) - { -- case CODEC_ID_AC3: -+ case AV_CODEC_ID_AC3: - strInfo = "ac3"; - break; -- case CODEC_ID_EAC3: -+ case AV_CODEC_ID_EAC3: - strInfo = "eac3"; - break; -- case CODEC_ID_MP2: -+ case AV_CODEC_ID_MP2: - strInfo = "mpeg2audio"; - break; -- case CODEC_ID_AAC: -+ case AV_CODEC_ID_AAC: - strInfo = "aac"; - break; -- case CODEC_ID_DTS: -+ case AV_CODEC_ID_DTS: - strInfo = "dts"; - break; - default: -@@ -349,7 +349,7 @@ - { - st = dynamic_cast<CDemuxStreamAudioPVRClient*>(stm); - if (!st -- || (st->codec != (CodecID)props.stream[i].iCodecId) -+ || (st->codec != (AVCodecID)props.stream[i].iCodecId) - || (st->iChannels != props.stream[i].iChannels)) - DisposeStream(i); - } -@@ -375,7 +375,7 @@ - { - st = dynamic_cast<CDemuxStreamVideoPVRClient*>(stm); - if (!st -- || (st->codec != (CodecID)props.stream[i].iCodecId) -+ || (st->codec != (AVCodecID)props.stream[i].iCodecId) - || (st->iWidth != props.stream[i].iWidth) - || (st->iHeight != props.stream[i].iHeight)) - DisposeStream(i); -@@ -395,11 +395,11 @@ - m_streams[i] = st; - st->m_parser_split = true; - } -- else if (props.stream[i].iCodecId == CODEC_ID_DVB_TELETEXT) -+ else if (props.stream[i].iCodecId == AV_CODEC_ID_DVB_TELETEXT) - { - if (stm) - { -- if (stm->codec != (CodecID)props.stream[i].iCodecId) -+ if (stm->codec != (AVCodecID)props.stream[i].iCodecId) - DisposeStream(i); - } - if (!m_streams[i]) -@@ -411,7 +411,7 @@ - if (stm) - { - st = dynamic_cast<CDemuxStreamSubtitlePVRClient*>(stm); -- if (!st || (st->codec != (CodecID)props.stream[i].iCodecId)) -+ if (!st || (st->codec != (AVCodecID)props.stream[i].iCodecId)) - DisposeStream(i); - } - if (!m_streams[i]) -@@ -428,7 +428,7 @@ - m_streams[i] = new CDemuxStream(); - } - -- m_streams[i]->codec = (CodecID)props.stream[i].iCodecId; -+ m_streams[i]->codec = (AVCodecID)props.stream[i].iCodecId; - m_streams[i]->iId = i; - m_streams[i]->iPhysicalId = props.stream[i].iPhysicalId; - m_streams[i]->language[0] = props.stream[i].strLanguage[0]; -@@ -475,19 +475,19 @@ - CDemuxStream *stream = GetStream(iStreamId); - if (stream) - { -- if (stream->codec == CODEC_ID_AC3) -+ if (stream->codec == AV_CODEC_ID_AC3) - strName = "ac3"; -- else if (stream->codec == CODEC_ID_MP2) -+ else if (stream->codec == AV_CODEC_ID_MP2) - strName = "mp2"; -- else if (stream->codec == CODEC_ID_AAC) -+ else if (stream->codec == AV_CODEC_ID_AAC) - strName = "aac"; -- else if (stream->codec == CODEC_ID_DTS) -+ else if (stream->codec == AV_CODEC_ID_DTS) - strName = "dca"; -- else if (stream->codec == CODEC_ID_MPEG2VIDEO) -+ else if (stream->codec == AV_CODEC_ID_MPEG2VIDEO) - strName = "mpeg2video"; -- else if (stream->codec == CODEC_ID_H264) -+ else if (stream->codec == AV_CODEC_ID_H264) - strName = "h264"; -- else if (stream->codec == CODEC_ID_EAC3) -+ else if (stream->codec == AV_CODEC_ID_EAC3) - strName = "eac3"; - } - } -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxShoutcast.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxShoutcast.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxShoutcast.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxShoutcast.cpp 2013-08-03 15:17:39.182291301 +1100 -@@ -86,12 +86,12 @@ - stricmp(strMimeType.c_str(), CONTENT_TYPE_AACPLUS) == 0) - { - // need an aac decoder first -- m_pDemuxStream->codec = CODEC_ID_AAC; -+ m_pDemuxStream->codec = AV_CODEC_ID_AAC; - } - else // (stricmp(strMimeType, CONTENT_TYPE_MP3) == 0) - { - // default to mp3 -- m_pDemuxStream->codec = CODEC_ID_MP3; -+ m_pDemuxStream->codec = AV_CODEC_ID_MP3; - } - - return true; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxVobsub.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxVobsub.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxVobsub.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxVobsub.cpp 2013-08-03 15:17:39.182291301 +1100 -@@ -71,7 +71,7 @@ - - CDVDStreamInfo hints; - CDVDCodecOptions options; -- hints.codec = CODEC_ID_DVD_SUBTITLE; -+ hints.codec = AV_CODEC_ID_DVD_SUBTITLE; - - char line[2048]; - DECLARE_UNUSED(bool,res) -@@ -211,7 +211,7 @@ - else - stream->iPhysicalId = -1; - -- stream->codec = CODEC_ID_DVD_SUBTITLE; -+ stream->codec = AV_CODEC_ID_DVD_SUBTITLE; - stream->iId = m_Streams.size(); - - state.id = stream->iId; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDFileInfo.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDFileInfo.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDFileInfo.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDFileInfo.cpp 2013-08-03 15:17:39.182291301 +1100 -@@ -162,7 +162,7 @@ - CDVDStreamInfo hint(*pDemuxer->GetStream(nVideoStream), true); - hint.software = true; - -- if (hint.codec == CODEC_ID_MPEG2VIDEO || hint.codec == CODEC_ID_MPEG1VIDEO) -+ if (hint.codec == AV_CODEC_ID_MPEG2VIDEO || hint.codec == AV_CODEC_ID_MPEG1VIDEO) - { - // libmpeg2 is not thread safe so use ffmepg for mpeg2/mpeg1 thumb extraction - CDVDCodecOptions dvdOptions; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDPlayerAudio.h xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDPlayerAudio.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDPlayerAudio.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDPlayerAudio.h 2013-08-03 15:37:53.655526419 +1100 -@@ -38,7 +38,7 @@ - class IAudioCallback; - class CDVDAudioCodec; - --enum CodecID; -+enum AVCodecID; - - #define DECODE_FLAG_DROP 1 - #define DECODE_FLAG_RESYNC 2 -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDPlayerSubtitle.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDPlayerSubtitle.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDPlayerSubtitle.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDPlayerSubtitle.cpp 2013-08-03 15:17:39.183291318 +1100 -@@ -86,7 +86,7 @@ - } - } - } -- else if (m_streaminfo.codec == CODEC_ID_DVD_SUBTITLE) -+ else if (m_streaminfo.codec == AV_CODEC_ID_DVD_SUBTITLE) - { - CDVDOverlaySpu* pSPUInfo = m_dvdspus.AddData(pPacket->pData, pPacket->iSize, pPacket->pts); - if (pSPUInfo) -@@ -171,7 +171,7 @@ - } - - // dvd's use special subtitle decoder -- if(hints.codec == CODEC_ID_DVD_SUBTITLE && filename == "dvd") -+ if(hints.codec == AV_CODEC_ID_DVD_SUBTITLE && filename == "dvd") - return true; - - m_pOverlayCodec = CDVDFactoryCodec::CreateOverlayCodec(hints); -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDPlayerTeletext.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDPlayerTeletext.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDPlayerTeletext.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDPlayerTeletext.cpp 2013-08-03 15:20:16.168885372 +1100 -@@ -114,7 +114,7 @@ - bool CDVDTeletextData::CheckStream(CDVDStreamInfo &hints) - { - #if LIBAVCODEC_VERSION_INT >= AV_VERSION_INT(52,38,1) -- if (hints.codec == CODEC_ID_DVB_TELETEXT) -+ if (hints.codec == AV_CODEC_ID_DVB_TELETEXT) - return true; - #endif - -@@ -126,7 +126,7 @@ - m_messageQueue.Init(); - - #if LIBAVCODEC_VERSION_INT >= AV_VERSION_INT(52,38,1) -- if (hints.codec == CODEC_ID_DVB_TELETEXT) -+ if (hints.codec == AV_CODEC_ID_DVB_TELETEXT) - { - CLog::Log(LOGNOTICE, "Creating teletext data thread"); - Create(); -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDPlayerVideo.h xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDPlayerVideo.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDPlayerVideo.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDPlayerVideo.h 2013-08-03 15:17:39.184291335 +1100 -@@ -31,7 +31,6 @@ - #include "cores/VideoRenderers/RenderManager.h" - #endif - --enum CodecID; - class CDemuxStreamVideo; - class CDVDOverlayCodecCC; - -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDStreamInfo.cpp xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDStreamInfo.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDStreamInfo.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDStreamInfo.cpp 2013-08-03 15:17:39.184291335 +1100 -@@ -38,7 +38,7 @@ - - void CDVDStreamInfo::Clear() - { -- codec = CODEC_ID_NONE; -+ codec = AV_CODEC_ID_NONE; - type = STREAM_NONE; - software = false; - codec_tag = 0; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDStreamInfo.h xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDStreamInfo.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDStreamInfo.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/dvdplayer/DVDStreamInfo.h 2013-08-03 15:17:39.184291335 +1100 -@@ -59,7 +59,7 @@ - void Assign(const CDVDStreamInfo &right, bool withextradata); - void Assign(const CDemuxStream &right, bool withextradata); - -- CodecID codec; -+ AVCodecID codec; - StreamType type; - bool software; //force software decoding - -diff -urN xbmc-12.2-orig/xbmc/cores/omxplayer/OMXAudio.cpp xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXAudio.cpp ---- xbmc-12.2-orig/xbmc/cores/omxplayer/OMXAudio.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXAudio.cpp 2013-08-03 15:17:39.185291351 +1100 -@@ -1225,17 +1225,17 @@ - } - } - --bool COMXAudio::CanHWDecode(CodecID codec) -+bool COMXAudio::CanHWDecode(AVCodecID codec) - { - bool ret = false; - switch(codec) - { -- case CODEC_ID_DTS: -+ case AV_CODEC_ID_DTS: - CLog::Log(LOGDEBUG, "COMXAudio::CanHWDecode OMX_AUDIO_CodingDTS\n"); - ret = true; - break; -- case CODEC_ID_AC3: -- case CODEC_ID_EAC3: -+ case AV_CODEC_ID_AC3: -+ case AV_CODEC_ID_EAC3: - CLog::Log(LOGDEBUG, "COMXAudio::CanHWDecode OMX_AUDIO_CodingDDP\n"); - ret = true; - break; -diff -urN xbmc-12.2-orig/xbmc/cores/omxplayer/OMXAudio.h xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXAudio.h ---- xbmc-12.2-orig/xbmc/cores/omxplayer/OMXAudio.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXAudio.h 2013-08-03 15:17:39.185291351 +1100 -@@ -85,7 +85,7 @@ - void Process(); - - void SetCodingType(AEDataFormat dataFormat); -- static bool CanHWDecode(CodecID codec); -+ static bool CanHWDecode(AVCodecID codec); - - void PrintChannels(OMX_AUDIO_CHANNELTYPE eChannelMapping[]); - void PrintPCM(OMX_AUDIO_PARAM_PCMMODETYPE *pcm, std::string direction); -diff -urN xbmc-12.2-orig/xbmc/cores/omxplayer/OMXPlayerAudio.cpp xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXPlayerAudio.cpp ---- xbmc-12.2-orig/xbmc/cores/omxplayer/OMXPlayerAudio.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXPlayerAudio.cpp 2013-08-03 15:19:42.317320020 +1100 -@@ -305,8 +305,8 @@ - m_hints.samplerate = m_pAudioCodec->GetSampleRate(); - } - -- /* only check bitrate changes on CODEC_ID_DTS, CODEC_ID_AC3, CODEC_ID_EAC3 */ -- if(m_hints.codec != CODEC_ID_DTS && m_hints.codec != CODEC_ID_AC3 && m_hints.codec != CODEC_ID_EAC3) -+ /* only check bitrate changes on AV_CODEC_ID_DTS, AV_CODEC_ID_AC3, AV_CODEC_ID_EAC3 */ -+ if(m_hints.codec != AV_CODEC_ID_DTS && m_hints.codec != AV_CODEC_ID_AC3 && m_hints.codec != AV_CODEC_ID_EAC3) - new_bitrate = old_bitrate = 0; - - if(m_hints_current.codec != m_hints.codec || -@@ -667,12 +667,12 @@ - /* pathrought is overriding hw decode*/ - if(AUDIO_IS_BITSTREAM(g_guiSettings.GetInt("audiooutput.mode")) && m_use_passthrough) - { -- if(hints.codec == CODEC_ID_AC3 && g_guiSettings.GetBool("audiooutput.ac3passthrough") && hdmi_passthrough_ac3) -+ if(hints.codec == AV_CODEC_ID_AC3 && g_guiSettings.GetBool("audiooutput.ac3passthrough") && hdmi_passthrough_ac3) - { - dataFormat = AE_FMT_AC3; - m_passthrough = true; - } -- if(hints.codec == CODEC_ID_DTS && g_guiSettings.GetBool("audiooutput.dtspassthrough") && hdmi_passthrough_dts) -+ if(hints.codec == AV_CODEC_ID_DTS && g_guiSettings.GetBool("audiooutput.dtspassthrough") && hdmi_passthrough_dts) - { - dataFormat = AE_FMT_DTS; - m_passthrough = true; -@@ -682,12 +682,12 @@ - /* hw decode */ - if(m_use_hw_decode && !m_passthrough) - { -- if(hints.codec == CODEC_ID_AC3 && COMXAudio::CanHWDecode(m_hints.codec)) -+ if(hints.codec == AV_CODEC_ID_AC3 && COMXAudio::CanHWDecode(m_hints.codec)) - { - dataFormat = AE_FMT_AC3; - m_hw_decode = true; - } -- if(hints.codec == CODEC_ID_DTS && COMXAudio::CanHWDecode(m_hints.codec)) -+ if(hints.codec == AV_CODEC_ID_DTS && COMXAudio::CanHWDecode(m_hints.codec)) - { - dataFormat = AE_FMT_DTS; - m_hw_decode = true; -diff -urN xbmc-12.2-orig/xbmc/cores/omxplayer/OMXVideo.cpp xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXVideo.cpp ---- xbmc-12.2-orig/xbmc/cores/omxplayer/OMXVideo.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXVideo.cpp 2013-08-03 15:17:39.186291368 +1100 -@@ -131,11 +131,11 @@ - return true; - } - --bool COMXVideo::NaluFormatStartCodes(enum CodecID codec, uint8_t *in_extradata, int in_extrasize) -+bool COMXVideo::NaluFormatStartCodes(enum AVCodecID codec, uint8_t *in_extradata, int in_extrasize) - { - switch(codec) - { -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - if (in_extrasize < 7 || in_extradata == NULL) - return true; - // valid avcC atom data always starts with the value 1 (version), otherwise annexb -@@ -178,7 +178,7 @@ - - switch (hints.codec) - { -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - { - switch(hints.profile) - { -@@ -234,64 +234,64 @@ - } - } - break; -- case CODEC_ID_MPEG4: -+ case AV_CODEC_ID_MPEG4: - // (role name) video_decoder.mpeg4 - // MPEG-4, DivX 4/5 and Xvid compatible - decoder_name = OMX_MPEG4_DECODER; - m_codingType = OMX_VIDEO_CodingMPEG4; - m_video_codec_name = "omx-mpeg4"; - break; -- case CODEC_ID_MPEG1VIDEO: -- case CODEC_ID_MPEG2VIDEO: -+ case AV_CODEC_ID_MPEG1VIDEO: -+ case AV_CODEC_ID_MPEG2VIDEO: - // (role name) video_decoder.mpeg2 - // MPEG-2 - decoder_name = OMX_MPEG2V_DECODER; - m_codingType = OMX_VIDEO_CodingMPEG2; - m_video_codec_name = "omx-mpeg2"; - break; -- case CODEC_ID_H263: -+ case AV_CODEC_ID_H263: - // (role name) video_decoder.mpeg4 - // MPEG-4, DivX 4/5 and Xvid compatible - decoder_name = OMX_MPEG4_DECODER; - m_codingType = OMX_VIDEO_CodingMPEG4; - m_video_codec_name = "omx-h263"; - break; -- case CODEC_ID_VP6: -+ case AV_CODEC_ID_VP6: - // this form is encoded upside down - vflip = true; - // fall through -- case CODEC_ID_VP6F: -- case CODEC_ID_VP6A: -+ case AV_CODEC_ID_VP6F: -+ case AV_CODEC_ID_VP6A: - // (role name) video_decoder.vp6 - // VP6 - decoder_name = OMX_VP6_DECODER; - m_codingType = OMX_VIDEO_CodingVP6; - m_video_codec_name = "omx-vp6"; - break; -- case CODEC_ID_VP8: -+ case AV_CODEC_ID_VP8: - // (role name) video_decoder.vp8 - // VP8 - decoder_name = OMX_VP8_DECODER; - m_codingType = OMX_VIDEO_CodingVP8; - m_video_codec_name = "omx-vp8"; - break; -- case CODEC_ID_THEORA: -+ case AV_CODEC_ID_THEORA: - // (role name) video_decoder.theora - // theora - decoder_name = OMX_THEORA_DECODER; - m_codingType = OMX_VIDEO_CodingTheora; - m_video_codec_name = "omx-theora"; - break; -- case CODEC_ID_MJPEG: -- case CODEC_ID_MJPEGB: -+ case AV_CODEC_ID_MJPEG: -+ case AV_CODEC_ID_MJPEGB: - // (role name) video_decoder.mjpg - // mjpg - decoder_name = OMX_MJPEG_DECODER; - m_codingType = OMX_VIDEO_CodingMJPEG; - m_video_codec_name = "omx-mjpeg"; - break; -- case CODEC_ID_VC1: -- case CODEC_ID_WMV3: -+ case AV_CODEC_ID_VC1: -+ case AV_CODEC_ID_WMV3: - // (role name) video_decoder.vc1 - // VC-1, WMV9 - decoder_name = OMX_VC1_DECODER; -diff -urN xbmc-12.2-orig/xbmc/cores/omxplayer/OMXVideo.h xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXVideo.h ---- xbmc-12.2-orig/xbmc/cores/omxplayer/OMXVideo.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/cores/omxplayer/OMXVideo.h 2013-08-03 15:18:46.130381924 +1100 -@@ -98,7 +98,7 @@ - ResolutionUpdateCallBackFn m_res_callback; - void *m_res_ctx; - bool m_submitted_eos; -- bool NaluFormatStartCodes(enum CodecID codec, uint8_t *in_extradata, int in_extrasize); -+ bool NaluFormatStartCodes(enum AVCodecID codec, uint8_t *in_extradata, int in_extrasize); - }; - - #endif -diff -urN xbmc-12.2-orig/xbmc/utils/BitstreamConverter.cpp xbmc-12.2-avcodec/xbmc/utils/BitstreamConverter.cpp ---- xbmc-12.2-orig/xbmc/utils/BitstreamConverter.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/utils/BitstreamConverter.cpp 2013-08-03 15:25:54.780538147 +1100 -@@ -431,7 +431,7 @@ - Close(); - } - --bool CBitstreamConverter::Open(enum CodecID codec, uint8_t *in_extradata, int in_extrasize, bool to_annexb) -+bool CBitstreamConverter::Open(enum AVCodecID codec, uint8_t *in_extradata, int in_extrasize, bool to_annexb) - { - m_to_annexb = to_annexb; - -@@ -439,7 +439,7 @@ - - switch(codec) - { -- case CODEC_ID_H264: -+ case AV_CODEC_ID_H264: - if (in_extrasize < 7 || in_extradata == NULL) - { - CLog::Log(LOGERROR, "CBitstreamConverter::Open avcC data too small or missing\n"); -@@ -587,7 +587,7 @@ - - if (pData) - { -- if(m_codec == CODEC_ID_H264) -+ if(m_codec == AV_CODEC_ID_H264) - { - if(m_to_annexb) - { -diff -urN xbmc-12.2-orig/xbmc/utils/BitstreamConverter.h xbmc-12.2-avcodec/xbmc/utils/BitstreamConverter.h ---- xbmc-12.2-orig/xbmc/utils/BitstreamConverter.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-avcodec/xbmc/utils/BitstreamConverter.h 2013-08-03 15:17:39.188291400 +1100 -@@ -114,7 +114,7 @@ - static void skip_bits( bits_reader_t *br, int nbits ); - static uint32_t get_bits( bits_reader_t *br, int nbits ); - -- bool Open(enum CodecID codec, uint8_t *in_extradata, int in_extrasize, bool to_annexb); -+ bool Open(enum AVCodecID codec, uint8_t *in_extradata, int in_extrasize, bool to_annexb); - void Close(void); - bool NeedConvert(void) { return m_convert_bitstream; }; - bool Convert(uint8_t *pData, int iSize); -@@ -163,7 +163,7 @@ - bool m_convert_bytestream; - DllAvUtil *m_dllAvUtil; - DllAvFormat *m_dllAvFormat; -- CodecID m_codec; -+ AVCodecID m_codec; - }; - - #endif -diff -urN xbmc-12.2-orig/lib/DllAvFilter.h xbmc-12.2-bufferframe/lib/DllAvFilter.h ---- xbmc-12.2-orig/lib/DllAvFilter.h 2013-05-03 16:57:40.000000000 +1100 -+++ xbmc-12.2-bufferframe/lib/DllAvFilter.h 2013-08-03 15:57:21.000000000 +1100 -@@ -46,6 +46,7 @@ - #include <libavfilter/avfiltergraph.h> - #include <libavfilter/buffersink.h> - #include <libavfilter/avcodec.h> -+ #include <libavfilter/buffersrc.h> - #elif (defined HAVE_FFMPEG_AVFILTER_H) - #include <ffmpeg/avfiltergraph.h> - #include <ffmpeg/buffersink.h> -@@ -55,9 +56,17 @@ - #include "libavfilter/avfiltergraph.h" - #include "libavfilter/buffersink.h" - #include "libavfilter/avcodec.h" -+ #include <libavfilter/buffersrc.h> - #endif - } - -+#if LIBAVFILTER_VERSION_MICRO >= 100 -+ #define LIBAVFILTER_FROM_FFMPEG -+#else -+ #define LIBAVFILTER_FROM_LIBAV -+#endif -+ -+ - #include "threads/SingleLock.h" - - class DllAvFilterInterface -@@ -74,10 +83,13 @@ - virtual void avfilter_inout_free(AVFilterInOut **inout)=0; - virtual int avfilter_graph_parse(AVFilterGraph *graph, const char *filters, AVFilterInOut **inputs, AVFilterInOut **outputs, void *log_ctx)=0; - virtual int avfilter_graph_config(AVFilterGraph *graphctx, void *log_ctx)=0; --#if LIBAVFILTER_VERSION_INT < AV_VERSION_INT(3,0,0) -- virtual int av_vsrc_buffer_add_frame(AVFilterContext *buffer_filter, AVFrame *frame, int flags)=0; --#else -+#if (defined(LIBAVFILTER_FROM_LIBAV) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(3,5,0)) || \ -+ (defined(LIBAVFILTER_FROM_FFMPEG) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(3,43,100)) -+ virtual int av_buffersrc_add_frame(AVFilterContext *buffer_filter, AVFrame *frame)=0; -+#elif defined(LIBAVFILTER_FROM_FFMPEG) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(2,72,105) - virtual int av_buffersrc_add_frame(AVFilterContext *buffer_filter, AVFrame *frame, int flags)=0; -+#else -+ virtual int av_vsrc_buffer_add_frame(AVFilterContext *buffer_filter, AVFrame *frame, int flags)=0; - #endif - virtual void avfilter_unref_buffer(AVFilterBufferRef *ref)=0; - virtual int avfilter_link(AVFilterContext *src, unsigned srcpad, AVFilterContext *dst, unsigned dstpad)=0; -@@ -134,10 +146,13 @@ - { - return ::avfilter_graph_config(graphctx, log_ctx); - } --#if LIBAVFILTER_VERSION_INT < AV_VERSION_INT(3,0,0) -- virtual int av_vsrc_buffer_add_frame(AVFilterContext *buffer_filter, AVFrame *frame, int flags) { return ::av_vsrc_buffer_add_frame(buffer_filter, frame, flags); } --#else -+#if (defined(LIBAVFILTER_FROM_LIBAV) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(3,5,0)) || \ -+ (defined(LIBAVFILTER_FROM_FFMPEG) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(3,43,100)) -+ virtual int av_buffersrc_add_frame(AVFilterContext *buffer_filter, AVFrame* frame) { return ::av_buffersrc_add_frame(buffer_filter, frame); } -+#elif defined(LIBAVFILTER_FROM_FFMPEG) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(2,72,105) - virtual int av_buffersrc_add_frame(AVFilterContext *buffer_filter, AVFrame* frame, int flags) { return ::av_buffersrc_add_frame(buffer_filter, frame, flags); } -+#else -+ virtual int av_vsrc_buffer_add_frame(AVFilterContext *buffer_filter, AVFrame *frame, int flags) { return ::av_vsrc_buffer_add_frame(buffer_filter, frame, flags); } - #endif - virtual void avfilter_unref_buffer(AVFilterBufferRef *ref) { ::avfilter_unref_buffer(ref); } - virtual int avfilter_link(AVFilterContext *src, unsigned srcpad, AVFilterContext *dst, unsigned dstpad) { return ::avfilter_link(src, srcpad, dst, dstpad); } -@@ -172,10 +187,13 @@ - DEFINE_METHOD1(void, avfilter_inout_free_dont_call, (AVFilterInOut **p1)) - DEFINE_FUNC_ALIGNED5(int, __cdecl, avfilter_graph_parse_dont_call, AVFilterGraph *, const char *, AVFilterInOut **, AVFilterInOut **, void *) - DEFINE_FUNC_ALIGNED2(int, __cdecl, avfilter_graph_config_dont_call, AVFilterGraph *, void *) --#if LIBAVFILTER_VERSION_INT < AV_VERSION_INT(3,0,0) -- DEFINE_METHOD3(int, av_vsrc_buffer_add_frame, (AVFilterContext *p1, AVFrame *p2, int p3)) --#else -+#if (defined(LIBAVFILTER_FROM_LIBAV) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(3,5,0)) || \ -+ (defined(LIBAVFILTER_FROM_FFMPEG) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(3,43,100)) -+ DEFINE_METHOD2(int, av_buffersrc_add_frame, (AVFilterContext *p1, AVFrame *p2)) -+#elif defined(LIBAVFILTER_FROM_FFMPEG) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(2,72,105) - DEFINE_METHOD3(int, av_buffersrc_add_frame, (AVFilterContext *p1, AVFrame *p2, int p3)) -+#else -+ DEFINE_METHOD3(int, av_vsrc_buffer_add_frame, (AVFilterContext *p1, AVFrame *p2, int p3)) - #endif - DEFINE_METHOD1(void, avfilter_unref_buffer, (AVFilterBufferRef *p1)) - DEFINE_METHOD4(int, avfilter_link, (AVFilterContext *p1, unsigned p2, AVFilterContext *p3, unsigned p4)) -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp xbmc-12.2-bufferframe/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-bufferframe/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp 2013-08-03 15:55:20.699922079 +1100 -@@ -796,18 +796,25 @@ - - if (frame) - { --#if LIBAVFILTER_VERSION_INT < AV_VERSION_INT(3,0,0) -- result = m_dllAvFilter.av_vsrc_buffer_add_frame(m_pFilterIn, frame, 0); --#else -+#if (defined(LIBAVFILTER_FROM_LIBAV) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(3,5,0)) || \ -+ (defined(LIBAVFILTER_FROM_FFMPEG) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(3,43,100)) -+ // API changed in: -+ // ffmpeg: commit 7e350379f87e7f74420b4813170fe808e2313911 (28 Nov 2012) -+ // not released (post 1.2) -+ // libav: commit 7e350379f87e7f74420b4813170fe808e2313911 (28 Nov 2012) -+ // release v9 (5 January 2013) -+ result = m_dllAvFilter.av_buffersrc_add_frame(m_pFilterIn, frame); -+#elif defined(LIBAVFILTER_FROM_FFMPEG) && LIBAVFILTER_VERSION_INT >= AV_VERSION_INT(2,72,105) -+ // API changed in: -+ // ffmpeg: commit 7bac2a78c2241df4bcc1665703bb71afd9a3e692 (28 Apr 2012) -+ // release 0.11 (25 May 2012) - result = m_dllAvFilter.av_buffersrc_add_frame(m_pFilterIn, frame, 0); -+#else -+ result = m_dllAvFilter.av_vsrc_buffer_add_frame(m_pFilterIn, frame, 0); - #endif - if (result < 0) - { --#if LIBAVFILTER_VERSION_INT < AV_VERSION_INT(3,0,0) -- CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterProcess - av_vsrc_buffer_add_frame"); --#else -- CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterProcess - av_buffersrc_add_frame"); --#endif -+ CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterProcess - av_buffersrc_add_frame/av_vsrc_buffer_add_frame"); - return VC_ERROR; - } - } -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp xbmc-12.2-dsp_mask/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-dsp_mask/xbmc/cores/dvdplayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp 2013-08-03 16:51:34.431714287 +1100 -@@ -272,9 +272,6 @@ - memcpy(m_pCodecContext->extradata, hints.extradata, hints.extrasize); - } - -- // set acceleration -- m_pCodecContext->dsp_mask = 0;//FF_MM_FORCE | FF_MM_MMX | FF_MM_MMXEXT | FF_MM_SSE; -- - // advanced setting override for skip loop filter (see avcodec.h for valid options) - // TODO: allow per video setting? - if (g_advancedSettings.m_iSkipLoopFilter != 0) -diff -urN xbmc-12.2-orig/xbmc/cdrip/EncoderFFmpeg.h xbmc-12.2-framesize/xbmc/cdrip/EncoderFFmpeg.h ---- xbmc-12.2-orig/xbmc/cdrip/EncoderFFmpeg.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-framesize/xbmc/cdrip/EncoderFFmpeg.h 2013-08-03 16:25:51.108586271 +1100 -@@ -45,7 +45,7 @@ - AVCodecContext *m_CodecCtx; - AVStream *m_Stream; - AVPacket m_Pkt; -- unsigned char m_BCBuffer[AVCODEC_MAX_AUDIO_FRAME_SIZE]; -+ unsigned char m_BCBuffer[192000]; - static int MuxerReadPacket(void *opaque, uint8_t *buf, int buf_size); - void SetTag(const CStdString tag, const CStdString value); - -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecFFmpeg.cpp xbmc-12.2-framesize/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-framesize/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecFFmpeg.cpp 2013-08-03 16:26:54.049609066 +1100 -@@ -30,8 +30,8 @@ - { - m_iBufferSize1 = 0; - m_iBufferSize2 = 0; -- m_pBuffer2 = (BYTE*)_aligned_malloc(AVCODEC_MAX_AUDIO_FRAME_SIZE + FF_INPUT_BUFFER_PADDING_SIZE, 16); -- memset(m_pBuffer2, 0, AVCODEC_MAX_AUDIO_FRAME_SIZE + FF_INPUT_BUFFER_PADDING_SIZE); -+ m_pBuffer2 = (BYTE*)_aligned_malloc(192000 + FF_INPUT_BUFFER_PADDING_SIZE, 16); -+ memset(m_pBuffer2, 0, 192000 + FF_INPUT_BUFFER_PADDING_SIZE); - - m_iBuffered = 0; - m_pCodecContext = NULL; -@@ -145,7 +145,7 @@ - int iBytesUsed, got_frame; - if (!m_pCodecContext) return -1; - -- m_iBufferSize1 = AVCODEC_MAX_AUDIO_FRAME_SIZE ; -+ m_iBufferSize1 = 192000 ; - m_iBufferSize2 = 0; - - AVPacket avpkt; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.h xbmc-12.2-framesize/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-framesize/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecLPcm.h 2013-08-03 16:27:14.603943109 +1100 -@@ -24,7 +24,7 @@ - #include "DVDCodecs/DVDCodecs.h" - #include "DVDAudioCodecPcm.h" - --#define LPCM_BUFFER_SIZE (AVCODEC_MAX_AUDIO_FRAME_SIZE / 2) -+#define LPCM_BUFFER_SIZE (192000 / 2) - - class CDVDAudioCodecLPcm : public CDVDAudioCodecPcm - { -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.h xbmc-12.2-framesize/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-framesize/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPassthroughFFmpeg.h 2013-08-03 16:27:33.671253002 +1100 -@@ -66,7 +66,7 @@ - std::list<DataPacket*> m_OutputBuffer; - unsigned int m_OutputSize; - bool m_WroteHeader; -- unsigned char m_BCBuffer[AVCODEC_MAX_AUDIO_FRAME_SIZE]; -+ unsigned char m_BCBuffer[192000]; - unsigned int m_Consumed; - unsigned int m_BufferSize; - uint8_t *m_Buffer; -@@ -89,7 +89,7 @@ - unsigned int m_DecodeSize; - bool SupportsFormat(CDVDStreamInfo &hints); - -- uint8_t m_NeededBuffer[AVCODEC_MAX_AUDIO_FRAME_SIZE]; -+ uint8_t m_NeededBuffer[192000]; - unsigned int m_NeededUsed; - unsigned int m_Needed; - bool m_LostSync; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.cpp xbmc-12.2-framesize/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-framesize/xbmc/cores/dvdplayer/DVDCodecs/Audio/DVDAudioCodecPcm.cpp 2013-08-03 16:27:23.996095755 +1100 -@@ -172,8 +172,8 @@ - src = pData; - int buf_size = iSize; - -- if (iSize > AVCODEC_MAX_AUDIO_FRAME_SIZE / 2) -- iSize = AVCODEC_MAX_AUDIO_FRAME_SIZE / 2; -+ if (iSize > 192000 / 2) -+ iSize = 192000 / 2; - - switch (m_codecID) - { -diff -urN xbmc-12.2-orig/xbmc/cores/omxplayer/OMXAudioCodecOMX.cpp xbmc-12.2-framesize/xbmc/cores/omxplayer/OMXAudioCodecOMX.cpp ---- xbmc-12.2-orig/xbmc/cores/omxplayer/OMXAudioCodecOMX.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-framesize/xbmc/cores/omxplayer/OMXAudioCodecOMX.cpp 2013-08-03 16:27:42.952403863 +1100 -@@ -26,7 +26,7 @@ - - #include "cores/AudioEngine/Utils/AEUtil.h" - --#define MAX_AUDIO_FRAME_SIZE (AVCODEC_MAX_AUDIO_FRAME_SIZE*2) -+#define MAX_AUDIO_FRAME_SIZE (192000*2) - - template <class AudioDataType> - static inline void _Upmix(AudioDataType *input, -@@ -178,7 +178,7 @@ - int iBytesUsed, got_frame; - if (!m_pCodecContext) return -1; - -- m_iBufferSize1 = AVCODEC_MAX_AUDIO_FRAME_SIZE; -+ m_iBufferSize1 = 192000; - m_iBufferSize2 = 0; - - AVPacket avpkt; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecFFmpeg.cpp xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDCodecs/Overlay/DVDOverlayCodecFFmpeg.cpp 2013-08-03 16:41:47.751742559 +1100 -@@ -60,7 +60,6 @@ - m_pCodecContext->debug_mv = 0; - m_pCodecContext->debug = 0; - m_pCodecContext->workaround_bugs = FF_BUG_AUTODETECT; -- m_pCodecContext->sub_id = hints.identifier; - m_pCodecContext->codec_tag = hints.codec_tag; - m_pCodecContext->time_base.num = 1; - m_pCodecContext->time_base.den = DVD_TIME_BASE; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxFFmpeg.cpp xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxFFmpeg.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxFFmpeg.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxFFmpeg.cpp 2013-08-03 16:41:47.752742576 +1100 -@@ -1043,7 +1043,6 @@ - { - CDemuxStreamSubtitleFFmpeg* st = new CDemuxStreamSubtitleFFmpeg(this, pStream); - m_streams[iId] = st; -- st->identifier = pStream->codec->sub_id; - - if(m_dllAvUtil.av_dict_get(pStream->metadata, "title", NULL, 0)) - st->m_description = m_dllAvUtil.av_dict_get(pStream->metadata, "title", NULL, 0)->value; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.h xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemux.h 2013-08-03 16:41:47.752742576 +1100 -@@ -207,11 +207,8 @@ - public: - CDemuxStreamSubtitle() : CDemuxStream() - { -- identifier = 0; - type = STREAM_SUBTITLE; - } -- -- int identifier; - }; - - class CDemuxStreamTeletext : public CDemuxStream -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxHTSP.cpp xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxHTSP.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxHTSP.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxHTSP.cpp 2013-08-03 16:41:47.753742593 +1100 -@@ -316,7 +316,13 @@ - uint32_t composition_id = 0, ancillary_id = 0; - htsmsg_get_u32(sub, "composition_id", &composition_id); - htsmsg_get_u32(sub, "ancillary_id" , &ancillary_id); -- st.s->identifier = (composition_id & 0xffff) | ((ancillary_id & 0xffff) << 16); -+ if(composition_id || ancillary_id) -+ { -+ st.s->ExtraData = new uint8_t[4]; -+ st.s->ExtraSize = 4; -+ ((uint16_t*)st.s->ExtraData)[0] = composition_id; -+ ((uint16_t*)st.s->ExtraData)[1] = ancillary_id; -+ } - } else if(!strcmp(type, "TEXTSUB")) { - st.s = new CDemuxStreamSubtitle(); - st.s->codec = AV_CODEC_ID_TEXT; -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxPVRClient.cpp xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxPVRClient.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxPVRClient.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDDemuxers/DVDDemuxPVRClient.cpp 2013-08-03 16:41:47.753742593 +1100 -@@ -418,7 +418,13 @@ - { - st = new CDemuxStreamSubtitlePVRClient(this); - } -- st->identifier = props.stream[i].iIdentifier; -+ if(props.stream[i].iIdentifier) -+ { -+ st->ExtraData = new uint8_t[4]; -+ st->ExtraSize = 4; -+ ((uint16_t*)st->ExtraData)[0] = (props.stream[i].iIdentifier >> 0) & 0xFFFFu; -+ ((uint16_t*)st->ExtraData)[1] = (props.stream[i].iIdentifier >> 4) & 0xFFFFu; -+ } - m_streams[i] = st; - } - else -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDStreamInfo.cpp xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDStreamInfo.cpp ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDStreamInfo.cpp 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDStreamInfo.cpp 2013-08-03 16:41:47.753742593 +1100 -@@ -67,7 +67,6 @@ - bitrate = 0; - bitspersample = 0; - -- identifier = 0; - orientation = 0; - } - -@@ -108,7 +107,6 @@ - || bitspersample != right.bitspersample ) return false; - - // SUBTITLE -- if( identifier != right.identifier ) return false; - - return true; - } -@@ -164,7 +162,6 @@ - bitspersample = right.bitspersample; - - // SUBTITLE -- identifier = right.identifier; - } - - void CDVDStreamInfo::Assign(const CDemuxStream& right, bool withextradata) -@@ -209,7 +206,5 @@ - } - else if( right.type == STREAM_SUBTITLE ) - { -- const CDemuxStreamSubtitle *stream = static_cast<const CDemuxStreamSubtitle*>(&right); -- identifier = stream->identifier; - } - } -diff -urN xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDStreamInfo.h xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDStreamInfo.h ---- xbmc-12.2-orig/xbmc/cores/dvdplayer/DVDStreamInfo.h 2013-05-03 16:57:41.000000000 +1100 -+++ xbmc-12.2-sub_id/xbmc/cores/dvdplayer/DVDStreamInfo.h 2013-08-03 16:41:47.753742593 +1100 -@@ -87,7 +87,6 @@ - int bitspersample; - - // SUBTITLE -- int identifier; - - // CODEC EXTRADATA - void* extradata; // extra data for codec to use diff --git a/multimedia/xbmc/patches/xbmc-Gotham-rtmpdump-build.patch b/multimedia/xbmc/patches/xbmc-Gotham-rtmpdump-build.patch new file mode 100644 index 0000000000000..b745a55754c79 --- /dev/null +++ b/multimedia/xbmc/patches/xbmc-Gotham-rtmpdump-build.patch @@ -0,0 +1,13 @@ +diff -Naur xbmc-Gotham_alpha9.orig/xbmc/cores/dvdplayer/DVDInputStreams/DVDInputStreamRTMP.cpp xbmc-Gotham_alpha9/xbmc/cores/dvdplayer/DVDInputStreams/DVDInputStreamRTMP.cpp +--- xbmc-Gotham_alpha9.orig/xbmc/cores/dvdplayer/DVDInputStreams/DVDInputStreamRTMP.cpp 2013-10-31 16:48:45.000000000 +0000 ++++ xbmc-Gotham_alpha9/xbmc/cores/dvdplayer/DVDInputStreams/DVDInputStreamRTMP.cpp 2013-11-28 05:47:36.418763917 +0000 +@@ -21,9 +21,7 @@ + #if (defined HAVE_CONFIG_H) && (!defined TARGET_WINDOWS) + #include "config.h" + #endif +-#ifdef TARGET_WINDOWS + #include "system.h" // just for HAS_LIBRTMP +-#endif + + #ifdef HAS_LIBRTMP + #include "settings/AdvancedSettings.h" diff --git a/multimedia/xbmc/patches/xbmc-Gotham-samba-4.0.patch b/multimedia/xbmc/patches/xbmc-Gotham-samba-4.0.patch new file mode 100644 index 0000000000000..63064720091e4 --- /dev/null +++ b/multimedia/xbmc/patches/xbmc-Gotham-samba-4.0.patch @@ -0,0 +1,24 @@ +diff -Naur xbmc-Gotham_alpha9.orig/xbmc/filesystem/SMBDirectory.cpp xbmc-Gotham_alpha9/xbmc/filesystem/SMBDirectory.cpp +--- xbmc-Gotham_alpha9.orig/xbmc/filesystem/SMBDirectory.cpp 2013-10-31 16:48:45.000000000 +0000 ++++ xbmc-Gotham_alpha9/xbmc/filesystem/SMBDirectory.cpp 2013-11-28 06:04:24.156764793 +0000 +@@ -43,7 +43,7 @@ + #include "threads/SingleLock.h" + #include "PasswordManager.h" + +-#include <libsmbclient.h> ++#include <samba-4.0/libsmbclient.h> + + #if defined(TARGET_DARWIN) + #define XBMC_SMB_MOUNT_PATH "Library/Application Support/XBMC/Mounts/" +diff -Naur xbmc-Gotham_alpha9.orig/xbmc/filesystem/SmbFile.cpp xbmc-Gotham_alpha9/xbmc/filesystem/SmbFile.cpp +--- xbmc-Gotham_alpha9.orig/xbmc/filesystem/SmbFile.cpp 2013-10-31 16:48:45.000000000 +0000 ++++ xbmc-Gotham_alpha9/xbmc/filesystem/SmbFile.cpp 2013-11-28 06:05:11.648764834 +0000 +@@ -26,7 +26,7 @@ + #include "SmbFile.h" + #include "PasswordManager.h" + #include "SMBDirectory.h" +-#include <libsmbclient.h> ++#include <samba-4.0/libsmbclient.h> + #include "settings/AdvancedSettings.h" + #include "settings/Settings.h" + #include "threads/SingleLock.h" diff --git a/multimedia/xbmc/patches/xbmc-pvr-addons-ffmpeg-2.0.patch b/multimedia/xbmc/patches/xbmc-pvr-addons-ffmpeg-2.0.patch deleted file mode 100644 index 35d4d6db4fd76..0000000000000 --- a/multimedia/xbmc/patches/xbmc-pvr-addons-ffmpeg-2.0.patch +++ /dev/null @@ -1,14 +0,0 @@ -diff -Naur xbmc-pvr-addons-12.0-Frodo.orig/addons/pvr.hts/src/client.h xbmc-pvr-addons-12.0-Frodo/addons/pvr.hts/src/client.h ---- xbmc-pvr-addons-12.0-Frodo.orig/addons/pvr.hts/src/client.h 2013-01-19 01:40:32.000000000 +0000 -+++ xbmc-pvr-addons-12.0-Frodo/addons/pvr.hts/src/client.h 2013-11-12 01:35:15.818543473 +0000 -@@ -26,6 +26,10 @@ - #include "libXBMC_gui.h" - #include "avcodec.h" - -+#if !defined (CodecID) -+#define CodecID AVCodecID -+#endif -+ - #define DEFAULT_HOST "127.0.0.1" - #define DEFAULT_HTTP_PORT 9981 - #define DEFAULT_HTSP_PORT 9982 diff --git a/multimedia/xbmc/patches/xbmc-rtmpdump-build.patch b/multimedia/xbmc/patches/xbmc-rtmpdump-build.patch deleted file mode 100644 index e77d7d0e8a973..0000000000000 --- a/multimedia/xbmc/patches/xbmc-rtmpdump-build.patch +++ /dev/null @@ -1,13 +0,0 @@ -diff -Naur xbmc-11.0.orig/xbmc/cores/dvdplayer/DVDInputStreams/DVDInputStreamRTMP.cpp xbmc-11.0/xbmc/cores/dvdplayer/DVDInputStreams/DVDInputStreamRTMP.cpp ---- xbmc-11.0.orig/xbmc/cores/dvdplayer/DVDInputStreams/DVDInputStreamRTMP.cpp 2012-03-21 22:07:50.000000000 +0000 -+++ xbmc-11.0/xbmc/cores/dvdplayer/DVDInputStreams/DVDInputStreamRTMP.cpp 2012-03-31 21:44:15.320639375 +0000 -@@ -22,9 +22,7 @@ - #if (defined HAVE_CONFIG_H) && (!defined WIN32) - #include "config.h" - #endif --#ifdef _WIN32 - #include "system.h" // just for HAS_LIBRTMP --#endif - - #ifdef HAS_LIBRTMP - #include "settings/AdvancedSettings.h" diff --git a/multimedia/xbmc/xbmc.SlackBuild b/multimedia/xbmc/xbmc.SlackBuild index d82f5414f6f03..958faa08343cc 100644 --- a/multimedia/xbmc/xbmc.SlackBuild +++ b/multimedia/xbmc/xbmc.SlackBuild @@ -2,7 +2,7 @@ # Slackware build script for XBMC -# Copyright 2009-2013 Larry Hajali <larryhaja[at]gmail[dot]com> +# Copyright 2009-2014 Larry Hajali <larryhaja[at]gmail[dot]com> # All rights reserved. # # Redistribution and use of this script, with or without modification, is @@ -23,7 +23,7 @@ # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. PRGNAM=xbmc -VERSION=${VERSION:-12.3} +VERSION=${VERSION:-13.0_r2} BUILD=${BUILD:-1} TAG=${TAG:-_SBo} @@ -64,7 +64,7 @@ cd $TMP rm -rf $DIRNAME tar xvf $CWD/$PRGNAM-$VERSION.tar.gz cd $DIRNAME -tar xvf $CWD/$PRGNAM-pvr-addons-12.0-Frodo.tar.gz || tar xvf $CWD/12.0-Frodo.tar.gz +tar xvf $CWD/$PRGNAM-pvr-addons-13.0-Gotham.tar.gz || tar xvf $CWD/13.0-Gotham.tar.gz chown -R root:root . find -L . \ \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ @@ -78,30 +78,28 @@ if grep 'sse2' /proc/cpuinfo 2>&1 > /dev/null; then fi # No need to show Git: "Version" in a release build. -sed -i 's|^#ifdef GIT_REV|#ifndef GIT_REV|' $PRGNAM/GUIInfoManager.cpp +sed -i '/GetXbmcGitRevision/,/else/d' $PRGNAM/GUIInfoManager.cpp # Patch for building against rtmpdump. Only needed if xbmc fails to build # w/rtmpdump. See the following link for a rather obtuse explanation. # http://slaxbmc.blogspot.com/2011/03/23-install-xbmc-from-source.html -patch -p1 < $CWD/patches/xbmc-rtmpdump-build.patch +patch -p1 < $CWD/patches/xbmc-Gotham-rtmpdump-build.patch # Patch for Samba 4.0. -patch -p1 < $CWD/patches/samba-4.0.patch +patch -p1 < $CWD/patches/xbmc-Gotham-samba-4.0.patch # Hack for using afpfs-ng. cat lib/afpfs-ng/fix_afpfs-ng_includes.patch | head -1336 | tail -1172 | patch -p1 AFPFS_NGFLAGS="-I$PWD/include" -# Build external ffmpeg. if [ "${FFMPEG:-no}" == "yes" ]; then OPT_DEPS="--enable-external-ffmpeg" - OPT_DEPS_ADDONS="--enable-external-ffmpeg" - # Patches for newer ffmpeg > 2.0. - patch -p1 < $CWD/patches/xbmc-12.2-ffmpeg-2.0.patch - patch -p0 < $CWD/patches/xbmc-pvr-addons-ffmpeg-2.0.patch + # Renable external ffmpeg. Patches from fedora. + patch -p1 < $CWD/patches/0001-Revert-drop-support-for-external-ffmpeg.patch + patch -p1 < $CWD/patches/0002-Revert-linux-link-ffmpeg-statically.patch + patch -p1 < $CWD/patches/0003-makefile-include.patch else - OPT_DEPS="--disable-external-ffmpeg" - OPT_DEPS_ADDONS="--disable-external-ffmpeg" + OPT_DEPS="" fi # Build webserver. Requires libmicrohttpd. @@ -117,14 +115,13 @@ if [ "${PULSE:-no}" == "yes" ]; then fi # Build the pvr addons. -cd $PRGNAM-pvr-addons-12.0-Frodo +cd $PRGNAM-pvr-addons-13.0-Gotham ./bootstrap CFLAGS="$SLKCFLAGS $AFPFS_NGFLAGS" \ CXXFLAGS="$SLKCFLAGS $AFPFS_NGFLAGS" \ ./configure \ --prefix=/usr \ --libdir=/usr/lib${LIBDIRSUFFIX}/xbmc/addons \ - $OPT_DEPS_ADDONS \ --enable-release \ --enable-addons-with-dependencies=yes \ --docdir=/usr/doc/$PRGNAM-$VERSION \ @@ -150,6 +147,7 @@ CXXFLAGS="$SLKCFLAGS $AFPFS_NGFLAGS" \ --enable-ffmpeg-libvorbis \ --enable-alsa \ --disable-asap-codec \ + --enable-texturepacker \ $OPT_DEPS \ --enable-external-libraries \ --build=$ARCH-slackware-linux @@ -164,8 +162,7 @@ fi make install DESTDIR=$PKG -# Remove *.in files from the pvr addons. -find $PKG -name "*\.in" -exec rm -f '{}' \; +install -m 0755 tools/TexturePacker/TexturePacker $PKG/usr/lib${LIBDIRSUFFIX}/$PRGNAM find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \ | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true @@ -186,10 +183,13 @@ fi gzip -9 $PKG/usr/man/man?/*.? cp -a \ - tools/EventClients/README.txt $PRGNAM-pvr-addons-12.0-Frodo/COPYING \ + tools/EventClients/README.txt $PRGNAM-pvr-addons-13.0-Gotham/COPYING \ $PKG/usr/doc/$PRGNAM-$VERSION cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild + +# Final clean up. rm -f $PKG/usr/share/xbmc/{README.linux,LICENSE.GPL,*.txt} +find $PKG \( -name "Makefile*" -o -name "*cmake*" -o -name "*\.in" \) -exec rm -f '{}' \; mkdir -p $PKG/install cat $CWD/slack-desc > $PKG/install/slack-desc diff --git a/multimedia/xbmc/xbmc.info b/multimedia/xbmc/xbmc.info index cf3a533b1950e..7c34597ce215f 100644 --- a/multimedia/xbmc/xbmc.info +++ b/multimedia/xbmc/xbmc.info @@ -1,12 +1,12 @@ PRGNAM="xbmc" -VERSION="12.3" +VERSION="13.0_r2" HOMEPAGE="http://xbmc.org/" -DOWNLOAD="http://mirrors.xbmc.org/releases/source/xbmc-12.3.tar.gz \ - https://github.com/opdenkamp/xbmc-pvr-addons/archive/12.0-Frodo.tar.gz" -MD5SUM="7ae385ebf8e5cfcb917393235e6efbdb \ - 4a1020b1a890e26505da7cc9afef1cea" +DOWNLOAD="http://mirrors.xbmc.org/releases/source/xbmc-13.0_r2.tar.gz \ + https://github.com/opdenkamp/xbmc-pvr-addons/archive/13.0-Gotham.tar.gz" +MD5SUM="8f34b930be1dbeced07b43e316a9fcce \ + 63f5863393ca869eb6f357a62de76378" DOWNLOAD_x86_64="" MD5SUM_x86_64="" -REQUIRES="%README% jdk libass libmpeg2 libmodplug yajl tinyxml" +REQUIRES="jdk libass libmpeg2 libmodplug yajl tinyxml" MAINTAINER="Larry Hajali" EMAIL="larryhaja[at]gmail[dot]com" |