audioconvert: only emit node_info once in add_listener

This commit is contained in:
Wim Taymans 2019-08-13 18:42:21 +02:00
parent ab069d45be
commit 697976f416
2 changed files with 18 additions and 2 deletions

View file

@ -71,6 +71,7 @@ struct impl {
struct spa_hook_list hooks; struct spa_hook_list hooks;
struct spa_callbacks callbacks; struct spa_callbacks callbacks;
unsigned int add_listener:1;
unsigned int use_converter:1; unsigned int use_converter:1;
unsigned int started:1; unsigned int started:1;
unsigned int driver:1; unsigned int driver:1;
@ -186,6 +187,9 @@ static int link_io(struct impl *this)
static void emit_node_info(struct impl *this, bool full) static void emit_node_info(struct impl *this, bool full)
{ {
if (this->add_listener)
return;
if (full) if (full)
this->info.change_mask = this->info_all; this->info.change_mask = this->info_all;
@ -446,7 +450,7 @@ static int impl_node_add_listener(void *object,
spa_log_trace(this->log, NAME" %p: add listener %p", this, listener); spa_log_trace(this->log, NAME" %p: add listener %p", this, listener);
spa_hook_list_isolate(&this->hooks, &save, listener, events, data); spa_hook_list_isolate(&this->hooks, &save, listener, events, data);
emit_node_info(this, true); this->add_listener = true;
if (this->use_converter) { if (this->use_converter) {
spa_zero(l); spa_zero(l);
@ -454,6 +458,10 @@ static int impl_node_add_listener(void *object,
spa_hook_remove(&l); spa_hook_remove(&l);
} }
this->add_listener = false;
emit_node_info(this, true);
spa_hook_list_join(&this->hooks, &save); spa_hook_list_join(&this->hooks, &save);
return 0; return 0;

View file

@ -106,6 +106,7 @@ struct impl {
struct spa_hook listener[2]; struct spa_hook listener[2];
unsigned int started:1; unsigned int started:1;
unsigned int add_listener:1;
}; };
#define IS_MONITOR_PORT(this,dir,port_id) (dir == SPA_DIRECTION_OUTPUT && port_id > 0 && \ #define IS_MONITOR_PORT(this,dir,port_id) (dir == SPA_DIRECTION_OUTPUT && port_id > 0 && \
@ -113,6 +114,9 @@ struct impl {
static void emit_node_info(struct impl *this, bool full) static void emit_node_info(struct impl *this, bool full)
{ {
if (this->add_listener)
return;
if (full) if (full)
this->info.change_mask = this->info_all; this->info.change_mask = this->info_all;
if (this->info.change_mask) { if (this->info.change_mask) {
@ -798,7 +802,7 @@ impl_node_add_listener(void *object,
spa_log_trace(this->log, "%p: add listener %p", this, listener); spa_log_trace(this->log, "%p: add listener %p", this, listener);
emit_node_info(this, true); this->add_listener = true;
spa_zero(l); spa_zero(l);
spa_node_add_listener(this->fmt[SPA_DIRECTION_INPUT], spa_node_add_listener(this->fmt[SPA_DIRECTION_INPUT],
@ -815,6 +819,10 @@ impl_node_add_listener(void *object,
spa_hook_remove(&l[2]); spa_hook_remove(&l[2]);
spa_hook_remove(&l[3]); spa_hook_remove(&l[3]);
this->add_listener = false;
emit_node_info(this, true);
spa_hook_list_join(&this->hooks, &save); spa_hook_list_join(&this->hooks, &save);
return 0; return 0;