Browse Source

package/bento4: bump version to 1.6.0-639-6-Nexus

Switch to kodi fork, remove all kodi-related patches.

Needed by upcoming bump of kodi-inputstream-adaptive.

Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
[yann.morin.1998@free.fr: update .checkpackageignore]
Signed-off-by: Yann E. MORIN <yann.morin.1998@free.fr>
Bernd Kuhls 2 years ago
parent
commit
129c83bdd4

+ 0 - 16
.checkpackageignore

@@ -219,22 +219,6 @@ package/beecrypt/0002-build-system.patch Upstream
 package/beecrypt/0003-don-t-check-for-cplusplus-compiler.patch Upstream
 package/benejson/0001-c-std.patch Upstream
 package/benejson/0002-Use-print-as-a-function-for-Py3-compatibility.patch Upstream
-package/bento4/0001-Add-support-for-cmake-install.patch Upstream
-package/bento4/0002-Add-additional-methods-funtions-and-passing-poolid.patch Upstream
-package/bento4/0003-Backport-Smmothstream-changes.patch Upstream
-package/bento4/0004-more-SPS-parameters.patch Upstream
-package/bento4/0005-AVC-extract-VUI-values-from-SPS.patch Upstream
-package/bento4/0006-Implement-SPS-Frame-parser.patch Upstream
-package/bento4/0007-Fix-segfault-when-AP4_Sample-s-seek.patch Upstream
-package/bento4/0008-Hack-HBO.patch Upstream
-package/bento4/0009-Android-32-ftello-fix.patch Upstream
-package/bento4/0010-Dazn-sample-duration-workaround.patch Upstream
-package/bento4/0011-Add-argument-to-reuse-single-sample-decrypter.patch Upstream
-package/bento4/0012-Static-ReadGolomb-SignedGolomb.patch Upstream
-package/bento4/0013-Add-GetChannels-method.patch Upstream
-package/bento4/0014-Implemented-GetSampleIndexForTimeStamp-GetNearestSyn.patch Upstream
-package/bento4/0015-Avoid-set-next-fragment-position.patch Upstream
-package/bento4/0016-Fix-segfault-in-AP4_LinearReader-ProcessMoof.patch Upstream
 package/berkeleydb/0001-cwd-db_config.patch Upstream
 package/berkeleydb/0002-atomic_compare_exchange.patch Upstream
 package/bind/0001-cross.patch Upstream

+ 0 - 130
package/bento4/0001-Add-support-for-cmake-install.patch

