Package: release.debian.org Severity: normal Tags: bookworm User: release.debian....@packages.debian.org Usertags: pu
I would like to update mgba in bookworm with the following changes. Both bugs were introduced in mgba 0.10.0 and are thus regressions in bookworm. The patches are cherry-picks from mgba 0.10.2. * Import upstream patch to fix broken audio in libretro core. (Closes: #1036829) The bug subject says "Audio stutters horribly and sounds distorted". On my system, I just get no audio at all, with either gnome-games-app or retroarch as frontend. In any case, the patch is the only change to libretro code in 0.10.2, and does make audio work properly for me. The short explanation of the bug is that the libretro core is maintained downstream (in a fork owned by the libretro folks), changes are pulled back to mgba upstream from time to time, and they missed one hunk during a resync. The patch simply restores the missing hunk of code. I asked the submitter to test the proposed package, but they didn't respond. * Import upstream patch to fix crash on hardware incapable of OpenGL 3.2. I actually have hardware (Intel GM45) affected by this, so I was able to verify it. Depending on configuration, mgba crashes either on startup, or when starting emulation. The patch restores support for older OpenGL implementations. * debian/gbp.conf: Set debian-branch to bookworm. Hopefully self-explanatory. The package does not have automated tests. I verified each fix with the libretro core and mgba-qt, and did some additional smoke testing to check for obvious regressions. Thank you, Ryan
diff -Nru mgba-0.10.1+dfsg/debian/changelog mgba-0.10.1+dfsg/debian/changelog --- mgba-0.10.1+dfsg/debian/changelog 2023-01-15 10:33:17.000000000 -0800 +++ mgba-0.10.1+dfsg/debian/changelog 2023-06-26 16:51:44.000000000 -0700 @@ -1,3 +1,12 @@ +mgba (0.10.1+dfsg-1+deb12u1) UNRELEASED; urgency=medium + + * Import upstream patch to fix broken audio in libretro core. + (Closes: #1036829) + * Import upstream patch to fix crash on hardware incapable of OpenGL 3.2. + * debian/gbp.conf: Set debian-branch to bookworm. + + -- Ryan Tandy <r...@nardis.ca> Mon, 26 Jun 2023 16:51:44 -0700 + mgba (0.10.1+dfsg-1) unstable; urgency=medium * New upstream release. diff -Nru mgba-0.10.1+dfsg/debian/gbp.conf mgba-0.10.1+dfsg/debian/gbp.conf --- mgba-0.10.1+dfsg/debian/gbp.conf 2023-01-15 10:33:17.000000000 -0800 +++ mgba-0.10.1+dfsg/debian/gbp.conf 2023-06-26 16:51:44.000000000 -0700 @@ -1,5 +1,6 @@ [DEFAULT] pristine-tar = True +debian-branch = bookworm [pq] patch-numbers = False diff -Nru mgba-0.10.1+dfsg/debian/patches/Libretro-Add-back-missing-audio-overkill-fixes-2734.patch mgba-0.10.1+dfsg/debian/patches/Libretro-Add-back-missing-audio-overkill-fixes-2734.patch --- mgba-0.10.1+dfsg/debian/patches/Libretro-Add-back-missing-audio-overkill-fixes-2734.patch 1969-12-31 16:00:00.000000000 -0800 +++ mgba-0.10.1+dfsg/debian/patches/Libretro-Add-back-missing-audio-overkill-fixes-2734.patch 2023-06-26 16:51:44.000000000 -0700 @@ -0,0 +1,56 @@ +From 71d1f122f9ecc0e4d85bf64a9fead6cdfc11dbd8 Mon Sep 17 00:00:00 2001 +From: Vicki Pfau <v...@endrift.com> +Date: Tue, 29 Nov 2022 02:20:02 -0800 +Subject: [PATCH] Libretro: Add back missing audio overkill (fixes #2734) + +--- + src/platform/libretro/libretro.c | 33 ++++++++++++++++++++++++++++++++ + 1 file changed, 33 insertions(+) + +diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c +index 9bbd55ae6..2c0184d99 100644 +--- a/src/platform/libretro/libretro.c ++++ b/src/platform/libretro/libretro.c +@@ -617,6 +617,39 @@ void retro_run(void) { + core->desiredVideoDimensions(core, &width, &height); + videoCallback(outputBuffer, width, height, BYTES_PER_PIXEL * 256); + ++#ifdef M_CORE_GBA ++ if (core->platform(core) == mPLATFORM_GBA) { ++ blip_t *audioChannelLeft = core->getAudioChannel(core, 0); ++ blip_t *audioChannelRight = core->getAudioChannel(core, 1); ++ int samplesAvail = blip_samples_avail(audioChannelLeft); ++ if (samplesAvail > 0) { ++ /* Update 'running average' of number of ++ * samples per frame. ++ * Note that this is not a true running ++ * average, but just a leaky-integrator/ ++ * exponential moving average, used because ++ * it is simple and fast (i.e. requires no ++ * window of samples). */ ++ audioSamplesPerFrameAvg = (SAMPLES_PER_FRAME_MOVING_AVG_ALPHA * (float)samplesAvail) + ++ ((1.0f - SAMPLES_PER_FRAME_MOVING_AVG_ALPHA) * audioSamplesPerFrameAvg); ++ size_t samplesToRead = (size_t)(audioSamplesPerFrameAvg); ++ /* Resize audio output buffer, if required */ ++ if (audioSampleBufferSize < (samplesToRead * 2)) { ++ audioSampleBufferSize = (samplesToRead * 2); ++ audioSampleBuffer = realloc(audioSampleBuffer, audioSampleBufferSize * sizeof(int16_t)); ++ } ++ int produced = blip_read_samples(audioChannelLeft, audioSampleBuffer, samplesToRead, true); ++ blip_read_samples(audioChannelRight, audioSampleBuffer + 1, samplesToRead, true); ++ if (produced > 0) { ++ if (audioLowPassEnabled) { ++ _audioLowPassFilter(audioSampleBuffer, produced); ++ } ++ audioCallback(audioSampleBuffer, (size_t)produced); ++ } ++ } ++ } ++#endif ++ + if (rumbleCallback) { + if (rumbleUp) { + rumbleCallback(0, RETRO_RUMBLE_STRONG, rumbleUp * 0xFFFF / (rumbleUp + rumbleDown)); +-- +2.30.2 + diff -Nru mgba-0.10.1+dfsg/debian/patches/Qt-Fix-crash-when-attempting-to-use-OpenGL-2.1-to-3.1.patch mgba-0.10.1+dfsg/debian/patches/Qt-Fix-crash-when-attempting-to-use-OpenGL-2.1-to-3.1.patch --- mgba-0.10.1+dfsg/debian/patches/Qt-Fix-crash-when-attempting-to-use-OpenGL-2.1-to-3.1.patch 1969-12-31 16:00:00.000000000 -0800 +++ mgba-0.10.1+dfsg/debian/patches/Qt-Fix-crash-when-attempting-to-use-OpenGL-2.1-to-3.1.patch 2023-06-26 16:51:44.000000000 -0700 @@ -0,0 +1,65 @@ +From df6ae1883cc7d4d67a21fba2f8eaff6644bd152d Mon Sep 17 00:00:00 2001 +From: Vicki Pfau <v...@endrift.com> +Date: Thu, 26 Jan 2023 05:57:08 -0800 +Subject: [PATCH] Qt: Fix crash when attempting to use OpenGL 2.1 to 3.1 (fixes + #2794) + +--- + src/platform/qt/DisplayGL.cpp | 10 +++++----- + 1 file changed, 5 insertions(+), 5 deletions(-) + +diff --git a/src/platform/qt/DisplayGL.cpp b/src/platform/qt/DisplayGL.cpp +index 7a4f73858..469b7e315 100644 +--- a/src/platform/qt/DisplayGL.cpp ++++ b/src/platform/qt/DisplayGL.cpp +@@ -513,10 +513,10 @@ void PainterGL::create() { + + #if defined(BUILD_GLES2) || defined(BUILD_GLES3) + if (m_supportsShaders) { +- QOpenGLFunctions_Baseline* fn = m_gl->versionFunctions<QOpenGLFunctions_Baseline>(); + gl2Backend = static_cast<mGLES2Context*>(malloc(sizeof(mGLES2Context))); + mGLES2ContextCreate(gl2Backend); + m_backend = &gl2Backend->d; ++ QOpenGLFunctions* fn = m_gl->functions(); + fn->glGenTextures(m_bridgeTexes.size(), m_bridgeTexes.data()); + for (auto tex : m_bridgeTexes) { + m_freeTex.enqueue(tex); +@@ -543,7 +543,7 @@ void PainterGL::create() { + #if defined(BUILD_GLES2) || defined(BUILD_GLES3) + mGLES2Context* gl2Backend = reinterpret_cast<mGLES2Context*>(painter->m_backend); + if (painter->m_widget && painter->supportsShaders()) { +- QOpenGLFunctions_Baseline* fn = painter->m_gl->versionFunctions<QOpenGLFunctions_Baseline>(); ++ QOpenGLFunctions* fn = painter->m_gl->functions(); + fn->glFinish(); + painter->m_widget->setTex(painter->m_finalTex[painter->m_finalTexIdx]); + painter->m_finalTexIdx ^= 1; +@@ -589,7 +589,7 @@ void PainterGL::destroy() { + } + makeCurrent(); + #if defined(BUILD_GLES2) || defined(BUILD_GLES3) +- QOpenGLFunctions_Baseline* fn = m_gl->versionFunctions<QOpenGLFunctions_Baseline>(); ++ QOpenGLFunctions* fn = m_gl->functions(); + if (m_shader.passes) { + mGLES2ShaderFree(&m_shader); + } +@@ -680,7 +680,7 @@ void PainterGL::start() { + if (glContextHasBug(OpenGLBug::GLTHREAD_BLOCKS_SWAP)) { + // Suggested on Discord as a way to strongly hint that glthread should be disabled + // See https://gitlab.freedesktop.org/mesa/mesa/-/issues/8035 +- QOpenGLFunctions_Baseline* fn = m_gl->versionFunctions<QOpenGLFunctions_Baseline>(); ++ QOpenGLFunctions* fn = m_gl->functions(); + fn->glEnable(GL_DEBUG_OUTPUT_SYNCHRONOUS); + } + #endif +@@ -972,7 +972,7 @@ QOpenGLContext* PainterGL::shareContext() { + } + + void PainterGL::updateFramebufferHandle() { +- QOpenGLFunctions_Baseline* fn = m_gl->versionFunctions<QOpenGLFunctions_Baseline>(); ++ QOpenGLFunctions* fn = m_gl->functions(); + // TODO: Figure out why glFlush doesn't work here on Intel/Windows + if (glContextHasBug(OpenGLBug::CROSS_THREAD_FLUSH)) { + fn->glFinish(); +-- +2.30.2 + diff -Nru mgba-0.10.1+dfsg/debian/patches/series mgba-0.10.1+dfsg/debian/patches/series --- mgba-0.10.1+dfsg/debian/patches/series 2023-01-15 10:33:17.000000000 -0800 +++ mgba-0.10.1+dfsg/debian/patches/series 2023-06-26 16:51:44.000000000 -0700 @@ -1,2 +1,4 @@ exclude-rapidjson.patch exclude-inih.patch +Libretro-Add-back-missing-audio-overkill-fixes-2734.patch +Qt-Fix-crash-when-attempting-to-use-OpenGL-2.1-to-3.1.patch