Hi Vinicius, On Wed, Feb 17, 2010 at 2:34 AM, Vinicius Gomes <vinicius.gomes@xxxxxxxxxxxxx> wrote: > Hi Luiz, > > On Tue, Feb 16, 2010 at 12:58 PM, Luiz Augusto von Dentz > <luiz.dentz@xxxxxxxxx> wrote: >> Hi Marcel, >> >> On Tue, Feb 16, 2010 at 5:37 PM, Marcel Holtmann <marcel@xxxxxxxxxxxx> wrote: >>> Hi Luiz, >>> >>>> > This should fix g_dbus_add_signal_watch when a service like org.bluez is given. >>>> >>>> >>>> Updating since the last one was broken. >>> >>> I also think that in check_service() we actually have a missing call to >>> dbus_pending_unref(). That would cause a memory leak. >> >> There is a call to dbus_pending_call_unref on check_service after >> dbus_pending_call_set_notify, which I took a look and seems correct >> but we have another problem there since we never cancel the pending >> call if the filter is unregister. Anyway there is a leak on >> service_reply where I don't call dbus_message_unref, so I will come up >> with another update soon. >> > > This is fixed on obexd, but as far as I could see it is not (yet?) > applied on the other users > of gdbus. Hmm, that why I see it, I used obexd to test this not bluetoothd as (probably) Marcel did, anyway we still need to store and cancel the pending call if we really want the watches to be truly cancelable. > And, from what I tested the greater problem is that the timeout of the > pending call would still > trigger. This would cause libdbus to terminate the application, if > libdbus was built with debug enabled, > because one assert would fail (the message is "trying to remove an > nonexistent timeout" or > something like it). The timeout still triggering is the reason we > don't see the pending call leaking. @Marcel: So before you apply this you should really apply Vinicius patch to the rest of projects: bluez, ofono, connman... -- Luiz Augusto von Dentz Computer Engineer -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html