mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-02 09:01:50 -05:00
seq: track port latency
This commit is contained in:
parent
4c09eb227f
commit
f03f1926e3
2 changed files with 47 additions and 31 deletions
|
|
@ -399,6 +399,8 @@ static void free_port(struct seq_state *state, struct seq_stream *stream, struct
|
||||||
static void init_port(struct seq_state *state, struct seq_port *port, const snd_seq_addr_t *addr,
|
static void init_port(struct seq_state *state, struct seq_port *port, const snd_seq_addr_t *addr,
|
||||||
unsigned int caps)
|
unsigned int caps)
|
||||||
{
|
{
|
||||||
|
enum spa_direction reverse = SPA_DIRECTION_REVERSE(port->direction);
|
||||||
|
|
||||||
port->addr = *addr;
|
port->addr = *addr;
|
||||||
port->info_all = SPA_PORT_CHANGE_MASK_FLAGS |
|
port->info_all = SPA_PORT_CHANGE_MASK_FLAGS |
|
||||||
SPA_PORT_CHANGE_MASK_PROPS |
|
SPA_PORT_CHANGE_MASK_PROPS |
|
||||||
|
|
@ -407,19 +409,24 @@ static void init_port(struct seq_state *state, struct seq_port *port, const snd_
|
||||||
port->info.flags = SPA_PORT_FLAG_LIVE;
|
port->info.flags = SPA_PORT_FLAG_LIVE;
|
||||||
if (caps & (SND_SEQ_PORT_TYPE_HARDWARE|SND_SEQ_PORT_TYPE_PORT|SND_SEQ_PORT_TYPE_SPECIFIC))
|
if (caps & (SND_SEQ_PORT_TYPE_HARDWARE|SND_SEQ_PORT_TYPE_PORT|SND_SEQ_PORT_TYPE_SPECIFIC))
|
||||||
port->info.flags |= SPA_PORT_FLAG_PHYSICAL | SPA_PORT_FLAG_TERMINAL;
|
port->info.flags |= SPA_PORT_FLAG_PHYSICAL | SPA_PORT_FLAG_TERMINAL;
|
||||||
port->params[IDX_EnumFormat] = SPA_PARAM_INFO(SPA_PARAM_EnumFormat, SPA_PARAM_INFO_READ);
|
port->params[PORT_EnumFormat] = SPA_PARAM_INFO(SPA_PARAM_EnumFormat, SPA_PARAM_INFO_READ);
|
||||||
port->params[IDX_Meta] = SPA_PARAM_INFO(SPA_PARAM_Meta, SPA_PARAM_INFO_READ);
|
port->params[PORT_Meta] = SPA_PARAM_INFO(SPA_PARAM_Meta, SPA_PARAM_INFO_READ);
|
||||||
port->params[IDX_IO] = SPA_PARAM_INFO(SPA_PARAM_IO, SPA_PARAM_INFO_READ);
|
port->params[PORT_IO] = SPA_PARAM_INFO(SPA_PARAM_IO, SPA_PARAM_INFO_READ);
|
||||||
port->params[IDX_Format] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_WRITE);
|
port->params[PORT_Format] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_WRITE);
|
||||||
port->params[IDX_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
|
port->params[PORT_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
|
||||||
port->params[IDX_Latency] = SPA_PARAM_INFO(SPA_PARAM_Latency, SPA_PARAM_INFO_READWRITE);
|
port->params[PORT_Latency] = SPA_PARAM_INFO(SPA_PARAM_Latency, SPA_PARAM_INFO_READWRITE);
|
||||||
|
|
||||||
port->info.params = port->params;
|
port->info.params = port->params;
|
||||||
port->info.n_params = N_PORT_PARAMS;
|
port->info.n_params = N_PORT_PARAMS;
|
||||||
|
|
||||||
spa_list_init(&port->free);
|
spa_list_init(&port->free);
|
||||||
spa_list_init(&port->ready);
|
spa_list_init(&port->ready);
|
||||||
|
|
||||||
|
port->latency[port->direction] = SPA_LATENCY_INFO(
|
||||||
|
port->direction,
|
||||||
|
.min_quantum = 1.0f,
|
||||||
|
.max_quantum = 1.0f);
|
||||||
|
port->latency[reverse] = SPA_LATENCY_INFO(reverse);
|
||||||
|
|
||||||
spa_alsa_seq_activate_port(state, port, true);
|
spa_alsa_seq_activate_port(state, port, true);
|
||||||
|
|
||||||
emit_port_info(state, port, true);
|
emit_port_info(state, port, true);
|
||||||
|
|
@ -578,14 +585,9 @@ impl_node_port_enum_params(void *object, int seq,
|
||||||
|
|
||||||
case SPA_PARAM_Latency:
|
case SPA_PARAM_Latency:
|
||||||
switch (result.index) {
|
switch (result.index) {
|
||||||
case 0:
|
case 0: case 1:
|
||||||
{
|
param = spa_latency_build(&b, id, &port->latency[result.index]);
|
||||||
struct spa_latency_info info = {
|
|
||||||
.direction = direction,
|
|
||||||
.min_quantum = 1.0f, .max_quantum = 1.0f };
|
|
||||||
param = spa_latency_build(&b, id, &info);
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
default:
|
default:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
@ -646,11 +648,11 @@ static int port_set_format(void *object, struct seq_port *port,
|
||||||
port->info.rate = SPA_FRACTION(1, 1);
|
port->info.rate = SPA_FRACTION(1, 1);
|
||||||
port->info.change_mask |= SPA_PORT_CHANGE_MASK_PARAMS;
|
port->info.change_mask |= SPA_PORT_CHANGE_MASK_PARAMS;
|
||||||
if (port->have_format) {
|
if (port->have_format) {
|
||||||
port->params[IDX_Format] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_READWRITE);
|
port->params[PORT_Format] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_READWRITE);
|
||||||
port->params[IDX_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, SPA_PARAM_INFO_READ);
|
port->params[PORT_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, SPA_PARAM_INFO_READ);
|
||||||
} else {
|
} else {
|
||||||
port->params[IDX_Format] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_WRITE);
|
port->params[PORT_Format] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_WRITE);
|
||||||
port->params[IDX_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
|
port->params[PORT_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
|
||||||
}
|
}
|
||||||
emit_port_info(this, port, false);
|
emit_port_info(this, port, false);
|
||||||
|
|
||||||
|
|
@ -678,8 +680,19 @@ impl_node_port_set_param(void *object,
|
||||||
res = port_set_format(this, port, flags, param);
|
res = port_set_format(this, port, flags, param);
|
||||||
break;
|
break;
|
||||||
case SPA_PARAM_Latency:
|
case SPA_PARAM_Latency:
|
||||||
res = 0;
|
{
|
||||||
|
struct spa_latency_info info;
|
||||||
|
if ((res = spa_latency_parse(param, &info)) < 0)
|
||||||
|
return res;
|
||||||
|
if (direction == info.direction)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
port->latency[info.direction] = info;
|
||||||
|
port->info.change_mask |= SPA_PORT_CHANGE_MASK_PARAMS;
|
||||||
|
port->params[PORT_Latency].flags ^= SPA_PARAM_INFO_SERIAL;
|
||||||
|
emit_port_info(this, port, false);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
res = -ENOENT;
|
res = -ENOENT;
|
||||||
break;
|
break;
|
||||||
|
|
@ -891,9 +904,9 @@ impl_init(const struct spa_handle_factory *factory,
|
||||||
this->info.max_input_ports = MAX_PORTS;
|
this->info.max_input_ports = MAX_PORTS;
|
||||||
this->info.max_output_ports = MAX_PORTS;
|
this->info.max_output_ports = MAX_PORTS;
|
||||||
this->info.flags = SPA_NODE_FLAG_RT;
|
this->info.flags = SPA_NODE_FLAG_RT;
|
||||||
this->params[IDX_PropInfo] = SPA_PARAM_INFO(SPA_PARAM_PropInfo, SPA_PARAM_INFO_READ);
|
this->params[NODE_PropInfo] = SPA_PARAM_INFO(SPA_PARAM_PropInfo, SPA_PARAM_INFO_READ);
|
||||||
this->params[IDX_Props] = SPA_PARAM_INFO(SPA_PARAM_Props, SPA_PARAM_INFO_READWRITE);
|
this->params[NODE_Props] = SPA_PARAM_INFO(SPA_PARAM_Props, SPA_PARAM_INFO_READWRITE);
|
||||||
this->params[IDX_NODE_IO] = SPA_PARAM_INFO(SPA_PARAM_IO, SPA_PARAM_INFO_READ);
|
this->params[NODE_IO] = SPA_PARAM_INFO(SPA_PARAM_IO, SPA_PARAM_INFO_READ);
|
||||||
this->info.params = this->params;
|
this->info.params = this->params;
|
||||||
this->info.n_params = N_NODE_PARAMS;
|
this->info.n_params = N_NODE_PARAMS;
|
||||||
reset_props(&this->props);
|
reset_props(&this->props);
|
||||||
|
|
|
||||||
|
|
@ -44,6 +44,7 @@ extern "C" {
|
||||||
#include <spa/node/io.h>
|
#include <spa/node/io.h>
|
||||||
#include <spa/param/param.h>
|
#include <spa/param/param.h>
|
||||||
#include <spa/param/audio/format-utils.h>
|
#include <spa/param/audio/format-utils.h>
|
||||||
|
#include <spa/param/latency-utils.h>
|
||||||
|
|
||||||
#include "dll.h"
|
#include "dll.h"
|
||||||
|
|
||||||
|
|
@ -71,12 +72,12 @@ struct seq_port {
|
||||||
|
|
||||||
uint64_t info_all;
|
uint64_t info_all;
|
||||||
struct spa_port_info info;
|
struct spa_port_info info;
|
||||||
#define IDX_EnumFormat 0
|
#define PORT_EnumFormat 0
|
||||||
#define IDX_Meta 1
|
#define PORT_Meta 1
|
||||||
#define IDX_IO 2
|
#define PORT_IO 2
|
||||||
#define IDX_Format 3
|
#define PORT_Format 3
|
||||||
#define IDX_Buffers 4
|
#define PORT_Buffers 4
|
||||||
#define IDX_Latency 5
|
#define PORT_Latency 5
|
||||||
#define N_PORT_PARAMS 6
|
#define N_PORT_PARAMS 6
|
||||||
struct spa_param_info params[N_PORT_PARAMS];
|
struct spa_param_info params[N_PORT_PARAMS];
|
||||||
|
|
||||||
|
|
@ -96,6 +97,8 @@ struct seq_port {
|
||||||
unsigned int have_format:1;
|
unsigned int have_format:1;
|
||||||
unsigned int valid:1;
|
unsigned int valid:1;
|
||||||
unsigned int active:1;
|
unsigned int active:1;
|
||||||
|
|
||||||
|
struct spa_latency_info latency[2];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct seq_stream {
|
struct seq_stream {
|
||||||
|
|
@ -135,9 +138,9 @@ struct seq_state {
|
||||||
|
|
||||||
uint64_t info_all;
|
uint64_t info_all;
|
||||||
struct spa_node_info info;
|
struct spa_node_info info;
|
||||||
#define IDX_PropInfo 0
|
#define NODE_PropInfo 0
|
||||||
#define IDX_Props 1
|
#define NODE_Props 1
|
||||||
#define IDX_NODE_IO 2
|
#define NODE_IO 2
|
||||||
#define N_NODE_PARAMS 3
|
#define N_NODE_PARAMS 3
|
||||||
struct spa_param_info params[N_NODE_PARAMS];
|
struct spa_param_info params[N_NODE_PARAMS];
|
||||||
struct props props;
|
struct props props;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue