mirror of https://github.com/mgba-emu/mgba.git
GB Audio: Simplify envelope code
This commit is contained in:
parent
c83833bfd4
commit
053598fa7f
1
CHANGES
1
CHANGES
|
@ -57,6 +57,7 @@ Misc:
|
||||||
- Util: Add size counting to Table
|
- Util: Add size counting to Table
|
||||||
- Qt: Move last directory setting from qt.ini to config.ini
|
- Qt: Move last directory setting from qt.ini to config.ini
|
||||||
- 3DS, PSP2, Wii: Last directory loaded is saved
|
- 3DS, PSP2, Wii: Last directory loaded is saved
|
||||||
|
- GB Audio: Simplify envelope code
|
||||||
|
|
||||||
0.5.1: (2016-10-05)
|
0.5.1: (2016-10-05)
|
||||||
Bugfixes:
|
Bugfixes:
|
||||||
|
|
|
@ -26,6 +26,7 @@ static void _writeDuty(struct GBAudioEnvelope* envelope, uint8_t value);
|
||||||
static bool _writeSweep(struct GBAudioEnvelope* envelope, uint8_t value);
|
static bool _writeSweep(struct GBAudioEnvelope* envelope, uint8_t value);
|
||||||
static int32_t _updateSquareChannel(struct GBAudioSquareControl* envelope, int duty);
|
static int32_t _updateSquareChannel(struct GBAudioSquareControl* envelope, int duty);
|
||||||
static void _updateEnvelope(struct GBAudioEnvelope* envelope);
|
static void _updateEnvelope(struct GBAudioEnvelope* envelope);
|
||||||
|
static void _updateEnvelopeDead(struct GBAudioEnvelope* envelope);
|
||||||
static bool _updateSweep(struct GBAudioChannel1* ch, bool initial);
|
static bool _updateSweep(struct GBAudioChannel1* ch, bool initial);
|
||||||
static int32_t _updateChannel1(struct GBAudioChannel1* ch);
|
static int32_t _updateChannel1(struct GBAudioChannel1* ch);
|
||||||
static int32_t _updateChannel2(struct GBAudioChannel2* ch);
|
static int32_t _updateChannel2(struct GBAudioChannel2* ch);
|
||||||
|
@ -146,11 +147,8 @@ void GBAudioWriteNR14(struct GBAudio* audio, uint8_t value) {
|
||||||
if (GBAudioRegisterControlIsRestart(value << 8)) {
|
if (GBAudioRegisterControlIsRestart(value << 8)) {
|
||||||
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) {
|
_updateEnvelopeDead(&audio->ch1.envelope);
|
||||||
audio->ch1.envelope.dead = audio->ch1.envelope.stepTime ? 0 : 1;
|
|
||||||
} else {
|
|
||||||
audio->ch1.envelope.dead = audio->ch1.envelope.stepTime ? 0 : 2;
|
|
||||||
}
|
|
||||||
if (audio->nextEvent == INT_MAX) {
|
if (audio->nextEvent == INT_MAX) {
|
||||||
audio->eventDiff = 0;
|
audio->eventDiff = 0;
|
||||||
}
|
}
|
||||||
|
@ -209,11 +207,8 @@ void GBAudioWriteNR24(struct GBAudio* audio, uint8_t value) {
|
||||||
if (GBAudioRegisterControlIsRestart(value << 8)) {
|
if (GBAudioRegisterControlIsRestart(value << 8)) {
|
||||||
audio->playingCh2 = audio->ch2.envelope.initialVolume || audio->ch2.envelope.direction;
|
audio->playingCh2 = audio->ch2.envelope.initialVolume || audio->ch2.envelope.direction;
|
||||||
audio->ch2.envelope.currentVolume = audio->ch2.envelope.initialVolume;
|
audio->ch2.envelope.currentVolume = audio->ch2.envelope.initialVolume;
|
||||||
if (audio->ch2.envelope.currentVolume > 0) {
|
_updateEnvelopeDead(&audio->ch2.envelope);
|
||||||
audio->ch2.envelope.dead = audio->ch2.envelope.stepTime ? 0 : 1;
|
|
||||||
} else {
|
|
||||||
audio->ch2.envelope.dead = audio->ch2.envelope.stepTime ? 0 : 2;
|
|
||||||
}
|
|
||||||
if (audio->nextEvent == INT_MAX) {
|
if (audio->nextEvent == INT_MAX) {
|
||||||
audio->eventDiff = 0;
|
audio->eventDiff = 0;
|
||||||
}
|
}
|
||||||
|
@ -330,11 +325,8 @@ void GBAudioWriteNR44(struct GBAudio* audio, uint8_t value) {
|
||||||
if (GBAudioRegisterNoiseControlIsRestart(value)) {
|
if (GBAudioRegisterNoiseControlIsRestart(value)) {
|
||||||
audio->playingCh4 = audio->ch4.envelope.initialVolume || audio->ch4.envelope.direction;
|
audio->playingCh4 = audio->ch4.envelope.initialVolume || audio->ch4.envelope.direction;
|
||||||
audio->ch4.envelope.currentVolume = audio->ch4.envelope.initialVolume;
|
audio->ch4.envelope.currentVolume = audio->ch4.envelope.initialVolume;
|
||||||
if (audio->ch4.envelope.currentVolume > 0) {
|
_updateEnvelopeDead(&audio->ch4.envelope);
|
||||||
audio->ch4.envelope.dead = audio->ch4.envelope.stepTime ? 0 : 1;
|
|
||||||
} else {
|
|
||||||
audio->ch4.envelope.dead = audio->ch4.envelope.stepTime ? 0 : 2;
|
|
||||||
}
|
|
||||||
if (audio->ch4.power) {
|
if (audio->ch4.power) {
|
||||||
audio->ch4.lfsr = 0x40;
|
audio->ch4.lfsr = 0x40;
|
||||||
} else {
|
} else {
|
||||||
|
@ -689,15 +681,7 @@ bool _writeSweep(struct GBAudioEnvelope* envelope, uint8_t value) {
|
||||||
envelope->stepTime = GBAudioRegisterSweepGetStepTime(value);
|
envelope->stepTime = GBAudioRegisterSweepGetStepTime(value);
|
||||||
envelope->direction = GBAudioRegisterSweepGetDirection(value);
|
envelope->direction = GBAudioRegisterSweepGetDirection(value);
|
||||||
envelope->initialVolume = GBAudioRegisterSweepGetInitialVolume(value);
|
envelope->initialVolume = GBAudioRegisterSweepGetInitialVolume(value);
|
||||||
if (envelope->stepTime == 0) {
|
_updateEnvelopeDead(envelope);
|
||||||
envelope->dead = envelope->currentVolume ? 1 : 2;
|
|
||||||
} else if (!envelope->direction && !envelope->currentVolume) {
|
|
||||||
envelope->dead = 2;
|
|
||||||
} else if (envelope->direction && envelope->currentVolume == 0xF) {
|
|
||||||
envelope->dead = 1;
|
|
||||||
} else {
|
|
||||||
envelope->dead = 0;
|
|
||||||
}
|
|
||||||
envelope->nextStep = envelope->stepTime;
|
envelope->nextStep = envelope->stepTime;
|
||||||
return envelope->initialVolume || envelope->direction;
|
return envelope->initialVolume || envelope->direction;
|
||||||
}
|
}
|
||||||
|
@ -737,6 +721,18 @@ static void _updateEnvelope(struct GBAudioEnvelope* envelope) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void _updateEnvelopeDead(struct GBAudioEnvelope* envelope) {
|
||||||
|
if (envelope->stepTime == 0) {
|
||||||
|
envelope->dead = envelope->currentVolume ? 1 : 2;
|
||||||
|
} else if (!envelope->direction && !envelope->currentVolume) {
|
||||||
|
envelope->dead = 2;
|
||||||
|
} else if (envelope->direction && envelope->currentVolume == 0xF) {
|
||||||
|
envelope->dead = 1;
|
||||||
|
} else {
|
||||||
|
envelope->dead = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
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->realFrequency;
|
int frequency = ch->realFrequency;
|
||||||
|
|
Loading…
Reference in New Issue