summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMilan Crha <mcrha@redhat.com>2016-05-27 07:30:00 +0000
committerMatthias Clasen <mclasen@redhat.com>2016-08-17 12:07:39 -0400
commit9f4a567da755ea726f20a970ef7081fd8e297a71 (patch)
tree5c9612069a47a040650870ff67c29559c3254c1e
parent077a7a482109a9f7166ab00c9ff58e8e39a370a6 (diff)
downloadglib-9f4a567da755ea726f20a970ef7081fd8e297a71.tar.gz
Fix memory leaks in GNetworkMonitorNetlink
As claimed by valgrind in a downstream bug report: https://bugzilla.redhat.com/show_bug.cgi?id=1317369 https://bugzilla.gnome.org/show_bug.cgi?id=766933
-rw-r--r--gio/gnetworkmonitornetlink.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/gio/gnetworkmonitornetlink.c b/gio/gnetworkmonitornetlink.c
index b9ff01101..776628bbe 100644
--- a/gio/gnetworkmonitornetlink.c
+++ b/gio/gnetworkmonitornetlink.c
@@ -295,7 +295,7 @@ read_netlink_messages (GSocket *socket,
gssize len;
gint flags;
GError *error = NULL;
- GSocketAddress *addr;
+ GSocketAddress *addr = NULL;
struct nlmsghdr *msg;
struct rtmsg *rtmsg;
struct rtattr *attr;
@@ -326,6 +326,7 @@ read_netlink_messages (GSocket *socket,
if (len < 0)
{
g_warning ("Error on netlink socket: %s", error->message);
+ g_clear_object (&addr);
g_error_free (error);
if (nl->priv->dump_networks)
finish_dump (nl);
@@ -335,6 +336,7 @@ read_netlink_messages (GSocket *socket,
if (!g_socket_address_to_native (addr, &source_sockaddr, sizeof (source_sockaddr), &error))
{
g_warning ("Error on netlink socket: %s", error->message);
+ g_clear_object (&addr);
g_error_free (error);
if (nl->priv->dump_networks)
finish_dump (nl);
@@ -425,6 +427,7 @@ read_netlink_messages (GSocket *socket,
done:
g_free (iv.buffer);
+ g_clear_object (&addr);
if (!retval && nl->priv->dump_networks)
finish_dump (nl);