summaryrefslogtreecommitdiff
path: root/plugins/neard.c
diff options
context:
space:
mode:
authorSzymon Janc <szymon.janc@tieto.com>2013-01-29 09:54:31 +0100
committerJohan Hedberg <johan.hedberg@intel.com>2013-01-29 15:57:31 -0600
commitee9c08452c5cf724b0e50158f2394510bfd3a145 (patch)
treecea2e79b752fbabef03b9c11056a16690fb14fdb /plugins/neard.c
parente5b216061bdd60adc95431e593bb4c36f99beda8 (diff)
downloadbluez-ee9c08452c5cf724b0e50158f2394510bfd3a145.tar.gz
neard: Fix memory leak on registering as agent
Message reference was not dropped in register_agent. This fix following memory leak reported by valgrind: 454 (184 direct, 270 indirect) bytes in 1 blocks are definitely lost in loss record 207 of 220 at 0x4C29DB4: calloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so) by 0x513DCF2: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514222E: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5149F46: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514A070: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514AA63: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514B0A5: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5149E0C: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5134D24: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5136088: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5135643: dbus_connection_send_with_reply_and_block (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5130C93: dbus_bus_register (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) 102 bytes in 1 blocks are indirectly lost in loss record 154 of 220 at 0x4C2B7B2: realloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so) by 0x514F02F: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514F0DD: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514F239: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514DE0A: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514E3D3: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x513C138: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x513FF4D: dbus_message_iter_append_basic (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5141790: dbus_message_new_error (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5135C70: dbus_connection_dispatch (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x40A747: message_dispatch (mainloop.c:76) by 0x4E7A91A: ??? (in /lib/x86_64-linux-gnu/libglib-2.0.so.0.3200.3) 168 bytes in 1 blocks are indirectly lost in loss record 185 of 220 at 0x4C2B7B2: realloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so) by 0x514F02F: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514F0DD: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514F239: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x513A3B3: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514228F: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5149F46: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514A070: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514AA63: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x514B0A5: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5149E0C: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8) by 0x5134D24: ??? (in /lib/x86_64-linux-gnu/libdbus-1.so.3.5.8)
Diffstat (limited to 'plugins/neard.c')
-rw-r--r--plugins/neard.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/plugins/neard.c b/plugins/neard.c
index a68500adb..b0150e975 100644
--- a/plugins/neard.c
+++ b/plugins/neard.c
@@ -121,12 +121,15 @@ static void register_agent(void)
if (!dbus_connection_send_with_reply(btd_get_dbus_connection(),
message, &call, -1)) {
+ dbus_message_unref(message);
error("D-Bus send failed");
return;
}
dbus_pending_call_set_notify(call, register_agent_cb, NULL, NULL);
dbus_pending_call_unref(call);
+
+ dbus_message_unref(message);
}
static void unregister_agent(void)