dummy backend: fix playback

This commit is contained in:
Andrew Kelley 2015-07-20 00:35:46 -07:00
parent 24f466a0a0
commit 96c8332246
2 changed files with 46 additions and 15 deletions

View file

@ -25,6 +25,12 @@ static void panic(const char *format, ...) {
abort(); abort();
} }
static int usage(char *exe) {
fprintf(stderr, "Usage: %s [--dummy] [--alsa] [--pulseaudio]\n", exe);
return 1;
}
static const float PI = 3.1415926535f; static const float PI = 3.1415926535f;
static float seconds_offset = 0.0f; static float seconds_offset = 0.0f;
static void write_callback(struct SoundIoOutStream *outstream, int requested_frame_count) { static void write_callback(struct SoundIoOutStream *outstream, int requested_frame_count) {
@ -69,12 +75,29 @@ static void error_callback(struct SoundIoOutStream *device, int err) {
} }
int main(int argc, char **argv) { int main(int argc, char **argv) {
char *exe = argv[0];
enum SoundIoBackend backend = SoundIoBackendNone;
for (int i = 1; i < argc; i += 1) {
char *arg = argv[i];
if (strcmp("--dummy", arg) == 0) {
backend = SoundIoBackendDummy;
} else if (strcmp("--alsa", arg) == 0) {
backend = SoundIoBackendAlsa;
} else if (strcmp("--pulseaudio", arg) == 0) {
backend = SoundIoBackendPulseAudio;
} else {
return usage(exe);
}
}
struct SoundIo *soundio = soundio_create(); struct SoundIo *soundio = soundio_create();
if (!soundio) if (!soundio)
panic("out of memory"); panic("out of memory");
int err; int err = (backend == SoundIoBackendNone) ?
if ((err = soundio_connect(soundio))) soundio_connect(soundio) : soundio_connect_backend(soundio, backend);
if (err)
panic("error connecting: %s", soundio_strerror(err)); panic("error connecting: %s", soundio_strerror(err));
int default_out_device_index = soundio_get_default_output_device_index(soundio); int default_out_device_index = soundio_get_default_output_device_index(soundio);

View file

@ -138,7 +138,7 @@ static int outstream_open_dummy(SoundIoPrivate *si, SoundIoOutStreamPrivate *os)
} }
os->backend_data = osd; os->backend_data = osd;
osd->buffer_size = outstream->bytes_per_frame * outstream->buffer_duration; osd->buffer_size = outstream->bytes_per_frame * outstream->sample_rate * outstream->buffer_duration;
soundio_ring_buffer_init(&osd->ring_buffer, osd->buffer_size); soundio_ring_buffer_init(&osd->ring_buffer, osd->buffer_size);
@ -185,13 +185,19 @@ static int outstream_begin_write_dummy(SoundIoPrivate *si,
int byte_count = *frame_count * outstream->bytes_per_frame; int byte_count = *frame_count * outstream->bytes_per_frame;
assert(byte_count <= osd->buffer_size); assert(byte_count <= osd->buffer_size);
char *write_ptr = soundio_ring_buffer_write_ptr(&osd->ring_buffer); int free_byte_count = soundio_ring_buffer_free_count(&osd->ring_buffer);
for (int ch = 0; ch < outstream->layout.channel_count; ch += 1) { int free_frame_count = free_byte_count / outstream->bytes_per_frame;
osd->areas[ch].ptr = write_ptr + outstream->bytes_per_sample * ch; *frame_count = min(*frame_count, free_frame_count);
osd->areas[ch].step = outstream->bytes_per_frame;
}
*out_areas = osd->areas; if (free_frame_count) {
char *write_ptr = soundio_ring_buffer_write_ptr(&osd->ring_buffer);
for (int ch = 0; ch < outstream->layout.channel_count; ch += 1) {
osd->areas[ch].ptr = write_ptr + outstream->bytes_per_sample * ch;
osd->areas[ch].step = outstream->bytes_per_frame;
}
*out_areas = osd->areas;
}
return 0; return 0;
} }
@ -319,14 +325,15 @@ int soundio_dummy_init(SoundIoPrivate *si) {
destroy_dummy(si); destroy_dummy(si);
return SoundIoErrorNoMem; return SoundIoErrorNoMem;
} }
device->layout_count = 1; device->layout_count = soundio_channel_layout_builtin_count();
device->layouts = allocate<SoundIoChannelLayout>(1); device->layouts = allocate<SoundIoChannelLayout>(device->layout_count);
if (!device->layouts) { if (!device->layouts) {
soundio_device_unref(device); soundio_device_unref(device);
destroy_dummy(si); destroy_dummy(si);
return SoundIoErrorNoMem; return SoundIoErrorNoMem;
} }
device->layouts[0] = *soundio_channel_layout_get_builtin(SoundIoChannelLayoutIdMono); for (int i = 0; i < device->layout_count; i += 1)
device->layouts[i] = *soundio_channel_layout_get_builtin(i);
int err; int err;
if ((err = set_all_device_formats(device))) { if ((err = set_all_device_formats(device))) {
@ -371,14 +378,15 @@ int soundio_dummy_init(SoundIoPrivate *si) {
return SoundIoErrorNoMem; return SoundIoErrorNoMem;
} }
device->layout_count = 1; device->layout_count = soundio_channel_layout_builtin_count();
device->layouts = allocate<SoundIoChannelLayout>(1); device->layouts = allocate<SoundIoChannelLayout>(device->layout_count);
if (!device->layouts) { if (!device->layouts) {
soundio_device_unref(device); soundio_device_unref(device);
destroy_dummy(si); destroy_dummy(si);
return SoundIoErrorNoMem; return SoundIoErrorNoMem;
} }
device->layouts[0] = *soundio_channel_layout_get_builtin(SoundIoChannelLayoutIdMono); for (int i = 0; i < device->layout_count; i += 1)
device->layouts[i] = *soundio_channel_layout_get_builtin(i);
int err; int err;
if ((err = set_all_device_formats(device))) { if ((err = set_all_device_formats(device))) {