git: edac4920e0a1 - main - multimedia/kodi: Update to 21.0
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sun, 26 May 2024 05:33:54 UTC
The branch main has been updated by decke: URL: https://cgit.FreeBSD.org/ports/commit/?id=edac4920e0a19b7c6979fb2b4a891418d2fbd871 commit edac4920e0a19b7c6979fb2b4a891418d2fbd871 Author: yzrh <yzrh@noema.org> AuthorDate: 2024-05-25 19:24:48 +0000 Commit: Bernhard Froehlich <decke@FreeBSD.org> CommitDate: 2024-05-26 05:32:32 +0000 multimedia/kodi: Update to 21.0 PR: 278334 --- multimedia/kodi/Makefile | 71 +- multimedia/kodi/distinfo | 24 +- .../files/patch-cmake_modules_FindCrossGUID.cmake | 37 +- .../files/patch-cmake_modules_FindLibDvdCSS.cmake | 11 - .../files/patch-cmake_modules_FindLibDvdNav.cmake | 11 - .../files/patch-cmake_modules_FindLibDvdRead.cmake | 11 - multimedia/kodi/files/patch-ffmpeg6-support | 2155 -------------------- ...tch-xbmc_cores_AudioEngine_Sinks_AESinkALSA.cpp | 4 +- ...ch-xbmc_cores_AudioEngine_Utils_AEELDParser.cpp | 11 - multimedia/kodi/pkg-plist | 275 +-- 10 files changed, 156 insertions(+), 2454 deletions(-) diff --git a/multimedia/kodi/Makefile b/multimedia/kodi/Makefile index 6407e95a6982..e4ca578bd2a5 100644 --- a/multimedia/kodi/Makefile +++ b/multimedia/kodi/Makefile @@ -1,6 +1,11 @@ PORTNAME= kodi -DISTVERSION= 20.5 +DISTVERSION= 21.0 CATEGORIES= multimedia java +MASTER_SITES= http://mirrors.kodi.tv/build-deps/sources/ +DISTFILES= apache-groovy-binary-${GROOVY_VERSION}.zip \ + commons-lang3-${COMMONS_LANG_VERSION}-bin.tar.gz \ + commons-text-${COMMONS_TEXT_VERSION}-bin.tar.gz +DIST_SUBDIR= ${PORTNAME} # do not forget to fix devel/kodi-platform when updating kodi MAINTAINER= yzrh@noema.org @@ -38,6 +43,8 @@ LIB_DEPENDS= libass.so:multimedia/libass \ libswscale.so:multimedia/ffmpeg \ libtag.so:audio/taglib \ libtinyxml.so:textproc/tinyxml \ + libtinyxml2.so:textproc/tinyxml2 \ + libudfread.so:multimedia/libudfread \ libuuid.so:misc/e2fsprogs-libuuid RUN_DEPENDS= ${PYTHON_PKGNAMEPREFIX}sqlite3>0:databases/py-sqlite3@${PY_FLAVOR} @@ -45,10 +52,13 @@ USES= autoreconf:build cmake:noninja compiler:c++17-lang cpe \ desktop-file-utils gettext gmake gnome iconv jpeg libtool \ pkgconfig python sqlite ssl -KODI_CODENAME= Nexus +KODI_CODENAME= Omega LIBDVDCSS_VERSION= 1.4.3-Next-Nexus-Alpha2-2 LIBDVDNAV_VERSION= 6.1.1-Next-Nexus-Alpha2-2 LIBDVDREAD_VERSION= 6.1.3-Next-Nexus-Alpha2-2 +GROOVY_VERSION= 4.0.16 +COMMONS_LANG_VERSION= 3.14.0 +COMMONS_TEXT_VERSION= 1.11.0 USE_GITHUB= yes GH_TUPLE= xbmc:xbmc:${DISTVERSION}-${KODI_CODENAME} \ @@ -71,20 +81,24 @@ USE_JAVA= yes JAVA_BUILD= jre USE_GNOME= libxml2 CMAKE_ARGS= -DGIT_VERSION="${DISTVERSION}-${KODI_CODENAME}" \ - -DLIBDVDCSS_URL="${DISTDIR}/xbmc-libdvdcss-${LIBDVDCSS_VERSION}_GH0.tar.gz" \ - -DLIBDVDNAV_URL="${DISTDIR}/xbmc-libdvdnav-${LIBDVDNAV_VERSION}_GH0.tar.gz" \ - -DLIBDVDREAD_URL="${DISTDIR}/xbmc-libdvdread-${LIBDVDREAD_VERSION}_GH0.tar.gz" \ - -DCROSSGUID_INCLUDE_DIR="${LOCALBASE}/include" -CMAKE_OFF= ENABLE_INTERNAL_CROSSGUID ENABLE_INTERNAL_RapidJSON + -DLIBDVDCSS_URL="${DISTDIR}/${PORTNAME}/xbmc-libdvdcss-${LIBDVDCSS_VERSION}_GH0.tar.gz" \ + -DLIBDVDNAV_URL="${DISTDIR}/${PORTNAME}/xbmc-libdvdnav-${LIBDVDNAV_VERSION}_GH0.tar.gz" \ + -DLIBDVDREAD_URL="${DISTDIR}/${PORTNAME}/xbmc-libdvdread-${LIBDVDREAD_VERSION}_GH0.tar.gz" \ + -Dgroovy_SOURCE_DIR="${WRKSRC}/tools/depends/share/groovy" \ + -Dapache-commons-lang_SOURCE_DIR="${WRKSRC}/tools/depends/share/java/lang" \ + -Dapache-commons-text_SOURCE_DIR="${WRKSRC}/tools/depends/share/java/text" \ + -DCROSSGUID_INCLUDE_DIR="${LOCALBASE}/include" \ + -DCORE_PLATFORM_NAME:STRING="${KODI_PLATFORM}" \ + -DCMAKE_VERBOSE_MAKEFILE=ON +CMAKE_OFF= ENABLE_INTERNAL_CROSSGUID CONFIGURE_ENV= _CPU_FEATURE="${CPU_FEATURE}" OPTIONS_SUB= yes -# Broken: BLUETOOTH OPTIONS_DEFINE= AIRPLAY AVAHI LIBBLURAY CEC DAV1D DBUS \ DVDCSS LCMS2 LIRC WEBSERVER MYSQL NFS DVD SMB TEST \ UDEV UPNP VAAPI VDPAU XSLT DOCS OPTIONS_DEFAULT= LIBBLURAY CEC LCMS2 WEBSERVER DAV1D \ - DVD UPNP VAAPI VDPAU XSLT WAYLAND X11 GL + DVD UPNP VAAPI VDPAU XSLT GBM WAYLAND X11 GL OPTIONS_DEFAULT_amd64= SSE SSE2 SSE3 SSSE3 SSE4_1 SSE4_2 OPTIONS_DEFAULT_i386= SSE SSE2 SSE3 OPTIONS_SINGLE= RENDER @@ -103,7 +117,6 @@ PLATFORM_DESC= Kodi platform FEATURE_DESC= X86 CPU feature AIRPLAY_DESC= AirPlay support -BLUETOOTH_DESC= Bluetooth support CEC_DESC= CEC adapter support DAV1D_DESC= Use dav1d as AV1 decoder DVD_DESC= DVD support @@ -132,9 +145,6 @@ AIRPLAY_CMAKE_BOOL= ENABLE_PLIST \ AVAHI_LIB_DEPENDS= libavahi-client.so:net/avahi-app AVAHI_CMAKE_BOOL= ENABLE_AVAHI -BLUETOOTH_CMAKE_BOOL= ENABLE_BLUETOOTH -BLUETOOTH_CMAKE_ON= -DBLUETOOTH_INCLUDE_DIR="${LOCALBASE}/include" - LIBBLURAY_LIB_DEPENDS= libbluray.so:multimedia/libbluray LIBBLURAY_CMAKE_BOOL= ENABLE_BLURAY @@ -177,6 +187,7 @@ UPNP_CMAKE_BOOL= ENABLE_UPNP VAAPI_LIB_DEPENDS= libva.so:multimedia/libva VAAPI_CMAKE_BOOL= ENABLE_VAAPI +VDPAU_IMPLIES= X11 GL VDPAU_LIB_DEPENDS= libvdpau.so:multimedia/libvdpau VDPAU_CMAKE_BOOL= ENABLE_VDPAU @@ -216,17 +227,18 @@ AVX_VARS= CPU_FEATURE+=AVX AVX2_VARS= CPU_FEATURE+=AVX2 GBM_IMPLIES= UDEV +GBM_VARS= KODI_PLATFORM+=gbm GBM_USES= gl GBM_USE= GL=egl,gbm,glu -GBM_CFLAGS= -I${LOCALBASE}/include/libepoll-shim -GBM_LDFLAGS= -L${LOCALBASE}/lib -lepoll-shim GBM_BUILD_DEPENDS= evdev-proto>0:devel/evdev-proto GBM_LIB_DEPENDS= libepoll-shim.so:devel/libepoll-shim \ libdrm.so:graphics/libdrm \ libxkbcommon.so:x11/libxkbcommon \ - libinput.so:x11/libinput + libinput.so:x11/libinput \ + libdisplay-info.so:sysutils/libdisplay-info GBM_RUN_DEPENDS= mesa-dri>0:graphics/mesa-dri +WAYLAND_VARS= KODI_PLATFORM+=wayland WAYLAND_CATEGORIES= wayland WAYLAND_USES= gl WAYLAND_USE= GL=egl,glu @@ -237,6 +249,7 @@ WAYLAND_LIB_DEPENDS= libdrm.so:graphics/libdrm \ libinput.so:x11/libinput \ libwayland-client++.so:graphics/waylandpp +X11_VARS= KODI_PLATFORM+=x11 X11_USES= xorg gl X11_USE= XORG=x11,xext,xrandr GL=egl,gbm,glu X11_LIB_DEPENDS= libdrm.so:graphics/libdrm @@ -247,22 +260,6 @@ X11_LIB_DEPENDS= libdrm.so:graphics/libdrm BROKEN= option GLES does not build with multiple PLATFORM .endif -.if !empty(PORT_OPTIONS:MGBM) && !empty(PORT_OPTIONS:MWAYLAND) && !empty(PORT_OPTIONS:MX11) -CMAKE_ARGS+= -DCORE_PLATFORM_NAME:STRING="gbm wayland x11" -.elif empty(PORT_OPTIONS:MGBM) && !empty(PORT_OPTIONS:MWAYLAND) && !empty(PORT_OPTIONS:MX11) -CMAKE_ARGS+= -DCORE_PLATFORM_NAME:STRING="wayland x11" -.elif !empty(PORT_OPTIONS:MGBM) && empty(PORT_OPTIONS:MWAYLAND) && !empty(PORT_OPTIONS:MX11) -CMAKE_ARGS+= -DCORE_PLATFORM_NAME:STRING="gbm x11" -.elif !empty(PORT_OPTIONS:MGBM) && !empty(PORT_OPTIONS:MWAYLAND) && empty(PORT_OPTIONS:MX11) -CMAKE_ARGS+= -DCORE_PLATFORM_NAME:STRING="gbm wayland" -.elif empty(PORT_OPTIONS:MGBM) && empty(PORT_OPTIONS:MWAYLAND) && !empty(PORT_OPTIONS:MX11) -CMAKE_ARGS+= -DCORE_PLATFORM_NAME:STRING="x11" -.elif empty(PORT_OPTIONS:MGBM) && !empty(PORT_OPTIONS:MWAYLAND) && empty(PORT_OPTIONS:MX11) -CMAKE_ARGS+= -DCORE_PLATFORM_NAME:STRING="wayland" -.elif !empty(PORT_OPTIONS:MGBM) && empty(PORT_OPTIONS:MWAYLAND) && empty(PORT_OPTIONS:MX11) -CMAKE_ARGS+= -DCORE_PLATFORM_NAME:STRING="gbm" -.endif - .if !empty(PORT_OPTIONS:MGBM) && !empty(PORT_OPTIONS:MWAYLAND) || !empty(PORT_OPTIONS:MGBM) && !empty(PORT_OPTIONS:MX11) || !empty(PORT_OPTIONS:MWAYLAND) && !empty(PORT_OPTIONS:MX11) PLIST_SUB+= KODICOMBINED="" \ KODIGBM="@comment " \ @@ -290,6 +287,14 @@ PLIST_SUB+= KODIX11="@comment " .endif .endif +post-extract: + @${MKDIR} ${WRKSRC}/tools/depends/share + @${MV} ${WRKDIR}/groovy-${GROOVY_VERSION} ${WRKSRC}/tools/depends/share/groovy + + @${MKDIR} ${WRKSRC}/tools/depends/share/java + @${MV} ${WRKDIR}/commons-lang3-${COMMONS_LANG_VERSION} ${WRKSRC}/tools/depends/share/java/lang + @${MV} ${WRKDIR}/commons-text-${COMMONS_TEXT_VERSION} ${WRKSRC}/tools/depends/share/java/text + post-patch: ${REINPLACE_CMD} 's|/usr/share|${LOCALBASE}/share|' \ ${WRKSRC}/xbmc/platform/linux/input/LibInputSettings.cpp @@ -297,7 +302,7 @@ post-patch: post-install: ${INSTALL_MAN} ${WRKSRC}/docs/manpages/kodi.bin.1 ${STAGEDIR}${PREFIX}/share/man/man1 cd ${STAGEDIR}${PREFIX}/share/man/man1 && ${LN} -s kodi.bin.1.gz kodi.1.gz - cd ${STAGEDIR}${PREFIX}/bin && ${STRIP_CMD} JsonSchemaBuilder kodi-TexturePacker + cd ${STAGEDIR}${PREFIX}/bin && ${STRIP_CMD} kodi-TexturePacker TexturePacker ${FIND} ${STAGEDIR}${PREFIX}/lib/kodi -type f -name '*.so' -print0 | ${XARGS} -0 ${STRIP_CMD} ${RM} -r ${STAGEDIR}${PREFIX}/lib/firewalld diff --git a/multimedia/kodi/distinfo b/multimedia/kodi/distinfo index 9962dfff28b0..da2b055758eb 100644 --- a/multimedia/kodi/distinfo +++ b/multimedia/kodi/distinfo @@ -1,9 +1,15 @@ -TIMESTAMP = 1709571779 -SHA256 (xbmc-xbmc-20.5-20.5-Nexus_GH0.tar.gz) = 9bf3257ebf251d20f276b7f90681985a270779150af2fb395d4b593c04002deb -SIZE (xbmc-xbmc-20.5-20.5-Nexus_GH0.tar.gz) = 54568445 -SHA256 (xbmc-libdvdcss-1.4.3-Next-Nexus-Alpha2-2_GH0.tar.gz) = f38c4a4e7a4f4da6d8e83b8852489aa3bb6588a915dc41f5ee89d9aad305a06e -SIZE (xbmc-libdvdcss-1.4.3-Next-Nexus-Alpha2-2_GH0.tar.gz) = 102124 -SHA256 (xbmc-libdvdnav-6.1.1-Next-Nexus-Alpha2-2_GH0.tar.gz) = 584f62a3896794408d46368e2ecf2c6217ab9c676ce85921b2d68b8961f49dfc -SIZE (xbmc-libdvdnav-6.1.1-Next-Nexus-Alpha2-2_GH0.tar.gz) = 128547 -SHA256 (xbmc-libdvdread-6.1.3-Next-Nexus-Alpha2-2_GH0.tar.gz) = 719130091e3adc9725ba72df808f24a14737a009dca5a4c38c601c0c76449b62 -SIZE (xbmc-libdvdread-6.1.3-Next-Nexus-Alpha2-2_GH0.tar.gz) = 110513 +TIMESTAMP = 1712510398 +SHA256 (kodi/apache-groovy-binary-4.0.16.zip) = b8c3bec88a3f5a62235d9429a97e371032bf7216f3e28724823a9169dd10befc +SIZE (kodi/apache-groovy-binary-4.0.16.zip) = 29793704 +SHA256 (kodi/commons-lang3-3.14.0-bin.tar.gz) = 317c3e3fcd5fcca3781a7996ff1e0c50c13244ee961e94e5f6f6d84b84733b16 +SIZE (kodi/commons-lang3-3.14.0-bin.tar.gz) = 9442785 +SHA256 (kodi/commons-text-1.11.0-bin.tar.gz) = 4169cb90571fb28fad4c5eea7c1c994c18f1995452f73e8ea7a86087c0e3822e +SIZE (kodi/commons-text-1.11.0-bin.tar.gz) = 3018564 +SHA256 (kodi/xbmc-xbmc-21.0-21.0-Omega_GH0.tar.gz) = 7f54c1fd8456ac46221fbc85e447362bdc209163c6cb19fca98d106560071b7c +SIZE (kodi/xbmc-xbmc-21.0-21.0-Omega_GH0.tar.gz) = 40987733 +SHA256 (kodi/xbmc-libdvdcss-1.4.3-Next-Nexus-Alpha2-2_GH0.tar.gz) = f38c4a4e7a4f4da6d8e83b8852489aa3bb6588a915dc41f5ee89d9aad305a06e +SIZE (kodi/xbmc-libdvdcss-1.4.3-Next-Nexus-Alpha2-2_GH0.tar.gz) = 102124 +SHA256 (kodi/xbmc-libdvdnav-6.1.1-Next-Nexus-Alpha2-2_GH0.tar.gz) = 584f62a3896794408d46368e2ecf2c6217ab9c676ce85921b2d68b8961f49dfc +SIZE (kodi/xbmc-libdvdnav-6.1.1-Next-Nexus-Alpha2-2_GH0.tar.gz) = 128547 +SHA256 (kodi/xbmc-libdvdread-6.1.3-Next-Nexus-Alpha2-2_GH0.tar.gz) = 719130091e3adc9725ba72df808f24a14737a009dca5a4c38c601c0c76449b62 +SIZE (kodi/xbmc-libdvdread-6.1.3-Next-Nexus-Alpha2-2_GH0.tar.gz) = 110513 diff --git a/multimedia/kodi/files/patch-cmake_modules_FindCrossGUID.cmake b/multimedia/kodi/files/patch-cmake_modules_FindCrossGUID.cmake index 4fd05dca7c94..9abea5170820 100644 --- a/multimedia/kodi/files/patch-cmake_modules_FindCrossGUID.cmake +++ b/multimedia/kodi/files/patch-cmake_modules_FindCrossGUID.cmake @@ -1,29 +1,20 @@ ---- cmake/modules/FindCrossGUID.cmake.orig 2022-07-08 10:04:52 UTC +--- cmake/modules/FindCrossGUID.cmake.orig 2024-03-04 21:39:38 UTC +++ cmake/modules/FindCrossGUID.cmake -@@ -45,7 +45,7 @@ else() - endif() +@@ -45,7 +45,7 @@ if(NOT TARGET CrossGUID::CrossGUID) + set(CROSSGUID_VERSION ${PC_CROSSGUID_VERSION}) + endif() - if(CROSSGUID_FOUND) - find_path(CROSSGUID_INCLUDE_DIR NAMES crossguid/guid.hpp guid.h + find_path(CROSSGUID_INCLUDE_DIR NAMES guid.hpp guid.h - PATHS ${PC_CROSSGUID_INCLUDEDIR}) - - find_library(CROSSGUID_LIBRARY_RELEASE NAMES crossguid -@@ -53,7 +53,7 @@ else() - find_library(CROSSGUID_LIBRARY_DEBUG NAMES crossguidd crossguid-dgb - PATHS ${PC_CROSSGUID_LIBDIR}) - else() -- find_path(CROSSGUID_INCLUDE_DIR NAMES crossguid/guid.hpp guid.h) -+ find_path(CROSSGUID_INCLUDE_DIR NAMES guid.hpp guid.h) - find_library(CROSSGUID_LIBRARY_RELEASE NAMES crossguid) - find_library(CROSSGUID_LIBRARY_DEBUG NAMES crossguidd) - endif() -@@ -73,7 +73,7 @@ if(CROSSGUID_FOUND) - set(CROSSGUID_INCLUDE_DIRS ${CROSSGUID_INCLUDE_DIR}) + HINTS ${DEPENDS_PATH}/include ${PC_CROSSGUID_INCLUDEDIR} + ${${CORE_PLATFORM_LC}_SEARCH_CONFIG} + NO_CACHE) +@@ -59,7 +59,7 @@ if(NOT TARGET CrossGUID::CrossGUID) + NO_CACHE) - # NEW_CROSSGUID >= 0.2.0 release -- if(EXISTS "${CROSSGUID_INCLUDE_DIR}/crossguid/guid.hpp") -+ if(EXISTS "${CROSSGUID_INCLUDE_DIR}/guid.hpp") - list(APPEND CROSSGUID_DEFINITIONS -DHAVE_NEW_CROSSGUID) + # NEW_CROSSGUID >= 0.2.0 release +- if(EXISTS "${CROSSGUID_INCLUDE_DIR}/crossguid/guid.hpp") ++ if(EXISTS "${CROSSGUID_INCLUDE_DIR}/guid.hpp") + list(APPEND _crossguid_definitions HAVE_NEW_CROSSGUID) + endif() endif() - diff --git a/multimedia/kodi/files/patch-cmake_modules_FindLibDvdCSS.cmake b/multimedia/kodi/files/patch-cmake_modules_FindLibDvdCSS.cmake deleted file mode 100644 index 450c48a9ed4d..000000000000 --- a/multimedia/kodi/files/patch-cmake_modules_FindLibDvdCSS.cmake +++ /dev/null @@ -1,11 +0,0 @@ ---- cmake/modules/FindLibDvdCSS.cmake.orig 2022-08-18 23:36:30 UTC -+++ cmake/modules/FindLibDvdCSS.cmake -@@ -63,7 +63,7 @@ if(ENABLE_DVDCSS) - ${LIBDVD_ADDITIONAL_ARGS}) - else() - find_program(AUTORECONF autoreconf REQUIRED) -- find_program(MAKE_EXECUTABLE make REQUIRED) -+ find_program(MAKE_EXECUTABLE gmake REQUIRED) - - set(CONFIGURE_COMMAND ${AUTORECONF} -vif - COMMAND ac_cv_path_GIT= ./configure diff --git a/multimedia/kodi/files/patch-cmake_modules_FindLibDvdNav.cmake b/multimedia/kodi/files/patch-cmake_modules_FindLibDvdNav.cmake deleted file mode 100644 index c8efbe69cbc6..000000000000 --- a/multimedia/kodi/files/patch-cmake_modules_FindLibDvdNav.cmake +++ /dev/null @@ -1,11 +0,0 @@ ---- cmake/modules/FindLibDvdNav.cmake.orig 2022-08-18 23:36:26 UTC -+++ cmake/modules/FindLibDvdNav.cmake -@@ -76,7 +76,7 @@ if(NOT TARGET LibDvdNav::LibDvdNav) - string(APPEND LIBDVDNAV_CFLAGS " -I$<TARGET_PROPERTY:LibDvdRead::LibDvdRead,INTERFACE_INCLUDE_DIRECTORIES> $<TARGET_PROPERTY:LibDvdRead::LibDvdRead,INTERFACE_COMPILE_DEFINITIONS>") - - find_program(AUTORECONF autoreconf REQUIRED) -- find_program(MAKE_EXECUTABLE make REQUIRED) -+ find_program(MAKE_EXECUTABLE gmake REQUIRED) - - set(CONFIGURE_COMMAND ${AUTORECONF} -vif - COMMAND ac_cv_path_GIT= ./configure diff --git a/multimedia/kodi/files/patch-cmake_modules_FindLibDvdRead.cmake b/multimedia/kodi/files/patch-cmake_modules_FindLibDvdRead.cmake deleted file mode 100644 index 44208f126053..000000000000 --- a/multimedia/kodi/files/patch-cmake_modules_FindLibDvdRead.cmake +++ /dev/null @@ -1,11 +0,0 @@ ---- cmake/modules/FindLibDvdRead.cmake.orig 2022-08-18 23:36:34 UTC -+++ cmake/modules/FindLibDvdRead.cmake -@@ -81,7 +81,7 @@ if(NOT TARGET LibDvdRead::LibDvdRead) - endif() - - find_program(AUTORECONF autoreconf REQUIRED) -- find_program(MAKE_EXECUTABLE make REQUIRED) -+ find_program(MAKE_EXECUTABLE gmake REQUIRED) - - set(CONFIGURE_COMMAND ${AUTORECONF} -vif - COMMAND ac_cv_path_GIT= ./configure diff --git a/multimedia/kodi/files/patch-ffmpeg6-support b/multimedia/kodi/files/patch-ffmpeg6-support deleted file mode 100644 index f337f73931b2..000000000000 --- a/multimedia/kodi/files/patch-ffmpeg6-support +++ /dev/null @@ -1,2155 +0,0 @@ -diff -urN cmake/modules/FindFFMPEG.cmake.orig cmake/modules/FindFFMPEG.cmake ---- cmake/modules/FindFFMPEG.cmake.orig 2023-03-11 22:16:38.000000000 +0000 -+++ cmake/modules/FindFFMPEG.cmake 2023-04-19 10:01:30.831589000 +0000 -@@ -151,14 +151,14 @@ - set(REQUIRED_FFMPEG_VERSION undef) - else() - # required ffmpeg library versions -- set(REQUIRED_FFMPEG_VERSION 4.4.1) -- set(_avcodec_ver ">=58.134.100") -- set(_avfilter_ver ">=7.110.100") -- set(_avformat_ver ">=58.76.100") -- set(_avutil_ver ">=56.70.100") -- set(_postproc_ver ">=55.9.100") -- set(_swresample_ver ">=3.9.100") -- set(_swscale_ver ">=5.9.100") -+ set(REQUIRED_FFMPEG_VERSION 6.0.0) -+ set(_avcodec_ver ">=60.2.100") -+ set(_avfilter_ver ">=9.3.100") -+ set(_avformat_ver ">=60.3.100") -+ set(_avutil_ver ">=58.2.100") -+ set(_postproc_ver ">=57.1.100") -+ set(_swresample_ver ">=4.10.100") -+ set(_swscale_ver ">=7.1.100") - endif() - - # Allows building with external ffmpeg not found in system paths, -diff -urN tools/buildsteps/windows/patches/0001-ffmpeg-windows-configure-detect-openssl.patch.orig tools/buildsteps/windows/patches/0001-ffmpeg-windows-configure-detect-openssl.patch ---- tools/buildsteps/windows/patches/0001-ffmpeg-windows-configure-detect-openssl.patch.orig 2023-03-11 22:16:38.000000000 +0000 -+++ tools/buildsteps/windows/patches/0001-ffmpeg-windows-configure-detect-openssl.patch 2023-04-19 10:01:22.854832000 +0000 -@@ -11,7 +11,7 @@ - index d7a3f507e8..4b85e881b1 100755 - --- a/configure - +++ b/configure --@@ -6530,6 +6530,8 @@ enabled openssl && { check_pkg_config openssl openssl openssl/ssl.h OP -+@@ -6728,6 +6728,8 @@ enabled openssl && { check_pkg_config openssl openssl openssl/ssl.h OP - check_lib openssl openssl/ssl.h SSL_library_init -lssl -lcrypto || - check_lib openssl openssl/ssl.h SSL_library_init -lssl32 -leay32 || - check_lib openssl openssl/ssl.h SSL_library_init -lssl -lcrypto -lws2_32 -lgdi32 || -diff -urN tools/buildsteps/windows/patches/0002-ffmpeg-windows-configure-fix-zlib-conflict.patch.orig tools/buildsteps/windows/patches/0002-ffmpeg-windows-configure-fix-zlib-conflict.patch ---- tools/buildsteps/windows/patches/0002-ffmpeg-windows-configure-fix-zlib-conflict.patch.orig 2023-03-11 22:16:38.000000000 +0000 -+++ tools/buildsteps/windows/patches/0002-ffmpeg-windows-configure-fix-zlib-conflict.patch 2023-04-19 10:01:22.854952000 +0000 -@@ -11,16 +11,16 @@ - index 4b85e881b1..da457705d1 100755 - --- a/configure - +++ b/configure --@@ -7627,6 +7627,9 @@ print_config CONFIG_ "$config_files" $CONFIG_LIST \ -+@@ -7825,6 +7825,9 @@ print_config CONFIG_ "$config_files" $CONFIG_LIST \ -+ print_config CONFIG_ "$config_files" $CONFIG_LIST \ - $CONFIG_EXTRA \ -- $ALL_COMPONENTS \ - - +echo "#if defined(HAVE_UNISTD_H) && HAVE_UNISTD_H == 0" >> $TMPH - +echo "#undef HAVE_UNISTD_H" >> $TMPH - +echo "#endif" >> $TMPH - echo "#endif /* FFMPEG_CONFIG_H */" >> $TMPH -- echo "endif # FFMPEG_CONFIG_MAK" >> ffbuild/config.mak - -+ # Do not overwrite an unchanged config.h to avoid superfluous rebuilds. - -- - 2.29.2 - -diff -urN tools/buildsteps/windows/patches/0003-ffmpeg-windows-configure-allow-building-static.patch.orig tools/buildsteps/windows/patches/0003-ffmpeg-windows-configure-allow-building-static.patch ---- tools/buildsteps/windows/patches/0003-ffmpeg-windows-configure-allow-building-static.patch.orig 2023-03-11 22:16:38.000000000 +0000 -+++ tools/buildsteps/windows/patches/0003-ffmpeg-windows-configure-allow-building-static.patch 2023-04-19 10:01:22.855081000 +0000 -@@ -11,7 +11,7 @@ - index da457705d1..e3a8f45ff4 100755 - --- a/configure - +++ b/configure --@@ -5440,6 +5440,8 @@ case $target_os in -+@@ -5566,6 +5566,8 @@ case $target_os in - enabled shared && ! enabled small && test_cmd $windres --version && enable gnu_windres - enabled x86_32 && check_ldflags -Wl,--large-address-aware - shlibdir_default="$bindir_default" -@@ -20,7 +20,7 @@ - SLIBPREF="" - SLIBSUF=".dll" - SLIBNAME_WITH_VERSION='$(SLIBPREF)$(FULLNAME)-$(LIBVERSION)$(SLIBSUF)' --@@ -5489,6 +5491,8 @@ case $target_os in -+@@ -5615,6 +5617,8 @@ case $target_os in - fi - enabled x86_32 && check_ldflags -LARGEADDRESSAWARE - shlibdir_default="$bindir_default" -diff -urN tools/buildsteps/windows/patches/0004-ffmpeg-windows-configure-detect-libdav1d.patch.orig tools/buildsteps/windows/patches/0004-ffmpeg-windows-configure-detect-libdav1d.patch ---- tools/buildsteps/windows/patches/0004-ffmpeg-windows-configure-detect-libdav1d.patch.orig 2023-03-11 22:16:38.000000000 +0000 -+++ tools/buildsteps/windows/patches/0004-ffmpeg-windows-configure-detect-libdav1d.patch 2023-04-19 10:01:22.855205000 +0000 -@@ -11,7 +11,7 @@ - index e3a8f45ff4..983d7e1078 100755 - --- a/configure - +++ b/configure --@@ -6358,7 +6358,7 @@ enabled libcelt && require libcelt celt/celt.h celt_decode -lcelt0 && -+@@ -6541,7 +6541,7 @@ enabled libcelt && require libcelt celt/celt.h celt_decode -lcelt0 && - die "ERROR: libcelt must be installed and version must be >= 0.11.0."; } - enabled libcaca && require_pkg_config libcaca caca caca.h caca_create_canvas - enabled libcodec2 && require libcodec2 codec2/codec2.h codec2_create -lcodec2 -diff -urN tools/depends/target/ffmpeg/CMakeLists.txt.orig tools/depends/target/ffmpeg/CMakeLists.txt ---- tools/depends/target/ffmpeg/CMakeLists.txt.orig 2023-03-11 22:16:38.000000000 +0000 -+++ tools/depends/target/ffmpeg/CMakeLists.txt 2023-04-19 10:01:22.854687000 +0000 -@@ -92,6 +92,7 @@ - elseif(CORE_SYSTEM_NAME STREQUAL darwin_embedded) - list(APPEND ffmpeg_conf --disable-crystalhd - --enable-videotoolbox -+ --disable-filter=yadif_videotoolbox - --target-os=darwin - ) - elseif(CORE_SYSTEM_NAME STREQUAL osx) -diff -urN tools/depends/target/ffmpeg/FFMPEG-VERSION.orig tools/depends/target/ffmpeg/FFMPEG-VERSION ---- tools/depends/target/ffmpeg/FFMPEG-VERSION.orig 2023-03-11 22:16:38.000000000 +0000 -+++ tools/depends/target/ffmpeg/FFMPEG-VERSION 2023-04-19 10:02:41.108169000 +0000 -@@ -1,5 +1,5 @@ - LIBNAME=ffmpeg --BASE_URL=https://github.com/xbmc/FFmpeg --VERSION=4.4.1-Nexus-Alpha1 -+VERSION=6.0 - ARCHIVE=$(LIBNAME)-$(VERSION).tar.gz --SHA512=8beb04d577b5251e74b0d52f4d130997a8ba94bbd488c7c8309e6b45095c27807e150212888ce3a384b23dff52f8df1a7bde5407bae924ddc363f8125c0616c5 -+SHA512=b3214328f2792364353f38c6b46a71d4970c071d8656b20780abf0e02950167d0933eae825c09102cf8fb19fc679ac444bf1f41a448b624eaa5ea6b0f0bdf4f5 -+ -diff -urN xbmc/cdrip/EncoderFFmpeg.cpp.orig xbmc/cdrip/EncoderFFmpeg.cpp ---- xbmc/cdrip/EncoderFFmpeg.cpp.orig 2023-03-11 22:16:38.000000000 +0000 -+++ xbmc/cdrip/EncoderFFmpeg.cpp 2023-04-19 10:01:22.848595000 +0000 -@@ -11,6 +11,7 @@ - #include "ServiceBroker.h" - #include "addons/Addon.h" - #include "addons/AddonManager.h" -+#include "cores/FFmpeg.h" - #include "settings/Settings.h" - #include "settings/SettingsComponent.h" - #include "utils/StringUtils.h" -@@ -19,24 +20,9 @@ - #include "utils/log.h" - - using namespace KODI::CDRIP; -+using FFMPEG_HELP_TOOLS::FFMpegErrorToString; -+using FFMPEG_HELP_TOOLS::FFMpegException; - --namespace --{ -- --struct EncoderException : public std::exception --{ -- std::string s; -- template<typename... Args> -- EncoderException(const std::string& fmt, Args&&... args) -- : s(StringUtils::Format(fmt, std::forward<Args>(args)...)) -- { -- } -- ~EncoderException() throw() {} // Updated -- const char* what() const throw() { return s.c_str(); } --}; -- --} /* namespace */ -- - bool CEncoderFFmpeg::Init() - { - try -@@ -54,7 +40,7 @@ - } - else - { -- throw EncoderException("Could not get add-on: {}", addonId); -+ throw FFMpegException("Could not get add-on: {}", addonId); - } - - // Hack fix about PTS on generated files. -@@ -66,50 +52,50 @@ - else if (addonId == "audioencoder.kodi.builtin.wma") - m_samplesCountMultiply = 1000; - else -- throw EncoderException("Internal add-on id \"{}\" not known as usable", addonId); -+ throw FFMpegException("Internal add-on id \"{}\" not known as usable", addonId); - - const std::string filename = URIUtils::GetFileName(m_strFile); - - m_formatCtx = avformat_alloc_context(); - if (!m_formatCtx) -- throw EncoderException("Could not allocate output format context"); -+ throw FFMpegException("Could not allocate output format context"); - - m_bcBuffer = static_cast<uint8_t*>(av_malloc(BUFFER_SIZE + AV_INPUT_BUFFER_PADDING_SIZE)); - if (!m_bcBuffer) -- throw EncoderException("Could not allocate buffer"); -+ throw FFMpegException("Could not allocate buffer"); - - m_formatCtx->pb = avio_alloc_context(m_bcBuffer, BUFFER_SIZE, AVIO_FLAG_WRITE, this, nullptr, - avio_write_callback, avio_seek_callback); - if (!m_formatCtx->pb) -- throw EncoderException("Failed to allocate ByteIOContext"); -+ throw FFMpegException("Failed to allocate ByteIOContext"); - - /* Guess the desired container format based on the file extension. */ - m_formatCtx->oformat = av_guess_format(nullptr, filename.c_str(), nullptr); - if (!m_formatCtx->oformat) -- throw EncoderException("Could not find output file format"); -+ throw FFMpegException("Could not find output file format"); - - m_formatCtx->url = av_strdup(filename.c_str()); - if (!m_formatCtx->url) -- throw EncoderException("Could not allocate url"); -+ throw FFMpegException("Could not allocate url"); - - /* Find the encoder to be used by its name. */ -- AVCodec* codec = avcodec_find_encoder(m_formatCtx->oformat->audio_codec); -+ const AVCodec* codec = avcodec_find_encoder(m_formatCtx->oformat->audio_codec); - if (!codec) -- throw EncoderException("Unable to find a suitable FFmpeg encoder"); -+ throw FFMpegException("Unable to find a suitable FFmpeg encoder"); - - /* Create a new audio stream in the output file container. */ - m_stream = avformat_new_stream(m_formatCtx, nullptr); - if (!m_stream) -- throw EncoderException("Failed to allocate AVStream context"); -+ throw FFMpegException("Failed to allocate AVStream context"); - - m_codecCtx = avcodec_alloc_context3(codec); - if (!m_codecCtx) -- throw EncoderException("Failed to allocate the encoder context"); -+ throw FFMpegException("Failed to allocate the encoder context"); - - /* Set the basic encoder parameters. - * The input file's sample rate is used to avoid a sample rate conversion. */ -- m_codecCtx->channels = m_iInChannels; -- m_codecCtx->channel_layout = av_get_default_channel_layout(m_iInChannels); -+ av_channel_layout_uninit(&m_codecCtx->ch_layout); -+ av_channel_layout_default(&m_codecCtx->ch_layout, m_iInChannels); - m_codecCtx->sample_rate = m_iInSampleRate; - m_codecCtx->sample_fmt = codec->sample_fmts[0]; - m_codecCtx->bit_rate = bitrate; -@@ -128,14 +114,14 @@ - - int err = avcodec_open2(m_codecCtx, codec, nullptr); - if (err < 0) -- throw EncoderException("Failed to open the codec {} (error '{}')", -- codec->long_name ? codec->long_name : codec->name, -- FFmpegErrorToString(err)); -+ throw FFMpegException("Failed to open the codec {} (error '{}')", -+ codec->long_name ? codec->long_name : codec->name, -+ FFMpegErrorToString(err)); - - err = avcodec_parameters_from_context(m_stream->codecpar, m_codecCtx); - if (err < 0) -- throw EncoderException("Failed to copy encoder parameters to output stream (error '{}')", -- FFmpegErrorToString(err)); -+ throw FFMpegException("Failed to copy encoder parameters to output stream (error '{}')", -+ FFMpegErrorToString(err)); - - m_inFormat = GetInputFormat(m_iInBitsPerSample); - m_outFormat = m_codecCtx->sample_fmt; -@@ -150,44 +136,48 @@ - - m_bufferFrame = av_frame_alloc(); - if (!m_bufferFrame || !m_buffer) -- throw EncoderException("Failed to allocate necessary buffers"); -+ throw FFMpegException("Failed to allocate necessary buffers"); - - m_bufferFrame->nb_samples = m_codecCtx->frame_size; - m_bufferFrame->format = m_inFormat; -- m_bufferFrame->channel_layout = m_codecCtx->channel_layout; -+ -+ av_channel_layout_uninit(&m_bufferFrame->ch_layout); -+ av_channel_layout_copy(&m_bufferFrame->ch_layout, &m_codecCtx->ch_layout); -+ - m_bufferFrame->sample_rate = m_codecCtx->sample_rate; - - err = av_frame_get_buffer(m_bufferFrame, 0); - if (err < 0) -- throw EncoderException("Could not allocate output frame samples (error '{}')", -- FFmpegErrorToString(err)); -+ throw FFMpegException("Could not allocate output frame samples (error '{}')", -+ FFMpegErrorToString(err)); - - avcodec_fill_audio_frame(m_bufferFrame, m_iInChannels, m_inFormat, m_buffer, m_neededBytes, 0); - - if (m_needConversion) - { -- m_swrCtx = swr_alloc_set_opts(nullptr, m_codecCtx->channel_layout, m_outFormat, -- m_codecCtx->sample_rate, m_codecCtx->channel_layout, m_inFormat, -+ int ret = swr_alloc_set_opts2(&m_swrCtx, &m_codecCtx->ch_layout, m_outFormat, -+ m_codecCtx->sample_rate, &m_codecCtx->ch_layout, m_inFormat, - m_codecCtx->sample_rate, 0, nullptr); -- if (!m_swrCtx || swr_init(m_swrCtx) < 0) -- throw EncoderException("Failed to initialize the resampler"); -+ if (ret || swr_init(m_swrCtx) < 0) -+ throw FFMpegException("Failed to initialize the resampler"); - - m_resampledBufferSize = - av_samples_get_buffer_size(nullptr, m_iInChannels, m_neededFrames, m_outFormat, 0); - m_resampledBuffer = static_cast<uint8_t*>(av_malloc(m_resampledBufferSize)); - m_resampledFrame = av_frame_alloc(); - if (!m_resampledBuffer || !m_resampledFrame) -- throw EncoderException("Failed to allocate a frame for resampling"); -+ throw FFMpegException("Failed to allocate a frame for resampling"); - - m_resampledFrame->nb_samples = m_neededFrames; - m_resampledFrame->format = m_outFormat; -- m_resampledFrame->channel_layout = m_codecCtx->channel_layout; -+ av_channel_layout_uninit(&m_resampledFrame->ch_layout); -+ av_channel_layout_copy(&m_resampledFrame->ch_layout, &m_codecCtx->ch_layout); - m_resampledFrame->sample_rate = m_codecCtx->sample_rate; - - err = av_frame_get_buffer(m_resampledFrame, 0); - if (err < 0) -- throw EncoderException("Could not allocate output resample frame samples (error '{}')", -- FFmpegErrorToString(err)); -+ throw FFMpegException("Could not allocate output resample frame samples (error '{}')", -+ FFMpegErrorToString(err)); - - avcodec_fill_audio_frame(m_resampledFrame, m_iInChannels, m_outFormat, m_resampledBuffer, - m_resampledBufferSize, 0); -@@ -204,7 +194,7 @@ - /* write the header */ - err = avformat_write_header(m_formatCtx, nullptr); - if (err != 0) -- throw EncoderException("Failed to write the header (error '{}')", FFmpegErrorToString(err)); -+ throw FFMpegException("Failed to write the header (error '{}')", FFMpegErrorToString(err)); - - CLog::Log(LOGDEBUG, "CEncoderFFmpeg::{} - Successfully initialized with muxer {} and codec {}", - __func__, -@@ -212,16 +202,19 @@ - : m_formatCtx->oformat->name, - codec->long_name ? codec->long_name : codec->name); - } -- catch (EncoderException& caught) -+ catch (const FFMpegException& caught) - { - CLog::Log(LOGERROR, "CEncoderFFmpeg::{} - {}", __func__, caught.what()); - - av_freep(&m_buffer); -+ av_channel_layout_uninit(&m_bufferFrame->ch_layout); - av_frame_free(&m_bufferFrame); - swr_free(&m_swrCtx); -+ av_channel_layout_uninit(&m_resampledFrame->ch_layout); - av_frame_free(&m_resampledFrame); - av_freep(&m_resampledBuffer); - av_free(m_bcBuffer); -+ av_channel_layout_uninit(&m_codecCtx->ch_layout); - avcodec_free_context(&m_codecCtx); - if (m_formatCtx) - { -@@ -299,7 +292,7 @@ - if (swr_convert(m_swrCtx, m_resampledFrame->data, m_neededFrames, - const_cast<const uint8_t**>(m_bufferFrame->extended_data), - m_neededFrames) < 0) -- throw EncoderException("Error resampling audio"); -+ throw FFMpegException("Error resampling audio"); - - frame = m_resampledFrame; - } -@@ -316,8 +309,8 @@ - m_bufferSize = 0; - err = avcodec_send_frame(m_codecCtx, frame); - if (err < 0) -- throw EncoderException("Error sending a frame for encoding (error '{}')", __func__, -- FFmpegErrorToString(err)); -+ throw FFMpegException("Error sending a frame for encoding (error '{}')", -+ FFMpegErrorToString(err)); - - while (err >= 0) - { -@@ -329,19 +322,18 @@ - } - else if (err < 0) - { -- throw EncoderException("Error during encoding (error '{}')", __func__, -- FFmpegErrorToString(err)); -+ throw FFMpegException("Error during encoding (error '{}')", FFMpegErrorToString(err)); - } - - err = av_write_frame(m_formatCtx, pkt); - if (err < 0) -- throw EncoderException("Failed to write the frame data (error '{}')", __func__, -- FFmpegErrorToString(err)); -+ throw FFMpegException("Failed to write the frame data (error '{}')", -+ FFMpegErrorToString(err)); - - av_packet_unref(pkt); - } - } -- catch (EncoderException& caught) -+ catch (const FFMpegException& caught) - { - CLog::Log(LOGERROR, "CEncoderFFmpeg::{} - {}", __func__, caught.what()); - } -@@ -366,8 +358,10 @@ - - /* Flush if needed */ - av_freep(&m_buffer); -+ av_channel_layout_uninit(&m_bufferFrame->ch_layout); - av_frame_free(&m_bufferFrame); - swr_free(&m_swrCtx); -+ av_channel_layout_uninit(&m_resampledFrame->ch_layout); - av_frame_free(&m_resampledFrame); - av_freep(&m_resampledBuffer); - m_needConversion = false; -@@ -379,6 +373,7 @@ - - /* cleanup */ - av_free(m_bcBuffer); -+ av_channel_layout_uninit(&m_codecCtx->ch_layout); - avcodec_free_context(&m_codecCtx); - av_freep(&m_formatCtx->pb); - avformat_free_context(m_formatCtx); -@@ -400,14 +395,6 @@ - case 32: - return AV_SAMPLE_FMT_S32; - default: -- throw EncoderException("Invalid input bits per sample"); -+ throw FFMpegException("Invalid input bits per sample"); - } --} -- --std::string CEncoderFFmpeg::FFmpegErrorToString(int err) --{ -- std::string text; -- text.reserve(AV_ERROR_MAX_STRING_SIZE); -- av_strerror(err, text.data(), AV_ERROR_MAX_STRING_SIZE); -- return text; - } -diff -urN xbmc/cdrip/EncoderFFmpeg.h.orig xbmc/cdrip/EncoderFFmpeg.h ---- xbmc/cdrip/EncoderFFmpeg.h.orig 2023-03-11 22:16:38.000000000 +0000 -+++ xbmc/cdrip/EncoderFFmpeg.h 2023-04-19 10:01:22.835616000 +0000 -@@ -39,7 +39,6 @@ - void SetTag(const std::string& tag, const std::string& value); - bool WriteFrame(); - AVSampleFormat GetInputFormat(int inBitsPerSample); -- std::string FFmpegErrorToString(int err); - - AVFormatContext* m_formatCtx{nullptr}; - AVCodecContext* m_codecCtx{nullptr}; -diff -urN xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp.orig xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp ---- xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp.orig 2023-03-11 22:16:38.000000000 +0000 -+++ xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp 2023-04-19 10:01:22.848879000 +0000 -@@ -10,14 +10,25 @@ - #define DTS_ENCODE_BITRATE 1411200 - - #include "cores/AudioEngine/Encoders/AEEncoderFFmpeg.h" --#include "cores/AudioEngine/Utils/AEUtil.h" -+ - #include "ServiceBroker.h" --#include "utils/log.h" -+#include "cores/AudioEngine/Utils/AEUtil.h" -+#include "cores/FFmpeg.h" - #include "settings/Settings.h" - #include "settings/SettingsComponent.h" --#include <string.h> -+#include "utils/log.h" -+ -+extern "C" -+{ -+#include <libavutil/channel_layout.h> -+} -+ - #include <cassert> -+#include <string.h> - -+using FFMPEG_HELP_TOOLS::FFMpegErrorToString; -+using FFMPEG_HELP_TOOLS::FFMpegException; -+ - CAEEncoderFFmpeg::CAEEncoderFFmpeg() : m_CodecCtx(NULL), m_SwrCtx(NULL) - { - } -@@ -26,6 +37,7 @@ - { - Reset(); - swr_free(&m_SwrCtx); -+ av_channel_layout_uninit(&m_CodecCtx->ch_layout); - avcodec_free_context(&m_CodecCtx); - } - -@@ -81,7 +93,7 @@ - - bool ac3 = CServiceBroker::GetSettingsComponent()->GetSettings()->GetBool(CSettings::SETTING_AUDIOOUTPUT_AC3PASSTHROUGH); - -- AVCodec *codec = NULL; -+ const AVCodec* codec = nullptr; - - /* fallback to ac3 if we support it, we might not have DTS support */ - if (ac3) -@@ -102,7 +114,8 @@ - - m_CodecCtx->bit_rate = m_BitRate; - m_CodecCtx->sample_rate = format.m_sampleRate; -- m_CodecCtx->channel_layout = AV_CH_LAYOUT_5POINT1_BACK; -+ av_channel_layout_uninit(&m_CodecCtx->ch_layout); -+ av_channel_layout_from_mask(&m_CodecCtx->ch_layout, AV_CH_LAYOUT_5POINT1_BACK); - - /* select a suitable data format */ - if (codec->sample_fmts) -@@ -179,22 +192,28 @@ - LOGERROR, - "CAEEncoderFFmpeg::Initialize - Unable to find a suitable data format for the codec ({})", - m_CodecName); -+ av_channel_layout_uninit(&m_CodecCtx->ch_layout); - avcodec_free_context(&m_CodecCtx); - return false; - } - } - -- m_CodecCtx->channels = BuildChannelLayout(m_CodecCtx->channel_layout, m_Layout); -+ uint64_t mask = m_CodecCtx->ch_layout.u.mask; -+ av_channel_layout_uninit(&m_CodecCtx->ch_layout); -+ av_channel_layout_from_mask(&m_CodecCtx->ch_layout, mask); -+ m_CodecCtx->ch_layout.nb_channels = BuildChannelLayout(mask, m_Layout); - - /* open the codec */ - if (avcodec_open2(m_CodecCtx, codec, NULL)) - { -+ av_channel_layout_uninit(&m_CodecCtx->ch_layout); - avcodec_free_context(&m_CodecCtx); - return false; - } - - format.m_frames = m_CodecCtx->frame_size; -- format.m_frameSize = m_CodecCtx->channels * (CAEUtil::DataFormatToBits(format.m_dataFormat) >> 3); -+ int channels = m_CodecCtx->ch_layout.nb_channels; -+ format.m_frameSize = channels * (CAEUtil::DataFormatToBits(format.m_dataFormat) >> 3); - format.m_channelLayout = m_Layout; - - m_CurrentFormat = format; -@@ -204,14 +223,14 @@ - - if (m_NeedConversion) - { -- m_SwrCtx = swr_alloc_set_opts(NULL, -- m_CodecCtx->channel_layout, m_CodecCtx->sample_fmt, m_CodecCtx->sample_rate, -- m_CodecCtx->channel_layout, AV_SAMPLE_FMT_FLT, m_CodecCtx->sample_rate, -- 0, NULL); -- if (!m_SwrCtx || swr_init(m_SwrCtx) < 0) -+ int ret = swr_alloc_set_opts2(&m_SwrCtx, &m_CodecCtx->ch_layout, m_CodecCtx->sample_fmt, -+ m_CodecCtx->sample_rate, &m_CodecCtx->ch_layout, -+ AV_SAMPLE_FMT_FLT, m_CodecCtx->sample_rate, 0, NULL); -+ if (ret || swr_init(m_SwrCtx) < 0) - { - CLog::Log(LOGERROR, "CAEEncoderFFmpeg::Initialize - Failed to initialise resampler."); - swr_free(&m_SwrCtx); -+ av_channel_layout_uninit(&m_CodecCtx->ch_layout); - avcodec_free_context(&m_CodecCtx); - return false; - } -@@ -242,62 +261,83 @@ - - int CAEEncoderFFmpeg::Encode(uint8_t *in, int in_size, uint8_t *out, int out_size) - { -- int got_output; -- AVFrame *frame; -+ int size = 0; -+ int err = AVERROR_UNKNOWN; -+ AVFrame* frame = nullptr; -+ AVPacket* pkt = nullptr; - - if (!m_CodecCtx) -- return 0; -+ return size; - -- /* allocate the input frame -- * sadly, we have to alloc/dealloc it everytime since we have no guarantee the -- * data argument will be constant over iterated calls and the frame needs to -- * setup pointers inside data */ -- frame = av_frame_alloc(); -- if (!frame) -- return 0; -+ try -+ { -+ /* allocate the input frame and output packet -+ * sadly, we have to alloc/dealloc it everytime since we have no guarantee the -+ * data argument will be constant over iterated calls and the frame needs to -+ * setup pointers inside data */ -+ frame = av_frame_alloc(); -+ pkt = av_packet_alloc(); -+ if (!frame || !pkt) -+ throw FFMpegException( -+ "Failed to allocate \"AVFrame\" or \"AVPacket\" for encoding (error '{}')", -+ strerror(errno)); - -- frame->nb_samples = m_CodecCtx->frame_size; -- frame->format = m_CodecCtx->sample_fmt; -- frame->channel_layout = m_CodecCtx->channel_layout; -- frame->channels = m_CodecCtx->channels; -+ frame->nb_samples = m_CodecCtx->frame_size; -+ frame->format = m_CodecCtx->sample_fmt; -+ av_channel_layout_uninit(&frame->ch_layout); -+ av_channel_layout_copy(&frame->ch_layout, &m_CodecCtx->ch_layout); -+ int channelNum = m_CodecCtx->ch_layout.nb_channels; - -- avcodec_fill_audio_frame(frame, m_CodecCtx->channels, m_CodecCtx->sample_fmt, -- in, in_size, 0); -+ avcodec_fill_audio_frame(frame, channelNum, m_CodecCtx->sample_fmt, in, in_size, 0); - -- /* initialize the output packet */ -- AVPacket* pkt = av_packet_alloc(); -- if (!pkt) -+ /* encode it */ -+ err = avcodec_send_frame(m_CodecCtx, frame); -+ if (err < 0) -+ throw FFMpegException("Error sending a frame for encoding (error '{}')", -+ FFMpegErrorToString(err)); -+ -+ err = avcodec_receive_packet(m_CodecCtx, pkt); -+ //! @TODO: This is a workaround for our current design. The caller should be made -+ // aware of the potential error values to use the ffmpeg API in a proper way, which means -+ // copying with EAGAIN and multiple packet output. -+ // For the current situation there is a relationship implicitely assumed of: -+ // 1 frame in - 1 packet out. This holds true in practice but the API does not guarantee it. -+ if (err >= 0) -+ { -+ if (pkt->size <= out_size) -+ { -+ memset(out, 0, out_size); -+ memcpy(out, pkt->data, pkt->size); -+ size = pkt->size; -+ } -+ else -+ { -+ CLog::LogF(LOGERROR, "Encoded pkt size ({}) is bigger than buffer ({})", pkt->size, -+ out_size); -+ } -+ av_packet_unref(pkt); -+ } -+ else -+ { -+ CLog::LogF(LOGERROR, "Error receiving encoded paket ({})", err); -+ } -+ } -+ catch (const FFMpegException& caught) - { -- CLog::Log(LOGERROR, "CAEEncoderFFmpeg::{} - av_packet_alloc failed: {}", __FUNCTION__, -- strerror(errno)); -- av_frame_free(&frame); -- return 0; -+ CLog::Log(LOGERROR, "CAEEncoderFFmpeg::{} - {}", __func__, caught.what()); - } - -- pkt->size = out_size; -- pkt->data = out; -+ av_channel_layout_uninit(&frame->ch_layout); - -- /* encode it */ -- int ret = avcodec_encode_audio2(m_CodecCtx, pkt, frame, &got_output); -- -- int size = pkt->size; -- - /* free temporary data */ - av_frame_free(&frame); - - /* free the packet */ - av_packet_free(&pkt); - -- if (ret < 0 || !got_output) -- { -- CLog::Log(LOGERROR, "CAEEncoderFFmpeg::Encode - Encoding failed"); -- return 0; -- } *** 1912 LINES SKIPPED ***