GB Audio: Fix timing when reseting audio channels

This commit is contained in:
Jeffrey Pfau 2016-02-22 00:05:55 -08:00
parent e9e6eaa353
commit 883bf55660
1 changed files with 7 additions and 7 deletions

View File

@ -142,9 +142,10 @@ void GBAudioWriteNR14(struct GBAudio* audio, uint8_t value) {
if (audio->nextEvent == INT_MAX) { if (audio->nextEvent == INT_MAX) {
audio->eventDiff = 0; audio->eventDiff = 0;
} }
if (!audio->playingCh1) { if (audio->playingCh1) {
audio->nextCh1 = audio->eventDiff; audio->ch1.control.hi = !audio->ch1.control.hi;
} }
audio->nextCh1 = audio->eventDiff;
audio->playingCh1 = audio->ch1.envelope.initialVolume || audio->ch1.envelope.direction; audio->playingCh1 = audio->ch1.envelope.initialVolume || audio->ch1.envelope.direction;
audio->ch1.envelope.currentVolume = audio->ch1.envelope.initialVolume; audio->ch1.envelope.currentVolume = audio->ch1.envelope.initialVolume;
if (audio->ch1.envelope.currentVolume > 0) { if (audio->ch1.envelope.currentVolume > 0) {
@ -210,9 +211,10 @@ void GBAudioWriteNR24(struct GBAudio* audio, uint8_t value) {
if (audio->nextEvent == INT_MAX) { if (audio->nextEvent == INT_MAX) {
audio->eventDiff = 0; audio->eventDiff = 0;
} }
if (!audio->playingCh2) { if (audio->playingCh2) {
audio->nextCh2 = audio->eventDiff; audio->ch2.control.hi = !audio->ch2.control.hi;
} }
audio->nextCh2 = audio->eventDiff;
if (!audio->ch2.control.length) { if (!audio->ch2.control.length) {
audio->ch2.control.length = 64; audio->ch2.control.length = 64;
if (audio->ch2.control.stop && !(audio->frame & 1)) { if (audio->ch2.control.stop && !(audio->frame & 1)) {
@ -335,9 +337,7 @@ void GBAudioWriteNR44(struct GBAudio* audio, uint8_t value) {
if (audio->nextEvent == INT_MAX) { if (audio->nextEvent == INT_MAX) {
audio->eventDiff = 0; audio->eventDiff = 0;
} }
if (!audio->playingCh4) { audio->nextCh4 = audio->eventDiff;
audio->nextCh4 = audio->eventDiff;
}
if (!audio->ch4.length) { if (!audio->ch4.length) {
audio->ch4.length = 64; audio->ch4.length = 64;
if (audio->ch4.stop && !(audio->frame & 1)) { if (audio->ch4.stop && !(audio->frame & 1)) {