aboutsummaryrefslogtreecommitdiffstats
path: root/tools/libxc/xc_core.c
diff options
context:
space:
mode:
authorkaf24@firebug.cl.cam.ac.uk <kaf24@firebug.cl.cam.ac.uk>2006-03-14 15:33:57 +0100
committerkaf24@firebug.cl.cam.ac.uk <kaf24@firebug.cl.cam.ac.uk>2006-03-14 15:33:57 +0100
commit0c5dfaeeb43d7e4c6ffdcfb3ac6e33fe4cb458af (patch)
tree939c055a3cee143e189ec01485d646c29d96e45d /tools/libxc/xc_core.c
parent596876059cb3f7fa9e6f5f47a5755870d0f879f1 (diff)
downloadxen-0c5dfaeeb43d7e4c6ffdcfb3ac6e33fe4cb458af.tar.gz
xen-0c5dfaeeb43d7e4c6ffdcfb3ac6e33fe4cb458af.tar.bz2
xen-0c5dfaeeb43d7e4c6ffdcfb3ac6e33fe4cb458af.zip
Fix memory leak in xc_domain_dumpcore and simplify copy_from_domain_page.
Signed-off-by: Keir Fraser <keir@xensource.com>
Diffstat (limited to 'tools/libxc/xc_core.c')
-rw-r--r--tools/libxc/xc_core.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/tools/libxc/xc_core.c b/tools/libxc/xc_core.c
index b5cb742325..d5ffbb0376 100644
--- a/tools/libxc/xc_core.c
+++ b/tools/libxc/xc_core.c
@@ -12,12 +12,11 @@
static int
copy_from_domain_page(int xc_handle,
uint32_t domid,
- unsigned long *page_array,
- unsigned long src_pfn,
+ unsigned long mfn,
void *dst_page)
{
void *vaddr = xc_map_foreign_range(
- xc_handle, domid, PAGE_SIZE, PROT_READ, page_array[src_pfn]);
+ xc_handle, domid, PAGE_SIZE, PROT_READ, mfn);
if ( vaddr == NULL )
return -1;
memcpy(dst_page, vaddr, PAGE_SIZE);
@@ -32,7 +31,7 @@ xc_domain_dumpcore_via_callback(int xc_handle,
dumpcore_rtn_t dump_rtn)
{
unsigned long nr_pages;
- unsigned long *page_array;
+ unsigned long *page_array = NULL;
xc_dominfo_t info;
int i, nr_vcpus = 0;
char *dump_mem, *dump_mem_start = NULL;
@@ -79,11 +78,11 @@ xc_domain_dumpcore_via_callback(int xc_handle,
sts = dump_rtn(args, (char *)&header, sizeof(struct xc_core_header));
if ( sts != 0 )
- return sts;
+ goto error_out;
sts = dump_rtn(args, (char *)&ctxt, sizeof(ctxt[0]) * nr_vcpus);
if ( sts != 0 )
- return sts;
+ goto error_out;
if ( (page_array = malloc(nr_pages * sizeof(unsigned long))) == NULL )
{
@@ -97,17 +96,17 @@ xc_domain_dumpcore_via_callback(int xc_handle,
}
sts = dump_rtn(args, (char *)page_array, nr_pages * sizeof(unsigned long));
if ( sts != 0 )
- return sts;
+ goto error_out;
/* Pad the output data to page alignment. */
memset(dummy, 0, PAGE_SIZE);
sts = dump_rtn(args, dummy, header.xch_pages_offset - dummy_len);
if ( sts != 0 )
- return sts;
+ goto error_out;
for ( dump_mem = dump_mem_start, i = 0; i < nr_pages; i++ )
{
- copy_from_domain_page(xc_handle, domid, page_array, i, dump_mem);
+ copy_from_domain_page(xc_handle, domid, page_array[i], dump_mem);
dump_mem += PAGE_SIZE;
if ( ((i + 1) % DUMP_INCREMENT == 0) || ((i + 1) == nr_pages) )
{
@@ -119,10 +118,12 @@ xc_domain_dumpcore_via_callback(int xc_handle,
}
free(dump_mem_start);
+ free(page_array);
return 0;
error_out:
free(dump_mem_start);
+ free(page_array);
return -1;
}