aboutsummaryrefslogtreecommitdiffstats
path: root/tools/libxl/libxl_utils.c
diff options
context:
space:
mode:
author"Gianni Tedesco (3P)" <gianni.tedesco@citrix.com>2010-08-11 13:07:21 +0100
committer"Gianni Tedesco (3P)" <gianni.tedesco@citrix.com>2010-08-11 13:07:21 +0100
commit0cd00834b5db08ff76668815b55100ff850d44bc (patch)
tree5c59866dfb68a94d70769ffad7194769e3cab4c2 /tools/libxl/libxl_utils.c
parent4791ea5fa3c2a776cb7788da91cff6be94928ec3 (diff)
downloadxen-0cd00834b5db08ff76668815b55100ff850d44bc.tar.gz
xen-0cd00834b5db08ff76668815b55100ff850d44bc.tar.bz2
xen-0cd00834b5db08ff76668815b55100ff850d44bc.zip
xl: don't use libxl allocator for nic_list
This also fixes a bug with an erroneous call to libxl_free(). A destructor for the nic list is also implemented which is called from xl. Signed-off-by: Gianni Tedesco <gianni.tedesco@citrix.com> Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Diffstat (limited to 'tools/libxl/libxl_utils.c')
-rw-r--r--tools/libxl/libxl_utils.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/tools/libxl/libxl_utils.c b/tools/libxl/libxl_utils.c
index 4ccca2f271..1042cc848c 100644
--- a/tools/libxl/libxl_utils.c
+++ b/tools/libxl/libxl_utils.c
@@ -368,14 +368,14 @@ int libxl_pipe(libxl_ctx *ctx, int pipes[2])
int libxl_mac_to_device_nic(libxl_ctx *ctx, uint32_t domid,
const char *mac, libxl_device_nic *nic)
{
- libxl_nicinfo *nics;
- unsigned int nb, i;
+ libxl_nicinfo *nics, *list;
+ unsigned int nb, i, j;
uint8_t mac_n[6];
uint8_t *a, *b;
const char *tok;
char *endptr;
- nics = libxl_list_nics(ctx, domid, &nb);
+ list = nics = libxl_list_nics(ctx, domid, &nb);
if (!nics) {
return ERROR_FAIL;
}
@@ -387,7 +387,7 @@ int libxl_mac_to_device_nic(libxl_ctx *ctx, uint32_t domid,
}
}
memset(nic, 0, sizeof (libxl_device_nic));
- for (; nb; --nb, ++nics) {
+ for (j = 0; j < nb; ++j, ++nics) {
for (i = 0, a = nics->mac, b = mac_n;
(b < mac_n + 6) && (*a == *b); ++a, ++b)
;
@@ -397,12 +397,12 @@ int libxl_mac_to_device_nic(libxl_ctx *ctx, uint32_t domid,
nic->devid = nics->devid;
memcpy(nic->mac, nics->mac, sizeof (nic->mac));
nic->script = nics->script;
- libxl_free(ctx, nics);
+ libxl_free_nics_list(list, nb);
return 0;
}
}
- libxl_free(ctx, nics);
+ libxl_free_nics_list(list, nb);
return 0;
}
@@ -422,6 +422,9 @@ int libxl_devid_to_device_nic(libxl_ctx *ctx, uint32_t domid,
nic_path_be = libxl_xs_read(ctx, XBT_NULL,
libxl_sprintf(ctx, "%s/backend", nic_path_fe));
val = libxl_xs_read(ctx, XBT_NULL, libxl_sprintf(ctx, "%s/backend-id", nic_path_fe));
+ if ( NULL == val ) {
+ return ERROR_FAIL;
+ }
nic->backend_domid = strtoul(val, NULL, 10);
nic->devid = strtoul(devid, NULL, 10);
libxl_free(ctx, val);