diff options
author | Lennart Poettering <lennart@poettering.net> | 2008-06-26 02:56:00 +0200 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2008-06-26 02:56:00 +0200 |
commit | eab1cb8df952bc302d14efd1640d96f8bbdb148a (patch) | |
tree | d3de307ecdaa284308e7d726153ffb6a10f012cc /src/modules/module-alsa-sink.c | |
parent | 1e36b57b13d421dab20c436e0ae302acc34fbac9 (diff) |
make sure to call process_rewind() under all circumstances before we do the next loop iteration
Diffstat (limited to 'src/modules/module-alsa-sink.c')
-rw-r--r-- | src/modules/module-alsa-sink.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/src/modules/module-alsa-sink.c b/src/modules/module-alsa-sink.c index 6765775a..5818dee2 100644 --- a/src/modules/module-alsa-sink.c +++ b/src/modules/module-alsa-sink.c @@ -882,7 +882,7 @@ static void sink_update_requested_latency_cb(pa_sink *s) { if (u->hwbuf_unused_frames > before) { pa_log_debug("Requesting rewind due to latency change."); - pa_sink_request_rewind(s, 0); + pa_sink_request_rewind(s, (size_t) -1); } } @@ -967,9 +967,12 @@ static void thread_func(void *userdata) { int work_done; pa_usec_t sleep_usec; - if (u->sink->thread_info.rewind_nbytes > 0) - if (process_rewind(u) < 0) - goto fail; + if (u->sink->thread_info.rewind_requested) { + if (u->sink->thread_info.rewind_nbytes <= 0) + pa_sink_process_rewind(u->sink, 0); + else if (process_rewind(u) < 0) + goto fail; + } if (u->use_mmap) work_done = mmap_write(u, &sleep_usec); |