jack: Use latency of sink as buffer size

This commit is contained in:
Wim Taymans 2017-10-16 18:12:20 +02:00
parent ce6b75cf63
commit 630dbd2c90
2 changed files with 27 additions and 4 deletions

View file

@ -70,6 +70,8 @@ struct socket {
};
struct impl {
uint32_t prop_min_latency;
struct pw_core *core;
struct pw_type *t;
struct pw_module *module;
@ -1284,6 +1286,7 @@ static bool on_global(void *data, struct pw_global *global)
const char *str;
char *error;
struct pw_port *in_port, *out_port;
struct spa_props *props;
if (pw_global_get_type(global) != impl->t->node)
return true;
@ -1314,6 +1317,19 @@ static bool on_global(void *data, struct pw_global *global)
free(error);
return true;
}
if (spa_node_get_props(node->node, &props) == SPA_RESULT_OK) {
int min_latency = -1;
spa_props_parse(props,
":", impl->prop_min_latency, "?i", &min_latency, NULL);
if (min_latency != -1)
jack_engine_control_set_buffer_size(impl->server.engine_control, min_latency);
}
pw_log_debug("module-jack %p: using buffer_size %d", impl,
impl->server.engine_control->buffer_size);
pw_link_register(impl->sink_link, NULL, pw_module_get_global(impl->module));
return false;
@ -1487,6 +1503,7 @@ static bool module_init(struct pw_module *module, struct pw_properties *properti
impl->t = pw_core_get_type(core);
impl->module = module;
impl->properties = properties;
impl->prop_min_latency = spa_type_map_get_id(impl->t->map, SPA_TYPE_PROPS__minLatency);
spa_list_init(&impl->socket_list);
spa_list_init(&impl->client_list);

View file

@ -1010,6 +1010,15 @@ static inline uint64_t calc_computation(jack_nframes_t buffer_size)
return 100;
}
static inline void
jack_engine_control_set_buffer_size(struct jack_engine_control *ctrl, jack_nframes_t buffer_size)
{
ctrl->buffer_size = buffer_size;
ctrl->period_usecs = 1000000.f / ctrl->sample_rate * ctrl->buffer_size;
ctrl->period = ctrl->constraint = ctrl->period_usecs * 1000;
ctrl->computation = calc_computation(ctrl->buffer_size) * 1000;
}
static inline struct jack_engine_control *
jack_engine_control_alloc(const char* name)
{
@ -1024,11 +1033,9 @@ jack_engine_control_alloc(const char* name)
ctrl = (struct jack_engine_control *)jack_shm_addr(&info);
ctrl->info = info;
ctrl->buffer_size = 128;
ctrl->sample_rate = 48000;
ctrl->sync_mode = false;
ctrl->temporary = false;
ctrl->period_usecs = 1000000.f / ctrl->sample_rate * ctrl->buffer_size;
ctrl->timeout_usecs = 0;
ctrl->max_delayed_usecs = 0.f;
ctrl->xrun_delayed_usecs = 0.f;
@ -1050,8 +1057,7 @@ jack_engine_control_alloc(const char* name)
jack_engine_control_reset_rolling_usecs(ctrl);
ctrl->CPU_load = 0.f;
ctrl->period = ctrl->constraint = ctrl->period_usecs * 1000;
ctrl->computation = calc_computation(ctrl->buffer_size) * 1000;
jack_engine_control_set_buffer_size(ctrl, 128);
return ctrl;
}