summaryrefslogtreecommitdiffstats
path: root/src/pulsecore/source-output.c
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2008-04-09 01:16:43 +0000
committerLennart Poettering <lennart@poettering.net>2008-04-09 01:16:43 +0000
commitda37a7e93db0f17e03f94f7835d7075faa3ac4ba (patch)
tree040b705c610962c101bf1225709efc2858de7e49 /src/pulsecore/source-output.c
parentad18107223e8c4199b86bb3616677a2b57293fad (diff)
export both min and max latency that is configured for a sink; add API for querying the requested latency of a sink/source from the main thread
git-svn-id: file:///home/lennart/svn/public/pulseaudio/branches/glitch-free@2225 fefdeb5f-60dc-0310-8127-8f9354f1896f
Diffstat (limited to 'src/pulsecore/source-output.c')
-rw-r--r--src/pulsecore/source-output.c15
1 files changed, 12 insertions, 3 deletions
diff --git a/src/pulsecore/source-output.c b/src/pulsecore/source-output.c
index d6c2a2b2..cf576ac9 100644
--- a/src/pulsecore/source-output.c
+++ b/src/pulsecore/source-output.c
@@ -364,13 +364,22 @@ pa_usec_t pa_source_output_set_requested_latency(pa_source_output *o, pa_usec_t
pa_source_output_assert_ref(o);
pa_assert(PA_SOURCE_OUTPUT_LINKED(o->state));
- if (usec < o->source->min_latency)
- usec = o->source->min_latency;
+ if (usec > 0) {
+
+ if (o->source->max_latency > 0 && usec > o->source->max_latency)
+ usec = o->source->max_latency;
+
+ if (o->source->min_latency > 0 && usec < o->source->min_latency)
+ usec = o->source->min_latency;
+
+ }
if (PA_SOURCE_OUTPUT_LINKED(o->state))
pa_asyncmsgq_post(o->source->asyncmsgq, PA_MSGOBJECT(o), PA_SOURCE_OUTPUT_MESSAGE_SET_REQUESTED_LATENCY, NULL, (int64_t) usec, NULL, NULL);
- else
+ else {
o->thread_info.requested_source_latency = usec;
+ o->source->thread_info.requested_latency_valid = FALSE;
+ }
return usec;
}