@@ -1,130 +0,0 @@
-From ba95f55c495c4c34c75a95de843acfa00f6afe24 Mon Sep 17 00:00:00 2001
-From: Harry Mallon <harry.mallon@codex.online>
-Date: Fri, 9 Jul 2021 15:50:26 +0100
-Subject: [PATCH] Add support for cmake install
-
-Downloaded from upstream commit
-https://github.com/axiomatic-systems/Bento4/commit/ba95f55c495c4c34c75a95de843acfa00f6afe24
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Build/cmake/Config.cmake.in |  4 ++
- CMakeLists.txt              | 73 ++++++++++++++++++++++++++++++++++---
- 2 files changed, 71 insertions(+), 6 deletions(-)
- create mode 100644 Build/cmake/Config.cmake.in
-
-diff --git a/Build/cmake/Config.cmake.in b/Build/cmake/Config.cmake.in
-new file mode 100644
-index 00000000..38bbde7b
---- /dev/null
-+++ b/Build/cmake/Config.cmake.in
-@@ -0,0 +1,4 @@
-+@PACKAGE_INIT@
-+
-+include("${CMAKE_CURRENT_LIST_DIR}/@TARGETS_EXPORT_NAME@.cmake")
-+check_required_components("@PROJECT_NAME@")
-diff --git a/CMakeLists.txt b/CMakeLists.txt
-index 6de3bfe1..6ebf127f 100644
---- a/CMakeLists.txt
-+++ b/CMakeLists.txt
-@@ -7,7 +7,14 @@ else()
-   cmake_minimum_required(VERSION 3.10)
- endif()
- 
--project(bento4)
-+function(get_bento4_version)
-+  file(STRINGS "Source/C++/Core/Ap4Version.h" _temp REGEX "AP4_VERSION_STRING")
-+  string(REGEX MATCH "\"([^\"]+)\"" _temp "${_temp}")
-+  set(BENTO4_VERSION "${CMAKE_MATCH_1}" PARENT_SCOPE)
-+endfunction()
-+
-+get_bento4_version()
-+project(bento4 VERSION "${BENTO4_VERSION}")
- 
- # Variables
- set(SOURCE_ROOT ${CMAKE_CURRENT_SOURCE_DIR}/Source/C++)
-@@ -51,14 +58,22 @@ endif()
- 
- # Includes
- set(AP4_INCLUDE_DIRS
--  ${SOURCE_CORE}
--  ${SOURCE_CODECS}
--  ${SOURCE_CRYPTO}
--  ${SOURCE_METADATA}
-+  $<BUILD_INTERFACE:${SOURCE_CORE}>
-+  $<BUILD_INTERFACE:${SOURCE_CODECS}>
-+  $<BUILD_INTERFACE:${SOURCE_CRYPTO}>
-+  $<BUILD_INTERFACE:${SOURCE_METADATA}>
-+)
-+file(GLOB AP4_HEADERS
-+  ${SOURCE_CORE}/*.h
-+  ${SOURCE_CODECS}/*.h
-+  ${SOURCE_CRYPTO}/*.h
-+  ${SOURCE_METADATA}/*.h
- )
- 
- add_library(ap4 STATIC ${AP4_SOURCES})
--target_include_directories(ap4 PUBLIC ${AP4_INCLUDE_DIRS})
-+target_include_directories(ap4 PUBLIC
-+  ${AP4_INCLUDE_DIRS}
-+)
- 
- # Use the statically linked C runtime library
- if(MSVC)
-@@ -72,6 +87,7 @@ if(BUILD_APPS)
- file(GLOB BENTO4_APPS RELATIVE ${SOURCE_ROOT}/Apps ${SOURCE_ROOT}/Apps/*)
- foreach(app ${BENTO4_APPS})
-   string(TOLOWER ${app} binary_name)
-+  list(APPEND BENTO4_APPS_LOWERCASE ${binary_name})
-   add_executable(${binary_name} ${SOURCE_ROOT}/Apps/${app}/${app}.cpp)
-   target_link_libraries(${binary_name} ap4)
- 
-@@ -81,3 +97,48 @@ foreach(app ${BENTO4_APPS})
-   endif()
- endforeach()
- endif(BUILD_APPS)
-+
-+# Install
-+include(GNUInstallDirs)
-+set(config_install_dir "${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}")
-+set(generated_dir "${CMAKE_CURRENT_BINARY_DIR}/generated")
-+set(version_config "${generated_dir}/${PROJECT_NAME}ConfigVersion.cmake")
-+set(project_config "${generated_dir}/${PROJECT_NAME}Config.cmake")
-+set(TARGETS_EXPORT_NAME "${PROJECT_NAME}Targets")
-+set(namespace "${PROJECT_NAME}::")
-+
-+include(CMakePackageConfigHelpers)
-+write_basic_package_version_file(
-+    "${version_config}" COMPATIBILITY SameMajorVersion
-+)
-+
-+configure_package_config_file(
-+    "Build/cmake/Config.cmake.in"
-+    "${project_config}"
-+    INSTALL_DESTINATION "${config_install_dir}"
-+)
-+
-+install(
-+    TARGETS ap4 ${BENTO4_APPS_LOWERCASE}
-+    EXPORT "${TARGETS_EXPORT_NAME}"
-+    LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
-+    ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
-+    RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}"
-+    INCLUDES DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}"
-+)
-+
-+install(
-+    FILES ${AP4_HEADERS}
-+    DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}/bento4"
-+)
-+
-+install(
-+    FILES "${project_config}" "${version_config}"
-+    DESTINATION "${config_install_dir}"
-+)
-+
-+install(
-+    EXPORT "${TARGETS_EXPORT_NAME}"
-+    NAMESPACE "${namespace}"
-+    DESTINATION "${config_install_dir}"
-+)

+ 0 - 634
package/bento4/0002-Add-additional-methods-funtions-and-passing-poolid.patch

@@ -1,634 +0,0 @@
-From b2027d354ef5d52efd525730fa5e6beccb88d33f Mon Sep 17 00:00:00 2001
-From: Glenn Guy <glennguy83@gmail.com>
-Date: Thu, 22 Jul 2021 10:00:44 +0200
-Subject: [PATCH] Add additional methods/funtions and passing poolid
-
-Added back:
-* SSD - > ParentIsOwner functionality
-* LinearReader: GetSample, SeekSample, Reset
-* Ap4Movie -> GetPsshAtoms
-* Uuid/VppC -> GetData
-* Ap4Protection -> WVTT atom type
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4ByteStream.h         |  1 -
- Source/C++/Core/Ap4CommonEncryption.cpp | 15 ++--
- Source/C++/Core/Ap4CommonEncryption.h   | 24 +++++--
- Source/C++/Core/Ap4IsmaCryp.cpp         |  5 +-
- Source/C++/Core/Ap4IsmaCryp.h           |  3 +-
- Source/C++/Core/Ap4LinearReader.cpp     | 94 ++++++++++++++++++++++++-
- Source/C++/Core/Ap4LinearReader.h       |  4 ++
- Source/C++/Core/Ap4Marlin.cpp           |  5 +-
- Source/C++/Core/Ap4Marlin.h             |  3 +-
- Source/C++/Core/Ap4MoovAtom.cpp         | 28 +++++++-
- Source/C++/Core/Ap4MoovAtom.h           |  5 ++
- Source/C++/Core/Ap4Movie.cpp            | 10 +++
- Source/C++/Core/Ap4Movie.h              |  4 ++
- Source/C++/Core/Ap4OmaDcf.cpp           |  8 ++-
- Source/C++/Core/Ap4OmaDcf.h             |  6 +-
- Source/C++/Core/Ap4Protection.h         |  3 +-
- Source/C++/Core/Ap4SampleDescription.h  |  1 +
- Source/C++/Core/Ap4UuidAtom.h           |  1 +
- Source/C++/Core/Ap4VpccAtom.h           |  3 +
- 19 files changed, 197 insertions(+), 26 deletions(-)
-
-diff --git a/Source/C++/Core/Ap4ByteStream.h b/Source/C++/Core/Ap4ByteStream.h
-index 0a59e63..93ac80f 100644
---- a/Source/C++/Core/Ap4ByteStream.h
-+++ b/Source/C++/Core/Ap4ByteStream.h
-@@ -195,7 +195,6 @@ public:
-     AP4_UI08*       UseData()     { return m_Buffer->UseData(); }
-     AP4_Size        GetDataSize() { return m_Buffer->GetDataSize(); }
- 
--protected:
-     virtual ~AP4_MemoryByteStream();
- 
- private:
-diff --git a/Source/C++/Core/Ap4CommonEncryption.cpp b/Source/C++/Core/Ap4CommonEncryption.cpp
-index acd6361..5308200 100644
---- a/Source/C++/Core/Ap4CommonEncryption.cpp
-+++ b/Source/C++/Core/Ap4CommonEncryption.cpp
-@@ -1859,7 +1859,8 @@ AP4_CencSingleSampleDecrypter::~AP4_CencSingleSampleDecrypter() {
- |   AP4_CencSingleSampleDecrypter::DecryptSampleData
- +---------------------------------------------------------------------*/
- AP4_Result 
--AP4_CencSingleSampleDecrypter::DecryptSampleData(AP4_DataBuffer& data_in,
-+AP4_CencSingleSampleDecrypter::DecryptSampleData(AP4_UI32 poolid,
-+                                                 AP4_DataBuffer& data_in,
-                                                  AP4_DataBuffer& data_out,
-                                                  const AP4_UI08* iv,
-                                                  unsigned int    subsample_count,
-@@ -2094,8 +2095,9 @@ AP4_CencSampleDecrypter::Create(AP4_CencSampleInfoTable*  sample_info_table,
- +---------------------------------------------------------------------*/
- AP4_CencSampleDecrypter::~AP4_CencSampleDecrypter()
- {
--	delete m_SampleInfoTable;
--	delete m_SingleSampleDecrypter;
-+  delete m_SampleInfoTable;
-+  if (m_SingleSampleDecrypter->GetParentIsOwner())
-+    delete m_SingleSampleDecrypter;
- }
- 
- /*----------------------------------------------------------------------
-@@ -2112,7 +2114,8 @@ AP4_CencSampleDecrypter::SetSampleIndex(AP4_Ordinal sample_index)
- |   AP4_CencSampleDecrypter::DecryptSampleData
- +---------------------------------------------------------------------*/
- AP4_Result 
--AP4_CencSampleDecrypter::DecryptSampleData(AP4_DataBuffer& data_in,
-+AP4_CencSampleDecrypter::DecryptSampleData(AP4_UI32 poolid,
-+                                           AP4_DataBuffer& data_in,
-                                            AP4_DataBuffer& data_out,
-                                            const AP4_UI08* iv)
- {
-@@ -2139,7 +2142,7 @@ AP4_CencSampleDecrypter::DecryptSampleData(AP4_DataBuffer& data_in,
-     }
-     
-     // decrypt the sample
--    return m_SingleSampleDecrypter->DecryptSampleData(data_in, data_out, iv_block, subsample_count, bytes_of_cleartext_data, bytes_of_encrypted_data);
-+    return m_SingleSampleDecrypter->DecryptSampleData(poolid, data_in, data_out, iv_block, subsample_count, bytes_of_cleartext_data, bytes_of_encrypted_data);
- }
- 
- /*----------------------------------------------------------------------
-@@ -2323,7 +2326,7 @@ AP4_CencFragmentDecrypter::ProcessSample(AP4_DataBuffer& data_in,
-                                          AP4_DataBuffer& data_out)
- {
-     // decrypt the sample
--    return m_SampleDecrypter->DecryptSampleData(data_in, data_out, NULL);
-+    return m_SampleDecrypter->DecryptSampleData(0, data_in, data_out, NULL);
- }
- 
- /*----------------------------------------------------------------------
-diff --git a/Source/C++/Core/Ap4CommonEncryption.h b/Source/C++/Core/Ap4CommonEncryption.h
-index 80db456..580de66 100644
---- a/Source/C++/Core/Ap4CommonEncryption.h
-+++ b/Source/C++/Core/Ap4CommonEncryption.h
-@@ -691,9 +691,18 @@ public:
-     // methods
-     AP4_CencSingleSampleDecrypter(AP4_StreamCipher* cipher) :
-         m_Cipher(cipher),
--        m_FullBlocksOnly(false) {}
-+        m_FullBlocksOnly(false),
-+        m_ParentIsOwner(true) {}
-     virtual ~AP4_CencSingleSampleDecrypter();
--    virtual AP4_Result DecryptSampleData(AP4_DataBuffer& data_in,
-+    virtual AP4_Result SetFragmentInfo(AP4_UI32 poolid, const AP4_UI08* keyid, const AP4_UI08 nalu_length_size,
-+      AP4_DataBuffer &annexb_sps_pps, AP4_UI32 flags) {
-+      return AP4_ERROR_NOT_SUPPORTED;
-+    };
-+    virtual AP4_UI32 AddPool() { return 0; };
-+    virtual void RemovePool(AP4_UI32 poolid) {};
-+    virtual const char* GetSessionId() { return nullptr; };
-+    virtual AP4_Result DecryptSampleData(AP4_UI32 poolid, 
-+                                         AP4_DataBuffer& data_in,
-                                          AP4_DataBuffer& data_out,
-                                          
-                                          // always 16 bytes
-@@ -706,7 +715,9 @@ public:
-                                          const AP4_UI16* bytes_of_cleartext_data,
-                                          
-                                          // array of <subsample_count> integers. NULL if subsample_count is 0
--                                         const AP4_UI32* bytes_of_encrypted_data);  
-+                                         const AP4_UI32* bytes_of_encrypted_data);
-+    bool GetParentIsOwner()const { return m_ParentIsOwner; };
-+    void SetParentIsOwner(bool parent_is_owner) { m_ParentIsOwner = parent_is_owner; };
-     
- private:
-     // constructor
-@@ -715,12 +726,14 @@ private:
-                                   bool              reset_iv_at_each_subsample) :
-         m_Cipher(cipher),
-         m_FullBlocksOnly(full_blocks_only),
--        m_ResetIvAtEachSubsample(reset_iv_at_each_subsample) {}
-+        m_ResetIvAtEachSubsample(reset_iv_at_each_subsample),
-+        m_ParentIsOwner(true) {}
- 
-     // members
-     AP4_StreamCipher* m_Cipher;
-     bool              m_FullBlocksOnly;
-     bool              m_ResetIvAtEachSubsample;
-+    bool              m_ParentIsOwner;
- };
- 
- /*----------------------------------------------------------------------
-@@ -766,7 +779,8 @@ public:
-         m_SampleCursor(0) {}
-     virtual ~AP4_CencSampleDecrypter();
-     virtual AP4_Result SetSampleIndex(AP4_Ordinal sample_index);
--    virtual AP4_Result DecryptSampleData(AP4_DataBuffer& data_in,
-+    virtual AP4_Result DecryptSampleData(AP4_UI32 poolid, 
-+                                         AP4_DataBuffer& data_in,
-                                          AP4_DataBuffer& data_out,
-                                          const AP4_UI08* iv);
-     
-diff --git a/Source/C++/Core/Ap4IsmaCryp.cpp b/Source/C++/Core/Ap4IsmaCryp.cpp
-index dfb59a4..442ad49 100644
---- a/Source/C++/Core/Ap4IsmaCryp.cpp
-+++ b/Source/C++/Core/Ap4IsmaCryp.cpp
-@@ -142,7 +142,8 @@ AP4_IsmaCipher::GetDecryptedSampleSize(AP4_Sample& sample)
- |   AP4_IsmaCipher::DecryptSampleData
- +---------------------------------------------------------------------*/
- AP4_Result 
--AP4_IsmaCipher::DecryptSampleData(AP4_DataBuffer& data_in,
-+AP4_IsmaCipher::DecryptSampleData(AP4_UI32 poolid,
-+                                  AP4_DataBuffer& data_in,
-                                   AP4_DataBuffer& data_out,
-                                   const AP4_UI08* /*iv*/)
- {
-@@ -333,7 +334,7 @@ AP4_Result
- AP4_IsmaTrackDecrypter::ProcessSample(AP4_DataBuffer& data_in,
-                                       AP4_DataBuffer& data_out)
- {
--    return m_Cipher->DecryptSampleData(data_in, data_out);
-+    return m_Cipher->DecryptSampleData(0, data_in, data_out);
- }
- 
- /*----------------------------------------------------------------------
-diff --git a/Source/C++/Core/Ap4IsmaCryp.h b/Source/C++/Core/Ap4IsmaCryp.h
-index 4b9c60e..970dac8 100644
---- a/Source/C++/Core/Ap4IsmaCryp.h
-+++ b/Source/C++/Core/Ap4IsmaCryp.h
-@@ -74,7 +74,8 @@ public:
-     AP4_Result EncryptSampleData(AP4_DataBuffer& data_in,
-                                  AP4_DataBuffer& data_out,
-                                  AP4_UI32        block_counter);
--    AP4_Result DecryptSampleData(AP4_DataBuffer& data_in,
-+    AP4_Result DecryptSampleData(AP4_UI32 poolid,
-+                                 AP4_DataBuffer& data_in,
-                                  AP4_DataBuffer& data_out,
-                                  const AP4_UI08* iv = NULL);
-     AP4_Size   GetDecryptedSampleSize(AP4_Sample& sample);
-diff --git a/Source/C++/Core/Ap4LinearReader.cpp b/Source/C++/Core/Ap4LinearReader.cpp
-index 08b55ee..7cc3ebd 100644
---- a/Source/C++/Core/Ap4LinearReader.cpp
-+++ b/Source/C++/Core/Ap4LinearReader.cpp
-@@ -117,6 +117,29 @@ AP4_LinearReader::FlushQueues()
-     }
- }
- 
-+/*----------------------------------------------------------------------
-+|   AP4_LinearReader::Reset
-++---------------------------------------------------------------------*/
-+void
-+AP4_LinearReader::Reset()
-+{
-+  // flush any queued samples
-+  FlushQueues();
-+
-+  // reset tracker states
-+  for (unsigned int i = 0; i < m_Trackers.ItemCount(); i++) {
-+    if (m_Trackers[i]->m_SampleTableIsOwned) {
-+      delete m_Trackers[i]->m_SampleTable;
-+    }
-+    delete m_Trackers[i]->m_NextSample;
-+    m_Trackers[i]->m_SampleTable = NULL;
-+    m_Trackers[i]->m_NextSample = NULL;
-+    m_Trackers[i]->m_NextSampleIndex = 0;
-+    m_Trackers[i]->m_Eos = false;
-+  }
-+  m_NextFragmentPosition = 0;
-+}
-+
- /*----------------------------------------------------------------------
- |   AP4_LinearReader::SetSampleIndex
- +---------------------------------------------------------------------*/
-@@ -591,6 +614,75 @@ AP4_LinearReader::ReadNextSample(AP4_Sample&     sample,
-     return ReadNextSample(sample, &sample_data, track_id);
- }
- 
-+/*----------------------------------------------------------------------
-+|   AP4_LinearReader::GetSample
-++---------------------------------------------------------------------*/
-+AP4_Result AP4_LinearReader::GetSample(AP4_UI32 track_id, AP4_Sample &sample, AP4_Ordinal sample_index)
-+{
-+    // look for a sample from a specific track
-+    Tracker* tracker = FindTracker(track_id);
-+    if (tracker == NULL)
-+        return AP4_ERROR_INVALID_PARAMETERS;
-+
-+    // don't continue if we've reached the end of that tracker
-+    if (tracker->m_Eos)
-+        return AP4_ERROR_EOS;
-+
-+    return tracker->m_SampleTable->GetSample(sample_index, sample);
-+}
-+
-+/*----------------------------------------------------------------------
-+|   AP4_LinearReader::SeekSample
-++---------------------------------------------------------------------*/
-+AP4_Result
-+AP4_LinearReader::SeekSample(AP4_UI32 track_id, AP4_UI64 ts, AP4_Ordinal &sample_index, bool preceedingSync)
-+{
-+    // we only support fragmented sources for now
-+    if (!m_HasFragments)
-+        return AP4_ERROR_NOT_SUPPORTED;
-+
-+    if (m_Trackers.ItemCount() == 0) {
-+        return AP4_ERROR_NO_SUCH_ITEM;
-+    }
-+
-+    // look for a sample from a specific track
-+    Tracker* tracker = FindTracker(track_id);
-+    if (tracker == NULL)
-+        return AP4_ERROR_INVALID_PARAMETERS;
-+
-+    // don't continue if we've reached the end of that tracker
-+    if (tracker->m_Eos)
-+        return AP4_ERROR_EOS;
-+
-+    AP4_Result result;
-+
-+    if (!tracker->m_SampleTable && AP4_FAILED(result = Advance()))
-+        return result;
-+
-+    while (AP4_FAILED(result = tracker->m_SampleTable->GetSampleIndexForTimeStamp(ts, sample_index)))
-+    {
-+        if (result == AP4_ERROR_NOT_ENOUGH_DATA)
-+        {
-+            tracker->m_NextSampleIndex = tracker->m_SampleTable->GetSampleCount();
-+            if (AP4_FAILED(result = Advance()))
-+                return result;
-+            continue;
-+        }
-+        return result;
-+    }
-+
-+    sample_index = tracker->m_SampleTable->GetNearestSyncSampleIndex(sample_index, preceedingSync);
-+    //we have reached the end -> go for the first sample of the next segment
-+    if (sample_index == tracker->m_SampleTable->GetSampleCount())
-+    {
-+        tracker->m_NextSampleIndex = tracker->m_SampleTable->GetSampleCount();
-+        if (AP4_FAILED(result = Advance()))
-+            return result;
-+        sample_index = 0;
-+    }
-+    return SetSampleIndex(tracker->m_Track->GetId(), sample_index);
-+}
-+
- /*----------------------------------------------------------------------
- |   AP4_LinearReader::GetNextSample
- +---------------------------------------------------------------------*/
-@@ -633,5 +725,5 @@ AP4_DecryptingSampleReader::ReadSampleData(AP4_Sample&     sample,
-     AP4_Result result = sample.ReadData(m_DataBuffer);
-     if (AP4_FAILED(result)) return result;
- 
--    return m_Decrypter->DecryptSampleData(m_DataBuffer, sample_data);
-+    return m_Decrypter->DecryptSampleData(0, m_DataBuffer, sample_data);
- }
-diff --git a/Source/C++/Core/Ap4LinearReader.h b/Source/C++/Core/Ap4LinearReader.h
-index 549cb5f..21f4871 100644
---- a/Source/C++/Core/Ap4LinearReader.h
-+++ b/Source/C++/Core/Ap4LinearReader.h
-@@ -85,6 +85,8 @@ public:
-     AP4_Result SetSampleIndex(AP4_UI32 track_id, AP4_UI32 sample_index);
-     
-     AP4_Result SeekTo(AP4_UI32 time_ms, AP4_UI32* actual_time_ms = 0);
-+
-+    AP4_Result SeekSample(AP4_UI32 track_id, AP4_UI64 ts, AP4_Ordinal &sample_index, bool preceedingSync);
-     
-     // accessors
-     AP4_Size GetBufferFullness() { return m_BufferFullness; }
-@@ -169,8 +171,10 @@ protected:
-     AP4_Result ReadNextSample(AP4_Sample&     sample, 
-                               AP4_DataBuffer* sample_data,
-                               AP4_UI32&       track_id);
-+    AP4_Result GetSample(AP4_UI32 track_id, AP4_Sample &sample, AP4_Ordinal sample_index);
-     void       FlushQueue(Tracker* tracker);
-     void       FlushQueues();
-+    void       Reset();
-     
-     // members
-     AP4_Movie&          m_Movie;
-diff --git a/Source/C++/Core/Ap4Marlin.cpp b/Source/C++/Core/Ap4Marlin.cpp
-index d0ddd3f..c1aa8b6 100644
---- a/Source/C++/Core/Ap4Marlin.cpp
-+++ b/Source/C++/Core/Ap4Marlin.cpp
-@@ -431,7 +431,8 @@ AP4_MarlinIpmpSampleDecrypter::GetDecryptedSampleSize(AP4_Sample& sample)
- |   AP4_MarlinIpmpSampleDecrypter::DecryptSampleData
- +---------------------------------------------------------------------*/
- AP4_Result 
--AP4_MarlinIpmpSampleDecrypter::DecryptSampleData(AP4_DataBuffer&    data_in,
-+AP4_MarlinIpmpSampleDecrypter::DecryptSampleData(AP4_UI32 poolid,
-+                                                 AP4_DataBuffer&    data_in,
-                                                  AP4_DataBuffer&    data_out,
-                                                  const AP4_UI08*    /*iv*/)
- {
-@@ -630,7 +631,7 @@ AP4_Result
- AP4_MarlinIpmpTrackDecrypter::ProcessSample(AP4_DataBuffer& data_in,
-                                             AP4_DataBuffer& data_out)
- {
--    return m_SampleDecrypter->DecryptSampleData(data_in, data_out);
-+    return m_SampleDecrypter->DecryptSampleData(0, data_in, data_out);
- }
- 
- /*----------------------------------------------------------------------
-diff --git a/Source/C++/Core/Ap4Marlin.h b/Source/C++/Core/Ap4Marlin.h
-index 774e04f..9280ad6 100644
---- a/Source/C++/Core/Ap4Marlin.h
-+++ b/Source/C++/Core/Ap4Marlin.h
-@@ -118,7 +118,8 @@ public:
-     
-     // AP4_SampleDecrypter methods
-     AP4_Size   GetDecryptedSampleSize(AP4_Sample& sample);
--    AP4_Result DecryptSampleData(AP4_DataBuffer&    data_in,
-+    AP4_Result DecryptSampleData(AP4_UI32 poolid,
-+                                 AP4_DataBuffer&    data_in,
-                                  AP4_DataBuffer&    data_out,
-                                  const AP4_UI08*    iv = NULL);
-                                  
-diff --git a/Source/C++/Core/Ap4MoovAtom.cpp b/Source/C++/Core/Ap4MoovAtom.cpp
-index 1ceab49..fbeee4f 100644
---- a/Source/C++/Core/Ap4MoovAtom.cpp
-+++ b/Source/C++/Core/Ap4MoovAtom.cpp
-@@ -31,6 +31,7 @@
- +---------------------------------------------------------------------*/
- #include "Ap4MoovAtom.h"
- #include "Ap4TrakAtom.h"
-+#include "Ap4PsshAtom.h"
- #include "Ap4AtomFactory.h"
- 
- /*----------------------------------------------------------------------
-@@ -61,6 +62,29 @@ private:
-     AP4_List<AP4_TrakAtom>* m_TrakAtoms;
- };
- 
-+/*----------------------------------------------------------------------
-+|   AP4_PsshAtomCollector
-++---------------------------------------------------------------------*/
-+class AP4_PsshAtomCollector : public AP4_List<AP4_Atom>::Item::Operator
-+{
-+public:
-+  AP4_PsshAtomCollector(AP4_List<AP4_PsshAtom>* pssh_atoms) :
-+    m_PsshAtoms(pssh_atoms) {}
-+
-+  AP4_Result Action(AP4_Atom* atom) const {
-+    if (atom->GetType() == AP4_ATOM_TYPE_PSSH) {
-+      AP4_PsshAtom* pssh = AP4_DYNAMIC_CAST(AP4_PsshAtom, atom);
-+      if (pssh) {
-+        m_PsshAtoms->Add(pssh);
-+      }
-+    }
-+    return AP4_SUCCESS;
-+  }
-+
-+private:
-+  AP4_List<AP4_PsshAtom>* m_PsshAtoms;
-+};
-+
- /*----------------------------------------------------------------------
- |   AP4_MoovAtom::AP4_MoovAtom
- +---------------------------------------------------------------------*/
-@@ -80,7 +104,9 @@ AP4_MoovAtom::AP4_MoovAtom(AP4_UI32         size,
-     m_TimeScale(0)
- {
-     // collect all trak atoms
--    m_Children.Apply(AP4_TrakAtomCollector(&m_TrakAtoms));    
-+    m_Children.Apply(AP4_TrakAtomCollector(&m_TrakAtoms));
-+    // collect all pssh atoms
-+    m_Children.Apply(AP4_PsshAtomCollector(&m_PsshAtoms));
- }
- 
- /*----------------------------------------------------------------------
-diff --git a/Source/C++/Core/Ap4MoovAtom.h b/Source/C++/Core/Ap4MoovAtom.h
-index f06b2a1..d1a0147 100644
---- a/Source/C++/Core/Ap4MoovAtom.h
-+++ b/Source/C++/Core/Ap4MoovAtom.h
-@@ -40,6 +40,7 @@
- +---------------------------------------------------------------------*/
- class AP4_AtomFactory;
- class AP4_TrakAtom;
-+class AP4_PsshAtom;
- 
- /*----------------------------------------------------------------------
- |   AP4_MoovAtom
-@@ -61,6 +62,9 @@ public:
-     AP4_List<AP4_TrakAtom>& GetTrakAtoms() {
-         return m_TrakAtoms;
-     }
-+    AP4_List<AP4_PsshAtom>& GetPsshAtoms() {
-+      return m_PsshAtoms;
-+    }
-     AP4_UI32 GetTimeScale() {
-         return m_TimeScale;
-     }
-@@ -77,6 +81,7 @@ private:
-                  AP4_AtomFactory& atom_factory);
- 
-     // members
-+    AP4_List<AP4_PsshAtom> m_PsshAtoms;
-     AP4_List<AP4_TrakAtom> m_TrakAtoms;
-     AP4_UI32               m_TimeScale;
- };
-diff --git a/Source/C++/Core/Ap4Movie.cpp b/Source/C++/Core/Ap4Movie.cpp
-index b080b53..9617494 100644
---- a/Source/C++/Core/Ap4Movie.cpp
-+++ b/Source/C++/Core/Ap4Movie.cpp
-@@ -32,6 +32,7 @@
- #include "Ap4File.h"
- #include "Ap4Atom.h"
- #include "Ap4TrakAtom.h"
-+#include "Ap4PsshAtom.h"
- #include "Ap4MoovAtom.h"
- #include "Ap4MvhdAtom.h"
- #include "Ap4AtomFactory.h"
-@@ -110,6 +111,15 @@ AP4_Movie::AP4_Movie(AP4_MoovAtom* moov, AP4_ByteStream& sample_stream, bool tra
-         time_scale = 0;
-     }
- 
-+    // get the pssh atoms
-+    AP4_List<AP4_PsshAtom>* pssh_atoms;
-+    pssh_atoms = &moov->GetPsshAtoms();
-+    AP4_List<AP4_PsshAtom>::Item* pssh_item = pssh_atoms->FirstItem();
-+    while (pssh_item) {
-+        m_PsshAtoms.Append(*pssh_item->GetData());
-+        pssh_item = pssh_item->GetNext();
-+    }
-+
-     // get all tracks
-     AP4_List<AP4_TrakAtom>* trak_atoms;
-     trak_atoms = &moov->GetTrakAtoms();
-diff --git a/Source/C++/Core/Ap4Movie.h b/Source/C++/Core/Ap4Movie.h
-index 21ef173..04992a4 100644
---- a/Source/C++/Core/Ap4Movie.h
-+++ b/Source/C++/Core/Ap4Movie.h
-@@ -37,6 +37,7 @@
- #include "Ap4MvhdAtom.h"
- #include "Ap4Track.h"
- #include "Ap4List.h"
-+#include "Ap4PsshAtom.h"
- 
- /*----------------------------------------------------------------------
- |   class references
-@@ -60,6 +61,8 @@ public:
-     AP4_Result Inspect(AP4_AtomInspector& inspector);
- 
-     AP4_MoovAtom* GetMoovAtom() { return m_MoovAtom;}
-+    void SetMoovAtom(AP4_MoovAtom* atom) { m_MoovAtom = atom; }
-+    AP4_Array<AP4_PsshAtom>& GetPsshAtoms() { return m_PsshAtoms; }
-     AP4_MvhdAtom* GetMvhdAtom() { return m_MvhdAtom;}
-     AP4_List<AP4_Track>& GetTracks() { return m_Tracks; }
-     AP4_Track*   GetTrack(AP4_UI32 track_id);
-@@ -75,6 +78,7 @@ private:
-     AP4_MoovAtom*       m_MoovAtom;
-     bool                m_MoovAtomIsOwned;
-     AP4_MvhdAtom*       m_MvhdAtom;
-+    AP4_Array<AP4_PsshAtom> m_PsshAtoms;
-     AP4_List<AP4_Track> m_Tracks;
- };
- 
-diff --git a/Source/C++/Core/Ap4OmaDcf.cpp b/Source/C++/Core/Ap4OmaDcf.cpp
-index 17099a1..4eefbaf 100644
---- a/Source/C++/Core/Ap4OmaDcf.cpp
-+++ b/Source/C++/Core/Ap4OmaDcf.cpp
-@@ -436,7 +436,8 @@ AP4_OmaDcfCtrSampleDecrypter::~AP4_OmaDcfCtrSampleDecrypter()
- |   AP4_OmaDcfCtrSampleDecrypter::DecryptSampleData
- +---------------------------------------------------------------------*/
- AP4_Result 
--AP4_OmaDcfCtrSampleDecrypter::DecryptSampleData(AP4_DataBuffer& data_in,
-+AP4_OmaDcfCtrSampleDecrypter::DecryptSampleData(AP4_UI32 poolid,
-+                                                AP4_DataBuffer& data_in,
-                                                 AP4_DataBuffer& data_out,
-                                                 const AP4_UI08* /*iv*/)
- {   
-@@ -531,7 +532,8 @@ AP4_OmaDcfCbcSampleDecrypter::~AP4_OmaDcfCbcSampleDecrypter()
- |   AP4_OmaDbcCbcSampleDecrypter::DecryptSampleData
- +---------------------------------------------------------------------*/
- AP4_Result 
--AP4_OmaDcfCbcSampleDecrypter::DecryptSampleData(AP4_DataBuffer& data_in,
-+AP4_OmaDcfCbcSampleDecrypter::DecryptSampleData(AP4_UI32 poolid,
-+                                                AP4_DataBuffer& data_in,
-                                                 AP4_DataBuffer& data_out,
-                                                 const AP4_UI08* /*iv*/)
- {   
-@@ -853,7 +855,7 @@ AP4_Result
- AP4_OmaDcfTrackDecrypter::ProcessSample(AP4_DataBuffer& data_in,
-                                         AP4_DataBuffer& data_out)
- {
--    return m_Cipher->DecryptSampleData(data_in, data_out);
-+    return m_Cipher->DecryptSampleData(0, data_in, data_out);
- }
- 
- /*----------------------------------------------------------------------
-diff --git a/Source/C++/Core/Ap4OmaDcf.h b/Source/C++/Core/Ap4OmaDcf.h
-index 23f10ed..bb7b3d6 100644
---- a/Source/C++/Core/Ap4OmaDcf.h
-+++ b/Source/C++/Core/Ap4OmaDcf.h
-@@ -133,7 +133,8 @@ public:
-     ~AP4_OmaDcfCtrSampleDecrypter();
- 
-     // methods
--    virtual AP4_Result DecryptSampleData(AP4_DataBuffer& data_in,
-+    virtual AP4_Result DecryptSampleData(AP4_UI32 poolid,
-+                                         AP4_DataBuffer& data_in,
-                                          AP4_DataBuffer& data_out,
-                                          const AP4_UI08* iv = NULL);
-     virtual AP4_Size   GetDecryptedSampleSize(AP4_Sample& sample);
-@@ -155,7 +156,8 @@ public:
-     ~AP4_OmaDcfCbcSampleDecrypter();
- 
-     // methods
--    virtual AP4_Result DecryptSampleData(AP4_DataBuffer& data_in,
-+    virtual AP4_Result DecryptSampleData(AP4_UI32 poolid,
-+                                         AP4_DataBuffer& data_in,
-                                          AP4_DataBuffer& data_out,
-                                          const AP4_UI08* iv = NULL);
-     virtual AP4_Size   GetDecryptedSampleSize(AP4_Sample& sample);
-diff --git a/Source/C++/Core/Ap4Protection.h b/Source/C++/Core/Ap4Protection.h
-index 856f1f3..4080584 100644
---- a/Source/C++/Core/Ap4Protection.h
-+++ b/Source/C++/Core/Ap4Protection.h
-@@ -393,7 +393,8 @@ public:
-     // methods
-     virtual AP4_Size   GetDecryptedSampleSize(AP4_Sample& sample) { return sample.GetSize(); }
-     virtual AP4_Result SetSampleIndex(AP4_Ordinal /*index*/)      { return AP4_SUCCESS;      }
--    virtual AP4_Result DecryptSampleData(AP4_DataBuffer&    data_in,
-+    virtual AP4_Result DecryptSampleData(AP4_UI32 poolid,
-+                                         AP4_DataBuffer&    data_in,
-                                          AP4_DataBuffer&    data_out,
-                                          const AP4_UI08*    iv = NULL) = 0;
- };
-diff --git a/Source/C++/Core/Ap4SampleDescription.h b/Source/C++/Core/Ap4SampleDescription.h
-index 27f3136..d493f96 100644
---- a/Source/C++/Core/Ap4SampleDescription.h
-+++ b/Source/C++/Core/Ap4SampleDescription.h
-@@ -101,6 +101,7 @@ const AP4_UI32 AP4_SAMPLE_FORMAT_TX3G = AP4_ATOM_TYPE('t','x','3','g');
- const AP4_UI32 AP4_SAMPLE_FORMAT_VC_1 = AP4_ATOM_TYPE('v','c','-','1');
- const AP4_UI32 AP4_SAMPLE_FORMAT_XML_ = AP4_ATOM_TYPE('x','m','l',' ');
- const AP4_UI32 AP4_SAMPLE_FORMAT_STPP = AP4_ATOM_TYPE('s','t','p','p');
-+const AP4_UI32 AP4_SAMPLE_FORMAT_WVTT = AP4_ATOM_TYPE('w','v','t','t');
- const AP4_UI32 AP4_SAMPLE_FORMAT_FLAC = AP4_ATOM_TYPE('f','L','a','C');
- const AP4_UI32 AP4_SAMPLE_FORMAT_OPUS = AP4_ATOM_TYPE('O','p','u','s');
- const AP4_UI32 AP4_SAMPLE_FORMAT_VP8  = AP4_ATOM_TYPE('v','p','0','8');
-diff --git a/Source/C++/Core/Ap4UuidAtom.h b/Source/C++/Core/Ap4UuidAtom.h
-index b9771bd..0ec3b08 100644
---- a/Source/C++/Core/Ap4UuidAtom.h
-+++ b/Source/C++/Core/Ap4UuidAtom.h
-@@ -90,6 +90,7 @@ public:
- 
-     // methods
-     virtual AP4_Result WriteFields(AP4_ByteStream& stream);
-+    const AP4_DataBuffer &GetData() { return m_Data; };
- 
- protected:
-     // members
-diff --git a/Source/C++/Core/Ap4VpccAtom.h b/Source/C++/Core/Ap4VpccAtom.h
-index 9fb60bc..929048a 100644
---- a/Source/C++/Core/Ap4VpccAtom.h
-+++ b/Source/C++/Core/Ap4VpccAtom.h
-@@ -79,10 +79,13 @@ public:
-     AP4_UI08              GetTransferCharacteristics() { return m_TransferCharacteristics; }
-     AP4_UI08              GetMatrixCoefficients()      { return m_MatrixCoefficients;      }
-     const AP4_DataBuffer& GetCodecInitializationData() { return m_CodecIntializationData;  }
-+    const AP4_DataBuffer& GetData() { return m_Data; }
- 
-     // helpers
-     AP4_Result GetCodecString(AP4_UI32 container_type, AP4_String& codec);
- 
-+protected:
-+  AP4_DataBuffer m_Data;
- private:
-     // methods
-     AP4_VpccAtom(AP4_UI32 size, const AP4_UI08* payload);
--- 
-2.30.2
-

+ 0 - 99
package/bento4/0003-Backport-Smmothstream-changes.patch

@@ -1,99 +0,0 @@
-From 97088e7bd7e84a493bea7e5fe4e808c8ac3e00ff Mon Sep 17 00:00:00 2001
-From: CastagnaIT <gottardo.stefano.83@gmail.com>
-Date: Thu, 22 Jul 2021 10:09:24 +0200
-Subject: [PATCH] Backport Smmothstream changes
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4File.cpp                | 14 ++++++++------
- Source/C++/Core/Ap4File.h                  |  6 ++++--
- Source/C++/Core/Ap4FragmentSampleTable.cpp |  2 +-
- 3 files changed, 13 insertions(+), 9 deletions(-)
-
-diff --git a/Source/C++/Core/Ap4File.cpp b/Source/C++/Core/Ap4File.cpp
-index cb20c3e..f1d2727 100644
---- a/Source/C++/Core/Ap4File.cpp
-+++ b/Source/C++/Core/Ap4File.cpp
-@@ -55,13 +55,14 @@ AP4_File::AP4_File(AP4_Movie* movie) :
- +---------------------------------------------------------------------*/
- AP4_File::AP4_File(AP4_ByteStream&  stream, 
-                    AP4_AtomFactory& atom_factory,
--                   bool             moov_only) :
--    m_Movie(NULL),
-+                   bool             moov_only,
-+                   AP4_Movie*       movie) :
-+    m_Movie(movie),
-     m_FileType(NULL),
-     m_MetaData(NULL),
-     m_MoovIsBeforeMdat(true)
- {
--    ParseStream(stream, atom_factory, moov_only);
-+    ParseStream(stream, atom_factory, moov_only, movie);
- }
- 
- /*----------------------------------------------------------------------
-@@ -75,7 +76,7 @@ AP4_File::AP4_File(AP4_ByteStream&  stream,
-     m_MoovIsBeforeMdat(true)
- {
-     AP4_DefaultAtomFactory atom_factory;
--    ParseStream(stream, atom_factory, moov_only);
-+    ParseStream(stream, atom_factory, moov_only, m_Movie);
- }
- 
- /*----------------------------------------------------------------------
-@@ -93,12 +94,13 @@ AP4_File::~AP4_File()
- void
- AP4_File::ParseStream(AP4_ByteStream&  stream,
-                       AP4_AtomFactory& atom_factory,
--                      bool             moov_only)
-+                      bool             moov_only,
-+                      AP4_Movie*       movie)
- {
-     // parse top-level atoms
-     AP4_Atom*    atom;
-     AP4_Position stream_position;
--    bool         keep_parsing = true;
-+    bool         keep_parsing = movie == 0;
-     while (keep_parsing &&
-            AP4_SUCCEEDED(stream.Tell(stream_position)) && 
-            AP4_SUCCEEDED(atom_factory.CreateAtomFromStream(stream, atom))) {
-diff --git a/Source/C++/Core/Ap4File.h b/Source/C++/Core/Ap4File.h
-index 9375258..2f00187 100644
---- a/Source/C++/Core/Ap4File.h
-+++ b/Source/C++/Core/Ap4File.h
-@@ -101,7 +101,8 @@ public:
-      */
-     AP4_File(AP4_ByteStream&  stream, 
-              AP4_AtomFactory& atom_factory,
--             bool             moov_only);
-+             bool             moov_only,
-+             AP4_Movie*       movie = NULL);
- 
-     /**
-      * Constructs an AP4_File from a stream using the default atom factory
-@@ -161,7 +162,8 @@ private:
-     // methods
-     void ParseStream(AP4_ByteStream&  stream,
-                      AP4_AtomFactory& atom_factory,
--                     bool             moov_only);
-+                     bool             moov_only,
-+                     AP4_Movie*       movie);
-     
-     // members
-     AP4_Movie*    m_Movie;
-diff --git a/Source/C++/Core/Ap4FragmentSampleTable.cpp b/Source/C++/Core/Ap4FragmentSampleTable.cpp
-index 84e5ded..3fbb53e 100644
---- a/Source/C++/Core/Ap4FragmentSampleTable.cpp
-+++ b/Source/C++/Core/Ap4FragmentSampleTable.cpp
-@@ -130,7 +130,7 @@ AP4_FragmentSampleTable::AddTrun(AP4_TrunAtom*   trun,
-         data_offset += trun->GetDataOffset();
-     }         
-     // MS hack
--    if (data_offset == moof_offset) {
-+    if (data_offset < payload_offset) {
-         data_offset = payload_offset;
-     } else {
-         payload_offset = data_offset;
--- 
-2.30.2
-

+ 0 - 219
package/bento4/0004-more-SPS-parameters.patch

@@ -1,219 +0,0 @@
-From 25df596f009514b213c5eaf5d5eb94072391c1be Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 10:22:39 +0200
-Subject: [PATCH] more SPS parameters
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Codecs/Ap4AvcParser.cpp | 100 ++++++++++++++++++++++++++++-
- Source/C++/Codecs/Ap4AvcParser.h   |  22 +++++++
- Source/C++/Core/Ap4Utils.cpp       |   8 +++
- Source/C++/Core/Ap4Utils.h         |   2 +-
- 4 files changed, 129 insertions(+), 3 deletions(-)
-
-diff --git a/Source/C++/Codecs/Ap4AvcParser.cpp b/Source/C++/Codecs/Ap4AvcParser.cpp
-index b95398b..7efb5c9 100644
---- a/Source/C++/Codecs/Ap4AvcParser.cpp
-+++ b/Source/C++/Codecs/Ap4AvcParser.cpp
-@@ -30,7 +30,6 @@
- |   includes
- +---------------------------------------------------------------------*/
- #include "Ap4AvcParser.h"
--#include "Ap4Utils.h"
- 
- /*----------------------------------------------------------------------
- |   debugging
-@@ -123,6 +122,25 @@ AP4_AvcNalParser::SliceTypeName(unsigned int slice_type)
-     }
- }
- 
-+const int SAR[17][2] = {
-+  { 0,  1 },
-+  { 1,  1 },
-+  { 12, 11 },
-+  { 10, 11 },
-+  { 16, 11 },
-+  { 40, 33 },
-+  { 24, 11 },
-+  { 20, 11 },
-+  { 32, 11 },
-+  { 80, 33 },
-+  { 18, 11 },
-+  { 15, 11 },
-+  { 64, 33 },
-+  { 160, 99 },
-+  { 4,  3 },
-+  { 3,  2 },
-+  { 2,  1 },
-+};
- /*----------------------------------------------------------------------
- |   AP4_AvcNalParser::AP4_AvcNalParser
- +---------------------------------------------------------------------*/
-@@ -236,7 +254,28 @@ AP4_AvcSequenceParameterSet::AP4_AvcSequenceParameterSet() :
-     frame_crop_left_offset(0),
-     frame_crop_right_offset(0),
-     frame_crop_top_offset(0),
--    frame_crop_bottom_offset(0)
-+    frame_crop_bottom_offset(0),
-+    vui_parameters_present_flag(0),
-+    aspect_ratio_info_present_flag(0),
-+    aspect_ratio_idc(0),
-+    sar_width(0),
-+    sar_height(0),
-+    overscan_info_present_flag(0),
-+    overscan_appropriate_flag(0),
-+    video_signal_type_present_flag(0),
-+    video_format(0),
-+    video_full_range_flag(0),
-+    colour_description_present_flag(0),
-+    colour_primaries(0),
-+    transfer_characteristics(0),
-+    matrix_coefficients(0),
-+    chroma_loc_info_present_flag(0),
-+    chroma_sample_loc_type_top_field(0),
-+    chroma_sample_loc_type_bottom_field(0),
-+    timing_info_present_flag(0),
-+    num_units_in_tick(0),
-+    time_scale(0),
-+    fixed_frame_rate_flag(0)
- {
-     AP4_SetMemory(scaling_list_4x4, 0, sizeof(scaling_list_4x4));
-     AP4_SetMemory(use_default_scaling_matrix_4x4, 0, sizeof(use_default_scaling_matrix_4x4));
-@@ -372,7 +411,64 @@ AP4_AvcFrameParser::ParseSPS(const unsigned char*         data,
-         sps.frame_crop_top_offset    = ReadGolomb(bits);
-         sps.frame_crop_bottom_offset = ReadGolomb(bits);
-     }
-+    sps.vui_parameters_present_flag = bits.ReadBit();
-+    if (sps.vui_parameters_present_flag) {
-+      sps.aspect_ratio_info_present_flag = bits.ReadBit();
-+      if (sps.aspect_ratio_info_present_flag) {
-+        sps.aspect_ratio_idc = bits.ReadBits(8);
-+        if (sps.aspect_ratio_idc == 0xFF)
-+        {
-+          sps.sar_width = bits.ReadBits(16);
-+          sps.sar_height = bits.ReadBits(16);
-+        }
-+        else if (sps.aspect_ratio_idc < 17)
-+        {
-+          sps.sar_width = SAR[sps.aspect_ratio_idc][0];
-+          sps.sar_height = SAR[sps.aspect_ratio_idc][1];
-+        }
-+      }
-+      sps.overscan_info_present_flag = bits.ReadBit();
-+      if (sps.overscan_info_present_flag)
-+        sps.overscan_appropriate_flag = bits.ReadBit();
-+
-+      sps.video_signal_type_present_flag = bits.ReadBit();
-+      if (sps.video_signal_type_present_flag) {
-+        sps.video_format = bits.ReadBits(3);
-+        sps.video_full_range_flag = bits.ReadBit();
-+        sps.colour_description_present_flag = bits.ReadBit();
-+        if (sps.colour_description_present_flag) {
-+          sps.colour_primaries = bits.ReadBits(8);
-+          sps.transfer_characteristics = bits.ReadBits(8);
-+          sps.matrix_coefficients = bits.ReadBits(8);
-+        }
-+      }
-+
- 
-+      sps.chroma_loc_info_present_flag = bits.ReadBit();
-+      if (sps.chroma_loc_info_present_flag) {
-+        sps.chroma_sample_loc_type_top_field = ReadGolomb(bits);
-+        sps.chroma_sample_loc_type_bottom_field = ReadGolomb(bits);
-+      }
-+
-+      if (bits.PeekBit() && bits.BitsLeft() < 10)
-+        return AP4_SUCCESS;
-+
-+      sps.timing_info_present_flag = bits.ReadBit();
-+      if (sps.timing_info_present_flag) {
-+#if AP4_PLATFORM_BYTE_ORDER == AP4_PLATFORM_BYTE_ORDER_BIG_ENDIAN
-+        sps.num_units_in_tick = bits.ReadBits(32);
-+        sps.time_scale = bits.ReadBits(32);
-+#else
-+        sps.num_units_in_tick = bits.ReadBits(16) << 16;
-+        sps.num_units_in_tick |= bits.ReadBits(16);
-+        sps.time_scale = bits.ReadBits(16) << 16;
-+        sps.time_scale |= bits.ReadBits(16);
-+#endif
-+        if (!sps.num_units_in_tick || !sps.time_scale)
-+          sps.timing_info_present_flag = 0;
-+        sps.fixed_frame_rate_flag = bits.ReadBit();
-+      }
-+    }
-     return AP4_SUCCESS;
- }
- 
-diff --git a/Source/C++/Codecs/Ap4AvcParser.h b/Source/C++/Codecs/Ap4AvcParser.h
-index 8f9cd6c..9f97892 100644
---- a/Source/C++/Codecs/Ap4AvcParser.h
-+++ b/Source/C++/Codecs/Ap4AvcParser.h
-@@ -37,6 +37,7 @@
- #include "Ap4DataBuffer.h"
- #include "Ap4NalParser.h"
- #include "Ap4Array.h"
-+#include "Ap4Utils.h"
- 
- /*----------------------------------------------------------------------
- |   constants
-@@ -131,6 +132,27 @@ struct AP4_AvcSequenceParameterSet {
-     unsigned int frame_crop_right_offset;
-     unsigned int frame_crop_top_offset;
-     unsigned int frame_crop_bottom_offset;
-+    unsigned int vui_parameters_present_flag;
-+    unsigned int aspect_ratio_info_present_flag;
-+    unsigned int aspect_ratio_idc;
-+    unsigned int sar_width;
-+    unsigned int sar_height;
-+    unsigned int overscan_info_present_flag;
-+    unsigned int overscan_appropriate_flag;
-+    unsigned int video_signal_type_present_flag;
-+    unsigned int video_format;
-+    unsigned int video_full_range_flag;
-+    unsigned int colour_description_present_flag;
-+    unsigned int colour_primaries;
-+    unsigned int transfer_characteristics;
-+    unsigned int matrix_coefficients;
-+    unsigned int chroma_loc_info_present_flag;
-+    unsigned int chroma_sample_loc_type_top_field;
-+    unsigned int chroma_sample_loc_type_bottom_field;
-+    unsigned int timing_info_present_flag;
-+    unsigned int num_units_in_tick;
-+    unsigned int time_scale;
-+    unsigned int fixed_frame_rate_flag;
- };
- 
- struct AP4_AvcPictureParameterSet {
-diff --git a/Source/C++/Core/Ap4Utils.cpp b/Source/C++/Core/Ap4Utils.cpp
-index 96def27..6de4dba 100644
---- a/Source/C++/Core/Ap4Utils.cpp
-+++ b/Source/C++/Core/Ap4Utils.cpp
-@@ -581,4 +581,12 @@ AP4_BitReader::SkipBit()
-    }
- }
- 
-+/*----------------------------------------------------------------------
-+|   AP4_BitReader::BitsLeft
-++---------------------------------------------------------------------*/
-+AP4_UI32
-+AP4_BitReader::BitsLeft()
-+{
-+    return (m_Buffer.GetDataSize() - m_Position) * 8 + m_BitsCached;
-+}
- 
-diff --git a/Source/C++/Core/Ap4Utils.h b/Source/C++/Core/Ap4Utils.h
-index 475bff3..e66bafa 100644
---- a/Source/C++/Core/Ap4Utils.h
-+++ b/Source/C++/Core/Ap4Utils.h
-@@ -262,7 +262,7 @@ public:
-     AP4_Result   SkipBytes(AP4_Size byte_count);
-     void         SkipBit();
-     void         SkipBits(unsigned int bit_count);
--
-+    AP4_UI32     BitsLeft();
-     unsigned int GetBitsRead();
- 
- private:
--- 
-2.30.2
-

+ 0 - 96
package/bento4/0005-AVC-extract-VUI-values-from-SPS.patch

@@ -1,96 +0,0 @@
-From 56e0acde44adbc5503da20dd96c31db33f744bd7 Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 10:27:50 +0200
-Subject: [PATCH] AVC extract VUI values from SPS
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Codecs/Ap4AvcParser.cpp | 54 +++++++++++++++++++++++++-----
- Source/C++/Codecs/Ap4AvcParser.h   |  3 +-
- 2 files changed, 47 insertions(+), 10 deletions(-)
-
-diff --git a/Source/C++/Codecs/Ap4AvcParser.cpp b/Source/C++/Codecs/Ap4AvcParser.cpp
-index 7efb5c9..7f4fc34 100644
---- a/Source/C++/Codecs/Ap4AvcParser.cpp
-+++ b/Source/C++/Codecs/Ap4AvcParser.cpp
-@@ -287,18 +287,54 @@ AP4_AvcSequenceParameterSet::AP4_AvcSequenceParameterSet() :
- /*----------------------------------------------------------------------
- |   AP4_AvcSequenceParameterSet::GetInfo
- +---------------------------------------------------------------------*/
--void
-+bool
- AP4_AvcSequenceParameterSet::GetInfo(unsigned int& width, unsigned int& height)
- {
--    width = (pic_width_in_mbs_minus1+1) * 16;
--	height = (2-frame_mbs_only_flag) * (pic_height_in_map_units_minus1+1) * 16;
-+  unsigned int nwidth = (pic_width_in_mbs_minus1+1) * 16;
-+  unsigned int nheight = (2-frame_mbs_only_flag) * (pic_height_in_map_units_minus1+1) * 16;
- 
--    if (frame_cropping_flag) {
--        unsigned int crop_h = 2*(frame_crop_left_offset+frame_crop_right_offset);
--        unsigned int crop_v = 2*(frame_crop_top_offset+frame_crop_bottom_offset)*(2-frame_mbs_only_flag);
--		if (crop_h < width) width   -= crop_h;
--		if (crop_v < height) height -= crop_v;
--	}
-+  if (frame_cropping_flag) {
-+      unsigned int crop_h = 2*(frame_crop_left_offset+frame_crop_right_offset);
-+      unsigned int crop_v = 2*(frame_crop_top_offset+frame_crop_bottom_offset)*(2-frame_mbs_only_flag);
-+      if (crop_h < nwidth) nwidth   -= crop_h;
-+      if (crop_v < nheight) nheight -= crop_v;
-+  }
-+  if (nwidth != width || nheight != height)
-+  {
-+      width = nwidth;
-+      height = nheight;
-+      return true;
-+  }
-+  return false;
-+}
-+
-+/*----------------------------------------------------------------------
-+|   AP4_AvcSequenceParameterSet::GetVUIInfo
-++---------------------------------------------------------------------*/
-+bool
-+AP4_AvcSequenceParameterSet::GetVUIInfo(unsigned int& fps_ticks, unsigned int& fps_scale, float &aspect)
-+{
-+  bool ret(false);
-+  if (timing_info_present_flag && fixed_frame_rate_flag)
-+  {
-+    if (fps_scale != (num_units_in_tick << 1) || fps_ticks != time_scale)
-+    {
-+      fps_scale = num_units_in_tick << 1;
-+      fps_ticks = time_scale;
-+      ret = true;
-+    }
-+  }
-+  unsigned int w, h;
-+  if (aspect_ratio_info_present_flag && GetInfo(w, h))
-+  {
-+    float a((float)(sar_width * w) / (sar_height * h));
-+    if (a != aspect)
-+    {
-+      aspect = a;
-+      ret = true;
-+    }
-+  }
-+  return ret;
- }
- 
- /*----------------------------------------------------------------------
-diff --git a/Source/C++/Codecs/Ap4AvcParser.h b/Source/C++/Codecs/Ap4AvcParser.h
-index 9f97892..431a294 100644
---- a/Source/C++/Codecs/Ap4AvcParser.h
-+++ b/Source/C++/Codecs/Ap4AvcParser.h
-@@ -91,7 +91,8 @@ typedef struct {
- struct AP4_AvcSequenceParameterSet {
-     AP4_AvcSequenceParameterSet();
-     
--    void GetInfo(unsigned int& width, unsigned int& height);
-+    bool GetInfo(unsigned int& width, unsigned int& height);
-+    bool GetVUIInfo(unsigned int& fps_ticks, unsigned int& fps_scale, float &aspect);
-     
-     AP4_DataBuffer raw_bytes;
- 
--- 
-2.30.2
-

+ 0 - 67
package/bento4/0006-Implement-SPS-Frame-parser.patch

@@ -1,67 +0,0 @@
-From 441247d84e8493a49d234fe062100b049956de90 Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 10:34:42 +0200
-Subject: [PATCH] Implement SPS Frame parser
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Codecs/Ap4AvcParser.cpp | 26 ++++++++++++++++++++++++++
- Source/C++/Codecs/Ap4AvcParser.h   |  5 +++++
- 2 files changed, 31 insertions(+)
-
-diff --git a/Source/C++/Codecs/Ap4AvcParser.cpp b/Source/C++/Codecs/Ap4AvcParser.cpp
-index 7f4fc34..cfa841d 100644
---- a/Source/C++/Codecs/Ap4AvcParser.cpp
-+++ b/Source/C++/Codecs/Ap4AvcParser.cpp
-@@ -1112,6 +1112,32 @@ AP4_AvcFrameParser::AppendNalUnitData(const unsigned char* data, unsigned int da
-     m_AccessUnitData.Append(new AP4_DataBuffer(data, data_size));
- }
- 
-+/*----------------------------------------------------------------------
-+|   AP4_AvcFrameParser::Feed
-++---------------------------------------------------------------------*/
-+AP4_Result AP4_AvcFrameParser::ParseFrameForSPS(const AP4_Byte* data, AP4_Size data_size, AP4_UI08 naluLengthSize, AP4_AvcSequenceParameterSet &sps)
-+{
-+  if (data_size < naluLengthSize)
-+    return AP4_ERROR_EOS;
-+
-+  while (data_size > naluLengthSize)
-+  {
-+    AP4_Size nalSize(0);
-+    for (unsigned int i(0); i < naluLengthSize; ++i) { nalSize = (nalSize << 8) + *data++; };
-+    data_size -= naluLengthSize;
-+    if (nalSize > data_size)
-+      return AP4_ERROR_INVALID_PARAMETERS;
-+
-+    if ((*data & 0x1F) == AP4_AVC_NAL_UNIT_TYPE_SPS)
-+    {
-+      AP4_AvcFrameParser fp;
-+      return fp.ParseSPS(data, data_size, sps);
-+    }
-+    data_size -= nalSize;
-+  }
-+  return AP4_SUCCESS;
-+}
-+
- /*----------------------------------------------------------------------
- |   AP4_AvcFrameParser::Feed
- +---------------------------------------------------------------------*/
-diff --git a/Source/C++/Codecs/Ap4AvcParser.h b/Source/C++/Codecs/Ap4AvcParser.h
-index 431a294..99c5320 100644
---- a/Source/C++/Codecs/Ap4AvcParser.h
-+++ b/Source/C++/Codecs/Ap4AvcParser.h
-@@ -258,6 +258,11 @@ public:
-     AP4_AvcFrameParser();
-    ~AP4_AvcFrameParser();
-     
-+   static AP4_Result ParseFrameForSPS(const AP4_Byte* data,
-+     AP4_Size data_size,
-+     AP4_UI08 naluLengthSize,
-+     AP4_AvcSequenceParameterSet &sps);
-+
-     /**
-      * Feed some data to the parser and look for the next NAL Unit.
-      *
--- 
-2.30.2
-

+ 0 - 25
package/bento4/0007-Fix-segfault-when-AP4_Sample-s-seek.patch

@@ -1,25 +0,0 @@
-From b36f3c02a93029308654f77c01c3c04259449c5c Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 10:35:48 +0200
-Subject: [PATCH] Fix segfault when AP4_Sample's seek
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4LinearReader.cpp | 1 +
- 1 file changed, 1 insertion(+)
-
-diff --git a/Source/C++/Core/Ap4LinearReader.cpp b/Source/C++/Core/Ap4LinearReader.cpp
-index 7cc3ebd..61dd60e 100644
---- a/Source/C++/Core/Ap4LinearReader.cpp
-+++ b/Source/C++/Core/Ap4LinearReader.cpp
-@@ -482,6 +482,7 @@ AP4_LinearReader::Advance(bool read_data)
-                 result = buffer->m_Sample->ReadData(buffer->m_Data);
-             }
-             if (AP4_FAILED(result)) {
-+                buffer->m_Sample = nullptr;
-                 delete buffer;
-                 return result;
-             }
--- 
-2.30.2
-

+ 0 - 214
package/bento4/0008-Hack-HBO.patch

@@ -1,214 +0,0 @@
-From 37e54320f2822bdc7eab50eb54b1fc4a452c7f60 Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 11:18:14 +0200
-Subject: [PATCH] Hack HBO
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4FragmentSampleTable.cpp |  8 +++++++-
- Source/C++/Core/Ap4FragmentSampleTable.h   |  1 +
- Source/C++/Core/Ap4LinearReader.cpp        | 20 +++++++++++++-------
- Source/C++/Core/Ap4LinearReader.h          |  3 ++-
- Source/C++/Core/Ap4MovieFragment.cpp       |  5 ++++-
- Source/C++/Core/Ap4MovieFragment.h         |  2 ++
- Source/C++/Core/Ap4Processor.cpp           |  3 ++-
- 7 files changed, 31 insertions(+), 11 deletions(-)
-
-diff --git a/Source/C++/Core/Ap4FragmentSampleTable.cpp b/Source/C++/Core/Ap4FragmentSampleTable.cpp
-index 3fbb53e..cea5c7d 100644
---- a/Source/C++/Core/Ap4FragmentSampleTable.cpp
-+++ b/Source/C++/Core/Ap4FragmentSampleTable.cpp
-@@ -47,6 +47,7 @@ AP4_FragmentSampleTable::AP4_FragmentSampleTable(AP4_ContainerAtom* traf,
-                                                  AP4_ByteStream*    sample_stream,
-                                                  AP4_Position       moof_offset,
-                                                  AP4_Position       mdat_payload_offset,
-+                                                 AP4_UI64           mdat_payload_size,
-                                                  AP4_UI64           dts_origin) :
-     m_Duration(0)
- {
-@@ -73,6 +74,7 @@ AP4_FragmentSampleTable::AP4_FragmentSampleTable(AP4_ContainerAtom* traf,
-     }
-     
-     // process all the trun atoms
-+    AP4_UI32 trun_flags(0);
-     for (AP4_List<AP4_Atom>::Item* item = traf->GetChildren().FirstItem();
-                                    item;
-                                    item = item->GetNext()) {
-@@ -88,9 +90,13 @@ AP4_FragmentSampleTable::AP4_FragmentSampleTable(AP4_ContainerAtom* traf,
-                                             mdat_payload_offset,
-                                             dts_origin);
-                 if (AP4_FAILED(result)) return;
-+                trun_flags |= trun->GetFlags();
-             }
-         }
--    }    
-+    }
-+    // Hack if we have a single sample and default sample size is wrong (hbo ttml)
-+    if (m_Samples.ItemCount() == 1 && (trun_flags & AP4_TRUN_FLAG_SAMPLE_SIZE_PRESENT) == 0)
-+        m_Samples[0].SetSize(mdat_payload_size);
- }
- 
- /*----------------------------------------------------------------------
-diff --git a/Source/C++/Core/Ap4FragmentSampleTable.h b/Source/C++/Core/Ap4FragmentSampleTable.h
-index 67192de..29fa4a9 100644
---- a/Source/C++/Core/Ap4FragmentSampleTable.h
-+++ b/Source/C++/Core/Ap4FragmentSampleTable.h
-@@ -57,6 +57,7 @@ class AP4_FragmentSampleTable : public AP4_SampleTable
-                                      AP4_ByteStream*    sample_stream,
-                                      AP4_Position       moof_offset,
-                                      AP4_Position       mdat_payload_offset, // hack because MS doesn't implement the spec correctly
-+                                     AP4_UI64           mdat_payload_size,
-                                      AP4_UI64           dts_origin=0);
-     virtual ~AP4_FragmentSampleTable();
- 
-diff --git a/Source/C++/Core/Ap4LinearReader.cpp b/Source/C++/Core/Ap4LinearReader.cpp
-index 61dd60e..eabeacf 100644
---- a/Source/C++/Core/Ap4LinearReader.cpp
-+++ b/Source/C++/Core/Ap4LinearReader.cpp
-@@ -309,7 +309,8 @@ AP4_LinearReader::ProcessTrack(AP4_Track* track)
- AP4_Result
- AP4_LinearReader::ProcessMoof(AP4_ContainerAtom* moof, 
-                               AP4_Position       moof_offset, 
--                              AP4_Position       mdat_payload_offset)
-+                              AP4_Position       mdat_payload_offset,
-+                              AP4_UI64 mdat_payload_size)
- {
-     AP4_Result result;
-    
-@@ -334,7 +335,8 @@ AP4_LinearReader::ProcessMoof(AP4_ContainerAtom* moof,
-                                                        ids[j], 
-                                                        m_FragmentStream, 
-                                                        moof_offset, 
--                                                       mdat_payload_offset, 
-+                                                       mdat_payload_offset,
-+                                                       mdat_payload_size,
-                                                        tracker->m_NextDts,
-                                                        sample_table);
-                 if (AP4_FAILED(result)) return result;
-@@ -382,13 +384,11 @@ AP4_LinearReader::AdvanceFragment()
-                     AP4_Position position = 0;
-                     m_FragmentStream->Tell(position);
-         
--                    // process the movie fragment
--                    result = ProcessMoof(moof, position-atom->GetSize(), position+8);
--                    if (AP4_FAILED(result)) return result;
--
-                     // compute where the next fragment will be
-                     AP4_UI32 size;
-                     AP4_UI32 type;
-+                    AP4_UI64 size_64 = 0;
-+
-                     m_FragmentStream->Tell(position);
-                     result = m_FragmentStream->ReadUI32(size);
-                     if (AP4_FAILED(result)) return AP4_SUCCESS; // can't read more
-@@ -397,13 +397,19 @@ AP4_LinearReader::AdvanceFragment()
-                     if (size == 0) {
-                         m_NextFragmentPosition = 0;
-                     } else if (size == 1) {
--                        AP4_UI64 size_64 = 0;
-                         result = m_FragmentStream->ReadUI64(size_64);
-                         if (AP4_FAILED(result)) return AP4_SUCCESS; // can't read more
-                         m_NextFragmentPosition = position+size_64;
-+                        size_64 -= 8;
-                     } else {
-                         m_NextFragmentPosition = position+size;
-+                        size_64 = size;
-                     }
-+
-+                    // process the movie fragment
-+                    result = ProcessMoof(moof, position - atom->GetSize(), position + 8, size_64 - 8);
-+                    if (AP4_FAILED(result)) return result;
-+
-                     return AP4_SUCCESS;
-                 } else {
-                     delete atom;
-diff --git a/Source/C++/Core/Ap4LinearReader.h b/Source/C++/Core/Ap4LinearReader.h
-index 21f4871..929b4e1 100644
---- a/Source/C++/Core/Ap4LinearReader.h
-+++ b/Source/C++/Core/Ap4LinearReader.h
-@@ -161,7 +161,8 @@ protected:
-     virtual AP4_Result ProcessTrack(AP4_Track* track);
-     virtual AP4_Result ProcessMoof(AP4_ContainerAtom* moof, 
-                                    AP4_Position       moof_offset, 
--                                   AP4_Position       mdat_payload_offset);
-+                                   AP4_Position       mdat_payload_offset,
-+                                   AP4_UI64           mdat_payload_size);
-     
-     // methods
-     Tracker*   FindTracker(AP4_UI32 track_id);
-diff --git a/Source/C++/Core/Ap4MovieFragment.cpp b/Source/C++/Core/Ap4MovieFragment.cpp
-index 028d42d..c2ead25 100644
---- a/Source/C++/Core/Ap4MovieFragment.cpp
-+++ b/Source/C++/Core/Ap4MovieFragment.cpp
-@@ -127,6 +127,7 @@ AP4_MovieFragment::CreateSampleTable(AP4_MoovAtom*             moov,
-                                      AP4_ByteStream*           sample_stream,
-                                      AP4_Position              moof_offset,
-                                      AP4_Position              mdat_payload_offset,
-+                                     AP4_UI64                  mdat_payload_size,
-                                      AP4_UI64                  dts_origin,
-                                      AP4_FragmentSampleTable*& sample_table)
- {
-@@ -158,6 +159,7 @@ AP4_MovieFragment::CreateSampleTable(AP4_MoovAtom*             moov,
-                                                    sample_stream,
-                                                    moof_offset,
-                                                    mdat_payload_offset,
-+                                                   mdat_payload_size,
-                                                    dts_origin);
-         return AP4_SUCCESS;
-     }
-@@ -174,9 +176,10 @@ AP4_MovieFragment::CreateSampleTable(AP4_Movie*                movie,
-                                      AP4_ByteStream*           sample_stream,
-                                      AP4_Position              moof_offset,
-                                      AP4_Position              mdat_payload_offset,
-+                                     AP4_UI64                  mdat_payload_size,
-                                      AP4_UI64                  dts_origin,
-                                      AP4_FragmentSampleTable*& sample_table)
- {
-     AP4_MoovAtom* moov = movie?movie->GetMoovAtom():NULL;
--    return CreateSampleTable(moov, track_id, sample_stream, moof_offset, mdat_payload_offset, dts_origin, sample_table);
-+    return CreateSampleTable(moov, track_id, sample_stream, moof_offset, mdat_payload_offset, mdat_payload_size, dts_origin, sample_table);
- }
-diff --git a/Source/C++/Core/Ap4MovieFragment.h b/Source/C++/Core/Ap4MovieFragment.h
-index f829411..de59c42 100644
---- a/Source/C++/Core/Ap4MovieFragment.h
-+++ b/Source/C++/Core/Ap4MovieFragment.h
-@@ -70,6 +70,7 @@ public:
-                                          AP4_ByteStream*           sample_stream,
-                                          AP4_Position              moof_offset,
-                                          AP4_Position              mdat_payload_offset, // hack because MS doesn't implement the spec properly
-+                                         AP4_UI64                  mdat_payload_size,
-                                          AP4_UI64                  dts_origin,
-                                          AP4_FragmentSampleTable*& sample_table);
-     AP4_Result         CreateSampleTable(AP4_Movie*                movie,
-@@ -77,6 +78,7 @@ public:
-                                          AP4_ByteStream*           sample_stream,
-                                          AP4_Position              moof_offset,
-                                          AP4_Position              mdat_payload_offset, // hack because MS doesn't implement the spec properly
-+                                         AP4_UI64                  mdat_payload_size,
-                                          AP4_UI64                  dts_origin,
-                                          AP4_FragmentSampleTable*& sample_table);
-     
-diff --git a/Source/C++/Core/Ap4Processor.cpp b/Source/C++/Core/Ap4Processor.cpp
-index c4e1d78..365d955 100644
---- a/Source/C++/Core/Ap4Processor.cpp
-+++ b/Source/C++/Core/Ap4Processor.cpp
-@@ -156,6 +156,7 @@ AP4_Processor::ProcessFragments(AP4_MoovAtom*              moov,
-         AP4_Atom*          atom        = locator->m_Atom;
-         AP4_UI64           atom_offset = locator->m_Offset;
-         AP4_UI64           mdat_payload_offset = atom_offset+atom->GetSize()+AP4_ATOM_HEADER_SIZE;
-+        AP4_UI64           mdat_payload_size = atom->GetSize();
-         AP4_Sample         sample;
-         AP4_DataBuffer     sample_data_in;
-         AP4_DataBuffer     sample_data_out;
-@@ -226,7 +227,7 @@ AP4_Processor::ProcessFragments(AP4_MoovAtom*              moov,
-             
-             // create a sample table object so we can read the sample data
-             AP4_FragmentSampleTable* sample_table = NULL;
--            result = fragment->CreateSampleTable(moov, tfhd->GetTrackId(), &input, atom_offset, mdat_payload_offset, 0, sample_table);
-+            result = fragment->CreateSampleTable(moov, tfhd->GetTrackId(), &input, atom_offset, mdat_payload_offset, mdat_payload_size, 0, sample_table);
-             if (AP4_FAILED(result)) return result;
-             sample_tables.Append(sample_table);
-             
--- 
-2.30.2
-

+ 0 - 31
package/bento4/0009-Android-32-ftello-fix.patch

@@ -1,31 +0,0 @@
-From f12fbb6f54b8302db2ab7c926a26f9189cf86532 Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 10:41:35 +0200
-Subject: [PATCH] Android 32 ftello fix
-
-ref: https://android.googlesource.com/platform/bionic/+/master/docs/32-bit-abi.md
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4Config.h | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-diff --git a/Source/C++/Core/Ap4Config.h b/Source/C++/Core/Ap4Config.h
-index 422069e..c859a03 100644
---- a/Source/C++/Core/Ap4Config.h
-+++ b/Source/C++/Core/Ap4Config.h
-@@ -141,10 +141,10 @@
- #endif
- 
- #if !defined(AP4_fseek)
--#define AP4_fseek fseeko
-+#define AP4_fseek fseek
- #endif
- #if !defined(AP4_ftell)
--#define AP4_ftell ftello
-+#define AP4_ftell ftell
- #endif
- 
- /* some compilers (ex: MSVC 8) deprecate those, so we rename them */
--- 
-2.30.2
-

+ 0 - 30
package/bento4/0010-Dazn-sample-duration-workaround.patch

@@ -1,30 +0,0 @@
-From 10f931c703c68b4fc856e09788dfe64579252bb8 Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 10:48:36 +0200
-Subject: [PATCH] Dazn sample duration workaround
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4TrunAtom.cpp | 6 ++++++
- 1 file changed, 6 insertions(+)
-
-diff --git a/Source/C++/Core/Ap4TrunAtom.cpp b/Source/C++/Core/Ap4TrunAtom.cpp
-index c51f21d..77b7c6d 100644
---- a/Source/C++/Core/Ap4TrunAtom.cpp
-+++ b/Source/C++/Core/Ap4TrunAtom.cpp
-@@ -128,6 +128,12 @@ AP4_TrunAtom::AP4_TrunAtom(AP4_UI32        size,
-     for (unsigned int i=0; i<sample_count; i++) {
-         if (flags & AP4_TRUN_FLAG_SAMPLE_DURATION_PRESENT) {
-             stream.ReadUI32(m_Entries[i].sample_duration);
-+            // Workaround for dazn streams, which provide 24 -> 1 sequences
-+            if (i && m_Entries[i].sample_duration == 1 && m_Entries[i - 1].sample_duration > 1)
-+            {
-+                m_Entries[i].sample_duration = m_Entries[i - 1].sample_duration >> 1;
-+                m_Entries[i - 1].sample_duration -= m_Entries[i].sample_duration;
-+            }
-             --record_fields_count;
-         }
-         if (flags & AP4_TRUN_FLAG_SAMPLE_SIZE_PRESENT) {
--- 
-2.30.2
-

+ 0 - 179
package/bento4/0011-Add-argument-to-reuse-single-sample-decrypter.patch

@@ -1,179 +0,0 @@
-From 7bb5120b52814e4471a165e295acdc6b6155259e Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 11:01:12 +0200
-Subject: [PATCH] Add argument to reuse single sample decrypter
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4CommonEncryption.cpp | 36 ++++++++++++++++++-------
- Source/C++/Core/Ap4CommonEncryption.h   |  8 +++++-
- Source/C++/Core/Ap4Protection.cpp       |  3 ++-
- 3 files changed, 35 insertions(+), 12 deletions(-)
-
-diff --git a/Source/C++/Core/Ap4CommonEncryption.cpp b/Source/C++/Core/Ap4CommonEncryption.cpp
-index 5308200..cb5c328 100644
---- a/Source/C++/Core/Ap4CommonEncryption.cpp
-+++ b/Source/C++/Core/Ap4CommonEncryption.cpp
-@@ -1967,6 +1967,7 @@ AP4_CencSampleDecrypter::Create(AP4_ProtectedSampleDescription* sample_descripti
-                                 const AP4_UI08*                 key, 
-                                 AP4_Size                        key_size,
-                                 AP4_BlockCipherFactory*         block_cipher_factory,
-+                                AP4_CencSingleSampleDecrypter*  singlesample_decrypter,
-                                 AP4_CencSampleDecrypter*&       decrypter)
- {
-     AP4_SaioAtom* saio = NULL;
-@@ -1982,6 +1983,7 @@ AP4_CencSampleDecrypter::Create(AP4_ProtectedSampleDescription* sample_descripti
-                   saio,
-                   saiz,
-                   sample_encryption_atom,
-+                  singlesample_decrypter,
-                   decrypter);
- }
- 
-@@ -1999,6 +2001,7 @@ AP4_CencSampleDecrypter::Create(AP4_ProtectedSampleDescription* sample_descripti
-                                 AP4_SaioAtom*&                  saio,
-                                 AP4_SaizAtom*&                  saiz,
-                                 AP4_CencSampleEncryption*&      sample_encryption_atom,
-+                                AP4_CencSingleSampleDecrypter*  singlesample_decrypter,
-                                 AP4_CencSampleDecrypter*&       decrypter)
- {
-     // default return values
-@@ -2032,6 +2035,7 @@ AP4_CencSampleDecrypter::Create(AP4_ProtectedSampleDescription* sample_descripti
-                   key_size,
-                   block_cipher_factory,
-                   reset_iv_at_each_subsample,
-+                  singlesample_decrypter,
-                   decrypter);
- }
- 
-@@ -2045,6 +2049,7 @@ AP4_CencSampleDecrypter::Create(AP4_CencSampleInfoTable*  sample_info_table,
-                                 AP4_Size                  key_size,
-                                 AP4_BlockCipherFactory*   block_cipher_factory,
-                                 bool                      reset_iv_at_each_subsample,
-+                                AP4_CencSingleSampleDecrypter* singlesample_decrypter,
-                                 AP4_CencSampleDecrypter*& decrypter)
- {
-     // default return value
-@@ -2074,15 +2079,23 @@ AP4_CencSampleDecrypter::Create(AP4_CencSampleInfoTable*  sample_info_table,
- 
-     // create a single-sample decrypter
-     AP4_CencSingleSampleDecrypter* single_sample_decrypter = NULL;
--    AP4_Result result = AP4_CencSingleSampleDecrypter::Create(cipher_type,
--                                                              key,
--                                                              key_size,
--                                                              sample_info_table->GetCryptByteBlock(),
--                                                              sample_info_table->GetSkipByteBlock(),
--                                                              block_cipher_factory,
--                                                              reset_iv_at_each_subsample,
--                                                              single_sample_decrypter);
--    if (AP4_FAILED(result)) return result;
-+    if (!singlesample_decrypter)
-+    {
-+        AP4_Result result = AP4_CencSingleSampleDecrypter::Create(cipher_type,
-+                                                                  key,
-+                                                                  key_size,
-+                                                                  sample_info_table->GetCryptByteBlock(),
-+                                                                  sample_info_table->GetSkipByteBlock(),
-+                                                                  block_cipher_factory,
-+                                                                  reset_iv_at_each_subsample,
-+                                                                  single_sample_decrypter);
-+
-+        if (AP4_FAILED(result)) return result;
-+    }
-+    else
-+    {
-+        single_sample_decrypter = singlesample_decrypter;
-+    }
- 
-     // create the decrypter
-     decrypter = new AP4_CencSampleDecrypter(single_sample_decrypter, sample_info_table);
-@@ -2333,7 +2346,9 @@ AP4_CencFragmentDecrypter::ProcessSample(AP4_DataBuffer& data_in,
- |   AP4_CencDecryptingProcessor::AP4_CencDecryptingProcessor
- +---------------------------------------------------------------------*/
- AP4_CencDecryptingProcessor::AP4_CencDecryptingProcessor(const AP4_ProtectionKeyMap* key_map, 
--                                                         AP4_BlockCipherFactory*     block_cipher_factory) :
-+                                                         AP4_BlockCipherFactory*     block_cipher_factory,
-+                                                         AP4_CencSingleSampleDecrypter *cenc_singlesample_decrypter) :
-+    m_CencSingleSampleDecrypter(cenc_singlesample_decrypter),
-     m_KeyMap(key_map)
- {
-     if (block_cipher_factory) {
-@@ -2483,6 +2498,7 @@ AP4_CencDecryptingProcessor::CreateFragmentHandler(AP4_TrakAtom*      trak,
-         saio,
-         saiz,
-         sample_encryption_atom,
-+        m_CencSingleSampleDecrypter,
-         sample_decrypter);
-     if (AP4_FAILED(result)) return NULL;
-     
-diff --git a/Source/C++/Core/Ap4CommonEncryption.h b/Source/C++/Core/Ap4CommonEncryption.h
-index 580de66..a6b20ce 100644
---- a/Source/C++/Core/Ap4CommonEncryption.h
-+++ b/Source/C++/Core/Ap4CommonEncryption.h
-@@ -48,6 +48,7 @@ class AP4_SaioAtom;
- class AP4_CencSampleInfoTable;
- class AP4_AvcFrameParser;
- class AP4_HevcFrameParser;
-+class AP4_CencSingleSampleDecrypter;
- 
- /*----------------------------------------------------------------------
- |   constants
-@@ -654,7 +655,8 @@ class AP4_CencDecryptingProcessor : public AP4_Processor
- public:
-     // constructor
-     AP4_CencDecryptingProcessor(const AP4_ProtectionKeyMap* key_map, 
--                                AP4_BlockCipherFactory*     block_cipher_factory = NULL);
-+                                AP4_BlockCipherFactory*     block_cipher_factory = NULL,
-+                                AP4_CencSingleSampleDecrypter* cenc_singlesample_decrypter = NULL);
- 
-     // AP4_Processor methods
-     virtual AP4_Processor::TrackHandler*    CreateTrackHandler(AP4_TrakAtom* trak);
-@@ -670,6 +672,7 @@ protected:
- 
-     // members
-     AP4_BlockCipherFactory*     m_BlockCipherFactory;
-+    AP4_CencSingleSampleDecrypter* m_CencSingleSampleDecrypter;
-     const AP4_ProtectionKeyMap* m_KeyMap;
- };
- 
-@@ -752,6 +755,7 @@ public:
-                              AP4_SaioAtom*&                  saio_atom,              // [out]
-                              AP4_SaizAtom*&                  saiz_atom,              // [out]
-                              AP4_CencSampleEncryption*&      sample_encryption_atom, // [out]
-+                             AP4_CencSingleSampleDecrypter*  singlesample_decrypter,
-                              AP4_CencSampleDecrypter*&       decrypter);
- 
-     static AP4_Result Create(AP4_ProtectedSampleDescription* sample_description, 
-@@ -761,6 +765,7 @@ public:
-                              const AP4_UI08*                 key, 
-                              AP4_Size                        key_size,
-                              AP4_BlockCipherFactory*         block_cipher_factory,
-+                             AP4_CencSingleSampleDecrypter*  singlesample_decrypter,
-                              AP4_CencSampleDecrypter*&       decrypter);
- 
-     static AP4_Result Create(AP4_CencSampleInfoTable*  sample_info_table,
-@@ -769,6 +774,7 @@ public:
-                              AP4_Size                  key_size,
-                              AP4_BlockCipherFactory*   block_cipher_factory,
-                              bool                      reset_iv_at_each_subsample,
-+                             AP4_CencSingleSampleDecrypter* singlesample_decrypter,
-                              AP4_CencSampleDecrypter*& decrypter);
-     
-     // methods
-diff --git a/Source/C++/Core/Ap4Protection.cpp b/Source/C++/Core/Ap4Protection.cpp
-index fd421e9..80bb9f0 100644
---- a/Source/C++/Core/Ap4Protection.cpp
-+++ b/Source/C++/Core/Ap4Protection.cpp
-@@ -812,7 +812,8 @@ AP4_SampleDecrypter::Create(AP4_ProtectedSampleDescription* sample_description,
-                                                                 aux_info_data_offset,
-                                                                 key, 
-                                                                 key_size, 
--                                                                block_cipher_factory, 
-+                                                                block_cipher_factory,
-+                                                                NULL,
-                                                                 decrypter);
-             if (AP4_FAILED(result)) return NULL;
-             return decrypter;
--- 
-2.30.2
-

+ 0 - 54
package/bento4/0012-Static-ReadGolomb-SignedGolomb.patch

@@ -1,54 +0,0 @@
-From 91e148a9c53811447d35c36d9f11f767d49477a0 Mon Sep 17 00:00:00 2001
-From: Glenn Guy <glennguy83@gmail.com>
-Date: Thu, 22 Jul 2021 11:04:26 +0200
-Subject: [PATCH] Static ReadGolomb/SignedGolomb
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Codecs/Ap4AvcParser.cpp | 8 ++++----
- Source/C++/Codecs/Ap4AvcParser.h   | 3 +++
- 2 files changed, 7 insertions(+), 4 deletions(-)
-
-diff --git a/Source/C++/Codecs/Ap4AvcParser.cpp b/Source/C++/Codecs/Ap4AvcParser.cpp
-index cfa841d..a17b698 100644
---- a/Source/C++/Codecs/Ap4AvcParser.cpp
-+++ b/Source/C++/Codecs/Ap4AvcParser.cpp
-@@ -191,8 +191,8 @@ AP4_AvcFrameParser::~AP4_AvcFrameParser()
- /*----------------------------------------------------------------------
- |   ReadGolomb
- +---------------------------------------------------------------------*/
--static unsigned int
--ReadGolomb(AP4_BitReader& bits)
-+unsigned int
-+AP4_AvcFrameParser::ReadGolomb(AP4_BitReader& bits)
- {
-     unsigned int leading_zeros = 0;
-     while (bits.ReadBit() == 0) {
-@@ -209,8 +209,8 @@ ReadGolomb(AP4_BitReader& bits)
- /*----------------------------------------------------------------------
- |   SignedGolomb
- +---------------------------------------------------------------------*/
--static int
--SignedGolomb(unsigned int code_num)
-+int
-+AP4_AvcFrameParser::SignedGolomb(unsigned int code_num)
- {
-     if (code_num % 2) {
-         return (code_num+1)/2;
-diff --git a/Source/C++/Codecs/Ap4AvcParser.h b/Source/C++/Codecs/Ap4AvcParser.h
-index 99c5320..0c74c0e 100644
---- a/Source/C++/Codecs/Ap4AvcParser.h
-+++ b/Source/C++/Codecs/Ap4AvcParser.h
-@@ -321,6 +321,9 @@ public:
-                                 unsigned int                  nal_ref_idc,
-                                 AP4_AvcSliceHeader&           slice_header);
- 
-+    static unsigned int ReadGolomb(AP4_BitReader& bits);
-+    static int SignedGolomb(unsigned int code_num);
-+
- private:
-     // methods
-     bool SameFrame(unsigned int nal_unit_type_1, unsigned int nal_ref_idc_1, AP4_AvcSliceHeader& sh1,
--- 
-2.30.2
-

+ 0 - 40
package/bento4/0013-Add-GetChannels-method.patch

@@ -1,40 +0,0 @@
-From 15e31e3641e4f85475984bf4d9ebf8ae47303a8a Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 11:07:13 +0200
-Subject: [PATCH] Add GetChannels method
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4Dac3Atom.cpp | 6 ++++++
- Source/C++/Core/Ap4Dac3Atom.h   | 1 +
- 2 files changed, 7 insertions(+)
-
-diff --git a/Source/C++/Core/Ap4Dac3Atom.cpp b/Source/C++/Core/Ap4Dac3Atom.cpp
-index 80a511e..a9ea78a 100644
---- a/Source/C++/Core/Ap4Dac3Atom.cpp
-+++ b/Source/C++/Core/Ap4Dac3Atom.cpp
-@@ -143,3 +143,9 @@ AP4_Dac3Atom::InspectFields(AP4_AtomInspector& inspector)
-     inspector.AddField("lfeon", m_StreamInfo.lfeon);
-     return AP4_SUCCESS;
- }
-+
-+AP4_UI08 AP4_Dac3Atom::GetChannels() const
-+{
-+  static const AP4_UI08 CC[] = { 2, 1, 2, 3, 3, 4, 4, 5 };
-+  return CC[m_StreamInfo.acmod] + m_StreamInfo.lfeon;
-+}
-diff --git a/Source/C++/Core/Ap4Dac3Atom.h b/Source/C++/Core/Ap4Dac3Atom.h
-index 2532ef2..78e2875 100644
---- a/Source/C++/Core/Ap4Dac3Atom.h
-+++ b/Source/C++/Core/Ap4Dac3Atom.h
-@@ -73,6 +73,7 @@ public:
-     const AP4_DataBuffer& GetRawBytes()   const { return m_RawBytes;   }
-     unsigned int          GetDataRate()   const { return m_DataRate;   }
-     const StreamInfo&     GetStreamInfo() const { return m_StreamInfo; }
-+    AP4_UI08              GetChannels() const;
- 
- private:
-     // methods
--- 
-2.30.2
-

+ 0 - 59
package/bento4/0014-Implemented-GetSampleIndexForTimeStamp-GetNearestSyn.patch

@@ -1,59 +0,0 @@
-From f673675843144785658a010bab455972d83af004 Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 11:09:37 +0200
-Subject: [PATCH] Implemented
- GetSampleIndexForTimeStamp/GetNearestSyncSampleIndex
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4FragmentSampleTable.cpp | 25 ++++++++++++++++++----
- 1 file changed, 21 insertions(+), 4 deletions(-)
-
-diff --git a/Source/C++/Core/Ap4FragmentSampleTable.cpp b/Source/C++/Core/Ap4FragmentSampleTable.cpp
-index cea5c7d..1c62f24 100644
---- a/Source/C++/Core/Ap4FragmentSampleTable.cpp
-+++ b/Source/C++/Core/Ap4FragmentSampleTable.cpp
-@@ -297,10 +297,19 @@ AP4_FragmentSampleTable::GetSampleChunkPosition(AP4_Ordinal  sample_index,
- |   AP4_FragmentSampleTable::GetSampleIndexForTimeStamp
- +---------------------------------------------------------------------*/
- AP4_Result 
--AP4_FragmentSampleTable::GetSampleIndexForTimeStamp(AP4_UI64     /*ts*/, 
-+AP4_FragmentSampleTable::GetSampleIndexForTimeStamp(AP4_UI64 ts, 
-                                                     AP4_Ordinal& sample_index)
- {
--    sample_index = 0; // TODO
-+    if (!m_Samples.ItemCount())
-+        return AP4_ERROR_NOT_ENOUGH_DATA;
-+
-+    sample_index = 0;
-+    while (sample_index < m_Samples.ItemCount() && m_Samples[sample_index].GetCts() + m_Samples[sample_index].GetDuration() < ts)
-+        ++sample_index;
-+
-+    if (sample_index == m_Samples.ItemCount())
-+        return AP4_ERROR_NOT_ENOUGH_DATA;
-+
-     return AP4_SUCCESS;
- }
- 
-@@ -308,8 +317,16 @@ AP4_FragmentSampleTable::GetSampleIndexForTimeStamp(AP4_UI64     /*ts*/,
- |   AP4_FragmentSampleTable::GetNearestSyncSampleIndex
- +---------------------------------------------------------------------*/
- AP4_Ordinal  
--AP4_FragmentSampleTable::GetNearestSyncSampleIndex(AP4_Ordinal /*sample_index*/, bool /*before*/)
-+AP4_FragmentSampleTable::GetNearestSyncSampleIndex(AP4_Ordinal sample_index, bool before)
- {
--    return 0; // TODO
-+    if (sample_index >= m_Samples.ItemCount())
-+        return sample_index;
-+
-+    AP4_Ordinal end(before ? 0 : m_Samples.ItemCount());
-+
-+    while (sample_index != end && !m_Samples[sample_index].IsSync())
-+        sample_index = sample_index + (before ? -1 : 1);
-+
-+    return sample_index;
- }
- 
--- 
-2.30.2
-

+ 0 - 43
package/bento4/0015-Avoid-set-next-fragment-position.patch

@@ -1,43 +0,0 @@
-From 0658d38be16c88585b248b237895b4dc63f28e79 Mon Sep 17 00:00:00 2001
-From: peak3d <pfau@peak3d.de>
-Date: Thu, 22 Jul 2021 11:23:13 +0200
-Subject: [PATCH] Avoid set next fragment position
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4LinearReader.cpp | 12 +++++++-----
- 1 file changed, 7 insertions(+), 5 deletions(-)
-
-diff --git a/Source/C++/Core/Ap4LinearReader.cpp b/Source/C++/Core/Ap4LinearReader.cpp
-index eabeacf..61c3a9d 100644
---- a/Source/C++/Core/Ap4LinearReader.cpp
-+++ b/Source/C++/Core/Ap4LinearReader.cpp
-@@ -54,8 +54,8 @@ AP4_LinearReader::AP4_LinearReader(AP4_Movie&      movie,
-     m_HasFragments = movie.HasFragments();
-     if (fragment_stream) {
-         fragment_stream->AddReference();
--        fragment_stream->Tell(m_CurrentFragmentPosition);
--        m_NextFragmentPosition = m_CurrentFragmentPosition;
-+        //fragment_stream->Tell(m_CurrentFragmentPosition);
-+        //m_NextFragmentPosition = m_CurrentFragmentPosition;
-     }
- }
- 
-@@ -360,9 +360,11 @@ AP4_LinearReader::AdvanceFragment()
-     AP4_Result result;
-      
-     // go the the start of the next fragment
--    result = m_FragmentStream->Seek(m_NextFragmentPosition);
--    if (AP4_FAILED(result)) return result;
--    m_CurrentFragmentPosition = m_NextFragmentPosition;
-+    if (m_NextFragmentPosition) {
-+        result = m_FragmentStream->Seek(m_NextFragmentPosition);
-+        if (AP4_FAILED(result)) return result;
-+        m_CurrentFragmentPosition = m_NextFragmentPosition;
-+    }
- 
-     // read atoms until we find a moof
-     assert(m_HasFragments);
--- 
-2.30.2
-

+ 0 - 27
package/bento4/0016-Fix-segfault-in-AP4_LinearReader-ProcessMoof.patch

@@ -1,27 +0,0 @@
-From e5b37c1e0a7a84fdc7b403c5e30a5e93706104b8 Mon Sep 17 00:00:00 2001
-From: Dobroslaw Kijowski <dobo90@gmail.com>
-Date: Tue, 19 Oct 2021 14:17:11 +0200
-Subject: [PATCH] Fix segfault in Ap4LinearReader ProcessMoof
-
-Downloaded from https://github.com/xbmc/inputstream.adaptive/pull/856
-
-Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
----
- Source/C++/Core/Ap4LinearReader.cpp | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-diff --git a/Source/C++/Core/Ap4LinearReader.cpp b/Source/C++/Core/Ap4LinearReader.cpp
-index 61c3a9d..2464865 100644
---- a/Source/C++/Core/Ap4LinearReader.cpp
-+++ b/Source/C++/Core/Ap4LinearReader.cpp
-@@ -329,7 +329,7 @@ AP4_LinearReader::ProcessMoof(AP4_ContainerAtom* moof,
-         tracker->m_SampleTable = NULL;
-         tracker->m_NextSampleIndex = 0;
-         for (unsigned int j=0; j<ids.ItemCount(); j++) {
--            if (ids[j] == tracker->m_Track->GetId()) {
-+            if (ids.ItemCount()==1 || ids[j] == tracker->m_Track->GetId()) {
-                 AP4_FragmentSampleTable* sample_table = NULL;
-                 result = m_Fragment->CreateSampleTable(&m_Movie, 
-                                                        ids[j], 
--- 
-2.33.1

+ 1 - 1
package/bento4/bento4.hash

@@ -1,3 +1,3 @@
 # Locally calculated
-sha256  9f3eb912207d7ed9c1e6e05315083404b32a11f8aacd604a9b2bdcb10bf79eb9  bento4-1.6.0-639.tar.gz
+sha256  8afa4ae07a7629a65e0d5014750960ced33a8771d363652f3913261fb5d0c84f  bento4-1.6.0-639-6-Nexus.tar.gz
 sha256  7daae92c8628ada28def8d096fe2fde298b72ec3e2d64a3c408afce38edb361b  Documents/LICENSE.txt

+ 2 - 2
package/bento4/bento4.mk

@@ -4,8 +4,8 @@
 #
 ################################################################################
 
-BENTO4_VERSION = 1.6.0-639
-BENTO4_SITE = $(call github,axiomatic-systems,Bento4,v$(BENTO4_VERSION))
+BENTO4_VERSION = 1.6.0-639-6-Nexus
+BENTO4_SITE = $(call github,xbmc,Bento4,$(BENTO4_VERSION))
 BENTO4_INSTALL_STAGING = YES
 BENTO4_LICENSE = GPL-2.0+
 BENTO4_LICENSE_FILES = Documents/LICENSE.txt