- input latency
- fix tcp/native
- suid
+- add volume to create_stream command in native protocol
** later ***
- xmlrpc/http
}
static pa_usec_t sink_get_latency_cb(struct pa_sink *s) {
+ pa_usec_t r = 0;
struct userdata *u = s->userdata;
snd_pcm_sframes_t frames;
assert(s && u && u->sink);
if (frames < 0)
frames = 0;
- return pa_bytes_to_usec(frames * u->frame_size, &s->sample_spec);
+ r += pa_bytes_to_usec(frames * u->frame_size, &s->sample_spec);
+
+ if (u->memchunk.memblock)
+ r += pa_bytes_to_usec(u->memchunk.length, &s->sample_spec);
+
+ return r;
}
int pa__init(struct pa_core *c, struct pa_module*m) {
}
static pa_usec_t sink_get_latency_cb(struct pa_sink *s) {
+ pa_usec_t r = 0;
int arg;
struct userdata *u = s->userdata;
assert(s && u && u->sink);
return 0;
}
- return pa_bytes_to_usec(arg, &s->sample_spec);
+ r += pa_bytes_to_usec(arg, &s->sample_spec);
+
+ if (u->memchunk.memblock)
+ r += pa_bytes_to_usec(u->memchunk.length, &s->sample_spec);
+
+ return r;
}
int pa__init(struct pa_core *c, struct pa_module*m) {
}
pa_usec_t pa_sink_input_get_latency(struct pa_sink_input *i) {
+ pa_usec_t r = 0;
assert(i);
if (i->get_latency)
- return i->get_latency(i);
+ r += i->get_latency(i);
- return 0;
+ if (i->resampled_chunk.memblock)
+ r += pa_bytes_to_usec(i->resampled_chunk.length, &i->sample_spec);
+
+ return r;
}
int pa_sink_input_peek(struct pa_sink_input *i, struct pa_memchunk *chunk) {