mirror of
https://github.com/Ryujinx/libsoundio.git
synced 2025-01-05 17:15:39 +00:00
PulseAudio: fix invalid value sent to pa_stream_write
This commit is contained in:
parent
1eeeff5a24
commit
787a7164e0
|
@ -20,6 +20,7 @@ struct SoundIoOutStreamPulseAudio {
|
||||||
atomic_bool stream_ready;
|
atomic_bool stream_ready;
|
||||||
pa_buffer_attr buffer_attr;
|
pa_buffer_attr buffer_attr;
|
||||||
SoundIoChannelArea areas[SOUNDIO_MAX_CHANNELS];
|
SoundIoChannelArea areas[SOUNDIO_MAX_CHANNELS];
|
||||||
|
char *write_ptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct SoundIoInStreamPulseAudio {
|
struct SoundIoInStreamPulseAudio {
|
||||||
|
@ -740,12 +741,11 @@ static int outstream_begin_write_pa(SoundIoPrivate *si,
|
||||||
SoundIoOutStreamPulseAudio *ospa = (SoundIoOutStreamPulseAudio *)os->backend_data;
|
SoundIoOutStreamPulseAudio *ospa = (SoundIoOutStreamPulseAudio *)os->backend_data;
|
||||||
pa_stream *stream = ospa->stream;
|
pa_stream *stream = ospa->stream;
|
||||||
size_t byte_count = *frame_count * outstream->bytes_per_frame;
|
size_t byte_count = *frame_count * outstream->bytes_per_frame;
|
||||||
char *data;
|
if (pa_stream_begin_write(stream, (void**)&ospa->write_ptr, &byte_count))
|
||||||
if (pa_stream_begin_write(stream, (void**)&data, &byte_count))
|
|
||||||
return SoundIoErrorStreaming;
|
return SoundIoErrorStreaming;
|
||||||
|
|
||||||
for (int ch = 0; ch < outstream->layout.channel_count; ch += 1) {
|
for (int ch = 0; ch < outstream->layout.channel_count; ch += 1) {
|
||||||
ospa->areas[ch].ptr = data + outstream->bytes_per_sample * ch;
|
ospa->areas[ch].ptr = ospa->write_ptr + outstream->bytes_per_sample * ch;
|
||||||
ospa->areas[ch].step = outstream->bytes_per_frame;
|
ospa->areas[ch].step = outstream->bytes_per_frame;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -760,7 +760,7 @@ static int outstream_write_pa(SoundIoPrivate *si, SoundIoOutStreamPrivate *os, i
|
||||||
SoundIoOutStreamPulseAudio *ospa = (SoundIoOutStreamPulseAudio *)os->backend_data;
|
SoundIoOutStreamPulseAudio *ospa = (SoundIoOutStreamPulseAudio *)os->backend_data;
|
||||||
pa_stream *stream = ospa->stream;
|
pa_stream *stream = ospa->stream;
|
||||||
size_t byte_count = frame_count * outstream->bytes_per_frame;
|
size_t byte_count = frame_count * outstream->bytes_per_frame;
|
||||||
if (pa_stream_write(stream, ospa->areas[0].ptr, byte_count, NULL, 0, PA_SEEK_RELATIVE))
|
if (pa_stream_write(stream, ospa->write_ptr, byte_count, NULL, 0, PA_SEEK_RELATIVE))
|
||||||
return SoundIoErrorStreaming;
|
return SoundIoErrorStreaming;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -780,7 +780,21 @@ static void outstream_clear_buffer_pa(SoundIoPrivate *si,
|
||||||
}
|
}
|
||||||
|
|
||||||
static int outstream_pause_pa(SoundIoPrivate *si, SoundIoOutStreamPrivate *os, bool pause) {
|
static int outstream_pause_pa(SoundIoPrivate *si, SoundIoOutStreamPrivate *os, bool pause) {
|
||||||
soundio_panic("TODO");
|
SoundIoOutStreamPulseAudio *ospa = (SoundIoOutStreamPulseAudio *)os->backend_data;
|
||||||
|
SoundIoPulseAudio *sipa = (SoundIoPulseAudio *)si->backend_data;
|
||||||
|
|
||||||
|
pa_threaded_mainloop_lock(sipa->main_loop);
|
||||||
|
|
||||||
|
if (pause != !pa_stream_is_corked(ospa->stream)) {
|
||||||
|
pa_operation *op = pa_stream_cork(ospa->stream, pause, NULL, NULL);
|
||||||
|
if (!op)
|
||||||
|
return SoundIoErrorStreaming;
|
||||||
|
pa_operation_unref(op);
|
||||||
|
}
|
||||||
|
|
||||||
|
pa_threaded_mainloop_unlock(sipa->main_loop);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void recording_stream_state_callback(pa_stream *stream, void *userdata) {
|
static void recording_stream_state_callback(pa_stream *stream, void *userdata) {
|
||||||
|
|
Loading…
Reference in a new issue