From 66cfa72eb4fd4669dfd7e465c07c41bb7e6d3d85 Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Mon, 18 Jan 2010 01:33:04 +0100 Subject: native: rework handling of seeks that depend on variables the client does not know anything about All seeks/flushes that depend on the playback buffer read pointer cannot be accounted for properly in the client since it does not know the actual read pointer. Due to that the clients do not account for it at all. We need do the same on the server side. And we did, but a little bit too extreme. While we properly have not applied the changes to the "request" counter we still do have to apply it to the "missing" counter. This patch fixes that. --- src/modules/module-loopback.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'src/modules/module-loopback.c') diff --git a/src/modules/module-loopback.c b/src/modules/module-loopback.c index bb0182b0..15ef96ef 100644 --- a/src/modules/module-loopback.c +++ b/src/modules/module-loopback.c @@ -430,7 +430,7 @@ static int sink_input_process_msg_cb(pa_msgobject *obj, int code, void *data, in if (PA_SINK_IS_OPENED(u->sink_input->sink->thread_info.state)) pa_memblockq_push_align(u->memblockq, chunk); else - pa_memblockq_flush_write(u->memblockq); + pa_memblockq_flush_write(u->memblockq, TRUE); update_min_memblockq_length(u); @@ -457,7 +457,7 @@ static int sink_input_process_msg_cb(pa_msgobject *obj, int code, void *data, in if (PA_SINK_IS_OPENED(u->sink_input->sink->thread_info.state)) pa_memblockq_seek(u->memblockq, -offset, PA_SEEK_RELATIVE, TRUE); else - pa_memblockq_flush_write(u->memblockq); + pa_memblockq_flush_write(u->memblockq, TRUE); u->recv_counter -= offset; -- cgit