params: only emit callback for requested seq

This commit is contained in:
Wim Taymans 2019-03-14 16:37:58 +01:00
parent efa74adfc3
commit 8b2b7c3053
2 changed files with 8 additions and 4 deletions

View file

@ -1160,12 +1160,14 @@ struct result_node_params_data {
int (*callback) (void *data, int seq,
uint32_t id, uint32_t index, uint32_t next,
struct spa_pod *param);
int seq;
};
static void result_node_params(void *data, int seq, int res, const void *result)
{
struct result_node_params_data *d = data;
const struct spa_result_node_params *r = result;
if (d->seq == seq)
d->callback(d->data, seq, r->id, r->index, r->next, r->param);
}
@ -1180,7 +1182,7 @@ int pw_node_for_each_param(struct pw_node *node,
void *data)
{
int res;
struct result_node_params_data user_data = { data, callback };
struct result_node_params_data user_data = { data, callback, seq };
struct spa_hook listener;
static const struct spa_node_events node_events = {
SPA_VERSION_NODE_EVENTS,

View file

@ -736,12 +736,14 @@ struct result_port_params_data {
int (*callback) (void *data, int seq,
uint32_t id, uint32_t index, uint32_t next,
struct spa_pod *param);
int seq;
};
static void result_port_params(void *data, int seq, int res, const void *result)
{
struct result_port_params_data *d = data;
const struct spa_result_node_params *r = result;
if (d->seq == seq)
d->callback(d->data, seq, r->id, r->index, r->next, r->param);
}
@ -757,7 +759,7 @@ int pw_port_for_each_param(struct pw_port *port,
{
int res;
struct pw_node *node = port->node;
struct result_port_params_data user_data = { data, callback };
struct result_port_params_data user_data = { data, callback, seq };
struct spa_hook listener;
static const struct spa_node_events node_events = {
SPA_VERSION_NODE_EVENTS,