mirror of https://github.com/mgba-emu/mgba.git
GB: More audio fixes
This commit is contained in:
parent
f1f9dee111
commit
e97d36b7fc
|
@ -98,6 +98,7 @@ void GBAudioWriteNR10(struct GBAudio* audio, uint8_t value) {
|
||||||
audio->p->memory.io[REG_NR52] &= ~0x0001;
|
audio->p->memory.io[REG_NR52] &= ~0x0001;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
audio->ch1.sweepOccurred = false;
|
||||||
audio->ch1.time = GBAudioRegisterSquareSweepGetTime(value);
|
audio->ch1.time = GBAudioRegisterSquareSweepGetTime(value);
|
||||||
if (!audio->ch1.time) {
|
if (!audio->ch1.time) {
|
||||||
audio->ch1.time = 8;
|
audio->ch1.time = 8;
|
||||||
|
@ -381,6 +382,7 @@ void GBAudioWriteNR51(struct GBAudio* audio, uint8_t value) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void GBAudioWriteNR52(struct GBAudio* audio, uint8_t value) {
|
void GBAudioWriteNR52(struct GBAudio* audio, uint8_t value) {
|
||||||
|
bool wasEnable = audio->enable;
|
||||||
audio->enable = GBAudioEnableGetEnable(value);
|
audio->enable = GBAudioEnableGetEnable(value);
|
||||||
if (!audio->enable) {
|
if (!audio->enable) {
|
||||||
audio->playingCh1 = 0;
|
audio->playingCh1 = 0;
|
||||||
|
@ -430,7 +432,7 @@ void GBAudioWriteNR52(struct GBAudio* audio, uint8_t value) {
|
||||||
audio->p->memory.io[REG_NR51] = 0;
|
audio->p->memory.io[REG_NR51] = 0;
|
||||||
audio->p->memory.io[REG_NR52] &= ~0x000F;
|
audio->p->memory.io[REG_NR52] &= ~0x000F;
|
||||||
}
|
}
|
||||||
} else {
|
} else if (!wasEnable) {
|
||||||
audio->frame = 7;
|
audio->frame = 7;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -725,14 +727,14 @@ static void _updateEnvelope(struct GBAudioEnvelope* envelope) {
|
||||||
|
|
||||||
static bool _updateSweep(struct GBAudioChannel1* ch, bool initial) {
|
static bool _updateSweep(struct GBAudioChannel1* ch, bool initial) {
|
||||||
if (initial || ch->time != 8) {
|
if (initial || ch->time != 8) {
|
||||||
|
int frequency = ch->control.frequency;
|
||||||
if (ch->direction) {
|
if (ch->direction) {
|
||||||
int frequency = ch->control.frequency;
|
|
||||||
frequency -= frequency >> ch->shift;
|
frequency -= frequency >> ch->shift;
|
||||||
if (frequency >= 0) {
|
if (!initial && frequency >= 0) {
|
||||||
ch->control.frequency = frequency;
|
ch->control.frequency = frequency;
|
||||||
|
ch->realFrequency = frequency;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
int frequency = ch->control.frequency;
|
|
||||||
frequency += frequency >> ch->shift;
|
frequency += frequency >> ch->shift;
|
||||||
if (frequency < 2048) {
|
if (frequency < 2048) {
|
||||||
if (!initial && ch->shift) {
|
if (!initial && ch->shift) {
|
||||||
|
@ -740,6 +742,7 @@ static bool _updateSweep(struct GBAudioChannel1* ch, bool initial) {
|
||||||
if (!_updateSweep(ch, true)) {
|
if (!_updateSweep(ch, true)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
ch->realFrequency = frequency;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
|
Loading…
Reference in New Issue