mirror of
https://github.com/Ryujinx/libsoundio.git
synced 2025-01-18 15:27:08 +00:00
fix devices race condition
This commit is contained in:
parent
71a365ca1b
commit
20f3f76ef3
|
@ -184,10 +184,11 @@ int soundio_connect_backend(SoundIo *soundio, SoundIoBackend backend) {
|
|||
#endif
|
||||
case SoundIoBackendDummy:
|
||||
si->current_backend = SoundIoBackendDummy;
|
||||
err = soundio_dummy_init(si);
|
||||
if (err)
|
||||
if ((err = soundio_dummy_init(si))) {
|
||||
soundio_disconnect(soundio);
|
||||
return err;
|
||||
}
|
||||
return 0;
|
||||
case SoundIoBackendNone:
|
||||
return SoundIoErrorInvalid;
|
||||
}
|
||||
|
@ -229,13 +230,12 @@ void soundio_disconnect(struct SoundIo *soundio) {
|
|||
|
||||
void soundio_flush_events(struct SoundIo *soundio) {
|
||||
SoundIoPrivate *si = (SoundIoPrivate *)soundio;
|
||||
assert(si->flush_events);
|
||||
if (si->flush_events)
|
||||
si->flush_events(si);
|
||||
}
|
||||
|
||||
int soundio_get_input_device_count(struct SoundIo *soundio) {
|
||||
SoundIoPrivate *si = (SoundIoPrivate *)soundio;
|
||||
if (!si->safe_devices_info)
|
||||
soundio_flush_events(soundio);
|
||||
assert(si->safe_devices_info);
|
||||
return si->safe_devices_info->input_devices.length;
|
||||
|
@ -243,6 +243,7 @@ int soundio_get_input_device_count(struct SoundIo *soundio) {
|
|||
|
||||
int soundio_get_output_device_count(struct SoundIo *soundio) {
|
||||
SoundIoPrivate *si = (SoundIoPrivate *)soundio;
|
||||
if (!si->safe_devices_info)
|
||||
soundio_flush_events(soundio);
|
||||
assert(si->safe_devices_info);
|
||||
return si->safe_devices_info->output_devices.length;
|
||||
|
@ -250,6 +251,7 @@ int soundio_get_output_device_count(struct SoundIo *soundio) {
|
|||
|
||||
int soundio_get_default_input_device_index(struct SoundIo *soundio) {
|
||||
SoundIoPrivate *si = (SoundIoPrivate *)soundio;
|
||||
if (!si->safe_devices_info)
|
||||
soundio_flush_events(soundio);
|
||||
assert(si->safe_devices_info);
|
||||
return si->safe_devices_info->default_input_index;
|
||||
|
@ -257,6 +259,7 @@ int soundio_get_default_input_device_index(struct SoundIo *soundio) {
|
|||
|
||||
int soundio_get_default_output_device_index(struct SoundIo *soundio) {
|
||||
SoundIoPrivate *si = (SoundIoPrivate *)soundio;
|
||||
if (!si->safe_devices_info)
|
||||
soundio_flush_events(soundio);
|
||||
assert(si->safe_devices_info);
|
||||
return si->safe_devices_info->default_output_index;
|
||||
|
|
Loading…
Reference in a new issue