|
|
42fe6e |
From c06ce2520886d42e3489c6a4abf5735e6bb080b9 Mon Sep 17 00:00:00 2001
|
|
|
42fe6e |
From: Debarshi Ray <debarshir@freedesktop.org>
|
|
|
42fe6e |
Date: Mon, 19 Jan 2015 19:24:05 +0100
|
|
|
42fe6e |
Subject: [PATCH] [Connector] Don't crash when trying to unwatch non-existent
|
|
|
42fe6e |
client
|
|
|
42fe6e |
|
|
|
42fe6e |
$ gdbus call \
|
|
|
42fe6e |
--session \
|
|
|
42fe6e |
--dest com.intel.dleyna-renderer \
|
|
|
42fe6e |
--object-path /com/intel/dLeynaRenderer \
|
|
|
42fe6e |
--method com.intel.dLeynaRenderer.Manager.Release
|
|
|
42fe6e |
|
|
|
42fe6e |
If a service is spawned as a result of the above command, then it will
|
|
|
42fe6e |
lead to a crash with this backtrace:
|
|
|
42fe6e |
|
|
|
42fe6e |
(client_name=0x7f7c94009750 ":1.603") at src/connector-dbus.c:271
|
|
|
42fe6e |
(conn=<optimized out>, sender=0x7f7c94009750 ":1.603",
|
|
|
42fe6e |
object=<optimized out>, interface=<optimized out>,
|
|
|
42fe6e |
method=<optimized out>, parameters=<optimized out>,
|
|
|
42fe6e |
invocation=0x2360e00) at server.c:780
|
|
|
42fe6e |
at gdbusconnection.c:4884
|
|
|
42fe6e |
at gmain.c:3111
|
|
|
42fe6e |
(context=context@entry=0x2342ea0) at gmain.c:3710
|
|
|
42fe6e |
block=block@entry=1, dispatch=dispatch@entry=1,
|
|
|
42fe6e |
self=<optimized out>) at gmain.c:3781
|
|
|
42fe6e |
at gmain.c:3975
|
|
|
42fe6e |
(server=<optimized out>, control_point=<optimized out>,
|
|
|
42fe6e |
user_data=0x0) at libdleyna/core/main-loop.c:155
|
|
|
42fe6e |
argv=<optimized out>) at daemon.c:93
|
|
|
42fe6e |
|
|
|
42fe6e |
This is because g_hash_table_lookup returns NULL which we try to
|
|
|
42fe6e |
dereference to get the client_id.
|
|
|
42fe6e |
|
|
|
42fe6e |
Instead of our hand-spun solution for storing unsigned integers in a
|
|
|
42fe6e |
GHashTable, let's use standard GLib mechanisms for doing that. We
|
|
|
42fe6e |
avoid this problem and reduce a g_new/g_free pair as a bonus.
|
|
|
42fe6e |
---
|
|
|
42fe6e |
src/connector-dbus.c | 11 ++++-------
|
|
|
42fe6e |
1 file changed, 4 insertions(+), 7 deletions(-)
|
|
|
42fe6e |
|
|
|
42fe6e |
diff --git a/src/connector-dbus.c b/src/connector-dbus.c
|
|
|
42fe6e |
index 0e16239..83774c0 100644
|
|
|
42fe6e |
--- a/src/connector-dbus.c
|
|
|
42fe6e |
+++ b/src/connector-dbus.c
|
|
|
42fe6e |
@@ -173,7 +173,7 @@ static gboolean prv_connector_initialize(const gchar *server_info,
|
|
|
42fe6e |
g_context.objects = g_hash_table_new_full(g_direct_hash, g_direct_equal,
|
|
|
42fe6e |
g_free, prv_free_dbus_object);
|
|
|
42fe6e |
g_context.clients = g_hash_table_new_full(g_str_hash, g_str_equal,
|
|
|
42fe6e |
- g_free, g_free);
|
|
|
42fe6e |
+ g_free, NULL);
|
|
|
42fe6e |
|
|
|
42fe6e |
g_context.root_node_info = g_dbus_node_info_new_for_xml(root_info,
|
|
|
42fe6e |
NULL);
|
|
|
42fe6e |
@@ -268,8 +268,8 @@ static void prv_connector_unwatch_client(const gchar *client_name)
|
|
|
42fe6e |
|
|
|
42fe6e |
DLEYNA_LOG_DEBUG("Enter");
|
|
|
42fe6e |
|
|
|
42fe6e |
- client_id = *(guint *)g_hash_table_lookup(g_context.clients,
|
|
|
42fe6e |
- client_name);
|
|
|
42fe6e |
+ client_id = GPOINTER_TO_UINT(g_hash_table_lookup(g_context.clients,
|
|
|
42fe6e |
+ client_name));
|
|
|
42fe6e |
(void) g_hash_table_remove(g_context.clients, client_name);
|
|
|
42fe6e |
|
|
|
42fe6e |
g_bus_unwatch_name(client_id);
|
|
|
42fe6e |
@@ -287,7 +287,6 @@ static void prv_lost_client(GDBusConnection *connection, const gchar *name,
|
|
|
42fe6e |
static gboolean prv_connector_watch_client(const gchar *client_name)
|
|
|
42fe6e |
{
|
|
|
42fe6e |
guint watch_id;
|
|
|
42fe6e |
- guint *client_id;
|
|
|
42fe6e |
gboolean added = TRUE;
|
|
|
42fe6e |
|
|
|
42fe6e |
DLEYNA_LOG_DEBUG("Enter");
|
|
|
42fe6e |
@@ -301,10 +300,8 @@ static gboolean prv_connector_watch_client(const gchar *client_name)
|
|
|
42fe6e |
G_BUS_NAME_WATCHER_FLAGS_NONE,
|
|
|
42fe6e |
NULL, prv_lost_client, NULL,
|
|
|
42fe6e |
NULL);
|
|
|
42fe6e |
- client_id = g_new(guint, 1);
|
|
|
42fe6e |
- *client_id = watch_id;
|
|
|
42fe6e |
g_hash_table_insert(g_context.clients, g_strdup(client_name),
|
|
|
42fe6e |
- client_id);
|
|
|
42fe6e |
+ GUINT_TO_POINTER(watch_id));
|
|
|
42fe6e |
|
|
|
42fe6e |
out:
|
|
|
42fe6e |
DLEYNA_LOG_DEBUG("Exit");
|
|
|
42fe6e |
--
|
|
|
42fe6e |
2.1.0
|
|
|
42fe6e |
|