mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-11-03 09:01:54 -05:00 
			
		
		
		
	spa: Clean up some of the param handling
This commit is contained in:
		
							parent
							
								
									079b90bde5
								
							
						
					
					
						commit
						89c10dad70
					
				
					 4 changed files with 78 additions and 55 deletions
				
			
		| 
						 | 
				
			
			@ -114,7 +114,13 @@ struct port {
 | 
			
		|||
 | 
			
		||||
	uint64_t info_all;
 | 
			
		||||
	struct spa_port_info info;
 | 
			
		||||
	struct spa_param_info params[8];
 | 
			
		||||
#define IDX_EnumFormat	0
 | 
			
		||||
#define IDX_Meta	1
 | 
			
		||||
#define IDX_IO		2
 | 
			
		||||
#define IDX_Format	3
 | 
			
		||||
#define IDX_Buffers	4
 | 
			
		||||
#define N_PORT_PARAMS	5
 | 
			
		||||
	struct spa_param_info params[N_PORT_PARAMS];
 | 
			
		||||
	char position[16];
 | 
			
		||||
 | 
			
		||||
	struct spa_audio_info format;
 | 
			
		||||
| 
						 | 
				
			
			@ -140,7 +146,11 @@ struct impl {
 | 
			
		|||
 | 
			
		||||
	uint64_t info_all;
 | 
			
		||||
	struct spa_node_info info;
 | 
			
		||||
	struct spa_param_info params[8];
 | 
			
		||||
#define IDX_PortConfig	0
 | 
			
		||||
#define IDX_PropInfo	1
 | 
			
		||||
#define IDX_Props	2
 | 
			
		||||
#define N_NODE_PARAMS	3
 | 
			
		||||
	struct spa_param_info params[N_NODE_PARAMS];
 | 
			
		||||
 | 
			
		||||
	struct spa_hook_list hooks;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -232,13 +242,13 @@ static int init_port(struct impl *this, enum spa_direction direction, uint32_t p
 | 
			
		|||
	port->info = SPA_PORT_INFO_INIT();
 | 
			
		||||
	port->info.flags = SPA_PORT_FLAG_NO_REF |
 | 
			
		||||
		SPA_PORT_FLAG_DYNAMIC_DATA;
 | 
			
		||||
	port->params[0] = SPA_PARAM_INFO(SPA_PARAM_EnumFormat, SPA_PARAM_INFO_READ);
 | 
			
		||||
	port->params[1] = SPA_PARAM_INFO(SPA_PARAM_Meta, SPA_PARAM_INFO_READ);
 | 
			
		||||
	port->params[2] = SPA_PARAM_INFO(SPA_PARAM_IO, SPA_PARAM_INFO_READ);
 | 
			
		||||
	port->params[3] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_WRITE);
 | 
			
		||||
	port->params[4] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
 | 
			
		||||
	port->params[IDX_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[IDX_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[IDX_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
 | 
			
		||||
	port->info.params = port->params;
 | 
			
		||||
	port->info.n_params = 5;
 | 
			
		||||
	port->info.n_params = N_PORT_PARAMS;
 | 
			
		||||
 | 
			
		||||
	port->n_buffers = 0;
 | 
			
		||||
	port->have_format = false;
 | 
			
		||||
| 
						 | 
				
			
			@ -565,14 +575,14 @@ static int impl_node_set_param(void *object, uint32_t id, uint32_t flags,
 | 
			
		|||
		port->have_format = true;
 | 
			
		||||
 | 
			
		||||
		this->info.change_mask |= SPA_NODE_CHANGE_MASK_PARAMS;
 | 
			
		||||
		this->params[2].flags ^= SPA_PARAM_INFO_SERIAL;
 | 
			
		||||
		this->params[IDX_Props].flags ^= SPA_PARAM_INFO_SERIAL;
 | 
			
		||||
		emit_node_info(this, false);
 | 
			
		||||
		return 0;
 | 
			
		||||
	}
 | 
			
		||||
	case SPA_PARAM_Props:
 | 
			
		||||
		if (apply_props(this, param) > 0) {
 | 
			
		||||
			this->info.change_mask |= SPA_NODE_CHANGE_MASK_PARAMS;
 | 
			
		||||
			this->params[2].flags ^= SPA_PARAM_INFO_SERIAL;
 | 
			
		||||
			this->params[IDX_Props].flags ^= SPA_PARAM_INFO_SERIAL;
 | 
			
		||||
			emit_node_info(this, false);
 | 
			
		||||
		}
 | 
			
		||||
		break;
 | 
			
		||||
| 
						 | 
				
			
			@ -980,11 +990,11 @@ static int port_set_format(void *object,
 | 
			
		|||
 | 
			
		||||
	port->info.change_mask |= SPA_PORT_CHANGE_MASK_PARAMS;
 | 
			
		||||
	if (port->have_format) {
 | 
			
		||||
		port->params[3] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_READWRITE);
 | 
			
		||||
		port->params[4] = SPA_PARAM_INFO(SPA_PARAM_Buffers, SPA_PARAM_INFO_READ);
 | 
			
		||||
		port->params[IDX_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);
 | 
			
		||||
	} else {
 | 
			
		||||
		port->params[3] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_WRITE);
 | 
			
		||||
		port->params[4] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
 | 
			
		||||
		port->params[IDX_Format] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_WRITE);
 | 
			
		||||
		port->params[IDX_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
 | 
			
		||||
	}
 | 
			
		||||
	emit_port_info(this, port, false);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1401,11 +1411,11 @@ impl_init(const struct spa_handle_factory *factory,
 | 
			
		|||
	this->info.max_output_ports = MAX_PORTS+1;
 | 
			
		||||
	this->info.flags = SPA_NODE_FLAG_RT |
 | 
			
		||||
		SPA_NODE_FLAG_IN_PORT_CONFIG;
 | 
			
		||||
	this->params[0] = SPA_PARAM_INFO(SPA_PARAM_PortConfig, SPA_PARAM_INFO_WRITE);
 | 
			
		||||
	this->params[1] = SPA_PARAM_INFO(SPA_PARAM_PropInfo, SPA_PARAM_INFO_READ);
 | 
			
		||||
	this->params[2] = SPA_PARAM_INFO(SPA_PARAM_Props, SPA_PARAM_INFO_READWRITE);
 | 
			
		||||
	this->params[IDX_PortConfig] = SPA_PARAM_INFO(SPA_PARAM_PortConfig, SPA_PARAM_INFO_WRITE);
 | 
			
		||||
	this->params[IDX_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->info.params = this->params;
 | 
			
		||||
	this->info.n_params = 3;
 | 
			
		||||
	this->info.n_params = N_NODE_PARAMS;
 | 
			
		||||
 | 
			
		||||
	port = GET_OUT_PORT(this, 0);
 | 
			
		||||
	port->direction = SPA_DIRECTION_OUTPUT;
 | 
			
		||||
| 
						 | 
				
			
			@ -1414,13 +1424,13 @@ impl_init(const struct spa_handle_factory *factory,
 | 
			
		|||
			SPA_PORT_CHANGE_MASK_PARAMS;
 | 
			
		||||
	port->info = SPA_PORT_INFO_INIT();
 | 
			
		||||
	port->info.flags = SPA_PORT_FLAG_DYNAMIC_DATA;
 | 
			
		||||
	port->params[0] = SPA_PARAM_INFO(SPA_PARAM_EnumFormat, SPA_PARAM_INFO_READ);
 | 
			
		||||
	port->params[1] = SPA_PARAM_INFO(SPA_PARAM_Meta, SPA_PARAM_INFO_READ);
 | 
			
		||||
	port->params[2] = SPA_PARAM_INFO(SPA_PARAM_IO, SPA_PARAM_INFO_READ);
 | 
			
		||||
	port->params[3] = SPA_PARAM_INFO(SPA_PARAM_Format, SPA_PARAM_INFO_WRITE);
 | 
			
		||||
	port->params[4] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
 | 
			
		||||
	port->params[IDX_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[IDX_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[IDX_Buffers] = SPA_PARAM_INFO(SPA_PARAM_Buffers, 0);
 | 
			
		||||
	port->info.params = port->params;
 | 
			
		||||
	port->info.n_params = 5;
 | 
			
		||||
	port->info.n_params = N_PORT_PARAMS;
 | 
			
		||||
	spa_list_init(&port->queue);
 | 
			
		||||
 | 
			
		||||
	this->volume.cpu_flags = this->cpu_flags;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue