mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-04 13:30:12 -05:00
port: don't schedule disabled ports
This commit is contained in:
parent
2ea9addcf2
commit
c0865581b9
1 changed files with 14 additions and 3 deletions
|
|
@ -58,8 +58,11 @@ static int schedule_tee_input(struct spa_node *data)
|
||||||
|
|
||||||
if (!spa_list_is_empty(&node->ports[SPA_DIRECTION_OUTPUT])) {
|
if (!spa_list_is_empty(&node->ports[SPA_DIRECTION_OUTPUT])) {
|
||||||
pw_log_trace("node %p: tee input %d %d", node, io->status, io->buffer_id);
|
pw_log_trace("node %p: tee input %d %d", node, io->status, io->buffer_id);
|
||||||
spa_list_for_each(p, &node->ports[SPA_DIRECTION_OUTPUT], link)
|
spa_list_for_each(p, &node->ports[SPA_DIRECTION_OUTPUT], link) {
|
||||||
|
if (p->flags & SPA_GRAPH_PORT_FLAG_DISABLED)
|
||||||
|
continue;
|
||||||
*p->io = *io;
|
*p->io = *io;
|
||||||
|
}
|
||||||
io->buffer_id = SPA_ID_INVALID;
|
io->buffer_id = SPA_ID_INVALID;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -74,8 +77,11 @@ static int schedule_tee_output(struct spa_node *data)
|
||||||
struct spa_graph_port *p;
|
struct spa_graph_port *p;
|
||||||
struct spa_io_buffers *io = this->rt.mix_port.io;
|
struct spa_io_buffers *io = this->rt.mix_port.io;
|
||||||
|
|
||||||
spa_list_for_each(p, &node->ports[SPA_DIRECTION_OUTPUT], link)
|
spa_list_for_each(p, &node->ports[SPA_DIRECTION_OUTPUT], link) {
|
||||||
|
if (p->flags & SPA_GRAPH_PORT_FLAG_DISABLED)
|
||||||
|
continue;
|
||||||
*io = *p->io;
|
*io = *p->io;
|
||||||
|
}
|
||||||
pw_log_trace("node %p: tee output %d %d", node, io->status, io->buffer_id);
|
pw_log_trace("node %p: tee output %d %d", node, io->status, io->buffer_id);
|
||||||
return io->status;
|
return io->status;
|
||||||
}
|
}
|
||||||
|
|
@ -109,6 +115,8 @@ static int schedule_mix_input(struct spa_node *data)
|
||||||
struct spa_io_buffers *io = this->rt.mix_port.io;
|
struct spa_io_buffers *io = this->rt.mix_port.io;
|
||||||
|
|
||||||
spa_list_for_each(p, &node->ports[SPA_DIRECTION_INPUT], link) {
|
spa_list_for_each(p, &node->ports[SPA_DIRECTION_INPUT], link) {
|
||||||
|
if (p->flags & SPA_GRAPH_PORT_FLAG_DISABLED)
|
||||||
|
continue;
|
||||||
pw_log_trace("mix %p: input %p %p->%p %d %d", node,
|
pw_log_trace("mix %p: input %p %p->%p %d %d", node,
|
||||||
p, p->io, io, p->io->status, p->io->buffer_id);
|
p, p->io, io, p->io->status, p->io->buffer_id);
|
||||||
*io = *p->io;
|
*io = *p->io;
|
||||||
|
|
@ -126,8 +134,11 @@ static int schedule_mix_output(struct spa_node *data)
|
||||||
struct spa_io_buffers *io = this->rt.mix_port.io;
|
struct spa_io_buffers *io = this->rt.mix_port.io;
|
||||||
|
|
||||||
if (!spa_list_is_empty(&node->ports[SPA_DIRECTION_INPUT])) {
|
if (!spa_list_is_empty(&node->ports[SPA_DIRECTION_INPUT])) {
|
||||||
spa_list_for_each(p, &node->ports[SPA_DIRECTION_INPUT], link)
|
spa_list_for_each(p, &node->ports[SPA_DIRECTION_INPUT], link) {
|
||||||
|
if (p->flags & SPA_GRAPH_PORT_FLAG_DISABLED)
|
||||||
|
continue;
|
||||||
*p->io = *io;
|
*p->io = *io;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
io->status = SPA_STATUS_HAVE_BUFFER;
|
io->status = SPA_STATUS_HAVE_BUFFER;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue