link: improve buffer negotiation

Don't free the buffers when the mix is released, this will happen
when nothing is using them anymore with port_use_buffers later.

Mark a mixer as having buffers when the output port has buffers.
Don't set buffers on a mixer port that already has buffers.
This commit is contained in:
Wim Taymans 2019-08-06 17:07:21 +02:00
parent d98a6d22d5
commit ba118e26a3
2 changed files with 26 additions and 31 deletions

View file

@ -1319,7 +1319,6 @@ static int port_release_mix(void *data, struct pw_port_mix *mix)
{
struct port *port = data;
struct impl *impl = port->impl;
struct node *this = &impl->node;
struct mix *m;
pw_log_debug(NAME " %p: remove mix io %d %p %p", impl, mix->id, mix->io,
@ -1329,7 +1328,8 @@ static int port_release_mix(void *data, struct pw_port_mix *mix)
return -EINVAL;
pw_map_remove(&impl->io_map, mix->id);
mix_clear(this, m);
m->valid = false;
return 0;
}

View file

@ -584,9 +584,9 @@ static int do_allocation(struct pw_link *this)
}
if (output->allocation.n_buffers) {
move_allocation(&output->allocation, &allocation);
pw_log_debug("link %p: reusing %d output buffers %p", this,
allocation.n_buffers, allocation.buffers);
output->allocation.n_buffers, output->allocation.buffers);
this->rt.out_mix.have_buffers = true;
} else {
struct spa_pod **params, *param;
uint8_t buffer[4096];
@ -676,14 +676,10 @@ static int do_allocation(struct pw_link *this)
}
out_res = res;
out_alloc = true;
move_allocation(&allocation, &output->allocation);
pw_log_debug("link %p: allocated %d buffers %p from output port: %s", this,
allocation.n_buffers, allocation.buffers, spa_strerror(out_res));
}
}
if (!out_alloc) {
} else {
pw_log_debug("link %p: using %d buffers %p on output port", this,
allocation.n_buffers, allocation.buffers);
@ -696,9 +692,8 @@ static int do_allocation(struct pw_link *this)
goto error;
}
out_res = res;
move_allocation(&allocation, &output->allocation);
}
move_allocation(&allocation, &output->allocation);
if (SPA_RESULT_IS_ASYNC(out_res)) {
pw_work_queue_add(impl->work, output->node,
@ -709,7 +704,7 @@ static int do_allocation(struct pw_link *this)
} else {
complete_paused(output->node, this, out_res, 0);
}
}
pw_log_debug("link %p: using %d buffers %p on input port", this,
output->allocation.n_buffers, output->allocation.buffers);