GBA Audio: Fix initial channel 3 wave RAM (fixes #2947)

This commit is contained in:
Vicki Pfau 2023-06-26 00:21:03 -07:00
parent 24f3d8808f
commit 76fe63a254
2 changed files with 19 additions and 16 deletions

View File

@ -4,6 +4,7 @@ Emulation fixes:
- GB I/O: Read back proper SVBK value after writing 0 (fixes mgba.io/i/2921) - GB I/O: Read back proper SVBK value after writing 0 (fixes mgba.io/i/2921)
- GB SIO: Disabling SIO should cancel pending transfers (fixes mgba.io/i/2537) - GB SIO: Disabling SIO should cancel pending transfers (fixes mgba.io/i/2537)
- GBA Audio: Fix sample timing drifting when changing sample interval - GBA Audio: Fix sample timing drifting when changing sample interval
- GBA Audio: Fix initial channel 3 wave RAM (fixes mgba.io/i/2947)
- GBA BIOS: Fix clobbering registers with word-sized CpuSet - GBA BIOS: Fix clobbering registers with word-sized CpuSet
Other fixes: Other fixes:
- mGUI: Fix cases where an older save state screenshot would be shown (fixes mgba.io/i/2183) - mGUI: Fix cases where an older save state screenshot would be shown (fixes mgba.io/i/2183)

View File

@ -100,6 +100,7 @@ void GBAudioReset(struct GBAudio* audio) {
audio->ch3 = (struct GBAudioWaveChannel) { .bank = 0 }; audio->ch3 = (struct GBAudioWaveChannel) { .bank = 0 };
audio->ch4 = (struct GBAudioNoiseChannel) { .nSamples = 0 }; audio->ch4 = (struct GBAudioNoiseChannel) { .nSamples = 0 };
// TODO: DMG randomness // TODO: DMG randomness
if (audio->style != GB_AUDIO_GBA) {
audio->ch3.wavedata8[0] = 0x00; audio->ch3.wavedata8[0] = 0x00;
audio->ch3.wavedata8[1] = 0xFF; audio->ch3.wavedata8[1] = 0xFF;
audio->ch3.wavedata8[2] = 0x00; audio->ch3.wavedata8[2] = 0x00;
@ -116,6 +117,7 @@ void GBAudioReset(struct GBAudio* audio) {
audio->ch3.wavedata8[13] = 0xFF; audio->ch3.wavedata8[13] = 0xFF;
audio->ch3.wavedata8[14] = 0x00; audio->ch3.wavedata8[14] = 0x00;
audio->ch3.wavedata8[15] = 0xFF; audio->ch3.wavedata8[15] = 0xFF;
}
audio->ch4 = (struct GBAudioNoiseChannel) { .envelope = { .dead = 2 } }; audio->ch4 = (struct GBAudioNoiseChannel) { .envelope = { .dead = 2 } };
audio->frame = 0; audio->frame = 0;
audio->sampleInterval = SAMPLE_INTERVAL * GB_MAX_SAMPLES; audio->sampleInterval = SAMPLE_INTERVAL * GB_MAX_SAMPLES;