Qt: Fix cancelling pausing before the frame ends

This commit is contained in:
Vicki Pfau 2020-11-17 22:52:44 -08:00
parent 61f8f14694
commit 67dae057ed
3 changed files with 28 additions and 16 deletions

View File

@ -59,6 +59,7 @@ Other fixes:
- Qt: Load/save bytes from memory viewer in the order visible (fixes mgba.io/i/1900) - Qt: Load/save bytes from memory viewer in the order visible (fixes mgba.io/i/1900)
- Qt: Fix running proxied video if it gets pushed to the main thread - Qt: Fix running proxied video if it gets pushed to the main thread
- Qt: Fix game display sometimes disappearing after closing load/save state screen - Qt: Fix game display sometimes disappearing after closing load/save state screen
- Qt: Fix cancelling pausing before the frame ends
- SM83: Simplify register pair access on big endian - SM83: Simplify register pair access on big endian
- SM83: Disassemble STOP as one byte - SM83: Disassemble STOP as one byte
Misc: Misc:

View File

@ -406,23 +406,25 @@ void CoreController::reset() {
} }
void CoreController::setPaused(bool paused) { void CoreController::setPaused(bool paused) {
if (paused == isPaused()) { QMutexLocker locker(&m_actionMutex);
return;
}
if (paused) { if (paused) {
addFrameAction([this]() { if (m_moreFrames < 0) {
mCoreThreadPauseFromThread(&m_threadContext); m_moreFrames = 1;
}); }
} else { } else {
m_moreFrames = -1;
if (isPaused()) {
mCoreThreadUnpause(&m_threadContext); mCoreThreadUnpause(&m_threadContext);
} }
}
} }
void CoreController::frameAdvance() { void CoreController::frameAdvance() {
addFrameAction([this]() { QMutexLocker locker(&m_actionMutex);
mCoreThreadPauseFromThread(&m_threadContext); m_moreFrames = 1;
}); if (isPaused()) {
setPaused(false); mCoreThreadUnpause(&m_threadContext);
}
} }
void CoreController::addFrameAction(std::function<void ()> action) { void CoreController::addFrameAction(std::function<void ()> action) {
@ -947,12 +949,20 @@ void CoreController::finishFrame() {
memcpy(m_completeBuffer.data(), m_activeBuffer.constData(), width * height * BYTES_PER_PIXEL); memcpy(m_completeBuffer.data(), m_activeBuffer.constData(), width * height * BYTES_PER_PIXEL);
} }
{
QMutexLocker locker(&m_actionMutex); QMutexLocker locker(&m_actionMutex);
QList<std::function<void ()>> frameActions(m_frameActions); QList<std::function<void ()>> frameActions(m_frameActions);
m_frameActions.clear(); m_frameActions.clear();
for (auto& action : frameActions) { for (auto& action : frameActions) {
action(); action();
} }
if (m_moreFrames > 0) {
--m_moreFrames;
if (!m_moreFrames) {
mCoreThreadPauseFromThread(&m_threadContext);
}
}
}
updateKeys(); updateKeys();
QMetaObject::invokeMethod(this, "frameAvailable"); QMetaObject::invokeMethod(this, "frameAvailable");

View File

@ -213,6 +213,7 @@ private:
QList<std::function<void()>> m_resetActions; QList<std::function<void()>> m_resetActions;
QList<std::function<void()>> m_frameActions; QList<std::function<void()>> m_frameActions;
QMutex m_actionMutex{QMutex::Recursive}; QMutex m_actionMutex{QMutex::Recursive};
int m_moreFrames = -1;
QMutex m_bufferMutex; QMutex m_bufferMutex;
int m_activeKeys = 0; int m_activeKeys = 0;