mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-11-03 09:01:54 -05:00 
			
		
		
		
	handle cleanup of remote proxies
Destroying a resource informs the client to destroy the proxy. Destroying an object destroys all the bound resources on it.
This commit is contained in:
		
							parent
							
								
									e6f45a7686
								
							
						
					
					
						commit
						5e8a3afe17
					
				
					 8 changed files with 38 additions and 4 deletions
				
			
		| 
						 | 
				
			
			@ -121,7 +121,6 @@ core_dispatch_func (void             *object,
 | 
			
		|||
      proxy = pinos_map_lookup (&this->objects, m->id);
 | 
			
		||||
      if (proxy) {
 | 
			
		||||
        pinos_log_debug ("context %p: object remove %u", this, m->id);
 | 
			
		||||
        pinos_map_remove (&this->objects, m->id);
 | 
			
		||||
        pinos_proxy_destroy (proxy);
 | 
			
		||||
      }
 | 
			
		||||
      break;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -113,7 +113,7 @@ pinos_map_for_each (PinosMap *map,
 | 
			
		|||
  PinosMapItem *item;
 | 
			
		||||
 | 
			
		||||
  pinos_array_for_each (item, &map->items) {
 | 
			
		||||
    if (!pinos_map_item_is_free (item))
 | 
			
		||||
    if (item->data && !pinos_map_item_is_free (item))
 | 
			
		||||
      func (item->data, data);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -46,6 +46,13 @@ client_dispatch_func (void             *object,
 | 
			
		|||
  return SPA_RESULT_OK;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
client_unbind_func (void *data)
 | 
			
		||||
{
 | 
			
		||||
  PinosResource *resource = data;
 | 
			
		||||
  spa_list_remove (&resource->link);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
client_bind_func (PinosGlobal *global,
 | 
			
		||||
                  PinosClient *client,
 | 
			
		||||
| 
						 | 
				
			
			@ -61,13 +68,15 @@ client_bind_func (PinosGlobal *global,
 | 
			
		|||
                                 id,
 | 
			
		||||
                                 global->core->uri.client,
 | 
			
		||||
                                 global->object,
 | 
			
		||||
                                 NULL);
 | 
			
		||||
                                 client_unbind_func);
 | 
			
		||||
 | 
			
		||||
  resource->dispatch_func = client_dispatch_func;
 | 
			
		||||
  resource->dispatch_data = global;
 | 
			
		||||
 | 
			
		||||
  pinos_log_debug ("client %p: bound to %d", global->object, resource->id);
 | 
			
		||||
 | 
			
		||||
  spa_list_insert (this->resource_list.prev, &resource->link);
 | 
			
		||||
 | 
			
		||||
  m.info = &info;
 | 
			
		||||
  info.id = resource->id;
 | 
			
		||||
  info.change_mask = ~0;
 | 
			
		||||
| 
						 | 
				
			
			@ -102,6 +111,8 @@ pinos_client_new (PinosCore       *core,
 | 
			
		|||
  this->core = core;
 | 
			
		||||
  this->properties = properties;
 | 
			
		||||
 | 
			
		||||
  spa_list_init (&this->resource_list);
 | 
			
		||||
 | 
			
		||||
  pinos_map_init (&this->objects, 64);
 | 
			
		||||
  pinos_signal_init (&this->destroy_signal);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -149,6 +160,8 @@ destroy_resource (void *object,
 | 
			
		|||
void
 | 
			
		||||
pinos_client_destroy (PinosClient * client)
 | 
			
		||||
{
 | 
			
		||||
  PinosResource *resource, *tmp;
 | 
			
		||||
 | 
			
		||||
  pinos_log_debug ("client %p: destroy", client);
 | 
			
		||||
  pinos_signal_emit (&client->destroy_signal, client);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -157,6 +170,9 @@ pinos_client_destroy (PinosClient * client)
 | 
			
		|||
  pinos_global_destroy (client->global);
 | 
			
		||||
  spa_list_remove (&client->link);
 | 
			
		||||
 | 
			
		||||
  spa_list_for_each_safe (resource, tmp, &client->resource_list, link)
 | 
			
		||||
    pinos_resource_destroy (resource);
 | 
			
		||||
 | 
			
		||||
  pinos_main_loop_defer (client->core->main_loop,
 | 
			
		||||
                         client,
 | 
			
		||||
                         SPA_RESULT_WAIT_SYNC,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -45,6 +45,8 @@ struct _PinosClient {
 | 
			
		|||
 | 
			
		||||
  PinosMap objects;
 | 
			
		||||
 | 
			
		||||
  SpaList resource_list;
 | 
			
		||||
 | 
			
		||||
  PinosSendFunc   send_func;
 | 
			
		||||
  void           *send_data;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -326,7 +326,7 @@ pinos_global_destroy (PinosGlobal *global)
 | 
			
		|||
  PinosResource *registry;
 | 
			
		||||
  PinosMessageNotifyGlobalRemove ng;
 | 
			
		||||
 | 
			
		||||
  pinos_log_debug ("global %p: destroy", global);
 | 
			
		||||
  pinos_log_debug ("global %p: destroy %u", global, global->id);
 | 
			
		||||
  pinos_signal_emit (&global->destroy_signal, global);
 | 
			
		||||
 | 
			
		||||
  pinos_map_remove (&core->objects, global->id);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -892,6 +892,7 @@ pinos_link_destroy (PinosLink * this)
 | 
			
		|||
{
 | 
			
		||||
  SpaResult res = SPA_RESULT_OK;
 | 
			
		||||
  PinosLinkImpl *impl = SPA_CONTAINER_OF (this, PinosLinkImpl, this);
 | 
			
		||||
  PinosResource *resource, *tmp;
 | 
			
		||||
 | 
			
		||||
  pinos_log_debug ("link %p: destroy", impl);
 | 
			
		||||
  pinos_signal_emit (&this->destroy_signal, this);
 | 
			
		||||
| 
						 | 
				
			
			@ -899,6 +900,9 @@ pinos_link_destroy (PinosLink * this)
 | 
			
		|||
  pinos_global_destroy (this->global);
 | 
			
		||||
  spa_list_remove (&this->link);
 | 
			
		||||
 | 
			
		||||
  spa_list_for_each_safe (resource, tmp, &this->resource_list, link)
 | 
			
		||||
    pinos_resource_destroy (resource);
 | 
			
		||||
 | 
			
		||||
  if (this->input) {
 | 
			
		||||
    pinos_signal_remove (&impl->input_port_destroy);
 | 
			
		||||
    pinos_signal_remove (&impl->input_async_complete);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -630,6 +630,7 @@ pinos_node_destroy (PinosNode * this)
 | 
			
		|||
{
 | 
			
		||||
  SpaResult res;
 | 
			
		||||
  PinosNodeImpl *impl = SPA_CONTAINER_OF (this, PinosNodeImpl, this);
 | 
			
		||||
  PinosResource *resource, *tmp;
 | 
			
		||||
 | 
			
		||||
  pinos_log_debug ("node %p: destroy", impl);
 | 
			
		||||
  pinos_signal_emit (&this->destroy_signal, this);
 | 
			
		||||
| 
						 | 
				
			
			@ -637,6 +638,9 @@ pinos_node_destroy (PinosNode * this)
 | 
			
		|||
  spa_list_remove (&this->link);
 | 
			
		||||
  pinos_global_destroy (this->global);
 | 
			
		||||
 | 
			
		||||
  spa_list_for_each_safe (resource, tmp, &this->resource_list, link)
 | 
			
		||||
    pinos_resource_destroy (resource);
 | 
			
		||||
 | 
			
		||||
  res = pinos_loop_invoke (this->data_loop->loop,
 | 
			
		||||
                           do_node_remove,
 | 
			
		||||
                           impl->seq++,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -71,6 +71,15 @@ pinos_resource_destroy (PinosResource *resource)
 | 
			
		|||
  if (resource->destroy)
 | 
			
		||||
    resource->destroy (resource);
 | 
			
		||||
 | 
			
		||||
  if (resource->client->core_resource) {
 | 
			
		||||
    PinosMessageRemoveId m;
 | 
			
		||||
    m.id = resource->id;
 | 
			
		||||
    pinos_resource_send_message (resource->client->core_resource,
 | 
			
		||||
                                 PINOS_MESSAGE_REMOVE_ID,
 | 
			
		||||
                                 &m,
 | 
			
		||||
                                 true);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  pinos_main_loop_defer (resource->core->main_loop,
 | 
			
		||||
                         resource,
 | 
			
		||||
                         SPA_RESULT_WAIT_SYNC,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue