mirror of https://github.com/mgba-emu/mgba.git
GB I/O: Fix incrementing SGB controller when P14 is low (fixes #2202)
This commit is contained in:
parent
59939d3241
commit
c5c6948653
1
CHANGES
1
CHANGES
|
@ -1,5 +1,6 @@
|
||||||
0.9.3: (Future)
|
0.9.3: (Future)
|
||||||
Emulation fixes:
|
Emulation fixes:
|
||||||
|
- GB I/O: Fix incrementing SGB controller when P14 is low (fixes mgba.io/i/2202)
|
||||||
- GB Video: Render SGB border when unmasking with ATTR/PAL_SET (fixes mgba.io/i/2261)
|
- GB Video: Render SGB border when unmasking with ATTR/PAL_SET (fixes mgba.io/i/2261)
|
||||||
- GBA SIO: Fix SI value for unattached MULTI mode
|
- GBA SIO: Fix SI value for unattached MULTI mode
|
||||||
- GBA Video: Fix backdrop color if DISPCNT is first set to 0 (fixes mgba.io/i/2260)
|
- GBA Video: Fix backdrop color if DISPCNT is first set to 0 (fixes mgba.io/i/2260)
|
||||||
|
|
14
src/gb/io.c
14
src/gb/io.c
|
@ -119,19 +119,15 @@ static void _writeSGBBits(struct GB* gb, int bits) {
|
||||||
if (bits == gb->currentSgbBits) {
|
if (bits == gb->currentSgbBits) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
switch (bits) {
|
if (bits & 2) {
|
||||||
case 0:
|
|
||||||
case 1:
|
|
||||||
if (gb->currentSgbBits & 2) {
|
|
||||||
gb->sgbIncrement = !gb->sgbIncrement;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
if (gb->sgbIncrement) {
|
if (gb->sgbIncrement) {
|
||||||
gb->sgbIncrement = false;
|
gb->sgbIncrement = false;
|
||||||
gb->sgbCurrentController = (gb->sgbCurrentController + 1) & gb->sgbControllers;
|
gb->sgbCurrentController = (gb->sgbCurrentController + 1) & gb->sgbControllers;
|
||||||
}
|
}
|
||||||
break;
|
} else {
|
||||||
|
if (gb->currentSgbBits & 2) {
|
||||||
|
gb->sgbIncrement = !gb->sgbIncrement;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
gb->currentSgbBits = bits;
|
gb->currentSgbBits = bits;
|
||||||
if (gb->sgbBit == 128 && bits == 2) {
|
if (gb->sgbBit == 128 && bits == 2) {
|
||||||
|
|
Loading…
Reference in New Issue