GB, GBA Audio: Refactor stream code to do less when no stream is present

This commit is contained in:
Vicki Pfau 2024-04-22 21:38:54 -07:00
parent 3f54bcbc87
commit 2bce03023b
2 changed files with 26 additions and 23 deletions

View File

@ -822,25 +822,26 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) {
GBAudioSample(audio, mTimingCurrentTime(audio->timing)); GBAudioSample(audio, mTimingCurrentTime(audio->timing));
mCoreSyncLockAudio(audio->p->sync); mCoreSyncLockAudio(audio->p->sync);
unsigned produced;
mAudioBufferWrite(&audio->buffer, (int16_t*) audio->currentSamples, GB_MAX_SAMPLES); mAudioBufferWrite(&audio->buffer, (int16_t*) audio->currentSamples, GB_MAX_SAMPLES);
if (audio->p->stream && audio->p->stream->postAudioFrame) { if (audio->p->stream) {
if (audio->p->stream->postAudioFrame) {
int i; int i;
for (i = 0; i < GB_MAX_SAMPLES; ++i) { for (i = 0; i < GB_MAX_SAMPLES; ++i) {
audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right); audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right);
} }
} }
if (audio->p->stream->postAudioBuffer) {
produced = mAudioBufferAvailable(&audio->buffer); unsigned produced = mAudioBufferAvailable(&audio->buffer);
bool wait = produced >= audio->samples; bool wait = produced >= audio->samples;
if (wait) {
audio->p->stream->postAudioBuffer(audio->p->stream, &audio->buffer);
}
}
}
if (!mCoreSyncProduceAudio(audio->p->sync, &audio->buffer)) { if (!mCoreSyncProduceAudio(audio->p->sync, &audio->buffer)) {
// Interrupted // Interrupted
audio->p->earlyExit = true; audio->p->earlyExit = true;
} }
if (wait && audio->p->stream && audio->p->stream->postAudioBuffer) {
audio->p->stream->postAudioBuffer(audio->p->stream, &audio->buffer);
}
mTimingSchedule(timing, &audio->sampleEvent, audio->sampleInterval * audio->timingFactor - cyclesLate); mTimingSchedule(timing, &audio->sampleEvent, audio->sampleInterval * audio->timingFactor - cyclesLate);
} }

View File

@ -392,25 +392,27 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) {
memset(audio->chB.samples, audio->chB.samples[samples - 1], sizeof(audio->chB.samples)); memset(audio->chB.samples, audio->chB.samples[samples - 1], sizeof(audio->chB.samples));
mCoreSyncLockAudio(audio->p->sync); mCoreSyncLockAudio(audio->p->sync);
unsigned produced;
mAudioBufferWrite(&audio->psg.buffer, (int16_t*) audio->currentSamples, samples); mAudioBufferWrite(&audio->psg.buffer, (int16_t*) audio->currentSamples, samples);
if (audio->p->stream && audio->p->stream->postAudioFrame) { if (audio->p->stream) {
if (audio->p->stream->postAudioFrame) {
int i; int i;
for (i = 0; i < samples; ++i) { for (i = 0; i < samples; ++i) {
audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right); audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right);
} }
} }
produced = mAudioBufferAvailable(&audio->psg.buffer); if (audio->p->stream->postAudioBuffer) {
unsigned produced = mAudioBufferAvailable(&audio->psg.buffer);
bool wait = produced >= audio->samples; bool wait = produced >= audio->samples;
if (wait) {
audio->p->stream->postAudioBuffer(audio->p->stream, &audio->psg.buffer);
}
}
}
if (!mCoreSyncProduceAudio(audio->p->sync, &audio->psg.buffer)) { if (!mCoreSyncProduceAudio(audio->p->sync, &audio->psg.buffer)) {
// Interrupted // Interrupted
audio->p->earlyExit = true; audio->p->earlyExit = true;
} }
if (wait && audio->p->stream && audio->p->stream->postAudioBuffer) {
audio->p->stream->postAudioBuffer(audio->p->stream, &audio->psg.buffer);
}
mTimingSchedule(timing, &audio->sampleEvent, SAMPLE_INTERVAL - cyclesLate); mTimingSchedule(timing, &audio->sampleEvent, SAMPLE_INTERVAL - cyclesLate);
} }