[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen-unstable] libxc: convert mca interface over to hypercall buffers
# HG changeset patch # User Ian Campbell <ian.campbell@xxxxxxxxxx> # Date 1287756891 -3600 # Node ID 480197ff0be2c9df3bff187e9aba35d3f8d95789 # Parent 001e48a6f088cf023a0d8dc7d604c49264189019 libxc: convert mca interface over to hypercall buffers Signed-off-by: Ian Campbell <ian.campbell@xxxxxxxxxx> Signed-off-by: Ian Jackson <ian.jackson.citrix.com> --- tools/libxc/xc_misc.c | 17 +++++++++-------- 1 files changed, 9 insertions(+), 8 deletions(-) diff -r 001e48a6f088 -r 480197ff0be2 tools/libxc/xc_misc.c --- a/tools/libxc/xc_misc.c Fri Oct 22 15:14:51 2010 +0100 +++ b/tools/libxc/xc_misc.c Fri Oct 22 15:14:51 2010 +0100 @@ -167,18 +167,19 @@ int xc_mca_op(xc_interface *xch, struct { int ret = 0; DECLARE_HYPERCALL; - + DECLARE_HYPERCALL_BOUNCE(mc, sizeof(*mc), XC_HYPERCALL_BUFFER_BOUNCE_BOTH); + + if ( xc_hypercall_bounce_pre(xch, mc) ) + { + PERROR("Could not bounce xen_mc memory buffer"); + return -1; + } mc->interface_version = XEN_MCA_INTERFACE_VERSION; - if ( lock_pages(xch, mc, sizeof(*mc)) ) - { - PERROR("Could not lock xen_mc memory"); - return -EINVAL; - } hypercall.op = __HYPERVISOR_mca; - hypercall.arg[0] = (unsigned long)mc; + hypercall.arg[0] = HYPERCALL_BUFFER_AS_ARG(mc); ret = do_xen_hypercall(xch, &hypercall); - unlock_pages(xch, mc, sizeof(*mc)); + xc_hypercall_bounce_post(xch, mc); return ret; } #endif _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |