aboutsummaryrefslogtreecommitdiff
path: root/emulators/dosbox-x/files/patch-fix-ffmpeg8
diff options
context:
space:
mode:
Diffstat (limited to 'emulators/dosbox-x/files/patch-fix-ffmpeg8')
-rw-r--r--emulators/dosbox-x/files/patch-fix-ffmpeg888
1 files changed, 88 insertions, 0 deletions
diff --git a/emulators/dosbox-x/files/patch-fix-ffmpeg8 b/emulators/dosbox-x/files/patch-fix-ffmpeg8
new file mode 100644
index 000000000000..7c1782a7b3bd
--- /dev/null
+++ b/emulators/dosbox-x/files/patch-fix-ffmpeg8
@@ -0,0 +1,88 @@
+Fix build with FFmpeg 8
+https://github.com/joncampbell123/dosbox-x/issues/5803
+
+--- src/hardware/hardware.cpp.orig 2025-08-25 08:00:00 UTC
++++ src/hardware/hardware.cpp
+@@ -123,20 +123,18 @@ void ffmpeg_closeall() {
+ ffmpeg_avformat_began = false;
+ }
+ avio_close(ffmpeg_fmt_ctx->pb);
+- if (ffmpeg_vid_ctx != NULL) avcodec_close(ffmpeg_vid_ctx);
+- if (ffmpeg_aud_ctx != NULL) avcodec_close(ffmpeg_aud_ctx);
++ if (ffmpeg_vid_ctx != NULL) avcodec_free_context(&ffmpeg_vid_ctx);
++ if (ffmpeg_aud_ctx != NULL) avcodec_free_context(&ffmpeg_aud_ctx);
+ avformat_free_context(ffmpeg_fmt_ctx);
+ ffmpeg_fmt_ctx = NULL;
+ ffmpeg_vid_ctx = NULL; // NTS: avformat_free_context() freed this for us, don't free again
+ ffmpeg_aud_ctx = NULL; // NTS: avformat_free_context() freed this for us, don't free again
+ }
+ if (ffmpeg_vid_ctx != NULL) {
+- avcodec_close(ffmpeg_vid_ctx);
+ avcodec_free_context(&ffmpeg_vid_ctx);
+ ffmpeg_vid_ctx = NULL;
+ }
+ if (ffmpeg_aud_ctx != NULL) {
+- avcodec_close(ffmpeg_aud_ctx);
+ avcodec_free_context(&ffmpeg_aud_ctx);
+ ffmpeg_aud_ctx = NULL;
+ }
+@@ -171,7 +169,6 @@ void ffmpeg_audio_frame_send() {
+
+ if (!pkt) E_Exit("Error: Unable to alloc packet");
+
+- ffmpeg_aud_frame->key_frame = 1;
+ ffmpeg_aud_frame->pts = (int64_t)ffmpeg_audio_sample_counter;
+ r=avcodec_send_frame(ffmpeg_aud_ctx,ffmpeg_aud_frame);
+ if (r < 0 && r != AVERROR(EAGAIN))
+@@ -426,7 +423,6 @@ void ffmpeg_reopen_video(double fps,const int bpp) {
+
+ void ffmpeg_reopen_video(double fps,const int bpp) {
+ if (ffmpeg_vid_ctx != NULL) {
+- avcodec_close(ffmpeg_vid_ctx);
+ avcodec_free_context(&ffmpeg_vid_ctx);
+ ffmpeg_vid_ctx = NULL;
+ }
+@@ -1271,7 +1267,7 @@ skip_shot:
+ ffmpeg_aud_ctx->sample_rate = (int)capture.video.audiorate;
+ ffmpeg_aud_ctx->flags = 0; // do not use global headers
+ ffmpeg_aud_ctx->bit_rate = 320000;
+- ffmpeg_aud_ctx->profile = FF_PROFILE_AAC_LOW;
++ // ffmpeg_aud_ctx->profile = FF_PROFILE_AAC_LOW;
+
+ #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,24,100)
+ ffmpeg_aud_ctx->channels = 2;
+@@ -1531,7 +1527,6 @@ skip_shot:
+
+ // encode it
+ ffmpeg_vid_frame->pts = (int64_t)capture.video.frames; // or else libx264 complains about non-monotonic timestamps
+- ffmpeg_vid_frame->key_frame = ((capture.video.frames % 15) == 0)?1:0;
+
+ r=avcodec_send_frame(ffmpeg_vid_ctx,ffmpeg_vid_frame);
+ if (r < 0 && r != AVERROR(EAGAIN))
+@@ -1768,7 +1763,7 @@ skip_mt_wav:
+ }
+
+ #pragma pack(push,1)
+-typedef struct pcap_hdr_struct_t {
++typedef struct {
+ uint32_t magic_number; /* magic number */
+ uint16_t version_major; /* major version number */
+ uint16_t version_minor; /* minor version number */
+@@ -1776,14 +1771,14 @@ typedef struct pcap_hdr_struct_t {
+ uint32_t sigfigs; /* accuracy of timestamps */
+ uint32_t snaplen; /* max length of captured packets, in octets */
+ uint32_t network; /* data link type */
+-};
++} pcap_hdr_struct_t;
+
+-typedef struct pcaprec_hdr_struct_t {
++typedef struct {
+ uint32_t ts_sec; /* timestamp seconds */
+ uint32_t ts_usec; /* timestamp microseconds */
+ uint32_t incl_len; /* number of octets of packet saved in file */
+ uint32_t orig_len; /* actual length of packet */
+-};
++} pcaprec_hdr_struct_t;
+ #pragma pack(pop)
+
+ void Capture_WritePacket(bool /*send*/,const unsigned char *buf,size_t len) {