From 090048ec065e5777a7f3f1c256d1a45a4b248de5 Mon Sep 17 00:00:00 2001 From: Jeffrey Pfau Date: Tue, 9 Dec 2014 12:58:35 -0800 Subject: [PATCH] GBA Thread: Handle the lack of a sync object properly --- src/gba/gba-thread.c | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/src/gba/gba-thread.c b/src/gba/gba-thread.c index 77b175b6d..85d73aa5e 100644 --- a/src/gba/gba-thread.c +++ b/src/gba/gba-thread.c @@ -628,18 +628,34 @@ void GBASyncWaitFrameEnd(struct GBASync* sync) { } bool GBASyncDrawingFrame(struct GBASync* sync) { + if (!sync) { + return true; + } + return sync->videoFrameSkip <= 0; } void GBASyncSuspendDrawing(struct GBASync* sync) { + if (!sync) { + return; + } + _changeVideoSync(sync, false); } void GBASyncResumeDrawing(struct GBASync* sync) { + if (!sync) { + return; + } + _changeVideoSync(sync, true); } void GBASyncProduceAudio(struct GBASync* sync, bool wait) { + if (!sync) { + return; + } + if (sync->audioWait && wait) { // TODO loop properly in event of spurious wakeups ConditionWait(&sync->audioRequiredCond, &sync->audioBufferMutex); @@ -648,14 +664,26 @@ void GBASyncProduceAudio(struct GBASync* sync, bool wait) { } void GBASyncLockAudio(struct GBASync* sync) { + if (!sync) { + return; + } + MutexLock(&sync->audioBufferMutex); } void GBASyncUnlockAudio(struct GBASync* sync) { + if (!sync) { + return; + } + MutexUnlock(&sync->audioBufferMutex); } void GBASyncConsumeAudio(struct GBASync* sync) { + if (!sync) { + return; + } + ConditionWake(&sync->audioRequiredCond); MutexUnlock(&sync->audioBufferMutex); }