mirror of https://github.com/mgba-emu/mgba.git
GB Serialize: Fix audio state loading
This commit is contained in:
parent
a7fb446029
commit
1a30dcc553
1
CHANGES
1
CHANGES
|
@ -6,6 +6,7 @@ Bugfixes:
|
||||||
- Python: Fix importing .gb or .gba before .core
|
- Python: Fix importing .gb or .gba before .core
|
||||||
- GBA: Reset active region as needed when loading a ROM
|
- GBA: Reset active region as needed when loading a ROM
|
||||||
- Qt: Fix command line debugger closing second game
|
- Qt: Fix command line debugger closing second game
|
||||||
|
- GB Serialize: Fix audio state loading
|
||||||
Misc:
|
Misc:
|
||||||
- GBA Timer: Use global cycles for timers
|
- GBA Timer: Use global cycles for timers
|
||||||
- GBA: Extend oddly-sized ROMs to full address space (fixes mgba.io/i/722)
|
- GBA: Extend oddly-sized ROMs to full address space (fixes mgba.io/i/722)
|
||||||
|
|
|
@ -960,6 +960,8 @@ void GBAudioPSGDeserialize(struct GBAudio* audio, const struct GBSerializedPSGSt
|
||||||
mTimingSchedule(audio->timing, &audio->frameEvent, when);
|
mTimingSchedule(audio->timing, &audio->frameEvent, when);
|
||||||
|
|
||||||
LOAD_32LE(flags, 0, flagsIn);
|
LOAD_32LE(flags, 0, flagsIn);
|
||||||
|
audio->frame = GBSerializedAudioFlagsGetFrame(flags);
|
||||||
|
|
||||||
LOAD_32LE(ch1Flags, 0, &state->ch1.envelope);
|
LOAD_32LE(ch1Flags, 0, &state->ch1.envelope);
|
||||||
audio->ch1.envelope.currentVolume = GBSerializedAudioFlagsGetCh1Volume(flags);
|
audio->ch1.envelope.currentVolume = GBSerializedAudioFlagsGetCh1Volume(flags);
|
||||||
audio->ch1.envelope.dead = GBSerializedAudioFlagsGetCh1Dead(flags);
|
audio->ch1.envelope.dead = GBSerializedAudioFlagsGetCh1Dead(flags);
|
||||||
|
|
30
src/gb/io.c
30
src/gb/io.c
|
@ -580,6 +580,36 @@ void GBIOSerialize(const struct GB* gb, struct GBSerializedState* state) {
|
||||||
void GBIODeserialize(struct GB* gb, const struct GBSerializedState* state) {
|
void GBIODeserialize(struct GB* gb, const struct GBSerializedState* state) {
|
||||||
memcpy(gb->memory.io, state->io, GB_SIZE_IO);
|
memcpy(gb->memory.io, state->io, GB_SIZE_IO);
|
||||||
gb->memory.ie = state->ie;
|
gb->memory.ie = state->ie;
|
||||||
|
|
||||||
|
if (GBAudioEnableGetEnable(*gb->audio.nr52)) {
|
||||||
|
GBIOWrite(gb, REG_NR10, gb->memory.io[REG_NR10]);
|
||||||
|
GBIOWrite(gb, REG_NR11, gb->memory.io[REG_NR11]);
|
||||||
|
GBIOWrite(gb, REG_NR12, gb->memory.io[REG_NR12]);
|
||||||
|
GBIOWrite(gb, REG_NR13, gb->memory.io[REG_NR13]);
|
||||||
|
gb->audio.ch1.control.frequency &= 0xFF;
|
||||||
|
gb->audio.ch1.control.frequency |= GBAudioRegisterControlGetFrequency(gb->memory.io[REG_NR14] << 8);
|
||||||
|
gb->audio.ch1.control.stop = GBAudioRegisterControlGetStop(gb->memory.io[REG_NR14] << 8);
|
||||||
|
GBIOWrite(gb, REG_NR21, gb->memory.io[REG_NR21]);
|
||||||
|
GBIOWrite(gb, REG_NR22, gb->memory.io[REG_NR22]);
|
||||||
|
GBIOWrite(gb, REG_NR22, gb->memory.io[REG_NR23]);
|
||||||
|
gb->audio.ch2.control.frequency &= 0xFF;
|
||||||
|
gb->audio.ch2.control.frequency |= GBAudioRegisterControlGetFrequency(gb->memory.io[REG_NR24] << 8);
|
||||||
|
gb->audio.ch2.control.stop = GBAudioRegisterControlGetStop(gb->memory.io[REG_NR24] << 8);
|
||||||
|
GBIOWrite(gb, REG_NR30, gb->memory.io[REG_NR30]);
|
||||||
|
GBIOWrite(gb, REG_NR31, gb->memory.io[REG_NR31]);
|
||||||
|
GBIOWrite(gb, REG_NR32, gb->memory.io[REG_NR32]);
|
||||||
|
GBIOWrite(gb, REG_NR32, gb->memory.io[REG_NR33]);
|
||||||
|
gb->audio.ch3.rate &= 0xFF;
|
||||||
|
gb->audio.ch3.rate |= GBAudioRegisterControlGetRate(gb->memory.io[REG_NR34] << 8);
|
||||||
|
gb->audio.ch3.stop = GBAudioRegisterControlGetStop(gb->memory.io[REG_NR34] << 8);
|
||||||
|
GBIOWrite(gb, REG_NR41, gb->memory.io[REG_NR41]);
|
||||||
|
GBIOWrite(gb, REG_NR42, gb->memory.io[REG_NR42]);
|
||||||
|
GBIOWrite(gb, REG_NR43, gb->memory.io[REG_NR43]);
|
||||||
|
gb->audio.ch4.stop = GBAudioRegisterNoiseControlGetStop(gb->memory.io[REG_NR44]);
|
||||||
|
GBIOWrite(gb, REG_NR50, gb->memory.io[REG_NR50]);
|
||||||
|
GBIOWrite(gb, REG_NR51, gb->memory.io[REG_NR51]);
|
||||||
|
}
|
||||||
|
|
||||||
gb->video.renderer->writeVideoRegister(gb->video.renderer, REG_LCDC, state->io[REG_LCDC]);
|
gb->video.renderer->writeVideoRegister(gb->video.renderer, REG_LCDC, state->io[REG_LCDC]);
|
||||||
gb->video.renderer->writeVideoRegister(gb->video.renderer, REG_SCY, state->io[REG_SCY]);
|
gb->video.renderer->writeVideoRegister(gb->video.renderer, REG_SCY, state->io[REG_SCY]);
|
||||||
gb->video.renderer->writeVideoRegister(gb->video.renderer, REG_SCX, state->io[REG_SCX]);
|
gb->video.renderer->writeVideoRegister(gb->video.renderer, REG_SCX, state->io[REG_SCX]);
|
||||||
|
|
|
@ -150,16 +150,16 @@ bool GBDeserialize(struct GB* gb, const struct GBSerializedState* state) {
|
||||||
gb->doubleSpeed = GBSerializedCpuFlagsGetDoubleSpeed(flags);
|
gb->doubleSpeed = GBSerializedCpuFlagsGetDoubleSpeed(flags);
|
||||||
gb->audio.timingFactor = gb->doubleSpeed + 1;
|
gb->audio.timingFactor = gb->doubleSpeed + 1;
|
||||||
|
|
||||||
|
LOAD_32LE(gb->cpu->cycles, 0, &state->cpu.cycles);
|
||||||
|
LOAD_32LE(gb->cpu->nextEvent, 0, &state->cpu.nextEvent);
|
||||||
|
gb->timing.root = NULL;
|
||||||
|
|
||||||
uint32_t when;
|
uint32_t when;
|
||||||
LOAD_32LE(when, 0, &state->cpu.eiPending);
|
LOAD_32LE(when, 0, &state->cpu.eiPending);
|
||||||
if (GBSerializedCpuFlagsIsEiPending(flags)) {
|
if (GBSerializedCpuFlagsIsEiPending(flags)) {
|
||||||
mTimingSchedule(&gb->timing, &gb->eiPending, when);
|
mTimingSchedule(&gb->timing, &gb->eiPending, when);
|
||||||
}
|
}
|
||||||
|
|
||||||
LOAD_32LE(gb->cpu->cycles, 0, &state->cpu.cycles);
|
|
||||||
LOAD_32LE(gb->cpu->nextEvent, 0, &state->cpu.nextEvent);
|
|
||||||
gb->timing.root = NULL;
|
|
||||||
|
|
||||||
gb->model = state->model;
|
gb->model = state->model;
|
||||||
|
|
||||||
if (gb->model < GB_MODEL_CGB) {
|
if (gb->model < GB_MODEL_CGB) {
|
||||||
|
|
Loading…
Reference in New Issue