qemu-ga: Plug leaks on qmp_guest_network_get_interfaces() error paths
Spotted by Coverity. Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Luiz Capitulino <lcapitulino@redhat.com> Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
This commit is contained in:
parent
6f6867493c
commit
10a2158f52
@ -935,9 +935,11 @@ GuestNetworkInterfaceList *qmp_guest_network_get_interfaces(Error **errp)
|
|||||||
error_setg_errno(errp, errno,
|
error_setg_errno(errp, errno,
|
||||||
"failed to get MAC address of %s",
|
"failed to get MAC address of %s",
|
||||||
ifa->ifa_name);
|
ifa->ifa_name);
|
||||||
|
close(sock);
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
close(sock);
|
||||||
mac_addr = (unsigned char *) &ifr.ifr_hwaddr.sa_data;
|
mac_addr = (unsigned char *) &ifr.ifr_hwaddr.sa_data;
|
||||||
|
|
||||||
info->value->hardware_address =
|
info->value->hardware_address =
|
||||||
@ -947,20 +949,19 @@ GuestNetworkInterfaceList *qmp_guest_network_get_interfaces(Error **errp)
|
|||||||
(int) mac_addr[4], (int) mac_addr[5]);
|
(int) mac_addr[4], (int) mac_addr[5]);
|
||||||
|
|
||||||
info->value->has_hardware_address = true;
|
info->value->has_hardware_address = true;
|
||||||
close(sock);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ifa->ifa_addr &&
|
if (ifa->ifa_addr &&
|
||||||
ifa->ifa_addr->sa_family == AF_INET) {
|
ifa->ifa_addr->sa_family == AF_INET) {
|
||||||
/* interface with IPv4 address */
|
/* interface with IPv4 address */
|
||||||
address_item = g_malloc0(sizeof(*address_item));
|
|
||||||
address_item->value = g_malloc0(sizeof(*address_item->value));
|
|
||||||
p = &((struct sockaddr_in *)ifa->ifa_addr)->sin_addr;
|
p = &((struct sockaddr_in *)ifa->ifa_addr)->sin_addr;
|
||||||
if (!inet_ntop(AF_INET, p, addr4, sizeof(addr4))) {
|
if (!inet_ntop(AF_INET, p, addr4, sizeof(addr4))) {
|
||||||
error_setg_errno(errp, errno, "inet_ntop failed");
|
error_setg_errno(errp, errno, "inet_ntop failed");
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
address_item = g_malloc0(sizeof(*address_item));
|
||||||
|
address_item->value = g_malloc0(sizeof(*address_item->value));
|
||||||
address_item->value->ip_address = g_strdup(addr4);
|
address_item->value->ip_address = g_strdup(addr4);
|
||||||
address_item->value->ip_address_type = GUEST_IP_ADDRESS_TYPE_IPV4;
|
address_item->value->ip_address_type = GUEST_IP_ADDRESS_TYPE_IPV4;
|
||||||
|
|
||||||
@ -973,14 +974,14 @@ GuestNetworkInterfaceList *qmp_guest_network_get_interfaces(Error **errp)
|
|||||||
} else if (ifa->ifa_addr &&
|
} else if (ifa->ifa_addr &&
|
||||||
ifa->ifa_addr->sa_family == AF_INET6) {
|
ifa->ifa_addr->sa_family == AF_INET6) {
|
||||||
/* interface with IPv6 address */
|
/* interface with IPv6 address */
|
||||||
address_item = g_malloc0(sizeof(*address_item));
|
|
||||||
address_item->value = g_malloc0(sizeof(*address_item->value));
|
|
||||||
p = &((struct sockaddr_in6 *)ifa->ifa_addr)->sin6_addr;
|
p = &((struct sockaddr_in6 *)ifa->ifa_addr)->sin6_addr;
|
||||||
if (!inet_ntop(AF_INET6, p, addr6, sizeof(addr6))) {
|
if (!inet_ntop(AF_INET6, p, addr6, sizeof(addr6))) {
|
||||||
error_setg_errno(errp, errno, "inet_ntop failed");
|
error_setg_errno(errp, errno, "inet_ntop failed");
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
address_item = g_malloc0(sizeof(*address_item));
|
||||||
|
address_item->value = g_malloc0(sizeof(*address_item->value));
|
||||||
address_item->value->ip_address = g_strdup(addr6);
|
address_item->value->ip_address = g_strdup(addr6);
|
||||||
address_item->value->ip_address_type = GUEST_IP_ADDRESS_TYPE_IPV6;
|
address_item->value->ip_address_type = GUEST_IP_ADDRESS_TYPE_IPV6;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user