mirror of https://github.com/mgba-emu/mgba.git
GBA Audio: Make larger buffer sizes than 2048 actually work properly
Conflicts: src/gba/gba-audio.c
This commit is contained in:
parent
cbcfffcba4
commit
e38a01f221
1
CHANGES
1
CHANGES
|
@ -11,6 +11,7 @@ Bugfixes:
|
||||||
- Qt: Fix window focus issues
|
- Qt: Fix window focus issues
|
||||||
- GBA Memory: Properly initialize 1 Mb flash, and add debug logging
|
- GBA Memory: Properly initialize 1 Mb flash, and add debug logging
|
||||||
- Qt: Properly set default video recording settings
|
- Qt: Properly set default video recording settings
|
||||||
|
- GBA Audio: Make larger buffer sizes than 2048 actually work properly
|
||||||
Misc:
|
Misc:
|
||||||
- Qt: Disable sync to video by default
|
- Qt: Disable sync to video by default
|
||||||
- GBA: Exit cleanly on FATAL if the port supports it
|
- GBA: Exit cleanly on FATAL if the port supports it
|
||||||
|
|
|
@ -91,17 +91,14 @@ void GBAAudioDeinit(struct GBAAudio* audio) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void GBAAudioResizeBuffer(struct GBAAudio* audio, size_t samples) {
|
void GBAAudioResizeBuffer(struct GBAAudio* audio, size_t samples) {
|
||||||
if (samples > GBA_AUDIO_SAMPLES) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
GBASyncLockAudio(audio->p->sync);
|
GBASyncLockAudio(audio->p->sync);
|
||||||
int32_t buffer[GBA_AUDIO_SAMPLES];
|
size_t oldCapacity = audio->left.capacity;
|
||||||
|
int32_t* buffer = malloc(oldCapacity);
|
||||||
int32_t dummy;
|
int32_t dummy;
|
||||||
size_t read;
|
size_t read;
|
||||||
size_t i;
|
size_t i;
|
||||||
|
|
||||||
read = CircleBufferDump(&audio->left, buffer, sizeof(buffer));
|
read = CircleBufferDump(&audio->left, buffer, oldCapacity);
|
||||||
CircleBufferDeinit(&audio->left);
|
CircleBufferDeinit(&audio->left);
|
||||||
CircleBufferInit(&audio->left, samples * sizeof(int32_t));
|
CircleBufferInit(&audio->left, samples * sizeof(int32_t));
|
||||||
for (i = 0; i * sizeof(int32_t) < read; ++i) {
|
for (i = 0; i * sizeof(int32_t) < read; ++i) {
|
||||||
|
@ -111,7 +108,7 @@ void GBAAudioResizeBuffer(struct GBAAudio* audio, size_t samples) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
read = CircleBufferDump(&audio->right, buffer, sizeof(buffer));
|
read = CircleBufferDump(&audio->right, buffer, oldCapacity);
|
||||||
CircleBufferDeinit(&audio->right);
|
CircleBufferDeinit(&audio->right);
|
||||||
CircleBufferInit(&audio->right, samples * sizeof(int32_t));
|
CircleBufferInit(&audio->right, samples * sizeof(int32_t));
|
||||||
for (i = 0; i * sizeof(int32_t) < read; ++i) {
|
for (i = 0; i * sizeof(int32_t) < read; ++i) {
|
||||||
|
@ -121,6 +118,8 @@ void GBAAudioResizeBuffer(struct GBAAudio* audio, size_t samples) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
free(buffer);
|
||||||
|
|
||||||
GBASyncConsumeAudio(audio->p->sync);
|
GBASyncConsumeAudio(audio->p->sync);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -755,7 +754,7 @@ static void _sample(struct GBAAudio* audio) {
|
||||||
if (thread && thread->stream) {
|
if (thread && thread->stream) {
|
||||||
thread->stream->postAudioFrame(thread->stream, sampleLeft, sampleRight);
|
thread->stream->postAudioFrame(thread->stream, sampleLeft, sampleRight);
|
||||||
}
|
}
|
||||||
GBASyncProduceAudio(audio->p->sync, produced >= CircleBufferCapacity(&audio->left) / sizeof(int32_t) * 3);
|
GBASyncProduceAudio(audio->p->sync, produced >= CircleBufferCapacity(&audio->left));
|
||||||
}
|
}
|
||||||
|
|
||||||
void GBAAudioSerialize(const struct GBAAudio* audio, struct GBASerializedState* state) {
|
void GBAAudioSerialize(const struct GBAAudio* audio, struct GBASerializedState* state) {
|
||||||
|
|
Loading…
Reference in New Issue