guix/gnu/packages/patches/stepmania-ffmpeg-compat.patch
Liliana Marie Prikler 65f57fc74f
gnu: stepmania: Fix compatibility with ffmpeg 8.
This is a follow-up to 3191948625, which fixed
compile-time compatibility with newer ffmpeg, but introduced runtime crashes.

* gnu/packages/games.scm (stepmania): Replace ffmpeg-6 with ffmpeg.
* gnu/packages/patches/stepmania-ffmpeg-compat.patch: Add hunks for FFMPEG 8
compatibility.
Initialize m_pStreamCodec to nullptr and reinitialize it in
MovieDecoder_FFMpeg::OpenCodec.
2026-01-03 15:18:56 +01:00

88 lines
3.1 KiB
Diff

See [6], [7], and [8].
[6] https://github.com/Tatsh/tatsh-overlay/blob/master/games-arcade/stepmania/files/stepmania-ffmpeg-6.patch
[7] https://github.com/Tatsh/tatsh-overlay/blob/master/games-arcade/stepmania/files/stepmania-ffmpeg-7.patch
[8] https://github.com/Tatsh/tatsh-overlay/blob/master/games-arcade/stepmania/files/stepmania-ffmpeg-8.patch
Hunk #2 is not present in any of these patches, but prevents a segmentation
fault due to freeing unallocated memory.
Hunk #4 was likewise altered to prevent nullptr dereferences.
diff --git a/src/arch/MovieTexture/MovieTexture_FFMpeg.cpp b/src/arch/MovieTexture/MovieTexture_FFMpeg.cpp
index 935ddf324b0..d4eed01d599 100644
--- a/src/arch/MovieTexture/MovieTexture_FFMpeg.cpp
+++ b/src/arch/MovieTexture/MovieTexture_FFMpeg.cpp
@@ -9,6 +9,10 @@
#include <cerrno>
+#if LIBAVCODEC_VERSION_MAJOR > 59
+#define frame_number frame_num
+#endif
+
static void FixLilEndian()
{
#if defined(ENDIAN_LITTLE)
@@ -118,5 +118,6 @@
m_buffer = NULL;
m_fctx = nullptr;
m_pStream = nullptr;
+ m_pStreamCodec = nullptr;
m_iCurrentPacketOffset = -1;
m_Frame = avcodec::av_frame_alloc();
@@ -405,7 +405,7 @@ void MovieTexture_FFMpeg::RegisterProtocols()
return;
Done = true;
-#if !FF_API_NEXT
+#if LIBAVCODEC_VERSION_MAJOR < 58
avcodec::avcodec_register_all();
avcodec::av_register_all();
#endif
@@ -508,6 +508,16 @@ RString MovieDecoder_FFMpeg::OpenCodec()
+#if LIBAVCODEC_VERSION_MAJOR < 58
if( m_pStreamCodec->codec )
avcodec::avcodec_close( m_pStreamCodec );
+#else
+ if ( m_pStreamCodec )
+ {
+ avcodec::avcodec_free_context ( &m_pStreamCodec );
+ m_pStreamCodec = avcodec::avcodec_alloc_context3(nullptr);
+ if (avcodec::avcodec_parameters_to_context(m_pStreamCodec, m_pStream->codecpar) < 0)
+ return ssprintf("Could not get context from parameters");
+ }
+#endif
- avcodec::AVCodec *pCodec = avcodec::avcodec_find_decoder( m_pStreamCodec->codec_id );
+ const avcodec::AVCodec *pCodec = avcodec::avcodec_find_decoder( m_pStreamCodec->codec_id );
if( pCodec == nullptr )
return ssprintf( "Couldn't find decoder %i", m_pStreamCodec->codec_id );
@@ -535,7 +535,7 @@ void MovieDecoder_FFMpeg::Close()
{
if( m_pStream && m_pStreamCodec->codec )
{
- avcodec::avcodec_close( m_pStreamCodec );
+ avcodec::avcodec_free_context( &m_pStreamCodec );
m_pStream = nullptr;
}
diff --git a/src/arch/MovieTexture/MovieTexture_FFMpeg.h b/src/arch/MovieTexture/MovieTexture_FFMpeg.h
index c092b765fc2..99f5ffcb1be 100644
--- a/src/arch/MovieTexture/MovieTexture_FFMpeg.h
+++ b/src/arch/MovieTexture/MovieTexture_FFMpeg.h
@@ -13,6 +13,7 @@ namespace avcodec
#include <libavformat/avformat.h>
#include <libswscale/swscale.h>
#include <libavutil/pixdesc.h>
+ #include <libavcodec/avcodec.h>
#if LIBAVCODEC_VERSION_MAJOR >= 58
#define av_free_packet av_packet_unref
@@ -32,7 +32,7 @@ namespace avcodec
};
#define STEPMANIA_FFMPEG_BUFFER_SIZE 4096
-static const int sws_flags = SWS_BICUBIC; // XXX: Reasonable default?
+static const int sws_flags = avcodec::SWS_BICUBIC; // XXX: Reasonable default?
class MovieTexture_FFMpeg: public MovieTexture_Generic
{