From 8b75c170d3ca338c95475ce0c4c82a0d7467a960 Mon Sep 17 00:00:00 2001 From: Jeffrey Pfau Date: Sun, 25 Sep 2016 22:02:45 -0700 Subject: [PATCH] GBA Hardware: Improve Game Boy Player rumble behavior --- CHANGES | 1 + src/gba/hardware.c | 13 ++++++++----- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/CHANGES b/CHANGES index 6d83de50c..266bc53c9 100644 --- a/CHANGES +++ b/CHANGES @@ -18,6 +18,7 @@ Bugfixes: - GB: Fix invalid STOP behavior on Game Boy Color - GB, GBA: Fix emulator hardlocking when halting with IRQs off - SDL: Attach rumble in SDL frontend + - GBA Hardware: Improve Game Boy Player rumble behavior Misc: - All: Only update version info if needed - FFmpeg: Encoding cleanup diff --git a/src/gba/hardware.c b/src/gba/hardware.c index f62d92eac..0a2b60bb1 100644 --- a/src/gba/hardware.c +++ b/src/gba/hardware.c @@ -563,12 +563,15 @@ int32_t _gbpSioProcessEvents(struct GBASIODriver* driver, int32_t cycles) { gbp->p->gbpNextEvent -= cycles; if (gbp->p->gbpNextEvent <= 0) { uint32_t tx = 0; - if (gbp->p->gbpTxPosition <= 12) { - tx = _gbpTxData[gbp->p->gbpTxPosition]; - if (gbp->p->gbpTxPosition < 12) { - ++gbp->p->gbpTxPosition; - } + int txPosition = gbp->p->gbpTxPosition; + if (txPosition > 16) { + gbp->p->gbpTxPosition = 0; + txPosition = 0; + } else if (txPosition > 12) { + txPosition = 12; } + tx = _gbpTxData[txPosition]; + ++gbp->p->gbpTxPosition; gbp->p->p->memory.io[REG_SIODATA32_LO >> 1] = tx; gbp->p->p->memory.io[REG_SIODATA32_HI >> 1] = tx >> 16; if (gbp->d.p->normalControl.irq) {