[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH 8 of 9] xenpaging: move page_buffer into struct xenpaging
# HG changeset patch # User Olaf Hering <olaf@xxxxxxxxx> # Date 1329769124 -3600 # Node ID bb3de3bbdff3ea9da31f421053cae65999d15c89 # Parent c137d7bd207b7b21d69bd6470be285023a4c2baf xenpaging: move page_buffer into struct xenpaging Signed-off-by: Olaf Hering <olaf@xxxxxxxxx> diff -r c137d7bd207b -r bb3de3bbdff3 tools/xenpaging/xenpaging.c --- a/tools/xenpaging/xenpaging.c +++ b/tools/xenpaging/xenpaging.c @@ -44,7 +44,6 @@ static char *dom_path; static char watch_token[16]; static char *filename; static int interrupted; -static void *paging_buffer = NULL; static void unlink_pagefile(void) { @@ -441,8 +440,8 @@ static struct xenpaging *xenpaging_init( goto err; } - paging_buffer = init_page(); - if ( !paging_buffer ) + paging->paging_buffer = init_page(); + if ( !paging->paging_buffer ) { PERROR("Creating page aligned load buffer"); goto err; @@ -465,6 +464,11 @@ static struct xenpaging *xenpaging_init( xs_close(paging->xs_handle); if ( xch ) xc_interface_close(xch); + if ( paging->paging_buffer ) + { + munlock(paging->paging_buffer, PAGE_SIZE); + free(paging->paging_buffer); + } if ( paging->mem_event.shared_page ) { munlock(paging->mem_event.shared_page, PAGE_SIZE); @@ -687,7 +691,7 @@ static int xenpaging_populate_page(struc DPRINTF("populate_page < gfn %lx pageslot %d\n", gfn, i); /* Read page */ - ret = read_page(paging->fd, paging_buffer, i); + ret = read_page(paging->fd, paging->paging_buffer, i); if ( ret != 0 ) { PERROR("Error reading page"); @@ -697,8 +701,7 @@ static int xenpaging_populate_page(struc do { /* Tell Xen to allocate a page for the domain */ - ret = xc_mem_paging_load(xch, paging->mem_event.domain_id, gfn, - paging_buffer); + ret = xc_mem_paging_load(xch, paging->mem_event.domain_id, gfn, paging->paging_buffer); if ( ret < 0 ) { if ( errno == ENOMEM ) diff -r c137d7bd207b -r bb3de3bbdff3 tools/xenpaging/xenpaging.h --- a/tools/xenpaging/xenpaging.h +++ b/tools/xenpaging/xenpaging.h @@ -49,6 +49,8 @@ struct xenpaging { unsigned long *slot_to_gfn; int *gfn_to_slot; + void *paging_buffer; + struct mem_event mem_event; int fd; /* number of pages for which data structures were allocated */ _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xensource.com/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |