mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-11-03 09:01:54 -05:00 
			
		
		
		
	Revert "rework param updates"
This reverts commit 5aa7746c95.
Routes are duplicated for some reason, needs more debugging.
			
			
This commit is contained in:
		
							parent
							
								
									be25a00ddb
								
							
						
					
					
						commit
						994fc1169e
					
				
					 6 changed files with 88 additions and 112 deletions
				
			
		| 
						 | 
					@ -73,45 +73,24 @@ static void core_sync(struct manager *m)
 | 
				
			||||||
	pw_log_debug("sync start %u", m->sync_seq);
 | 
						pw_log_debug("sync start %u", m->sync_seq);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static uint32_t clear_params(struct spa_list *param_list, uint32_t id)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	struct pw_manager_param *p, *t;
 | 
					 | 
				
			||||||
	uint32_t count = 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	spa_list_for_each_safe(p, t, param_list, link) {
 | 
					 | 
				
			||||||
		if (id == SPA_ID_INVALID || p->id == id) {
 | 
					 | 
				
			||||||
			spa_list_remove(&p->link);
 | 
					 | 
				
			||||||
			free(p);
 | 
					 | 
				
			||||||
			count++;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	return count;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static struct pw_manager_param *add_param(struct spa_list *params, uint32_t id, const struct spa_pod *param)
 | 
					static struct pw_manager_param *add_param(struct spa_list *params, uint32_t id, const struct spa_pod *param)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct pw_manager_param *p;
 | 
						struct pw_manager_param *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (id == SPA_ID_INVALID) {
 | 
					 | 
				
			||||||
	if (param == NULL || !spa_pod_is_object(param)) {
 | 
						if (param == NULL || !spa_pod_is_object(param)) {
 | 
				
			||||||
		errno = EINVAL;
 | 
							errno = EINVAL;
 | 
				
			||||||
		return NULL;
 | 
							return NULL;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
						if (id == SPA_ID_INVALID)
 | 
				
			||||||
		id = SPA_POD_OBJECT_ID(param);
 | 
							id = SPA_POD_OBJECT_ID(param);
 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	p = malloc(sizeof(*p) + (param != NULL ? SPA_POD_SIZE(param) : 0));
 | 
						p = malloc(sizeof(*p) + SPA_POD_SIZE(param));
 | 
				
			||||||
	if (p == NULL)
 | 
						if (p == NULL)
 | 
				
			||||||
		return NULL;
 | 
							return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	p->id = id;
 | 
						p->id = id;
 | 
				
			||||||
	if (param != NULL) {
 | 
					 | 
				
			||||||
	p->param = SPA_MEMBER(p, sizeof(*p), struct spa_pod);
 | 
						p->param = SPA_MEMBER(p, sizeof(*p), struct spa_pod);
 | 
				
			||||||
	memcpy(p->param, param, SPA_POD_SIZE(param));
 | 
						memcpy(p->param, param, SPA_POD_SIZE(param));
 | 
				
			||||||
	} else {
 | 
					 | 
				
			||||||
		clear_params(params, id);
 | 
					 | 
				
			||||||
		p->param = NULL;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	spa_list_append(params, &p->link);
 | 
						spa_list_append(params, &p->link);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return p;
 | 
						return p;
 | 
				
			||||||
| 
						 | 
					@ -129,6 +108,21 @@ static bool has_param(struct spa_list *param_list, struct pw_manager_param *p)
 | 
				
			||||||
	return false;
 | 
						return false;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static uint32_t clear_params(struct spa_list *param_list, uint32_t id)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct pw_manager_param *p, *t;
 | 
				
			||||||
 | 
						uint32_t count = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						spa_list_for_each_safe(p, t, param_list, link) {
 | 
				
			||||||
 | 
							if (id == SPA_ID_INVALID || p->id == id) {
 | 
				
			||||||
 | 
								spa_list_remove(&p->link);
 | 
				
			||||||
 | 
								free(p);
 | 
				
			||||||
 | 
								count++;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return count;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static struct object *find_object(struct manager *m, uint32_t id)
 | 
					static struct object *find_object(struct manager *m, uint32_t id)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					@ -146,16 +140,14 @@ static void object_update_params(struct object *o)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct pw_manager_param *p;
 | 
						struct pw_manager_param *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						spa_list_for_each(p, &o->pending_list, link)
 | 
				
			||||||
 | 
							clear_params(&o->this.param_list, p->id);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_list_consume(p, &o->pending_list, link) {
 | 
						spa_list_consume(p, &o->pending_list, link) {
 | 
				
			||||||
		spa_list_remove(&p->link);
 | 
							spa_list_remove(&p->link);
 | 
				
			||||||
		if (p->param == NULL) {
 | 
					 | 
				
			||||||
			clear_params(&o->this.param_list, p->id);
 | 
					 | 
				
			||||||
			free(p);
 | 
					 | 
				
			||||||
		} else {
 | 
					 | 
				
			||||||
		spa_list_append(&o->this.param_list, &p->link);
 | 
							spa_list_append(&o->this.param_list, &p->link);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void object_destroy(struct object *o)
 | 
					static void object_destroy(struct object *o)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					@ -285,7 +277,7 @@ static void device_event_info(void *object, const struct pw_device_info *info)
 | 
				
			||||||
			case SPA_PARAM_Route:
 | 
								case SPA_PARAM_Route:
 | 
				
			||||||
				break;
 | 
									break;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			add_param(&o->pending_list, id, NULL);
 | 
								clear_params(&o->pending_list, id);
 | 
				
			||||||
			if (!(info->params[i].flags & SPA_PARAM_INFO_READ))
 | 
								if (!(info->params[i].flags & SPA_PARAM_INFO_READ))
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -390,7 +382,7 @@ static void node_event_info(void *object, const struct pw_node_info *info)
 | 
				
			||||||
			info->params[i].user = 0;
 | 
								info->params[i].user = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			changed++;
 | 
								changed++;
 | 
				
			||||||
			add_param(&o->pending_list, id, NULL);
 | 
								clear_params(&o->pending_list, id);
 | 
				
			||||||
			if (!(info->params[i].flags & SPA_PARAM_INFO_READ))
 | 
								if (!(info->params[i].flags & SPA_PARAM_INFO_READ))
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -741,7 +741,7 @@ static void device_info(void *data, const struct spa_device_info *info)
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			pw_log_debug(NAME" %p: update param %d", device, id);
 | 
								pw_log_debug(NAME" %p: update param %d", device, id);
 | 
				
			||||||
			pw_param_add(&impl->pending_list, id, NULL);
 | 
								pw_param_clear(&impl->pending_list, id);
 | 
				
			||||||
			device->info.params[i] = info->params[i];
 | 
								device->info.params[i] = info->params[i];
 | 
				
			||||||
			device->info.params[i].user = 0;
 | 
								device->info.params[i].user = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1286,7 +1286,7 @@ static void node_info(void *data, const struct spa_node_info *info)
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			pw_log_debug(NAME" %p: update param %d", node, id);
 | 
								pw_log_debug(NAME" %p: update param %d", node, id);
 | 
				
			||||||
			pw_param_add(&impl->pending_list, id, NULL);
 | 
								pw_param_clear(&impl->pending_list, id);
 | 
				
			||||||
			node->info.params[i] = info->params[i];
 | 
								node->info.params[i] = info->params[i];
 | 
				
			||||||
			node->info.params[i].user = 0;
 | 
								node->info.params[i].user = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -378,7 +378,7 @@ static void update_info(struct pw_impl_port *port, const struct spa_port_info *i
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			pw_log_debug(NAME" %p: update param %d", port, id);
 | 
								pw_log_debug(NAME" %p: update param %d", port, id);
 | 
				
			||||||
			pw_param_add(&impl->pending_list, id, NULL);
 | 
								pw_param_clear(&impl->pending_list, id);
 | 
				
			||||||
			port->info.params[i] = info->params[i];
 | 
								port->info.params[i] = info->params[i];
 | 
				
			||||||
			port->info.params[i].user = 0;
 | 
								port->info.params[i].user = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -90,6 +90,28 @@ struct pw_param {
 | 
				
			||||||
	struct spa_pod *param;
 | 
						struct spa_pod *param;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static inline struct pw_param *pw_param_add(struct spa_list *params,
 | 
				
			||||||
 | 
							uint32_t id, const struct spa_pod *param)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct pw_param *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (param == NULL || !spa_pod_is_object(param)) {
 | 
				
			||||||
 | 
							errno = EINVAL;
 | 
				
			||||||
 | 
							return NULL;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if (id == SPA_ID_INVALID)
 | 
				
			||||||
 | 
							id = SPA_POD_OBJECT_ID(param);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if ((p = malloc(sizeof(*p) + SPA_POD_SIZE(param))) == NULL)
 | 
				
			||||||
 | 
							return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						p->id = id;
 | 
				
			||||||
 | 
						p->param = SPA_MEMBER(p, sizeof(*p), struct spa_pod);
 | 
				
			||||||
 | 
						memcpy(p->param, param, SPA_POD_SIZE(param));
 | 
				
			||||||
 | 
						spa_list_append(params, &p->link);
 | 
				
			||||||
 | 
						return p;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static inline uint32_t pw_param_clear(struct spa_list *param_list, uint32_t id)
 | 
					static inline uint32_t pw_param_clear(struct spa_list *param_list, uint32_t id)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct pw_param *p, *t;
 | 
						struct pw_param *p, *t;
 | 
				
			||||||
| 
						 | 
					@ -105,48 +127,18 @@ static inline uint32_t pw_param_clear(struct spa_list *param_list, uint32_t id)
 | 
				
			||||||
	return count;
 | 
						return count;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static inline struct pw_param *pw_param_add(struct spa_list *params,
 | 
					 | 
				
			||||||
		uint32_t id, const struct spa_pod *param)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	struct pw_param *p;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (id == SPA_ID_INVALID) {
 | 
					 | 
				
			||||||
		if (param == NULL || !spa_pod_is_object(param)) {
 | 
					 | 
				
			||||||
			errno = EINVAL;
 | 
					 | 
				
			||||||
			return NULL;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
		id = SPA_POD_OBJECT_ID(param);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if ((p = malloc(sizeof(*p) + (param != NULL ? SPA_POD_SIZE(param) : 0))) == NULL)
 | 
					 | 
				
			||||||
		return NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	p->id = id;
 | 
					 | 
				
			||||||
	if (param != NULL) {
 | 
					 | 
				
			||||||
		p->param = SPA_MEMBER(p, sizeof(*p), struct spa_pod);
 | 
					 | 
				
			||||||
		memcpy(p->param, param, SPA_POD_SIZE(param));
 | 
					 | 
				
			||||||
	} else {
 | 
					 | 
				
			||||||
		pw_param_clear(params, id);
 | 
					 | 
				
			||||||
		p->param = NULL;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	spa_list_append(params, &p->link);
 | 
					 | 
				
			||||||
	return p;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static inline void pw_param_update(struct spa_list *param_list, struct spa_list *pending_list)
 | 
					static inline void pw_param_update(struct spa_list *param_list, struct spa_list *pending_list)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct pw_param *p;
 | 
						struct pw_param *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						spa_list_for_each(p, pending_list, link)
 | 
				
			||||||
 | 
							pw_param_clear(param_list, p->id);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_list_consume(p, pending_list, link) {
 | 
						spa_list_consume(p, pending_list, link) {
 | 
				
			||||||
		spa_list_remove(&p->link);
 | 
							spa_list_remove(&p->link);
 | 
				
			||||||
		if (p->param == NULL) {
 | 
					 | 
				
			||||||
			pw_param_clear(param_list, p->id);
 | 
					 | 
				
			||||||
			free(p);
 | 
					 | 
				
			||||||
		} else {
 | 
					 | 
				
			||||||
		spa_list_append(param_list, &p->link);
 | 
							spa_list_append(param_list, &p->link);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
static inline struct spa_param_info *pw_param_info_find(struct spa_param_info info[],
 | 
					static inline struct spa_param_info *pw_param_info_find(struct spa_param_info info[],
 | 
				
			||||||
		uint32_t n_info, uint32_t id)
 | 
							uint32_t n_info, uint32_t id)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -122,6 +122,29 @@ static void core_sync(struct data *d)
 | 
				
			||||||
	pw_log_debug("sync start %u", d->sync_seq);
 | 
						pw_log_debug("sync start %u", d->sync_seq);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static struct param *add_param(struct spa_list *params, uint32_t id, const struct spa_pod *param)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct param *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (param == NULL || !spa_pod_is_object(param)) {
 | 
				
			||||||
 | 
							errno = EINVAL;
 | 
				
			||||||
 | 
							return NULL;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if (id == SPA_ID_INVALID)
 | 
				
			||||||
 | 
							id = SPA_POD_OBJECT_ID(param);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						p = malloc(sizeof(*p) + SPA_POD_SIZE(param));
 | 
				
			||||||
 | 
						if (p == NULL)
 | 
				
			||||||
 | 
							return NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						p->id = id;
 | 
				
			||||||
 | 
						p->param = SPA_MEMBER(p, sizeof(*p), struct spa_pod);
 | 
				
			||||||
 | 
						memcpy(p->param, param, SPA_POD_SIZE(param));
 | 
				
			||||||
 | 
						spa_list_append(params, &p->link);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return p;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static uint32_t clear_params(struct spa_list *param_list, uint32_t id)
 | 
					static uint32_t clear_params(struct spa_list *param_list, uint32_t id)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct param *p, *t;
 | 
						struct param *p, *t;
 | 
				
			||||||
| 
						 | 
					@ -137,35 +160,6 @@ static uint32_t clear_params(struct spa_list *param_list, uint32_t id)
 | 
				
			||||||
	return count;
 | 
						return count;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static struct param *add_param(struct spa_list *params, uint32_t id, const struct spa_pod *param)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	struct param *p;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (id == SPA_ID_INVALID) {
 | 
					 | 
				
			||||||
		if (param == NULL || !spa_pod_is_object(param)) {
 | 
					 | 
				
			||||||
			errno = EINVAL;
 | 
					 | 
				
			||||||
			return NULL;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
		id = SPA_POD_OBJECT_ID(param);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	p = malloc(sizeof(*p) + (param != NULL ? SPA_POD_SIZE(param) : 0));
 | 
					 | 
				
			||||||
	if (p == NULL)
 | 
					 | 
				
			||||||
		return NULL;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	p->id = id;
 | 
					 | 
				
			||||||
	if (param != NULL) {
 | 
					 | 
				
			||||||
		p->param = SPA_MEMBER(p, sizeof(*p), struct spa_pod);
 | 
					 | 
				
			||||||
		memcpy(p->param, param, SPA_POD_SIZE(param));
 | 
					 | 
				
			||||||
	} else {
 | 
					 | 
				
			||||||
		clear_params(params, id);
 | 
					 | 
				
			||||||
		p->param = NULL;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	spa_list_append(params, &p->link);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return p;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static struct object *find_object(struct data *d, uint32_t id)
 | 
					static struct object *find_object(struct data *d, uint32_t id)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct object *o;
 | 
						struct object *o;
 | 
				
			||||||
| 
						 | 
					@ -180,16 +174,14 @@ static void object_update_params(struct object *o)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct param *p;
 | 
						struct param *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						spa_list_for_each(p, &o->pending_list, link)
 | 
				
			||||||
 | 
							clear_params(&o->param_list, p->id);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_list_consume(p, &o->pending_list, link) {
 | 
						spa_list_consume(p, &o->pending_list, link) {
 | 
				
			||||||
		spa_list_remove(&p->link);
 | 
							spa_list_remove(&p->link);
 | 
				
			||||||
		if (p->param == NULL) {
 | 
					 | 
				
			||||||
			clear_params(&o->param_list, p->id);
 | 
					 | 
				
			||||||
			free(p);
 | 
					 | 
				
			||||||
		} else {
 | 
					 | 
				
			||||||
		spa_list_append(&o->param_list, &p->link);
 | 
							spa_list_append(&o->param_list, &p->link);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void object_destroy(struct object *o)
 | 
					static void object_destroy(struct object *o)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					@ -490,7 +482,7 @@ static void put_params(struct data *d, const char *key,
 | 
				
			||||||
		put_begin(d, spa_debug_type_find_short_name(spa_type_param, pi->id),
 | 
							put_begin(d, spa_debug_type_find_short_name(spa_type_param, pi->id),
 | 
				
			||||||
				"[", flags);
 | 
									"[", flags);
 | 
				
			||||||
		spa_list_for_each(p, list, link) {
 | 
							spa_list_for_each(p, list, link) {
 | 
				
			||||||
			if (p->id == pi->id)
 | 
								if (p->id == pi->id && flags == 0)
 | 
				
			||||||
				put_pod(d, NULL, p->param);
 | 
									put_pod(d, NULL, p->param);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		put_end(d, "]", flags);
 | 
							put_end(d, "]", flags);
 | 
				
			||||||
| 
						 | 
					@ -842,7 +834,7 @@ static void node_event_info(void *object, const struct pw_node_info *info)
 | 
				
			||||||
			info->params[i].user = 0;
 | 
								info->params[i].user = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			changed++;
 | 
								changed++;
 | 
				
			||||||
			add_param(&o->pending_list, id, NULL);
 | 
								clear_params(&o->pending_list, id);
 | 
				
			||||||
			if (!(info->params[i].flags & SPA_PARAM_INFO_READ))
 | 
								if (!(info->params[i].flags & SPA_PARAM_INFO_READ))
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -925,7 +917,7 @@ static void port_event_info(void *object, const struct pw_port_info *info)
 | 
				
			||||||
			info->params[i].user = 0;
 | 
								info->params[i].user = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			changed++;
 | 
								changed++;
 | 
				
			||||||
			add_param(&o->pending_list, id, NULL);
 | 
								clear_params(&o->pending_list, id);
 | 
				
			||||||
			if (!(info->params[i].flags & SPA_PARAM_INFO_READ))
 | 
								if (!(info->params[i].flags & SPA_PARAM_INFO_READ))
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue