mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-12-19 08:57:14 -05:00
jack: stop data thread when closing client
Make sure we deactivate and stop the data thread when closing a client or we might get segfaults.
This commit is contained in:
parent
940aba8623
commit
ae51b0acf1
1 changed files with 10 additions and 8 deletions
|
|
@ -2121,13 +2121,13 @@ jack_client_t * jack_client_open (const char *client_name,
|
||||||
client->pool = pw_core_get_mempool(client->core);
|
client->pool = pw_core_get_mempool(client->core);
|
||||||
|
|
||||||
pw_core_add_listener(client->core,
|
pw_core_add_listener(client->core,
|
||||||
&client->core_listener,
|
&client->core_listener,
|
||||||
&core_events, client);
|
&core_events, client);
|
||||||
client->registry = pw_core_get_registry(client->core,
|
client->registry = pw_core_get_registry(client->core,
|
||||||
PW_VERSION_REGISTRY, 0);
|
PW_VERSION_REGISTRY, 0);
|
||||||
pw_registry_add_listener(client->registry,
|
pw_registry_add_listener(client->registry,
|
||||||
&client->registry_listener,
|
&client->registry_listener,
|
||||||
®istry_events, client);
|
®istry_events, client);
|
||||||
|
|
||||||
props = SPA_DICT_INIT(items, 0);
|
props = SPA_DICT_INIT(items, 0);
|
||||||
items[props.n_items++] = SPA_DICT_ITEM_INIT(PW_KEY_NODE_NAME, client_name);
|
items[props.n_items++] = SPA_DICT_ITEM_INIT(PW_KEY_NODE_NAME, client_name);
|
||||||
|
|
@ -2209,21 +2209,23 @@ SPA_EXPORT
|
||||||
int jack_client_close (jack_client_t *client)
|
int jack_client_close (jack_client_t *client)
|
||||||
{
|
{
|
||||||
struct client *c = (struct client *) client;
|
struct client *c = (struct client *) client;
|
||||||
|
int res;
|
||||||
|
|
||||||
pw_log_debug(NAME" %p: close", client);
|
pw_log_debug(NAME" %p: close", client);
|
||||||
|
|
||||||
do_sync(c);
|
c->destroyed = true;
|
||||||
|
|
||||||
|
res = jack_deactivate(client);
|
||||||
|
|
||||||
pw_thread_loop_stop(c->context.loop);
|
pw_thread_loop_stop(c->context.loop);
|
||||||
|
|
||||||
c->destroyed = true;
|
|
||||||
pw_context_destroy(c->context.context);
|
pw_context_destroy(c->context.context);
|
||||||
pw_thread_loop_destroy(c->context.loop);
|
pw_thread_loop_destroy(c->context.loop);
|
||||||
|
|
||||||
pw_log_debug(NAME" %p: free", client);
|
pw_log_debug(NAME" %p: free", client);
|
||||||
free(c);
|
free(c);
|
||||||
|
|
||||||
return 0;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
SPA_EXPORT
|
SPA_EXPORT
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue